*,*: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}.automations-paused-banner{background:#d4934a1a;border-bottom:1px solid rgba(212,147,74,.3);color:var(--warn);font-size:12px;font-weight:500;text-align:center;padding:7px 16px;cursor:pointer;letter-spacing:.02em}.automations-paused-banner:hover{background:#d4934a2e}.holiday-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;background:#c9a87c26;border:1px solid var(--accent);color:var(--accent);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,.cov-btn-stop{flex:1}.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{display:flex;align-items:center;gap:8px;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)}.hd-active-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px;background:#c9a87c26;color:var(--accent);text-transform:none;letter-spacing:0}.hd-period-row{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border)}.hd-period-label{font-size:13px;font-weight:500;margin-right:8px}.hd-period-dates{font-size:12px;color:var(--text-dim);font-family:var(--font-mono)}.hd-add-form{display:flex;flex-wrap:wrap;gap:8px;padding:10px 16px}.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-badge.gardena-zone{color:#3b82f6;border-color:#3b82f6}.mgmt-badge.gardena-mower{color:#f97316;border-color:#f97316}.mgmt-badge.gardena-sensor{color:#22c55e;border-color:#22c55e}.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);letter-spacing:.01em}.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-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px}.dash-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.dash-card-title{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);margin-bottom:14px}.dash-card-header .dash-card-title{margin-bottom:0}.dash-empty{font-size:13px;color:var(--text-dim)}.dash-placeholder{opacity:.55}.windschutz-banner{display:flex;align-items:flex-start;gap:10px;background:#e070601a;border:1px solid var(--danger);border-radius:var(--radius-md);padding:12px 14px;margin-bottom:12px;color:var(--danger)}.ws-banner-title{font-size:14px;font-weight:600}.ws-banner-sub{font-size:12px;opacity:.8;margin-top:2px}.wx-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.wx-tile{background:var(--bg-elev);border-radius:var(--radius-md);padding:12px}.wx-tile-wide{grid-column:span 1}.wx-icon{color:var(--text-dim);margin-bottom:6px;display:block}.wx-val{font-family:var(--font-mono);font-size:18px;font-weight:500;line-height:1.1}.wx-unit{font-size:12px;color:var(--text-dim)}.wx-sub{font-size:12px;color:var(--text-dim);margin-top:2px}.wx-label{font-size:11px;color:var(--text-dim);margin-top:4px;text-transform:uppercase;letter-spacing:.06em}.wx-rain{border:1px solid rgba(212,147,74,.4)}.wx-rain .wx-val{color:var(--warn)}.solar-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.solar-item{background:var(--bg-elev);border-radius:var(--radius-sm);padding:10px 12px}.solar-val{font-family:var(--font-mono);font-size:16px;font-weight:500}.solar-label{font-size:11px;color:var(--text-dim);margin-top:2px;text-transform:uppercase;letter-spacing:.06em}.solar-badge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;letter-spacing:.04em}.solar-sunny{background:#c9a87c26;color:var(--accent)}.solar-cloudy{background:#8a82781f;color:var(--text-dim)}.solar-night{background:#6464a01f;color:#88b}.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-text{font-size:13px;color:var(--text-dim);margin-top:10px}.wx-detail-grid{display:flex;flex-direction:column;gap:0;margin-bottom:14px}.wx-detail-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}.wx-detail-item:last-child{border-bottom:none}.wx-detail-item span:first-child{color:var(--text-dim)}.wx-detail-item .mono{font-family:var(--font-mono);font-size:13px}.wx-charts{display:flex;flex-direction:column;gap:10px}.wx-chart-row{display:flex;align-items:center;gap:10px}.wx-chart-label{font-size:11px;color:var(--text-dim);min-width:60px;text-transform:uppercase;letter-spacing:.05em}.sr-card{border-left:3px solid transparent;border-bottom:1px solid var(--border);transition:border-color .2s}.sr-card.sr-on{border-left-color:var(--green)}.sr-card.sr-off{border-left-color:var(--border);opacity:.7}.sr-card-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;gap:10px}.sr-card-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.sr-card-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.sr-type-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sr-name{font-size:14px;font-weight:500;display:block}.sr-type-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em}.sr-active-badge{font-size:11px;font-weight:600;padding:2px 7px;border-radius:10px;background:#e0706026;color:var(--danger)}.sr-toggle-btn{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:5px 8px;cursor:pointer;display:flex;align-items:center;color:var(--text-dim)}.sr-toggle-btn.on{border-color:var(--green);color:var(--green)}.sr-toggle-btn.off{border-color:var(--border)}.sr-body{padding:0 16px 16px}.sr-field{margin-bottom:10px}.sr-field label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin-bottom:5px}.sr-row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.sr-group-chips{display:flex;flex-wrap:wrap;gap:6px}.sr-chip{background:var(--bg-elev);border:1px solid var(--border);border-radius:20px;padding:4px 10px;font-size:12px;cursor:pointer;color:var(--text)}.sr-chip.selected{background:#c9a87c26;border-color:var(--accent);color:var(--accent)}.sr-valve-row{display:flex;gap:6px;align-items:center;margin-bottom:6px}.sr-override-badge{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 7px;border-radius:10px;background:#c9a87c1f;color:var(--accent)}.sr-override-cancel{background:none;border:none;color:var(--accent);cursor:pointer;font-size:14px;padding:0 2px;line-height:1}.scenes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.scene-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:14px 8px;border-radius:var(--radius-md);background:var(--bg-elev);border:1px solid var(--border);color:var(--text);font-size:12px;font-weight:500;cursor:pointer;transition:border-color .15s,color .15s}.scene-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.scene-btn.firing{border-color:var(--accent);color:var(--accent);opacity:.7}.scene-btn:disabled{opacity:.5;cursor:not-allowed}.gd-emergency-stop{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;border-radius:var(--radius-md);background:#e070601a;border:1.5px solid var(--danger);color:var(--danger);font-size:15px;font-weight:600;cursor:pointer;margin-bottom:16px;transition:background .15s}.gd-emergency-stop:hover:not(:disabled){background:#e0706033}.gd-emergency-stop:disabled{opacity:.5;cursor:not-allowed}.garden-section{margin-bottom:16px}.garden-section-title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);padding:0 2px 8px}.garden-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;margin-bottom:8px}.garden-card.gd-active{border-color:#5ba4cf66}.garden-card.gd-mower-active{border-color:#74c69d66}.garden-card.offline{opacity:.55}.gd-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.gd-name{display:flex;align-items:center;gap:7px;font-size:14px;font-weight:500}.gd-edit-btn{display:flex;align-items:center;background:none;border:none;color:var(--text-dim);padding:2px;cursor:pointer;opacity:.5}.gd-edit-btn:hover{opacity:1}.gd-name-input{font-size:14px;font-weight:500;font-family:inherit;background:none;border:none;border-bottom:1px solid var(--accent);color:var(--text);outline:none;width:130px;padding:0}.gd-status{font-size:12px}.gd-running{color:var(--green);font-weight:600}.gd-idle{color:var(--text-dim)}.gd-offline{color:var(--danger)}.gd-sensor-card .gd-card-top{margin-bottom:10px}.gd-sensor-values{display:flex;flex-wrap:wrap;gap:12px}.gd-sensor-val{display:flex;align-items:baseline;gap:3px}.gd-sensor-icon{font-size:13px;margin-right:1px}.gd-sensor-icon.moisture{color:#60a5fa}.gd-sensor-icon.temp{color:var(--accent)}.gd-sensor-icon.ambient{color:var(--text-dim)}.gd-sensor-icon.lux{color:#fbbf24;font-style:normal}.gd-sensor-num{font-size:18px;font-weight:600;line-height:1;font-variant-numeric:tabular-nums}.gd-sensor-unit{font-size:12px;color:var(--text-dim);margin-left:1px}.gd-sensor-label{font-size:11px;color:var(--text-dim);margin-left:4px}.gd-conflict{font-size:12px;color:var(--warn);margin-bottom:8px;background:#d4934a14;border-radius:var(--radius-sm);padding:6px 8px}.gd-dur-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.gd-dur-label{font-family:var(--font-mono);font-size:13px;color:var(--text-dim);min-width:36px}.gd-start-btn,.gd-stop-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:9px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:opacity .15s}.gd-start-btn{background:#5ba4cf1f;border:1px solid #5ba4cf66;color:#5ba4cf}.gd-start-btn:hover:not(:disabled){background:#5ba4cf33}.gd-stop-btn{background:#e070601a;border:1px solid var(--danger);color:var(--danger)}.gd-start-btn:disabled,.gd-stop-btn:disabled{opacity:.4;cursor:not-allowed}.gd-mower-btns{display:flex;gap:8px}.gd-mow-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:9px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;background:var(--bg-elev);border:1px solid var(--border);color:var(--text)}.gd-mow-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.gd-mow-btn:disabled{opacity:.4;cursor:not-allowed}.gd-floor-mini{background:var(--bg-card);border-top:1px solid var(--border)}.gd-floor-mini-row{display:flex;align-items:center;justify-content:space-between;padding:7px 16px;border-bottom:1px solid var(--border);font-size:13px}.gd-floor-mini-row:last-child{border-bottom:none}.gd-floor-mini-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.gd-floor-mini-status{font-size:11px;color:var(--text-muted);flex-shrink:0;margin-left:8px}.gd-floor-mini-status.offline{opacity:.45}.gd-room-section{display:flex;flex-direction:column;gap:8px;padding:10px 12px 12px;border-bottom:1px solid var(--border)}.gd-room-section:last-child{border-bottom:none}.gd-room-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:0 2px 2px}.gd-room-label .room-dot{background:var(--gc, var(--border-light))}.room-unit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:6px 0 2px}.compact-cell{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px;display:flex;flex-direction:column;gap:4px}.compact-cell.offline{opacity:.55}.compact-combo-cell{gap:0}.compact-combo-title{font-size:10px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;padding-bottom:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.compact-divider{border:none;border-top:1px solid var(--border);margin:5px 0}.compact-device{display:flex;flex-direction:column;gap:3px}.compact-device-header{display:flex;align-items:center;justify-content:space-between;gap:4px}.compact-device-name{font-size:11px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.compact-device-pct{font-size:11px;font-family:var(--font-mono);color:var(--accent);flex-shrink:0}.compact-bar{height:3px;background:var(--border-light);border-radius:2px;overflow:hidden}.compact-bar-fill{height:100%;background:var(--gc, var(--accent));border-radius:2px}.compact-btns{display:flex;gap:2px;margin-top:1px}.compact-btn{flex:1;font-size:10px;padding:3px 0;background:var(--bg);border:1px solid var(--border);border-radius:3px;color:var(--text-muted);cursor:pointer;transition:background .1s,color .1s}.compact-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text)}.compact-btn:disabled{opacity:.35;cursor:not-allowed}.log-toolbar{display:flex;gap:8px;margin-bottom:10px}.log-search{flex:1;display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 10px}.log-search-icon{color:var(--text-dim);flex-shrink:0}.log-search-input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:14px;padding:9px 0}.log-meta{font-size:12px;color:var(--text-dim);margin-bottom:8px}.log-list{display:flex;flex-direction:column;gap:2px}.log-entry{background:var(--bg-card);border-radius:var(--radius-sm);padding:10px 12px;border:1px solid transparent}.log-entry:hover{border-color:var(--border)}.log-entry-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:4px}.log-action{font-size:13px;font-weight:500}.log-ts{font-size:11px;color:var(--text-dim);font-family:var(--font-mono);flex-shrink:0}.log-entry-meta{display:flex;flex-wrap:wrap;gap:6px}.log-device,.log-source,.log-triggered,.log-reason{font-size:11px;padding:1px 6px;border-radius:10px;background:var(--bg-elev);color:var(--text-dim)}.log-reason{color:var(--text-dim);font-style:italic}.log-loading,.log-empty{color:var(--text-dim);font-size:13px;text-align:center;padding:20px}.log-more-btn{width:100%;margin-top:10px;padding:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-dim);font-size:13px;cursor:pointer}.log-more-btn:hover{border-color:var(--accent);color:var(--text)}.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}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0000008c;display:flex;align-items:flex-start;justify-content:center;padding:48px 16px 16px}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:100%;max-width:480px;max-height:calc(100vh - 80px);display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;font-size:14px;font-weight:600;border-bottom:1px solid var(--border)}.modal-close{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:2px;display:flex;align-items:center}.modal-close:hover{color:var(--text)}.modal-body{padding:14px 16px;overflow-y:auto}.scan-subnet-row{display:flex;align-items:center;gap:8px;margin-bottom:14px}.scan-results{display:flex;flex-direction:column;gap:6px}.scan-result-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;background:var(--surface-raised, var(--bg));border:1px solid var(--border);border-radius:8px}.scan-result-info{display:flex;flex-direction:column;gap:2px;min-width:0}.scan-result-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scan-result-meta{font-size:11px;color:var(--text-dim)}.scan-result-known{font-size:11px;color:var(--text-dim);white-space:nowrap}
