*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--font-body: "DM Sans", system-ui, sans-serif;--font-mono: "DM Mono", "Courier New", monospace;--bg: #0e0e0e;--bg-card: #181818;--bg-elevated: #222222;--bg-elev: #222222;--bg-input: #2a2a2a;--text: #ede8e0;--text-muted: #8a8278;--text-dim: #504c47;--accent: #c9a87c;--accent-dim: rgba(201, 168, 124, .13);--warn: #d4934a;--warning: #d4934a;--danger: #e07060;--danger-dim: rgba(224, 112, 96, .13);--green: #74c69d;--online: #74c69d;--offline: #504c47;--border: #2c2a27;--border-light: #3a3733;--radius: 16px;--radius-md: 11px;--radius-sm: 8px;--tab-h: 64px;--header-h: 56px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}@media (prefers-color-scheme: light){:root{--bg: #f2efe9;--bg-card: #ffffff;--bg-elevated: #ece9e2;--bg-elev: #ece9e2;--bg-input: #f7f5f1;--text: #1a1714;--text-muted: #6b6560;--text-dim: #b0aa9f;--accent: #9a7040;--accent-dim: rgba(154, 112, 64, .1);--warn: #a0601a;--warning: #a0601a;--danger: #c04030;--danger-dim: rgba(192, 64, 48, .1);--green: #2e8a5a;--online: #2e8a5a;--offline: #c0bab0;--border: #e0dbd2;--border-light: #d4cfc5}}.gc-blue{--gc: #3b82f6}.gc-green{--gc: #22c55e}.gc-orange{--gc: #f97316}.gc-red{--gc: #ef4444}.gc-purple{--gc: #a855f7}.gc-yellow{--gc: #eab308}.gc-pink{--gc: #ec4899}.gc-teal{--gc: #14b8a6}.gc-{--gc: var(--border-light)}html{height:100%}.font-mono{font-family:var(--font-mono)}body{height:100%;font-family:var(--font-body);background:var(--bg);color:var(--text);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;overscroll-behavior:none}#root{height:100%;display:flex;flex-direction:column}.app{display:flex;flex-direction:column;height:100%;padding-top:var(--safe-top)}.app-header{height:var(--header-h);display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0;gap:12px}.app-header-title{font-size:16px;font-weight:600;color:var(--text);white-space:nowrap}.app-header-right{display:flex;align-items:center;gap:10px}.mode-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;border:1px solid var(--border-light);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.app-content{flex:1;overflow-y:auto;padding-bottom:calc(var(--tab-h) + var(--safe-bottom));-webkit-overflow-scrolling:touch}.tab-bar{position:fixed;bottom:0;left:0;right:0;height:calc(var(--tab-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);display:flex;background:var(--bg-card);border-top:1px solid var(--border);z-index:100}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:11px;font-weight:500;padding:0;transition:color .15s;-webkit-tap-highlight-color:transparent}.tab-btn.active{color:var(--accent)}.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100%;padding:24px}.login-card{width:100%;max-width:360px;background:var(--bg-card);border-radius:var(--radius);padding:32px 24px;border:1px solid var(--border)}.login-title{font-size:20px;font-weight:700;margin-bottom:4px}.login-sub{font-size:13px;color:var(--text-muted);margin-bottom:28px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field label{font-size:13px;font-weight:500;color:var(--text-muted)}.field input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;font-size:15px;color:var(--text);outline:none;transition:border-color .15s;width:100%}.field input:focus{border-color:var(--accent)}.btn-primary{width:100%;padding:12px;background:var(--accent);color:#000;font-size:15px;font-weight:600;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:opacity .15s;margin-top:8px}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.error-msg{font-size:13px;color:var(--danger);margin-top:10px;text-align:center}.stop-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--danger-dim);color:var(--danger);border:1px solid var(--danger);border-radius:var(--radius-sm);font-size:13px;font-weight:700;cursor:pointer;transition:background .15s;white-space:nowrap;-webkit-tap-highlight-color:transparent}.stop-btn:active{background:var(--danger);color:#fff}.page{padding:16px;display:flex;flex-direction:column;gap:24px;max-width:680px;margin:0 auto;width:100%}.weather-bar{display:flex;align-items:center;gap:16px;padding:10px 14px;background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border);flex-wrap:wrap}.weather-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted)}.weather-item strong{color:var(--text);font-weight:600}.weather-stale{font-size:12px;color:var(--text-dim);margin-left:auto}.group-section{display:flex;flex-direction:column;gap:10px}.group-header{display:flex;align-items:center;gap:10px;padding:0 2px}.group-dot{width:10px;height:10px;border-radius:50%;background:var(--gc, var(--border-light));flex-shrink:0}.group-name{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.group-count{font-size:12px;color:var(--text-dim)}.empty-state{text-align:center;color:var(--text-muted);padding:48px 24px;font-size:14px}.cover-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);border-left:3px solid var(--gc, var(--border-light));padding:14px 16px;display:flex;flex-direction:column;gap:12px;transition:opacity .2s}.cover-card.offline{opacity:.5}.cover-card-inner{display:flex;align-items:center;gap:12px}.cover-icon-box{width:48px;height:48px;border-radius:var(--radius-sm);background:var(--accent-dim);border:1px solid var(--border-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}.cover-info{flex:1;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:8px}.cover-name{font-size:15px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.cover-meta{display:flex;align-items:center;gap:8px;flex-shrink:0}.cover-pos-val{font-size:13px;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:34px;text-align:right}.online-dot{width:8px;height:8px;border-radius:50%;background:var(--offline);flex-shrink:0}.online-dot.is-online{background:var(--online)}.cover-controls{display:flex;gap:6px}.cover-btn{display:flex;align-items:center;justify-content:center;gap:4px;padding:8px 6px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text);font-size:12px;font-weight:500;cursor:pointer;transition:background .12s,border-color .12s,color .12s,opacity .12s;-webkit-tap-highlight-color:transparent;white-space:nowrap}.cover-btn:active:not(:disabled){background:var(--bg-input)}.cover-btn:disabled{opacity:.35;cursor:not-allowed}.cov-btn-up,.cov-btn-down{flex:1}.cov-btn-stop{flex:0 0 36px}.cov-btn-up:not(:disabled):hover{border-color:var(--accent);color:var(--accent)}.cov-btn-down:not(:disabled):hover{border-color:var(--warning);color:var(--warning)}.cov-btn-stop:not(:disabled):hover{border-color:var(--danger);color:var(--danger)}.cover-slider{width:100%;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:linear-gradient(to right,var(--gc, var(--accent)) calc(var(--val, 50) * 1%),var(--border) calc(var(--val, 50) * 1%));border-radius:2px;outline:none;cursor:pointer}.cover-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:var(--bg-card);border:2px solid var(--gc, var(--accent));border-radius:50%;cursor:pointer}.cover-slider::-moz-range-thumb{width:20px;height:20px;background:var(--bg-card);border:2px solid var(--gc, var(--accent));border-radius:50%;cursor:pointer}.cover-slider:disabled{cursor:not-allowed;opacity:.4}.settings-section{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}.settings-section-title{padding:10px 16px;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border)}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;gap:12px;border-bottom:1px solid var(--border)}.settings-row:last-child{border-bottom:none}.settings-row-label{display:flex;flex-direction:column;gap:2px}.settings-row-label span:first-child{font-size:15px;font-weight:500}.settings-row-label span:last-child{font-size:12px;color:var(--text-muted)}.toggle{position:relative;width:48px;height:28px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border-light);border-radius:14px;transition:background .2s;cursor:pointer}.toggle input:checked+.toggle-track{background:var(--accent)}.toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:22px;height:22px;background:#fff;border-radius:50%;transition:transform .2s}.toggle input:checked+.toggle-track:after{transform:translate(20px)}.toggle input:disabled+.toggle-track{opacity:.4;cursor:not-allowed}.settings-btn{padding:8px 16px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-weight:500;cursor:pointer;white-space:nowrap}.mgmt-row{border-bottom:1px solid var(--border)}.mgmt-row:last-child{border-bottom:none}.mgmt-row-summary{display:flex;align-items:center;gap:10px;padding:12px 16px;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.mgmt-row-summary:active{background:var(--bg-elevated)}.mgmt-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.mgmt-row-name{flex:1;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mgmt-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:20px;border:1px solid var(--border-light);color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;flex-shrink:0}.mgmt-badge.floor{color:var(--accent);border-color:var(--accent)}.mgmt-badge.active{color:var(--green);border-color:var(--green)}.mgmt-badge.inactive{color:var(--text-dim)}.mgmt-chevron{color:var(--text-dim);flex-shrink:0;transition:transform .15s}.mgmt-chevron.open{transform:rotate(180deg)}.mgmt-edit-form{padding:12px 16px 16px;background:var(--bg-elevated);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:12px}.mgmt-field{display:flex;flex-direction:column;gap:5px}.mgmt-field label{font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em}.mgmt-input{background:var(--bg-input);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:9px 12px;font-size:14px;font-family:var(--font-body);color:var(--text);outline:none;transition:border-color .15s;width:100%}.mgmt-input:focus{border-color:var(--accent)}.mgmt-select{background:var(--bg-input);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:9px 12px;font-size:14px;font-family:var(--font-body);color:var(--text);outline:none;width:100%;cursor:pointer}.color-swatches{display:flex;gap:8px;flex-wrap:wrap}.color-swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s,border-color .1s;flex-shrink:0}.color-swatch.selected{border-color:var(--text);transform:scale(1.15)}.mgmt-actions{display:flex;gap:8px;padding-top:4px}.mgmt-btn{flex:1;padding:9px 8px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:var(--font-body);border:1px solid var(--border-light);background:var(--bg-input);color:var(--text);cursor:pointer;transition:background .12s}.mgmt-btn:active{background:var(--bg-elevated)}.mgmt-btn.primary{background:var(--accent);border-color:var(--accent);color:#0e0e0e}.mgmt-btn.danger{background:transparent;border-color:var(--danger);color:var(--danger)}.mgmt-btn:disabled{opacity:.4;cursor:not-allowed}.mgmt-add-row{padding:12px 16px;display:flex;align-items:center;gap:8px;color:var(--accent);font-size:14px;font-weight:500;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;border-top:1px solid var(--border)}.mgmt-add-row:active{background:var(--bg-elevated)}.mgmt-filter{display:flex;gap:0;background:var(--bg-elevated);border-radius:var(--radius-sm);padding:3px;margin-bottom:4px}.mgmt-filter-btn{flex:1;padding:7px 8px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);font-size:12px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:background .12s,color .12s}.mgmt-filter-btn.active{background:var(--bg-card);color:var(--text)}.splash{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:14px}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.floor-section{display:flex;flex-direction:column;gap:0;border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}.floor-header{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;background:var(--bg-card);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;gap:10px}.floor-header-left{display:flex;align-items:baseline;gap:10px}.floor-label{font-size:15px;font-weight:700;color:var(--text);letter-spacing:.04em}.floor-device-count{font-size:12px;color:var(--text-dim)}.floor-chevron{color:var(--text-dim);flex-shrink:0;transition:transform .2s}.floor-chevron.open{transform:rotate(180deg)}.floor-mini-grid{background:var(--bg-card);border-top:1px solid var(--border)}.floor-mini-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:10px;padding:9px 16px;border-bottom:1px solid var(--border)}.floor-mini-row:last-child{border-bottom:none}.floor-mini-name{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.floor-mini-pct{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);min-width:32px;text-align:right}.floor-mini-bar{width:44px;height:4px;background:var(--border-light);border-radius:2px;overflow:hidden}.floor-mini-bar-fill{height:100%;background:var(--gc, var(--accent));border-radius:2px}.floor-body{background:var(--bg);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:0}.room-section{display:flex;flex-direction:column;gap:8px;padding:12px 12px 14px;border-bottom:1px solid var(--border)}.room-section:last-child{border-bottom:none}.room-header{display:flex;align-items:center;gap:8px;padding:0 4px}.room-dot{width:8px;height:8px;border-radius:50%;background:var(--gc, var(--border-light));flex-shrink:0}.room-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.room-count{font-size:11px;color:var(--text-dim)}.combo-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);border-left:3px solid var(--gc, var(--border-light));overflow:hidden;transition:opacity .2s}.combo-card.offline{opacity:.5}.combo-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;gap:10px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.combo-header-left{display:flex;align-items:center;gap:10px;min-width:0}.combo-chevron{color:var(--text-dim);flex-shrink:0;transition:transform .2s}.combo-chevron.open{transform:rotate(180deg)}.combo-title{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.combo-summary{display:flex;gap:12px}.combo-summary-item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-muted)}.combo-summary-item strong{font-family:var(--font-mono);color:var(--text);font-size:13px}.combo-mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border-top:1px solid var(--border)}.combo-mini-cell{background:var(--bg-card);padding:10px 14px;display:flex;align-items:center;gap:10px}.combo-mini-name{font-size:12px;font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.combo-mini-pct{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);min-width:30px;text-align:right}.combo-mini-bar-wrap{width:36px;height:4px;background:var(--border-light);border-radius:2px;overflow:hidden}.combo-mini-bar-fill{height:100%;background:var(--gc, var(--accent));border-radius:2px;transition:width .3s ease}.combo-expanded-body{display:flex;gap:0;border-top:1px solid var(--border)}.combo-diagram-col{width:72px;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:16px 8px;border-right:1px solid var(--border)}.combo-controls-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:0}.combo-device-row{padding:12px 14px;display:flex;flex-direction:column;gap:10px}.combo-device-row+.combo-device-row{border-top:1px solid var(--border)}.combo-device-label{display:flex;align-items:center;justify-content:space-between}.combo-device-name{font-size:13px;font-weight:600}.combo-device-pct{font-family:var(--font-mono);font-size:12px;color:var(--text-muted)}.bg-card-section{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:16px}.dash-weather-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.dash-wx-item{display:flex;align-items:flex-start;gap:10px;color:var(--text-muted)}.dash-wx-val{font-family:var(--font-mono);font-size:18px;font-weight:500;color:var(--text);line-height:1.1}.dash-wx-val span{font-size:11px;font-weight:400;color:var(--text-muted)}.dash-wx-label{font-size:11px;color:var(--text-dim);margin-top:2px}.dash-placeholder{opacity:.5}.dash-placeholder-text{font-size:13px;color:var(--text-dim);margin-top:10px}.stub-page{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 24px;color:var(--text-muted);max-width:680px;margin:0 auto;width:100%}.stub-page-icon{color:var(--text-dim)}.stub-page-title{font-size:18px;font-weight:600;color:var(--text)}.stub-page-sub{font-size:13px}.section-title{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;padding:0 2px}
