/* ============================================
   PARKSEVEN Energy Dashboard - Styles
   Modern sidebar + 5 distinct dashboard themes
   ============================================ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:14px}
body{font-family:'Inter',sans-serif;background:#f5f3f0;color:#1a1a1a;display:flex;min-height:100vh;overflow-x:hidden}
.live-dot{width:8px;height:8px;background:#10b981;border-radius:50%;display:inline-block;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(16,185,129,.4)}50%{box-shadow:0 0 0 6px rgba(16,185,129,0)}}
.dashboard{display:none}
.dashboard.active{display:block;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ============================================
   LOGO BAR (inside each dashboard)
   ============================================ */
.logo-bar{display:flex;align-items:center;gap:28px}
.db-logo-main{height:170px;width:auto}
.db-logo-partner{height:90px;width:auto;opacity:.45;filter:none;transition:opacity .3s}
.db-logo-partner:hover{opacity:.7}
.db-logo-dark{background:#fff;border-radius:14px;padding:10px 20px;height:auto;max-height:190px;object-fit:contain}
.db-logo-dark.db-logo-partner{padding:8px 16px;max-height:110px}
.logo-bar-dark .db-logo-partner{opacity:.45}
.logo-bar-dark .db-logo-partner:hover{opacity:.65}

/* ============================================
   ANIMATED NUMBER TRANSITIONS
   ============================================ */
.anim-num{transition:opacity .15s ease}

/* ============================================
   ENERGY FLOW DIAGRAM
   ============================================ */
.energy-flow{width:100%;height:280px;position:relative;margin-bottom:0}
.energy-flow canvas{width:100%!important;height:100%!important;display:block}
#dashboard-style2 ~ .energy-flow,#dashboard-style3 ~ .energy-flow{background:transparent}

/* ============================================
   FULLSCREEN MODE
   ============================================ */
.fullscreen-btn{width:30px;height:30px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s;padding:0;flex-shrink:0}
.fullscreen-btn svg{width:16px;height:16px;stroke:#94a3b8}
.fullscreen-btn:hover{background:rgba(99,102,241,.15);border-color:#6366f1}
.fullscreen-btn:hover svg{stroke:#a5b4fc}
.sidebar-header{padding:20px 18px 16px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between}

body.fullscreen-mode .sidebar{transform:translateX(-100%)}
body.fullscreen-mode .main-content{margin-left:0}
body.fullscreen-mode .mobile-header{display:none}

/* ============================================
   SIDEBAR - Modern Dark Slate
   ============================================ */
.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;background:#0f172a;display:flex;flex-direction:column;z-index:100;transition:transform .3s;overflow-y:auto}
.sidebar-brand{font-size:1rem;font-weight:600;color:#e2e8f0;letter-spacing:.3px}
.sidebar-nav{padding:10px 10px 6px}
.nav-section-label{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:#475569;padding:10px 12px 4px}
.nav-item{display:flex;align-items:center;gap:11px;width:100%;padding:9px 13px;margin:2px 0;border:none;border-radius:8px;background:0;color:#94a3b8;font-size:.85rem;font-family:inherit;cursor:pointer;transition:.15s;text-align:left}
.nav-item svg{width:18px;height:18px;flex-shrink:0;opacity:.5}
.nav-item:hover{background:rgba(255,255,255,.05);color:#e2e8f0}
.nav-item:hover svg{opacity:.8}
.nav-item.active{background:rgba(99,102,241,.15);color:#a5b4fc;font-weight:500}
.nav-item.active svg{opacity:1;color:#a5b4fc}
.sidebar-section{padding:6px 10px;border-top:1px solid rgba(255,255,255,.05);margin-top:2px}
.demo-modes{display:flex;flex-direction:column;gap:3px}
.demo-btn{display:flex;align-items:center;gap:9px;width:100%;padding:7px 11px;border:1px solid rgba(255,255,255,.06);border-radius:7px;background:0;color:#94a3b8;font-size:.75rem;font-family:inherit;cursor:pointer;transition:.15s;text-align:left}
.demo-btn svg{width:15px;height:15px;flex-shrink:0;opacity:.4}
.demo-btn:hover{background:rgba(255,255,255,.05);color:#e2e8f0;border-color:rgba(255,255,255,.1)}
.demo-btn.active{background:rgba(99,102,241,.12);border-color:#6366f1;color:#a5b4fc}
.demo-btn.active svg{opacity:1;color:#a5b4fc}

/* Sliders */
.slider-group{padding:6px 12px}
.slider-label{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;color:#94a3b8;margin-bottom:5px}
.slider-val{color:#e2e8f0;font-weight:600;font-variant-numeric:tabular-nums}
.slider{-webkit-appearance:none;appearance:none;width:100%;height:5px;border-radius:3px;background:#1e293b;outline:none;cursor:pointer}
.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#6366f1;border:2px solid #0f172a;cursor:pointer;transition:background .15s}
.slider::-webkit-slider-thumb:hover{background:#818cf8}
.slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#6366f1;border:2px solid #0f172a;cursor:pointer}

/* Chart type buttons */
.chart-type-options{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:4px 10px 8px}
.chart-type-btn{display:flex;align-items:center;gap:7px;padding:7px 10px;border:1px solid rgba(255,255,255,.06);border-radius:7px;background:0;color:#94a3b8;font-size:.72rem;font-family:inherit;cursor:pointer;transition:.15s;text-align:left}
.chart-type-btn svg{width:16px;height:16px;flex-shrink:0;opacity:.4}
.chart-type-btn:hover{background:rgba(255,255,255,.05);color:#e2e8f0;border-color:rgba(255,255,255,.1)}
.chart-type-btn.active{background:rgba(99,102,241,.12);border-color:#6366f1;color:#a5b4fc}
.chart-type-btn.active svg{opacity:1;color:#a5b4fc}

/* Dataset toggles */
.dataset-toggles{padding:4px 10px 8px;display:flex;flex-direction:column;gap:3px}
.ds-toggle{display:flex;align-items:center;gap:8px;padding:5px 10px;border-radius:6px;cursor:pointer;font-size:.75rem;color:#94a3b8;transition:.15s;user-select:none}
.ds-toggle:hover{background:rgba(255,255,255,.04);color:#e2e8f0}
.ds-toggle input{display:none}
.ds-color{width:10px;height:10px;border-radius:3px;flex-shrink:0;transition:opacity .2s}
.ds-toggle input:not(:checked)~.ds-color{opacity:.25}
.ds-toggle input:not(:checked)~.ds-name{opacity:.4;text-decoration:line-through}
.ds-name{font-size:.72rem}

/* View mode toggle */
.view-toggles{display:flex;gap:4px;padding:4px 10px 8px}
.view-btn{flex:1;padding:7px 10px;border:1px solid rgba(255,255,255,.06);border-radius:7px;background:0;color:#94a3b8;font-size:.72rem;font-family:inherit;cursor:pointer;transition:.15s;text-align:center}
.view-btn:hover{background:rgba(255,255,255,.05);color:#e2e8f0;border-color:rgba(255,255,255,.1)}
.view-btn.active{background:rgba(99,102,241,.12);border-color:#6366f1;color:#a5b4fc}

.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:#0f172a;z-index:90;align-items:center;padding:0 14px;gap:14px}
.hamburger{width:34px;height:34px;display:flex;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{display:block;width:100%;height:2px;background:#e2e8f0;border-radius:1px}
.mobile-brand{color:#e2e8f0;font-size:.9rem;font-weight:600}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99}
.sidebar-overlay.visible{display:block}
.main-content{margin-left:280px;flex:1;min-height:100vh;transform-origin:top left;transition:margin-left .3s}

/* Heatmap wrap hidden by default, shown when view=heatmap */
.heatmap-wrap{height:200px}

/* ============================================
   STYLE 1: CLEAN MINIMAL
   ============================================ */
#dashboard-style1{background:#fafaf8}
.s1-wrapper{padding:28px 32px;max-width:1400px;margin:0 auto}
.s1-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;flex-wrap:wrap;gap:12px}
.s1-live{font-size:.8rem;color:#6b7280;display:flex;align-items:center;gap:8px}
.s1-hero{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:36px}
.s1-hero-card{background:#fff;border-radius:16px;padding:28px 24px;box-shadow:0 1px 4px rgba(0,0,0,.04);text-align:center;border:1px solid #f0ece8;transition:box-shadow .2s,transform .2s}
.s1-hero-card:hover{box-shadow:0 8px 24px rgba(74,55,40,.08);transform:translateY(-2px)}
.s1-hero-label{font-size:.7rem;text-transform:uppercase;letter-spacing:1.2px;color:#9a8d82;margin-bottom:12px;font-weight:500}
.s1-hero-num{font-size:3.2rem;font-weight:800;line-height:1;letter-spacing:-1px}
.s1-hero-unit{font-size:.85rem;color:#9a8d82;margin:4px 0 10px}
.s1-hero-sub{font-size:.75rem;color:#b0a596}
.s1-solar .s1-hero-num{color:#d97706}.s1-consumption .s1-hero-num{color:#dc2626}.s1-grid .s1-hero-num{color:#4f46e5}.s1-autarky .s1-hero-num{color:#059669}
.s1-solar{border-top:3px solid #f59e0b}.s1-consumption{border-top:3px solid #ef4444}.s1-grid{border-top:3px solid #6366f1}.s1-autarky{border-top:3px solid #10b981}
.s1-chart-section{background:#fff;border-radius:16px;padding:24px 28px;box-shadow:0 1px 4px rgba(0,0,0,.04);border:1px solid #f0ece8;margin-bottom:28px}
.s1-section-title{font-size:1rem;font-weight:500;color:#3d3029;margin-bottom:16px}
.s1-chart-wrap{height:280px;position:relative}.s1-chart-wrap canvas{width:100%!important;height:100%!important}
.s1-bottom{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.s1-donut-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 1px 4px rgba(0,0,0,.04);border:1px solid #f0ece8}
.s1-donut-card h3{font-size:.95rem;font-weight:500;color:#3d3029;margin-bottom:12px}
.s1-donut-wrap{height:240px;position:relative}.s1-donut-wrap canvas{width:100%!important;height:100%!important}
.s1-small-kpis{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.s1-kpi{background:#fff;border-radius:12px;padding:18px 20px;display:flex;flex-direction:column;gap:4px;box-shadow:0 1px 4px rgba(0,0,0,.04);border:1px solid #f0ece8}
.s1-kpi-label{font-size:.7rem;color:#9a8d82;text-transform:uppercase;letter-spacing:.5px}
.s1-kpi-val{font-size:1.3rem;font-weight:700;color:#3d3029}

/* ============================================
   STYLE 2: DARK CONTROL ROOM
   ============================================ */
#dashboard-style2{background:#0a0e17;min-height:100vh}
.s2-wrapper{padding:20px 24px;font-family:'JetBrains Mono','Courier New',monospace}
.s2-topbar{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;border-bottom:1px solid #1a2035;margin-bottom:20px;flex-wrap:wrap;gap:8px}
.s2-status{font-size:.7rem;color:#10b981;display:flex;align-items:center;gap:8px}
.s2-status-dot{width:6px;height:6px;background:#10b981;border-radius:50%;box-shadow:0 0 8px #10b981;display:inline-block}
.s2-ts{color:#475569;margin-left:12px}
.s2-gauge-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:20px}
.s2-gauge-box{background:#111827;border:1px solid #1e293b;border-radius:6px;padding:16px 14px;text-align:center}
.s2-gauge-label{font-size:.55rem;letter-spacing:2px;color:#64748b;margin-bottom:8px}
.s2-gauge-val{font-size:2.2rem;font-weight:700;line-height:1}
.s2-gauge-unit{font-size:.65rem;color:#475569;margin:4px 0 10px}
.s2-neon-yellow{color:#fbbf24;text-shadow:0 0 12px rgba(251,191,36,.4)}
.s2-neon-red{color:#f87171;text-shadow:0 0 12px rgba(248,113,113,.4)}
.s2-neon-blue{color:#818cf8;text-shadow:0 0 12px rgba(129,140,248,.4)}
.s2-neon-green{color:#34d399;text-shadow:0 0 12px rgba(52,211,153,.4)}
.s2-neon-cyan{color:#22d3ee;text-shadow:0 0 12px rgba(34,211,238,.4)}
.s2-bar{height:4px;background:#1e293b;border-radius:2px;overflow:hidden}
.s2-bar-fill{height:100%;border-radius:2px;transition:width .8s ease}
.s2-bar-yellow{background:linear-gradient(90deg,#92400e,#fbbf24);box-shadow:0 0 6px rgba(251,191,36,.3)}
.s2-bar-red{background:linear-gradient(90deg,#991b1b,#f87171);box-shadow:0 0 6px rgba(248,113,113,.3)}
.s2-bar-blue{background:linear-gradient(90deg,#312e81,#818cf8);box-shadow:0 0 6px rgba(129,140,248,.3)}
.s2-bar-green{background:linear-gradient(90deg,#064e3b,#34d399);box-shadow:0 0 6px rgba(52,211,153,.3)}
.s2-bar-cyan{background:linear-gradient(90deg,#164e63,#22d3ee);box-shadow:0 0 6px rgba(34,211,238,.3)}
.s2-charts{display:grid;grid-template-columns:2fr 1fr;gap:14px;margin-bottom:18px}
.s2-chart-box{background:#111827;border:1px solid #1e293b;border-radius:6px;padding:16px}
.s2-chart-title{font-size:.6rem;letter-spacing:2px;color:#64748b;margin-bottom:12px}
.s2-chart-wrap{height:260px;position:relative}.s2-chart-wrap canvas{width:100%!important;height:100%!important}
.s2-table-section{background:#111827;border:1px solid #1e293b;border-radius:6px;padding:16px}
.s2-table{width:100%;border-collapse:collapse;font-size:.75rem}
.s2-table th{text-align:left;padding:8px 12px;color:#64748b;font-weight:500;font-size:.6rem;letter-spacing:1.5px;border-bottom:1px solid #1e293b}
.s2-table td{padding:7px 12px;border-bottom:1px solid #1a2035;color:#94a3b8}
.s2-table td:first-child{color:#64748b}.s2-table tr:last-child td{border:none}

/* ============================================
   STYLE 3: GLASSMORPHISM
   ============================================ */
#dashboard-style3{background:#1a1033;overflow:hidden;min-height:100vh}
.s3-wrapper{position:relative;min-height:100vh;font-family:'DM Sans',sans-serif}
.s3-bg-orbs{position:fixed;inset:0;pointer-events:none;z-index:0}
.s3-orb{position:absolute;border-radius:50%;filter:blur(80px)}
.s3-orb1{width:500px;height:500px;background:radial-gradient(circle,rgba(245,158,11,.35),transparent);top:-100px;left:10%}
.s3-orb2{width:400px;height:400px;background:radial-gradient(circle,rgba(139,92,246,.35),transparent);bottom:-50px;right:5%}
.s3-orb3{width:350px;height:350px;background:radial-gradient(circle,rgba(16,185,129,.25),transparent);top:40%;left:50%}
.s3-content{position:relative;z-index:1;padding:28px 32px}
.s3-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;flex-wrap:wrap;gap:10px}
.s3-live{font-size:.8rem;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:8px}
.s3-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:24px}
.s3-card{background:rgba(255,255,255,.08);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:28px 24px;text-align:center;transition:transform .2s,background .2s}
.s3-card:hover{transform:translateY(-3px);background:rgba(255,255,255,.12)}
.s3-card-icon{font-size:2rem;margin-bottom:10px}.s3-card-label{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.5);margin-bottom:8px}
.s3-card-val{font-size:2.4rem;font-weight:700;color:#fff;line-height:1.1}.s3-card-sub{font-size:.75rem;color:rgba(255,255,255,.4);margin-top:8px}
.s3-gauges{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:24px}
.s3-gauge-card{background:rgba(255,255,255,.07);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:24px 20px;text-align:center}
.s3-gauge-wrap{position:relative;width:140px;height:140px;margin:0 auto 10px}.s3-gauge-wrap canvas{width:100%!important;height:100%!important}
.s3-gauge-center{position:absolute;top:55%;left:50%;transform:translate(-50%,-50%);font-size:1.6rem;font-weight:700;color:#fff}
.s3-gauge-label{font-size:.8rem;color:rgba(255,255,255,.6);margin-top:4px}
.s3-chart-glass{background:rgba(255,255,255,.07);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:24px;margin-bottom:22px}
.s3-chart-glass h3{font-size:.95rem;color:rgba(255,255,255,.8);margin-bottom:14px;font-weight:500}
.s3-chart-wrap{height:260px;position:relative}.s3-chart-wrap canvas{width:100%!important;height:100%!important}
.s3-pills{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}
.s3-pill{background:rgba(255,255,255,.08);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:40px;padding:12px 22px;display:flex;align-items:center;gap:8px;flex:1;min-width:160px;justify-content:center}
.s3-pill-num{font-size:1.2rem;font-weight:700;color:#fff}.s3-pill-label{font-size:.7rem;color:rgba(255,255,255,.5)}

/* ============================================
   STYLE 4: CORPORATE DATA-DENSE
   ============================================ */
#dashboard-style4{background:#f0f2f5}
.s4-wrapper{padding:0;font-family:'Space Grotesk',sans-serif}
.s4-topbar{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;background:#fff;border-bottom:2px solid #d1d5db;flex-wrap:wrap;gap:8px}
.s4-meta{font-size:.75rem;color:#6b7280;display:flex;align-items:center;gap:12px}.s4-status{color:#059669;font-weight:600}
.s4-data-grid{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:2px solid #d1d5db}
.s4-panel{border-right:1px solid #d1d5db;padding:0}.s4-panel:last-child{border-right:none}
.s4-panel-head{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;padding:10px 16px;border-bottom:1px solid #e5e7eb}
.s4-panel-production .s4-panel-head{background:#fef3c7;color:#92400e;border-bottom-color:#fcd34d}
.s4-panel-consumption .s4-panel-head{background:#fee2e2;color:#991b1b;border-bottom-color:#fca5a5}
.s4-panel-grid .s4-panel-head{background:#e0e7ff;color:#3730a3;border-bottom-color:#a5b4fc}
.s4-datatable{width:100%;border-collapse:collapse;font-size:.8rem;background:#fff}
.s4-datatable td{padding:7px 16px;border-bottom:1px solid #f3f4f6}.s4-datatable td:first-child{color:#6b7280;width:55%}
.s4-val{font-weight:600;color:#1f2937;text-align:right;font-variant-numeric:tabular-nums}
.s4-chart-grid{display:grid;grid-template-columns:2fr 1fr;border-bottom:1px solid #d1d5db}
.s4-chart-grid:last-child{border-bottom:none}.s4-chart-grid:nth-child(even){grid-template-columns:1fr 1fr}
.s4-chart-panel{border-right:1px solid #d1d5db;padding:0;background:#fff}.s4-chart-panel:last-child{border-right:none}
.s4-chart-panel .s4-panel-head{background:#f9fafb;color:#374151}
.s4-chart-wrap{height:240px;padding:12px 16px;position:relative}.s4-chart-wrap canvas{width:100%!important;height:100%!important}

/* ============================================
   STYLE 5: NATURE / ECO
   ============================================ */
#dashboard-style5{background:linear-gradient(170deg,#f0fdf4 0%,#ecfdf5 30%,#f5f0eb 100%)}
.s5-wrapper{padding:28px 32px;max-width:1400px;margin:0 auto;font-family:'Outfit',sans-serif}
.s5-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:10px}
.s5-live{font-size:.8rem;color:#6b7280;display:flex;align-items:center;gap:8px}
.s5-impact-banner{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.s5-impact-item{background:linear-gradient(135deg,#065f46,#059669);border-radius:16px;padding:22px 18px;text-align:center;color:#fff;box-shadow:0 4px 16px rgba(6,95,70,.2)}
.s5-impact-icon{font-size:2rem;margin-bottom:6px}.s5-impact-num{font-size:2rem;font-weight:700;line-height:1.1}
.s5-impact-label{font-size:.65rem;color:rgba(255,255,255,.7);margin-top:6px;text-transform:uppercase;letter-spacing:.5px}
.s5-stat-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:24px}
.s5-stat{border-radius:16px;padding:22px 20px;color:#fff;position:relative;overflow:hidden}
.s5-stat-solar{background:linear-gradient(135deg,#b45309,#f59e0b)}.s5-stat-cons{background:linear-gradient(135deg,#991b1b,#ef4444)}.s5-stat-autarky{background:linear-gradient(135deg,#1e40af,#3b82f6)}
.s5-stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.75);margin-bottom:6px}
.s5-stat-val{font-size:2.2rem;font-weight:700;line-height:1.1}.s5-stat-sub{font-size:.75rem;color:rgba(255,255,255,.6);margin-top:6px}
.s5-stat-gauge-wrap{position:absolute;right:10px;bottom:8px;width:70px;height:70px;opacity:.4}.s5-stat-gauge-wrap canvas{width:100%!important;height:100%!important}
.s5-chart-row{display:grid;grid-template-columns:1fr;gap:18px;margin-bottom:20px}
.s5-chart-row:has(.s5-half){grid-template-columns:1fr 1fr}
.s5-chart-card{background:#fff;border-radius:16px;padding:22px;box-shadow:0 2px 8px rgba(0,0,0,.04);border:1px solid #d1fae5}
.s5-chart-card h3{font-size:.9rem;font-weight:600;color:#064e3b;margin-bottom:14px}
.s5-chart-wrap{height:260px;position:relative}.s5-chart-wrap canvas{width:100%!important;height:100%!important}
.s5-savings-bar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.s5-save-item{flex:1;min-width:140px;background:#fff;border-radius:12px;padding:14px 18px;border:1px solid #d1fae5;display:flex;flex-direction:column;gap:2px}
.s5-save-label{font-size:.65rem;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}
.s5-save-val{font-size:1.2rem;font-weight:700;color:#064e3b}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
    .s1-hero,.s2-gauge-strip{grid-template-columns:repeat(2,1fr)}
    .s3-cards,.s3-gauges,.s5-stat-cards,.s5-impact-banner{grid-template-columns:1fr 1fr}
    .s2-charts,.s4-data-grid,.s4-chart-grid,.s4-chart-grid:nth-child(even){grid-template-columns:1fr}
    .s4-panel{border-right:none;border-bottom:1px solid #d1d5db}
    .s1-bottom{grid-template-columns:1fr}
    .s5-chart-row:has(.s5-half){grid-template-columns:1fr}
}
@media(max-width:768px){
    .sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}
    .mobile-header{display:flex}.main-content{margin-left:0}
    .s1-wrapper,.s3-content,.s5-wrapper{padding:70px 14px 20px}.s2-wrapper{padding:70px 14px 20px}
    .s1-hero,.s2-gauge-strip,.s3-cards,.s3-gauges,.s5-stat-cards,.s5-impact-banner{grid-template-columns:1fr}
    .s3-pills,.s5-savings-bar{flex-direction:column}
    .energy-flow{height:200px}
}
::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#94a3b8;border-radius:3px}.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1)}
