@import url('https://fonts.googleapis.com/css2?family=Sora:wght@600;700;800&display=swap');
/* ============================================================
   SOLYX — DATA-VIZ COMPONENTS
   All chart styling lives here. Tokens are scoped to .solyx-viz
   (apply that class to each chart <section>) so nothing leaks
   into the main site stylesheet. Component class names are unique
   to charts; only .pill was renamed to .vyr to avoid a clash.
   ============================================================ */
.solyx-viz{
  --c-flame:#E8641C; --c-orange:#F7902B; --c-amber:#FFC23D; --c-sun:#FFD36B;
  --c-ink:#0E1320; --c-ink-2:#1A2236; --c-ink-3:#2A334B;
  --c-slate:#5A6378; --c-mute:#8A93A6; --c-line:#E5E8EF;
  --c-bg:#FFFFFF; --c-soft:#F7F8FB;
  --c-green:#2EA15C; --c-blue:#1668E3; --c-teal:#00A0A8;
  --f-sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --f-display:'Sora','Inter',system-ui,sans-serif;
  --radius-lg:22px;
  --shadow-sm:0 1px 2px rgba(14,19,32,.06),0 2px 8px rgba(14,19,32,.04);
  --shadow:0 8px 30px rgba(14,19,32,.10);
  --grad-sun:linear-gradient(135deg,var(--c-flame) 0%,var(--c-orange) 45%,var(--c-amber) 100%);
}

/* ---- section shell ---- */
.solyx-viz.viz{padding:clamp(56px,7vw,96px) 0;border-bottom:1px solid var(--c-line)}
.solyx-viz.viz.dark{background:linear-gradient(180deg,var(--c-ink) 0%,var(--c-ink-2) 100%);color:#fff;border-bottom:0}
.solyx-viz.viz.dark h2{color:#fff}
.solyx-viz .viz-head{max-width:780px;margin-bottom:36px}
.solyx-viz .viz-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:72px;align-items:center}
.solyx-viz .viz-grid.rev{grid-template-columns:.85fr 1.15fr}
.solyx-viz .body-lg{font-size:1.05rem;color:var(--c-slate);max-width:64ch}
.solyx-viz.viz.dark .body-lg{color:rgba(255,255,255,.74)}
.solyx-viz .eyebrow.accent{color:var(--c-flame)}
.solyx-viz .eyebrow.accent-light{color:var(--c-amber)}
.solyx-viz .grad-text{background:var(--grad-sun);-webkit-background-clip:text;background-clip:text;color:transparent}
.solyx-viz .proof-num{display:inline-block;font-family:var(--f-display);font-weight:800;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase}

/* ---- reveal ---- */
.solyx-viz .reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease,transform .7s ease}
.solyx-viz .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.solyx-viz .reveal{opacity:1;transform:none;transition:none}}

/* ---- cards + chart chrome ---- */
.solyx-viz .chart-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:26px}
.solyx-viz.dark .chart-card{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.10);box-shadow:none}
.solyx-viz .chart-title{font-family:var(--f-display);font-weight:700;font-size:.95rem;letter-spacing:.02em;margin:0 0 2px;color:inherit}
.solyx-viz .chart-sub{font-size:.8rem;color:var(--c-mute);margin:0 0 18px}
.solyx-viz.dark .chart-sub{color:rgba(255,255,255,.5)}

.solyx-viz .stat-num{font-family:var(--f-display);font-weight:800;font-size:clamp(2.4rem,5.5vw,3.6rem);line-height:1;background:var(--grad-sun);-webkit-background-clip:text;background-clip:text;color:transparent}
.solyx-viz .stat-cap{font-size:.95rem;color:var(--c-slate)}
.solyx-viz.dark .stat-cap{color:rgba(255,255,255,.7)}

