.battery-gauge.svelte-18ggdi7{display:flex;flex-direction:column;align-items:center;gap:.75rem}.battery-icon.svelte-18ggdi7{position:relative;display:flex;flex-direction:column;align-items:center}.battery-tip.svelte-18ggdi7{width:24px;height:8px;background:#334155;border-radius:4px 4px 0 0}.battery-body.svelte-18ggdi7{width:60px;height:100px;background:#334155;border-radius:0 0 8px 8px;padding:4px;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;position:relative}.battery-fill.svelte-18ggdi7{border-radius:4px;transition:height .5s ease,background .5s ease}.soc-target-marker.svelte-18ggdi7{position:absolute;left:2px;right:2px;height:2px;background:#60a5fa;border-radius:1px;box-shadow:0 0 4px #60a5fa}.battery-fill.charging.svelte-18ggdi7{animation:svelte-18ggdi7-pulse 1.5s infinite}@keyframes svelte-18ggdi7-pulse{0%,to{opacity:1}50%{opacity:.7}}.battery-info.svelte-18ggdi7{text-align:center}.soc.svelte-18ggdi7{font-size:2rem;font-weight:700}.soc-target.svelte-18ggdi7{display:block;font-size:.75rem;color:#60a5fa}.charging-indicator.svelte-18ggdi7{display:block;font-size:.75rem;color:#4ade80;text-transform:uppercase;letter-spacing:.05em;animation:svelte-18ggdi7-blink 1s infinite}.battery-temp.svelte-18ggdi7{display:block;font-size:.75rem;color:#94a3b8;margin-top:.25rem}.capacity-estimate.svelte-18ggdi7{display:flex;align-items:center;justify-content:center;gap:.3rem;font-size:.75rem;color:#94a3b8;margin-top:.25rem;cursor:help}.confidence-dot.svelte-18ggdi7{width:6px;height:6px;border-radius:50%;background:#64748b;flex-shrink:0}.confidence-dot.high.svelte-18ggdi7{background:#4ade80}.confidence-dot.medium.svelte-18ggdi7{background:#f59e0b}.confidence-dot.low.svelte-18ggdi7{background:#64748b}@keyframes svelte-18ggdi7-blink{0%,to{opacity:1}50%{opacity:.5}}.power-flow.svelte-189r1tc{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto auto;gap:1rem;align-items:center;justify-items:center;padding:1rem 0}.source.svelte-189r1tc,.center.svelte-189r1tc{display:flex;flex-direction:column;align-items:center;gap:.25rem}.icon.svelte-189r1tc{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#334155}.icon.svelte-189r1tc svg:where(.svelte-189r1tc){width:28px;height:28px}.solar.svelte-189r1tc .icon:where(.svelte-189r1tc){background:#854d0e;color:#fbbf24}.house.svelte-189r1tc .icon:where(.svelte-189r1tc){background:#1e3a5f;color:#60a5fa}.battery.svelte-189r1tc .icon:where(.svelte-189r1tc){background:#334155;color:#94a3b8}.battery.charging.svelte-189r1tc .icon:where(.svelte-189r1tc){background:#14532d;color:#4ade80;animation:svelte-189r1tc-pulse 1s infinite}.battery.discharging.svelte-189r1tc .icon:where(.svelte-189r1tc){background:#7f1d1d;color:#f87171;animation:svelte-189r1tc-pulse 1s infinite}.battery.svelte-189r1tc .value.positive:where(.svelte-189r1tc){color:#f87171}.battery.svelte-189r1tc .value.negative:where(.svelte-189r1tc){color:#4ade80}.grid.svelte-189r1tc .icon:where(.svelte-189r1tc){background:#334155;color:#94a3b8}.grid.import.svelte-189r1tc .icon:where(.svelte-189r1tc){background:#7f1d1d;color:#f87171;animation:svelte-189r1tc-pulse 1s infinite}.grid.export.svelte-189r1tc .icon:where(.svelte-189r1tc){background:#14532d;color:#4ade80;animation:svelte-189r1tc-pulse 1s infinite}.grid.svelte-189r1tc .value.positive:where(.svelte-189r1tc){color:#f87171}.grid.svelte-189r1tc .value.negative:where(.svelte-189r1tc){color:#4ade80}.label.svelte-189r1tc{font-size:.75rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.value.svelte-189r1tc{font-size:1rem;font-weight:600;color:#e2e8f0}.solar.svelte-189r1tc{grid-column:2;grid-row:1}.arrows.svelte-189r1tc{grid-column:1 / -1;grid-row:1 / -1;pointer-events:none}.house.svelte-189r1tc{grid-column:2;grid-row:2}.battery.svelte-189r1tc{grid-column:1;grid-row:2}.grid.svelte-189r1tc{grid-column:3;grid-row:2}@keyframes svelte-189r1tc-pulse{0%,to{opacity:1}50%{opacity:.6}}.status-card.svelte-10n255z{display:flex;flex-direction:column}.label.svelte-10n255z{font-size:.875rem;color:#94a3b8;margin-bottom:.5rem}.value-row.svelte-10n255z{display:flex;align-items:baseline;gap:.25rem}.value.svelte-10n255z{font-size:2rem;font-weight:700;color:#e2e8f0}.unit.svelte-10n255z{font-size:.875rem;color:#94a3b8}.charging-status.svelte-aoqp22{padding:.5rem 0}.status-content.svelte-aoqp22{display:flex;gap:1.5rem;align-items:flex-start}.status-main.svelte-aoqp22{flex:1;min-width:0}.status-header.svelte-aoqp22{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem}.status-icon.svelte-aoqp22{width:48px;height:48px;border-radius:50%;background:#334155;display:flex;align-items:center;justify-content:center;color:#94a3b8;flex-shrink:0}.status-icon.svelte-aoqp22 svg:where(.svelte-aoqp22){width:28px;height:28px}.status-icon.active.svelte-aoqp22{background:#14532d;color:#4ade80;animation:svelte-aoqp22-pulse 1.5s infinite}.charging.svelte-aoqp22 .status-icon.active:where(.svelte-aoqp22){background:#166534}.should-charge.svelte-aoqp22 .status-icon:where(.svelte-aoqp22){background:#854d0e;color:#fbbf24}@keyframes svelte-aoqp22-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.status-text.svelte-aoqp22{flex:1}.status-title.svelte-aoqp22{font-size:1.25rem;font-weight:600;color:#e2e8f0}.charging.svelte-aoqp22 .status-title:where(.svelte-aoqp22){color:#4ade80}.should-charge.svelte-aoqp22 .status-title:where(.svelte-aoqp22){color:#fbbf24}.reason.svelte-aoqp22{font-size:.875rem;color:#94a3b8;line-height:1.5}.savings-card.svelte-1ka78do{color:#e2e8f0}h3.svelte-1ka78do{font-size:.875rem;color:#86efac;margin-bottom:1rem;font-weight:500}.loading.svelte-1ka78do,.error.svelte-1ka78do,.no-data.svelte-1ka78do{color:#86efac;opacity:.7}.error.svelte-1ka78do{color:#fca5a5}.stats.svelte-1ka78do{display:flex;gap:2rem;margin-bottom:1rem}.stat.svelte-1ka78do{display:flex;flex-direction:column}.stat.svelte-1ka78do .value:where(.svelte-1ka78do){font-size:1.5rem;font-weight:700;color:#fff}.stat.svelte-1ka78do .unit:where(.svelte-1ka78do){font-size:.875rem;color:#86efac;margin-left:.25rem}.stat.svelte-1ka78do .label:where(.svelte-1ka78do){font-size:.75rem;color:#86efac;opacity:.8}.comparison.svelte-1ka78do{display:flex;gap:.5rem;font-size:.875rem;color:#86efac;opacity:.9}@media (max-width: 480px){.stats.svelte-1ka78do{flex-wrap:wrap;gap:1rem}}.price-chart.svelte-f17xs{display:flex;flex-direction:column;height:100%}.header.svelte-f17xs{display:flex;justify-content:flex-end;margin-bottom:.75rem}.tabs.svelte-f17xs{display:flex;gap:.25rem;background:#1e293b;padding:.25rem;border-radius:.5rem}.tabs.svelte-f17xs button:where(.svelte-f17xs){padding:.375rem .75rem;border:none;background:transparent;color:#94a3b8;font-size:.875rem;border-radius:.375rem;cursor:pointer;transition:all .15s}.tabs.svelte-f17xs button:where(.svelte-f17xs):hover:not(.disabled){background:#334155}.tabs.svelte-f17xs button.active:where(.svelte-f17xs){background:#334155;color:#e2e8f0}.tabs.svelte-f17xs button.disabled:where(.svelte-f17xs){opacity:.5;cursor:not-allowed}.chart-container.svelte-f17xs{flex:1;min-height:300px}.loading.svelte-f17xs,.error.svelte-f17xs,.no-data.svelte-f17xs{display:flex;align-items:center;justify-content:center;height:100%;color:#94a3b8}.error.svelte-f17xs{color:#f87171}.modal-backdrop.svelte-1t3tl5m{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal.svelte-1t3tl5m{background:#1e293b;border-radius:1rem;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}header.svelte-1t3tl5m{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #334155}header.svelte-1t3tl5m h2:where(.svelte-1t3tl5m){font-size:1.25rem;color:#e2e8f0}.close-btn.svelte-1t3tl5m{background:transparent;border:none;color:#94a3b8;cursor:pointer;padding:.25rem;border-radius:.25rem}.close-btn.svelte-1t3tl5m:hover{background:#334155;color:#e2e8f0}.tabs.svelte-1t3tl5m{display:flex;gap:.25rem;padding:.75rem 1.5rem;border-bottom:1px solid #334155;overflow-x:auto}.tabs.svelte-1t3tl5m button:where(.svelte-1t3tl5m){padding:.5rem 1rem;border:none;background:transparent;color:#94a3b8;font-size:.875rem;border-radius:.375rem;cursor:pointer;white-space:nowrap}.tabs.svelte-1t3tl5m button:where(.svelte-1t3tl5m):hover{background:#334155}.tabs.svelte-1t3tl5m button.active:where(.svelte-1t3tl5m){background:#334155;color:#e2e8f0}.content.svelte-1t3tl5m{flex:1;overflow:auto;padding:1.5rem}.loading.svelte-1t3tl5m,.error.svelte-1t3tl5m,.no-data.svelte-1t3tl5m{text-align:center;color:#94a3b8;padding:2rem}.error.svelte-1t3tl5m{color:#f87171}.chart-container.svelte-1t3tl5m{height:400px}.energy-summary.svelte-1t3tl5m{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid #334155}.energy-summary.svelte-1t3tl5m .stat:where(.svelte-1t3tl5m){display:flex;flex-direction:column;gap:.125rem}.energy-summary.svelte-1t3tl5m .value:where(.svelte-1t3tl5m){font-size:1.25rem;font-weight:600;color:#e2e8f0}.energy-summary.svelte-1t3tl5m .value.solar:where(.svelte-1t3tl5m){color:#facc15}.energy-summary.svelte-1t3tl5m .value.export:where(.svelte-1t3tl5m){color:#22d3ee}.energy-summary.svelte-1t3tl5m .value.import:where(.svelte-1t3tl5m){color:#f87171}.energy-summary.svelte-1t3tl5m .label:where(.svelte-1t3tl5m){font-size:.7rem;color:#94a3b8}.sessions-table.svelte-1t3tl5m{overflow-x:auto}table.svelte-1t3tl5m{width:100%;border-collapse:collapse}th.svelte-1t3tl5m,td.svelte-1t3tl5m{padding:.75rem;text-align:left;border-bottom:1px solid #334155}th.svelte-1t3tl5m{color:#94a3b8;font-weight:500;font-size:.875rem}td.svelte-1t3tl5m{color:#e2e8f0;font-size:.875rem}.savings-detail.svelte-1t3tl5m{padding:1rem 0}.savings-grid.svelte-1t3tl5m{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem}.stat.svelte-1t3tl5m{display:flex;flex-direction:column;gap:.25rem}.stat.large.svelte-1t3tl5m .value:where(.svelte-1t3tl5m){font-size:2.5rem;color:#4ade80}.stat.svelte-1t3tl5m .value:where(.svelte-1t3tl5m){font-size:1.5rem;font-weight:600;color:#e2e8f0}.stat.svelte-1t3tl5m .label:where(.svelte-1t3tl5m){font-size:.75rem;color:#94a3b8}@media (max-width: 640px){.modal.svelte-1t3tl5m{max-height:100vh;border-radius:0}.tabs.svelte-1t3tl5m{padding:.5rem}.tabs.svelte-1t3tl5m button:where(.svelte-1t3tl5m){padding:.5rem .75rem;font-size:.75rem}.energy-summary.svelte-1t3tl5m{gap:1rem}.energy-summary.svelte-1t3tl5m .value:where(.svelte-1t3tl5m){font-size:1rem}}.dashboard.svelte-kdmb3n{min-height:100vh;display:flex;flex-direction:column}header.svelte-kdmb3n{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#1e293b;border-bottom:1px solid #334155}.header-left.svelte-kdmb3n{display:flex;align-items:center;gap:1rem}header.svelte-kdmb3n h1:where(.svelte-kdmb3n){font-size:1.25rem;color:#4ade80}.connection-status.svelte-kdmb3n{font-size:.75rem;padding:.25rem .5rem;border-radius:9999px;background:#334155;color:#94a3b8}.connection-status.connected.svelte-kdmb3n{background:#166534;color:#4ade80}.connection-status.error.svelte-kdmb3n{background:#7f1d1d;color:#f87171}.update-age.svelte-kdmb3n{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:#94a3b8;min-width:3rem}.update-age.stale.svelte-kdmb3n{color:#f59e0b}.clock-icon.svelte-kdmb3n{width:14px;height:14px}.header-right.svelte-kdmb3n{display:flex;gap:.5rem}.btn-secondary.svelte-kdmb3n,.btn-logout.svelte-kdmb3n{padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;cursor:pointer;border:none}.btn-secondary.svelte-kdmb3n{background:#334155;color:#e2e8f0}.btn-secondary.svelte-kdmb3n:hover{background:#475569}.btn-logout.svelte-kdmb3n{background:transparent;color:#94a3b8;border:1px solid #334155}.btn-logout.svelte-kdmb3n:hover{background:#334155}.content.svelte-kdmb3n{flex:1;padding:1.5rem}.loading.svelte-kdmb3n{display:flex;align-items:center;justify-content:center;height:50vh;color:#94a3b8}.grid.svelte-kdmb3n{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.card.svelte-kdmb3n{background:#1e293b;border-radius:.75rem;padding:1.25rem}.card.svelte-kdmb3n h3:where(.svelte-kdmb3n){font-size:.875rem;color:#94a3b8;margin-bottom:.75rem;font-weight:500}.battery-card.svelte-kdmb3n{display:flex;align-items:center;justify-content:center}.savings-card.svelte-kdmb3n{background:linear-gradient(135deg,#166534,#14532d)}.price-range.svelte-kdmb3n{display:flex;justify-content:space-between;font-size:.75rem;color:#94a3b8;margin-top:.5rem}.price-range.svelte-kdmb3n .min:where(.svelte-kdmb3n){color:#4ade80}.price-range.svelte-kdmb3n .max:where(.svelte-kdmb3n){color:#f87171}.next-price.svelte-kdmb3n{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:#94a3b8;margin-top:.25rem}.next-price.svelte-kdmb3n .arrow:where(.svelte-kdmb3n){font-size:1rem}.next-price.rising.svelte-kdmb3n{color:#f87171}.next-price.falling.svelte-kdmb3n{color:#4ade80}.secondary.svelte-kdmb3n{font-size:.875rem;color:#94a3b8;margin-top:.5rem}.pv-breakdown.svelte-kdmb3n{display:flex;gap:.75rem;font-size:.75rem;margin-top:.25rem}.pv-actual.svelte-kdmb3n{color:#4ade80}.pv-remaining.svelte-kdmb3n{color:#94a3b8}.temperature-display.svelte-kdmb3n{display:flex;align-items:center;gap:.25rem}.thermometer-icon.svelte-kdmb3n{width:16px;height:16px;color:#60a5fa}.consumption-row.svelte-kdmb3n{display:flex;justify-content:space-between;align-items:baseline;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #334155}.consumption-label.svelte-kdmb3n{font-size:.75rem;color:#94a3b8}.consumption-value.svelte-kdmb3n{font-size:.875rem;color:#e2e8f0;font-weight:500}@media (max-width: 1024px){.grid.svelte-kdmb3n{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.grid.svelte-kdmb3n{grid-template-columns:1fr}header.svelte-kdmb3n{flex-direction:column;gap:1rem}.content.svelte-kdmb3n{padding:1rem}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:#0f172a;color:#e2e8f0;min-height:100vh}main.svelte-1n46o8q{min-height:100vh}.login-container.svelte-1n46o8q{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem}.login-card.svelte-1n46o8q{background:#1e293b;border-radius:1rem;padding:2rem;width:100%;max-width:400px;box-shadow:0 4px 6px -1px #0000004d}.login-card.svelte-1n46o8q h1:where(.svelte-1n46o8q){font-size:1.5rem;color:#4ade80;text-align:center;margin-bottom:.25rem}.login-card.svelte-1n46o8q h2:where(.svelte-1n46o8q){font-size:1rem;color:#94a3b8;text-align:center;margin-bottom:2rem;font-weight:400}.form-group.svelte-1n46o8q{margin-bottom:1rem}.form-group.svelte-1n46o8q label:where(.svelte-1n46o8q){display:block;margin-bottom:.5rem;color:#94a3b8;font-size:.875rem}.form-group.svelte-1n46o8q input:where(.svelte-1n46o8q){width:100%;padding:.75rem;border:1px solid #334155;border-radius:.5rem;background:#0f172a;color:#e2e8f0;font-size:1rem}.form-group.svelte-1n46o8q input:where(.svelte-1n46o8q):focus{outline:none;border-color:#4ade80}.error.svelte-1n46o8q{color:#f87171;font-size:.875rem;margin-bottom:1rem}button.svelte-1n46o8q{width:100%;padding:.75rem;background:#4ade80;color:#0f172a;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}button.svelte-1n46o8q:hover{background:#22c55e}
