*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#1a1d27;--surface2:#22263a;--border:#2a2e40;--text:#e2e8f0;--text-muted:#7c879a;--accent:#3b82f6;--font:system-ui, -apple-system, "Segoe UI", sans-serif;--solar:#a3e635;--battery:#60a5fa;--grid-import:#ef4444;--grid-export:#22c55e;--home:#e2e8f0}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.5}#root{text-align:left;border:none;width:100%;min-height:100vh}.solar{color:var(--solar)}.battery{color:var(--battery)}.val-good{color:#22c55e}.val-warn{color:#f97316}.val-error{color:#ef4444}.val-muted{color:var(--text-muted)}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:400px;padding:40px 36px}.login-logo{color:var(--accent);margin-bottom:16px}.login-title{margin-bottom:4px;font-size:28px;font-weight:700}.login-subtitle{color:var(--text-muted);margin-bottom:32px;font-size:14px}.login-form{flex-direction:column;gap:16px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field label{color:var(--text-muted);font-size:13px;font-weight:500}.field input{background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:15px;font-family:var(--font);border-radius:8px;outline:none;padding:10px 14px;transition:border-color .15s}.field input:focus{border-color:var(--accent)}.error-msg{color:#ef4444;background:#ef44441a;border-radius:6px;padding:8px 12px;font-size:13px}.btn-primary{background:var(--accent);color:#fff;font-size:15px;font-weight:600;font-family:var(--font);cursor:pointer;border:none;border-radius:8px;margin-top:4px;padding:12px;transition:opacity .15s}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-primary:hover:not(:disabled){opacity:.88}.status-bar{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;flex-wrap:wrap;align-items:center;gap:16px;padding:10px 24px;display:flex;position:sticky;top:0}.status-bar-left{flex:none;align-items:center;gap:10px;display:flex}.sg-logo{color:var(--accent);flex-shrink:0}.sg-name{font-size:16px;font-weight:700}.installation-name{color:var(--text-muted);background:var(--surface2);border-radius:4px;padding:2px 8px;font-size:13px}.installation-switcher{color:var(--text-muted);background:var(--surface2);border:1px solid var(--border);cursor:pointer;border-radius:4px;align-items:center;gap:5px;padding:2px 10px;font-size:13px;transition:background .15s,color .15s;display:flex}.installation-switcher:hover{background:var(--surface3,#ffffff14);color:var(--text)}.switcher-chevron{opacity:.6;font-size:10px}.picker-header{margin-bottom:28px}.picker-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.picker-card{background:var(--surface2);border:1.5px solid var(--border);cursor:pointer;text-align:center;border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:24px 20px;transition:border-color .2s,box-shadow .2s,transform .15s;display:flex}.picker-card:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 0 24px #3b82f633}.picker-card-icon{margin-bottom:4px;font-size:32px}.picker-card-name{color:var(--text);font-size:16px;font-weight:700}.picker-card-owner{color:var(--text-muted);font-size:12px}.picker-card-meta{color:var(--text-muted);background:var(--surface3,#ffffff0d);border-radius:4px;margin-top:4px;padding:2px 8px;font-size:11px}.status-bar-center{flex:1;align-items:center;gap:12px;display:flex}.status-badge{letter-spacing:.6px;text-transform:uppercase;border-radius:100px;padding:3px 10px;font-size:11px;font-weight:700}.status-badge.online{color:#22c55e;background:#22c55e26}.status-badge.offline{color:#ef4444;background:#ef444426}.age-tag{color:var(--text-muted);font-size:12px}.status-bar-right{flex:none;align-items:center;gap:12px;margin-left:auto;display:flex}.user-email{color:var(--text-muted);font-size:13px}.btn-logout{border:1px solid var(--border);color:var(--text-muted);font-size:13px;font-family:var(--font);cursor:pointer;background:0 0;border-radius:6px;padding:6px 14px;transition:all .15s}.btn-logout:hover{border-color:var(--text-muted);color:var(--text)}.dashboard{min-height:100vh}.dashboard-main{max-width:1280px;margin:0 auto;padding:24px}.dashboard-loading{justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-error{min-height:100vh;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg, var(--surface2) 25%, #ffffff0a 50%, var(--surface2) 75%);background-size:800px 100%;border-radius:8px;animation:1.4s ease-in-out infinite shimmer}.dashboard-skeleton{max-width:960px;margin:0 auto;padding:80px 20px 0}.dashboard-skeleton .sk-statusbar{border-radius:0;width:calc(100% + 40px);height:52px;margin:-80px -20px 32px}.dashboard-skeleton .sk-welcome{width:60%;height:48px;margin-bottom:24px}.dashboard-skeleton .sk-flow{height:280px;margin-bottom:16px}.dashboard-skeleton .sk-hero{width:38%;height:160px;margin-bottom:24px}.dashboard-skeleton .sk-row{gap:16px;margin-bottom:24px;display:flex}.dashboard-skeleton .sk-card{flex:1;height:120px}.history-skeleton{flex-direction:column;gap:12px;padding:8px 0 24px;display:flex}.history-skeleton .sk-chart{height:180px}.history-skeleton .sk-bar{width:40%;height:14px}.welcome-block{margin-bottom:28px}.welcome-title{letter-spacing:-.5px;font-size:32px;font-weight:300}.welcome-sub{color:var(--text-muted);margin-top:4px;font-size:14px}.section{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:20px;padding:24px}.section-heading{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:20px;font-size:12px;font-weight:600}.section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.section-title{letter-spacing:-.3px;color:var(--text);font-size:18px;font-weight:700}.section-badge{letter-spacing:.6px;text-transform:uppercase;border-radius:100px;flex-shrink:0;align-items:center;gap:6px;padding:4px 12px;font-size:11px;font-weight:700;display:inline-flex}.badge-live{color:#22c55e;background:#22c55e1f;border:1px solid #22c55e40}.badge-polling{color:#f59e0b;background:#f59e0b1f;border:1px solid #f59e0b40}.badge-today{color:var(--accent);background:#3b82f61f;border:1px solid #3b82f640}.badge-history{background:var(--surface2);color:var(--text-muted);border:1px solid var(--border)}.live-dot{background:#22c55e;border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}.sub-heading{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-top:24px;margin-bottom:14px;font-size:11px;font-weight:700}.sub-heading:first-of-type{margin-top:0}.solar-hero{background:#a3e63512;border:1px solid #a3e63533;border-radius:10px;grid-template-columns:1fr auto;align-items:center;gap:16px;margin-bottom:20px;padding:18px 20px;display:grid}.solar-hero-main{align-items:center;gap:16px;min-width:0;display:flex}.solar-hero-pct{letter-spacing:-2px;color:var(--solar);flex-shrink:0;font-size:44px;font-weight:800;line-height:1}.solar-hero-text{color:var(--text);min-width:0;font-size:14px;line-height:1.5}.solar-hero-text strong{color:var(--solar)}.solar-hero-status{color:var(--text-muted);margin-top:2px;font-size:12px;display:block}.solar-hero-stats{flex-shrink:0;gap:16px;display:flex}.solar-hero-stat{text-align:right;border-left:1px solid #a3e63533;padding-left:16px}.solar-hero-stat-value{letter-spacing:-.5px;white-space:nowrap;color:#22c55e;font-size:18px;font-weight:700}.solar-hero-stat-value.co2{color:#4ade80}.solar-hero-stat-label{color:var(--text-muted);white-space:nowrap;margin-top:2px;font-size:11px}.solar-hero-stat-sub{color:var(--text-muted);white-space:nowrap;opacity:.7;margin-top:1px;font-size:10px}.solar-hero-income{text-align:right;border-left:1px solid #a3e63533;flex-shrink:0;padding-left:20px}.solar-hero-income-value{color:#22c55e;letter-spacing:-.5px;white-space:nowrap;font-size:20px;font-weight:700}.solar-hero-income-label{color:var(--text-muted);white-space:nowrap;margin-top:2px;font-size:11px}@media (width<=560px){.solar-hero{grid-template-columns:1fr}.solar-hero-stats{border-top:1px solid #a3e63533;flex-wrap:wrap;gap:12px;padding-top:12px}.solar-hero-stat{text-align:left;border-left:none;padding-left:0}.solar-hero-stat:not(:first-child){border-left:1px solid #a3e63526;padding-left:12px}.solar-hero-income{text-align:left;border-top:1px solid #a3e63533;border-left:none;padding-top:12px;padding-left:0}}.status-alert{border-radius:8px;align-items:center;gap:10px;margin-bottom:16px;padding:10px 16px;font-size:13px;font-weight:500;display:flex}.alert-warn{color:#f97316;background:#f973161a;border:1px solid #f973164d}.alert-error{color:#ef4444;background:#ef44441a;border:1px solid #ef44444d}.ew-trend{margin-top:4px;font-size:11px;font-weight:600}.ew-trend-up{color:#f97316}.ew-trend-down{color:#22c55e}.ew-trend-flat{color:var(--text-muted)}.flow-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px;display:grid}.flow-node{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:16px}.flow-node-header{align-items:center;gap:8px;margin-bottom:10px;display:flex}.flow-node-icon{font-size:18px}.flow-node-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:11px;font-weight:600}.flow-node-main{letter-spacing:-1px;font-size:28px;font-weight:700;line-height:1}.flow-node-label{color:var(--text-muted);margin:4px 0 10px;font-size:12px}.flow-node-detail{align-items:center;gap:6px;margin-top:4px;font-size:13px;display:flex}.flow-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.node-solar .flow-node-main{color:var(--solar)}.node-battery .flow-node-main{color:var(--battery)}.node-grid-import .flow-node-main{color:var(--grid-import)}.node-grid-export .flow-node-main{color:var(--grid-export)}.node-home .flow-node-main{color:var(--home)}.node-default .flow-node-main{color:var(--text)}.live-cards{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px;display:grid}.live-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:4px;padding:18px 16px;display:flex}.live-card-icon{margin-bottom:4px;font-size:22px}.live-card-value{letter-spacing:-1px;color:var(--text);font-size:28px;font-weight:700;line-height:1}.live-card-title{color:var(--text);margin-top:4px;font-size:12px;font-weight:600}.live-card-sub{color:var(--text-muted);font-size:11px}.live-card-scope{color:var(--text-muted);background:var(--surface3,#ffffff0f);border:1px solid var(--border);letter-spacing:.3px;border-radius:4px;width:fit-content;margin-top:6px;padding:2px 6px;font-size:10px}.fd-scroll{-webkit-overflow-scrolling:touch;border-radius:16px;overflow-x:auto}.fd-wrapper{aspect-ratio:600/380;border:1px solid var(--border);background:radial-gradient(at 50% 40%,#1e2438 0%,#0f1117 100%);border-radius:16px;width:100%;min-width:480px;margin-bottom:4px;position:relative;overflow:hidden}.fd-bg-glow{pointer-events:none;z-index:0;background:radial-gradient(60% 40% at 50% 52%,#a3e6350a 0%,#0000 70%);position:absolute;inset:0}.fd-svg{z-index:1;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.fd-node{z-index:2;text-align:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1.5px solid;border-radius:14px;flex-direction:column;align-items:center;gap:3px;padding:10px 8px 9px;transition:box-shadow .4s,border-color .4s;display:flex;position:absolute}.fd-icon-bubble{border:1.5px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;margin-bottom:2px;display:flex}.fd-icon-emoji{font-size:24px;line-height:1}.fd-node-value{letter-spacing:-.4px;white-space:nowrap;font-size:15px;font-weight:800;line-height:1}.fd-node-label{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:10px;font-weight:600;overflow:hidden}.fd-node-sub{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:9px;overflow:hidden}.energy-balance{background:var(--surface2);border:1px solid var(--border);border-radius:10px;gap:0;margin-top:4px;display:flex;overflow:hidden}.energy-side{flex-direction:column;flex:1;gap:0;min-width:0;padding:20px;display:flex}.energy-side-title{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:14px;font-size:11px;font-weight:700}.energy-balance-sep{background:var(--border);flex-shrink:0;width:1px}.energy-row{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 0;display:flex}.energy-row:last-child{border-bottom:none}.energy-row-icon{flex-shrink:0;width:22px;font-size:16px}.energy-row-text{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.energy-row-label{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.energy-row-value{letter-spacing:-.5px;font-size:18px;font-weight:700}.energy-row-total{padding-top:10px}.energy-row-total .energy-row-label{color:var(--text);font-size:12px;font-weight:600}.energy-row-total .energy-row-value{color:var(--text);font-size:22px}.energy-row-sub{opacity:.85;padding-left:20px}.energy-row-sub .energy-row-value{font-size:15px}.energy-divider{background:var(--border);height:1px;margin:4px 0}.energy-grid-note{color:var(--text-muted);background:#ef444412;border-left:2px solid #ef444466;border-radius:0 6px 6px 0;margin:4px 0 6px;padding:6px 10px;font-size:11px;line-height:1.4}.consumption-live-block{margin-top:12px}.consumption-live-title{text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);flex-direction:column;gap:3px;margin-bottom:10px;font-size:11px;font-weight:600;display:flex}.consumption-timing-note{text-transform:none;letter-spacing:0;color:var(--text-muted);opacity:.6;font-size:10px;font-weight:400}.consumption-live-row{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.consumption-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:6px;padding:14px 16px;display:flex}.consumption-card-header{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.consumption-card-icon{font-size:16px}.consumption-card-label{color:var(--text);flex:1;font-size:12px;font-weight:600}.consumption-card-tag{color:var(--text-muted);background:var(--surface3,#ffffff0f);border:1px solid var(--border);white-space:nowrap;border-radius:4px;padding:1px 5px;font-size:9px}.consumption-card-value{letter-spacing:-.5px;color:var(--text);font-size:24px;font-weight:700;line-height:1}.consumption-card-sub{color:var(--text-muted);font-size:10px}@media (width<=560px){.consumption-live-row{grid-template-columns:1fr}.energy-balance{flex-direction:column}.energy-balance-sep{width:auto;height:1px}}.breakdown-grid{background:var(--surface2);border:1px solid var(--border);border-radius:10px;grid-template-columns:auto repeat(3,1fr);align-items:start;gap:16px;padding:16px;display:grid}.breakdown-total{flex-direction:column;gap:4px;display:flex}.breakdown-total-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:11px;font-weight:600}.breakdown-total-value{letter-spacing:-1px;font-size:32px;font-weight:700}.breakdown-item{flex-direction:column;gap:4px;display:flex}.breakdown-header{align-items:center;gap:6px;display:flex}.breakdown-dot{border-radius:50%;width:8px;height:8px}.breakdown-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:11px;font-weight:600}.breakdown-value{font-size:20px;font-weight:700}.breakdown-pct{color:var(--text-muted);font-size:12px}.breakdown-bar-track{background:var(--border);border-radius:2px;height:4px;margin-top:6px}.breakdown-bar-fill{border-radius:2px;height:4px;transition:width .5s}.info-cards-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;display:grid}.info-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:20px}.info-card-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:16px;font-size:13px;font-weight:600}.stat-row-3{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;display:grid}.stat-block{flex-direction:column;gap:4px;display:flex}.stat-block-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:11px;font-weight:600}.stat-block-value{letter-spacing:-.5px;font-size:22px;font-weight:700}.coverage-bar-section{margin-top:4px}.coverage-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.coverage-pct{font-size:18px;font-weight:700}.coverage-track{background:var(--border);border-radius:3px;height:6px}.coverage-fill{background:var(--solar);border-radius:3px;height:6px;transition:width .5s}.coverage-note{color:var(--text-muted);margin-top:8px;font-size:12px}.battery-main{margin-bottom:16px}.battery-soc{letter-spacing:-1.5px;font-size:40px;font-weight:700;line-height:1}.battery-status-label{color:var(--text-muted);margin:4px 0 10px;font-size:13px}.soc-track{background:var(--border);border-radius:3px;height:6px}.soc-fill{background:var(--battery);border-radius:3px;height:6px;transition:width .5s}.stat-list{flex-direction:column;gap:10px;display:flex}.stat-list-row{justify-content:space-between;align-items:center;font-size:14px;display:flex}.stat-list-row span:first-child{color:var(--text-muted)}.stat-list-row span:last-child{font-weight:500}.stat-list-row.separator{background:var(--border);height:1px;margin:4px 0}.ew-live-block{text-align:center;padding:24px 0 8px}.ew-live-power{letter-spacing:-2px;color:#a3e635;font-size:56px;font-weight:800;line-height:1}.ew-live-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:6px;font-size:13px}.ew-section-divider{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:10px;margin:20px 0 14px;font-size:12px;font-weight:600;display:flex}.ew-section-divider:before,.ew-section-divider:after{content:"";background:var(--border);flex:1;height:1px}.ew-unit-hint{text-transform:none;letter-spacing:0;color:var(--text-muted);opacity:.7;font-weight:400}.ew-kwh-highlight{flex-wrap:wrap;gap:12px;margin-bottom:4px;display:flex}.ew-kwh-block{background:var(--surface2);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:4px;min-width:120px;padding:16px 24px;display:flex}.ew-kwh-value{letter-spacing:-1.5px;color:var(--solar);font-size:32px;font-weight:700;line-height:1}.ew-kwh-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:11px;font-weight:600}.ew-switch-block{background:var(--surface2);border:1px solid var(--border);border-radius:10px;flex-direction:column;justify-content:center;align-items:flex-start;gap:8px;padding:16px 24px;display:flex}.ew-switch-pill{letter-spacing:.5px;border-radius:100px;padding:6px 18px;font-size:15px;font-weight:700}.sw-on{color:#22c55e;background:#22c55e26}.sw-off{color:#ef4444;background:#ef444426}.ewelink-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;display:grid}.ewelink-stat{flex-direction:column;gap:6px;display:flex}.ewelink-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:11px;font-weight:600}.ewelink-value{letter-spacing:-1px;font-size:28px;font-weight:700}.history-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.period-tabs{gap:6px;display:flex}.period-tab{background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);font-size:13px;font-family:var(--font);cursor:pointer;border-radius:100px;padding:6px 16px;transition:all .15s}.period-tab:hover{border-color:var(--text-muted);color:var(--text)}.period-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.period-tab:disabled{opacity:.5;cursor:not-allowed}.btn-history-refresh{background:var(--surface2);border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex}.btn-history-refresh:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn-history-refresh:disabled{opacity:.5;cursor:not-allowed}.btn-history-csv{background:var(--surface2);border:1px solid var(--border);height:32px;color:var(--text-muted);cursor:pointer;white-space:nowrap;border-radius:8px;flex-shrink:0;align-items:center;gap:4px;padding:0 10px;font-size:12px;transition:all .15s;display:flex}.btn-history-csv:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn-history-csv:disabled{opacity:.4;cursor:not-allowed}.history-sublabel{color:var(--text-muted);margin-bottom:20px;font-size:12px}.history-loading{color:var(--text-muted);padding:24px 0;font-size:14px}.history-chart-block{margin-bottom:24px}.history-chart-title{color:var(--text);align-items:center;gap:10px;margin-bottom:12px;font-size:13px;font-weight:600;display:flex}.history-count{color:var(--text-muted);font-size:12px;font-weight:400}.chart-empty{color:var(--text-muted);font-size:13px}.chart-wrapper{flex-direction:column;gap:8px;display:flex}.chart-legend{flex-wrap:wrap;gap:12px;display:flex}.legend-item{color:var(--text-muted);align-items:center;gap:6px;font-size:12px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.sparkline-wrapper{width:100%;overflow-x:auto}.sparkline{width:100%;height:auto;display:block}.grid-line{stroke:var(--border);stroke-width:1px}.axis-label{fill:var(--text-muted);font-size:11px;font-family:var(--font)}.system-grid{flex-direction:column;gap:12px;display:flex}.system-chip{border-radius:100px;padding:3px 10px;font-size:12px;font-weight:600}.chip-ok{color:#22c55e;background:#22c55e26}.chip-error{color:#ef4444;background:#ef444426}.chip-warn{color:#f97316;background:#f9731626}.tech-cta-block{justify-content:center;margin:8px 0 32px;display:flex}.btn-ai-analyze{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#4f46e5,#7c3aed);border:none;border-radius:8px;padding:7px 16px;font-size:13px;font-weight:600;transition:opacity .2s}.btn-ai-analyze:hover{opacity:.85}.btn-ai-analyze:disabled{opacity:.5;cursor:not-allowed}.ai-loading{color:var(--text-muted);align-items:center;gap:12px;padding:24px;font-size:14px;display:flex}.ai-pulse{background:#818cf8;border-radius:50%;flex-shrink:0;width:12px;height:12px;animation:1.2s ease-in-out infinite ai-pulse}@keyframes ai-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}.ai-empty{text-align:center;color:var(--text-muted);padding:36px 20px}.ai-empty-icon{margin-bottom:12px;font-size:40px}.ai-empty p{font-size:14px;line-height:1.6}.ai-content{flex-direction:column;gap:12px;display:flex}.ai-card{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:16px}.ai-card-label{text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.ai-resumen{border-left:3px solid #818cf8}.ai-text{color:var(--text);font-size:14px;line-height:1.65}.ai-text-muted{color:var(--text-muted);font-size:13px}.ai-score-row{align-items:center;gap:10px;margin:4px 0;display:flex}.ai-score-bar-bg{background:var(--surface3,#ffffff0f);border-radius:4px;flex:1;height:8px;overflow:hidden}.ai-score-bar-fill{border-radius:4px;height:100%;transition:width .6s}.ai-score-label{color:var(--text);text-align:right;min-width:40px;font-size:13px;font-weight:700}.ai-alerts-list{flex-direction:column;gap:8px;display:flex}.ai-alert{border:1px solid;border-radius:8px;overflow:hidden}.ai-alert-error{background:#ef444412;border-color:#ef44444d}.ai-alert-warn{background:#f9731612;border-color:#f973164d}.ai-alert-info{background:#60a5fa12;border-color:#60a5fa4d}.ai-alert-header{color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;font-weight:600;display:flex}.ai-alert-body{color:var(--text-muted);padding:0 14px 12px;font-size:13px;line-height:1.6}.ai-accion{color:#60a5fa;margin-top:6px;font-style:italic}.ai-chevron{opacity:.5;font-size:10px}.ai-suggestions-list{flex-direction:column;gap:8px;display:flex}.ai-suggestion{background:var(--surface3,#ffffff0a);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:12px 14px}.ai-suggestion-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.ai-suggestion-title{color:var(--text);font-size:13px;font-weight:600}.ai-suggestion-body{color:var(--text-muted);margin-top:8px;font-size:13px;line-height:1.6}.ai-impact{white-space:nowrap;border-radius:10px;padding:2px 7px;font-size:10px;font-weight:600}.ai-impact-high{color:#ef4444;background:#ef444426}.ai-impact-mid{color:#f97316;background:#f9731626}.ai-impact-low{color:#22c55e;background:#22c55e26}.ai-explain-grid{flex-direction:column;gap:12px;display:flex}.ai-explain-card{align-items:flex-start;gap:12px;display:flex}.ai-explain-icon{flex-shrink:0;margin-top:2px;font-size:22px}.ai-explain-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px;font-size:12px;font-weight:700}.ai-explain-text{color:var(--text);font-size:13px;line-height:1.6}.ai-causas{margin:8px 0 6px}.ai-causas-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:600}.ai-causas-list{flex-direction:column;gap:2px;margin:4px 0 0 16px;display:flex}.ai-causas-list li{color:var(--text-muted);font-size:12px}.ai-trazabilidad{border:1px solid var(--border);background:#1e223299;border-radius:10px;margin-top:8px;padding:12px 16px}.ai-traz-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.ai-traz-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:700}.ai-traz-badge{font-size:11px;font-weight:600}.ai-traz-sources{flex-wrap:wrap;gap:8px;display:flex}.ai-traz-source{background:var(--surface2);border:1px solid var(--border);border-radius:20px;align-items:center;gap:5px;padding:3px 8px;font-size:11px;display:flex}.ai-traz-ok .ai-traz-dot{color:#22c55e}.ai-traz-stale .ai-traz-dot{color:#ef4444}.ai-traz-name{color:var(--text-muted);text-transform:capitalize}.ai-traz-age{color:var(--text-muted);opacity:.6}.ai-chat-wrapper{flex-direction:column;gap:12px;display:flex}.ai-chips{flex-wrap:wrap;gap:8px;display:flex}.ai-chips-small{margin-top:4px}.ai-chip{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:20px;padding:6px 14px;font-size:13px;transition:background .15s,border-color .15s}.ai-chip:hover{color:#818cf8;background:#6366f126;border-color:#818cf8}.ai-chip-small{padding:4px 10px;font-size:11px}.ai-messages{flex-direction:column;gap:10px;max-height:320px;padding:4px 0;display:flex;overflow-y:auto}.ai-message{align-items:flex-end;gap:8px;display:flex}.ai-message-assistant{justify-content:flex-start}.ai-message-user{justify-content:flex-end}.ai-message-avatar{flex-shrink:0;font-size:20px}.ai-message-avatar-user{order:2}.ai-message-bubble{border-radius:14px;max-width:80%;padding:10px 14px;font-size:13px;line-height:1.6}.ai-message-assistant .ai-message-bubble{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px}.ai-message-user .ai-message-bubble{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-bottom-right-radius:4px}.ai-message-error{opacity:.7}.ai-typing{align-items:center;gap:4px;padding:12px 16px;display:flex}.ai-typing span{background:var(--text-muted);border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite ai-typing}.ai-typing span:nth-child(2){animation-delay:.2s}.ai-typing span:nth-child(3){animation-delay:.4s}@keyframes ai-typing{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-6px)}}.ai-input-row{gap:8px;display:flex}.ai-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:10px;outline:none;flex:1;padding:10px 14px;font-size:13px;transition:border-color .2s}.ai-input:focus{border-color:#818cf8}.ai-input::placeholder{color:var(--text-muted)}.ai-send-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#4f46e5,#7c3aed);border:none;border-radius:10px;flex-shrink:0;padding:10px 16px;font-size:15px;transition:opacity .2s}.ai-send-btn:disabled{opacity:.4;cursor:not-allowed}.btn-tech-detail{background:var(--surface);border:1px solid var(--border);cursor:pointer;font-family:var(--font);color:var(--text);border-radius:12px;flex-direction:column;align-items:center;gap:4px;padding:16px 40px;font-size:16px;font-weight:600;transition:border-color .2s,box-shadow .2s;display:flex}.btn-tech-detail:hover{border-color:var(--accent);box-shadow:0 0 24px #3b82f626}.btn-tech-sub{color:var(--text-muted);font-size:12px;font-weight:400}.download-report-wrap{display:inline-block;position:relative}.btn-download-report{cursor:pointer;font-family:var(--font);background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:border-color .2s,background .2s;display:flex}.btn-download-report:hover{border-color:var(--accent);background:var(--surface)}.btn-download-report:disabled{opacity:.6;cursor:not-allowed}.download-report-menu{background:var(--surface2);border:1px solid var(--border);z-index:50;border-radius:10px;min-width:160px;position:absolute;bottom:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 8px 24px #0006}.download-report-option{text-align:left;cursor:pointer;width:100%;font-family:var(--font);color:var(--text);background:0 0;border:none;padding:10px 16px;font-size:13px;transition:background .15s;display:block}.download-report-option:hover{background:var(--surface);color:var(--accent)}.tech-header{flex-wrap:wrap;align-items:flex-start;gap:20px;margin-bottom:28px;display:flex}.btn-back{background:var(--surface);border:1px solid var(--border);color:var(--text-muted);font-size:13px;font-family:var(--font);cursor:pointer;border-radius:8px;flex-shrink:0;margin-top:6px;padding:8px 16px;transition:all .15s}.btn-back:hover{border-color:var(--accent);color:var(--text)}.btn-pdf{background:var(--accent);color:#fff;font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;border:none;border-radius:8px;flex-shrink:0;margin-top:6px;padding:8px 18px;transition:opacity .15s}.btn-pdf:hover:not(:disabled){opacity:.85}.btn-pdf:disabled{opacity:.45;cursor:not-allowed}.fault-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;display:grid}.fault-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:18px;transition:border-color .2s}.fault-card-ok{border-left:3px solid #22c55e}.fault-card-warn{border-left:3px solid #f97316}.fault-card-error{border-left:3px solid #ef4444}.fault-card-header{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;display:flex}.fault-card-icon{flex-shrink:0;font-size:18px}.fault-card-label{flex:1;font-size:13px;font-weight:600}.fault-desc{margin-bottom:10px;font-size:12px;line-height:1.5}.fault-desc-ok{color:#22c55e}.fault-desc-warn{color:#f97316}.fault-desc-error{color:#ef4444}.fault-detail{border-bottom:1px solid var(--border);justify-content:space-between;gap:8px;padding:5px 0;font-size:12px;display:flex}.fault-detail:last-child{border-bottom:none}.fault-detail span:first-child{color:var(--text-muted)}.fault-detail span:last-child{color:var(--text);text-align:right;font-weight:500}@media (width<=600px){.fault-grid{grid-template-columns:1fr}.btn-tech-detail{padding:14px 24px;font-size:15px}}.eff-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;display:grid}.eff-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:18px}.eff-card-header{align-items:center;gap:8px;margin-bottom:10px;display:flex}.eff-card-icon{font-size:18px}.eff-card-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:12px;font-weight:600}.eff-card-value{letter-spacing:-1px;margin-bottom:10px;font-size:32px;font-weight:800;line-height:1}.eff-gauge-track{background:var(--border);border-radius:3px;height:6px;margin-bottom:10px;overflow:hidden}.eff-gauge-fill{border-radius:3px;height:100%;transition:width .4s}.eff-card-sub{color:var(--text-muted);margin-bottom:4px;font-size:12px}.eff-card-note{color:var(--text-muted);opacity:.65;margin-top:4px;font-size:11px;line-height:1.4}.history-chart-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.history-chart-header .history-chart-title{margin-bottom:0}@media (width<=768px){.dashboard-main{padding:16px}.breakdown-grid{grid-template-columns:1fr 1fr}.breakdown-total{grid-column:1/-1}.stat-row-3{grid-template-columns:1fr 1fr}.welcome-title{font-size:24px}.user-email{display:none}.flow-node-main{font-size:22px}}@media (width<=480px){.breakdown-grid{grid-template-columns:1fr}.flow-grid{grid-template-columns:1fr 1fr}}.pressable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform .1s,box-shadow .1s}.pressable:active{transform:scale(.97)}.live-card.pressable,.consumption-card.pressable{touch-action:manipulation;position:relative}.live-card.pressable:hover .press-hint,.consumption-card.pressable:hover .press-hint{opacity:1}.press-hint{color:var(--text-muted);opacity:0;pointer-events:none;letter-spacing:.02em;white-space:nowrap;font-size:9px;transition:opacity .2s;position:absolute;bottom:6px;right:8px}.fd-node.pressable{cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation}.fd-node.pressable:active{filter:brightness(1.22);transform:none}@keyframes explainFadeIn{0%{opacity:0}to{opacity:1}}@keyframes explainSlideUp{0%{opacity:0;transform:translateY(24px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.explain-overlay{-webkit-backdrop-filter:blur(6px);z-index:2000;background:#000000b8;justify-content:center;align-items:center;padding:24px;animation:.18s explainFadeIn;display:flex;position:fixed;inset:0}.explain-popup{text-align:center;background:#1e2130;border:1px solid #ffffff21;border-radius:20px;width:100%;max-width:380px;padding:28px 24px 20px;animation:.26s cubic-bezier(.34,1.56,.64,1) explainSlideUp;position:relative;box-shadow:0 28px 64px #0000008c}.explain-close{color:var(--text-muted);cursor:pointer;width:28px;height:28px;font-size:12px;font-family:var(--font);background:#ffffff14;border:1px solid #ffffff1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:flex;position:absolute;top:12px;right:14px}.explain-close:hover{background:#ffffff29}.explain-icon{margin-bottom:10px;font-size:38px;line-height:1}.explain-title{color:var(--text-primary);letter-spacing:.01em;margin-bottom:16px;font-size:15px;font-weight:700}.explain-text{color:var(--text-secondary);text-align:left;white-space:pre-wrap;font-size:14px;line-height:1.65}.explain-loading{color:var(--text-muted);flex-direction:column;align-items:center;gap:10px;padding:12px 0;font-size:13px;display:flex}.explain-hint{color:var(--text-muted);opacity:.5;margin-top:18px;margin-bottom:0;font-size:11px}.efd-outer{border-radius:16px;width:100%;margin-bottom:4px;overflow:hidden}.efd-canvas{background:radial-gradient(at 50% 48%,#151c35 0%,#07091a 100%);border:1px solid #ffffff14;border-radius:16px;width:780px;height:490px;position:relative;overflow:hidden}.efd-canvas:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(#ffffff09 1px,#0000 1px);background-size:28px 28px;position:absolute;inset:0}.efd-svg{pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;inset:0}.efd-node{z-index:2;-webkit-user-select:none;user-select:none;touch-action:manipulation;cursor:pointer;background:#0f1628;border:1.5px solid #ffffff12;border-radius:18px;padding:12px 13px 10px;transition:filter .15s;position:absolute;overflow:hidden}.efd-node:active{filter:brightness(1.18)}.efd-solar{background:linear-gradient(148deg,#f59e0b1a 0%,#0f1628 55%);border-color:#f59e0b61;animation:3s ease-in-out infinite efdGlowSolar}@keyframes efdGlowSolar{0%,to{box-shadow:0 0 20px #f59e0b21,0 6px 24px #00000080}50%{box-shadow:0 0 40px #f59e0b52,0 6px 24px #00000080}}.efd-battery{background:linear-gradient(148deg,#10b9811a 0%,#0f1628 55%);border-color:#10b98161;animation:3.8s ease-in-out .9s infinite efdGlowBat}@keyframes efdGlowBat{0%,to{box-shadow:0 0 20px #10b98121,0 6px 24px #00000080}50%{box-shadow:0 0 40px #10b9814d,0 6px 24px #00000080}}.efd-grid-inactive{opacity:.62;background:#0f1628;border-color:#60a5fa1c;box-shadow:0 6px 24px #00000080}.efd-grid-import{background:linear-gradient(148deg,#60a5fa1a 0%,#0f1628 55%);border-color:#60a5fa6b;animation:2.5s ease-in-out infinite efdGlowGrid}@keyframes efdGlowGrid{0%,to{box-shadow:0 0 20px #60a5fa29,0 6px 24px #00000080}50%{box-shadow:0 0 44px #60a5fa66,0 6px 24px #00000080}}.efd-grid-export{background:linear-gradient(148deg,#10b9811f 0%,#0f1628 55%);border-color:#10b98180;animation:2s ease-in-out infinite efdGlowExport}@keyframes efdGlowExport{0%,to{box-shadow:0 0 20px #10b9812e,0 6px 24px #00000080}50%{box-shadow:0 0 50px #10b98170,0 6px 24px #00000080}}.efd-santos{background:linear-gradient(148deg,#a78bfa1a 0%,#0f1628 55%);border-color:#a78bfa61;box-shadow:0 0 20px #a78bfa1f,0 6px 24px #00000080}.efd-garcia{background:linear-gradient(148deg,#f472b61a 0%,#0f1628 55%);border-color:#f472b661;box-shadow:0 0 20px #f472b61f,0 6px 24px #00000080}.efd-hrow{justify-content:space-between;align-items:center;margin-bottom:7px;display:flex}.efd-label{letter-spacing:.07em;text-transform:uppercase;white-space:nowrap;text-overflow:ellipsis;font-size:10px;font-weight:700;overflow:hidden}.efd-label-solar{color:#f59e0b}.efd-label-bat{color:#10b981}.efd-label-grid{color:#60a5fa}.efd-label-grid-export{color:#10b981}.efd-label-santos{color:#a78bfa}.efd-label-garcia{color:#f472b6}.efd-badge{letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;border-radius:20px;flex-shrink:0;align-items:center;gap:3px;padding:2px 6px;font-size:9px;font-weight:700;display:inline-flex}.efd-badge-on{color:#10b981;background:#10b9811f;border:1px solid #10b98140}.efd-badge-off{color:#475569;background:#33415580;border:1px solid #4755694d}.efd-badge-import{color:#60a5fa;background:#60a5fa1f;border:1px solid #60a5fa4d}.efd-badge-export{color:#10b981;background:#10b9811f;border:1px solid #10b9814d}.efd-bdot{border-radius:50%;width:5px;height:5px;display:inline-block}.efd-badge-on .efd-bdot{background:#10b981;animation:2s ease-in-out infinite efdBlink}.efd-badge-off .efd-bdot{background:#475569}.efd-badge-import .efd-bdot{background:#60a5fa;animation:1.5s ease-in-out infinite efdBlink}.efd-badge-export .efd-bdot{background:#10b981;animation:1.2s ease-in-out infinite efdBlink}@keyframes efdBlink{0%,to{opacity:1}50%{opacity:.3}}.efd-weather{align-items:center;gap:8px;margin-bottom:6px;display:flex}.efd-weather-icon{flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.efd-weather-info{flex:1;min-width:0}.efd-weather-desc{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1px;font-size:9px;font-weight:600}.efd-weather-owm{color:#64748b;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:9px;overflow:hidden}.efd-weather-kw{letter-spacing:-.04em;font-variant-numeric:tabular-nums;font-size:22px;font-weight:800;line-height:1}.efd-unit{color:#94a3b8;letter-spacing:0;font-size:11px;font-weight:500}.efd-grid-widget{align-items:center;gap:8px;margin-bottom:6px;display:flex}.efd-grid-icon{flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.efd-grid-info{flex:1;min-width:0}.efd-grid-desc{text-transform:uppercase;letter-spacing:.05em;margin-bottom:1px;font-size:9px;font-weight:600;transition:color .4s}.efd-grid-kw{letter-spacing:-.04em;font-variant-numeric:tabular-nums;font-size:22px;font-weight:800;line-height:1;transition:color .4s}.efd-bat-widget{margin-bottom:5px}.efd-bat-visual{align-items:center;gap:3px;margin-bottom:4px;display:flex}.efd-bat-body{background:#10b9810f;border:1.5px solid #10b98173;border-radius:4px;flex:1;height:18px;padding:2px;overflow:hidden}.efd-bat-fill{border-radius:2px;height:100%;transition:width .8s;position:relative;overflow:hidden}.efd-bat-fill:after{content:"";background:linear-gradient(90deg,#0000,#ffffff61 50%,#0000);animation:1.8s linear infinite efdShimmer;position:absolute;inset:0}@keyframes efdShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.efd-bat-nub{background:#10b98173;border-radius:0 2px 2px 0;flex-shrink:0;width:4px;height:10px}.efd-bat-footer{justify-content:space-between;align-items:center;display:flex}.efd-bat-pct{letter-spacing:-.03em;font-variant-numeric:tabular-nums;font-size:16px;font-weight:800;transition:color .4s}.efd-bat-dir{color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:3px;font-size:9px;font-weight:600;display:flex}.efd-bat-arr{border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:9px;display:flex}.efd-arr-discharge{color:#10b981;background:#10b98126;animation:1.5s ease-in-out infinite efdArrDown}.efd-arr-charge{color:#f59e0b;background:#f59e0b26;animation:1.5s ease-in-out infinite efdArrUp}@keyframes efdArrDown{0%,to{transform:translateY(0)}50%{transform:translateY(2px)}}@keyframes efdArrUp{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.efd-bat-kw{color:#10b981;letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:14px;font-weight:700}.efd-simple-kw{letter-spacing:-.04em;font-variant-numeric:tabular-nums;margin-bottom:4px;font-size:24px;font-weight:800;line-height:1}.efd-node-sub{color:#64748b;white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.efd-hub{z-index:3;justify-content:center;align-items:center;width:92px;height:92px;display:flex;position:absolute}.efd-hub-r3{border:1px solid #ffffff0a;border-radius:50%;width:128px;height:128px;animation:12s linear infinite efdSpin;position:absolute}.efd-hub-r3:after{content:"";border:1px solid #0000;border-top-color:#60a5fa38;border-radius:50%;position:absolute;inset:-1px}.efd-hub-r2{border:1px solid #ffffff0a;border-radius:50%;width:110px;height:110px;animation:7s linear infinite reverse efdSpin;position:absolute}.efd-hub-r2:after{content:"";border:1px solid #0000;border-color:#0000 #0000 #f59e0b61 #f59e0b1f;border-radius:50%;position:absolute;inset:-1px}.efd-hub-r1{border:1px solid #a78bfa66;border-color:#a78bfa66 #a78bfa24 #0000 #0000;border-radius:50%;width:93px;height:93px;animation:4.5s linear infinite efdSpin;position:absolute}@keyframes efdSpin{to{transform:rotate(360deg)}}.efd-hub-core{z-index:1;background:linear-gradient(145deg,#1a2240,#0f1628);border:1.5px solid #ffffff21;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:1px;width:76px;height:76px;display:flex;position:relative;box-shadow:0 0 0 1px #60a5fa14,0 0 28px #60a5fa33,0 0 56px #60a5fa12,inset 0 1px #ffffff1a}.efd-hub-kw{letter-spacing:-.04em;font-variant-numeric:tabular-nums;font-size:13px;font-weight:800}.efd-hub-lbl{letter-spacing:.1em;text-transform:uppercase;color:#94a3b8;font-size:7px;font-weight:600}@keyframes efdSunRotate{to{transform:rotate(360deg)}}@keyframes efdSunGlow{0%,to{stroke-opacity:.2}50%{stroke-opacity:.6}}@keyframes efdCloudFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-2.5px)}}@keyframes efdRainFall{0%{opacity:0;transform:translateY(-4px)}20%{opacity:1}80%{opacity:.7}to{opacity:0;transform:translateY(10px)}}@keyframes efdLightningPulse{0%,to{filter:drop-shadow(0 0 4px #60a5fa80);opacity:.7}50%{filter:drop-shadow(0 0 12px #60a5fa);opacity:1}}@keyframes efdArcFlash{0%,to{opacity:0}40%,60%{opacity:.5}}@keyframes efdExportBounce{0%,to{filter:drop-shadow(0 0 4px #10b98180);transform:translateY(2px)}50%{filter:drop-shadow(0 0 10px #10b981e6);transform:translateY(-3px)}}@keyframes efdSparkle{0%,to{opacity:0;transform:scale(.5)}50%{opacity:1;transform:scale(1)}}.flow-hero-layout{align-items:stretch;gap:16px;margin-bottom:20px;display:flex}.flow-hero-diagram{flex:auto;min-width:0;margin-bottom:0;overflow:hidden}.day-hero-panel{background:linear-gradient(160deg, #10b98114 0%, var(--surface) 50%);border:1px solid #10b98140;border-radius:12px;flex-direction:column;flex:0 0 240px;gap:0;padding:20px 18px;display:flex;position:relative;overflow:hidden;box-shadow:0 0 28px #10b98112,0 4px 16px #0006}.day-hero-panel:before{content:"";pointer-events:none;background:radial-gradient(circle,#a3e6351f 0%,#0000 70%);border-radius:50%;width:120px;height:120px;position:absolute;top:-40px;right:-40px}.day-hero-empty{opacity:.5;flex-direction:column;justify-content:center;align-items:center;gap:10px;display:flex}.day-hero-empty-icon{font-size:32px}.day-hero-empty-msg{color:var(--text-muted);text-align:center;font-size:13px}.day-hero-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.day-hero-eyebrow{letter-spacing:.08em;text-transform:uppercase;color:#10b981;font-size:10px;font-weight:700}.day-hero-live-dot{background:#10b981;border-radius:50%;width:7px;height:7px;animation:2s ease-in-out infinite efdBlink;box-shadow:0 0 6px #10b981}.day-hero-pct{letter-spacing:-.05em;font-variant-numeric:tabular-nums;margin-bottom:8px;font-size:52px;font-weight:900;line-height:1;transition:color .5s}.day-hero-desc{color:var(--text-muted);margin-bottom:4px;font-size:12px;line-height:1.45}.day-hero-desc strong{color:var(--text)}.day-hero-status{color:#10b981;margin-bottom:12px;font-size:11px;font-weight:600}.day-hero-bar{background:#ffffff12;border-radius:10px;height:5px;margin-bottom:16px;overflow:hidden}.day-hero-bar-fill{border-radius:10px;height:100%;transition:width .8s,background .5s;box-shadow:0 0 8px}.day-hero-sep{background:#ffffff0f;height:1px;margin-bottom:14px}.day-hero-stats{flex-direction:column;flex:1;gap:12px;display:flex}.day-hero-stat{align-items:flex-start;gap:10px;display:flex}.day-hero-stat-icon{flex-shrink:0;margin-top:1px;font-size:18px;line-height:1}.day-hero-stat-body{min-width:0}.day-hero-stat-val{letter-spacing:-.03em;color:var(--text);font-variant-numeric:tabular-nums;font-size:17px;font-weight:800;line-height:1.1}.day-hero-stat-lbl{color:var(--text-muted);margin-top:1px;font-size:10px}.day-hero-stat-sub{color:#475569;margin-top:1px;font-size:10px}.day-hero-month-income{background:#a3e63514;border:1px solid #a3e63533;border-radius:10px;margin-bottom:14px;padding:10px 14px}.day-hero-month-label{text-transform:uppercase;letter-spacing:.07em;color:#86efac;margin-bottom:3px;font-size:10px;font-weight:600}.day-hero-month-val{letter-spacing:-.04em;color:#a3e635;font-variant-numeric:tabular-nums;font-size:26px;font-weight:900}.day-hero-footer{color:var(--text-muted);letter-spacing:.02em;font-size:10px;font-weight:500}.day-hero-footer-row{border-top:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding-top:12px;display:flex}@media (width<=960px){.flow-hero-layout{flex-direction:column}.day-hero-panel{flex:none}}.btn-install{color:#60a5fa;cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font);background:#3b82f626;border:1px solid #3b82f659;border-radius:20px;align-items:center;gap:5px;padding:5px 12px;transition:background .2s;display:inline-flex}.btn-install:hover{background:#3b82f647}.alerts-btn{cursor:pointer;background:0 0;border:none;border-radius:8px;padding:4px;font-size:18px;line-height:1;transition:background .15s;position:relative}.alerts-btn:hover{background:#ffffff12}.alerts-badge{color:#fff;text-align:center;background:#ef4444;border-radius:8px;min-width:16px;height:16px;padding:0 3px;font-size:9px;font-weight:800;line-height:16px;position:absolute;top:-2px;right:-4px}.alerts-backdrop{z-index:49;background:#00000059;position:fixed;inset:0}.alerts-drawer{background:var(--surface);border-left:1px solid var(--border);z-index:50;flex-direction:column;width:340px;max-width:95vw;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-8px 0 32px #00000080}.alerts-drawer-open{transform:translate(0)}.alerts-drawer-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.alerts-drawer-title{font-size:15px;font-weight:700}.alerts-drawer-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:16px;transition:background .15s}.alerts-drawer-close:hover{background:#ffffff12}.alerts-drawer-body{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow-y:auto}.alerts-empty{height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:10px;display:flex}.alerts-empty-icon{font-size:36px}.alerts-empty p{font-size:13px}.alert-item{border:1px solid;border-radius:10px;padding:12px 14px;transition:opacity .2s;position:relative}.alert-item-unread:before{content:"";background:currentColor;border-radius:0 2px 2px 0;width:3px;height:60%;position:absolute;top:50%;left:-1px;transform:translateY(-50%)}.alert-item-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:5px;display:flex}.alert-item-title{font-size:13px;font-weight:700;line-height:1.3}.alert-item-dismiss{color:#475569;cursor:pointer;background:0 0;border:none;border-radius:3px;flex-shrink:0;padding:1px 4px;font-size:12px;transition:color .15s}.alert-item-dismiss:hover{color:var(--text)}.alert-item-msg{color:var(--text-muted);margin-bottom:6px;font-size:12px;line-height:1.45}.alert-item-time{color:#475569;font-size:10px}.forecast-roi-layout{gap:16px;margin-bottom:20px;display:flex}.wf-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;flex:1;gap:14px;padding:18px 20px;display:flex}.wf-loading{color:var(--text-muted);justify-content:center;align-items:center;gap:10px;font-size:13px}.wf-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite efdSpin}.wf-header{justify-content:space-between;align-items:center;display:flex}.wf-eyebrow{text-transform:uppercase;letter-spacing:.08em;color:#60a5fa;font-size:10px;font-weight:700}.wf-location{color:var(--text-muted);font-size:10px}.wf-body{align-items:center;gap:16px;display:flex}.wf-icon{flex-shrink:0;width:52px;height:52px}.wf-weather-info{flex:1}.wf-desc{color:var(--text-muted);text-transform:capitalize;margin-bottom:2px;font-size:11px}.wf-temps{align-items:baseline;gap:2px;margin-bottom:2px;display:flex}.wf-temp-max{font-size:22px;font-weight:800}.wf-temp-sep{color:var(--text-muted);margin:0 2px;font-size:16px}.wf-temp-min{color:var(--text-muted);font-size:14px}.wf-clouds{color:var(--text-muted);font-size:10px}.wf-cloud-msg{color:var(--text-muted);background:#ffffff0a;border-left:3px solid #60a5fa;border-radius:8px;padding:8px 12px;font-size:12px;line-height:1.4}@media (width<=720px){.forecast-roi-layout,.wf-body{flex-direction:column}}.roi-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex:1;padding:18px 20px}.roi-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.roi-eyebrow{font-size:13px;font-weight:700}.roi-setup-btn{color:#60a5fa;cursor:pointer;font-size:11px;font-family:var(--font);background:0 0;border:none;border-radius:4px;padding:2px 6px;transition:background .15s}.roi-setup-btn:hover{background:#3b82f61f}.roi-stats{flex-wrap:wrap;gap:16px;margin-bottom:16px;display:flex}.roi-stat{flex:1;min-width:80px}.roi-stat-val{letter-spacing:-.03em;font-variant-numeric:tabular-nums;font-size:20px;font-weight:800;line-height:1.1}.roi-stat-lbl{color:var(--text-muted);margin-top:2px;font-size:10px}.roi-progress-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.roi-progress-label{color:var(--text-muted);font-size:11px}.roi-progress-pct{font-variant-numeric:tabular-nums;font-size:15px;font-weight:800}.roi-bar{background:#ffffff12;border-radius:10px;height:8px;margin-bottom:4px;overflow:hidden}.roi-bar-fill{border-radius:10px;height:100%;transition:width .8s}.roi-bar-labels{color:var(--text-muted);justify-content:space-between;margin-bottom:10px;font-size:10px;display:flex}.roi-bar-cost{color:#475569}.roi-payback{color:var(--text-muted);background:#ffffff0a;border-radius:8px;padding:8px 12px;font-size:12px}.roi-payback strong{color:var(--text)}.roi-payback-done{color:#a3e635;background:#a3e63514;border-radius:8px;padding:8px 12px;font-size:13px;font-weight:700}.roi-no-cost{color:#475569;font-size:12px}.modal-overlay{z-index:60;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:420px;padding:28px;box-shadow:0 20px 60px #00000080}.modal-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.modal-title{font-size:17px;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:16px;transition:background .15s}.modal-close:hover{background:#ffffff12}.modal-desc{color:var(--text-muted);margin-bottom:20px;font-size:13px;line-height:1.5}.modal-field{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.modal-label{color:var(--text-muted);font-size:12px;font-weight:600}.modal-input{background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:16px;font-family:var(--font);border-radius:8px;outline:none;padding:11px 14px;transition:border-color .15s}.modal-input:focus{border-color:var(--accent)}.modal-error{color:#ef4444;background:#ef444414;border-radius:6px;margin-bottom:12px;padding:8px 12px;font-size:12px}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.btn-secondary{border:1px solid var(--border);color:var(--text);font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;background:#ffffff0f;border-radius:8px;padding:9px 18px;transition:background .15s}.btn-secondary:hover{background:#ffffff1a}.btn-admin{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:17px;line-height:1;transition:background .15s}.btn-admin:hover{color:var(--text);background:#ffffff14}.admin-page{max-width:1280px;margin:0 auto;padding:24px}.admin-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.admin-header-left{align-items:center;gap:16px;display:flex}.admin-back-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-size:13px;font-family:var(--font);white-space:nowrap;background:#ffffff0f;border-radius:8px;padding:8px 14px;transition:background .15s}.admin-back-btn:hover{background:#ffffff1a}.admin-title{letter-spacing:-.3px;font-size:22px;font-weight:800}.admin-subtitle{color:var(--text-muted);margin-top:3px;font-size:12px}.admin-refresh-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-size:13px;font-family:var(--font);background:0 0;border-radius:8px;padding:8px 14px;transition:background .15s}.admin-refresh-btn:hover{background:#ffffff0f}.admin-empty{text-align:center;color:var(--text-muted);padding:60px 20px;font-size:14px}.admin-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.admin-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:14px;flex-direction:column;gap:14px;padding:20px;transition:transform .15s,box-shadow .15s,border-color .2s;display:flex}.admin-card:hover{transform:translateY(-2px);box-shadow:0 8px 28px #0006}.admin-card-online{border-color:#10b9814d}.admin-card-offline{opacity:.65}.admin-card-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.admin-card-name{font-size:15px;font-weight:700}.admin-card-owner{color:var(--text-muted);margin-top:2px;font-size:11px}.admin-online-badge{text-transform:uppercase;letter-spacing:.05em;color:#10b981;white-space:nowrap;background:#10b9811a;border:1px solid #10b98140;border-radius:20px;flex-shrink:0;align-items:center;gap:5px;padding:3px 8px;font-size:10px;font-weight:700;display:inline-flex}.admin-offline-badge{color:#475569;white-space:nowrap;background:#47556926;border:1px solid #47556940;border-radius:20px;flex-shrink:0;align-items:center;gap:5px;padding:3px 8px;font-size:10px;font-weight:600;display:flex}.admin-offline-dot{background:#475569;border-radius:50%;flex-shrink:0;width:6px;height:6px}.admin-card-stats{flex-wrap:wrap;gap:10px;display:flex}.admin-stat-chip{background:#ffffff0a;border-radius:8px;flex-direction:column;flex:1;justify-content:center;min-width:72px;padding:7px 10px;display:flex}.admin-stat-val{font-variant-numeric:tabular-nums;font-size:13px;font-weight:700}.admin-stat-lbl{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:1px;font-size:9px}.admin-card-footer{border-top:1px solid #ffffff0d;flex-wrap:wrap;align-items:center;gap:8px;padding-top:10px;display:flex}.admin-card-age{color:#475569;flex:1;font-size:10px}.admin-card-go{color:var(--text-muted);margin-left:auto;font-size:11px}.admin-alert-badge{color:#94a3b8;background:#ffffff0f;border-radius:20px;padding:2px 8px;font-size:10px;font-weight:600}.admin-alert-badge-unread{color:#f59e0b;background:#f59e0b1a}@media (width<=600px){.admin-page{padding:16px}.admin-grid{grid-template-columns:1fr}}.btn-push{cursor:pointer;background:#ffffff0f;border:none;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;transition:background .2s,transform .1s;display:flex}.btn-push:hover{background:#ffffff1f}.btn-push:active{transform:scale(.92)}.btn-push.push-on{background:#facc1526}.btn-push.push-off{opacity:.7}.btn-push:disabled{opacity:.4;cursor:not-allowed}.onboarding-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;justify-content:center;align-items:center;padding:20px;animation:.25s fadeIn;display:flex;position:fixed;inset:0}.onboarding-modal{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:20px;width:100%;max-width:380px;padding:36px 32px 28px;animation:.3s slideUp;box-shadow:0 24px 80px #0009}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.onboarding-dots{justify-content:center;gap:6px;margin-bottom:28px;display:flex}.onboarding-dot{cursor:pointer;background:#ffffff26;border:none;border-radius:50%;width:8px;height:8px;padding:0;transition:background .2s,width .2s}.onboarding-dot.active{background:var(--accent);border-radius:4px;width:24px}.onboarding-icon{margin-bottom:16px;font-size:52px}.onboarding-title{color:var(--text);margin-bottom:12px;font-size:20px;font-weight:700;line-height:1.3}.onboarding-desc{color:var(--text-muted);margin-bottom:32px;font-size:14px;line-height:1.6}.onboarding-actions{justify-content:center;gap:10px;display:flex}.btn-onboarding-skip{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:10px;padding:10px 20px;font-size:14px;transition:background .2s}.btn-onboarding-skip:hover{background:#ffffff0f}.btn-onboarding-next,.btn-onboarding-done{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:10px 24px;font-size:14px;font-weight:600;transition:background .2s,transform .1s}.btn-onboarding-next:hover,.btn-onboarding-done:hover{background:#2563eb}.btn-onboarding-next:active,.btn-onboarding-done:active{transform:scale(.96)}.btn-onboarding-done{padding:10px 32px}.day-hero-empty-title{color:var(--text);margin-bottom:8px;font-size:15px;font-weight:600}.day-hero-empty-msg{color:var(--text-muted);text-align:center;max-width:220px;font-size:13px;line-height:1.5}
