@import"https://fonts.googleapis.com/css2?family=Exo:wght@400;500;600;700&display=swap";:root{color-scheme:light;--brand-primary: #49b83c;--brand-primary-dark: #13612e;--brand-neutral-700: #2d3748;--brand-neutral-600: #4a5568;--brand-neutral-500: #575e62;--brand-surface-soft: #edf2f7;--brand-surface: #f7fafc;--brand-white: #ffffff;--brand-accent-blue: #1159af;--brand-accent-orange: #f5a524;--brand-danger: #b82105;--color-bg-app: #f7fafc;--color-bg-card: #ffffff;--color-bg-muted: #edf2f7;--color-text-primary: #2d3748;--color-text-secondary: #575e62;--color-border-subtle: #e5e7eb;--color-action-primary: #49b83c;--color-action-primary-hover: #13612e;--color-action-secondary: #13612e;--color-state-warning: #f5a524;--color-state-danger: #b82105;--bg: var(--color-bg-app);--panel: var(--color-bg-card);--ink: var(--color-text-primary);--muted: var(--color-text-secondary);--accent: var(--color-action-primary);--accent-2: var(--brand-primary-dark);--shadow: 0 10px 24px rgba(45, 55, 72, .08);font-family:Exo,Noto Sans,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);min-height:100vh}button{font:inherit;border:none;background:none}.login-shell{min-height:100vh;display:grid;place-items:center;padding:28px}.app-fatal-error{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--color-bg-card)}.app-fatal-error-card{width:min(760px,100%);border:1px solid var(--color-border-subtle);border-radius:14px;background:var(--panel);padding:20px;display:grid;gap:12px}.app-fatal-error-card h1{margin:0;font-size:24px}.app-fatal-error-card p{margin:0;color:var(--muted)}.app-fatal-error-card code{display:block;white-space:pre-wrap;overflow-wrap:anywhere;border:1px solid var(--color-border-subtle);border-radius:10px;background:#0000000a;padding:10px}.login-card{width:min(420px,100%);background:var(--panel);border:1px solid var(--color-border-subtle);border-radius:14px;padding:28px;box-shadow:var(--shadow)}.login-card h1{margin:0;font-size:30px;letter-spacing:-.01em}.login-btn{margin-top:12px;font-size:14px;padding:10px 16px}.app-shell{min-height:100vh;max-width:1500px;margin:0 auto;padding:20px;display:grid;grid-template-columns:300px 1fr;gap:0}.app-sidebar{background:var(--color-bg-muted);border:1px solid var(--color-border-subtle);border-right:none;border-radius:14px 0 0 14px;padding:20px;display:flex;flex-direction:column;min-height:calc(100vh - 40px)}.sidebar-brand{margin-bottom:18px}.sidebar-brand h1{margin:0;font-size:28px;letter-spacing:-.01em}.sub{margin:6px 0 0;color:var(--muted)}.sidebar-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.sidebar-toggle .tab{flex:1}.sidebar-devices{flex:1;min-height:0;border-top:1px solid var(--color-border-subtle);padding-top:14px;display:flex;flex-direction:column}.admin-sidebar-sections{display:flex;flex-direction:column}.sidebar-section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.sidebar-section-title h2{margin:0;font-size:16px}.app-main{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:0 14px 14px 0;display:flex;flex-direction:column;min-height:calc(100vh - 40px);overflow:hidden}.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin:0}.app-topbar{padding:18px 24px;border-bottom:1px solid var(--color-border-subtle)}.topbar-heading h2{margin:0;font-size:26px;letter-spacing:-.01em}.mobile-sidebar-toggle,.mobile-sidebar-backdrop{display:none}.mobile-sidebar-toggle{width:38px;height:38px;border:1px solid var(--color-border-subtle);border-radius:10px;background:var(--color-bg-card);align-items:center;justify-content:center;gap:4px;cursor:pointer;padding:8px}.mobile-sidebar-toggle span{display:block;width:100%;height:2px;border-radius:999px;background:var(--color-text)}.topbar-actions{display:flex;align-items:center;gap:12px;margin-left:auto;flex-wrap:wrap;justify-content:flex-end}.mode-toggle{display:flex;gap:8px}.auth-value{font-size:12px;font-weight:600}.auth-groups{font-size:11px;color:var(--muted)}.auth-btn{border-radius:10px;font-size:12px;font-weight:600;padding:6px 12px;background:var(--accent);color:#fff;cursor:pointer}.auth-btn:hover{background:var(--color-action-primary-hover)}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-btn-danger{background:#b84040}.auth-btn-danger:hover{background:#9f3434}.kebab-btn{width:34px;height:34px;border:1px solid var(--color-border-subtle);border-radius:10px;background:var(--color-bg-card);display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer}.kebab-btn span{width:4px;height:4px;border-radius:999px;background:var(--color-text-secondary)}.kebab-btn:hover{border-color:var(--accent)}.topbar-auth{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.topbar-auth-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;margin-right:2px}.topbar-auth-email{font-size:13px;font-weight:600;line-height:1.2}.topbar-auth-groups{font-size:11px;color:var(--muted);line-height:1.2}.sidebar-auth-mobile{display:none}.auth-error{color:var(--color-state-danger);margin:14px 24px 0;font-size:13px}.status-dot{width:12px;height:12px;padding:0;border:none;border-radius:999px;background:#8a9197;box-shadow:0 0 0 3px #8a919726;cursor:help}.status-dot.connected{background:#49b83c;box-shadow:0 0 0 3px #49b83c29}.status-dot.connecting,.status-dot.reconnecting{background:#f5a524;box-shadow:0 0 0 3px #f5a5242e}.status-dot.error{background:#b82105;box-shadow:0 0 0 3px #b8210524}.status-dot.disconnected,.status-dot.auth-required,.status-dot.session-expired{background:#8a9197;box-shadow:0 0 0 3px #8a919726}.app-content{padding:18px 24px 24px;overflow:auto}.muted{color:var(--muted)}.panel{background:var(--panel);border-radius:12px;border:1px solid var(--color-border-subtle);padding:20px;box-shadow:none;animation:rise .25s ease}@keyframes rise{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.panel-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.panel-title h2{margin:0;font-size:18px}.count{background:var(--color-bg-muted);padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600}.device-list{display:flex;flex-direction:column;gap:12px;flex:1;min-height:0;max-height:none;overflow:auto;padding-right:2px}.device-item{text-align:left;border:1px solid var(--color-border-subtle);border-radius:10px;padding:12px 14px;background:var(--color-bg-card);cursor:pointer;transition:transform .2s ease,border-color .2s ease}.device-item:hover{transform:translateY(-2px);border-color:var(--accent)}.device-item.active{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent),0 6px 14px #14182114}.device-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.device-id{font-weight:600}.device-subhead{margin-bottom:8px;color:var(--muted);font-size:12px}.pill{padding:4px 8px;border-radius:999px;font-size:12px}.pill.ok{background:#49b83c2e;color:var(--brand-primary-dark)}.pill.off{background:var(--color-bg-muted);color:var(--color-text-secondary)}.last-seen-pill{text-transform:none}.device-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--muted)}.device-badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 8px;background:var(--color-bg-muted);color:var(--color-text-secondary);font-weight:600}.device-badge.battery.ok{background:#49b83c33;color:var(--brand-primary-dark)}.device-badge.battery.warn{background:#f5a52438;color:var(--color-state-warning)}.device-badge.battery.crit{background:#b8210529;color:var(--color-state-danger)}.device-badge.heat-pump.active{background:#f5a52438;color:var(--color-state-danger)}.device-badge.neutral,.device-badge.heat-pump.neutral,.device-badge.tank.neutral,.device-badge.battery.neutral{background:var(--color-bg-muted);color:var(--color-text-secondary)}.telemetry-view{display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 280px);overflow-y:auto;padding-right:6px}.telemetry-card{border-radius:12px;border:1px solid var(--color-border-subtle);padding:12px 14px;background:var(--color-bg-card)}.telemetry-header{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:8px}.telemetry-card pre{margin:0;font-size:12px;color:var(--color-text-primary);white-space:pre-wrap}.source{font-weight:600;color:var(--accent)}.empty{color:var(--muted);font-size:14px}.tabs{display:flex;gap:8px;margin-bottom:16px}.tab{padding:6px 12px;border-radius:999px;background:var(--color-bg-muted);font-size:12px;font-weight:600;cursor:pointer}.tab.active{background:var(--accent);color:#fff}.mode-toggle-underlined,.tabs-underlined{gap:0;border-bottom:1px solid var(--color-border-subtle)}.topbar-lang-toggle{border-bottom:none}.mode-toggle-underlined .tab,.tabs-underlined .tab{background:transparent;border-radius:0;padding:10px 18px 12px;font-size:13px;font-weight:600;color:var(--color-text-secondary);border-bottom:3px solid transparent}.mode-toggle-underlined .tab.active,.tabs-underlined .tab.active{background:transparent;color:var(--color-action-secondary);border-bottom-color:var(--color-action-secondary)}.mode-toggle-underlined .tab:hover,.tabs-underlined .tab:hover{color:var(--brand-primary-dark)}.topbar-lang-toggle .tab{padding:6px 10px;border-bottom-width:2px}.admin-panel{display:flex;flex-direction:column;gap:14px}.admin-split{display:grid;grid-template-columns:minmax(300px,360px) minmax(0,1fr);gap:16px;align-items:start}.admin-sidebar-pane,.admin-detail-pane{display:flex;flex-direction:column;gap:14px;min-width:0}.admin-list-card{border:1px solid var(--color-border-subtle);border-radius:14px;padding:14px;background:var(--color-bg-card);display:flex;flex-direction:column;gap:12px}.admin-list{display:flex;flex-direction:column;gap:8px}.admin-list-item{width:100%;border:1px solid var(--color-border-subtle);border-radius:12px;padding:10px 12px;background:var(--color-bg-card);text-align:left;display:flex;flex-direction:column;gap:4px;cursor:pointer}.app-sidebar .admin-list-item{background:transparent}.admin-list-item.active{border-color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 25%,transparent)}.admin-list-item-title{font-weight:700;color:var(--color-text)}.admin-list-item-subtitle,.admin-list-item-meta{font-size:12px;color:var(--color-text-secondary)}.admin-empty-detail{border:1px dashed var(--color-border-subtle);border-radius:14px;padding:24px;background:var(--color-bg-card);color:var(--color-text-secondary)}.admin-create{border:1px solid var(--color-border-subtle);border-radius:14px;padding:14px;background:var(--color-bg-card)}.admin-create h3{margin:0 0 12px;font-size:16px}.installation-card{gap:12px}.installation-card-header{display:flex;justify-content:space-between;gap:12px;align-items:baseline;flex-wrap:wrap}.installation-card-header h3{margin:0}.installation-action-row{display:flex;gap:8px;flex-wrap:wrap}.admin-grid{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:10px;margin-bottom:12px}.admin-form-stack{display:flex;flex-direction:column;gap:10px}.modal-overlay{position:fixed;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-card{width:min(640px,100%);max-height:calc(100vh - 40px);overflow:auto;border:1px solid var(--color-border-subtle);border-radius:14px;background:var(--color-bg-card);padding:16px;display:flex;flex-direction:column;gap:12px}.modal-card h3{margin:0}.modal-actions{display:flex;justify-content:flex-end;gap:8px}.account-actions-modal{width:min(560px,100%)}.account-actions-meta{display:grid;gap:6px;font-size:14px}.account-actions-row{justify-content:flex-start}.account-language-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.account-language-label{font-size:13px;color:var(--color-text-secondary)}.account-delete-block{border:1px solid var(--color-border-subtle);border-radius:10px;padding:12px;display:grid;gap:8px}.account-delete-note{margin:0}.account-actions-footer{margin-top:4px;padding-top:10px;border-top:1px solid var(--color-border-subtle);font-size:12px;display:grid;gap:4px}.admin-generic-form{display:flex;flex-direction:column;gap:12px}.admin-generic-form-grid{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:10px}.admin-form-field{display:flex;flex-direction:column;gap:6px}.admin-form-field span{font-size:12px;color:var(--color-text-secondary)}.admin-wide{grid-column:1 / -1}.admin-input{width:100%;border:1px solid var(--color-border-subtle);border-radius:8px;padding:8px 10px;font:inherit;background:var(--color-bg-card)}.admin-input:focus{outline:none;border-color:var(--accent)}.admin-checkbox-row{display:inline-flex;align-items:center;gap:8px;min-height:40px}.assign-field{display:flex;flex-direction:column;gap:8px}.assign-controls{display:flex;gap:8px}.assign-controls .admin-input{flex:1}.assign-chips{display:flex;flex-wrap:wrap;gap:6px}.assign-chip{border-radius:999px;padding:4px 10px;border:1px solid var(--color-border-subtle);background:var(--color-bg-card);color:var(--color-text-secondary);font-size:12px;cursor:pointer}.assign-chip:disabled{opacity:.65;cursor:not-allowed}.assign-help{margin:0}.admin-table-wrap{overflow-x:auto}.admin-security-warning{display:flex;flex-direction:column;gap:4px;padding:10px 12px;border-radius:12px;border:1px solid rgba(191,140,46,.35);background:#f5bc1e1f;color:#6b5310;font-size:12px}.admin-security-warning strong{font-size:12px;font-weight:700}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th,.admin-table td{border-bottom:1px solid var(--color-border-subtle);padding:8px;text-align:left;vertical-align:top}.admin-table th{white-space:nowrap}.admin-action-danger{margin-left:8px}.admin-device-status-grid{display:flex;flex-wrap:wrap;gap:8px}.admin-device-status-card{border:1px solid var(--color-border-subtle);border-radius:999px;padding:6px 10px;background:color-mix(in srgb,var(--color-bg-card) 92%,white);display:inline-flex;align-items:center;gap:6px}.admin-device-status-card span{font-size:11px;color:var(--color-text-secondary);text-transform:lowercase}.admin-device-status-card strong{font-size:13px}.admin-debug-section{margin-top:14px;border:1px solid var(--color-border-subtle);border-radius:12px;padding:14px;background:color-mix(in srgb,var(--color-bg-card) 94%,white);display:flex;flex-direction:column;gap:12px}.admin-debug-header{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.admin-debug-header h4{margin:0;font-size:15px}.admin-debug-actions{display:flex;gap:8px}.admin-debug-input-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-debug-result-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:10px}.admin-debug-result-card{border:1px solid var(--color-border-subtle);border-radius:10px;background:color-mix(in srgb,var(--color-bg-card) 92%,white);padding:10px}.admin-debug-result-card h5{margin:0 0 8px;font-size:13px}.admin-debug-result-card pre{margin:0;max-height:260px;overflow:auto;font-size:12px;line-height:1.35;background:color-mix(in srgb,var(--color-bg-card) 85%,black 5%);border-radius:8px;padding:8px}.admin-status-meta-grid{display:grid;grid-template-columns:repeat(2,minmax(140px,1fr));gap:8px;margin-bottom:10px}.admin-status-meta-row{border:1px solid var(--color-border-subtle);border-radius:8px;padding:8px;background:color-mix(in srgb,var(--color-bg-card) 95%,white);display:flex;flex-direction:column;gap:4px}.admin-status-meta-row span{font-size:12px;color:var(--color-text-secondary)}.admin-status-meta-row strong{font-size:13px;word-break:break-word}.admin-status-sections{display:flex;flex-direction:column;gap:10px}.admin-color-legend{border:1px solid var(--color-border-subtle);border-radius:8px;padding:8px;background:color-mix(in srgb,var(--color-bg-card) 95%,white);display:flex;flex-direction:column;gap:6px}.admin-color-legend-title{font-size:12px;color:var(--color-text-secondary);font-weight:700}.admin-color-legend-items{display:flex;flex-wrap:wrap;gap:8px 14px}.admin-color-legend-item{display:inline-flex;align-items:center;gap:6px;font-size:12px}.admin-color-legend-swatch{width:16px;height:12px;border-radius:3px;border:1px solid rgba(0,0,0,.2)}.admin-color-legend-swatch.excel-legend-user{background:#92d050}.admin-color-legend-swatch.excel-legend-operator{background:#5b9bd5}.admin-color-legend-swatch.excel-legend-constants{background:#d9d9d9}.admin-color-legend-swatch.excel-legend-computed{background:#ffc000}.admin-color-legend-swatch.excel-legend-sensor{background:#c56bc0}.admin-color-legend-swatch.excel-legend-setpoint{background:#e4c7e5}.admin-status-section{border:1px solid var(--color-border-subtle);border-radius:8px;padding:8px;background:color-mix(in srgb,var(--color-bg-card) 95%,white)}.admin-status-section-main{padding:6px}.admin-status-section h6{margin:0 0 6px;font-size:12px;color:var(--color-text-secondary);letter-spacing:.02em}.admin-status-table-wrap{max-height:240px;overflow:auto}.admin-status-table-wrap-main{max-height:min(68vh,860px)}.admin-status-table{width:100%;border-collapse:collapse;font-size:12px}.admin-status-table th,.admin-status-table td{border-bottom:1px solid var(--color-border-subtle);text-align:left;vertical-align:top;padding:5px 6px}.admin-status-table th{position:sticky;top:0;background:color-mix(in srgb,var(--color-bg-card) 90%,white);z-index:1;color:var(--color-text-secondary);font-weight:700}.admin-status-table td{word-break:break-word}.admin-status-table td.excel-legend-user{background:#92d050}.admin-status-table td.excel-legend-operator{background:#5b9bd5}.admin-status-table td.excel-legend-constants{background:#d9d9d9}.admin-status-table td.excel-legend-computed{background:#ffc000}.admin-status-table td.excel-legend-sensor{background:#c56bc0}.admin-status-table td.excel-legend-setpoint{background:#e4c7e5}.admin-status-table td[class*=excel-legend-] .admin-variable-edit-input{background:#ffffffeb}.admin-variable-edit-row{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.admin-variable-edit-controls{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}.admin-variable-edit-input{width:110px;min-width:0;padding:4px 8px;font-size:12px}.admin-variable-edit-input:disabled{opacity:.7}.admin-variable-upload-btn{width:24px;min-width:24px;height:24px;padding:0;border-radius:6px;font-size:12px;line-height:1}.admin-variable-upload-btn:disabled{background:#9aa0a6;color:#f5f5f5;opacity:1}.admin-variable-digest-state{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.02em}.admin-variable-digest-state.state-pending{color:#8d6a00}.admin-variable-digest-state.state-applied{color:#13612e}.admin-variable-digest-state.state-timeout,.admin-variable-digest-state.state-failed{color:#9b1c1c}.admin-status-field-raw{color:var(--color-text-muted);font-size:11px}.admin-log-toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;flex-wrap:wrap}.admin-log-toolbar .admin-form-field{margin:0;min-width:220px}.admin-log-toolbar-actions{display:flex;align-items:center;gap:8px}.admin-log-stream-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:12px;color:var(--color-text-secondary)}.admin-log-message-cell{white-space:pre-wrap;word-break:break-word;font-family:JetBrains Mono,Fira Mono,monospace;font-size:11px;line-height:1.45}.admin-log-time-col,.admin-log-time-cell{width:112px;min-width:112px}.admin-log-time-cell{white-space:nowrap}.admin-log-source-col,.admin-log-source-cell{width:108px;min-width:108px}.admin-log-kv-pair{display:inline}.admin-log-kv-key{color:#2f5d85;font-weight:700}.admin-log-kv-value{color:#0d4a1f}.admin-log-source-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;line-height:1.4}.admin-log-source-badge.admin-log-source-powersaver{background:#e7f6ea;color:#14532d}.admin-log-source-badge.admin-log-source-cloud{background:#fff6d8;color:#7c5a00}.admin-log-source-badge.admin-log-source-algorithm{background:#e8f2ff;color:#0f4f9f}.admin-log-source-badge.admin-log-source-modbus{background:#fde9e9;color:#8a1a1a}.admin-log-source-badge.admin-log-source-default{background:#eceff3;color:#41505f}.admin-log-row.admin-log-level-err{background:#fde9e9}.admin-log-row.admin-log-level-wrn{background:#fff6d8}.admin-log-row.admin-log-level-inf{background:#e8f2ff}.admin-log-row.admin-log-level-dbg{background:#e9f8ea}.admin-log-row.admin-log-level-trc{background:#efe3d4}.admin-var-unit{color:#0f6a86;font-weight:700}.admin-var-name[title]{cursor:help;text-decoration-line:underline;text-decoration-style:dotted;text-decoration-color:#0f6a868c;text-underline-offset:2px}.admin-role-pill,.admin-quality-pill{font-weight:700}.admin-role-pill.role-input{color:#1159af}.admin-role-pill.role-output{color:#7f2f8f}.admin-role-pill.role-derived{color:#0f6a86}.admin-quality-pill.q-good{color:#13612e}.admin-quality-pill.q-suspect{color:#8d6a00}.admin-quality-pill.q-bad{color:#9b1c1c}.admin-quality-pill.q-missing{color:#6c6f75}.mono{font-family:Space Mono,SFMono-Regular,Menlo,monospace;font-size:12px}.panel-view,.house-view,.history-view,.management-view{display:flex;flex-direction:column;gap:16px}.house-top-layout{display:grid;grid-template-columns:280px minmax(0,1fr);gap:14px}.house-label-toggle{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.house-label-toggle-main{display:inline-flex;align-items:center;gap:10px}@media(max-width:1100px){.admin-split,.admin-generic-form-grid,.admin-debug-input-grid,.admin-debug-result-grid,.admin-status-meta-grid{grid-template-columns:1fr}.admin-status-table-wrap-main{max-height:min(62vh,680px)}}.house-label-toggle-text{font-size:13px;color:var(--color-text-secondary);font-weight:600}.house-mini-range{display:inline-flex;align-items:center;gap:10px}.house-mini-range-label{font-size:12px;font-weight:600;color:var(--color-text-secondary)}.house-mini-range-tabs{min-width:120px}.house-mini-range-tabs .tab{min-width:48px}.house-mini-range-tabs .tab:disabled{opacity:.45;cursor:default}.house-switch{position:relative;width:42px;height:24px}.house-switch input{opacity:0;width:0;height:0}.house-switch span{position:absolute;inset:0;border-radius:999px;background:#cfd7d2;transition:background .2s ease}.house-switch span:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;border-radius:999px;background:#fff;box-shadow:0 1px 3px #00000040;transition:transform .2s ease}.house-switch input:checked+span{background:#4ab83d}.house-switch input:checked+span:before{transform:translate(18px)}.house-side-panel{background:#61666e;border:1px solid #7a8088;border-radius:14px;padding:14px 12px;display:flex;flex-direction:column;gap:14px}.house-actions{display:flex;flex-direction:column;gap:8px}.house-action-btn{width:100%;min-height:34px;font-size:12px}.house-action-message{color:#fff;font-size:11px;line-height:1.3}.house-side-group{border:1px solid rgba(140,220,120,.45);border-radius:12px;padding:10px 8px;display:flex;flex-direction:column;gap:10px}.house-side-row{display:grid;grid-template-columns:minmax(0,1fr) 120px;align-items:center;gap:10px}.house-side-label{color:#fff;font-size:11px;font-weight:600;line-height:1.2;text-transform:uppercase}.house-side-value{background:#ffffffe0;color:#353a40;border-radius:8px;min-height:36px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;padding:4px 8px;text-align:center}.house-side-value-missing{border:1px dashed rgba(72,75,80,.35);cursor:help}.house-canvas-wrap{border:1px solid var(--color-border-subtle);border-radius:14px;background:linear-gradient(180deg,#f7faf7,#edf4ee);padding:12px;overflow-x:auto}.house-main-wrap{position:relative;border:1px solid var(--color-border-subtle);border-radius:14px;background:#fff;padding:50px 8px 8px;overflow:hidden}@media(max-width:980px){.house-top-layout{grid-template-columns:1fr}.house-main-wrap{order:1}.house-side-panel{order:2}}.house-main-stack{position:relative;width:100%;max-width:976px;margin:0 auto}.house-brand-mark{position:absolute;z-index:1;top:14px;right:5%;width:160px;max-width:19%;height:auto;pointer-events:none}.house-main-stage{width:100%;height:auto;aspect-ratio:762.91003 / 601.25958;display:block}.house-main-stage-flow,.house-main-stage-labels{position:absolute;inset:0;pointer-events:none}.house-label-pointer-svg{fill:#54575b}.house-label-layer{position:absolute;inset:0;pointer-events:none}.house-label-fo-card{width:100%;height:100%;box-sizing:border-box;border-radius:10px;border:1px solid #45484c;background:#54575b;box-shadow:0 4px 10px #00000040;color:#fff;position:relative;overflow:hidden;clip-path:inset(0 round 10px);isolation:isolate;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:8px 10px;line-height:1.1;font-family:Poppins,sans-serif}.house-label-fo-content{position:relative;z-index:2;width:100%;display:flex;flex-direction:column;align-items:center;gap:2px}.house-label-fo-card .house-label-title,.house-label-fo-card .house-label-value,.house-label-fo-card .house-label-meta{white-space:normal;overflow-wrap:anywhere;word-break:break-word}.house-label-fo-mini-wrap{position:absolute;inset:0;z-index:1;opacity:.42;overflow:hidden;pointer-events:none}.house-label-card{position:absolute;z-index:2;background:#54575b;border:1px solid #45484c;border-radius:10px;padding:8px 10px;box-sizing:border-box;color:#fff;text-align:center;box-shadow:0 4px 10px #00000040;line-height:1.1;font-family:Poppins,sans-serif;isolation:isolate;--label-fit-scale: 1}.house-label-card-with-mini{padding-bottom:32px}.house-label-content{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.14em;transform-origin:center center;transform:scale(var(--label-fit-scale));width:100%;text-align:center}.house-label-mini-wrap{position:absolute;left:0;right:0;bottom:0;height:38%;min-height:24px;z-index:1;pointer-events:none;overflow:hidden;border-bottom-left-radius:8px;border-bottom-right-radius:8px}.house-label-card:after{content:"";position:absolute;display:none}.house-label-card.pointer-bottom:after,.house-label-card.pointer-top:after,.house-label-card.pointer-left:after,.house-label-card.pointer-right:after{display:block}.house-label-card.pointer-bottom:after{left:var(--pointer-offset, 50%);bottom:-9px;margin-left:-7px;width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-top:10px solid #54575b}.house-label-card.pointer-top:after{left:var(--pointer-offset, 50%);top:-9px;margin-left:-7px;width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:10px solid #54575b}.house-label-card.pointer-left:after{left:-9px;top:var(--pointer-offset, 50%);margin-top:-7px;width:0;height:0;border-top:7px solid transparent;border-bottom:7px solid transparent;border-right:10px solid #54575b}.house-label-card.pointer-right:after{right:-9px;top:var(--pointer-offset, 50%);margin-top:-7px;width:0;height:0;border-top:7px solid transparent;border-bottom:7px solid transparent;border-left:10px solid #54575b}.house-label-card-wide{min-width:140px}.house-label-title{font-size:10px;font-weight:700;color:#fff;white-space:nowrap;width:100%;text-align:center}.house-label-value{font-size:14px;font-weight:800;color:#fff;white-space:nowrap;width:100%;text-align:center}.house-label-meta{font-size:11px;font-weight:700;color:#fff;white-space:nowrap;width:100%;text-align:center}.house-label-mini{width:100%;height:100%;display:block}.house-label-mini-area{fill:#484b502e}.house-label-mini-line{fill:none;stroke:#484b50;stroke-width:1.8}.house-flow-track{stroke:color-mix(in srgb,var(--path-color, #4ab83d) 34%,transparent);stroke-width:2.8;fill:none;stroke-linecap:round;stroke-linejoin:round}.house-flow-live{stroke:var(--path-color, #4ab83d);stroke-width:3.2;fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:10 9;opacity:var(--flow-opacity, 0);animation:house-flow-move var(--flow-speed, 2.8s) linear infinite;filter:drop-shadow(0 0 2px color-mix(in srgb,var(--path-color, #4ab83d) 55%,transparent))}.house-flow-live.reverse{animation-direction:reverse}.house-inverter-bg{fill:#ffffff59;stroke:#febe0bb3;stroke-width:1.4}.house-inverter-power{fill:#febe0b;opacity:.45;filter:drop-shadow(0 0 4px rgba(254,190,11,.5))}.house-inverter-power.active{opacity:1;animation:house-inverter-pulse 1s ease-in-out infinite}@media(max-width:980px){.house-main-wrap{padding-top:30px}.house-brand-mark{top:12px;right:5%;width:98px;max-width:19%}}.house-fan-blade{fill:#f5bc1e;opacity:.6;transform-box:fill-box;transform-origin:center}.house-fan-blade.active{opacity:.95;animation:house-fan-spin 1.3s linear infinite}.house-fan-blade-alt.active{animation-duration:1.1s}@keyframes house-flow-move{0%{stroke-dashoffset:0}to{stroke-dashoffset:-38}}@keyframes house-fan-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes house-inverter-pulse{0%{opacity:.35;filter:drop-shadow(0 0 3px rgba(254,190,11,.35))}50%{opacity:1;filter:drop-shadow(0 0 9px rgba(254,190,11,.85))}to{opacity:.45;filter:drop-shadow(0 0 4px rgba(254,190,11,.45))}}.house-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px}.house-meta-card{border:1px solid var(--color-border-subtle);background:var(--color-bg-card);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--color-text-secondary)}.house-meta-card strong{font-size:16px;color:var(--color-text-primary)}.badge-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.badge{border-radius:14px;padding:12px;background:var(--color-bg-muted);border:1px dashed var(--color-border-subtle);display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--muted)}.badge strong{font-size:16px;color:var(--ink)}.ha-card{border-radius:18px;border:1px solid var(--color-border-subtle);padding:16px 18px;background:var(--color-bg-card);color:var(--color-text-primary);display:flex;flex-direction:column;gap:8px;min-height:190px;aspect-ratio:3 / 2;box-shadow:var(--shadow);position:relative;overflow:hidden;width:100%;min-width:0}.ha-header{display:flex;justify-content:space-between;font-size:13px;color:var(--color-text-secondary)}.ha-value{font-size:24px;font-weight:600;letter-spacing:-.01em;margin-bottom:0;z-index:2}.ha-value small{font-size:12px;color:var(--color-text-secondary)}.ha-sparkline{width:100%;height:66%;position:absolute;left:0;right:0;bottom:0;z-index:1;display:block}.ha-sparkline-area{fill:#49b83c33;stroke:none}.ha-sparkline-line{fill:none;stroke:var(--color-action-primary);stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}.history-chart-wrap{position:relative;border-radius:14px;border:1px solid var(--color-border-subtle);background:var(--color-bg-card);padding:28px 12px 12px}.history-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}.history-picker-wrap{position:relative}.history-param-btn{min-width:120px}.history-param-popover{position:absolute;z-index:30;top:calc(100% + 8px);left:0;width:min(360px,90vw);background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:12px;box-shadow:var(--shadow);padding:10px;display:flex;flex-direction:column;gap:8px}.history-param-list{max-height:240px;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.history-param-option{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-primary)}.history-date{display:flex;flex-direction:column;gap:6px;min-width:180px;font-size:12px;color:var(--muted)}.history-date-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.history-date-row .admin-input{flex:1;min-width:180px}.history-today-btn{white-space:nowrap;min-width:84px;justify-content:center}.history-period-tabs{display:flex;gap:6px;flex-wrap:wrap}.history-period-tabs.tabs-underlined{margin-left:auto;margin-right:8px}.history-period-tabs.tabs-underlined .tab{padding:7px 12px 9px}.history-chart{width:900px;height:320px;display:block;margin-bottom:10px}.history-chart-canvas{width:100%;overflow-x:auto;overflow-y:hidden}.history-line{fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}.history-grid-line{stroke:var(--color-border-subtle);stroke-width:1;stroke-dasharray:5 6}.history-axis-line{stroke:var(--color-border-subtle);stroke-width:1.2}.history-axis-tick{stroke:var(--color-border-subtle);stroke-width:1}.history-axis-label{fill:var(--color-text-secondary);font-size:11px}.history-axis-unit{fill:var(--color-text-primary);font-size:13px;font-weight:600}.history-legend{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.history-legend-item{display:inline-flex;align-items:center;gap:6px;background:var(--color-bg-muted);border-radius:999px;padding:4px 10px;font-size:12px;color:var(--color-text-primary)}.history-legend-color{width:10px;height:10px;border-radius:999px;display:inline-block}.history-range-slider{display:flex;flex-direction:column;gap:8px}.history-range-track{position:relative;height:26px;border-radius:999px;background:var(--color-bg-muted);overflow:visible}.history-range-selection{position:absolute;top:0;bottom:0;border-radius:999px;background:#49b83c47}.history-range-thumb{position:absolute;left:0;top:0;width:100%;height:26px;background:transparent;margin:0;pointer-events:none;appearance:none}.history-range-thumb::-webkit-slider-thumb{appearance:none;width:22px;height:22px;border-radius:999px;border:1px solid var(--color-border-subtle);background:var(--color-bg-card);box-shadow:0 2px 6px #0003;cursor:pointer;pointer-events:auto}.history-range-thumb::-moz-range-thumb{width:22px;height:22px;border-radius:999px;border:1px solid var(--color-border-subtle);background:var(--color-bg-card);box-shadow:0 2px 6px #0003;cursor:pointer;pointer-events:auto}.history-range-thumb::-webkit-slider-runnable-track{background:transparent}.history-range-thumb::-moz-range-track{background:transparent}.history-range-labels{display:flex;justify-content:space-between;gap:10px;font-size:12px;color:var(--muted)}.history-range-thumb:focus{outline:none}.history-range-thumb:focus::-webkit-slider-thumb{border-color:var(--accent)}.history-range-thumb:focus::-moz-range-thumb{border-color:var(--accent)}.history-range-slider input[type=range]{width:100%}.history-remove-btn{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:999px;border:1px solid var(--color-border-subtle);background:var(--color-bg-card);color:var(--color-state-danger);font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.history-remove-btn:hover{border-color:var(--color-state-danger);background:#b8210514}.history-add-btn{width:100%;border:2px dashed var(--color-action-secondary);border-radius:12px;color:var(--color-action-secondary);padding:10px 14px;font-size:18px;font-weight:600;text-align:center;cursor:pointer;background:transparent}.admin-add-btn{font-size:14px;font-weight:700}.history-add-btn:hover{background:#49b83c14}.management-stack{display:flex;flex-direction:column;gap:12px}.management-actions{display:flex;justify-content:flex-end;margin:8px 0 2px}.management-table{display:flex;flex-direction:column;gap:12px}.management-row{display:grid;grid-template-columns:240px 1fr;align-items:center;gap:12px;border:1px solid var(--color-border-subtle);background:#f2f2f2;padding:12px 14px}.management-row.user-row .management-input{background:#e3e3e3}.management-row.admin-row .management-input{background:#cbe6c1}.management-row-name{font-size:22px;line-height:1;color:#222}.management-row-inputs{display:flex;flex-wrap:wrap;gap:10px}.management-input-group{display:flex;flex-direction:column;gap:4px;min-width:220px;flex:1 1 220px}.management-input-label{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#2b2f36}.management-inline-note{display:inline-flex;align-items:center;font-size:13px;color:#2f2f2f;padding:0 2px}.management-input{width:100%;min-width:0;border:2px solid #7287a6;border-radius:10px;padding:8px 10px;font-size:18px;color:#111}.management-input:focus{outline:none;border-color:var(--color-action-secondary)}.management-input[disabled]{opacity:.85;cursor:not-allowed}.management-footnote{margin:0;font-size:15px;color:#2f2f2f}.management-sync-row{display:inline-flex;align-items:center;gap:8px}.management-sync-spinner{width:14px;height:14px;border-radius:999px;border:2px solid #c8ced8;border-top-color:var(--color-action-secondary);animation:management-sync-spin .9s linear infinite}@keyframes management-sync-spin{to{transform:rotate(360deg)}}.management-view .muted{font-size:13px}@media(max-width:1400px){.management-row{grid-template-columns:220px 1fr}.management-row-name{font-size:20px}.management-input{font-size:17px}}@media(max-width:900px){.management-row{grid-template-columns:1fr}.management-row-inputs{flex-direction:column}}.danger-btn{background:var(--color-state-danger)}@media(max-width:900px){body.mobile-sidebar-open{overflow:hidden}.app-shell{grid-template-columns:1fr;padding:0;position:relative}.app-sidebar{position:fixed;top:0;left:0;bottom:0;z-index:50;width:min(360px,82vw);min-height:100vh;transform:translate(-110%);transition:transform .2s ease;border-right:1px solid var(--color-border-subtle);border-radius:0 12px 12px 0;box-shadow:0 18px 48px #0f172a38}.sidebar-auth-mobile{display:block;margin-top:auto;border-top:1px solid var(--color-border-subtle);padding-top:12px}.sidebar-auth-mobile .topbar-auth{justify-content:flex-start;gap:8px}.sidebar-auth-mobile .topbar-auth-meta{align-items:flex-start;margin-right:0;width:100%}.topbar-auth-desktop{display:none}.app-sidebar.mobile-open{transform:translate(0)}.mobile-sidebar-backdrop{display:block;position:fixed;inset:0;z-index:40;border:none;padding:0;margin:0;background:#00000047}.app-main{border-radius:0;min-height:auto;margin-top:0}.app-topbar{position:sticky;top:0;z-index:30;background:var(--color-bg-card);padding:12px 16px}.topbar-heading{display:flex;align-items:center;gap:10px}.topbar-heading h2{margin:0;font-size:20px;line-height:1.2}.mobile-sidebar-toggle{display:inline-flex}.app-content{padding:14px 16px 16px}.device-list{max-height:none}.admin-grid{grid-template-columns:1fr}}