.solyx-viz .legend{list-style:none;margin:14px 0 0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:6px 18px}
.solyx-viz .legend li{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--c-slate)}
.solyx-viz.dark .legend li{color:rgba(255,255,255,.72)}
.solyx-viz .legend .sw{width:11px;height:11px;border-radius:3px;flex:0 0 auto}
.solyx-viz .legend b{color:var(--c-ink);font-weight:600;margin-left:auto;font-variant-numeric:tabular-nums}
.solyx-viz.dark .legend b{color:#fff}
.solyx-viz #w-legend li{white-space:nowrap}

/* ---- svg primitives ---- */
.solyx-viz .svg-chart{width:100%;height:auto;display:block;overflow:visible;touch-action:none}
.solyx-viz .axis-lbl{font-family:var(--f-sans);font-size:11px;fill:var(--c-mute)}
.solyx-viz.dark .axis-lbl{fill:rgba(255,255,255,.45)}
.solyx-viz .gridline{stroke:var(--c-line);stroke-width:1}
.solyx-viz.dark .gridline{stroke:rgba(255,255,255,.08)}
.solyx-viz .peakband{fill:rgba(232,100,28,.07)}
.solyx-viz.dark .peakband{fill:rgba(255,194,61,.10)}
.solyx-viz .peaklbl{font-family:var(--f-sans);font-weight:700;font-size:10px;letter-spacing:.08em;text-transform:uppercase;fill:var(--c-flame)}
.solyx-viz.dark .peaklbl{fill:var(--c-amber)}
.solyx-viz .draw{stroke-dasharray:var(--len);stroke-dashoffset:var(--len);transition:stroke-dashoffset 1.8s ease}
.solyx-viz .draw.go{stroke-dashoffset:0}
@media (prefers-reduced-motion:reduce){.solyx-viz .draw{stroke-dashoffset:0;transition:none}}
.solyx-viz .areafill{opacity:0;transition:opacity 1.1s ease .5s}
.solyx-viz .areafill.go{opacity:1}
.solyx-viz .cursor-line{stroke:var(--c-ink-3);stroke-width:1.5;stroke-dasharray:4 4;opacity:.5}
.solyx-viz.dark .cursor-line{stroke:rgba(255,255,255,.5)}
.solyx-viz .cursor-dot{fill:#fff;stroke-width:3}

/* horizontal bar labels (new charts) */
.solyx-viz .hb-name{font-family:var(--f-display);font-weight:700;font-size:13px;fill:var(--c-ink)}
.solyx-viz .hb-sub{font-size:10.5px;fill:var(--c-mute)}
.solyx-viz .hb-val{font-family:var(--f-display);font-weight:800;font-size:13px;fill:var(--c-ink)}
.solyx-viz.dark .hb-name,.solyx-viz.dark .hb-val{fill:#fff}

/* ---- chips / toggles ---- */
.solyx-viz .chips{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 16px}
.solyx-viz .chip{font:inherit;font-size:.82rem;font-weight:600;padding:7px 14px;border-radius:999px;border:1px solid var(--c-line);background:#fff;color:var(--c-slate);cursor:pointer;transition:.15s}
.solyx-viz .chip[aria-pressed="true"]{background:var(--grad-sun);color:#fff;border-color:transparent;box-shadow:0 6px 16px rgba(232,100,28,.28)}
.solyx-viz.dark .chip{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.14);color:rgba(255,255,255,.75)}
.solyx-viz.dark .chip[aria-pressed="true"]{background:#F27522;border-color:transparent;color:#fff;box-shadow:none}
/* duck-curve "With storage" toggle uses storage blue to match the battery section; "Net load today" stays orange */
#duck .chip[data-duck="store"][aria-pressed="true"]{background:#3b82f6;border-color:transparent;color:#fff;box-shadow:none}

/* ---- notes / sources / takeaway ---- */
.solyx-viz .note{margin-top:18px;font-size:.82rem;color:var(--c-mute);border-left:2px solid var(--c-flame);padding:2px 0 2px 14px}
.solyx-viz.dark .note{color:rgba(255,255,255,.6)}
.solyx-viz .src{font-size:.78rem;color:var(--c-mute);margin-top:10px}
.solyx-viz.dark .src{color:rgba(255,255,255,.45)}
.solyx-viz .takeaway{margin:24px 0 0;max-width:64ch;font-size:1.05rem;line-height:1.5;color:var(--c-ink-2);padding:4px 0 4px 16px;border-left:3px solid transparent;border-image:var(--grad-sun) 1}
.solyx-viz.dark .takeaway{color:rgba(255,255,255,.92)}
.solyx-viz .takeaway .lead{font-family:var(--f-display);font-weight:800;color:var(--c-flame)}
.solyx-viz.dark .takeaway .lead{color:var(--c-amber)}

/* ---- milestone year picker (renamed .pill -> .vyr) ---- */
.solyx-viz .mix-years{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0 18px}
.solyx-viz .vyr{position:relative;font:inherit;font-size:.84rem;font-weight:600;padding:7px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.05);color:rgba(255,255,255,.82);cursor:pointer;transition:.15s}
.solyx-viz .vyr:hover{border-color:rgba(255,194,61,.5);color:#fff}
.solyx-viz .vyr.on{background:#F27522;color:#fff;border-color:transparent;box-shadow:0 6px 16px rgba(232,100,28,.32)}
.solyx-viz .vyr.target{border-style:dashed;border-color:rgba(255,194,61,.45)}
.solyx-viz .vyr.target.on{background:linear-gradient(135deg,#2EA15C,#5BC97F);box-shadow:0 6px 16px rgba(46,161,92,.30)}

/* ---- TDS play controls + scrub ---- */
.solyx-viz .controls{display:flex;align-items:center;gap:14px;margin:2px 0 16px}
.solyx-viz .play{width:44px;height:44px;border-radius:50%;border:0;cursor:pointer;background:var(--grad-sun);color:#fff;display:flex;align-items:center;justify-content:center;flex:0 0 auto;box-shadow:0 6px 16px rgba(232,100,28,.30)}
.solyx-viz .play svg{width:18px;height:18px;fill:#fff}
.solyx-viz .scrub{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;background:var(--c-line);outline:none;cursor:pointer}
.solyx-viz.dark .scrub{background:rgba(255,255,255,.14)}
.solyx-viz .scrub::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--c-flame);border:3px solid #fff;box-shadow:var(--shadow-sm);cursor:pointer}
.solyx-viz .scrub::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--c-flame);border:3px solid #fff;cursor:pointer}

/* ---- TDS readout chips ---- */
.solyx-viz .readout{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:6px}
.solyx-viz .ro{background:var(--c-soft);border:1px solid var(--c-line);border-radius:12px;padding:12px 14px}
.solyx-viz.dark .ro{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.10)}
.solyx-viz .ro .lbl{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--c-mute);margin:0 0 3px}
.solyx-viz.dark .ro .lbl{color:rgba(255,255,255,.5)}
.solyx-viz .ro .val{font-family:var(--f-display);font-weight:800;font-size:1.5rem;line-height:1;color:var(--c-ink)}
.solyx-viz.dark .ro .val{color:#fff}
.solyx-viz .ro .val small{font-size:.85rem;font-weight:700;color:var(--c-slate);margin-left:3px}
.solyx-viz.dark .ro .val small{color:rgba(255,255,255,.6)}
.solyx-viz .ro.hl{background:linear-gradient(135deg,rgba(232,100,28,.10),rgba(255,194,61,.10));border-color:rgba(232,100,28,.30)}

/* ---- price tooltip ---- */
.solyx-viz .ptip{position:relative;min-height:1px}
.solyx-viz .tipbox{display:inline-flex;flex-wrap:wrap;gap:18px;align-items:baseline;background:var(--c-soft);border:1px solid var(--c-line);border-radius:12px;padding:12px 16px;margin-bottom:6px}
.solyx-viz.dark .tipbox{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.12)}
.solyx-viz .tipbox .yr{font-family:var(--f-display);font-weight:800;font-size:1.4rem;color:var(--c-ink)}
.solyx-viz.dark .tipbox .yr{color:#fff}
.solyx-viz .tipbox .it{font-size:.84rem;color:var(--c-slate)}
.solyx-viz.dark .tipbox .it{color:rgba(255,255,255,.7)}
.solyx-viz .tipbox .it b{font-family:var(--f-display);font-size:1rem}
.solyx-viz .tipbox .sdge b{color:var(--c-flame)}
.solyx-viz .tipbox .ca b{color:#1668E3}
.solyx-viz .tipbox .mult{font-weight:700;color:var(--c-flame)}

/* ---- grid-mix target/delta panel ---- */
.solyx-viz .tgt-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:20px 22px}
.solyx-viz .tgt-lbl{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);margin:0 0 10px}
.solyx-viz .tgt-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.solyx-viz .tgt-num{font-family:var(--f-display);font-weight:800;font-size:2.75rem;line-height:1;color:var(--c-amber)}
.solyx-viz .tgt-badge{font-size:.74rem;font-weight:700;padding:5px 12px;border-radius:999px;white-space:nowrap}
.solyx-viz .tgt-badge.beat{background:rgba(46,161,92,.20);color:#6FD699}
.solyx-viz .tgt-badge.miss{background:rgba(255,194,61,.18);color:var(--c-amber)}
.solyx-viz .tgt-badge.target{background:rgba(140,150,170,.20);color:#b6bdca}
.solyx-viz .tgt-sub{font-size:.92rem;color:rgba(255,255,255,.66);margin:10px 0 0}
.solyx-viz .tgt-expl{font-size:.95rem;color:rgba(255,255,255,.82);margin:12px 0 0;line-height:1.5}
.solyx-viz .delta-block{margin-top:20px}
.solyx-viz .delta-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:11px 0;border-top:1px solid rgba(255,255,255,.09)}
.solyx-viz .delta-name{font-size:.9rem;color:rgba(255,255,255,.78);display:flex;align-items:center;gap:8px;line-height:1.3}
.solyx-viz .delta-name .sw{width:11px;height:11px;border-radius:3px;flex:0 0 auto;display:inline-block}
.solyx-viz .delta-val{font-family:var(--f-display);font-weight:800;font-size:1.02rem;white-space:nowrap;flex:0 0 auto}
.solyx-viz .delta-val.good{color:#6FD699}
.solyx-viz .delta-val.bad{color:#FF8A6B}
.solyx-viz .delta-val.flat{color:var(--c-mute);font-weight:600;font-size:.9rem}

/* ---- closing CTA ---- */
.solyx-viz .cta-btn{display:inline-flex;align-items:center;gap:.5em;padding:15px 30px;border-radius:999px;background:var(--grad-sun);color:#fff;font-family:var(--f-display);font-weight:700;font-size:1.05rem;box-shadow:0 10px 28px rgba(232,100,28,.35);transition:transform .15s ease,box-shadow .15s ease}
.solyx-viz .cta-btn:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(232,100,28,.5)}
.solyx-viz .thesis-head{text-align:center;max-width:880px;margin:0 auto}

@media (max-width:900px){
  .solyx-viz .viz-grid,.solyx-viz .viz-grid.rev{grid-template-columns:1fr;gap:30px}
}
