*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #060d18;--bg-secondary: #0a1628;--bg-card: #0d1f3c;--bg-card-hover: #112a4a;--border: #1a3a5c;--border-glow: #1e4976;--text-primary: #e2e8f0;--text-secondary: #8899aa;--text-dim: #556677;--accent: #00dd88;--accent-dim: #00aa66;--accent-glow: rgba(0, 221, 136, .15);--red: #ff4757;--red-glow: rgba(255, 71, 87, .15);--amber: #ffa502;--amber-glow: rgba(255, 165, 2, .15);--blue: #3b82f6;--blue-glow: rgba(59, 130, 246, .15);--cyan: #06b6d4;--purple: #a855f7}body{font-family:Inter,-apple-system,sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow-x:hidden;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-glow)}.topbar{position:fixed;top:0;left:0;right:0;height:48px;background:linear-gradient(180deg,#0a1628fa,#060d18f2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:1000}.topbar-brand{display:flex;align-items:center;gap:10px}.topbar-brand .logo-icon{width:28px;height:28px;border-radius:6px;background:linear-gradient(135deg,var(--accent) 0%,var(--cyan) 100%);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--bg-primary)}.topbar-brand h1{font-size:15px;font-weight:600;letter-spacing:-.3px}.topbar-brand h1 span{color:var(--accent)}.topbar-metrics{display:flex;gap:32px;align-items:center}.topbar-metric{display:flex;flex-direction:column;align-items:center;gap:1px}.topbar-metric .label{font-size:9px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-dim);font-weight:500}.topbar-metric .value{font-size:15px;font-weight:600;font-variant-numeric:tabular-nums}.topbar-metric .value.green{color:var(--accent)}.topbar-metric .value.red{color:var(--red)}.topbar-metric .value.amber{color:var(--amber)}.topbar-live{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-dim)}.live-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent),0 0 16px #00dd884d;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.main-content{margin-top:48px;display:grid;grid-template-columns:1fr 360px;grid-template-rows:auto 1fr;gap:1px;height:calc(100vh - 48px);background:var(--border)}.price-strip{grid-column:1 / -1;background:var(--bg-secondary);display:flex;justify-content:center;gap:1px;padding:0}.price-card{flex:1;max-width:240px;padding:14px 18px;background:var(--bg-primary);display:flex;flex-direction:column;gap:4px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.price-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);opacity:0;transition:opacity .2s}.price-card:hover:before{opacity:1}.price-card:hover{background:var(--bg-card)}.price-card.negative:before{background:var(--accent);opacity:1}.price-card.high:before{background:var(--red);opacity:1}.price-card.spike:before{background:var(--red);opacity:1;animation:flash .5s ease-in-out infinite}@keyframes flash{0%,to{opacity:1}50%{opacity:.3}}.price-card .region-name{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);font-weight:500}.price-card .price-value{font-size:28px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-1px;line-height:1}.price-card .price-value.negative,.price-card .price-value.low{color:var(--accent)}.price-card .price-value.moderate{color:var(--text-primary)}.price-card .price-value.high{color:var(--amber)}.price-card .price-value.spike{color:var(--red)}.price-card .price-unit{font-size:10px;color:var(--text-dim)}.price-card .demand-value{font-size:11px;color:var(--text-secondary);margin-top:2px}.map-area{background:var(--bg-primary);position:relative;overflow:hidden}.sidebar{background:var(--bg-secondary);overflow-y:auto;display:flex;flex-direction:column;gap:1px}.card{background:var(--bg-primary);padding:20px}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.card-title{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);font-weight:600}.card-badge{font-size:10px;padding:2px 8px;border-radius:10px;font-weight:500}.battery-signal{text-align:center;padding:24px 20px}.signal-indicator{width:80px;height:80px;border-radius:50%;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;position:relative}.signal-indicator.CHARGE{background:var(--accent-glow);color:var(--accent);border:2px solid var(--accent);box-shadow:0 0 30px #0d83,inset 0 0 30px #00dd880d}.signal-indicator.HOLD{background:var(--amber-glow);color:var(--amber);border:2px solid var(--amber);box-shadow:0 0 30px #ffa50233,inset 0 0 30px #ffa5020d}.signal-indicator.DISCHARGE{background:var(--red-glow);color:var(--red);border:2px solid var(--red);box-shadow:0 0 30px #ff475733,inset 0 0 30px #ff47570d}.signal-label{font-size:16px;font-weight:700;margin-bottom:8px;letter-spacing:.5px}.signal-label.CHARGE{color:var(--accent)}.signal-label.HOLD{color:var(--amber)}.signal-label.DISCHARGE{color:var(--red)}.signal-reason{font-size:12px;color:var(--text-secondary);line-height:1.5;max-width:280px;margin:0 auto}.gen-mix-container{display:flex;align-items:center;gap:16px}.gen-donut{width:120px;height:120px;flex-shrink:0}.gen-legend{display:flex;flex-direction:column;gap:5px;flex:1;min-width:0}.gen-legend-item{display:flex;align-items:center;gap:8px;font-size:11px}.gen-legend-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.gen-legend-name{color:var(--text-secondary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gen-legend-value{color:var(--text-primary);font-weight:600;font-variant-numeric:tabular-nums}.renewable-gauge{text-align:center;padding:8px 0}.gauge-value{font-size:48px;font-weight:700;color:var(--accent);line-height:1;letter-spacing:-2px;text-shadow:0 0 40px rgba(0,221,136,.3)}.gauge-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1.5px;margin-top:4px}.forecast-chart{height:140px;width:100%}.ev-window{text-align:center}.ev-time{font-size:20px;font-weight:700;color:var(--cyan);margin-bottom:4px}.ev-price{font-size:13px;color:var(--text-secondary)}.ev-savings{margin-top:12px;padding:10px;background:var(--accent-glow);border-radius:8px;border:1px solid rgba(0,221,136,.2)}.ev-savings-value{font-size:18px;font-weight:700;color:var(--accent)}.ev-savings-label{font-size:11px;color:var(--text-secondary);margin-top:2px}.region-selector{display:flex;gap:4px;padding:3px;background:var(--bg-card);border-radius:8px}.region-btn{padding:5px 10px;border:none;background:none;color:var(--text-dim);font-size:11px;font-weight:500;cursor:pointer;border-radius:6px;font-family:Inter,sans-serif;transition:all .15s}.region-btn:hover{color:var(--text-primary)}.region-btn.active{background:var(--accent);color:var(--bg-primary);font-weight:600}.flow-line{stroke-dasharray:8,4;animation:flowDash 1s linear infinite}@keyframes flowDash{to{stroke-dashoffset:-12}}.loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-dim);font-size:14px}.loading-spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-right:10px}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 900px){.main-content{grid-template-columns:1fr;grid-template-rows:auto auto 1fr}.topbar-metrics{gap:16px}.topbar-metric .label{font-size:8px}.topbar-metric .value{font-size:13px}.price-card .price-value{font-size:22px}.price-strip{flex-wrap:wrap}.price-card{max-width:none}}@media (max-width: 600px){.topbar{padding:0 12px}.topbar-metrics{gap:10px}.price-strip{flex-direction:column}}
