@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600&display=swap";:root{--bg0: #04070d;--bg1: #070f1a;--bg2: #0b1a2a;--bg-space: radial-gradient(1200px 720px at 18% 14%, rgba(24, 92, 150, .35), transparent 60%), radial-gradient(980px 640px at 78% 22%, rgba(16, 160, 180, .25), transparent 55%), radial-gradient(700px 520px at 60% 85%, rgba(18, 64, 100, .35), transparent 62%), linear-gradient(180deg, #03060b 0%, #060b14 45%, #03060c 100%);--panel-bg: linear-gradient( 155deg, rgba(18, 30, 46, .76), rgba(8, 14, 22, .62) );--panel-border: rgba(96, 214, 255, .22);--panel-border-strong: rgba(128, 236, 255, .5);--panel-glow: 0 0 22px rgba(88, 214, 255, .18);--panel-inner: rgba(120, 232, 255, .1);--panel-highlight: rgba(200, 245, 255, .08);--text: #e1f6ff;--text-muted: #88a7bf;--accent: #66dcff;--accent2: #36f2d6;--danger: #ff7c7c;--ok: #7dffb5;--shadow-soft: 0 14px 32px rgba(3, 8, 16, .55);--shadow-strong: 0 28px 70px rgba(3, 10, 22, .75);--radius-lg: 18px;--radius-md: 12px;--focus-ring: 0 0 0 2px rgba(102, 220, 255, .55);--glass-blur: 18px;--panel: var(--panel-bg);--accent-soft: rgba(88, 214, 255, .18);--muted: var(--text-muted);--shadow: var(--shadow-soft);--glow: 0 0 30px rgba(88, 214, 255, .25)}:root{font-family:Space Grotesk,Segoe UI,sans-serif;line-height:1.4;font-weight:400;color:var(--text);background-color:var(--bg0);text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:dark}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0}body{overflow:hidden;background-image:var(--bg-space)}.app-root{position:relative;display:flex;flex-direction:column;gap:16px;height:100%;width:100%;padding:16px;background:transparent;color:var(--text)}.universe-background{position:fixed;inset:0;z-index:0;pointer-events:none;background-image:var(--bg-space);overflow:hidden}.universe-background canvas{width:100%;height:100%;display:block}.universe-background:before{content:"";position:absolute;inset:-10%;background-image:radial-gradient(600px 420px at 20% 30%,rgba(64,182,255,.18),transparent 62%),radial-gradient(520px 360px at 75% 28%,rgba(46,242,200,.12),transparent 60%),radial-gradient(520px 420px at 50% 80%,rgba(58,120,200,.18),transparent 65%);filter:blur(0px);opacity:.7;animation:nebula-drift 120s ease-in-out infinite alternate;pointer-events:none}.universe-background:after{content:"";position:absolute;inset:0;background:radial-gradient(110% 90% at 50% 30%,#060c141a,#04060abf),radial-gradient(120% 100% at 50% 100%,#020408f2,#020306fa);pointer-events:none}@keyframes nebula-drift{0%{transform:translate3d(-1%,-.6%,0) scale(1)}50%{transform:translate3d(1.2%,.6%,0) scale(1.02)}to{transform:translate3d(-.4%,1%,0) scale(1.01)}}.app-shell{display:flex;flex-direction:column;height:100%;width:100%;position:relative;z-index:1}.app-shell--immersive{overflow:hidden}.app-topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:12px 18px;border-bottom:1px solid var(--panel-border);background:linear-gradient(135deg,#0a121ee0,#080e16b3);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));box-shadow:0 8px 24px #040a128c,inset 0 0 18px #58d6ff14;position:relative;z-index:100}.app-topbar:after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(90deg,rgba(88,214,255,.08) 0,rgba(88,214,255,.08) 1px,transparent 1px,transparent 36px);opacity:.35;pointer-events:none}.app-topbar>*{position:relative;z-index:1}.topbar-left{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);display:flex;align-items:center;gap:6px}.brand-accent{color:var(--accent);text-shadow:0 0 12px rgba(88,214,255,.35)}.brand-divider{color:#58d6ff66}.brand-muted{color:var(--text-muted)}.topbar-center{font-size:16px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}.topbar-right{justify-self:end;display:flex;align-items:center;gap:12px;font-size:12px}.topbar-time{padding:6px 10px;border-radius:999px;border:1px solid var(--panel-border);background:#0a121c99;box-shadow:inset 0 0 12px #58d6ff1f}.topbar-status{font-weight:600;letter-spacing:.08em;text-transform:uppercase;display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--panel-border);background:#0a121c99;box-shadow:inset 0 0 12px #58d6ff1f}.topbar-status:before{content:"";width:6px;height:6px;border-radius:999px;background:currentColor;box-shadow:0 0 10px currentColor}.topbar-status.is-reconnecting{animation:status-pulse 2.2s ease-in-out infinite}@keyframes status-pulse{0%{box-shadow:inset 0 0 10px #58d6ff1f,0 0 #ffd27a00}50%{box-shadow:inset 0 0 12px #58d6ff33,0 0 16px #ffd27a59}to{box-shadow:inset 0 0 10px #58d6ff1f,0 0 #ffd27a00}}.app-body{display:flex;flex:1;min-height:0}.app-body--immersive{position:relative;min-height:0}.app-sidebar{width:220px;display:flex;flex-direction:column;gap:8px;padding:16px 12px;background:linear-gradient(160deg,#0a121ec7,#080c149e);border-right:1px solid var(--panel-border);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));box-shadow:inset -1px 0 #58d6ff1a;overflow:auto;min-height:0}.nav-title{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:6px}.nav-divider{height:1px;background:#58d6ff2e;margin:12px 0 8px}.nav-item{border-radius:12px;border:1px solid rgba(88,214,255,.1);background:#080e16c7;color:var(--text);padding:8px 12px 8px 18px;text-align:left;font-size:13px;cursor:pointer;position:relative;transition:border-color .15s ease,background .15s ease,color .15s ease}.nav-item:before{content:"";position:absolute;left:8px;top:50%;width:3px;height:60%;border-radius:999px;background:#58d6ff99;box-shadow:0 0 12px #58d6ff66;transform:translateY(-50%);opacity:0}.nav-item:hover{border-color:#58d6ff66;box-shadow:0 0 12px #58d6ff1f}.nav-item.active{background:#58d6ff2e;border-color:#58d6ffbf;color:#e9fbff;box-shadow:0 0 18px #58d6ff33}.nav-item.active:before{opacity:1}.nav-item-subtle{background:#060a1099;color:var(--text-muted)}.app-main{flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.app-main--immersive{position:relative;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid rgba(105,226,255,.2);background:#080c12e6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.app-title{font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}.app-header-controls{display:flex;align-items:center;flex-wrap:wrap;justify-content:flex-end;gap:12px}.app-mode-switch{display:flex;gap:8px}.mode-button{border-radius:10px;border:1px solid rgba(88,214,255,.3);background:#091018bf;color:var(--text);padding:6px 12px;font-size:12px;letter-spacing:.02em;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease,color .15s ease}.mode-button.active{background:#58d6ff33;color:#e9fbff;border-color:#58d6ffcc;box-shadow:0 0 18px #58d6ff33}.app-content{flex:1;min-height:0}.page{flex:1;min-height:0;display:flex;flex-direction:column;gap:12px;padding:16px}.page--home{padding:0;position:relative}.page--full{padding:0}.page-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;border-radius:var(--radius-lg);border:1px solid var(--panel-border);background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));box-shadow:var(--shadow-soft),inset 0 0 14px #58d6ff1a}.page-title{font-size:16px;text-transform:uppercase;letter-spacing:.14em;color:var(--accent)}.page-actions{display:flex;gap:8px;flex-wrap:wrap}.page-body{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:12px}.page-body--home{overflow:hidden;padding:0}.myhome-immersive{position:relative;width:100%;height:100%;min-height:0}.myhome-stage{position:fixed;inset:0;z-index:1}.myhome-stage .home-scene{position:absolute;inset:0}.myhome-overlay{position:fixed;inset:0;z-index:3;pointer-events:none;color:var(--text)}.glass-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid rgba(88,214,255,.3);background:#060c149e;color:var(--text);font-size:11px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;pointer-events:auto;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:inset 0 0 12px #58d6ff1f;transition:transform .14s ease,opacity .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease}.glass-chip.is-active{border-color:#58d6ffbf;background:#58d6ff2e;color:#e9fbff;box-shadow:0 0 18px #58d6ff47,inset 0 0 12px #58d6ff26}.glass-chip:active{transform:scale(.96)}.glass-chip-icon{width:20px;height:20px;border-radius:8px;border:1px solid rgba(88,214,255,.45);background:#040a12b3;display:grid;place-items:center;font-size:10px;color:var(--accent);letter-spacing:.12em}.glass-panel{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:16px;padding:14px 16px;-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));box-shadow:var(--shadow-soft),inset 0 0 18px #58d6ff1f;color:var(--text);pointer-events:auto}.myhome-chip-stack{position:absolute;top:16px;display:flex;flex-direction:column;gap:10px;pointer-events:none;transition:opacity .2s ease,transform .22s ease}.myhome-chip-stack--left{left:16px;align-items:flex-start}.myhome-chip-stack--right{right:16px;align-items:flex-end}.myhome-chip-stack.is-hidden{opacity:0;transform:translateY(-6px) scale(.98);pointer-events:none}.myhome-chip-stack.is-visible{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.myhome-escape-chip{position:absolute;top:16px;left:16px;font-size:10px;letter-spacing:.16em;text-transform:uppercase;pointer-events:auto;z-index:4;box-shadow:0 12px 26px #040a1259,inset 0 0 12px #58d6ff14}.myhome-sync-indicator{position:absolute;top:16px;right:16px;z-index:4;pointer-events:auto}.myhome-bottom-dock{position:absolute;left:50%;bottom:18px;transform:translate(-50%);pointer-events:auto;display:flex;justify-content:center;z-index:4;transition:opacity .2s ease,transform .24s ease}.myhome-bottom-dock.is-hidden{opacity:0;transform:translate(-50%) translateY(12px) scale(.98);pointer-events:none}.myhome-bottom-dock.is-visible{opacity:1;transform:translate(-50%) translateY(0) scale(1)}.myhome-bottom-dock-surface{position:relative;display:flex;align-items:center;gap:14px;padding:10px 14px;border-radius:18px;border:1px solid rgba(88,214,255,.25);background:linear-gradient(180deg,#08101ac7,#050a12eb);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 20px 40px #040a1273,inset 0 0 18px #58d6ff1f}.myhome-bottom-dock-surface:before{content:"";position:absolute;inset:1px;border-radius:16px;border:1px solid rgba(255,255,255,.04);pointer-events:none}.myhome-bottom-dock-group{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.myhome-bottom-dock-divider{width:1px;height:26px;background:#58d6ff47;box-shadow:0 0 12px #58d6ff33}.myhome-dock-chip{font-size:10px;padding:7px 10px;letter-spacing:.12em;transition:transform .16s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1),border-color .2s cubic-bezier(.4,0,.2,1),background-color .2s cubic-bezier(.4,0,.2,1)}.myhome-dock-chip:hover{transform:translateY(-1px);box-shadow:0 0 16px #58d6ff2e}.myhome-dock-chip:focus-visible{outline:none;box-shadow:0 0 0 2px #58d6ff80,0 0 16px #58d6ff40;border-color:#58d6ff99}.myhome-dock-chip:active{transform:translateY(0) scale(.96)}.myhome-dock-chip .glass-chip-icon{width:18px;height:18px;border-radius:6px}.myhome-advanced{position:absolute;bottom:92px;right:16px;width:220px;display:flex;flex-direction:column;gap:10px;transition:opacity .2s ease,transform .2s ease}.myhome-advanced.is-hidden{opacity:0;transform:translateY(-8px);pointer-events:none}.myhome-advanced-title{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}.myhome-advanced-toggle{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text)}.myhome-advanced-toggle input{appearance:none;width:18px;height:18px;border-radius:5px;border:1px solid rgba(88,214,255,.5);background:#08101899;display:inline-grid;place-content:center;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.myhome-advanced-toggle input:after{content:"";width:9px;height:9px;border-radius:2px;background:#58d6ffd9;box-shadow:0 0 10px #58d6ffcc;opacity:0;transform:scale(.6);transition:opacity .15s ease,transform .15s ease}.myhome-advanced-toggle input:checked{border-color:#58d6ffe6;background:#0c202ccc}.myhome-advanced-toggle input:checked:after{opacity:1;transform:scale(1)}.myhome-device-actions{position:absolute;inset:0;pointer-events:none;transition:opacity .2s cubic-bezier(.4,0,.2,1)}.myhome-device-actions.is-hidden{opacity:0;pointer-events:none}.myhome-device-actions.is-visible{opacity:1}.myhome-device-action{position:absolute;width:30px;height:30px;border-radius:999px;border:1px solid rgba(88,214,255,.4);background:#060c14bf;box-shadow:inset 0 0 10px #58d6ff33;display:grid;place-items:center;transform:translate(-50%,-50%) scale(1);opacity:1;pointer-events:auto;transition:transform .14s ease,box-shadow .2s ease,border-color .2s ease,opacity .18s cubic-bezier(.4,0,.2,1)}.myhome-device-action.is-hidden{opacity:0;pointer-events:none;transform:translate(-50%,-50%) scale(.85)}.myhome-device-action.is-visible{opacity:1;transform:translate(-50%,-50%) scale(1)}.myhome-device-action.is-active{border-color:#58d6ffbf;box-shadow:0 0 16px #58d6ff59}.myhome-device-action:hover{transform:translate(-50%,-50%) scale(1.05)}.myhome-device-action:active{transform:translate(-50%,-50%) scale(.96)}.myhome-device-icon{font-size:11px;letter-spacing:.12em;color:var(--accent)}@keyframes device-pop{to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.myhome-device-panel{position:absolute;width:min(320px,88vw);max-height:25vh;display:flex;flex-direction:column;gap:8px;opacity:1;transition:opacity .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1)}.myhome-device-panel.is-hidden{opacity:0;pointer-events:none}.myhome-device-panel.is-visible{opacity:1;pointer-events:auto}.myhome-device-panel--right{right:16px;top:50%;transform:translateY(-50%)}.myhome-device-panel--right.is-hidden{transform:translateY(-50%) translate(12px)}.myhome-device-panel--left{left:16px;top:50%;transform:translateY(-50%)}.myhome-device-panel--left.is-hidden{transform:translateY(-50%) translate(-12px)}.myhome-device-panel--top{top:16px;left:50%;transform:translate(-50%)}.myhome-device-panel--top.is-hidden{transform:translate(-50%) translateY(-12px)}.myhome-device-panel--bottom{bottom:16px;left:50%;transform:translate(-50%)}.myhome-device-panel--bottom.is-hidden{transform:translate(-50%) translateY(12px)}.myhome-device-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.myhome-device-room{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.myhome-device-name{font-size:14px;font-weight:600;color:#e9fbff}.myhome-device-close{border:1px solid rgba(88,214,255,.3);background:#060c128c;color:var(--text-muted);font-size:10px;letter-spacing:.1em;text-transform:uppercase;border-radius:999px;padding:4px 8px;cursor:pointer}.myhome-device-value{font-size:18px;font-weight:600;color:#dff7ff}.myhome-device-metrics{display:flex;gap:12px;font-size:11px;color:var(--text-muted);flex-wrap:wrap}.myhome-device-status{display:flex;gap:8px;flex-wrap:wrap}.myhome-device-chip{padding:4px 8px;border-radius:999px;border:1px solid rgba(88,214,255,.25);background:#060c12a6;font-size:10px;letter-spacing:.08em;text-transform:uppercase}.myhome-device-chip--on{border-color:#7dffb599;color:#c8ffe3}.myhome-device-chip--off{border-color:#7dbbff99;color:#cfe6ff}.myhome-device-chip--offline{border-color:#ff7c7c80;color:#ffd4d4}.myhome-device-chip--unknown{border-color:#94a3b880;color:#d2d8e3}.myhome-controls{position:absolute;top:20px;left:20px;background:#04101ac7;border:1px solid rgba(88,214,255,.35);border-radius:14px;padding:16px 18px;min-width:200px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 16px 36px #040a1273,inset 0 0 18px #58d6ff1a;pointer-events:auto}.myhome-controls h3{margin:0 0 12px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}.myhome-toggle{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text);padding:6px 0;cursor:pointer}.myhome-toggle input{appearance:none;width:18px;height:18px;border-radius:5px;border:1px solid rgba(88,214,255,.5);background:#08101899;display:inline-grid;place-content:center;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.myhome-toggle input:after{content:"";width:9px;height:9px;border-radius:2px;background:#58d6ffd9;box-shadow:0 0 10px #58d6ffcc;opacity:0;transform:scale(.6);transition:opacity .15s ease,transform .15s ease}.myhome-toggle input:checked{border-color:#58d6ffe6;background:#0c202ccc}.myhome-toggle input:checked:after{opacity:1;transform:scale(1)}.myhome-controls .panel-button{margin-top:10px;width:100%}.myhome-filter{display:flex;gap:6px;margin-top:12px}.myhome-filter button{flex:1;border-radius:10px;border:1px solid rgba(88,214,255,.2);background:#060c1299;color:var(--text-muted);padding:6px 8px;font-size:11px;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease}.myhome-filter button.active{background:#58d6ff33;border-color:#58d6ffb3;color:#e9fbff;box-shadow:0 0 14px #58d6ff33}.myhome-status{position:absolute;top:20px;right:20px;display:flex;flex-direction:column;gap:10px;pointer-events:auto}.myhome-status-chip{padding:8px 14px;border-radius:999px;border:1px solid rgba(88,214,255,.35);background:#060c14b8;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text);box-shadow:inset 0 0 12px #58d6ff1f}.myhome-room-label{position:absolute;bottom:20px;left:20px;padding:10px 16px;border-radius:12px;border:1px solid rgba(88,214,255,.4);background:#04101ad9;text-align:left;opacity:0;transition:opacity .2s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 18px 32px #040c1273;pointer-events:none}.myhome-room-label.is-visible{opacity:1}.myhome-room-title{font-size:16px;font-weight:600;color:#d9f7ff;margin-bottom:4px}.myhome-room-subtitle{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.myhome-hint{position:absolute;bottom:24px;right:24px;padding:10px 12px;border-radius:10px;border:1px solid rgba(88,214,255,.18);background:#050c12b3;font-size:11px;color:#78dcffcc;letter-spacing:.04em;pointer-events:none}.myhome-hint div+div{margin-top:4px}.page-body--full{overflow:hidden;padding:0}.myhome-layout{display:grid;grid-template-columns:minmax(320px,36%) minmax(0,1fr);gap:16px;height:100%;padding:16px}.myhome-panel{display:flex;flex-direction:column;gap:16px;overflow:auto;padding-right:6px;padding-top:4px;min-height:0}.myhome-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.myhome-title{font-size:22px;letter-spacing:.04em;color:#eaf6ff;font-weight:600;text-shadow:0 0 18px rgba(88,214,255,.25)}.myhome-subtitle{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-top:4px}.myhome-actions{display:flex;gap:8px;align-items:center}.myhome-card{flex-shrink:0}.myhome-scene{position:relative;border-radius:var(--radius-lg);border:1px solid var(--panel-border);background:#060a10a6;box-shadow:var(--shadow-strong);overflow:hidden;min-height:0}.myhome-scene:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 18% 22%,rgba(88,214,255,.1),transparent 48%),radial-gradient(circle at 76% 70%,rgba(46,242,200,.06),transparent 52%),radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:100% 100%,100% 100%,120px 120px;mix-blend-mode:screen;opacity:.16;pointer-events:none;z-index:1}.myhome-scene:after{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 40%,#0c162400,#04080ca6);pointer-events:none;z-index:1}.home-scene{width:100%;height:100%;position:relative;z-index:0}.home-scene canvas{width:100%;height:100%;display:block;cursor:grab;touch-action:none;position:relative;z-index:0}.home-scene canvas:active{cursor:grabbing}.home-scene-reset{position:absolute;top:12px;right:12px;z-index:3;border-radius:999px;border:1px solid rgba(88,214,255,.45);background:#060c12b3;color:var(--text);font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:6px 10px;cursor:pointer;pointer-events:auto;box-shadow:inset 0 0 8px #58d6ff1f}.home-scene-reset:hover{background:#0a121cd9}.myhome-immersive .home-scene-reset{display:none}.home-tooltip{position:absolute;z-index:3;left:0;top:0;transform:translate(-50%,-120%);padding:8px 10px;border-radius:12px;border:1px solid rgba(88,214,255,.45);background:#060c12d9;box-shadow:0 0 16px #00c8ff2e;color:var(--text);font-size:12px;pointer-events:none;opacity:0;transition:opacity .12s ease;min-width:140px}.home-tooltip-title{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:4px}.home-tooltip-value{font-size:14px;font-weight:600;color:#eaf6ff}.home-tooltip-meta{margin-top:4px;font-size:11px;color:var(--muted)}.scene-overlay{position:absolute;top:12px;left:12px;display:flex;gap:8px;z-index:2;pointer-events:none}.scene-chip{padding:6px 10px;border-radius:999px;border:1px solid rgba(88,214,255,.45);background:#060c12a6;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text);box-shadow:inset 0 0 8px #58d6ff1f}.devices-layout{display:grid;grid-template-columns:minmax(280px,38%) minmax(0,1fr);gap:16px;min-height:0}.devices-layout--placement{grid-template-columns:minmax(320px,40%) minmax(0,1fr);height:100%;flex:1;min-height:0}.panel.device-panel{display:flex;flex-direction:column;gap:12px;min-height:0;overflow:hidden;max-height:100%}.device-panel-controls{display:flex;flex-direction:column;gap:10px}.device-panel-scroll{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:16px;padding-right:6px;margin-right:-6px}.device-section-header{display:flex;align-items:center;justify-content:space-between;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted)}.device-section-header--spaced{margin-top:6px}.device-section-count{padding:2px 8px;border-radius:999px;border:1px solid rgba(88,214,255,.3);background:#080e16b3;color:var(--accent);font-size:10px;letter-spacing:.08em}.device-section-hint{font-size:11px;color:var(--text-muted)}.device-section-error{font-size:11px;color:#ffb2b8e6}.panel-row--stack{flex-direction:column;align-items:stretch;gap:6px}.device-filters{display:flex;flex-direction:column;gap:10px}.filter-chip-row{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{border-radius:999px;border:1px solid rgba(88,214,255,.2);background:#080e16b3;color:var(--text);padding:8px 12px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;min-height:44px}.filter-chip.active{border-color:#58d6ffa6;box-shadow:0 0 12px #58d6ff33;background:#58d6ff2e;color:#e9fbff}.device-list,.device-detail,.room-detail,.rooms-list,.floor-summary{min-height:0;overflow:auto}.filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px;margin-bottom:12px}.filter-select,.filter-input{width:100%;border-radius:10px;border:1px solid rgba(88,214,255,.25);background:#070c12bf;color:var(--text);padding:8px 10px;font-size:12px}.filter-input::placeholder{color:var(--text-muted)}.filter-select:focus,.filter-input:focus{outline:none;border-color:#58d6ff99;box-shadow:var(--focus-ring)}.device-list-scroll{display:flex;flex-direction:column;gap:8px;max-height:300px;min-height:100px;overflow-y:auto;overflow-x:hidden;padding-right:4px}.device-panel-scroll .device-list-scroll{max-height:none;min-height:0;overflow:visible;padding-right:0}.myhome-panel .device-list-scroll{max-height:none;overflow:visible;padding-right:0}.device-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-auto-rows:minmax(72px,auto);gap:10px;align-content:start;padding:2px}.device-card{display:grid;grid-template-columns:36px minmax(0,1fr) auto;grid-template-rows:auto auto;gap:4px 10px;align-items:center;width:100%;padding:10px 12px;min-height:72px;border-radius:14px;border:1px solid rgba(88,214,255,.22);background:linear-gradient(135deg,#0a101ac7,#080c14ad);color:var(--text);cursor:pointer;text-align:left;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease,background .16s ease;-webkit-user-select:none;user-select:none;touch-action:pan-y;position:relative;overflow:hidden;appearance:none;font:inherit}.device-card:before{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(ellipse at 50% 0%,rgba(88,214,255,.08) 0%,transparent 70%);pointer-events:none}.device-card:hover{border-color:#58d6ff80;background:linear-gradient(135deg,#101824e6,#0a101acc);transform:translateY(-1px);box-shadow:0 8px 20px #00000047,0 0 18px #58d6ff1f}.device-card:focus-visible{outline:2px solid rgba(88,214,255,.6);outline-offset:2px}.device-card:active{cursor:pointer;transform:translateY(0);border-color:#58d6ff99;box-shadow:0 0 18px #58d6ff2e,inset 0 0 16px #58d6ff14}.device-card.dragging{cursor:grabbing;border-color:#58d6ffb3;box-shadow:0 0 24px #58d6ff40,inset 0 0 18px #58d6ff1a}.device-card.device-card--selected{border-color:#58d6ffcc;background:linear-gradient(135deg,#101a26e6,#0a101ad1);box-shadow:0 0 20px #58d6ff38,inset 0 0 16px #58d6ff1f}.device-card-icon{grid-row:1 / span 2;width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;line-height:1;border:1px solid rgba(88,214,255,.35);background:#080e16bf;color:#bfefff;box-shadow:inset 0 0 10px #58d6ff14}.device-card-icon--temperature{border-color:#7dffb566;color:#baffd8}.device-card-icon--door{border-color:#ffc87880;color:#ffd9a6}.device-card-icon--motion{border-color:#ff9aa280;color:#ffd0d4}.device-card-icon--light{border-color:#58d6ff99;color:#bfefff}.device-card-icon--switch{border-color:#91a7ff8c;color:#d0ddff}.device-card-icon--other{border-color:#94a3b859;color:#cbd5e1}.device-card-name{grid-column:2;grid-row:1;font-size:13px;font-weight:600;color:#eaf6ff;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-card-subtitle{grid-column:2;grid-row:2;font-size:10px;color:var(--text-muted);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-card-status{grid-column:3;grid-row:1;justify-self:end;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:2px 8px;border-radius:10px;background:#58d6ff26;color:#58d6ffe6;white-space:nowrap}.device-card-meta{grid-column:3;grid-row:2;justify-self:end;display:inline-flex;align-items:center;gap:6px;font-size:10px;color:var(--text-muted);max-width:180px}.device-card-meta-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:110px}.device-card-handle{padding:2px 6px;border-radius:999px;border:1px dashed rgba(88,214,255,.4);background:#080e16b3;color:#8ba6bacc;font-size:9px;letter-spacing:.08em;text-transform:uppercase;cursor:grab}.device-card-handle:active{cursor:grabbing}.device-card:hover .device-card-handle{border-color:#58d6ffb3;color:#bfefff}.device-card-status--on{background:#2ecc7133;color:#2ecc71}.device-card-status--off{background:#95a5a633;color:#95a5a6}.device-card-status--offline{background:#e74c3c33;color:#e74c3c}.device-card-status--unknown{background:#f1c40f33;color:#f1c40f}@media(max-width:600px){.device-card-grid{grid-template-columns:1fr;gap:8px}.device-card{grid-template-columns:32px minmax(0,1fr) auto;padding:10px}.device-card-icon{width:30px;height:30px;font-size:12px}.device-card-name{font-size:12px}}.device-row{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:8px 12px;border-radius:var(--radius-md);border:1px solid rgba(88,214,255,.18);background:linear-gradient(135deg,#0a101ab8,#080c1499);color:var(--text);cursor:pointer;text-align:left;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease,background .15s ease;min-height:44px}.device-row:hover{border-color:#58d6ff73;box-shadow:0 0 16px #58d6ff24;transform:translateY(-1px)}.device-chip-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.device-chip{padding:2px 8px;border-radius:999px;border:1px solid rgba(88,214,255,.2);background:#060c1299;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text)}.device-chip--on{border-color:#7dffb599;color:#baffd8;box-shadow:inset 0 0 8px #7dffb533}.device-chip--off{border-color:#94a3b866;color:#cbd5e1}.device-chip--offline{border-color:#ff9aa299;color:#ffd0d4}.device-chip--unknown{border-color:#ffd16699;color:#ffe9b3}.device-chip--idle{border-color:#64748b80;color:#cbd5e1}.device-chip--domain{border-color:#58d6ff73;color:#bfefff}.device-row.active{border-color:#58d6ffb3;background:linear-gradient(135deg,#121c2abf,#080e16a6);box-shadow:0 0 0 1px #58d6ff2e,0 0 18px #58d6ff1f;transform:translateY(-1px)}.device-row--static{cursor:default}.device-row--static:hover{transform:none;box-shadow:none}.device-row-title{display:flex;align-items:center;gap:8px}.device-type-icon{width:28px;height:28px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;letter-spacing:.08em;color:#d7f5ff;border:1px solid rgba(88,214,255,.35);background:#080e16b3;flex-shrink:0}.device-type-icon--temperature{border-color:#7dffb566;color:#baffd8}.device-type-icon--door{border-color:#ffc87880;color:#ffd9a6}.device-type-icon--motion{border-color:#ff9aa280;color:#ffd0d4}.device-type-icon--light{border-color:#58d6ff99;color:#bfefff}.device-type-icon--switch{border-color:#91a7ff8c;color:#d0ddff}.device-type-icon--other{border-color:#94a3b859;color:#cbd5e1}.device-row-actions{display:flex;gap:8px;align-items:center}.panel-button-compact{padding:8px 12px;font-size:11px;min-height:44px}.drag-handle{display:inline-flex;align-items:center;gap:6px;border-radius:999px;border:1px dashed rgba(88,214,255,.4);background:#080e1699;color:var(--text);padding:8px 12px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;cursor:grab;min-height:44px}.drag-handle.active{border-color:#58d6ffcc;box-shadow:0 0 12px #58d6ff59}.drag-handle:active{cursor:grabbing}.drag-grip{width:12px;height:12px;display:inline-block;background-image:radial-gradient(currentColor 1px,transparent 1px);background-size:4px 4px;opacity:.7}.device-sync-row{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.device-scene{position:relative;border-radius:var(--radius-lg);border:1px solid var(--panel-border);background:#060a10a6;box-shadow:var(--shadow-strong);overflow:hidden;min-height:0}.device-scene:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 18% 22%,rgba(88,214,255,.1),transparent 48%),radial-gradient(circle at 76% 70%,rgba(46,242,200,.06),transparent 52%),radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:100% 100%,100% 100%,120px 120px;mix-blend-mode:screen;opacity:.16;pointer-events:none;z-index:1}.device-scene:after{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 40%,#0c162400,#04080ca6);pointer-events:none;z-index:1}.scene-placement-hint,.scene-placement-error{position:absolute;z-index:3;left:16px;bottom:16px;padding:10px 12px;border-radius:12px;border:1px solid rgba(88,214,255,.45);background:#060c12d9;color:var(--text);box-shadow:0 0 16px #00c8ff2e;display:flex;align-items:center;gap:10px}.scene-placement-error{border-color:#ff9aa28c;color:#ffd0d4}.scene-placement-text{font-size:12px;color:#eaf6ff}.scene-selection-hint{position:absolute;z-index:3;left:16px;top:56px;padding:6px 10px;border-radius:10px;border:1px solid rgba(88,214,255,.35);background:#060c12c7;color:#d7f5ff;font-size:11px;letter-spacing:.02em;max-width:320px;pointer-events:none}.device-quick-menu{position:absolute;z-index:4;transform:translate(-50%,-110%);border-radius:10px;border:1px solid rgba(88,214,255,.4);background:#080c12eb;box-shadow:0 0 18px #58d6ff33;display:flex;flex-direction:column;min-width:140px;overflow:hidden}.device-quick-menu button{border:none;background:transparent;color:var(--text);padding:10px 12px;text-align:left;cursor:pointer;font-size:12px;min-height:44px}.device-quick-menu button:hover{background:#58d6ff1f}.device-quick-menu button.danger{color:#ff9aa2}.device-settings-panel{position:absolute;right:16px;top:16px;bottom:16px;width:min(360px,90%);border-radius:16px;border:1px solid rgba(88,214,255,.35);background:#080c12eb;padding:16px;display:flex;flex-direction:column;gap:10px;overflow:auto;z-index:3;box-shadow:0 0 18px #58d6ff2e}.device-selection-panel{position:absolute;right:16px;top:16px;width:min(320px,85%);border-radius:14px;border:1px solid rgba(88,214,255,.35);background:#080c12e6;padding:14px;display:flex;flex-direction:column;gap:8px;z-index:3;box-shadow:0 0 16px #58d6ff29}.device-selection-panel--embedded{position:static;width:100%;box-shadow:none;margin-bottom:8px}.device-selection-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.device-selection-actions{display:flex;gap:10px;flex-wrap:wrap}.device-diagnostics{position:absolute;right:16px;bottom:16px;z-index:4;padding:8px 10px;border-radius:10px;border:1px solid rgba(88,214,255,.25);background:#060c12d1;color:#baf6ff;font-size:11px;line-height:1.4;white-space:nowrap;pointer-events:none}.panel-color-row{display:flex;align-items:center;gap:10px}.panel-color-input{width:56px;height:36px;padding:0;border-radius:10px;border:1px solid rgba(88,214,255,.35);background:#060c12b3;cursor:pointer}.panel-color-input::-webkit-color-swatch-wrapper{padding:0}.panel-color-input::-webkit-color-swatch{border:none;border-radius:8px}.panel-color-input::-moz-color-swatch{border:none;border-radius:8px}.device-settings-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.advanced-panel{border-radius:12px;border:1px solid rgba(88,214,255,.2);padding:10px;background:#070b10cc;display:flex;flex-direction:column;gap:8px}.device-json{margin:0;padding:8px;border-radius:10px;border:1px solid rgba(88,214,255,.18);background:#060a10d9;color:#bfefff;font-size:11px;white-space:pre-wrap;word-break:break-word}.device-row--unassigned{border-style:dashed;border-color:#58d6ff40}.device-row--holo{position:relative;padding-left:36px}.device-row--holo:before{content:"";position:absolute;left:14px;top:50%;width:10px;height:10px;border-radius:999px;background:#58d6ffa6;box-shadow:0 0 12px #58d6ff59;transform:translateY(-50%)}.device-row--holo.active:before{background:#58d6fff2;box-shadow:0 0 16px #58d6ff8c}.device-row-static{cursor:default}.device-row-main{display:flex;flex-direction:column;gap:4px;min-width:0}.device-name{font-size:13px}.device-meta{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.device-state{font-size:12px;color:var(--accent)}.device-state-card{margin:8px 0 12px;padding:10px;border-radius:12px;border:1px solid rgba(88,214,255,.22);background:#090e16a6;display:flex;flex-direction:column;gap:8px;box-shadow:inset 0 0 10px #58d6ff14}.device-state-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.device-ha-panel{display:flex;flex-direction:column;gap:10px}.device-ha-actions,.device-ha-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.entity-list{max-height:220px;overflow:auto;border-radius:12px;border:1px solid rgba(88,214,255,.2);background:#070c12b3}.entity-row{width:100%;text-align:left;border:none;border-bottom:1px solid rgba(88,214,255,.12);padding:8px 10px;background:transparent;color:var(--text);cursor:pointer}.entity-row:hover{background:#58d6ff1a}.entity-name{font-size:12px}.entity-meta{font-size:11px;color:var(--muted)}.rooms-layout,.floors-layout{display:grid;grid-template-columns:minmax(320px,42%) minmax(0,1fr);gap:16px;min-height:0}.room-group{margin-bottom:12px}.room-group-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:6px}.room-group-list{display:flex;flex-direction:column;gap:6px}.room-row-button{width:100%;text-align:left;cursor:pointer}.room-row-button:hover{border-color:#58d6ff73;box-shadow:0 0 12px #58d6ff1f}.room-stat{font-size:11px;color:var(--muted)}.room-status{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:6px}.room-chip{font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:2px 6px;border-radius:999px;border:1px solid rgba(88,214,255,.25);background:#080e1699;color:var(--text)}.room-chip--active{border-color:#7dffb599;color:#baffd8}.room-chip--alert{border-color:#ff9aa299;color:#ffd0d4}.room-chip--warn{border-color:#ffd16699;color:#ffe9b3}.floor-summary{min-height:0}.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.settings-card{min-height:0}.status-pill{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.08em;padding:4px 10px;border-radius:999px;border:1px solid rgba(88,214,255,.3);background:#080e16b3;box-shadow:inset 0 0 10px #58d6ff1f}.status-pill:before{content:"";width:6px;height:6px;border-radius:999px;background:currentColor;box-shadow:0 0 10px currentColor}.status-pill.is-reconnecting{animation:status-pulse 2.2s ease-in-out infinite}.toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;padding:12px 14px;border-radius:var(--radius-lg);border:1px solid var(--panel-border);background:var(--panel-bg);box-shadow:var(--shadow-soft),inset 0 0 12px #58d6ff14;position:relative;overflow:hidden}.toolbar:after{content:"";position:absolute;inset:0;background:radial-gradient(600px 120px at 20% 0%,rgba(88,214,255,.14),transparent 70%);pointer-events:none}.toolbar-group{display:flex;flex-wrap:wrap;align-items:center;gap:8px;position:relative;z-index:1}.toolbar-range-group{display:flex;align-items:center;gap:6px}.toolbar-range{width:120px;accent-color:var(--accent)}.toolbar-range:disabled{opacity:.5}.toolbar-label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.toolbar-button,.toolbar-select{border-radius:10px;border:1px solid rgba(88,214,255,.3);background:#091018bf;color:var(--text);padding:6px 10px;font-size:12px;letter-spacing:.02em;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease,color .15s ease,transform .15s ease}.toolbar-button{cursor:pointer}.toolbar-button:hover,.toolbar-select:hover{border-color:#58d6ffb3;box-shadow:0 0 0 2px #58d6ff1f}.toolbar-button.active{background:#58d6ff33;color:#e9fbff;border-color:#58d6ffcc;box-shadow:0 0 18px #58d6ff33}.toolbar-button:disabled{opacity:.5;cursor:default}.toolbar-select{min-width:90px}.toolbar-spacer{flex:1}.layout-io{display:flex;flex-direction:column;gap:6px}.main{display:grid;grid-template-columns:minmax(320px,42%) minmax(0,1fr);gap:16px;flex:1;min-height:0}.editor-panel{display:flex;flex-direction:column;gap:12px;min-width:0;min-height:0;overflow:auto;padding-right:6px}.preview-panel{border-radius:18px;border:1px solid var(--panel-border);background:#060a10a6;box-shadow:var(--shadow-strong);overflow:hidden;position:relative}.scene-panel{border-radius:var(--radius-lg);border:1px solid var(--panel-border);background:#060a10a6;box-shadow:var(--shadow-strong);overflow:hidden;position:relative}.preview-panel:before,.scene-panel:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 20%,rgba(88,214,255,.08),transparent 48%),radial-gradient(circle at 78% 78%,rgba(46,242,200,.05),transparent 50%),radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:100% 100%,100% 100%,140px 140px;mix-blend-mode:screen;opacity:.18;pointer-events:none;z-index:1}.editor-canvas-wrapper{position:relative;flex:1;min-height:360px;border-radius:18px;border:1px solid rgba(105,226,255,.18);background:radial-gradient(500px 280px at 20% 20%,rgba(105,226,255,.08),transparent 60%),#080c12f2;box-shadow:var(--shadow);overflow:hidden}.editor-canvas{width:100%;height:100%;display:block;cursor:crosshair;touch-action:none;-webkit-user-select:none;user-select:none}.editor-overlay{position:absolute;left:16px;bottom:14px;padding:6px 10px;border-radius:8px;background:#080c12bf;border:1px solid rgba(105,226,255,.25);color:var(--text);font-size:11px;letter-spacing:.06em;text-transform:uppercase}.editor-room-edit-actions{position:absolute;top:12px;right:12px;display:flex;gap:8px;z-index:2;pointer-events:auto}.editor-room-edit-button{border-radius:10px;border:1px solid rgba(88,214,255,.45);background:#060c12bf;color:var(--text);padding:6px 10px;font-size:11px;min-height:36px;cursor:pointer;text-transform:uppercase;letter-spacing:.06em}.editor-room-edit-button:hover{border-color:#58d6ffcc;box-shadow:0 0 12px #58d6ff33}.editor-room-edit-button-secondary{background:#0a1018b3}.panel{border-radius:var(--radius-lg);border:1px solid var(--panel-border);background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));padding:16px;box-shadow:var(--shadow-soft),inset 0 0 14px #58d6ff14;position:relative;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.panel:before{content:"";position:absolute;inset:10px;border-radius:calc(var(--radius-lg) - 6px);border:1px solid var(--panel-inner);box-shadow:inset 0 0 18px #58d6ff14;opacity:.75;pointer-events:none;z-index:0}.panel:after{content:"";position:absolute;inset:0;background-image:linear-gradient(180deg,var(--panel-highlight),transparent 45%),linear-gradient(225deg,rgba(46,242,200,.05),transparent 50%),repeating-linear-gradient(90deg,rgba(88,214,255,.03) 0,rgba(88,214,255,.03) 1px,transparent 1px,transparent 22px);opacity:.3;pointer-events:none;z-index:0}.panel:hover{transform:translateY(-2px);border-color:var(--panel-border-strong);box-shadow:var(--shadow-soft),0 0 24px #58d6ff1f,inset 0 0 16px #58d6ff1f}.panel>*{position:relative;z-index:1}.panel.device-list,.panel.device-detail,.panel.rooms-list,.panel.room-detail,.panel.floor-summary,.panel.settings-card{display:flex;flex-direction:column;min-height:0;overflow:auto}.panel-stack{display:flex;flex-direction:column;gap:12px;min-height:0}.panel-section{flex-shrink:0;border-radius:12px;border:1px solid rgba(88,214,255,.15);background:#080e1699;overflow:hidden}.panel-section.is-collapsed .panel-section-content{display:none}.panel-section-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;cursor:pointer;border:none;background:transparent;text-align:left;font:inherit;color:inherit;transition:background .15s ease}.panel-section-header:hover{background:#58d6ff14}.panel-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.panel-section-chevron{font-size:14px;color:var(--text-muted);width:16px;text-align:center}.panel-section-content{padding:8px 12px 12px;display:flex;flex-direction:column;gap:8px;border-top:1px solid rgba(88,214,255,.1)}.panel-title{text-transform:uppercase;letter-spacing:.16em;font-size:11px;color:var(--accent);margin-bottom:10px}.panel-row{display:flex;align-items:center;flex-wrap:wrap;gap:8px;justify-content:space-between;margin-bottom:8px}.panel-label{font-size:12px;color:var(--muted)}.panel-value{font-size:12px;color:var(--text)}.panel-input{flex:1;min-width:0;border-radius:10px;border:1px solid rgba(88,214,255,.25);background:#070c12bf;color:var(--text);padding:8px 10px;font-size:12px;min-height:44px;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.panel-input:focus{outline:none;border-color:#58d6ff99;box-shadow:var(--focus-ring)}.panel-input:hover{border-color:#58d6ff66}.panel-select{flex:1;min-width:0;border-radius:10px;border:1px solid rgba(88,214,255,.25);background:#070c12bf;color:var(--text);padding:8px 10px;font-size:12px;min-height:44px;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.panel-select:focus{outline:none;border-color:#58d6ff99;box-shadow:var(--focus-ring)}.panel-select:hover{border-color:#58d6ff66}.panel-actions{display:flex;gap:8px}.panel-button{border-radius:10px;border:1px solid rgba(88,214,255,.35);background:linear-gradient(135deg,#0c141ecc,#080e168c);color:var(--text);font-size:12px;padding:8px 12px;cursor:pointer;box-shadow:inset 0 0 12px #58d6ff1f;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease,background .2s ease;min-height:44px}.panel-button.active{background:#58d6ff33;border-color:#58d6ffbf;color:#e9fbff}.panel-button:hover{border-color:#58d6ffcc;box-shadow:0 0 18px #58d6ff38,inset 0 0 14px #58d6ff2e;transform:translateY(-1px)}.panel-button-danger{border-color:#ff7c7c8c;color:#ffd3d3;background:#7814184d}.panel-button-danger:hover{border-color:#ff7c7cd9}.panel-subtitle{margin:10px 0 6px;text-transform:uppercase;letter-spacing:.08em;font-size:11px;color:var(--accent)}.floor-list{display:flex;flex-direction:column;gap:8px;margin-bottom:10px;max-height:240px;overflow:auto}.floor-row{display:grid;grid-template-columns:34px minmax(0,1fr) 72px auto;gap:8px;align-items:center;padding:8px;border-radius:12px;border:1px solid rgba(105,226,255,.15);background:#090e14b3}.floor-row.active{border-color:#69e2ff80;box-shadow:0 0 0 1px #69e2ff1a}.floor-select{border-radius:8px;border:1px solid rgba(105,226,255,.3);background:#0a1018e6;color:var(--text);font-size:12px;padding:4px 6px;cursor:pointer}.floor-name-input,.floor-height-input{border-radius:8px;border:1px solid rgba(105,226,255,.25);background:#070b10e6;color:var(--text);padding:6px 8px;font-size:12px}.floor-height-input{text-align:right}.floor-actions{display:flex;flex-wrap:wrap;gap:6px}.floor-action{border-radius:8px;border:1px solid rgba(105,226,255,.25);background:#0a1018e6;color:var(--text);font-size:11px;padding:4px 6px;cursor:pointer}.floor-action:disabled{opacity:.5;cursor:default}.room-list{display:flex;flex-direction:column;gap:6px;max-height:220px;overflow:auto}.room-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;gap:8px;align-items:center;padding:6px 8px;border-radius:10px;border:1px solid rgba(105,226,255,.18);background:#090e14b3}.room-row.active{border-color:#69e2ff99;box-shadow:0 0 0 1px #69e2ff1f}.room-select{border-radius:8px;border:1px solid rgba(105,226,255,.3);background:#0a1018e6;color:var(--text);font-size:11px;padding:4px 6px;cursor:pointer}.room-name-input{border-radius:8px;border:1px solid rgba(105,226,255,.25);background:#070b10e6;color:var(--text);padding:6px 8px;font-size:12px}.room-floor-tag{font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:#7defff;padding:4px 6px;border-radius:999px;border:1px solid rgba(105,226,255,.35);background:#0c121a99}.room-delete{border-radius:8px;border:1px solid rgba(248,113,113,.45);background:#7f1d1d40;color:#fecaca;font-size:11px;padding:4px 6px;cursor:pointer}.furniture-filters{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.furniture-filter{border-radius:999px;border:1px solid rgba(105,226,255,.25);background:#0a1018d9;color:var(--text);font-size:11px;padding:4px 8px;cursor:pointer}.furniture-filter.active{background:#69e2ff2e;border-color:#69e2ffb3;color:#e9fbff}.furniture-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;max-height:420px;overflow:auto;padding-right:4px;margin-bottom:10px}.furniture-card{border-radius:12px;border:1px solid rgba(105,226,255,.2);background:#090e14b3;overflow:hidden;display:flex;flex-direction:column;min-height:140px;cursor:grab}.furniture-card:active{cursor:grabbing}.furniture-card.active{border-color:#69e2ff99;box-shadow:0 0 0 1px #69e2ff1f}.furniture-thumb{width:100%;height:96px;display:block;object-fit:contain;object-position:center;padding:8px;box-sizing:border-box;background:radial-gradient(120px 60px at 50% 20%,rgba(88,214,255,.12),transparent 70%),#070b10e6}.furniture-card-body{display:flex;flex-direction:column;gap:6px;padding:8px}.furniture-card-name{font-size:12px;color:var(--text)}.furniture-card-meta{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.anchor-list{display:flex;flex-direction:column;gap:6px;margin-bottom:6px}.anchor-row{display:flex;justify-content:space-between;gap:8px;padding:6px 8px;border-radius:8px;border:1px solid rgba(105,226,255,.2);background:#0a1018bf}.anchor-label{font-size:11px;color:var(--text)}.anchor-value{font-size:11px;color:var(--muted)}.panel-muted{color:var(--text-muted);font-size:12px;margin-bottom:8px}.panel-hint{margin-top:10px;font-size:11px;color:#8ba6babf}.preview-canvas{width:100%;height:100%}.preview-canvas canvas{width:100%;height:100%;display:block;position:relative;z-index:0}.builder-shell{gap:12px;min-height:0}.builder-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:12px 16px;border-radius:var(--radius-lg);border:1px solid var(--panel-border);background:var(--panel-bg);box-shadow:var(--shadow-soft),inset 0 0 12px #58d6ff14}.builder-title-group{display:flex;flex-direction:column;gap:4px;min-width:200px}.builder-title{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}.builder-hint{font-size:12px;color:var(--text-muted)}.builder-header-actions{display:flex;flex-wrap:wrap;gap:8px}.builder-advanced{display:flex;flex-direction:column;gap:16px;flex:1;min-height:0}.builder-appbar{display:grid;grid-template-columns:minmax(200px,1fr) minmax(260px,1.2fr) minmax(320px,1fr);align-items:center;gap:12px;padding:8px 14px;border-radius:16px;border:1px solid var(--panel-border);background:#070c12c7;box-shadow:var(--shadow-soft),inset 0 0 12px #58d6ff14}.builder-breadcrumb{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted)}.builder-context{display:flex;flex-direction:column;gap:4px;text-align:center}.builder-context-title{font-size:13px;font-weight:600;color:#e9fbff}.builder-context-meta{display:flex;justify-content:center;gap:8px;font-size:11px;color:var(--text-muted)}.builder-context-divider{color:#58d6ff99}.builder-appbar-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.builder-icon-button{border-radius:10px;border:1px solid rgba(88,214,255,.3);background:#091018cc;color:var(--text);padding:8px 10px;min-height:38px;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.builder-icon-button:hover{border-color:#58d6ffb3;box-shadow:0 0 10px #58d6ff2e;transform:translateY(-1px)}.builder-menu{position:relative}.builder-menu-trigger{list-style:none;border-radius:10px;border:1px solid rgba(88,214,255,.3);background:#091018cc;color:var(--text);padding:6px 10px;font-size:12px;cursor:pointer}.builder-menu-trigger::-webkit-details-marker{display:none}.builder-menu-body{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;padding:12px;border-radius:14px;border:1px solid var(--panel-border);background:#060a10f2;box-shadow:var(--shadow-strong);display:flex;flex-direction:column;gap:10px;z-index:30}.builder-menu-io{display:flex;flex-direction:column;gap:8px}.builder-menu-button{border-radius:10px;border:1px solid rgba(88,214,255,.35);background:#0a1018b3;color:var(--text);padding:8px 12px;font-size:12px;cursor:pointer}.builder-focusbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;border-radius:14px;border:1px solid rgba(88,214,255,.2);background:#080e16b3}.builder-focus-group{display:flex;align-items:center;gap:10px}.builder-focus-label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.builder-focus-buttons{display:flex;gap:6px}.builder-focus-button{border-radius:999px;border:1px solid rgba(88,214,255,.25);background:#0a1018cc;color:var(--text);padding:6px 10px;font-size:11px;cursor:pointer;transition:border-color .15s ease,background .15s ease}.builder-focus-button.active{background:#58d6ff33;border-color:#58d6ffb3;color:#e9fbff}.builder-focus-status{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-muted)}.builder-focus-divider{color:#58d6ff80}.builder-workspace{display:grid;grid-template-columns:minmax(240px,22%) minmax(0,1fr) minmax(260px,24%);gap:14px;flex:1;min-height:0}.builder-workspace.left-hidden{grid-template-columns:minmax(0,1fr) minmax(260px,24%)}.builder-workspace.right-hidden{grid-template-columns:minmax(240px,22%) minmax(0,1fr)}.builder-workspace.left-hidden.right-hidden{grid-template-columns:minmax(0,1fr)}.builder-workspace.focus-scene{grid-template-columns:minmax(0,1fr) minmax(320px,32%)}.builder-workspace.focus-library{grid-template-columns:minmax(320px,34%) minmax(0,1fr)}.builder-sidebar,.builder-inspector{display:flex;flex-direction:column;gap:0;border-radius:18px;border:1px solid var(--panel-border);background:#060a10b3;box-shadow:var(--shadow-soft);overflow:hidden;min-height:0}.builder-sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-bottom:1px solid rgba(88,214,255,.15);background:#060a1099}.builder-sidebar-tabs{display:flex;gap:6px}.builder-tab-button{border-radius:999px;border:1px solid rgba(88,214,255,.25);background:#0a1018cc;color:var(--text);padding:6px 12px;font-size:11px;cursor:pointer}.builder-tab-button.active{background:#58d6ff33;border-color:#58d6ffb3;color:#e9fbff}.builder-collapse-button{border-radius:10px;border:1px solid rgba(88,214,255,.3);background:#091018cc;color:var(--text);padding:6px 10px;font-size:11px;cursor:pointer}.builder-sidebar-body{display:flex;flex-direction:column;gap:12px;padding:12px;overflow:auto;min-height:0}.builder-tool-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.builder-tool-button{border-radius:12px;border:1px solid rgba(88,214,255,.3);background:#091018cc;color:var(--text);padding:8px;text-align:left;display:flex;flex-direction:column;gap:4px;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.builder-tool-button:hover{border-color:#58d6ff99;box-shadow:0 0 10px #58d6ff1f;transform:translateY(-1px)}.builder-tool-button.active{background:#58d6ff33;border-color:#58d6ffcc;color:#e9fbff}.builder-tool-name{font-size:12px;font-weight:600}.builder-tool-hint{font-size:10px;color:var(--text-muted)}.builder-canvas-stage{position:relative;flex:1;min-height:420px;display:flex;flex-direction:column;border-radius:18px;border:1px solid var(--panel-border);background:#060a10a6;box-shadow:var(--shadow-strong);overflow:hidden}.builder-canvas-stage>*{flex:1}.builder-canvas-floor{font-size:12px;color:var(--text);padding:6px 8px}.builder-action-log{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;gap:8px;pointer-events:none;z-index:5}.builder-action-toast{border-radius:10px;border:1px solid rgba(88,214,255,.3);background:#080e16e6;color:#e9fbff;font-size:11px;padding:8px 12px;box-shadow:0 0 14px #58d6ff33}.builder-inspector-body{display:flex;flex-direction:column;min-height:0}.builder-inspector-scroll{display:flex;flex-direction:column;gap:12px;padding:12px;overflow:auto;min-height:0}.inspector-summary{display:flex;flex-direction:column;gap:4px}.inspector-summary-title{font-size:13px;font-weight:600;color:#e9fbff}.inspector-summary-meta{font-size:11px;color:var(--text-muted)}.inspector-section{border-radius:12px;border:1px solid rgba(88,214,255,.2);background:#091018b3;overflow:hidden}.inspector-section-header{position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:8px 10px;border:none;background:#080e16f2;color:var(--text);font-size:11px;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;z-index:2}.inspector-section-title{color:var(--accent)}.inspector-section-chevron{color:var(--text-muted)}.inspector-section-content{padding:10px}.inspector-section.is-collapsed .inspector-section-content{display:none}.inspector-actions{display:flex;justify-content:flex-end}.inspector-empty{display:flex;flex-direction:column;gap:10px}.inspector-empty-tips{display:flex;flex-direction:column;gap:6px;font-size:11px;color:var(--text-muted)}.builder-library{display:flex;flex-direction:column;gap:10px}.builder-workspace.focus-library .furniture-grid{max-height:none}.builder-layout{display:grid;grid-template-columns:minmax(220px,24%) minmax(0,1fr) minmax(240px,24%);gap:14px;flex:1;min-height:0}.main:has(.builder-3d-controls){grid-template-columns:minmax(280px,32%) minmax(0,1fr) minmax(280px,22%)}.builder-3d-controls{display:flex;flex-direction:column;max-height:100%;min-height:0;overflow:hidden}.preview-panel.with-controls{min-height:400px}.builder-sidebar,.builder-inspector{display:flex;flex-direction:column;gap:12px;overflow:auto;min-height:0;padding-right:4px}.builder-section{border-radius:16px;border:1px solid var(--panel-border);background:#080e16bf;padding:12px;box-shadow:var(--shadow-soft),inset 0 0 10px #58d6ff14;display:flex;flex-direction:column;gap:10px}.builder-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--accent)}.simple-tool-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.simple-tool-button{border-radius:14px;border:1px solid rgba(88,214,255,.3);background:#091018cc;color:var(--text);min-height:56px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease,background .15s ease}.simple-tool-button:hover{border-color:#58d6ffb3;box-shadow:0 0 12px #58d6ff2e;transform:translateY(-1px)}.simple-tool-button.active{background:#58d6ff38;border-color:#58d6ffd9;color:#e9fbff;box-shadow:0 0 16px #58d6ff33}.simple-tool-icon{display:inline-flex;align-items:center;justify-content:center}.simple-tool-icon svg{width:22px;height:22px}.builder-button{border-radius:12px;border:1px solid rgba(88,214,255,.35);background:#091018cc;color:var(--text);padding:10px 14px;min-height:44px;font-size:13px;letter-spacing:.02em;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease,background .15s ease}.builder-button:hover{border-color:#58d6ffb3;box-shadow:0 0 12px #58d6ff33;transform:translateY(-1px)}.builder-button:disabled{opacity:.5;cursor:default;box-shadow:none;transform:none}.builder-button-primary{background:#58d6ff33;border-color:#58d6ffd9;color:#e9fbff;box-shadow:0 0 16px #58d6ff33}.builder-button-secondary{background:#0a1018b3;border-color:#58d6ff4d}.builder-button-danger{border-color:#ff7c7c99;background:#78141859;color:#ffd3d3}.builder-toggle.active{background:#58d6ff40;border-color:#58d6ffe6;color:#e9fbff}.builder-chip-group{display:flex;flex-wrap:wrap;gap:6px}.builder-chip{border-radius:999px;border:1px solid rgba(88,214,255,.3);background:#0a1018cc;color:var(--text);padding:6px 12px;min-height:44px;font-size:12px;cursor:pointer;transition:border-color .15s ease,background .15s ease,color .15s ease}.builder-chip.active{background:#58d6ff38;border-color:#58d6ffbf;color:#e9fbff}.builder-block-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}.builder-block{border-radius:14px;border:1px solid rgba(88,214,255,.2);background:#080e16b3;color:var(--text);padding:10px;min-height:64px;display:flex;flex-direction:column;align-items:flex-start;gap:4px;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.builder-block:hover{border-color:#58d6ff99;box-shadow:0 0 12px #58d6ff26;transform:translateY(-1px)}.builder-block-title{font-size:12px}.builder-block-meta{font-size:11px;color:var(--muted)}.builder-furniture-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.builder-furniture-card{border-radius:14px;border:1px solid rgba(88,214,255,.2);background:#080e16b3;color:var(--text);padding:8px;min-height:120px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.builder-furniture-card:hover{border-color:#58d6ff99;box-shadow:0 0 12px #58d6ff26;transform:translateY(-1px)}.builder-furniture-thumb{width:100%;height:64px;border-radius:10px;border:1px solid rgba(88,214,255,.2);background:#060a10cc;display:flex;align-items:center;justify-content:center}.builder-furniture-thumb img{width:48px;height:48px;object-fit:contain;opacity:.9}.builder-furniture-name{font-size:12px;text-align:center}.builder-canvas-panel{display:flex;flex-direction:column;min-height:0;overflow:hidden;gap:10px}.builder-canvas-toolbar{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:10px 12px;border-radius:16px;border:1px solid var(--panel-border);background:#080c12d9;box-shadow:var(--shadow-soft),inset 0 0 10px #58d6ff14}.builder-canvas-left,.builder-canvas-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.builder-view-toggle{display:flex;gap:6px}.builder-view-button{border-radius:12px;border:1px solid rgba(88,214,255,.35);background:#0a1018bf;color:var(--text);padding:8px 14px;min-height:44px;font-size:12px;cursor:pointer}.builder-view-button.active{background:#58d6ff38;border-color:#58d6ffcc;color:#e9fbff}.builder-canvas-actions{display:flex;gap:8px}.builder-canvas-group{display:flex;align-items:center;gap:6px}.builder-canvas-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.builder-canvas{flex:1;min-height:0;border-radius:18px;border:1px solid var(--panel-border);background:#060a10a6;box-shadow:var(--shadow-strong);overflow:hidden;position:relative}.builder-canvas .editor-canvas-wrapper,.builder-canvas .preview-canvas{width:100%;height:100%;min-height:0}.builder-simple{display:flex;flex-direction:column;gap:12px;flex:1;min-height:0;position:relative}.simple-topbar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:10px 12px;border-radius:16px;border:1px solid var(--panel-border);background:#080c12d9;box-shadow:var(--shadow-soft),inset 0 0 10px #58d6ff14}.simple-topbar-left,.simple-topbar-center,.simple-topbar-right{display:flex;align-items:center;gap:8px}.simple-topbar-center{justify-content:center}.simple-topbar-name{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--text)}.simple-topbar-select{border-radius:999px;border:1px solid rgba(88,214,255,.35);background:#0a1018bf;color:var(--text);min-height:34px;padding:4px 10px;font-size:11px;cursor:pointer}.simple-topbar-icon-button{width:34px;height:34px;border-radius:10px;border:1px solid rgba(88,214,255,.3);background:#0a1018b3;color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s ease,background .15s ease,opacity .15s ease}.simple-topbar-icon-button svg{width:18px;height:18px}.simple-topbar-icon-button:hover:not(:disabled){border-color:#58d6ff99;background:#58d6ff1a}.simple-topbar-icon-button:disabled{opacity:.4;cursor:not-allowed}.simple-topbar-icon-button.is-active{background:#58d6ff40;border-color:#58d6ffcc;color:#e9fbff}.simple-topbar-divider{width:1px;height:20px;background:#58d6ff33;margin:0 4px}.simple-segmented{display:inline-flex;border-radius:999px;border:1px solid rgba(88,214,255,.35);overflow:hidden;background:#0a101899}.simple-segment-button{border:none;background:transparent;color:var(--text-muted);padding:6px 14px;min-height:34px;cursor:pointer;font-size:11px;letter-spacing:.08em;text-transform:uppercase}.simple-segment-button.is-active{background:#58d6ff40;color:#e9fbff}.simple-body{display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;flex:1;min-height:0}.simple-tool-rail{display:flex;flex-direction:column;gap:6px;padding:10px 8px;border-radius:18px;border:1px solid var(--panel-border);background:#080e16e0;box-shadow:var(--shadow-soft),inset 0 0 10px #58d6ff14}.simple-tool-rail-button{position:relative;width:58px;min-height:62px;padding:8px 4px 6px;border-radius:14px;border:1px solid rgba(88,214,255,.3);background:#0a1018cc;color:var(--text);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.simple-tool-rail-button:hover{border-color:#58d6ffb3;background:#142030e6}.simple-tool-rail-button.is-active{background:#58d6ff3d;border-color:#58d6ffd9;color:#e9fbff;box-shadow:0 0 14px #58d6ff33}.simple-tool-rail-icon{display:inline-flex;align-items:center;justify-content:center}.simple-tool-rail-icon svg{width:26px;height:26px}.simple-tool-rail-caption{font-size:10px;font-weight:500;letter-spacing:.02em;text-align:center;color:#c8dcf0cc;line-height:1.1}.simple-tool-rail-button.is-active .simple-tool-rail-caption{color:#e9fbff}.simple-tool-rail-label{display:none}.simple-canvas-shell{position:relative;flex:1;min-height:0}.simple-canvas-stage{width:100%;height:100%}.simple-zoom-controls{position:absolute;right:16px;top:16px;display:flex;flex-direction:column;gap:8px;z-index:3}.simple-zoom-button{width:40px;height:40px;border-radius:12px;border:1px solid rgba(88,214,255,.4);background:#080c12e6;color:#e9fbff;font-size:16px;cursor:pointer}.simple-zoom-button-fit{font-size:11px;letter-spacing:.06em;text-transform:uppercase}.simple-furniture-drawer{position:absolute;left:76px;top:86px;bottom:20px;width:min(320px,86vw);border-radius:18px;border:1px solid var(--panel-border);background:#070c12f5;box-shadow:var(--shadow-strong);padding:12px;display:flex;flex-direction:column;gap:10px;z-index:6}.simple-furniture-header{display:flex;justify-content:space-between;align-items:center}.simple-furniture-title{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent)}.simple-furniture-close{border-radius:10px;border:1px solid rgba(88,214,255,.35);background:#0a1018b3;color:var(--text);font-size:11px;padding:4px 10px;cursor:pointer}.simple-furniture-body{display:flex;flex-direction:column;gap:10px;overflow:auto;padding-right:4px}.simple-quick-sheet{position:absolute;left:50%;transform:translate(-50%);bottom:16px;width:min(600px,92vw);border-radius:16px;border:1px solid var(--panel-border);background:#080c12f0;box-shadow:var(--shadow-strong);padding:12px 16px 16px;z-index:7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.simple-quick-sheet-handle{width:36px;height:4px;border-radius:999px;background:#58d6ff4d;margin:0 auto 8px}.simple-quick-sheet-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.simple-quick-sheet-heading{display:flex;align-items:center;gap:8px}.simple-quick-sheet-title{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.simple-quick-sheet-subtitle{font-size:13px;font-weight:500;color:var(--text)}.simple-quick-sheet-close{width:28px;height:28px;border-radius:8px;border:1px solid rgba(88,214,255,.3);background:#0a1018b3;color:var(--text);font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s ease,background .15s ease}.simple-quick-sheet-close:hover{border-color:#58d6ff99;background:#58d6ff1a}.simple-quick-sheet-body{display:flex;flex-wrap:wrap;align-items:flex-start;gap:16px}.simple-quick-sheet-body>.simple-scrub{flex:1;min-width:160px}.simple-quick-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-left:auto}.simple-quick-actions .builder-button{min-height:38px;padding:8px 12px;font-size:12px;border-radius:10px}.simple-quick-field{display:flex;flex-direction:column;gap:6px}.simple-quick-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.simple-quick-hint{font-size:11px;color:var(--text-muted)}.simple-scrub{display:flex;flex-direction:column;gap:6px}.simple-scrub-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.simple-scrub-controls{display:flex;align-items:center;gap:8px}.simple-scrub-step{width:40px;height:40px;border-radius:10px;border:1px solid rgba(88,214,255,.3);background:#0a1018b3;color:var(--text);font-size:18px;font-weight:300;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s ease,background .15s ease}.simple-scrub-step:hover{border-color:#58d6ff99;background:#58d6ff1a}.simple-scrub-step:active{background:#58d6ff33}.simple-scrub-surface{flex:1;min-width:100px;height:40px;border-radius:10px;border:1px solid rgba(88,214,255,.25);background:#060a10cc;display:flex;align-items:center;justify-content:center;cursor:ew-resize;touch-action:none;transition:border-color .15s ease,box-shadow .15s ease;-webkit-user-select:none;user-select:none}.simple-scrub-surface.is-active{border-color:#58d6ffb3;box-shadow:0 0 10px #58d6ff40}.simple-scrub-value{font-size:13px;font-weight:500;color:var(--text);pointer-events:none}.simple-scrub-inline-input{width:100%;height:100%;border:none;background:transparent;color:var(--text);font-size:13px;font-weight:500;text-align:center;outline:none}.editable-measure-label{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 10px;border-radius:6px;background:#0a121cd9;border:1px solid rgba(88,214,255,.25);cursor:ew-resize;touch-action:none;-webkit-user-select:none;user-select:none;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;z-index:50}.editable-measure-label:hover{border-color:#58d6ff80;background:#0f1926e6}.editable-measure-label.is-dragging{border-color:#58d6ffcc;box-shadow:0 0 12px #58d6ff4d;background:#142332f2}.editable-measure-label.is-editing{cursor:text;border-color:#ffb87099;background:#141c26f2}.editable-measure-label-title{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:#c8dcf099}.editable-measure-label-value{font-size:12px;font-weight:600;color:#c8f0fff2;letter-spacing:.02em}.editable-measure-label-input{width:60px;height:22px;border:none;border-radius:4px;background:#000a1499;color:#ffdcb4f2;font-size:12px;font-weight:600;text-align:center;outline:none}.editable-measure-label-input:focus{box-shadow:0 0 0 1px #ffb87066}.editor-canvas-wrapper.is-simple .editor-overlay{font-size:10px;letter-spacing:.08em;background:#080c12a6}@media(max-width:960px){.simple-topbar{grid-template-columns:1fr;justify-items:start}.simple-topbar-center{justify-content:flex-start}.simple-topbar-right{flex-wrap:wrap;justify-content:flex-start}.simple-furniture-drawer{left:12px;right:12px;width:auto}}.builder-form{display:flex;flex-direction:column;gap:10px}.builder-label{font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:6px}.builder-input{border-radius:12px;border:1px solid rgba(88,214,255,.25);background:#070c12bf;color:var(--text);padding:8px 10px;min-height:44px;font-size:13px}.builder-input-compact{min-height:38px;padding:6px 8px;font-size:12px}.builder-input:focus{outline:none;border-color:#58d6ff99;box-shadow:var(--focus-ring)}.builder-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.builder-row .builder-input{flex:1;min-width:0}.builder-row-compact{justify-content:space-between}.builder-meta-label{font-size:12px;color:var(--muted)}.builder-meta-value{font-size:12px;color:var(--text)}.builder-list{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow:auto;padding-right:2px}.builder-list-item{border-radius:12px;border:1px solid rgba(88,214,255,.2);background:#080e16b3;color:var(--text);padding:8px 12px;min-height:44px;text-align:left;cursor:pointer;transition:border-color .15s ease,background .15s ease}.builder-list-item.active{border-color:#58d6ffb3;background:#58d6ff2e}.template-modal-backdrop,.wizard-backdrop{position:fixed;inset:0;background:#04080cb8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50}.template-modal{width:min(960px,92vw);max-height:90vh;border-radius:22px;border:1px solid var(--panel-border);background:#070c12f5;padding:16px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-strong);overflow:hidden}.template-modal-header{font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent)}.template-modal-hint{font-size:12px;color:var(--text-muted)}.template-modal-actions{display:flex;justify-content:flex-end;gap:8px}.template-modal .panel-button,.wizard .panel-button{min-height:44px;padding:8px 14px}.template-cta{background:#58d6ff33;border-color:#58d6ffcc;color:#e9fbff}.template-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;overflow:auto;padding-right:6px}.template-card{border-radius:16px;border:1px solid rgba(88,214,255,.2);background:#080e16b3;color:var(--text);padding:0;text-align:left;overflow:hidden;display:flex;flex-direction:column;gap:0;cursor:pointer;min-height:200px;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.template-card:hover{border-color:#58d6ff99;box-shadow:0 0 16px #58d6ff2e;transform:translateY(-2px)}.template-card.active{border-color:#58d6ffe6;box-shadow:0 0 20px #58d6ff33}.template-preview{width:100%;height:96px;display:block;background:#060a10cc}.template-preview .template-frame{fill:#0c141e99;stroke:#58d6ff40;stroke-width:1}.template-preview .template-room{fill:#58d6ff1f;stroke:#58d6ff8c;stroke-width:1}.template-card:hover .template-room,.template-card.active .template-room{fill:#58d6ff2e;stroke:#58d6ffbf}.template-preview .template-courtyard{stroke:#58d6ff59;stroke-width:1}.template-preview .template-empty-line{stroke:#58d6ff66;stroke-width:1.5;stroke-linecap:round}.template-preview .template-floor-label{fill:#58d6ff80;font-size:9px;font-weight:600;font-family:var(--font-mono, monospace)}.template-preview rect{fill:#58d6ff24;stroke:#58d6ffa6;stroke-width:1.4}.template-preview path{stroke:#58d6ff99;stroke-width:2}.template-card-body{padding:12px;display:flex;flex-direction:column;gap:6px}.template-card-title{font-size:13px;color:var(--text)}.template-card-meta{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.template-card-description{font-size:11px;color:var(--text-muted)}.wizard{width:min(1080px,94vw);max-height:92vh;border-radius:24px;border:1px solid var(--panel-border);background:#070c12fa;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-strong)}.wizard-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid rgba(88,214,255,.2)}.wizard-title{font-size:16px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent)}.wizard-subtitle{font-size:12px;color:var(--text-muted)}.wizard-close{border-radius:10px;border:1px solid rgba(88,214,255,.3);background:#0a1018cc;color:var(--text);padding:8px 12px;min-height:44px;cursor:pointer}.wizard-body{flex:1;overflow:auto;padding:16px 20px}.wizard-step{display:flex;flex-direction:column;gap:14px}.wizard-step-title{font-size:14px;color:var(--text)}.wizard-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.wizard-label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--muted)}.wizard-input{border-radius:12px;border:1px solid rgba(88,214,255,.3);background:#070c12bf;color:var(--text);padding:8px 10px;min-height:44px}.wizard-button-group{display:flex;flex-wrap:wrap;gap:8px}.wizard-pill{border-radius:999px;border:1px solid rgba(88,214,255,.3);background:#0a1018cc;color:var(--text);padding:8px 14px;min-height:44px;font-size:12px;cursor:pointer}.wizard-pill.active{background:#58d6ff38;border-color:#58d6ffcc;color:#e9fbff}.wizard-room-tools{display:grid;grid-template-columns:minmax(180px,220px) minmax(0,1fr);gap:12px;min-height:360px}.wizard-room-palette{display:flex;flex-direction:column;gap:8px;overflow:auto;padding-right:4px}.wizard-room-block{border-radius:12px;border:1px solid rgba(88,214,255,.3);background:#091018cc;color:var(--text);padding:10px 12px;min-height:44px;text-align:left;cursor:pointer}.wizard-room-block-secondary{background:#58d6ff26;border-color:#58d6ffb3}.wizard-room-editor{display:flex;flex-direction:column;gap:10px;min-height:0}.wizard-floor-row{display:flex;flex-wrap:wrap;gap:8px}.wizard-summary{display:flex;gap:16px;font-size:13px;color:var(--text)}.wizard-actions{display:flex;gap:8px;flex-wrap:wrap}.wizard-footer{display:flex;justify-content:space-between;gap:12px;padding:12px 20px;border-top:1px solid rgba(88,214,255,.2)}@media(max-width:980px){.app-body{flex-direction:column}.app-sidebar{width:100%;flex-direction:row;flex-wrap:wrap;gap:6px}.nav-item{flex:1 1 120px;text-align:center}.app-topbar{grid-template-columns:1fr;row-gap:6px;justify-items:center}.topbar-right{justify-self:center}.myhome-layout{grid-template-columns:1fr;grid-template-rows:auto minmax(240px,1fr)}.myhome-title{font-size:18px}.glass-chip{padding:7px 10px;font-size:10px}.myhome-escape-chip{top:12px;left:12px}.myhome-sync-indicator{top:12px;right:12px}.myhome-bottom-dock{bottom:12px;width:calc(100% - 24px)}.myhome-bottom-dock-surface{width:100%;justify-content:center;flex-wrap:wrap;gap:10px;padding:10px 12px}.myhome-bottom-dock-group{width:100%;justify-content:center}.myhome-bottom-dock-divider{display:none}.myhome-dock-chip{flex:1 1 auto;justify-content:center}.myhome-chip-stack{top:12px}.myhome-chip-stack--left{left:12px}.myhome-chip-stack--right{right:12px}.myhome-advanced{inset:auto 12px 96px;width:auto}.myhome-controls{top:12px;left:12px;padding:12px 14px;min-width:180px}.myhome-status{top:12px;right:12px}.myhome-room-label{bottom:92px;left:12px;padding:8px 14px}.myhome-hint{display:none}.myhome-device-panel{width:min(320px,92vw);max-height:30vh}.myhome-device-panel--right{right:12px}.myhome-device-panel--left{left:12px}.myhome-device-panel--top{top:12px}.myhome-device-panel--bottom{bottom:12px}.myhome-device-action{width:28px;height:28px}.main,.devices-layout,.rooms-layout,.floors-layout,.settings-grid{grid-template-columns:1fr}.device-scene{min-height:320px}.device-settings-panel{inset:auto 16px 16px;width:auto;height:45%;border-radius:18px}.device-selection-panel{left:16px;right:16px;top:16px;width:auto}.scene-selection-hint{top:64px;max-width:calc(100% - 32px)}.filters{grid-template-columns:1fr}.preview-panel{min-height:320px}.floor-row{grid-template-columns:1fr}.floor-actions{justify-content:flex-start}.floor-select{width:100%}}@media(max-width:1100px){.builder-appbar{grid-template-columns:1fr;justify-items:start}.builder-context{text-align:left;align-items:flex-start}.builder-appbar-actions{justify-content:flex-start}.builder-focusbar{flex-direction:column;align-items:flex-start}.builder-workspace{display:flex;flex-direction:column}.builder-sidebar,.builder-inspector{max-height:40vh}.builder-layout{grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr) auto}.builder-sidebar{max-height:260px}.builder-inspector{max-height:35vh;border-radius:18px 18px 0 0;background:#080e16e6;border:1px solid rgba(88,214,255,.2);position:sticky;bottom:0}.builder-canvas-panel{min-height:280px}.wizard-grid,.wizard-room-tools{grid-template-columns:1fr}}.scene3d-controls{display:flex;flex-direction:column;flex:1;min-height:0;border-radius:16px;border:1px solid var(--panel-border);background:#080e16eb;box-shadow:var(--shadow-soft),inset 0 0 12px #58d6ff14;overflow:hidden}.scene3d-controls-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid rgba(88,214,255,.15);background:#060a1080}.scene3d-controls-title{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent)}.scene3d-controls-actions{display:flex;align-items:center;gap:6px}.scene3d-zero-all{border-radius:8px;border:1px solid rgba(88,214,255,.4);background:#0c1c2873;color:#cfefff;font-size:10px;padding:4px 8px;cursor:pointer;transition:border-color .15s ease,background .15s ease}.scene3d-zero-all:hover{border-color:#58d6ffb3;background:#0c1c28a6}.scene3d-reset-all{border-radius:8px;border:1px solid rgba(255,124,124,.4);background:#78141840;color:#ffd3d3;font-size:10px;padding:4px 8px;cursor:pointer;transition:border-color .15s ease,background .15s ease}.scene3d-reset-all:hover{border-color:#ff7c7cb3;background:#78141866}.scene3d-tabs{flex-shrink:0;display:flex;flex-wrap:wrap;gap:4px;padding:8px 10px;border-bottom:1px solid rgba(88,214,255,.12);background:#060a104d}.scene3d-tab{border-radius:8px;border:1px solid rgba(88,214,255,.2);background:#0a1018b3;color:var(--text-muted);font-size:11px;padding:6px 10px;cursor:pointer;transition:all .15s ease}.scene3d-tab:hover{border-color:#58d6ff80;color:var(--text)}.scene3d-tab.is-active{background:#58d6ff33;border-color:#58d6ffb3;color:#e9fbff}.scene3d-controls-body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:10px;display:flex;flex-direction:column;gap:8px}.scene3d-section{flex-shrink:0;border-radius:12px;border:1px solid rgba(88,214,255,.15);background:#080e1699;overflow:hidden}.scene3d-section.is-collapsed .scene3d-section-content{display:none}.scene3d-section-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;cursor:pointer;transition:background .15s ease}.scene3d-section-header:hover{background:#58d6ff14}.scene3d-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.scene3d-section-actions{display:flex;align-items:center;gap:8px}.scene3d-section-reset{border-radius:6px;border:1px solid rgba(88,214,255,.25);background:#0a1018b3;color:var(--text-muted);font-size:10px;padding:2px 6px;cursor:pointer;transition:all .15s ease}.scene3d-section-reset:hover{border-color:#58d6ff99;color:var(--text)}.scene3d-section-chevron{font-size:14px;color:var(--text-muted);width:16px;text-align:center}.scene3d-section-content{padding:8px 12px 12px;display:flex;flex-direction:column;gap:8px;border-top:1px solid rgba(88,214,255,.1)}.scene3d-control-row{display:flex;flex-direction:column;gap:4px}.scene3d-control-label{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--text-muted)}.scene3d-control-value{font-size:10px;color:var(--accent);font-family:monospace}.scene3d-control-slider{width:100%;height:4px;border-radius:2px;background:#58d6ff26;accent-color:var(--accent);cursor:pointer}.scene3d-control-slider::-webkit-slider-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 0 8px #58d6ff80}.scene3d-control-select{width:100%;padding:6px 8px;border-radius:6px;border:1px solid rgba(88,214,255,.3);background:#0a1018b3;color:var(--text-muted);font-size:11px}.scene3d-control-select:focus{outline:none;border-color:#58d6ff99;box-shadow:0 0 0 2px #58d6ff26}.scene3d-color-picker{display:flex;align-items:center;gap:8px}.scene3d-color-input{width:32px;height:24px;border:1px solid rgba(88,214,255,.3);border-radius:6px;background:transparent;cursor:pointer;padding:0}.scene3d-color-input::-webkit-color-swatch-wrapper{padding:2px}.scene3d-color-input::-webkit-color-swatch{border-radius:4px;border:none}.scene3d-color-value{font-size:10px;font-family:monospace;color:var(--text-muted)}.scene3d-toggle{border-radius:6px;border:1px solid rgba(88,214,255,.3);background:#0a1018b3;color:var(--text-muted);font-size:10px;padding:4px 10px;cursor:pointer;transition:all .15s ease}.scene3d-toggle.is-on{background:#58d6ff33;border-color:#58d6ffb3;color:#e9fbff}.scene3d-presets-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.scene3d-preset-button{border-radius:10px;border:1px solid rgba(88,214,255,.3);background:#0a1018bf;color:var(--text);font-size:11px;padding:10px 12px;cursor:pointer;text-align:center;transition:all .15s ease}.scene3d-preset-button:hover{border-color:#58d6ffb3;background:#58d6ff26;transform:translateY(-1px)}.scene3d-demo-mode{display:flex;flex-direction:column;gap:12px}.scene3d-demo-description{color:#c8dcffb3;font-size:11px;line-height:1.5;margin:0;padding:8px 10px;background:#00d4ff0d;border-left:2px solid rgba(0,212,255,.4);border-radius:0 6px 6px 0}.scene3d-import-export-buttons{display:flex;gap:8px}.scene3d-button{flex:1;border-radius:10px;border:1px solid rgba(88,214,255,.35);background:#0a1018bf;color:var(--text);font-size:11px;padding:10px 14px;cursor:pointer;transition:all .15s ease}.scene3d-button:hover:not(:disabled){border-color:#58d6ffb3;background:#58d6ff26}.scene3d-button:disabled{opacity:.5;cursor:not-allowed}.scene3d-button-danger{border-color:#ff7c7c80;background:#7814184d;color:#ffd3d3}.scene3d-button-danger:hover{border-color:#ff7c7ccc;background:#78141880}.scene3d-import-export{display:flex;flex-direction:column;gap:10px;padding:12px;border-radius:12px;border:1px solid rgba(88,214,255,.2);background:#060a10cc;margin-bottom:8px}.scene3d-import-export-header{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--accent)}.scene3d-import-export-close{border-radius:6px;border:1px solid rgba(88,214,255,.3);background:transparent;color:var(--text-muted);font-size:10px;padding:4px 8px;cursor:pointer}.scene3d-import-export-textarea{width:100%;min-height:120px;border-radius:8px;border:1px solid rgba(88,214,255,.2);background:#070c12e6;color:var(--text);font-size:10px;font-family:monospace;padding:8px;resize:vertical}.scene3d-import-export-textarea:focus{outline:none;border-color:#58d6ff80}.scene3d-import-export-actions{display:flex;justify-content:flex-end;gap:8px}.scene3d-guided{display:flex;flex-direction:column;gap:10px}.scene3d-progress{border-radius:12px;border:1px solid rgba(88,214,255,.2);background:#060a10a6;padding:10px 12px}.scene3d-progress-label{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted);margin-bottom:8px}.scene3d-progress-bar{height:6px;border-radius:999px;background:#58d6ff1f;overflow:hidden}.scene3d-progress-fill{display:block;height:100%;background:linear-gradient(90deg,#00d4ff66,#58d6ffe6);transition:width .2s ease}.scene3d-step{border-radius:14px;border:1px solid rgba(88,214,255,.18);background:#080e16a6;overflow:hidden}.scene3d-step.is-active{border-color:#58d6ff99;box-shadow:inset 0 0 16px #58d6ff1f}.scene3d-step.is-complete .scene3d-step-status{color:#7ef9c2}.scene3d-step-header{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;background:transparent;border:none;text-align:left;cursor:pointer;color:var(--text)}.scene3d-step-header:hover{background:#58d6ff14}.scene3d-step-index{width:22px;height:22px;border-radius:50%;background:#58d6ff26;color:var(--accent);font-size:11px;display:inline-flex;align-items:center;justify-content:center}.scene3d-step-text{flex:1;display:flex;flex-direction:column;gap:2px}.scene3d-step-title{font-size:12px;color:#e7faff}.scene3d-step-desc{font-size:10px;color:var(--text-muted)}.scene3d-step-status{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.scene3d-step-body{padding:10px 12px 12px;border-top:1px solid rgba(88,214,255,.1);display:flex;flex-direction:column;gap:10px}.scene3d-step-next{align-self:flex-end;border-radius:999px;border:1px solid rgba(88,214,255,.6);background:#00d4ff33;color:#e9fbff;font-size:10px;padding:6px 12px;cursor:pointer;transition:all .15s ease}.scene3d-step-next:hover{border-color:#58d6ffe6;background:#00d4ff4d}.scene3d-step-note{border-radius:10px;border-left:2px solid rgba(0,212,255,.6);background:#00d4ff0f;padding:8px 10px;display:flex;flex-direction:column;gap:4px}.scene3d-step-note-title{font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--accent)}.scene3d-step-note-text{font-size:11px;color:#d2e6ffbf;line-height:1.4}.scene3d-subsection{border-radius:10px;border:1px solid rgba(88,214,255,.12);background:#060a1099;padding:8px 10px;display:flex;flex-direction:column;gap:8px}.scene3d-subsection-header{display:flex;flex-direction:column;gap:2px}.scene3d-subsection-title{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.scene3d-subsection-description{font-size:10px;color:var(--text-muted)}.scene3d-subsection-body{display:flex;flex-direction:column;gap:8px}.scene3d-control-help{font-size:10px;color:#c8dcff99}.scene3d-inline-actions{display:flex;flex-wrap:wrap;gap:8px}.scene3d-button-primary{border-color:#00d4ffa6;background:linear-gradient(135deg,#00d4ff4d,#0078ff1f);color:#e8fbff}.scene3d-button-ghost{border-color:#a0b4c866;background:#0a101873;color:var(--text-muted)}.scene3d-button-ghost:hover{border-color:#a0b4c8b3;background:#0a1018a6}.scene3d-advanced-intro{font-size:11px;color:var(--text-muted);padding:8px 10px;border-radius:10px;background:#060a1080;border:1px solid rgba(88,214,255,.1)}.scene3d-advanced-body{display:flex;flex-direction:column;gap:8px}.scene3d-warning{font-size:10px;color:#ffbe8ccc;background:#783c1433;border-left:2px solid rgba(255,160,110,.6);padding:6px 8px;border-radius:8px}.scene-studio{display:flex;flex-direction:column;height:100%;overflow:hidden;background:linear-gradient(180deg,#040810fa,#060c14f2)}.scene-studio-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 16px;border-bottom:1px solid rgba(88,214,255,.12);background:#060a12d9;flex-shrink:0}.scene-studio-top-left,.scene-studio-top-center,.scene-studio-top-right{display:flex;align-items:center;gap:10px}.scene-studio-top-left{flex:0 0 auto}.scene-studio-top-center{flex:1 1 auto;justify-content:center}.scene-studio-top-right{flex:0 0 auto}.scene-studio-brand{font-size:14px;font-weight:600;color:#58d6ffe6;letter-spacing:.5px}.scene-studio-name-input{padding:6px 10px;font-size:12px;border:1px solid rgba(88,214,255,.2);border-radius:6px;background:#0a1018b3;color:var(--text-primary);min-width:140px}.scene-studio-name-input:focus{outline:none;border-color:#58d6ff80}.scene-studio-save-pill{font-size:10px;padding:3px 8px;border-radius:10px;background:#58d6ff1a;color:#58d6ffb3}.scene-studio-save-pill.is-saving{background:#ffb46426;color:#ffb464d9}.scene-studio-save-pill.is-saved{background:#4ade8026;color:#4ade80d9}.scene-studio-save-pill.is-error{background:#ff646426;color:#ff6464d9}.scene-studio-select-group{display:flex;align-items:center;gap:8px}.scene-studio-select-label{font-size:11px;color:var(--text-muted)}.scene-studio-select{padding:6px 10px;font-size:12px;border:1px solid rgba(88,214,255,.2);border-radius:6px;background:#0a1018b3;color:var(--text-primary);cursor:pointer;min-width:140px}.scene-studio-select:focus{outline:none;border-color:#58d6ff80}.scene-studio-button{padding:6px 12px;font-size:11px;font-weight:500;border:1px solid rgba(88,214,255,.25);border-radius:6px;background:#0a1018b3;color:var(--text-primary);cursor:pointer;transition:all .15s ease}.scene-studio-button:hover{border-color:#58d6ff80;background:#141e28cc}.scene-studio-button-primary{border-color:#00d4ff80;background:linear-gradient(135deg,#00d4ff40,#0078ff1a);color:#e0f8ff}.scene-studio-button-primary:hover{border-color:#00d4ffb3;background:linear-gradient(135deg,#00d4ff59,#0078ff33)}.scene-studio-button-danger{border-color:#ff64644d;background:#3c141466;color:#ff9696e6}.scene-studio-button-danger:hover{border-color:#ff646480;background:#50141480}.scene-studio-export-status{font-size:11px;color:#4ade80d9;padding:4px 8px;background:#4ade801a;border-radius:4px}.scene-studio-body{display:flex;flex:1;overflow:hidden}.scene-studio-panel{display:flex;flex-direction:column;background:#060a12e6;border-right:1px solid rgba(88,214,255,.1)}.scene-studio-left{width:320px;flex-shrink:0}.scene-studio-right{width:300px;flex-shrink:0;border-right:none;border-left:1px solid rgba(88,214,255,.1)}.scene-studio-left-tabs{display:flex;flex-direction:column;gap:2px;padding:8px;border-bottom:1px solid rgba(88,214,255,.1);background:#04080eb3}.scene-studio-tab{display:flex;flex-direction:column;align-items:flex-start;padding:8px 12px;border:none;border-radius:8px;background:transparent;cursor:pointer;transition:all .15s ease;text-align:left}.scene-studio-tab:hover{background:#58d6ff14}.scene-studio-tab.is-active{background:#00d4ff26;border-left:2px solid rgba(0,212,255,.7)}.scene-studio-tab-label{font-size:12px;font-weight:500;color:var(--text-primary)}.scene-studio-tab-desc{font-size:10px;color:var(--text-muted);margin-top:2px}.scene-studio-tab.is-active .scene-studio-tab-label{color:#58d6fff2}.scene-studio-left-scroll{flex:1;overflow-y:auto;padding:12px}.scene-studio-left-section{margin-bottom:16px}.scene-studio-left-header{margin-bottom:10px}.scene-studio-left-title{font-size:12px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.scene-studio-left-subtitle{font-size:10px;color:var(--text-muted)}.scene-studio-preset-grid{display:grid;grid-template-columns:1fr;gap:8px}.scene-studio-preset-grid--module{grid-template-columns:1fr}.scene-studio-preset-card{display:flex;align-items:stretch;gap:10px;padding:8px;border:1px solid rgba(88,214,255,.15);border-radius:10px;background:#0a101899;cursor:pointer;transition:all .18s ease;text-align:left}.scene-studio-preset-card:hover{border-color:#58d6ff66;background:#0f1620bf;transform:translateY(-1px)}.scene-studio-preset-card.is-active{border-color:#00d4ff99;background:#00d4ff1f}.scene-studio-preset-swatch{width:44px;height:44px;border-radius:8px;flex-shrink:0}.scene-studio-preset-body{display:flex;flex-direction:column;justify-content:center;min-width:0}.scene-studio-preset-title{font-size:11px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scene-studio-preset-subtitle{font-size:10px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scene-studio-quick-actions{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.scene-studio-quick-actions .scene-studio-button{flex:1 1 auto;min-width:80px;text-align:center;padding:8px 10px}.scene-studio-structure-stack{display:flex;flex-direction:column;gap:12px}.scene-studio-block{padding:10px;border:1px solid rgba(88,214,255,.1);border-radius:10px;background:#0a101880}.scene-studio-block-title{font-size:11px;font-weight:600;color:var(--text-primary);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid rgba(88,214,255,.1)}.scene-studio-viewport{flex:1;display:flex;flex-direction:column;min-width:0;background:#030508}.scene-studio-viewport-header{display:flex;align-items:center;gap:10px;padding:8px 16px;background:#060a12cc;border-bottom:1px solid rgba(88,214,255,.08)}.scene-studio-viewport-title{font-size:12px;font-weight:500;color:var(--text-primary)}.scene-studio-viewport-subtitle{font-size:11px;color:var(--text-muted)}.scene-studio-viewport-canvas{flex:1;position:relative;overflow:hidden}.scene-studio-viewport-canvas canvas{display:block;width:100%;height:100%}.scene-studio-right-header{padding:12px;border-bottom:1px solid rgba(88,214,255,.1);background:#04080eb3}.scene-studio-right-title{font-size:13px;font-weight:600;color:var(--text-primary)}.scene-studio-right-subtitle{font-size:10px;color:var(--text-muted);margin-top:2px}.scene-studio-right-body{flex:1;overflow-y:auto;padding:12px}.scene-studio-section{margin-bottom:12px;border:1px solid rgba(88,214,255,.1);border-radius:10px;background:#0a101880;overflow:hidden}.scene-studio-section-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#060c1499;border-bottom:1px solid rgba(88,214,255,.08);font-size:11px;font-weight:600;color:var(--text-primary)}.scene-studio-section-reset{font-size:10px;padding:3px 8px;border:1px solid rgba(88,214,255,.2);border-radius:4px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.scene-studio-section-reset:hover{border-color:#58d6ff66;color:var(--text-primary)}.scene-studio-section-hint{font-size:10px;color:var(--text-muted);padding:6px 12px;background:#04080e80;border-bottom:1px solid rgba(88,214,255,.05)}.scene-studio-section-body{padding:10px 12px;display:flex;flex-direction:column;gap:8px}.scene-studio-subsection-title{font-size:10px;font-weight:600;color:#58d6ffcc;margin-top:8px;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.scene-studio-advanced-toggle{width:100%;margin-top:8px;padding:10px;font-size:11px;font-weight:500;border:1px dashed rgba(88,214,255,.2);border-radius:8px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.scene-studio-advanced-toggle:hover{border-color:#58d6ff66;background:#58d6ff0d;color:var(--text-primary)}.scene-studio-segmented{display:flex;gap:2px;padding:3px;background:#060c14b3;border-radius:8px;border:1px solid rgba(88,214,255,.1)}.scene-studio-segment{flex:1;padding:6px 10px;font-size:11px;font-weight:500;border:none;border-radius:6px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.scene-studio-segment:hover{background:#58d6ff14;color:var(--text-primary)}.scene-studio-segment.is-active{background:#00d4ff33;color:#58d6fff2}.builder-sidebar-title{font-size:12px;font-weight:600;color:var(--text-primary);padding:6px 0}.simple-topbar-saved,.simple-topbar-saving{font-size:11px;padding:4px 8px;border-radius:4px;white-space:nowrap}.simple-topbar-saved{color:#4ade80;background:#4ade801a}.simple-topbar-saving{color:#58d6ffb3;background:#58d6ff1a}.simple-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}.simple-modal{background:var(--panel-bg);border:1px solid rgba(88,214,255,.2);border-radius:12px;padding:24px;max-width:360px;width:90%;animation:slideUp .2s ease}.simple-modal-title{margin:0 0 12px;font-size:18px;font-weight:500;color:var(--text)}.simple-modal-text{margin:0 0 20px;font-size:14px;color:var(--text-muted);line-height:1.5}.simple-modal-actions{display:flex;gap:12px;justify-content:flex-end}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.hologram-hero-scene{position:relative;width:100%;height:100%;min-height:400px;background:#000308;border-radius:12px;overflow:hidden}.hologram-hero-scene canvas{display:block;width:100%;height:100%}.hologram-hero-scene.fullscreen{position:fixed;inset:0;z-index:9999;border-radius:0;min-height:100vh}.hologram-hero-container{position:relative;width:100%;height:100vh;min-height:600px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#000308,#000510)}.hologram-hero-container .hologram-hero-scene{width:100%;height:100%}.hologram-hero-overlay{position:absolute;bottom:40px;left:50%;transform:translate(-50%);text-align:center;pointer-events:none;z-index:10}.hologram-hero-overlay h1{font-size:48px;font-weight:300;letter-spacing:.1em;color:#ffffffe6;text-shadow:0 0 40px rgba(0,212,255,.5);margin:0 0 12px}.hologram-hero-overlay p{font-size:16px;font-weight:400;letter-spacing:.2em;color:#00d4ffcc;text-transform:uppercase;margin:0}.hologram-hero-controls{position:absolute;top:20px;right:20px;display:flex;gap:8px;z-index:10}.hologram-hero-controls button{background:#00d4ff1a;border:1px solid rgba(0,212,255,.3);border-radius:6px;padding:8px 16px;color:#00d4ffe6;font-size:12px;letter-spacing:.1em;cursor:pointer;transition:all .2s ease}.hologram-hero-controls button:hover{background:#00d4ff33;border-color:#00d4ff80}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;cursor:pointer;transition:all .2s ease}.user-menu-trigger:hover{transform:scale(1.05);box-shadow:0 2px 12px #66dcff66}.user-avatar{font-size:14px;font-weight:600;color:var(--bg0)}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius-md);box-shadow:var(--shadow-strong);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));z-index:1000;overflow:hidden}.user-menu-header{padding:12px 14px;background:#0003}.user-menu-email{font-size:13px;color:var(--text);word-break:break-all}.user-menu-divider{height:1px;background:var(--panel-border)}.user-menu-section{padding:8px 0}.user-menu-section-title{display:block;padding:4px 14px 8px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.user-menu-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 14px;background:transparent;border:none;color:var(--text);font-size:13px;text-align:left;cursor:pointer;transition:background .15s ease}.user-menu-item:hover{background:#ffffff0d}.user-menu-item.is-active{color:var(--accent)}.user-menu-item .check-icon{color:var(--accent);font-size:12px}.user-menu-signout{color:var(--danger)}.user-menu-signout:hover{background:#ff7c7c1a}.panel-notice{padding:12px 14px;margin-bottom:12px;background:#66dcff1a;border:1px solid rgba(102,220,255,.2);border-radius:var(--radius-sm);color:var(--text);font-size:13px}.panel-error{padding:10px 14px;margin-bottom:12px;background:#ff7c7c1a;border:1px solid rgba(255,124,124,.3);border-radius:var(--radius-sm);color:var(--danger);font-size:13px}.panel-success{padding:10px 14px;margin-bottom:12px;background:#7dffb51a;border:1px solid rgba(125,255,181,.3);border-radius:var(--radius-sm);color:var(--ok);font-size:13px}.panel-hint{margin-top:12px;padding-top:12px;border-top:1px solid var(--panel-border);color:var(--text-muted);font-size:12px}.panel-button-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:var(--bg0);border-color:transparent}.panel-button-primary:hover:not(:disabled){box-shadow:0 2px 12px #66dcff66}.panel-button-primary:disabled{opacity:.5;cursor:not-allowed}.panel-button-danger{border-color:#ff7c7c66;color:var(--danger)}.panel-button-danger:hover{background:#ff7c7c26;border-color:#ff7c7c99}.panel-divider{margin:16px 0;border:none;border-top:1px solid var(--panel-border)}.panel-link{background:none;border:none;padding:0;color:var(--accent);font-size:13px;cursor:pointer;text-decoration:none;transition:opacity .15s}.panel-link:hover{opacity:.8;text-decoration:underline}.panel-advanced{margin-top:16px;padding-top:16px;border-top:1px solid var(--panel-border)}.scene-studio-preset-selector{position:relative}.scene-studio-preset-selector-button{display:flex;align-items:center;gap:8px;padding:6px 12px;min-width:160px;font-size:11px;font-weight:500;border:1px solid rgba(88,214,255,.25);border-radius:6px;background:#0a1018b3;color:var(--text-primary);cursor:pointer;transition:all .15s ease}.scene-studio-preset-selector-button:hover,.scene-studio-preset-selector-button.is-open{border-color:#58d6ff80;background:#141e28cc}.scene-studio-preset-selector-button:disabled{opacity:.5;cursor:not-allowed}.scene-studio-preset-selector-label{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scene-studio-preset-selector-arrow{font-size:8px;opacity:.6}.scene-studio-modified-badge{padding:2px 6px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:#ffb43233;border:1px solid rgba(255,180,50,.4);border-radius:4px;color:#ffc864e6}.scene-studio-preset-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:220px;max-height:320px;overflow-y:auto;background:#080e16fa;border:1px solid rgba(88,214,255,.25);border-radius:8px;box-shadow:0 8px 32px #00000080;z-index:100}.scene-studio-preset-dropdown-section{padding:8px 12px 4px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#58d6ff99;border-top:1px solid rgba(88,214,255,.1)}.scene-studio-preset-dropdown-section:first-child{border-top:none}.scene-studio-preset-dropdown-item{display:flex;flex-direction:column;gap:2px;width:100%;padding:8px 12px;text-align:left;background:transparent;border:none;cursor:pointer;transition:background .12s ease}.scene-studio-preset-dropdown-item:hover{background:#58d6ff1a}.scene-studio-preset-dropdown-item.is-selected{background:#00d4ff26}.scene-studio-preset-dropdown-item.is-selected .scene-studio-preset-dropdown-name{color:#00d4ff}.scene-studio-preset-dropdown-name{font-size:12px;font-weight:500;color:var(--text-primary)}.scene-studio-preset-dropdown-desc{font-size:10px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scene-studio-preset-dropdown-empty{padding:16px 12px;text-align:center;font-size:11px;color:var(--text-muted)}.scene-studio-actions-menu{position:relative}.scene-studio-actions-button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;font-size:16px;border:1px solid rgba(88,214,255,.25);border-radius:6px;background:#0a1018b3;color:var(--text-primary);cursor:pointer;transition:all .15s ease}.scene-studio-actions-button:hover,.scene-studio-actions-button.is-open{border-color:#58d6ff80;background:#141e28cc}.scene-studio-actions-icon{line-height:1}.scene-studio-actions-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:180px;background:#080e16fa;border:1px solid rgba(88,214,255,.25);border-radius:8px;box-shadow:0 8px 32px #00000080;z-index:100;overflow:hidden}.scene-studio-actions-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;font-size:11px;text-align:left;background:transparent;border:none;color:var(--text-primary);cursor:pointer;transition:background .12s ease}.scene-studio-actions-item:hover:not(:disabled){background:#58d6ff1a}.scene-studio-actions-item:disabled{opacity:.4;cursor:not-allowed}.scene-studio-actions-item-icon{width:16px;text-align:center;font-size:12px;opacity:.7}.scene-studio-actions-item-danger{color:#ff7878e6}.scene-studio-actions-item-danger:hover:not(:disabled){background:#ff505026}.scene-studio-actions-divider{height:1px;margin:4px 0;background:#58d6ff1a}.scene-studio-dialog-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000}.scene-studio-dialog{width:100%;max-width:400px;background:#0a1018fa;border:1px solid rgba(88,214,255,.25);border-radius:12px;box-shadow:0 16px 64px #00000080}.scene-studio-dialog-wide{max-width:500px}.scene-studio-dialog-header{padding:16px 20px 12px;border-bottom:1px solid rgba(88,214,255,.1)}.scene-studio-dialog-title{margin:0;font-size:14px;font-weight:600;color:var(--text-primary)}.scene-studio-dialog-body{padding:16px 20px}.scene-studio-dialog-message{margin:0;font-size:13px;line-height:1.5;color:var(--text)}.scene-studio-dialog-field{margin-bottom:16px}.scene-studio-dialog-field:last-child{margin-bottom:0}.scene-studio-dialog-label{display:block;margin-bottom:6px;font-size:11px;font-weight:500;color:var(--text-muted)}.scene-studio-dialog-required{color:#ff7878cc}.scene-studio-dialog-input{width:100%;padding:8px 12px;font-size:13px;font-family:inherit;background:#060a12cc;border:1px solid rgba(88,214,255,.2);border-radius:6px;color:var(--text-primary);transition:border-color .15s ease}.scene-studio-dialog-input:focus{outline:none;border-color:#58d6ff80}.scene-studio-dialog-textarea{width:100%;padding:8px 12px;font-size:13px;font-family:inherit;background:#060a12cc;border:1px solid rgba(88,214,255,.2);border-radius:6px;color:var(--text-primary);resize:vertical;min-height:60px;transition:border-color .15s ease}.scene-studio-dialog-textarea:focus{outline:none;border-color:#58d6ff80}.scene-studio-dialog-textarea-code{font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px;min-height:120px}.scene-studio-dialog-error{display:block;margin-top:6px;font-size:11px;color:#ff7878e6}.scene-studio-dialog-file{width:100%;padding:8px;font-size:12px;font-family:inherit;background:#060a12cc;border:1px dashed rgba(88,214,255,.3);border-radius:6px;color:var(--text);cursor:pointer}.scene-studio-dialog-file:hover{border-color:#58d6ff80}.scene-studio-dialog-divider{display:flex;align-items:center;gap:12px;margin:16px 0;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.scene-studio-dialog-divider:before,.scene-studio-dialog-divider:after{content:"";flex:1;height:1px;background:#58d6ff26}.scene-studio-dialog-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px 16px;border-top:1px solid rgba(88,214,255,.1)}.scene-studio-dialog-button{padding:8px 16px;font-size:12px;font-weight:500;border:1px solid rgba(88,214,255,.25);border-radius:6px;background:#0a1018b3;color:var(--text-primary);cursor:pointer;transition:all .15s ease}.scene-studio-dialog-button:hover:not(:disabled){border-color:#58d6ff80;background:#141e28cc}.scene-studio-dialog-button:disabled{opacity:.5;cursor:not-allowed}.scene-studio-dialog-button-primary{border-color:#00d4ff80;background:linear-gradient(135deg,#00d4ff40,#0078ff1a);color:#e0f8ff}.scene-studio-dialog-button-primary:hover:not(:disabled){border-color:#00d4ffb3;background:linear-gradient(135deg,#00d4ff59,#0078ff33)}.scene-studio-dialog-button-danger{border-color:#ff646466;background:#3c141480;color:#ff9696f2}.scene-studio-dialog-button-danger:hover:not(:disabled){border-color:#ff646499;background:#50141499}.scene-studio-dialog-button-warning{border-color:#ffb43266;background:#3c280a80;color:#ffc864f2}.scene-studio-dialog-button-warning:hover:not(:disabled){border-color:#ffb43299;background:#50320a99}.scene-studio-export-status--error{background:#ff64641a;color:#ff9696e6;cursor:pointer}.devices-page-layout{display:grid;grid-template-columns:320px 1fr 360px;gap:16px;height:100%;flex:1;min-height:0}@media(max-width:1200px){.devices-page-layout{grid-template-columns:280px 1fr}.devices-page-layout .attach-inspector{position:fixed;right:0;top:60px;bottom:0;z-index:50;border-radius:16px 0 0 16px;transform:translate(100%);transition:transform .3s ease}.devices-page-layout .attach-inspector.is-open{transform:translate(0)}}@media(max-width:768px){.devices-page-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr}.devices-page-layout .device-library{max-width:none;max-height:300px}.devices-page-layout .attach-canvas-wrapper{min-height:400px}}.device-library{display:flex;flex-direction:column;height:100%;min-width:320px;max-width:360px;border-radius:16px;border:1px solid rgba(88,214,255,.22);background:linear-gradient(155deg,#121e2ec2,#080e169e);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);overflow:hidden}.device-library-header{padding:16px;border-bottom:1px solid rgba(88,214,255,.15)}.device-library-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#58d6ff;margin:0 0 12px}.counter-chips{display:flex;flex-wrap:wrap;gap:8px}.counter-chip{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:#080e1699;border:1px solid rgba(88,214,255,.2);font-size:11px}.counter-chip-dot{width:6px;height:6px;border-radius:50%}.counter-chip-dot--unassigned{background:#facc15;box-shadow:0 0 8px #facc1580}.counter-chip-dot--assigned{background:#4ade80;box-shadow:0 0 8px #4ade8080}.counter-chip-dot--offline{background:#ef4444;box-shadow:0 0 8px #ef444480}.counter-chip-dot--warning{background:#f97316;box-shadow:0 0 8px #f9731680}.counter-chip-label{color:#8ba6ba}.counter-chip-count{color:#e1f6ff;font-weight:600}.device-filters{padding:12px 16px;border-bottom:1px solid rgba(88,214,255,.1);display:flex;flex-direction:column;gap:10px}.device-filters-search{position:relative}.device-filters-input{width:100%;padding:8px 32px 8px 12px;border-radius:10px;border:1px solid rgba(88,214,255,.25);background:#070c12bf;color:#e1f6ff;font-size:12px}.device-filters-input::placeholder{color:#8ba6ba}.device-filters-input:focus{outline:none;border-color:#58d6ff99;box-shadow:0 0 0 2px #66dcff26}.device-filters-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:#8ba6ba;font-size:16px;cursor:pointer;padding:2px 6px}.device-filters-clear:hover{color:#e1f6ff}.device-filters-row{display:flex;gap:8px}.device-filters-select{flex:1;min-width:0;padding:6px 8px;border-radius:8px;border:1px solid rgba(88,214,255,.25);background:#070c12bf;color:#e1f6ff;font-size:11px}.device-filters-select:focus{outline:none;border-color:#58d6ff99}.device-filters-sort{display:flex;align-items:center;gap:8px}.device-filters-sort-label{font-size:11px;color:#8ba6ba}.device-filters-sort-chips{display:flex;gap:4px;flex-wrap:wrap}.device-filters-sort-chip{padding:4px 8px;border-radius:6px;border:1px solid rgba(88,214,255,.2);background:transparent;color:#8ba6ba;font-size:10px;cursor:pointer;transition:all .15s ease}.device-filters-sort-chip:hover{border-color:#58d6ff66;color:#e1f6ff}.device-filters-sort-chip--active{border-color:#58d6ffb3;background:#58d6ff26;color:#e1f6ff}.device-library-content{flex:1;overflow-y:auto;padding:12px}.device-library-section{margin-bottom:16px}.device-library-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding:0 4px}.device-library-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#8ba6ba}.device-library-section-count{font-size:11px;color:#58d6ff;font-weight:600}.device-library-empty{padding:24px 16px;text-align:center;color:#8ba6ba;font-size:12px}.device-library-error{padding:16px;text-align:center;color:#ef4444;font-size:12px;background:#ef44441a;border-radius:8px;border:1px solid rgba(239,68,68,.2)}.device-library-grid{display:flex;flex-direction:column;gap:8px}.device-library-rooms{display:flex;flex-direction:column;gap:12px}.device-library-room-group{border-radius:10px;border:1px solid rgba(88,214,255,.15);background:#080e1666;overflow:hidden}.device-library-room-title{padding:8px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#58d6ff;background:#58d6ff14;border-bottom:1px solid rgba(88,214,255,.1)}.device-library-room-list{display:flex;flex-direction:column}.device-card-v2{display:grid;grid-template-columns:40px 1fr auto;gap:10px;align-items:center;padding:10px 12px;border-radius:12px;border:1px solid rgba(88,214,255,.18);background:linear-gradient(135deg,#0a101ac7,#080c14ad);cursor:pointer;transition:all .15s ease;text-align:left;width:100%}.device-card-v2:hover{border-color:#58d6ff66;background:linear-gradient(135deg,#101824e6,#0a101acc);transform:translateY(-1px)}.device-card-v2--selected{border-color:#58d6ffbf;background:#58d6ff1f;box-shadow:0 0 16px #58d6ff33}.device-card-v2-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;background:#080e16bf;border:1px solid rgba(88,214,255,.25)}.device-card-v2-icon--temperature{color:#f97316;border-color:#f9731666}.device-card-v2-icon--door{color:#facc15;border-color:#facc1566}.device-card-v2-icon--motion{color:#a78bfa;border-color:#a78bfa66}.device-card-v2-icon--light{color:#fbbf24;border-color:#fbbf2466}.device-card-v2-icon--switch{color:#60a5fa;border-color:#60a5fa66}.device-card-v2-icon--other{color:#8ba6ba;border-color:#8ba6ba66}.device-card-v2-info{min-width:0;display:flex;flex-direction:column;gap:2px}.device-card-v2-name{font-size:13px;font-weight:500;color:#e1f6ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.device-card-v2-meta{display:flex;flex-direction:column;gap:1px}.device-card-v2-entity{font-size:10px;color:#6b8a9f;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.device-card-v2-assignment{font-size:10px;color:#58d6ff}.device-card-v2-chips{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.device-card-v2-status{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border-radius:4px}.device-card-v2-status--on{background:#4ade8033;color:#4ade80}.device-card-v2-status--off{background:#8ba6ba33;color:#8ba6ba}.device-card-v2-status--offline{background:#ef444433;color:#ef4444}.device-card-v2-status--unknown{background:#facc1533;color:#facc15}.device-card-v2-battery,.device-card-v2-time{font-size:9px;color:#6b8a9f}.device-card-v2-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.device-card-v2-value{font-size:14px;font-weight:600;color:#e1f6ff;font-family:Space Grotesk,monospace}.device-card-v2-actions{display:flex;gap:6px}.device-card-v2-attach,.device-card-v2-drag{font-size:10px;color:#58d6ff;padding:2px 6px;border-radius:4px;background:#58d6ff1a;cursor:pointer;transition:all .15s ease}.device-card-v2-attach:hover,.device-card-v2-drag:hover{background:#58d6ff40}.device-card-v2-drag{cursor:grab}.device-card-v2-drag:active{cursor:grabbing}.device-row-v2{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid rgba(88,214,255,.08);background:transparent;cursor:pointer;transition:background .15s ease;text-align:left;width:100%;border:none;color:inherit}.device-row-v2:last-child{border-bottom:none}.device-row-v2:hover{background:#58d6ff14}.device-row-v2--selected{background:#58d6ff26}.device-row-v2-left{display:flex;align-items:center;gap:10px;min-width:0}.device-row-v2-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;background:#080e1699;flex-shrink:0}.device-row-v2-icon--temperature{color:#f97316}.device-row-v2-icon--door{color:#facc15}.device-row-v2-icon--motion{color:#a78bfa}.device-row-v2-icon--light{color:#fbbf24}.device-row-v2-icon--switch{color:#60a5fa}.device-row-v2-icon--other{color:#8ba6ba}.device-row-v2-info{display:flex;align-items:center;gap:8px;min-width:0}.device-row-v2-name{font-size:12px;color:#e1f6ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.device-row-v2-status{font-size:9px;font-weight:600;text-transform:uppercase;padding:2px 5px;border-radius:4px}.device-row-v2-status--on{background:#4ade8033;color:#4ade80}.device-row-v2-status--off{background:#8ba6ba33;color:#8ba6ba}.device-row-v2-status--offline{background:#ef444433;color:#ef4444}.device-row-v2-status--unknown{background:#facc1533;color:#facc15}.device-row-v2-value{font-size:13px;font-weight:600;color:#e1f6ff;font-family:Space Grotesk,monospace}.attach-canvas{display:flex;flex-direction:column;flex:1;min-width:0;height:100%;border-radius:16px;border:1px solid rgba(88,214,255,.22);background:linear-gradient(155deg,#0c1420d9,#060a10bf);overflow:hidden;position:relative}.canvas-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 16px;background:#080e1699;border-bottom:1px solid rgba(88,214,255,.15);flex-wrap:wrap}.canvas-toolbar-group{display:flex;align-items:center;gap:8px}.canvas-toolbar-group--right{margin-left:auto}.canvas-toolbar-label{font-size:11px;color:#8ba6ba;text-transform:uppercase;letter-spacing:.05em}.canvas-toolbar-select{padding:6px 10px;border-radius:8px;border:1px solid rgba(88,214,255,.25);background:#070c12bf;color:#e1f6ff;font-size:12px;min-width:120px}.canvas-toolbar-select:focus{outline:none;border-color:#58d6ff99}.canvas-toolbar-toggles{display:flex;gap:4px}.canvas-toolbar-toggle{padding:5px 10px;border-radius:6px;border:1px solid rgba(88,214,255,.2);background:transparent;color:#8ba6ba;font-size:11px;cursor:pointer;transition:all .15s ease}.canvas-toolbar-toggle:hover{border-color:#58d6ff66;color:#e1f6ff}.canvas-toolbar-toggle--active{border-color:#58d6ffb3;background:#58d6ff26;color:#58d6ff}.canvas-toolbar-btn{padding:6px 12px;border-radius:8px;border:1px solid rgba(88,214,255,.3);background:#091018bf;color:#e1f6ff;font-size:11px;cursor:pointer;transition:all .15s ease}.canvas-toolbar-btn:hover{border-color:#58d6ff99;background:#58d6ff1a}.canvas-toolbar-status{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;background:#080e1699;font-size:11px}.canvas-toolbar-status-dot{width:6px;height:6px;border-radius:50%}.canvas-toolbar-status--connected .canvas-toolbar-status-dot{background:#4ade80;box-shadow:0 0 8px #4ade8080}.canvas-toolbar-status--connected .canvas-toolbar-status-text{color:#4ade80}.canvas-toolbar-status--reconnecting .canvas-toolbar-status-dot{background:#facc15;box-shadow:0 0 8px #facc1580;animation:pulse 1.5s ease-in-out infinite}.canvas-toolbar-status--reconnecting .canvas-toolbar-status-text{color:#facc15}.canvas-toolbar-status--disconnected .canvas-toolbar-status-dot{background:#ef4444;box-shadow:0 0 8px #ef444480}.canvas-toolbar-status--disconnected .canvas-toolbar-status-text{color:#ef4444}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.attach-canvas-hint{padding:8px 16px;text-align:center;font-size:12px;color:#8ba6ba;background:#080e1666;border-bottom:1px solid rgba(88,214,255,.1);transition:all .2s ease}.attach-canvas-hint--active{background:#58d6ff1a;color:#58d6ff;border-bottom-color:#58d6ff33}.attach-canvas-scene{flex:1;position:relative;min-height:0}.attach-canvas-scene canvas{width:100%!important;height:100%!important}.attach-canvas-placement-overlay{position:absolute;bottom:16px;left:50%;transform:translate(-50%);padding:8px 16px;border-radius:8px;background:#58d6ff26;border:1px solid rgba(88,214,255,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none}.attach-canvas-placement-text{font-size:12px;color:#58d6ff}.attach-canvas-wrapper{flex:1;min-width:0;position:relative;display:flex;flex-direction:column}.device-quick-menu{position:absolute;z-index:100;min-width:120px;padding:4px;border-radius:10px;border:1px solid rgba(88,214,255,.3);background:#0c1420f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 24px #0006}.device-quick-menu button{width:100%;padding:8px 12px;border:none;background:transparent;color:#e1f6ff;font-size:12px;text-align:left;cursor:pointer;border-radius:6px;transition:background .15s ease}.device-quick-menu button:hover{background:#58d6ff26}.device-quick-menu button.danger{color:#ef4444}.device-quick-menu button.danger:hover{background:#ef444426}.scene-placement-error{position:absolute;bottom:16px;left:50%;transform:translate(-50%);padding:10px 20px;border-radius:8px;background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#ef4444;font-size:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeInUp .2s ease}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.attach-inspector{display:flex;flex-direction:column;height:100%;min-width:320px;max-width:380px;border-radius:16px;border:1px solid rgba(88,214,255,.22);background:linear-gradient(155deg,#121e2ec2,#080e169e);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);overflow:hidden}.attach-inspector-header{padding:16px;border-bottom:1px solid rgba(88,214,255,.15)}.attach-inspector-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#58d6ff;margin:0 0 4px}.attach-inspector-hint{font-size:11px;color:#8ba6ba}.attach-inspector-guide{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:#080e1680;border-bottom:1px solid rgba(88,214,255,.1)}.attach-guide-step{font-size:11px;color:#6b8a9f;padding:3px 8px;border-radius:4px;transition:all .15s ease}.attach-guide-step--active{color:#58d6ff;background:#58d6ff26}.attach-guide-step--done{color:#4ade80}.attach-guide-arrow{color:#6b8a9f;font-size:10px}.attach-inspector-content{flex:1;overflow-y:auto;padding:16px}.attach-stepper{display:flex;flex-direction:column;gap:16px}.attach-stepper-indicators{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:#080e1666;border-radius:10px}.attach-step-indicator{display:flex;flex-direction:column;align-items:center;gap:4px}.attach-step-number{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;background:#58d6ff1a;border:1px solid rgba(88,214,255,.3);color:#8ba6ba;transition:all .15s ease}.attach-step-indicator--active .attach-step-number{background:#58d6ff40;border-color:#58d6ff;color:#58d6ff;box-shadow:0 0 12px #58d6ff4d}.attach-step-indicator--completed .attach-step-number{background:#4ade8033;border-color:#4ade80;color:#4ade80}.attach-step-label{font-size:9px;text-transform:uppercase;letter-spacing:.05em;color:#6b8a9f}.attach-step-indicator--active .attach-step-label{color:#58d6ff}.attach-step-indicator--completed .attach-step-label{color:#4ade80}.attach-stepper-line{flex:1;height:1px;background:#58d6ff33;max-width:40px}.attach-feedback{padding:10px 14px;border-radius:8px;font-size:12px;text-align:center;animation:fadeIn .2s ease}.attach-feedback--success{background:#4ade8026;border:1px solid rgba(74,222,128,.3);color:#4ade80}.attach-feedback--error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#ef4444}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.attach-stepper-content{display:flex;flex-direction:column;gap:12px}.attach-stepper-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px 16px;text-align:center}.attach-stepper-empty-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;background:#58d6ff1a;border:2px dashed rgba(88,214,255,.3);color:#58d6ff}.attach-stepper-empty-text{font-size:13px;color:#8ba6ba;max-width:200px}.attach-stepper-section{padding:12px;border-radius:10px;background:#080e1666;border:1px solid rgba(88,214,255,.1)}.attach-stepper-section-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.attach-stepper-section-number{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;background:#58d6ff33;color:#58d6ff}.attach-stepper-section-title{font-size:12px;font-weight:600;color:#e1f6ff}.attach-stepper-hint{font-size:11px;color:#8ba6ba;font-style:italic;padding:8px 0}.attach-stepper-change{margin-top:8px;padding:4px 8px;border:none;background:transparent;color:#58d6ff;font-size:11px;cursor:pointer;text-decoration:underline}.attach-stepper-change:hover{color:#7de8ff}.attach-device-summary{display:flex;gap:12px;align-items:flex-start}.attach-device-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;background:#080e16bf;border:1px solid rgba(88,214,255,.25);flex-shrink:0}.attach-device-icon--temperature{color:#f97316;border-color:#f9731666}.attach-device-icon--door{color:#facc15;border-color:#facc1566}.attach-device-icon--motion{color:#a78bfa;border-color:#a78bfa66}.attach-device-icon--light{color:#fbbf24;border-color:#fbbf2466}.attach-device-icon--switch{color:#60a5fa;border-color:#60a5fa66}.attach-device-icon--other{color:#8ba6ba;border-color:#8ba6ba66}.attach-device-info{flex:1;min-width:0}.attach-device-name{font-size:13px;font-weight:500;color:#e1f6ff;margin-bottom:2px}.attach-device-entity{font-size:10px;color:#6b8a9f;margin-bottom:6px}.attach-device-state{display:flex;align-items:center;gap:8px}.attach-device-status{font-size:9px;font-weight:600;text-transform:uppercase;padding:2px 6px;border-radius:4px}.attach-device-status--on{background:#4ade8033;color:#4ade80}.attach-device-status--off{background:#8ba6ba33;color:#8ba6ba}.attach-device-status--offline{background:#ef444433;color:#ef4444}.attach-device-status--unknown{background:#facc1533;color:#facc15}.attach-device-value{font-size:12px;font-weight:600;color:#e1f6ff;font-family:Space Grotesk,monospace}.attach-target-selector{display:flex;flex-direction:column;gap:8px}.attach-target-label{font-size:11px;color:#8ba6ba}.attach-target-options{display:flex;flex-direction:column;gap:6px}.attach-target-option{display:flex;flex-direction:column;gap:2px;padding:10px 12px;border-radius:8px;border:1px solid rgba(88,214,255,.2);background:#080e1666;cursor:pointer;text-align:left;transition:all .15s ease}.attach-target-option:hover{border-color:#58d6ff66;background:#58d6ff14}.attach-target-option--selected{border-color:#58d6ffb3;background:#58d6ff26}.attach-target-option-label{font-size:12px;font-weight:500;color:#e1f6ff}.attach-target-option-desc{font-size:10px;color:#8ba6ba}.attach-target-summary{display:flex;gap:12px;align-items:center}.attach-target-summary-type{padding:6px 10px;border-radius:6px;background:#58d6ff26;color:#58d6ff;font-size:11px;font-weight:600;text-transform:uppercase}.attach-target-summary-info{flex:1}.attach-target-summary-label{font-size:12px;font-weight:500;color:#e1f6ff}.attach-target-summary-room,.attach-target-summary-floor{font-size:10px;color:#8ba6ba}.attach-stepper-actions{display:flex;gap:8px;margin-top:8px}.attach-stepper-btn{flex:1;padding:10px 16px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease}.attach-stepper-btn--primary{border:1px solid rgba(88,214,255,.5);background:linear-gradient(135deg,#58d6ff40,#58d6ff1a);color:#e1f6ff}.attach-stepper-btn--primary:hover{border-color:#58d6ffb3;background:linear-gradient(135deg,#58d6ff59,#58d6ff33)}.attach-stepper-btn--secondary{border:1px solid rgba(88,214,255,.2);background:transparent;color:#8ba6ba}.attach-stepper-btn--secondary:hover{border-color:#58d6ff66;color:#e1f6ff}.attach-stepper-footer{padding-top:12px;border-top:1px solid rgba(88,214,255,.1);margin-top:8px}.attach-stepper-clear{width:100%;padding:8px 16px;border:1px solid rgba(88,214,255,.15);background:transparent;color:#8ba6ba;font-size:11px;border-radius:6px;cursor:pointer;transition:all .15s ease}.attach-stepper-clear:hover{border-color:#58d6ff4d;color:#e1f6ff}.attach-inspector-settings{margin-top:16px;padding-top:16px;border-top:1px solid rgba(88,214,255,.15)}.attach-inspector-settings-header{margin-bottom:12px}.attach-inspector-settings-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#8ba6ba}.attach-inspector-row{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.attach-inspector-label{font-size:11px;color:#8ba6ba}.attach-inspector-input,.attach-inspector-select{padding:8px 10px;border-radius:8px;border:1px solid rgba(88,214,255,.25);background:#070c12bf;color:#e1f6ff;font-size:12px}.attach-inspector-input:focus,.attach-inspector-select:focus{outline:none;border-color:#58d6ff99}.attach-inspector-value{font-size:12px;color:#e1f6ff;word-break:break-all}.attach-inspector-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#58d6ff;margin:16px 0 8px}.attach-inspector-color-row{display:flex;gap:8px;align-items:center}.attach-inspector-color{width:40px;height:32px;border-radius:6px;border:1px solid rgba(88,214,255,.25);padding:2px;cursor:pointer}.attach-inspector-btn-small{padding:6px 10px;border-radius:6px;border:1px solid rgba(88,214,255,.2);background:transparent;color:#8ba6ba;font-size:10px;cursor:pointer;transition:all .15s ease}.attach-inspector-btn-small:hover{border-color:#58d6ff66;color:#e1f6ff}.attach-inspector-range{width:100%;accent-color:#58d6ff}.attach-inspector-actions{margin-top:16px}.attach-inspector-btn{width:100%;padding:10px 16px;border-radius:8px;font-size:12px;cursor:pointer;transition:all .15s ease}.attach-inspector-btn--danger{border:1px solid rgba(239,68,68,.3);background:#ef44441a;color:#ef4444}.attach-inspector-btn--danger:hover{border-color:#ef444480;background:#ef444433}.attach-inspector-toggle{width:100%;padding:8px;margin-top:12px;border:none;background:transparent;color:#58d6ff;font-size:11px;cursor:pointer;text-decoration:underline}.attach-inspector-toggle:hover{color:#7de8ff}.attach-inspector-advanced{margin-top:12px;padding:12px;border-radius:8px;background:#080e1666}.attach-inspector-json{font-size:10px;font-family:monospace;color:#8ba6ba;white-space:pre-wrap;word-break:break-all;max-height:200px;overflow-y:auto;padding:8px;border-radius:6px;background:#0003;margin-top:8px}._panel_1olj6_9{display:flex;flex-direction:column;width:280px;min-width:280px;flex-shrink:0;height:100%;background:#080f19d9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid rgba(88,214,255,.15);color:#d7f5ff;overflow:hidden;z-index:10}._panelHeader_1olj6_24{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid rgba(88,214,255,.1)}._panelTitle_1olj6_32{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#58d6ff}._closeButton_1olj6_40{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#ffffff0d;border:1px solid rgba(88,214,255,.2);border-radius:6px;color:#d7f5ff99;cursor:pointer;transition:all .15s ease}._closeButton_1olj6_40:hover{background:#ffffff1a;color:#d7f5ff}._panelContent_1olj6_59{flex:1;overflow-y:auto;padding:16px}._palette_1olj6_66{display:flex;flex-direction:column;gap:12px}._paletteTitle_1olj6_72{font-size:13px;font-weight:500;color:#d7f5ffcc;margin:0}._paletteHint_1olj6_79{font-size:11px;color:#d7f5ff80;margin:0;line-height:1.4}._blockGrid_1olj6_86{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}._blockCard_1olj6_94{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 8px;background:#ffffff08;border:1px solid rgba(88,214,255,.15);border-radius:8px;cursor:grab;transition:all .15s ease}._blockCard_1olj6_94:hover{background:#58d6ff1a;border-color:#58d6ff4d;transform:translateY(-2px)}._blockCard_1olj6_94:active{cursor:grabbing;transform:translateY(0)}._blockIcon_1olj6_118{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#58d6ff1a;border-radius:8px;color:#58d6ff}._blockInfo_1olj6_129{display:flex;flex-direction:column;align-items:center;gap:2px}._blockName_1olj6_136{font-size:11px;font-weight:500;color:#d7f5ffe6;text-align:center}._blockSize_1olj6_143{font-size:10px;color:#d7f5ff66}._inspector_1olj6_149{display:flex;flex-direction:column;height:100%}._inspectorHeader_1olj6_155{display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:1px solid rgba(88,214,255,.1);margin-bottom:16px}._backButton_1olj6_164{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#ffffff0d;border:1px solid rgba(88,214,255,.2);border-radius:6px;color:#d7f5ff99;cursor:pointer;transition:all .15s ease}._backButton_1olj6_164:hover{background:#ffffff1a;color:#d7f5ff}._inspectorTitle_1olj6_183{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#d7f5ff}._inspectorTitle_1olj6_183 svg{color:#58d6ff}._inspectorContent_1olj6_196{display:flex;flex-direction:column;gap:16px;flex:1;overflow-y:auto}._inspectorSection_1olj6_204{display:flex;flex-direction:column;gap:8px}._sectionLabel_1olj6_210{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.03em;color:#d7f5ff80}._select_1olj6_219{width:100%;padding:10px 32px 10px 12px;background:#ffffff0d;border:1px solid rgba(88,214,255,.2);border-radius:6px;color:#d7f5ff;font-size:13px;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%2358d6ff' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}._select_1olj6_219:focus{outline:none;border-color:#58d6ff;box-shadow:0 0 0 2px #58d6ff26}._select_1olj6_219 option{background:#0a1520;color:#d7f5ff}._textInput_1olj6_246{width:100%;padding:10px 12px;background:#ffffff0d;border:1px solid rgba(88,214,255,.2);border-radius:6px;color:#d7f5ff;font-size:13px}._textInput_1olj6_246:focus{outline:none;border-color:#58d6ff;box-shadow:0 0 0 2px #58d6ff26}._textInput_1olj6_246::placeholder{color:#d7f5ff4d}._sizeSelector_1olj6_267{display:flex;gap:8px}._sizeButton_1olj6_272{flex:1;padding:10px;background:#ffffff0d;border:1px solid rgba(88,214,255,.2);border-radius:6px;color:#d7f5ff99;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}._sizeButton_1olj6_272:hover{background:#58d6ff1a;color:#d7f5ff}._sizeButtonActive_1olj6_290{background:#58d6ff33;border-color:#58d6ff;color:#58d6ff}._deleteButton_1olj6_297{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;background:#f871711a;border:1px solid rgba(248,113,113,.3);border-radius:6px;color:#f87171;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease;margin-top:auto}._deleteButton_1olj6_297:hover{background:#f8717133;border-color:#f8717180}._blocksList_1olj6_321{display:flex;flex-direction:column;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid rgba(88,214,255,.1)}._blocksListTitle_1olj6_330{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.03em;color:#d7f5ff80;margin-bottom:4px}._blockListItem_1olj6_339{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#ffffff08;border:1px solid rgba(88,214,255,.1);border-radius:6px;cursor:pointer;transition:all .15s ease}._blockListItem_1olj6_339:hover{background:#58d6ff14;border-color:#58d6ff33}._blockListItemActive_1olj6_356{background:#58d6ff26;border-color:#58d6ff66}._blockListItemIcon_1olj6_361{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#58d6ff1a;border-radius:6px;color:#58d6ff}._blockListItemInfo_1olj6_372{flex:1;min-width:0}._blockListItemName_1olj6_377{font-size:12px;font-weight:500;color:#d7f5ffe6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}._blockListItemMeta_1olj6_386{font-size:10px;color:#d7f5ff66}._emptyState_1olj6_392{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;text-align:center;color:#d7f5ff66}._emptyStateIcon_1olj6_402{width:48px;height:48px;margin-bottom:12px;color:#58d6ff4d}._emptyStateText_1olj6_409{font-size:12px;line-height:1.5;margin-bottom:12px}._autoPopulateButton_1olj6_416{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:#58d6ff26;border:1px solid rgba(88,214,255,.4);border-radius:6px;color:#58d6ff;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease}._autoPopulateButton_1olj6_416:hover{background:#58d6ff40;border-color:#58d6ff99;transform:translateY(-1px)}._autoPopulateButton_1olj6_416:active{transform:translateY(0)}._cleanupSection_1olj6_443{margin-top:16px;padding-top:16px;border-top:1px solid rgba(88,214,255,.1)}._cleanupButton_1olj6_449{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px;background:#fbbf241a;border:1px solid rgba(251,191,36,.3);border-radius:6px;color:#fbbf24;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease}._cleanupButton_1olj6_449:hover{background:#fbbf2433;border-color:#fbbf2480}._cleanupButton_1olj6_449:disabled{opacity:.5;cursor:not-allowed}._blockListItemInvalid_1olj6_477{border-color:#f8717166}._blockListItemInvalid_1olj6_477 ._blockListItemIcon_1olj6_361{background:#f8717133;color:#f87171}._invalidBadge_1olj6_486{font-size:9px;padding:2px 6px;background:#f8717133;border-radius:4px;color:#f87171;margin-left:auto}._blockListItemWarning_1olj6_496{border-color:#fbbf244d}._blockListItemWarning_1olj6_496 ._blockListItemIcon_1olj6_361{background:#fbbf2426;color:#fbbf24}._blockListItemWarning_1olj6_496 ._blockListItemMeta_1olj6_386{color:#fbbf24b3}._warningBadge_1olj6_509{display:flex;align-items:center;justify-content:center;width:18px;height:18px;font-size:11px;font-weight:700;background:#fbbf2433;border-radius:50%;color:#fbbf24;margin-left:auto}.page--overlay-studio{display:flex;flex-direction:column;height:100%;background:#040a12;padding:0!important;gap:0!important}.page--overlay-studio .page-toolbar{display:flex;align-items:baseline;gap:16px;padding:16px 24px;border-bottom:1px solid rgba(88,214,255,.1)}.page--overlay-studio .page-title{font-size:18px;font-weight:600;color:#d7f5ff}.page--overlay-studio .page-subtitle{font-size:13px;color:#d7f5ff80}.page-body--overlay-studio{display:flex;flex-direction:row!important;flex:1;min-height:0;gap:0!important;overflow:hidden}.overlay-studio-scene{flex:1;min-width:0;position:relative;background:#040a12}.overlay-studio-scene .home-scene{position:absolute;inset:0}.overlay-studio-scene canvas{display:block;width:100%;height:100%}.page--overlay-studio .page-toolbar-spacer{flex:1}.save-status{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:#d7f5ff99;min-height:20px;padding:4px 10px;border-radius:12px;background:#58d6ff0f;transition:all .3s ease}.save-status--saving{color:#d7f5ffcc}.save-status--saved{color:#4ade80e6;background:#4ade801a}.save-status--error{color:#f87171e6;background:#f871711a}.save-status--idle{opacity:0;pointer-events:none}.save-status-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.save-status-dot--pulse{animation:savePulse 1s ease-in-out infinite}.save-status-dot--success{background:#4ade80}.save-status-dot--error{background:#f87171}@keyframes savePulse{0%,to{opacity:.4}50%{opacity:1}}.device-fallback{display:flex;align-items:center;justify-content:center;min-height:100%;padding:24px;box-sizing:border-box}.device-fallback__card{max-width:480px;padding:32px;background:#1e202cf2;border:1px solid rgba(255,255,255,.1);border-radius:16px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);text-align:center}.device-fallback__icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:0 auto 24px;background:#ff6b6b1a;border-radius:50%;color:#ff6b6b}.device-fallback__title{margin:0 0 12px;font-size:24px;font-weight:600;color:#fff}.device-fallback__message{margin:0 0 24px;font-size:15px;line-height:1.5;color:#ffffffb3}.device-fallback__requirements{padding:16px;background:#0003;border-radius:12px;text-align:left;margin-bottom:20px}.device-fallback__requirements h3{margin:0 0 12px;font-size:14px;font-weight:600;color:#ffffffe6;text-transform:uppercase;letter-spacing:.5px}.device-fallback__requirements ul{margin:0;padding:0;list-style:none}.device-fallback__requirements li{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:14px;color:#fffc;border-bottom:1px solid rgba(255,255,255,.05)}.device-fallback__requirements li:last-child{border-bottom:none}.requirement-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:#7dffb5}.device-fallback__tip{padding:12px 16px;background:#7dffb51a;border:1px solid rgba(125,255,181,.2);border-radius:8px;font-size:13px;line-height:1.5;color:#fffc;text-align:left;margin-bottom:24px}.device-fallback__tip strong{color:#7dffb5}.device-fallback__actions{display:flex;flex-direction:column;gap:12px}.device-fallback__button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 24px;font-size:15px;font-weight:500;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease}.device-fallback__button--primary{background:linear-gradient(135deg,#7dffb5,#5ce1a0);color:#1a1c24}.device-fallback__button--primary:hover{transform:translateY(-2px);box-shadow:0 4px 20px #7dffb54d}.device-fallback__button--secondary{background:#ffffff1a;color:#fffc}.device-fallback__button--secondary:hover{background:#ffffff26}@media(max-width:520px){.device-fallback{padding:16px}.device-fallback__card{padding:24px}.device-fallback__title{font-size:20px}}.room-label-sheet{display:flex;flex-direction:column;height:100%;background:linear-gradient(180deg,#1a1c24,#12141a);padding:24px;padding-bottom:max(24px,env(safe-area-inset-bottom))}.room-label-sheet__header{text-align:center;margin-bottom:24px}.room-label-sheet__header h2{margin:0 0 8px;font-size:24px;font-weight:600;color:#fff}.room-label-sheet__header p{margin:0;font-size:14px;color:#fff9}.room-label-sheet__rooms{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.room-label-sheet__room{display:flex;gap:12px;padding:16px;background:#ffffff0d;border-radius:12px;border:1px solid rgba(255,255,255,.08)}.room-label-sheet__room-number{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:linear-gradient(135deg,#7dffb5,#5ce1a0);border-radius:50%;font-size:14px;font-weight:700;color:#1a1c24;flex-shrink:0}.room-label-sheet__room-content{flex:1;min-width:0}.room-label-sheet__room-btn{display:flex;align-items:center;gap:12px;width:100%;padding:8px 12px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s ease}.room-label-sheet__room-btn:hover{background:#ffffff1f;border-color:#7dffb54d}.room-label-sheet__room-name{flex:1;font-size:15px;font-weight:500;color:#fff;text-align:left}.room-label-sheet__room-area{font-size:13px;color:#ffffff80;font-variant-numeric:tabular-nums}.room-label-sheet__edit-icon{color:#fff6}.room-label-sheet__edit{display:flex;flex-direction:column;gap:10px}.room-label-sheet__input{width:100%;padding:10px 14px;background:#0000004d;border:1px solid rgba(125,255,181,.4);border-radius:8px;font-size:15px;color:#fff;outline:none}.room-label-sheet__input:focus{border-color:#7dffb5;box-shadow:0 0 0 3px #7dffb526}.room-label-sheet__input::placeholder{color:#fff6}.room-label-sheet__suggestions{display:flex;flex-wrap:wrap;gap:6px}.room-label-sheet__suggestion{padding:6px 12px;background:#ffffff1a;border:none;border-radius:16px;font-size:13px;color:#fffc;cursor:pointer;transition:all .2s ease}.room-label-sheet__suggestion:hover{background:#7dffb533;color:#7dffb5}.room-label-sheet__edit-actions{display:flex;gap:8px}.room-label-sheet__btn{flex:1;padding:8px 16px;font-size:13px;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.room-label-sheet__btn--save{background:#7dffb5;color:#1a1c24}.room-label-sheet__btn--save:hover{background:#5ce1a0}.room-label-sheet__btn--cancel{background:#ffffff1a;color:#fffc}.room-label-sheet__btn--cancel:hover{background:#ffffff26}.room-label-sheet__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#fff9}.room-label-sheet__empty p{margin:0}.room-label-sheet__empty-hint{margin-top:8px!important;font-size:13px;color:#fff6}.room-label-sheet__footer{display:flex;gap:12px;margin-top:24px}.room-label-sheet__action{flex:1;padding:14px 24px;font-size:15px;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease}.room-label-sheet__action:disabled{opacity:.4;cursor:not-allowed}.room-label-sheet__action--primary{background:linear-gradient(135deg,#7dffb5,#5ce1a0);color:#1a1c24}.room-label-sheet__action--primary:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 4px 16px #7dffb566}.room-label-sheet__action--secondary{background:#ffffff1a;color:#fffc}.room-label-sheet__action--secondary:hover{background:#ffffff26}.scan-preview{display:flex;flex-direction:column;height:100%;background:linear-gradient(180deg,#1a1c24,#12141a)}.scan-preview__header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.scan-preview__header h2{margin:0;font-size:20px;font-weight:600;color:#fff}.scan-preview__view-toggle{display:flex;gap:4px;padding:4px;background:#0000004d;border-radius:8px}.scan-preview__view-btn{padding:8px 16px;font-size:13px;font-weight:500;color:#fff9;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.scan-preview__view-btn.active{color:#1a1c24;background:#7dffb5}.scan-preview__view-btn:not(.active):hover{color:#fff;background:#ffffff1a}.scan-preview__content{flex:1;min-height:200px;position:relative;overflow:hidden}.scan-preview__2d{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;position:relative}.scan-preview__edit-controls{position:absolute;top:8px;right:8px;display:flex;gap:8px;z-index:10}.scan-preview__edit-btn,.scan-preview__autofix-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;font-size:12px;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.scan-preview__edit-btn{background:#ffffff1a;color:#ffffffb3}.scan-preview__edit-btn:hover{background:#ffffff26;color:#fff}.scan-preview__edit-btn.active{background:#7dffb533;color:#7dffb5}.scan-preview__autofix-btn{background:#ffd37a33;color:#ffd37a}.scan-preview__autofix-btn:hover{background:#ffd37a4d}.scan-preview__validation{position:absolute;top:8px;left:8px;display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;border-radius:6px;z-index:10}.scan-preview__validation.valid{background:#7dffb526;color:#7dffb5}.scan-preview__validation.invalid{background:#ff6b6b26;color:#ff6b6b}.scan-preview__edit-hint{position:absolute;bottom:8px;left:50%;transform:translate(-50%);padding:6px 12px;font-size:11px;color:#fff9;background:#0009;border-radius:4px;white-space:nowrap;z-index:10}.scan-preview__svg{width:100%;height:100%;max-height:400px}.scan-preview__canvas{width:100%;height:100%}.scan-preview__tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.1)}.scan-preview__tab{flex:1;padding:12px 16px;font-size:14px;font-weight:500;color:#fff9;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .2s ease}.scan-preview__tab.active{color:#7dffb5;border-bottom-color:#7dffb5}.scan-preview__tab:not(.active):hover{color:#fff}.scan-preview__panel{flex:1;min-height:150px;max-height:250px;overflow-y:auto;padding:16px 20px}.scan-preview__summary{display:flex;flex-direction:column;gap:20px}.scan-preview__stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.scan-preview__stat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:#ffffff0d;border-radius:10px}.scan-preview__stat-value{font-size:18px;font-weight:700;color:#fff;font-variant-numeric:tabular-nums}.scan-preview__stat-label{font-size:11px;color:#ffffff80;text-transform:uppercase;letter-spacing:.3px}.scan-preview__settings{display:flex;flex-direction:column;gap:16px}.scan-preview__setting{display:flex;flex-direction:column;gap:8px}.scan-preview__setting label{font-size:13px;font-weight:500;color:#ffffffb3}.scan-preview__select{padding:10px 14px;font-size:14px;color:#fff;background:#0000004d;border:1px solid rgba(255,255,255,.15);border-radius:8px;outline:none;cursor:pointer}.scan-preview__select:focus{border-color:#7dffb5}.scan-preview__height-control{display:flex;align-items:center;gap:12px}.scan-preview__slider{flex:1;height:4px;appearance:none;background:#fff3;border-radius:2px;outline:none}.scan-preview__slider::-webkit-slider-thumb{appearance:none;width:16px;height:16px;background:#7dffb5;border-radius:50%;cursor:pointer}.scan-preview__height-value{min-width:50px;font-size:14px;font-weight:600;color:#7dffb5;font-variant-numeric:tabular-nums}.scan-preview__toggle-group{display:flex;background:#0000004d;border-radius:8px;padding:2px}.scan-preview__toggle-btn{flex:1;padding:8px 12px;font-size:12px;font-weight:500;color:#fff9;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.scan-preview__toggle-btn:hover{color:#fffc}.scan-preview__toggle-btn.active{background:#7dffb533;color:#7dffb5}.scan-preview__setting-hint{margin:6px 0 0;font-size:11px;color:#fff6}.scan-preview__rooms-list{display:flex;flex-direction:column;gap:8px}.scan-preview__room-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:10px;cursor:pointer;transition:all .2s ease}.scan-preview__room-item:hover{background:#ffffff14;border-color:#7dffb54d}.scan-preview__room-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}.scan-preview__room-info{flex:1;display:flex;flex-direction:column;gap:2px;text-align:left}.scan-preview__room-name{font-size:14px;font-weight:500;color:#fff}.scan-preview__room-meta{font-size:12px;color:#ffffff80}.scan-preview__room-area{font-size:13px;color:#ffffff80;font-variant-numeric:tabular-nums}.scan-preview__room-item svg{color:#fff6}.scan-preview__openings{display:flex;flex-direction:column;gap:12px}.scan-preview__openings-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;text-align:center;gap:12px}.scan-preview__openings-empty svg{color:#fff6}.scan-preview__openings-title{margin:0;font-size:14px;font-weight:500;color:#fffc}.scan-preview__openings-hint{margin:0;font-size:12px;color:#ffffff80;max-width:260px}.scan-preview__openings-btn{display:flex;align-items:center;gap:8px;margin-top:8px;padding:10px 16px;font-size:13px;font-weight:500;color:#ffffff80;background:#ffffff14;border:1px dashed rgba(255,255,255,.2);border-radius:8px;cursor:not-allowed}.scan-preview__openings-btn:disabled{opacity:.6}.scan-preview__openings-actions{display:flex;gap:8px;margin-bottom:16px}.scan-preview__openings-add{display:flex;align-items:center;gap:8px;flex:1;padding:12px 16px;font-size:13px;font-weight:500;color:#ffffffb3;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:8px;cursor:pointer;transition:all .2s ease}.scan-preview__openings-add:hover{color:#fff;background:#ffffff1f;border-color:#ffffff40}.scan-preview__openings-add.active{color:#7dffb5;background:#7dffb526;border-color:#7dffb5}.scan-preview__openings-select-wall{display:flex;flex-direction:column;gap:12px}.scan-preview__openings-select-wall p{margin:0;font-size:13px;color:#ffffffb3}.scan-preview__openings-wall-list{display:flex;flex-direction:column;gap:6px;max-height:150px;overflow-y:auto}.scan-preview__openings-wall-btn{display:flex;align-items:center;gap:10px;padding:10px 12px;font-size:13px;color:#fffc;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;transition:all .2s ease;text-align:left}.scan-preview__openings-wall-btn:hover{color:#fff;background:#ffffff1a;border-color:#7dffb566}.scan-preview__openings-wall-color{width:10px;height:10px;border-radius:50%;flex-shrink:0}.scan-preview__openings-cancel{padding:8px 16px;font-size:12px;color:#fff9;background:transparent;border:none;cursor:pointer}.scan-preview__openings-cancel:hover{color:#fff}.scan-preview__openings-list{display:flex;flex-direction:column;gap:8px}.scan-preview__opening-item{display:flex;align-items:center;gap:12px;padding:12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px}.scan-preview__opening-icon{color:#ffffff80}.scan-preview__opening-info{flex:1;display:flex;flex-direction:column;gap:2px}.scan-preview__opening-type{font-size:14px;font-weight:500;color:#fff}.scan-preview__opening-location{display:flex;align-items:center;gap:6px;font-size:12px;color:#fff9}.scan-preview__opening-room-dot{width:8px;height:8px;border-radius:50%}.scan-preview__opening-size{font-size:11px;color:#fff6}.scan-preview__opening-remove{padding:6px;color:#ff6b6bb3;background:transparent;border:none;border-radius:4px;cursor:pointer;transition:all .2s ease}.scan-preview__opening-remove:hover{color:#ff6b6b;background:#ff6b6b1a}.scan-preview__actions{display:flex;gap:12px;padding:16px 20px;padding-bottom:max(16px,env(safe-area-inset-bottom));border-top:1px solid rgba(255,255,255,.1)}.scan-preview__btn{flex:1;padding:14px 20px;font-size:14px;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease}.scan-preview__btn--primary{background:linear-gradient(135deg,#7dffb5,#5ce1a0);color:#1a1c24}.scan-preview__btn--primary:hover{transform:translateY(-2px);box-shadow:0 4px 16px #7dffb566}.scan-preview__btn--secondary{background:#ffffff1a;color:#fffc}.scan-preview__btn--secondary:hover{background:#ffffff26}.scan-preview__btn--danger{background:#ff6b6b26;color:#ff6b6b}.scan-preview__btn--danger:hover{background:#ff6b6b40}.scan-preview__btn--disabled{opacity:.5;cursor:not-allowed}.scan-preview__btn--disabled:hover{transform:none;box-shadow:none}@media(max-width:500px){.scan-preview__stat-grid{grid-template-columns:repeat(2,1fr)}.scan-preview__actions{flex-wrap:wrap}.scan-preview__btn{min-width:calc(50% - 6px)}.scan-preview__btn--primary{order:-1;width:100%;min-width:100%}}.scan-health-bar{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:10px}.scan-health-bar--compact{padding:6px 10px;gap:8px}.scan-health-bar__item{display:flex;align-items:center;gap:6px}.scan-health-bar__item--warning{color:#ffd37a}.scan-health-bar__indicator{position:relative;width:20px;height:20px}.scan-health-bar__ring{position:absolute;inset:0;border:2px solid;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:border-color .3s,box-shadow .3s}.scan-health-bar__fill{width:10px;height:10px;border-radius:50%;transition:transform .3s,background-color .3s}.scan-health-bar__label{font-size:12px;font-weight:500;white-space:nowrap;transition:color .3s}.scan-health-bar__lock-icon{display:flex;align-items:center;justify-content:center;color:#fff6;transition:color .3s}.scan-health-bar__lock-icon--locked{color:#7dffb5}.scan-health-bar--compact .scan-health-bar__dot{width:10px;height:10px;border-radius:50%;transition:background-color .3s}.scan-health-bar--compact .scan-health-bar__lock{color:#7dffb5}.scan-health-bar__geo-icon{display:flex;align-items:center;justify-content:center;color:#fff6;transition:color .3s}.scan-health-bar__geo-icon--valid{color:#7dffb5}.scan-health-bar__geo-icon--invalid{color:#ff6b6b;animation:geo-pulse 1s ease-in-out infinite}@keyframes geo-pulse{0%,to{opacity:1}50%{opacity:.5}}.scan-health-bar__room-icon{display:flex;align-items:center;justify-content:center;transition:color .3s}@keyframes tracking-pulse{0%,to{opacity:1}50%{opacity:.6}}.scan-health-bar__ring{animation:tracking-pulse 2s ease-in-out infinite}.minimal-scan-ui{position:fixed;inset:0;pointer-events:none;z-index:100;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif}.minimal-scan-ui__tap-area{position:absolute;inset:0;pointer-events:auto;cursor:pointer;-webkit-tap-highlight-color:transparent}.reticle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:56px;height:56px;pointer-events:none}.reticle__svg{width:100%;height:100%;filter:drop-shadow(0 0 8px rgba(0,255,204,.3))}.reticle__ring{stroke:#fffc;stroke-width:2.5;transition:all .25s cubic-bezier(.34,1.56,.64,1)}.reticle__dot{fill:#fff0;transition:all .2s ease-out}.reticle__snap-arc{stroke:#0f8;stroke-linecap:round;stroke-width:3.5;filter:drop-shadow(0 0 6px rgba(0,255,136,.6));animation:snap-pulse .8s ease-in-out infinite}.reticle--searching .reticle__ring{stroke:#ffffff59;stroke-width:2;animation:reticle-pulse 2s ease-in-out infinite}.reticle--searching .reticle__svg{filter:drop-shadow(0 0 4px rgba(255,255,255,.15))}.reticle--locked .reticle__ring{stroke:#0fc;stroke-width:2.5}.reticle--locked .reticle__svg{filter:drop-shadow(0 0 12px rgba(0,255,204,.4))}.reticle--placing .reticle__ring{stroke:#0f8;stroke-width:3;transform-origin:center;animation:reticle-place .2s cubic-bezier(.34,1.56,.64,1) forwards}.reticle--placing .reticle__dot{fill:#0f8;r:6}.reticle--placing .reticle__svg{filter:drop-shadow(0 0 16px rgba(0,255,136,.6))}.reticle--invalid .reticle__ring{stroke:#ff9500;stroke-width:2.5;animation:reticle-shake .35s ease-in-out}.reticle--snap .reticle__ring{stroke:#ffffff40;stroke-width:2}.reticle--snap .reticle__svg{filter:drop-shadow(0 0 8px rgba(0,255,136,.3))}@keyframes reticle-pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}@keyframes reticle-place{0%{transform:scale(1)}50%{transform:scale(.85)}to{transform:scale(1)}}@keyframes reticle-shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-3px)}40%,80%{transform:translate(3px)}}@keyframes snap-pulse{0%,to{opacity:.4}50%{opacity:1}}.status-whisper{position:absolute;top:0;left:0;right:0;display:flex;justify-content:center;align-items:center;gap:10px;padding:20px 24px;padding-top:max(20px,calc(env(safe-area-inset-top) + 8px));opacity:0;transform:translateY(-16px);transition:opacity .3s ease-out,transform .3s cubic-bezier(.34,1.56,.64,1);pointer-events:none}.status-whisper--visible{opacity:1;transform:translateY(0)}.status-whisper__icon{font-size:18px;color:#0f8;filter:drop-shadow(0 0 4px rgba(0,255,136,.4))}.status-whisper__text{font-size:16px;font-weight:500;color:#fffffff2;letter-spacing:.2px;text-shadow:0 2px 12px rgba(0,0,0,.5)}.minimal-scan-ui__actions{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;padding:24px;padding-bottom:max(24px,env(safe-area-inset-bottom));pointer-events:none}.action-pill{display:flex;align-items:center;justify-content:center;min-width:160px;padding:16px 32px;border:none;border-radius:30px;font-size:17px;font-weight:600;letter-spacing:.2px;cursor:pointer;pointer-events:auto;opacity:0;transform:translateY(24px);transition:all .35s cubic-bezier(.34,1.56,.64,1);-webkit-tap-highlight-color:transparent}.action-pill--visible{opacity:1;transform:translateY(0)}.action-pill--primary{background:linear-gradient(135deg,#0f8,#0da);color:#001a0f;box-shadow:0 6px 24px #00ff8859,0 2px 8px #0003,inset 0 1px #fff3}.action-pill--primary:active{transform:scale(.95);background:linear-gradient(135deg,#0d7,#0b9);box-shadow:0 3px 12px #00ff884d,0 1px 4px #0003}.action-pill--secondary{background:#ffffff1f;color:#fffffff2;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.18);box-shadow:0 4px 16px #0003}.action-pill--secondary:active{transform:scale(.95);background:#fff3}.action-pill:disabled{pointer-events:none}.corner-glyph{position:absolute;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;background:#14161c99;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:20px;border:1px solid rgba(255,255,255,.1);opacity:.85;transition:all .3s ease-out;pointer-events:none}.corner-glyph--bottom-left{bottom:24px;left:24px;padding-bottom:max(0px,env(safe-area-inset-bottom))}.corner-glyph__count{font-size:16px;font-weight:600;color:#0fc;font-variant-numeric:tabular-nums}.corner-glyph:before{content:"";width:8px;height:8px;background:#0fc;border-radius:2px;opacity:.8}.corner-glyph--highlight{opacity:1;transform:scale(1.05)}.minimal-scan-ui__undo-button{position:absolute;left:24px;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:#14161cb3;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.15);color:#ffffffe6;cursor:pointer;pointer-events:auto;display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.34,1.56,.64,1);-webkit-tap-highlight-color:transparent;box-shadow:0 4px 16px #0000004d}.minimal-scan-ui__undo-button:active{transform:translateY(-50%) scale(.88);background:#282a30d9;border-color:#ffffff40}.minimal-scan-ui__undo-button svg{width:24px;height:24px;opacity:.85}.minimal-scan-ui__guidance,.minimal-scan-ui__tap-hint,.minimal-scan-ui__walk-hint,.minimal-scan-ui__next-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,48px);font-size:15px;font-weight:500;letter-spacing:.3px;text-shadow:0 2px 12px rgba(0,0,0,.6);pointer-events:none}.minimal-scan-ui__guidance{color:#ffffffb3;animation:guidance-breathe 3s ease-in-out infinite}.minimal-scan-ui__tap-hint{color:#0fc;animation:hint-glow 2.5s ease-in-out infinite}.minimal-scan-ui__walk-hint{color:#ffffffa6;animation:hint-fade-in .4s cubic-bezier(.34,1.56,.64,1)}.minimal-scan-ui__next-hint{color:#00ff88d9;animation:hint-glow 2.5s ease-in-out infinite}@keyframes guidance-breathe{0%,to{opacity:.6}50%{opacity:.9}}@keyframes hint-glow{0%,to{opacity:.75;text-shadow:0 2px 12px rgba(0,0,0,.6)}50%{opacity:1;text-shadow:0 2px 16px rgba(0,255,204,.3),0 2px 12px rgba(0,0,0,.6)}}@keyframes hint-fade-in{0%{opacity:0;transform:translate(-50%,56px)}to{opacity:1;transform:translate(-50%,48px)}}@media(max-width:380px){.action-pill{min-width:120px;padding:12px 24px;font-size:15px}.status-whisper__text{font-size:14px}}@media(prefers-reduced-motion:reduce){.reticle--searching .reticle__ring,.reticle__snap-arc{animation:none}.action-pill,.status-whisper{transition-duration:.1s}}.room-completion{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(to top,#0c0e14fa,#0c0e14f2 60%,#0c0e14cc);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.1);padding:24px;padding-bottom:max(24px,env(safe-area-inset-bottom));z-index:200;animation:slide-up .3s cubic-bezier(.34,1.56,.64,1);font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif}@keyframes slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.room-completion__header{text-align:center;margin-bottom:20px}.room-completion__step{display:inline-block;font-size:11px;font-weight:600;color:#00ffcce6;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px}.room-completion__title{font-size:22px;font-weight:600;color:#fff;margin:0 0 4px}.room-completion__subtitle{font-size:14px;color:#fff9;margin:0}.room-completion__check{width:56px;height:56px;margin:0 auto 16px;background:#00ff8826;border-radius:50%;display:flex;align-items:center;justify-content:center}.room-completion__check svg{width:28px;height:28px;color:#0f8}.room-completion__content{margin-bottom:24px}.room-completion__height-display{text-align:center;margin-bottom:20px}.room-completion__height-value{font-size:48px;font-weight:300;color:#fff;font-variant-numeric:tabular-nums}.room-completion__height-slider{margin-bottom:16px}.room-completion__slider{width:100%;height:4px;appearance:none;background:#ffffff26;border-radius:2px;outline:none}.room-completion__slider::-webkit-slider-thumb{appearance:none;width:24px;height:24px;background:#0fc;border-radius:50%;cursor:pointer;box-shadow:0 2px 8px #0fc6}.room-completion__slider::-moz-range-thumb{width:24px;height:24px;background:#0fc;border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 8px #0fc6}.room-completion__slider-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:12px;color:#fff6}.room-completion__presets{display:flex;gap:8px;justify-content:center}.room-completion__preset{padding:8px 16px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:20px;font-size:13px;color:#fffc;cursor:pointer;transition:all .2s ease}.room-completion__preset:active{background:#ffffff26;transform:scale(.96)}.room-completion--openings-compact{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(to top,#0c0e14f2,#0c0e14d9);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,.1);padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom));z-index:200;display:flex;flex-wrap:wrap;align-items:center;gap:12px;animation:slide-up .3s cubic-bezier(.34,1.56,.64,1)}.room-completion__opening-instruction{flex:1 1 100%;text-align:center;font-size:14px;color:#fff9;margin-bottom:4px}.room-completion__opening-instruction--active{color:#0fc;font-weight:500}.room-completion__opening-toggles{display:flex;gap:8px;flex:1}.room-completion__opening-toggle{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:10px;cursor:pointer;transition:all .2s ease}.room-completion__opening-toggle svg{width:20px;height:20px;color:#ffffffb3}.room-completion__opening-toggle span{font-size:13px;color:#fffc}.room-completion__opening-toggle.active{background:#00ffcc26;border-color:#00ffcc80}.room-completion__opening-toggle.active svg{color:#0fc}.room-completion__opening-toggle.active span{color:#0fc;font-weight:500}.room-completion__opening-toggle:active{transform:scale(.96)}.room-completion__opening-count{display:flex;align-items:center;gap:4px;padding:8px 12px;background:#00ff881a;border:1px solid rgba(0,255,136,.3);border-radius:20px;font-size:12px;font-weight:500;color:#0f8;cursor:pointer}.room-completion__opening-count svg{width:14px;height:14px;transition:transform .2s ease}.room-completion__opening-count svg.rotated{transform:rotate(180deg)}.room-completion__opening-actions{display:flex;gap:8px}.room-completion__btn--compact{padding:10px 16px;font-size:14px;border-radius:10px}.room-completion__opening-list-panel{position:fixed;bottom:80px;left:16px;right:16px;max-height:200px;overflow-y:auto;background:#0c0e14f2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px;z-index:199;animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.room-completion__opening-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#ffffff0d;border-radius:8px;margin-bottom:8px}.room-completion__opening-item:last-child{margin-bottom:0}.room-completion__opening-icon{font-size:20px}.room-completion__opening-info{flex:1;display:flex;flex-direction:column;font-size:14px;color:#ffffffe6}.room-completion__opening-info small{font-size:12px;color:#ffffff80}.room-completion__opening-remove{width:28px;height:28px;background:#ff646426;border:none;border-radius:50%;color:#ff6b6b;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.room-completion__opening-remove:active{transform:scale(.9);background:#ff646440}.room-completion__opening-item{cursor:pointer;transition:all .2s ease}.room-completion__opening-item:active{transform:scale(.98)}.room-completion__opening-item--selected{background:#00ffcc26;border:1px solid rgba(0,255,204,.4)}.room-completion__opening-icon svg{color:#ffffffb3}.room-completion__opening-item--selected .room-completion__opening-icon svg{color:#0fc}.room-completion__opening-title{display:flex;align-items:center;gap:8px}.room-completion__opening-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:2px 6px;background:#0fc3;color:#0fc;border-radius:4px}.room-completion__undo-btn{width:40px;height:40px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:10px;color:#fffc;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.room-completion__undo-btn svg{width:20px;height:20px}.room-completion__undo-btn:active{transform:scale(.9);background:#fff3}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.room-completion__summary{display:flex;justify-content:center;gap:32px}.room-completion__summary-item{text-align:center}.room-completion__summary-label{display:block;font-size:11px;font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.room-completion__summary-value{font-size:20px;font-weight:500;color:#fff}.room-completion__actions{display:flex;gap:12px}.room-completion__actions--stacked{flex-direction:column}.room-completion__btn{flex:1;padding:16px 24px;border:none;border-radius:14px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.room-completion__btn--primary{background:#00ff88f2;color:#001a10;box-shadow:0 4px 20px #00ff8840}.room-completion__btn--primary:active{transform:scale(.98);background:#00dc78f2}.room-completion__btn--secondary{background:#ffffff1a;color:#ffffffe6;border:1px solid rgba(255,255,255,.15)}.room-completion__btn--secondary:active{transform:scale(.98);background:#ffffff26}.room-completion__btn--small{flex:none;padding:10px 20px;font-size:14px}@media(max-width:380px){.room-completion{padding:20px 16px}.room-completion__title{font-size:20px}.room-completion__height-value{font-size:40px}.room-completion__presets{flex-wrap:wrap}.room-completion__preset{flex:1;min-width:calc(50% - 4px)}.room-completion__summary{gap:20px}}@media(prefers-reduced-motion:reduce){.room-completion{animation:none}.room-completion__btn,.room-completion__preset,.room-completion__opening-type{transition:none}}.home-scan-page{position:relative;width:100%;height:100%;min-height:100vh;background:linear-gradient(180deg,#1a1c24,#12141a);overflow:auto}.home-scan-page__loading,.home-scan-page__permission,.home-scan-page__acquiring{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:24px;text-align:center;color:#fffc}.home-scan-page__spinner{width:48px;height:48px;border:3px solid rgba(125,255,181,.2);border-top-color:#7dffb5;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.home-scan-page__permission-hint,.home-scan-page__acquiring-hint{margin-top:8px;font-size:14px;color:#ffffff80}.home-scan-page__intro{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}.home-scan-page__intro-card{max-width:520px;width:100%;padding:32px;background:#1e202cf2;border:1px solid rgba(255,255,255,.1);border-radius:20px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.home-scan-page__intro-icon{display:flex;align-items:center;justify-content:center;width:88px;height:88px;margin:0 auto 24px;background:linear-gradient(135deg,#7dffb526,#5ce1a01a);border-radius:50%;color:#7dffb5}.home-scan-page__intro-title{margin:0 0 12px;font-size:28px;font-weight:700;color:#fff;text-align:center}.home-scan-page__intro-description{margin:0 0 28px;font-size:15px;line-height:1.6;color:#ffffffb3;text-align:center}.home-scan-page__intro-steps{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.intro-step{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;background:#0003;border-radius:12px}.intro-step__number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:linear-gradient(135deg,#7dffb5,#5ce1a0);border-radius:50%;font-size:14px;font-weight:700;color:#1a1c24;flex-shrink:0}.intro-step__content{display:flex;flex-direction:column;gap:2px}.intro-step__content strong{font-size:14px;font-weight:600;color:#fff}.intro-step__content span{font-size:13px;color:#fff9}.home-scan-page__intro-tips{padding:16px;background:#7dffb514;border:1px solid rgba(125,255,181,.15);border-radius:12px;margin-bottom:28px}.home-scan-page__intro-tips h3{margin:0 0 10px;font-size:13px;font-weight:600;color:#7dffb5;text-transform:uppercase;letter-spacing:.5px}.home-scan-page__intro-tips ul{margin:0;padding:0 0 0 20px}.home-scan-page__intro-tips li{font-size:13px;line-height:1.6;color:#ffffffbf}.home-scan-page__intro-actions{display:flex;flex-direction:column;gap:12px}.home-scan-page__button{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px 24px;font-size:16px;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease}.home-scan-page__button--primary{background:linear-gradient(135deg,#7dffb5,#5ce1a0);color:#1a1c24}.home-scan-page__button--primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #7dffb559}.home-scan-page__button--primary:active{transform:translateY(0)}.home-scan-page__button--secondary{background:#ffffff1a;color:#fffc}.home-scan-page__button--secondary:hover{background:#ffffff26}.home-scan-experience{position:absolute;inset:0;width:100%;height:100vh;overflow:hidden;background:#0f1117}.home-scan-experience.is-hidden{opacity:0;pointer-events:none}.home-scan-experience.is-active{opacity:1}.home-scan-experience__canvas{position:absolute;inset:0;width:100%;height:100%;touch-action:none}.home-scan-experience__overlay{position:absolute;inset:0;pointer-events:none}.home-scan-experience__overlay>*{pointer-events:auto}.home-scan-page__error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:24px;text-align:center}.home-scan-page__error-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin-bottom:20px;background:#ff6b6b1a;border-radius:50%;color:#ff6b6b}.home-scan-page__error h2{margin:0 0 8px;font-size:24px;font-weight:600;color:#fff}.home-scan-page__error p{margin:0 0 24px;font-size:15px;color:#ffffffb3}.home-scan-page__error-detail{margin:0 0 16px;font-size:13px;color:#fff9}.home-scan-page__error-detail summary{cursor:pointer}.home-scan-page__error-actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:300px}@media(max-width:560px){.home-scan-page__intro-card{padding:24px}.home-scan-page__intro-title{font-size:24px}.home-scan-page__intro-icon{width:72px;height:72px}.home-scan-page__intro-icon svg{width:48px;height:48px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-space);padding:20px}.login-card{width:100%;max-width:400px;background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius-lg);padding:40px 32px;box-shadow:var(--shadow-strong),var(--panel-glow);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur))}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:56px;height:56px;margin:0 auto 16px;color:var(--accent)}.login-logo svg{width:100%;height:100%}.login-header h1{font-size:24px;font-weight:600;color:var(--text);margin:0 0 8px}.login-header p{font-size:14px;color:var(--text-muted);margin:0}.login-google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 16px;background:#ffffff0d;border:1px solid var(--panel-border);border-radius:var(--radius-md);color:var(--text);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.login-google-btn:hover:not(:disabled){background:#ffffff1a;border-color:var(--panel-border-strong)}.login-google-btn:disabled{opacity:.6;cursor:not-allowed}.login-divider{display:flex;align-items:center;gap:16px;margin:24px 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--panel-border)}.login-divider span{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.login-form{display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:13px;font-weight:500;color:var(--text-muted)}.login-field input{padding:12px 14px;background:#0000004d;border:1px solid var(--panel-border);border-radius:var(--radius-md);color:var(--text);font-size:14px;transition:all .2s ease}.login-field input::placeholder{color:#88a7bf80}.login-field input:focus{outline:none;border-color:var(--accent);box-shadow:var(--focus-ring)}.login-field input:disabled{opacity:.6;cursor:not-allowed}.login-submit-btn{margin-top:8px;padding:12px 16px;background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;border-radius:var(--radius-md);color:var(--bg0);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.login-submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #66dcff66}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-error{margin-top:16px;padding:12px 14px;background:#ff7c7c1a;border:1px solid rgba(255,124,124,.3);border-radius:var(--radius-md);color:var(--danger);font-size:13px;text-align:center}.login-message{margin-top:16px;padding:12px 14px;background:#7dffb51a;border:1px solid rgba(125,255,181,.3);border-radius:var(--radius-md);color:var(--ok);font-size:13px;text-align:center}.login-toggle{display:block;width:100%;margin-top:24px;padding:8px;background:transparent;border:none;color:var(--accent);font-size:13px;cursor:pointer;transition:all .2s ease}.login-toggle:hover:not(:disabled){color:var(--accent2)}.login-toggle:disabled{opacity:.6;cursor:not-allowed}.auth-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;background:var(--bg-space);color:var(--text-muted);font-size:14px}.auth-loading-spinner{width:40px;height:40px;border:3px solid var(--panel-border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
