.hud{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.corner{position:absolute;width:20px;height:20px;border-color:#1e293b;border-style:solid;border-width:0}.corner.tl{top:12px;left:12px;border-top-width:1px;border-left-width:1px}.corner.tr{top:12px;right:12px;border-top-width:1px;border-right-width:1px}.corner.bl{bottom:12px;left:12px;border-bottom-width:1px;border-left-width:1px}.corner.br{bottom:12px;right:12px;border-bottom-width:1px;border-right-width:1px}.title-bar{position:absolute;top:24px;left:32px;display:flex;align-items:center;gap:10px}.hud-logo{width:22px;height:22px;overflow:visible}.hud-logo-front{fill:var(--text)}.hud-logo-glow{stroke:var(--green);animation:pulse 2s ease-in-out infinite}.title-bar .label{color:var(--text);font-size:14px;font-weight:300;letter-spacing:.1em;text-transform:uppercase;opacity:.85}.title-bar .label-sep{color:var(--green)}.title-bar.demo .hud-logo-glow{stroke:var(--orange)}.title-bar.demo .label-sep{color:var(--orange)}.time-display{position:absolute;top:24px;right:32px;text-align:right}.time-display .time{color:var(--text);font-size:22px;letter-spacing:.05em;font-weight:300}.time-display .date{color:var(--muted);font-size:10px;letter-spacing:.1em;text-transform:uppercase;margin-top:2px}@media(max-width:768px){.title-bar{top:16px;left:18px;gap:8px}.hud-logo{width:12px;height:12px}.title-bar .label{font-size:11px;letter-spacing:.05em}.time-display{top:16px;right:18px}.time-display .time{font-size:11px}.time-display .date{font-size:5px}.corner{width:10px;height:10px}.corner.tl{top:8px;left:8px}.corner.tr{top:8px;right:8px}.corner.bl{bottom:8px;left:8px}.corner.br{bottom:8px;right:8px}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--backdrop-bg);display:flex;align-items:center;justify-content:center;z-index:100;opacity:0;pointer-events:none;transition:opacity .2s;backdrop-filter:var(--backdrop-blur);-webkit-backdrop-filter:var(--backdrop-blur)}.modal-backdrop.visible{opacity:1;pointer-events:auto}.light-modal{background:var(--surface-alpha);background-image:var(--panel-dots);background-size:var(--panel-dots-size);border:var(--panel-border-width) solid var(--panel-border);border-radius:var(--corner-radius);width:280px;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-title{display:flex;align-items:center;gap:12px}.modal-bulb-icon{width:36px;height:36px;border-radius:8px;border:1px solid #334155;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .2s}.modal-entity-name{color:var(--text);font-size:12px;letter-spacing:.05em}.modal-entity-id{color:var(--muted);font-size:9px;letter-spacing:.05em;margin-top:2px}.modal-close-btn{background:none;border:none;color:var(--muted);font-size:16px;cursor:pointer;font-family:inherit;padding:4px;transition:color .15s}@media(hover:hover)and (pointer:fine){.modal-close-btn:hover{color:var(--text)}}.modal-body{padding:16px 20px;display:flex;flex-direction:column;gap:14px}.modal-row{display:flex;justify-content:space-between;align-items:center}.modal-label{color:var(--muted);font-size:10px;letter-spacing:.15em;text-transform:uppercase}.toggle-switch{position:relative;width:40px;height:22px;cursor:pointer;display:inline-block}.toggle-switch input{display:none}.toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;background:#1e293b;border-radius:11px;transition:background .2s}.toggle-thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#334155;transition:transform .2s,background .2s}.toggle-switch input:checked+.toggle-track{background:#1a3a2a}.toggle-switch input:checked+.toggle-track+.toggle-thumb{transform:translate(18px);background:var(--green)}.modal-slider-wrap{display:flex;flex-direction:column;gap:6px}.slider-header{display:flex;justify-content:space-between;align-items:center}.slider-value{color:#94a3b8;font-size:10px;letter-spacing:.05em;min-width:32px;text-align:right}.modal-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:3px;border-radius:3px;outline:none;cursor:pointer}.modal-slider.brightness{background:linear-gradient(to right,#1e293b,var(--yellow))}.modal-slider.warmcold{background:linear-gradient(to right,#bfdbfe,#f97316)}.modal-slider.white{background:linear-gradient(to right,#1e293b,#fff)}.modal-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--text);box-shadow:0 0 0 2px var(--surface),0 0 0 3px #334155;cursor:pointer;transition:box-shadow .15s}@media(hover:hover)and (pointer:fine){.modal-slider::-webkit-slider-thumb:hover{box-shadow:0 0 0 2px var(--surface),0 0 0 3px var(--green)}}.color-section{display:flex;flex-direction:column;gap:10px}.hue-ring-wrap{display:flex;justify-content:center}.modal-divider{height:1px;background:var(--border);margin:0 -20px}.remote-modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:300px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column}.remote-body{padding:14px 18px 20px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.remote-power-row{display:flex;gap:10px;justify-content:center}.remote-power-btn{width:54px;height:54px;border-radius:50%;border:2px solid var(--border);background:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s,border-color .15s,box-shadow .15s}.remote-power-btn .power-icon{font-size:20px;font-weight:800;font-family:inherit;line-height:1}.remote-power-btn.on .power-icon{color:#22c55e}.remote-power-btn.off .power-icon{color:#ef4444}.remote-power-btn.on.active{border-color:#22c55e;box-shadow:0 0 12px #22c55e4d}.remote-power-btn.off.active{border-color:#ef4444;box-shadow:0 0 12px #ef444433}.remote-power-btn:active,.remote-power-btn.pressed{transform:scale(.9)}@media(hover:hover)and (pointer:fine){.remote-power-btn.on:hover{border-color:#22c55e}.remote-power-btn.off:hover{border-color:#ef4444}}.remote-brightness-row{display:flex;align-items:center;gap:8px}.remote-bright-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .1s,border-color .15s}.remote-bright-btn:active,.remote-bright-btn.pressed{transform:scale(.9);border-color:var(--accent)}@media(hover:hover)and (pointer:fine){.remote-bright-btn:hover{border-color:var(--muted)}}.bright-icon{font-size:18px;color:var(--yellow, #fbbf24)}.bright-icon.dim{font-size:12px;opacity:.5}.bright-gradient{flex:1;height:6px;border-radius:3px;background:linear-gradient(to right,#1e293b,var(--yellow, #fbbf24))}.remote-scene-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.remote-scene-btn{aspect-ratio:1;border-radius:50%;border:1px solid var(--border);background:var(--bg);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;transition:transform .1s,border-color .15s,background .12s;padding:2px}.remote-scene-btn.empty{border-color:transparent;background:transparent;cursor:default}.remote-scene-btn:not(.empty):active,.remote-scene-btn:not(.empty).pressed{transform:scale(.9);border-color:var(--accent);background:var(--accent)}@media(hover:hover)and (pointer:fine){.remote-scene-btn:not(.empty):hover{border-color:var(--muted);background:var(--surface-hover, var(--border))}}.scene-icon{font-size:18px;line-height:1}.scene-label{font-size:7px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;line-height:1;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.remote-scene-btn.pressed .scene-label{color:var(--bg)}.remote-wheel-section{display:flex;flex-direction:column;align-items:center;gap:10px}.remote-wheel{position:relative;width:140px;height:140px}.wheel-ring{position:absolute;top:10%;right:10%;bottom:10%;left:10%;border-radius:50%;background:conic-gradient(from 0deg,#ef4444,#eab308,#22c55e,#3b82f6,#8b5cf6,#ef4444);-webkit-mask:radial-gradient(circle,transparent 58%,black 60%,black 78%,transparent 80%);mask:radial-gradient(circle,transparent 58%,black 60%,black 78%,transparent 80%)}.wheel-dot{position:absolute;width:22px;height:22px;border-radius:50%;border:2px solid rgba(255,255,255,.8);transform:translate(-50%,-50%);cursor:pointer;transition:transform .1s,box-shadow .15s;box-shadow:0 1px 4px #0000004d}.wheel-dot:active,.wheel-dot.pressed{transform:translate(-50%,-50%) scale(1.25);box-shadow:0 0 10px #fff6}@media(hover:hover)and (pointer:fine){.wheel-dot:hover{transform:translate(-50%,-50%) scale(1.15)}}.remote-mode-row{display:flex;gap:10px;justify-content:center}.remote-mode-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:16px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:inherit;font-size:10px;font-weight:600;letter-spacing:.08em;cursor:pointer;transition:transform .1s,border-color .15s}.remote-mode-btn:active,.remote-mode-btn.pressed{transform:scale(.93);border-color:var(--accent)}@media(hover:hover)and (pointer:fine){.remote-mode-btn:hover{border-color:var(--muted)}}.mode-dots{display:flex;gap:2px}.mode-dots span{width:8px;height:8px;border-radius:50%;display:block}.indicator-modal{background:var(--surface);border:1px solid var(--border);border-radius:10px;width:320px;max-height:85vh;overflow-y:auto}.im-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.im-title{display:flex;align-items:center;gap:12px}.im-icon{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--accent)}.im-name{color:var(--text);font-size:12px;letter-spacing:.05em}.im-value-inline{color:var(--muted);font-size:10px;margin-top:2px}.im-unit{margin-left:2px;font-size:9px}.im-body{padding:16px 20px;display:flex;flex-direction:column;gap:16px}.im-section{display:flex;flex-direction:column;gap:10px}.im-label{color:var(--muted);font-size:10px;letter-spacing:.15em;text-transform:uppercase}.im-graph{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:4px;min-height:100px;display:flex;align-items:center;justify-content:center}.im-graph svg{display:block}.im-graph-msg{color:var(--muted);font-size:10px}.im-periods{display:flex;gap:4px}.im-period-btn{flex:1;padding:5px 0;background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--muted);font-size:10px;font-family:inherit;cursor:pointer;transition:all .15s;letter-spacing:.05em}.im-period-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}@media(hover:hover)and (pointer:fine){.im-period-btn:not(.active):hover{border-color:var(--accent);color:var(--text)}}.im-gauge-wrap{display:flex;flex-direction:column;align-items:center;gap:4px}.im-gauge-svg{width:220px;height:200px;touch-action:none;-webkit-user-select:none;user-select:none}.im-gauge-handle{cursor:grab;filter:drop-shadow(0 0 3px rgba(255,255,255,.4))}.im-gauge-handle:active{cursor:grabbing}.im-gauge-status{font-size:13px;fill:var(--muted);font-family:inherit}.im-gauge-status.heating{fill:#f97316}.im-gauge-status.off{font-size:28px;fill:var(--text)}.im-gauge-temp-group{font-family:inherit}.im-gauge-temp-whole{font-size:42px;font-weight:300;fill:var(--text)}.im-gauge-temp-unit{font-size:14px;fill:var(--text)}.im-gauge-temp-decimal{font-size:18px;font-weight:300;fill:var(--text)}.im-mode-toggle-wrap{display:flex;justify-content:center;gap:4px}.im-mode-side{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 24px;border:1px solid var(--border);background:transparent;color:var(--muted);font-family:inherit;font-size:11px;cursor:pointer;transition:all .15s}.im-mode-side:first-child{border-radius:20px 0 0 20px}.im-mode-side:last-child{border-radius:0 20px 20px 0}.im-mode-side.active{background:#64748b33;border-color:var(--muted);color:var(--text)}.im-mode-side.heat.active{background:#f9731626;border-color:#f97316;color:#f97316}@media(hover:hover)and (pointer:fine){.im-mode-side:not(.active):hover{border-color:var(--accent);color:var(--text)}}.debug-panel{position:absolute;top:0;right:0;width:300px;height:100%;background-color:var(--side-panel-bg);background-image:var(--panel-dots);background-size:var(--panel-dots-size);border-left:var(--panel-border-width) solid var(--panel-border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);pointer-events:auto;z-index:90;transform:translate(100%);transition:transform .25s ease;display:flex;flex-direction:column;overflow:hidden}.debug-panel.open{transform:translate(0)}.debug-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.debug-panel-header .title{color:var(--accent);font-size:10px;letter-spacing:.15em;text-transform:uppercase}.debug-panel-close{background:none;border:1px solid var(--border);border-radius:3px;color:var(--muted);font-family:DM Mono,monospace;font-size:12px;width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.debug-panel-close:hover{border-color:var(--accent);color:var(--accent)}.debug-panel-body{flex:1;overflow-y:auto;padding:8px 0}.debug-section{border-bottom:1px solid var(--border)}.debug-section:last-child{border-bottom:none}.debug-section-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.debug-section-header:hover{background:var(--border)}.debug-section-header .section-title{color:var(--text);font-size:10px;letter-spacing:.12em;text-transform:uppercase}.debug-section-header .chevron{color:var(--muted);font-size:10px;transition:transform .2s}.debug-section-header .chevron.expanded{transform:rotate(90deg)}.debug-section-body{padding:0 16px 12px;display:flex;flex-direction:column;gap:10px}.debug-control{display:flex;flex-direction:column;gap:4px}.debug-control-row{display:flex;align-items:center;justify-content:space-between}.debug-control label{color:var(--muted);font-size:9px;letter-spacing:.1em;text-transform:uppercase}.debug-control .value{color:var(--text);font-size:10px;min-width:42px;text-align:right}.debug-control input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:2px;background:var(--border2);border-radius:2px;outline:none;cursor:pointer}.debug-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:var(--accent);cursor:pointer}.debug-control select{background:var(--bg);border:1px solid var(--border);border-radius:3px;color:var(--text);font-family:DM Mono,monospace;font-size:10px;padding:4px 8px;cursor:pointer;outline:none;width:100%}.debug-control select:focus{border-color:var(--accent)}.debug-toggle{display:flex;align-items:center;justify-content:space-between}.debug-toggle label{color:var(--muted);font-size:9px;letter-spacing:.1em;text-transform:uppercase}.debug-toggle-track{width:32px;height:16px;border-radius:8px;background:var(--border2);cursor:pointer;position:relative;transition:background .15s}.debug-toggle-track.on{background:var(--accent-dim)}.debug-toggle-thumb{width:12px;height:12px;border-radius:50%;background:var(--muted);position:absolute;top:2px;left:2px;transition:all .15s}.debug-toggle-track.on .debug-toggle-thumb{left:18px;background:var(--accent)}.debug-rebuild-btn{width:100%;padding:6px 0;background:none;border:1px solid var(--border);border-radius:4px;color:var(--accent);font-family:DM Mono,monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .15s}.debug-rebuild-btn:hover{border-color:var(--accent);background:var(--accent-dim)}.debug-panel-body::-webkit-scrollbar{width:4px}.debug-panel-body::-webkit-scrollbar-track{background:transparent}.debug-panel-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{transition:none;z-index:1;will-change:width,height}.react-grid-item.react-draggable-dragging{transition:none;z-index:3;will-change:transform}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:red;opacity:.2;transition-duration:.1s;z-index:2;-webkit-user-select:none;user-select:none}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{position:absolute;width:20px;height:20px;opacity:0}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-right:2px solid rgba(0,0,0,.4);border-bottom:2px solid rgba(0,0,0,.4)}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{position:absolute;width:20px;height:20px;background-repeat:no-repeat;background-origin:content-box;box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:bottom right;padding:0 3px 3px 0}.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.card-shell{width:100%;height:100%;background:color-mix(in srgb,var(--surface) 20%,transparent);border:1px solid color-mix(in srgb,var(--border) 20%,transparent);border-radius:6px;display:flex;flex-direction:column;overflow:hidden}.card-shell-header{padding:6px 10px;font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);border-bottom:1px solid var(--border);flex-shrink:0}.card-shell-body{flex:1;display:flex;align-items:center;justify-content:center;padding:8px;min-height:0}.card-props-overlay{position:fixed;top:0;right:0;bottom:0;z-index:1000;display:flex;justify-content:flex-end;pointer-events:none}.card-props-backdrop{display:none}.card-props-panel{position:relative;width:340px;max-width:90vw;height:100%;background-color:var(--side-panel-bg);background-image:var(--panel-dots);background-size:var(--panel-dots-size);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-left:var(--panel-border-width) solid var(--panel-border);display:flex;flex-direction:column;animation:card-props-slide-in .2s ease-out;overflow:hidden;pointer-events:auto}@keyframes card-props-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.card-props-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border)}.card-props-header h3{margin:0;font-family:DM Mono,monospace;font-size:13px;font-weight:500;color:var(--text);letter-spacing:.05em}.card-props-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:18px;padding:4px;line-height:1}.card-props-close:hover{color:var(--text)}.card-props-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.card-props-field{display:flex;flex-direction:column;gap:4px}.card-props-field label{font-family:DM Mono,monospace;font-size:10px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}.card-props-field input,.card-props-field select{background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:DM Mono,monospace;font-size:12px;padding:8px 10px;outline:none;transition:border-color .15s}.card-props-field input:focus,.card-props-field select:focus{border-color:var(--accent)}.card-props-field input::placeholder{color:var(--muted);opacity:.6}.card-props-row{display:flex;gap:10px}.card-props-row .card-props-field{flex:1}.card-props-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;font-family:DM Mono,monospace;font-size:11px;color:var(--muted)}.card-props-toggle input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}.card-props-section{font-family:DM Mono,monospace;font-size:10px;color:var(--accent);letter-spacing:.1em;text-transform:uppercase;padding-top:6px;border-top:1px solid var(--border)}.card-props-footer{display:flex;gap:8px;padding:16px;border-top:1px solid var(--border)}.card-props-btn{flex:1;padding:10px;border-radius:4px;font-family:DM Mono,monospace;font-size:11px;letter-spacing:.05em;cursor:pointer;transition:all .15s;border:1px solid var(--border)}.card-props-btn-cancel{background:none;color:var(--muted)}.card-props-btn-cancel:hover{border-color:var(--text);color:var(--text)}.card-props-btn-save{background:var(--accent);border-color:var(--accent);color:var(--bg)}.card-props-btn-save:hover{opacity:.85}.card-props-btn-save:disabled{opacity:.4;cursor:not-allowed}.card-edit-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;pointer-events:none}.card-edit-btn{position:absolute;top:4px;pointer-events:all;width:20px;height:20px;border-radius:2px;border:none;background:none;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;line-height:1;transition:color .15s,opacity .15s;padding:0;opacity:.5}.card-edit-btn:hover{opacity:1}.card-edit-btn-edit{right:4px;color:var(--accent)}.card-edit-btn-delete{left:4px;color:var(--red)}@media(max-width:768px){.card-props-panel{width:100%;max-width:100%}}.side-panel{height:100%;flex-shrink:0;background-color:var(--side-panel-bg);background-image:var(--panel-dots);background-size:var(--panel-dots-size);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border-right:var(--panel-border-width) solid color-mix(in srgb,var(--panel-border) 30%,transparent);display:flex;flex-direction:row;position:relative;z-index:2}.side-panel-inner{width:100%;height:100%;overflow:hidden;padding:12px;box-sizing:border-box;display:flex;flex-direction:column;user-select:none;-webkit-user-select:none}.side-panel-content{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;scrollbar-width:none}.side-panel-content::-webkit-scrollbar{display:none}.side-panel-handle{position:absolute;right:-6px;top:0;width:12px;height:100%;cursor:col-resize;z-index:10;display:flex;align-items:center;justify-content:center}.side-panel-handle-bar{width:3px;height:40px;border-radius:2px;background:var(--border2);transition:background .15s}@media(hover:hover)and (pointer:fine){.side-panel-handle:hover .side-panel-handle-bar{background:var(--accent)}}@media(max-width:768px){.side-panel{width:100%!important;height:var(--panel-size);border-right:none;border-top:var(--panel-border-width) solid color-mix(in srgb,var(--panel-border) 30%,transparent);flex-direction:column}.side-panel-handle{position:absolute;top:-6px;left:0;right:auto;width:100%;height:12px;cursor:row-resize}.side-panel-handle-bar{width:40px;height:3px}}.side-panel-settings-btn{margin-top:8px;padding:8px 0;background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);font-family:DM Mono,monospace;font-size:10px;letter-spacing:.1em;cursor:pointer;transition:all .15s;width:100%}@media(hover:hover)and (pointer:fine){.side-panel-settings-btn:hover{border-color:var(--accent);color:var(--accent)}}.side-panel-exit-sim-btn{margin-top:8px;padding:8px 0;background:none;border:1px solid var(--orange);border-radius:4px;color:var(--orange);font-family:DM Mono,monospace;font-size:10px;letter-spacing:.1em;cursor:pointer;transition:all .15s;width:100%}@media(hover:hover)and (pointer:fine){.side-panel-exit-sim-btn:hover{background:#fb923c1a}}.side-panel-add-btn{margin-top:8px;padding:8px 0;background:none;border:1px dashed var(--accent);border-radius:4px;color:var(--accent);font-family:DM Mono,monospace;font-size:10px;letter-spacing:.1em;cursor:pointer;transition:all .15s;width:100%}@media(hover:hover)and (pointer:fine){.side-panel-add-btn:hover{background:color-mix(in srgb,var(--accent) 10%,transparent)}}.side-panel-done-btn{margin-top:8px;padding:8px 0;background:var(--accent);border:1px solid var(--accent);border-radius:4px;color:var(--bg);font-family:DM Mono,monospace;font-size:10px;letter-spacing:.1em;cursor:pointer;transition:all .15s;width:100%}@media(hover:hover)and (pointer:fine){.side-panel-done-btn:hover{opacity:.85}}.side-panel-inner::-webkit-scrollbar{width:4px}.side-panel-inner::-webkit-scrollbar-track{background:transparent}.side-panel-inner::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.side-panel-grid{position:relative}.side-panel-grid .react-grid-item{transition:all .2s ease;padding:1px}.side-panel-grid .react-grid-item>.react-resizable-handle{background:none;width:12px;height:12px;opacity:1}.side-panel-grid .react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:6px;height:6px;border-right:2px solid var(--accent);border-bottom:2px solid var(--accent);opacity:.5}.script-card{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;background:color-mix(in srgb,var(--surface) 20%,transparent);border:1px solid color-mix(in srgb,var(--border) 20%,transparent);border-radius:6px;color:var(--accent);font-family:DM Mono,monospace;font-size:11px;cursor:pointer;transition:background .15s,border-color .15s;padding:8px;box-sizing:border-box;-webkit-tap-highlight-color:transparent;outline:none}@media(hover:hover)and (pointer:fine){.script-card:hover:not(:disabled){border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent)}}.script-card:disabled{opacity:.4;cursor:not-allowed}.script-card-spinner{animation:spin .8s linear infinite}.script-card-check{color:var(--green);animation:pop .3s ease-out}.script-card-error{color:var(--red);animation:shake .4s ease-out}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pop{0%{transform:scale(0)}60%{transform:scale(1.3)}to{transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-4px)}30%{transform:translate(4px)}45%{transform:translate(-3px)}60%{transform:translate(3px)}75%{transform:translate(-1px)}}.script-card-label{text-transform:uppercase;letter-spacing:.08em;line-height:1.2;text-align:center}.indicator-card{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:color-mix(in srgb,var(--surface) 20%,transparent);border:1px solid color-mix(in srgb,var(--border) 20%,transparent);border-radius:6px;padding:8px;box-sizing:border-box}.indicator-card-bg-icon{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--accent);opacity:.25;pointer-events:none}.indicator-card-value{position:relative;font-size:24px;font-weight:400;color:var(--text);line-height:1}.indicator-card-unit{font-size:11px;color:var(--muted);margin-left:2px}.indicator-card-title{position:absolute;bottom:4px;left:0;right:0;text-align:center;font-family:DM Mono,monospace;font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);pointer-events:none}.graph-card-container{width:100%;height:100%}.graph-card-loading,.graph-card-error{font-size:10px;color:var(--muted)}.graph-card-error{color:var(--red)}.side-panel-auto-grid{display:grid;gap:8px}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--backdrop-bg);display:flex;align-items:center;justify-content:center;z-index:100;backdrop-filter:var(--backdrop-blur);-webkit-backdrop-filter:var(--backdrop-blur)}.settings-modal{background:var(--surface-alpha);background-image:var(--panel-dots);background-size:var(--panel-dots-size);border:var(--panel-border-width) solid var(--panel-border);border-radius:var(--corner-radius);padding:20px;min-width:320px;max-width:400px;width:90%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.settings-header{display:flex;align-items:center;gap:8px;margin-bottom:20px}.settings-title{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);flex:1}.settings-back-btn,.settings-close-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:0;display:flex;align-items:center;transition:color .15s}@media(hover:hover)and (pointer:fine){.settings-back-btn:hover,.settings-close-btn:hover{color:var(--text)}}.settings-body{position:relative;overflow:hidden;flex:1;min-height:0}.settings-panel{position:absolute;top:0;left:0;width:100%;height:100%;transition:transform .25s ease,opacity .25s ease;will-change:transform,opacity}.settings-panel-main{transform:translate(0);opacity:1}.settings-panel-main.exit-left{transform:translate(-30%);opacity:0;pointer-events:none}.settings-panel-section{transform:translate(0);opacity:1}.settings-panel-section.exit-right{transform:translate(30%);opacity:0;pointer-events:none}.settings-panel.active{position:relative}.settings-main{display:flex;flex-direction:column;gap:20px}.settings-list{display:flex;flex-direction:column;gap:2px}.settings-list-item{display:flex;align-items:center;gap:12px;padding:12px;background:none;border:1px solid transparent;border-radius:6px;color:var(--muted);font-family:DM Mono,monospace;font-size:11px;letter-spacing:.1em;cursor:pointer;transition:all .15s}@media(hover:hover)and (pointer:fine){.settings-list-item:hover{background:var(--surface);border-color:var(--border);color:var(--accent)}}.settings-bottom-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.settings-big-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:14px 12px;background:none;border:1px solid var(--accent);border-radius:8px;color:var(--accent);font-family:DM Mono,monospace;font-size:10px;letter-spacing:.1em;cursor:pointer;transition:all .15s;text-decoration:none}@media(hover:hover)and (pointer:fine){.settings-big-btn:hover{background:color-mix(in srgb,var(--accent) 10%,transparent)}}.settings-page{display:flex;flex-direction:column;gap:8px;max-height:100%;overflow-y:auto}.settings-section{margin-bottom:24px}.settings-section-label{font-size:10px;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);margin-bottom:12px}.settings-mode-toggle{display:flex;gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden;width:fit-content}.settings-mode-btn{background:none;border:none;color:var(--muted);font-family:DM Mono,monospace;font-size:12px;letter-spacing:.1em;padding:8px 16px;cursor:pointer;transition:all .15s}.settings-mode-btn+.settings-mode-btn{border-left:1px solid var(--border)}.settings-mode-btn.active{background:color-mix(in srgb,var(--accent) 10%,transparent);color:var(--accent)}.settings-mode-btn.active.live{background:#4ade801a;color:var(--green)}.settings-mode-btn.active.demo{background:#fb923c1a;color:var(--orange)}.settings-scrubber{display:flex;align-items:center;gap:12px}.settings-scrubber input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:1;height:3px;background:var(--border2);border-radius:2px;outline:none;cursor:pointer}.settings-scrubber input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer}.settings-scrubber-time{color:var(--text);font-size:12px;min-width:38px;text-align:center}.settings-live-btn{background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);font-family:DM Mono,monospace;font-size:10px;letter-spacing:.1em;padding:6px 12px;cursor:pointer;transition:all .15s}.settings-live-btn.active{border-color:var(--green);color:var(--green)}.settings-cam-grid{display:flex;flex-direction:column;gap:10px}.settings-cam-row{display:flex;align-items:center;gap:10px}.settings-cam-device-icon{color:var(--muted);width:24px;flex-shrink:0}.settings-cam-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);cursor:pointer;transition:all .15s;padding:0}.settings-cam-btn.active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}@media(hover:hover)and (pointer:fine){.settings-cam-btn:hover{border-color:var(--accent);color:var(--accent)}}.settings-compass-row{display:flex;align-items:center;gap:16px}.settings-compass{cursor:pointer;-webkit-user-select:none;user-select:none}.compass-ring{fill:none;stroke:var(--border);stroke-width:1.5}.compass-label{font-size:10px;font-family:DM Mono,monospace;fill:var(--muted);text-anchor:middle;dominant-baseline:central;pointer-events:none}.compass-label.compass-n{fill:var(--accent);font-weight:700}.compass-needle{stroke:var(--accent);stroke-width:2;stroke-linecap:round}.compass-arrow{fill:var(--accent)}.compass-center{fill:var(--muted)}.settings-actions{display:flex;gap:10px}.settings-action-btn{background:none;border:1px solid var(--border);border-radius:6px;color:var(--muted);font-family:DM Mono,monospace;font-size:11px;letter-spacing:.1em;padding:8px 18px;cursor:pointer;transition:all .15s;text-decoration:none}@media(hover:hover)and (pointer:fine){.settings-action-btn:hover{border-color:var(--accent);color:var(--accent)}}.settings-action-btn.ha-ok{border-color:var(--green);color:var(--green)}.settings-action-btn.ha-err{border-color:var(--red);color:var(--red)}.settings-divider{height:1px;background:var(--border);margin:16px 0}.settings-status{display:flex;gap:20px}.settings-status-chip{font-size:11px;letter-spacing:.1em;color:var(--muted)}.settings-status-chip span{color:var(--text)}.settings-ha-fields{display:flex;flex-direction:column;gap:12px}.settings-ha-row{display:flex;gap:12px}.settings-ha-field{display:flex;flex-direction:column;gap:6px}.settings-ha-label{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.settings-ha-input{background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:DM Mono,monospace;font-size:12px;padding:8px 10px;outline:none;width:100%;box-sizing:border-box}.settings-ha-input:focus{border-color:var(--accent)}.settings-ha-input::placeholder{color:var(--muted);opacity:.5}.settings-swatch-row{display:flex;gap:8px;flex-wrap:wrap;padding:4px}.settings-swatch{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:border-color .15s,transform .15s;padding:0;outline:none;box-shadow:inset 0 0 0 1px #ffffff1a}[data-theme=light] .settings-swatch{box-shadow:inset 0 0 0 1px #00000026}.settings-swatch.active{border-color:var(--accent);transform:scale(1.15)}@media(hover:hover)and (pointer:fine){.settings-swatch:hover:not(.active){border-color:var(--muted);transform:scale(1.1)}}.settings-repo-link{display:inline-flex;align-items:center;gap:8px;width:fit-content}.settings-infos-license{display:flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.05em;color:var(--text)}.settings-infos-footer{display:flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.05em;color:var(--muted)}.settings-checkbox-group{display:flex;gap:20px}.settings-checkbox{display:flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.1em;color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none}.settings-checkbox input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border:1px solid var(--border);border-radius:3px;background:none;cursor:pointer;position:relative;flex-shrink:0}.settings-checkbox input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.settings-checkbox input[type=checkbox]:checked:after{content:"";position:absolute;left:4px;top:1px;width:5px;height:9px;border:solid var(--bg);border-width:0 2px 2px 0;transform:rotate(45deg)}.tour-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150;pointer-events:none}.tour-overlay-bg{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:auto;transition:opacity .3s ease}.tour-overlay:not(:has(.tour-spotlight)) .tour-overlay-bg{background:#000000a6}.tour-overlay:has(.tour-spotlight) .tour-overlay-bg{background:transparent}.tour-overlay.interactive .tour-overlay-bg{pointer-events:none}.tour-overlay.passthrough .tour-overlay-bg{pointer-events:none;background:#00000059}.tour-spotlight{position:fixed;border-radius:6px;box-shadow:0 0 0 9999px #000000a6;transition:all .35s ease;pointer-events:none;z-index:151}.tour-spotlight.interactive{pointer-events:none}.tour-tooltip{position:fixed;z-index:152;background:var(--surface);border:1px solid var(--accent);border-radius:8px;padding:16px 20px;width:340px;max-width:calc(100vw - 16px);pointer-events:auto;transition:all .35s ease;box-shadow:0 8px 32px #0006}.tour-tooltip-title{font-size:13px;font-weight:500;color:var(--text);margin-bottom:6px}.tour-tooltip-body{font-size:11px;color:var(--muted);line-height:1.6;margin-bottom:14px}.tour-tooltip-footer{display:flex;align-items:center;justify-content:space-between}.tour-tooltip-counter{font-size:10px;color:var(--muted);letter-spacing:.1em}.tour-tooltip-actions{display:flex;gap:6px}.tour-tooltip-btn{background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);font-family:DM Mono,monospace;font-size:10px;letter-spacing:.08em;padding:5px 12px;cursor:pointer;transition:all .15s}@media(hover:hover)and (pointer:fine){.tour-tooltip-btn:hover{border-color:var(--accent);color:var(--accent)}}.tour-tooltip-btn.primary{background:var(--accent);border-color:var(--accent);color:var(--bg)}.tour-tooltip-btn.primary.disabled{opacity:.35;cursor:not-allowed;filter:none}@media(hover:hover)and (pointer:fine){.tour-tooltip-btn.primary:not(.disabled):hover{filter:brightness(1.15);color:var(--bg)}}.tour-tooltip:before{content:"";position:absolute;width:10px;height:10px;background:var(--surface);border:1px solid var(--accent);transform:rotate(45deg)}.tour-tooltip.arrow-top:before{top:-6px;left:24px;border-right:none;border-bottom:none}.tour-tooltip.arrow-bottom:before{bottom:-6px;left:24px;border-left:none;border-top:none}.tour-tooltip.arrow-left:before{left:-6px;top:20px;border-right:none;border-top:none}.tour-tooltip.arrow-right:before{right:-6px;top:20px;border-left:none;border-bottom:none}.tour-tooltip.centered{left:50%!important;top:50%!important;transform:translate(-50%,-50%)}.tour-tooltip.centered:before{display:none}.tour-kbd{display:inline-block;background:var(--border);border:1px solid var(--border2);border-radius:3px;padding:1px 6px;font-size:10px;font-family:DM Mono,monospace;color:var(--text);margin:0 2px}.tour-shortcut-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.tour-shortcut-list li{display:flex;align-items:center;gap:6px}.tour-waiting-hint{font-size:10px;color:var(--accent);margin-bottom:10px;opacity:.8}.tour-key-done{font-size:10px;color:var(--accent);margin-bottom:10px;font-weight:500}.dashboard-wrapper{width:100%;height:100%;display:flex;flex-direction:row;overflow:hidden}.dashboard{flex:1;height:100%;position:relative;min-width:0;min-height:0;overflow:visible}.dashboard>canvas{position:absolute;top:0;left:calc(-1 * var(--panel-size, 0px));width:calc(100% + 2 * var(--panel-size, 0px));height:100%;display:block;touch-action:none}.home-view-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;justify-content:center;padding-bottom:80px;pointer-events:none;z-index:50}.home-view-overlay-box{pointer-events:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 28px;text-align:center;font-family:var(--font);color:var(--text);display:flex;flex-direction:column;align-items:center;gap:8px}.home-view-overlay-box p{margin:0;font-size:13px}.home-view-overlay-hint{opacity:.6;font-size:11px!important}.home-view-overlay-hint kbd{display:inline-block;padding:1px 6px;border:1px solid var(--border);border-radius:4px;font-family:var(--font);font-size:11px}.home-view-overlay-cancel{margin-top:4px;padding:4px 16px;background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:11px;cursor:pointer;opacity:.7;transition:opacity .15s}.home-view-overlay-cancel:hover{opacity:1}@media(max-width:768px){.dashboard-wrapper{flex-direction:column}.dashboard{order:-1}.dashboard>canvas{left:0;top:auto;bottom:calc(-1 * var(--panel-size, 0px));width:100%;height:calc(100% + 2 * var(--panel-size, 0px))}}@font-face{font-family:DM Mono;font-style:normal;font-weight:300;font-display:swap;src:url(/3Dash_webapp/fonts/dm-mono-300-latin-ext.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Mono;font-style:normal;font-weight:300;font-display:swap;src:url(/3Dash_webapp/fonts/dm-mono-300-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Mono;font-style:normal;font-weight:400;font-display:swap;src:url(/3Dash_webapp/fonts/dm-mono-400-latin-ext.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Mono;font-style:normal;font-weight:400;font-display:swap;src:url(/3Dash_webapp/fonts/dm-mono-400-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Mono;font-style:normal;font-weight:500;font-display:swap;src:url(/3Dash_webapp/fonts/dm-mono-500-latin-ext.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Mono;font-style:normal;font-weight:500;font-display:swap;src:url(/3Dash_webapp/fonts/dm-mono-500-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root,[data-theme=dark]{--bg: #0a0e1a;--surface: #0d1424;--surface-alpha: rgba(13, 20, 36, 1);--border: #1a2236;--border2: #243044;--text: #e2e8f0;--muted: #64748b;--accent: #38bdf8;--accent-dim:#0f3a52;--green: #4ade80;--yellow: #fbbf24;--red: #f87171;--orange: #fb923c;--backdrop-bg: rgba(0,0,0,.5);--backdrop-blur: blur(4px);--panel-dots: none;--panel-dots-size: auto;--panel-border: #1a2236;--panel-border-width: 1px;--side-panel-bg: rgba(10, 14, 26, .2);--corner-radius: 8px}[data-theme=light]{--bg: #f0f2f5;--surface: #ffffff;--surface-alpha: rgba(255, 255, 255, 1);--border: #d1d5db;--border2: #b0b8c4;--text: #1e293b;--muted: #64748b;--accent: #0284c7;--accent-dim:#dbeafe;--green: #16a34a;--yellow: #ca8a04;--red: #dc2626;--orange: #ea580c;--backdrop-bg: rgba(0,0,0,.5);--backdrop-blur: blur(4px);--panel-dots: none;--panel-dots-size: auto;--panel-border: #d1d5db;--panel-border-width: 1px;--side-panel-bg: rgba(240, 242, 245, .2);--corner-radius: 8px}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg);font-family:DM Mono,monospace;color:var(--text);overflow:hidden;width:100vw;height:100vh}#root{width:100%;height:100%}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}
