:root{color:#18212b;background:#f3f6f9;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0}button,input,select{font:inherit}img{max-width:100%}.projects-shell{min-height:100vh;min-height:100dvh;display:grid;grid-template-rows:auto 1fr;background:radial-gradient(circle at top left,rgba(255,255,255,.92),transparent 38%),#f3f6f9}.projects-shell.is-viewer-route{display:block;background:#0b1016}.projects-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 32px}.header-right{display:flex;align-items:center;gap:16px}.header-title{font-size:28px;font-weight:700;letter-spacing:-.02em;color:#18212b}.header-brand{display:inline-flex}.header-brand img{height:32px;width:auto;display:block}.eyebrow{display:inline-block;margin-bottom:8px;color:#6a7682;font-size:12px;text-transform:uppercase}.data-warning{display:inline-block;margin-top:10px;color:#935d22;font-size:12px}.locale-switcher{flex:0 0 auto;display:inline-flex;gap:4px;padding:4px;border:1px solid #d5e0ea;border-radius:8px;background:#ffffffc7}.locale-switcher button,.back-button,.house-card,.floor-tab,.room-list-item,.viewer-hotspot,.map-marker{cursor:pointer}.locale-switcher button{min-width:56px;height:34px;border:0;border-radius:6px;background:transparent;color:#5d6773}.locale-switcher button.is-active{background:#18212b;color:#fff}.houses-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;padding:0 32px 32px}.house-card{min-width:0;overflow:hidden;border:1px solid #dbe5ee;border-radius:8px;background:#ffffffdb;color:inherit;padding:0;text-align:left;box-shadow:0 12px 30px #1018280f}.house-card-media{aspect-ratio:16 / 10;display:grid;place-items:center;overflow:hidden;background:#dfe8ef}.house-card-media img,.pano-thumb,.pano-thumb canvas{width:100%;height:100%;display:block}.house-card-body{display:grid;gap:8px;padding:14px}.house-card-body strong{font-size:18px}.house-card-body small{color:#63707b}.house-room-tags{display:flex;flex-wrap:wrap;gap:6px}.house-room-tags span{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border:1px solid #d5e0ea;border-radius:999px;color:#52606d;font-size:12px;background:#f8fafc}.viewer-page{position:relative;min-height:100vh;min-height:100dvh;background:#0b1016;overflow:hidden}.viewer-locale{background:transparent}.back-button{width:fit-content;min-height:38px;padding:0 12px;border:1px solid #d5e0ea;border-radius:8px;background:#ffffffe0;color:#18212b}.viewer-main{position:relative;width:100%;height:100vh;height:100dvh}.viewer-stage-shell{position:relative;width:100%;height:100vh;height:100dvh;min-height:100vh;min-height:100dvh;overflow:hidden;border:0;border-radius:0;background:#0b1016;box-shadow:none}.viewer-stage,.viewer-stage canvas{width:100%;height:100%;display:block}.viewer-stage{cursor:grab;touch-action:none}.viewer-stage.is-dragging{cursor:grabbing}.viewer-state{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;display:grid;place-content:center;gap:8px;justify-items:center;padding:20px;background:#0b1016d1;color:#fff;text-align:center}.viewer-state strong{font-size:18px}.viewer-state span{color:#ffffffb8;max-width:320px}.viewer-overlay{position:absolute;top:0;right:0;bottom:0;left:0;padding:12px;pointer-events:none}.viewer-controls-row{display:flex;align-items:center;justify-content:space-between;pointer-events:auto;padding:0 4px}.viewer-brand{display:inline-flex;align-items:center;background:transparent;border:0;filter:drop-shadow(0 1px 4px rgba(0,0,0,.6));margin-right:16px}.viewer-brand img{display:block;width:auto;height:30px;filter:brightness(0) invert(1)}.viewer-menu-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#00000061;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-size:18px;cursor:pointer}.viewer-floor-select{height:34px;padding:0 8px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#00000061;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-size:13px;cursor:pointer;margin-right:8px}.viewer-dropdown{margin-top:10px;padding:12px;border-radius:12px;background:#0b1016eb;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);pointer-events:auto;display:flex;flex-direction:column;gap:14px;max-height:80vh;overflow-y:auto}.viewer-dropdown-section{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.viewer-dropdown-label{width:100%;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#fff6}.viewer-dropdown-pills{display:flex;flex-wrap:wrap;gap:6px}.floor-panel{padding:0;border:0;border-radius:0;background:transparent}.floor-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.floor-tab{min-height:26px;padding:0 8px;border:1px solid rgba(255,255,255,.12);border-radius:6px;background:#1a2430;color:#d3dbe5;font-size:12px}.floor-tab.is-active{border-color:#fff3;background:#f3f6f9;color:#18212b}.viewer-locale{padding:0;border:0;border-radius:0;background:transparent}.viewer-locale button{color:#d3dbe5}.viewer-locale button.is-active{background:#f3f6f9;color:#18212b}.back-button{width:fit-content;min-height:34px;padding:0 10px;border:1px solid rgba(255,255,255,.14);border-radius:6px;background:#1a2430;color:#f3f6f9}.floor-map-wrap{position:relative;overflow:hidden;border:0;border-radius:0;background:transparent}.floor-map-wrap img{display:block;width:100%;height:auto}.floor-map-empty{min-height:140px;display:grid;place-items:center;color:#9bacbd}.marker-layer{position:absolute;top:0;right:0;bottom:0;left:0}.map-marker{position:absolute;width:12px;height:12px;padding:0;border:2px solid #fff;border-radius:999px;background:#2d6df6;transform:translate(-50%,-50%)}.map-marker.is-active{background:#cf7b27}.viewer-room-strip{display:flex;flex:1 1 auto;min-width:0;gap:6px;overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap;padding:0;border:0;border-radius:0;background:transparent;scrollbar-width:none}.viewer-room-strip::-webkit-scrollbar{display:none}.viewer-room-pill{flex:0 0 auto;min-height:28px;padding:0 10px;border:1px solid rgba(255,255,255,.14);border-radius:6px;background:#1a2430;color:#f3f6f9;font-size:12px}.viewer-room-pill.is-active{background:#f3f6f9;color:#18212b;border-color:#ffffff2e}.viewer-hotspots{display:none}.page-state{width:min(640px,calc(100% - 64px));margin:0 auto 32px;display:grid;gap:10px;justify-items:start;padding:20px}.page-state.error{color:#8f2c2c}@media (max-width: 1200px){.houses-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 960px){.projects-header{padding:14px 20px}.houses-grid{grid-template-columns:repeat(2,minmax(0,1fr));padding:0 20px 20px}.viewer-minimap{display:none}}@media (max-width: 640px){.projects-header{padding:12px 16px}.header-title{font-size:20px}.header-brand img{height:26px}.houses-grid{grid-template-columns:1fr;padding:0 16px 20px;gap:12px}.viewer-bar{height:auto;padding:6px 10px;overflow:visible}.viewer-bar-controls,.viewer-room-strip{display:none}.viewer-menu-toggle{display:flex;align-items:center;justify-content:center}.viewer-dropdown{display:flex}.viewer-minimap{display:none}.map-marker{width:20px;height:20px}}
