:root{--bg:#f0f2f5;--card:#fff;--card-hover:#f8fafc;--text:#1f2937;--text-secondary:#6b7280;--border:#e5e7eb;--primary:#3b82f6;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--pv:#f59e0b;--grid:#6366f1;--batt:#10b981;--load:#ef4444;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5}[data-theme=dark]{--bg:#0f172a;--card:#1e293b;--card-hover:#334155;--text:#f1f5f9;--text-secondary:#94a3b8;--border:#334155;--primary:#60a5fa;--success:#34d399;--warning:#fbbf24;--danger:#f87171;--pv:#fbbf24;--grid:#818cf8;--batt:#34d399;--load:#f87171}body{background:var(--bg);color:var(--text);margin:0;transition:background .3s,color .3s}[data-theme=dark] ::-webkit-scrollbar{width:8px;height:8px}[data-theme=dark] ::-webkit-scrollbar-track{background:#0f172a}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#334155;border-radius:4px}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#475569}.loginPage{box-sizing:border-box;background:#f3f6fb;justify-content:center;align-items:flex-start;min-height:100vh;padding:40px 24px 60px;display:flex}.loginTabs{gap:0;margin-bottom:20px;padding:0;display:flex}.loginTab{cursor:pointer;color:#6b7280;-webkit-user-select:none;user-select:none;background:0 0;border:none;border-radius:12px;justify-content:center;align-items:center;padding:10px 16px;font-size:14px;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex}.loginTab:hover{color:#374151;background:#0284c70a}.loginTab.active{color:#fff;background:#0284c7;box-shadow:0 2px 8px #0284c74d}.loginCard{background:#fff;border:1px solid #e5e7eb;border-radius:16px;width:100%;max-width:420px;padding:22px;box-shadow:0 10px 30px #0f172a14}.loginTitle{color:#2768f3;font-size:22px;font-weight:900}.loginSub{color:#6b7280;margin-top:6px;font-size:13px}.loginForm{flex-direction:column;gap:12px;margin-top:16px;display:flex}.loginLabel{color:#374151;flex-direction:column;gap:8px;font-size:13px;display:flex}.loginInput{color:#111827;box-sizing:border-box;background:#fff;border:1px solid #d1d5db;border-radius:12px;outline:none;width:100%;padding:10px 12px}.loginInput:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.loginError{color:#b91c1c;background:#b91c1c0f;border:1px solid #b91c1c2e;border-radius:12px;padding:10px 12px;font-size:13px}.loginKickMsg{color:#b45309;background:#f59e0b14;border:1px solid #f59e0b40;border-radius:12px;padding:10px 12px;font-size:13px}.loginBtn{color:#fff;cursor:pointer;background:#0284c7;border:0;border-radius:12px;width:100%;margin-top:4px;padding:10px 14px;font-weight:700}.loginBtn:disabled{opacity:.5;cursor:not-allowed}.guideContent{text-align:center;flex-direction:column;align-items:center;padding:20px 0;display:flex}.guideTitle{color:#2768f3;margin-bottom:8px;font-size:20px;font-weight:800}.guideDesc{color:#6b7280;margin-bottom:24px;font-size:14px}.guideLink{color:#fff;background:#0284c7;border-radius:12px;align-items:center;gap:4px;padding:12px 28px;font-size:15px;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex;box-shadow:0 2px 8px #0284c740}.guideLink:hover{background:#0369a1;transform:translateY(-1px);box-shadow:0 4px 14px #0284c759}[data-theme=dark] .loginPage{background:#0f172a}[data-theme=dark] .loginTab{color:#94a3b8}[data-theme=dark] .loginTab:hover{color:#e2e8f0;background:#3b82f61a}[data-theme=dark] .loginTab.active{color:#fff;background:#2563eb}[data-theme=dark] .loginCard{background:#1e293b;border-color:#334155}[data-theme=dark] .loginTitle{color:#60a5fa}[data-theme=dark] .loginSub{color:#94a3b8}[data-theme=dark] .guideTitle{color:#60a5fa}[data-theme=dark] .guideDesc{color:#94a3b8}[data-theme=dark] .guideLink{background:#2563eb;box-shadow:0 2px 8px #2563eb59}[data-theme=dark] .guideLink:hover{background:#1d4ed8}[data-theme=dark] .loginLabel{color:#cbd5e1}[data-theme=dark] .loginInput{color:#e2e8f0;background:#0f172a;border-color:#475569}[data-theme=dark] .loginInput:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}@media (width<=600px){.loginPage{align-items:flex-start;padding:20px 16px 40px}.loginTab{padding:10px 20px;font-size:14px}}:root{--ha-bg:#f5f5f5;--ha-card-bg:#fff;--ha-card-radius:12px;--ha-border:#e8e8e8;--ha-shadow:0 1px 3px #0000000f;--ha-text-primary:#1a1a1a;--ha-text-secondary:#666;--ha-text-disabled:#999;--ha-success:#3fb950;--ha-danger:#f44336;--ha-warning:#ff9800;--ha-primary:#00aeff;--ha-hover:#0000000a}[data-theme=dark]{--ha-bg:#121212;--ha-card-bg:#1e1e1e;--ha-border:#333;--ha-shadow:0 1px 3px #0000004d;--ha-text-primary:#e8e8e8;--ha-text-secondary:#a0a0a0;--ha-text-disabled:#707070;--ha-success:#66bb6a;--ha-danger:#ef5350;--ha-warning:#ffb74d;--ha-primary:#58a6ff;--ha-hover:#ffffff0f}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--ha-bg);color:var(--ha-text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app-shell{background:var(--ha-bg);flex-direction:column;max-width:640px;min-height:100vh;margin:0 auto;display:flex;position:relative}.app-header{background:var(--ha-card-bg);border-bottom:1px solid var(--ha-border);z-index:100;justify-content:space-between;align-items:center;padding:8px 16px;display:flex;position:sticky;top:0}.app-header-left{align-items:center;gap:6px;display:flex}.app-header-center{text-align:center;flex:1}.app-header-right{align-items:center;gap:8px;display:flex}.app-status-text{color:var(--ha-text-secondary);font-size:12px}.device-sel{border:1px solid var(--ha-border);background:var(--ha-card-bg);color:var(--ha-text-primary);cursor:pointer;border-radius:8px;outline:none;max-width:200px;padding:6px 12px;font-size:13px;font-weight:600}.device-sel:focus{border-color:var(--ha-primary)}.icon-btn{cursor:pointer;width:32px;height:32px;color:var(--ha-text-primary);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:18px;display:flex}.kick-banner{color:#b45309;text-align:center;background:#f59e0b1a;border-bottom:1px solid #f59e0b4d;padding:8px 16px;font-size:12px;font-weight:500}.gw-dot{background:var(--ha-text-disabled);border-radius:50%;flex-shrink:0;width:8px;height:8px}.gw-dot.connected{background:var(--ha-success);box-shadow:0 0 6px var(--ha-success)}.gw-dot.disconnected{background:var(--ha-danger)}.tab-bar{border-top:1px solid var(--ha-border);background:var(--ha-card-bg);padding:6px 0;padding-bottom:calc(6px + env(safe-area-inset-bottom,0px));z-index:100;max-width:640px;margin:0 auto;display:flex;position:fixed;bottom:0;left:0;right:0}.tab-item{cursor:pointer;color:var(--ha-text-secondary);flex-direction:column;flex:1;align-items:center;gap:2px;padding:4px 0;transition:color .2s;display:flex;position:relative}.tab-item.active{color:var(--ha-primary)}.tab-icon{font-size:20px}.tab-label{font-size:10px;font-weight:500}.tab-badge{background:var(--ha-danger);color:#fff;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;display:flex;position:absolute;top:0;right:50%;transform:translate(14px)}.app-content{flex:1;padding-bottom:70px;overflow-y:auto}.page-empty{text-align:center;color:var(--ha-text-secondary);padding:80px 32px;font-size:14px}.gw-page{flex-direction:column;gap:8px;padding:0 8px;display:flex}.gw-overview{background:var(--ha-card-bg);border-radius:var(--ha-card-radius);border:1px solid var(--ha-border);justify-content:space-around;align-items:center;margin-top:8px;padding:12px 8px;display:flex}.gw-overview-item{flex-direction:column;flex:1;align-items:center;display:flex}.gw-overview-info{align-items:baseline;gap:2px;display:flex}.gw-overview-value{font-size:18px;font-weight:700}.gw-overview-unit{color:var(--ha-text-disabled);font-size:10px}.gw-overview-label{color:var(--ha-text-disabled);margin-top:2px;font-size:10px}.gw-overview-divider{background:var(--ha-border);width:1px;height:32px}.gw-dash-card{background:var(--ha-card-bg);border:1px solid var(--ha-border);border-radius:8px;overflow:hidden}.gw-dash-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.gw-dash-title-row{align-items:center;gap:6px;display:flex}.gw-dash-icon{font-size:16px}.gw-dash-title{color:var(--ha-text-primary);font-size:14px;font-weight:600}.gw-dash-summary{align-items:center;gap:4px;display:flex}.gw-dash-summary-value{color:var(--ha-text-primary);font-size:14px;font-weight:700}.gw-arrow{color:var(--ha-text-disabled);font-size:10px;transition:transform .2s}.gw-arrow.up{transform:rotate(180deg)}.gw-badge{background:var(--ha-border);color:var(--ha-text-secondary);border-radius:10px;padding:1px 8px;font-size:10px;font-weight:500}.gw-badge.discharging{color:var(--ha-success);background:#3fb95026}.gw-badge.charging{color:var(--ha-danger);background:#f4433626}.gw-badge.idle{color:var(--ha-text-disabled);background:#88888826}.gw-dash-body{border-top:1px solid var(--ha-border);padding:0 8px 8px}.gw-dash-grid-3{flex-wrap:wrap;padding-top:4px;display:flex}.gw-dash-item{text-align:center;width:33.33%;padding:4px 2px}.gw-dash-item-full{text-align:left;border-top:1px solid var(--ha-border);width:100%;margin-top:2px;padding-top:6px}.gw-dash-label{color:var(--ha-text-disabled);margin-bottom:1px;font-size:10px;display:block}.gw-dash-value{color:var(--ha-text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;display:block;overflow:hidden}.gw-dash-value.mono{font-family:Courier New,monospace;font-size:11px}.gw-pvtotal-val{font-weight:800;font-size:15px!important}.green{color:var(--ha-success)!important}.red{color:var(--ha-danger)!important}.orange{color:var(--ha-warning)!important}.blue{color:var(--ha-primary)!important}.golden{color:#f5a623!important}.gw-rssi-bar{text-align:center;color:var(--ha-text-disabled);padding:6px;font-size:11px}.ha-bms{flex-direction:column;gap:10px;padding:8px;display:flex}.ha-status-grid{background:var(--ha-card-bg);border-radius:var(--ha-card-radius);border:1px solid var(--ha-border);justify-content:space-around;gap:0;padding:10px 0;display:flex}.ha-status-item{align-items:center;gap:6px;display:flex}.ha-status-text{color:var(--ha-text-secondary);font-size:13px}.ha-status-dot{background:var(--ha-border);border-radius:50%;width:10px;height:10px;transition:all .3s}.ha-status-dot.on{background:var(--ha-success);box-shadow:0 0 8px #3fb95099}.ha-gauges-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.ha-gauge-card{background:var(--ha-card-bg);border-radius:var(--ha-card-radius);text-align:center;border:1px solid var(--ha-border);padding:12px 8px 8px}.ha-gauge-svg{width:100%;max-width:120px;height:auto;margin:0 auto 4px;display:block}.ha-gauge-info{flex-direction:column;align-items:center;gap:1px;display:flex}.ha-gauge-info.blue .ha-gauge-label{color:var(--ha-primary)}.ha-gauge-label{color:var(--ha-text-secondary);font-size:11px}.ha-gauge-value{color:var(--ha-text-primary);font-variant-numeric:tabular-nums;font-size:16px;font-weight:800}.ha-gauge-value.positive{color:var(--ha-success)}.ha-gauge-value.negative{color:var(--ha-warning)}.ha-tiles-grid{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.ha-tile{background:var(--ha-card-bg);border-radius:var(--ha-card-radius);border:1px solid var(--ha-border);flex-direction:column;align-items:center;gap:2px;padding:10px 4px 8px;display:flex}.ha-tile-icon{font-size:16px}.ha-tile-name{color:var(--ha-text-secondary);font-size:10px}.ha-tile-value{color:var(--ha-text-primary);font-variant-numeric:tabular-nums;font-size:13px;font-weight:700}.ha-tile-value small{color:var(--ha-text-secondary);margin-left:1px;font-size:9px;font-weight:400}.ha-section{background:var(--ha-card-bg);border-radius:var(--ha-card-radius);border:1px solid var(--ha-border);padding:12px}.ha-section-title{color:var(--ha-text-primary);margin-bottom:8px;font-size:13px;font-weight:700}.ha-temp-grid{grid-template-columns:repeat(6,1fr);gap:6px;display:grid}.ha-temp-tile{background:var(--ha-bg);border:1px solid var(--ha-border);border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:6px 2px;display:flex}.ha-temp-label{color:var(--ha-text-secondary);font-size:10px}.ha-temp-value{color:var(--ha-text-primary);font-size:13px;font-weight:600}.ha-cell-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:6px;display:flex}.ha-cell-header .ha-section-title{margin-bottom:0}.ha-cell-summary{gap:10px;display:flex}.ha-cs{font-size:11px;font-weight:500}.ha-cs.high{color:var(--ha-danger)}.ha-cs.low{color:var(--ha-primary)}.ha-cs.delta{color:var(--ha-warning)}.ha-cell-grid{grid-template-columns:repeat(4,1fr);gap:4px;margin-top:8px;display:grid}.ha-cell-mini{border-radius:6px;align-items:center;gap:3px;padding:3px 4px;display:flex}.hc-no{color:var(--ha-text-secondary);text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0;width:18px;font-size:10px}.hc-batt{border:1px solid var(--ha-border);background:var(--ha-bg);border-radius:3px;flex:1;justify-content:center;align-items:center;gap:1px;min-width:0;padding:2px 6px 2px 4px;transition:all .2s;display:flex}.hc-v{color:var(--ha-text-primary);font-variant-numeric:tabular-nums;font-size:11px;font-weight:600}.hc-u{color:var(--ha-text-secondary);font-size:8px}.hc-cap{background:var(--ha-border);border-radius:0 2px 2px 0;flex-shrink:0;width:3px;height:8px}.ha-cell-mini.max .hc-batt{background:#f4433614;border-color:#f4433699}.ha-cell-mini.max .hc-v{color:var(--ha-danger)}.ha-cell-mini.min .hc-batt{background:#00aeff14;border-color:#00aeff99}.ha-cell-mini.min .hc-v{color:var(--ha-primary)}.msg-page{padding:12px}.msg-page h2{color:var(--ha-text-primary);margin-bottom:12px;font-size:18px;font-weight:700}.msg-header{justify-content:space-between;align-items:center;display:flex}.msg-mark-all{border:1px solid var(--ha-border);background:var(--ha-card-bg);color:var(--ha-primary);cursor:pointer;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:600}.msg-tabs{gap:6px;margin:12px 0;display:flex}.msg-tab{border:1px solid var(--ha-border);background:var(--ha-card-bg);color:var(--ha-text-secondary);cursor:pointer;border-radius:8px;padding:6px 14px;font-size:12px;font-weight:500;transition:all .2s}.msg-tab.active{background:var(--ha-primary);color:#fff;border-color:var(--ha-primary)}.msg-list{flex-direction:column;gap:8px;display:flex}.msg-item{background:var(--ha-card-bg);border:1px solid var(--ha-border);cursor:pointer;border-radius:10px;padding:12px}.msg-item.unread{border-left:3px solid var(--ha-primary)}.msg-item-header{align-items:center;gap:6px;margin-bottom:4px;display:flex}.msg-item-type{font-size:14px}.msg-item-title{color:var(--ha-text-primary);flex:1;font-size:13px;font-weight:600}.msg-item-time{color:var(--ha-text-secondary);font-size:11px}.msg-item-body{color:var(--ha-text-secondary);font-size:12px;line-height:1.5}.msg-empty{text-align:center;color:var(--ha-text-secondary);padding:40px;font-size:13px}.smart-page{padding:12px}.smart-page h2{color:var(--ha-text-primary);margin-bottom:12px;font-size:18px;font-weight:700}.smart-cards{flex-direction:column;gap:10px;display:flex}.smart-card{background:var(--ha-card-bg);border-radius:var(--ha-card-radius);border:1px solid var(--ha-border);padding:12px}.smart-card.summary{border-left:3px solid var(--ha-primary)}.smart-card-title{color:var(--ha-text-primary);margin-bottom:6px;font-size:13px;font-weight:600}.smart-card-body{color:var(--ha-text-secondary);white-space:pre-wrap;font-size:12px;line-height:1.6}.me-page{padding:12px}.me-header{background:var(--ha-card-bg);border-radius:var(--ha-card-radius);border:1px solid var(--ha-border);align-items:center;gap:12px;margin-bottom:16px;padding:16px;display:flex}.me-avatar{background:var(--ha-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;font-weight:700;display:flex}.me-info{flex:1;min-width:0}.me-name{color:var(--ha-text-primary);font-size:16px;font-weight:700}.me-vip{color:var(--ha-text-secondary);margin-top:2px;font-size:12px}.me-expire{color:var(--ha-text-disabled);margin-left:6px}.me-section{background:var(--ha-card-bg);border-radius:var(--ha-card-radius);border:1px solid var(--ha-border);margin-bottom:12px;overflow:hidden}.me-section-title{color:var(--ha-text-secondary);padding:10px 16px 6px;font-size:12px;font-weight:600}.me-row{cursor:pointer;border-bottom:1px solid var(--ha-border);align-items:center;padding:12px 16px;transition:background .2s;display:flex}.me-row:last-child{border-bottom:none}.me-row:hover{background:var(--ha-hover)}.me-row-icon{margin-right:10px;font-size:16px}.me-row-label{color:var(--ha-text-primary);flex:1;font-size:14px}.me-row-value{color:var(--ha-text-secondary);font-size:13px}.me-field{margin-bottom:8px;padding:0 16px}.me-field:first-of-type{margin-top:8px}.me-input{border:1px solid var(--ha-border);background:var(--ha-bg);width:100%;color:var(--ha-text-primary);border-radius:8px;outline:none;padding:10px 12px;font-size:14px}.me-input:focus{border-color:var(--ha-primary)}.me-btn{background:var(--ha-primary);color:#fff;cursor:pointer;border:none;border-radius:8px;width:calc(100% - 32px);margin:8px 16px 12px;padding:10px;font-size:14px;font-weight:600;display:block}.me-btn:disabled{opacity:.5;cursor:not-allowed}.me-save-msg{text-align:center;color:var(--ha-primary);padding:0 16px 12px;font-size:12px}.me-logout{width:100%;color:var(--ha-danger);cursor:pointer;text-align:center;background:0 0;border:none;padding:12px;font-size:14px;font-weight:600;display:block}.me-logout:hover{background:#f443360f}.solar-tabs{-webkit-overflow-scrolling:touch;gap:6px;padding:8px 12px;display:flex;overflow-x:auto}.solar-tabs::-webkit-scrollbar{display:none}.solar-tab{border:1px solid var(--ha-border);color:var(--ha-text-primary);white-space:nowrap;cursor:pointer;background:0 0;border-radius:16px;align-items:center;gap:3px;padding:6px 12px;font-size:12px;display:flex}.solar-tab.active{background:var(--ha-primary);color:#fff;border-color:var(--ha-primary)}.solar-card{background:var(--ha-card-bg);border:1px solid var(--ha-border);border-radius:12px;margin:8px 12px;padding:14px}.solar-card-header{align-items:center;gap:6px;margin-bottom:10px;font-size:14px;font-weight:600;display:flex}.solar-card-header span:first-child{font-size:16px}.forecast-main{text-align:center}.forecast-kwh-wrap{justify-content:center;align-items:baseline;gap:4px;display:flex}.forecast-kwh{color:var(--ha-primary);font-size:36px;font-weight:700}.forecast-unit{color:var(--ha-text-secondary);font-size:14px}.forecast-meta{color:var(--ha-text-secondary);justify-content:center;gap:16px;margin-top:6px;font-size:13px;display:flex}.solar-detail-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.solar-detail-item{flex-direction:column;align-items:center;gap:2px;display:flex}.sdv{color:var(--ha-text-primary);font-size:16px;font-weight:600}.sdl{color:var(--ha-text-secondary);font-size:11px}.solar-suggestion{background:var(--ha-hover);color:var(--ha-text-primary);border-radius:8px;padding:10px;font-size:13px;line-height:1.6}.schedule-soc-wrap{align-items:center;gap:20px;margin-top:10px;display:flex}.schedule-soc-ring{border:4px solid;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:80px;height:80px;display:flex}.schedule-soc-val{font-size:20px;font-weight:700}.schedule-soc-label{color:var(--ha-text-secondary);font-size:10px}.schedule-weather{color:var(--ha-text-secondary);flex-direction:column;gap:4px;font-size:13px;display:flex}.cleanliness-score-wrap{align-items:center;gap:20px;margin:10px 0;display:flex}.cleanliness-ring{border:4px solid;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;display:flex}.cl-score{font-size:22px;font-weight:700}.cleanliness-info{flex-direction:column;gap:4px;display:flex}.cl-level{font-size:16px;font-weight:600}.cl-level.good{color:#4caf50}.cl-level.ok{color:#ff9800}.cl-level.warn{color:#f44336}.cl-pr{color:var(--ha-text-secondary);font-size:12px}.solar-chart{height:140px;margin-top:8px;position:relative}.solar-chart-bars{align-items:flex-end;gap:2px;height:110px;display:flex}.solar-chart-bar-wrap{flex:1;align-items:flex-end;height:100%;display:flex}.solar-chart-bar{border-radius:2px 2px 0 0;width:100%;min-height:1px;transition:height .3s}.solar-chart-x{justify-content:flex-start;height:20px;display:flex;overflow:hidden}.solar-chart-tick{color:var(--ha-text-secondary);text-align:center;flex:1;font-size:9px}.pr-legend{color:var(--ha-text-secondary);margin-top:4px;font-size:11px}.revenue-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.revenue-item{background:var(--ha-bg);border-radius:8px;flex-direction:column;gap:2px;padding:10px;display:flex}.rv-label{color:var(--ha-text-secondary);font-size:11px}.rv-kwh{color:var(--ha-text-primary);font-size:16px;font-weight:600}.rv-money{color:#4caf50;font-size:13px;font-weight:600}.payback-info{text-align:center;margin:10px 0}.payback-years{color:var(--ha-primary);font-size:28px;font-weight:700}.payback-label{color:var(--ha-text-secondary);font-size:12px;display:block}.payback-detail{color:var(--ha-text-secondary);justify-content:space-around;font-size:12px;display:flex}.eco-grid{text-align:center;grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.eco-item{background:var(--ha-bg);border-radius:8px;padding:10px}.eco-val{color:#4caf50;font-size:20px;font-weight:700;display:block}.eco-unit{color:var(--ha-text-secondary);font-size:11px}.eco-lbl{color:var(--ha-text-secondary);font-size:11px;display:block}.status-badge{border-radius:8px;margin-left:auto;padding:2px 8px;font-size:12px}.status-badge.ok{color:#4caf50;background:#4caf5026}.status-badge.warn{color:#ff9800;background:#ff980026}.alerts-list{flex-direction:column;gap:8px;display:flex}.alert-item{background:var(--ha-bg);border-radius:8px;gap:8px;padding:8px;display:flex}.alert-item.high{border-left:3px solid #f44336}.alert-item.medium{border-left:3px solid #ff9800}.alert-item.info{border-left:3px solid #3b82f6}.alert-item.good{border-left:3px solid #4caf50}.alert-icon{font-size:16px}.alert-content{flex-direction:column;gap:2px;display:flex}.alert-type{color:var(--ha-text-primary);font-size:13px;font-weight:600}.alert-msg{color:var(--ha-text-secondary);font-size:12px}.report-type-tabs{gap:8px;margin-bottom:10px;display:flex}.rt-btn{border:1px solid var(--ha-border);color:var(--ha-text-primary);cursor:pointer;background:0 0;border-radius:12px;padding:4px 14px;font-size:12px}.rt-btn.active{background:var(--ha-primary);color:#fff;border-color:var(--ha-primary)}.report-stat{color:var(--ha-text-primary);font-size:13px;line-height:1.8}.suggest-item{color:var(--ha-text-primary);padding-left:4px;font-size:13px;line-height:1.8}.ranking-main{align-items:center;gap:20px;margin:10px 0;display:flex}.ranking-pct-wrap{flex-direction:column;align-items:center;display:flex}.ranking-pct{color:var(--ha-primary);font-size:32px;font-weight:700}.ranking-lbl{color:var(--ha-text-secondary);font-size:11px}.ranking-level{border-radius:8px;padding:4px 12px;font-size:16px;font-weight:600}.ranking-level.good{color:#4caf50;background:#4caf501a}.ranking-level.ok{color:#ff9800;background:#ff98001a}.ranking-level.warn{color:#f44336;background:#f443361a}.ranking-stats{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.rs-item{background:var(--ha-bg);border-radius:8px;flex-direction:column;gap:2px;padding:8px;display:flex}.rs-label{color:var(--ha-text-secondary);font-size:11px}.rs-val{color:var(--ha-text-primary);font-size:15px;font-weight:600}@media (width>=641px){.app-shell{border-left:1px solid var(--ha-border);border-right:1px solid var(--ha-border)}}@media (width<=400px){.ha-tiles-grid{grid-template-columns:repeat(2,1fr)}.ha-temp-grid,.ha-cell-grid{grid-template-columns:repeat(3,1fr)}.gw-dash-value{font-size:12px}}
