/* Electric Homes & Vehicles — bespoke navy report theme.
   Sliced verbatim from the approved static build (Downloads/electric-homes-and-vehicles).
   Do not hand-edit values here without updating the source. */
:root{
  --navy:#0a1428; --navy-2:#0c1830; --navy-3:#0e1d39; --panel:#101f3c;
  --gold:#f5b731; --gold-soft:#fed24d;
  --ink:#eaf0f8; --ink-soft:#b7c4da; --ink-mute:#7d8eaa;
  --line:rgba(255,255,255,.10);
  --sunset:linear-gradient(90deg,#ED6221,#F79C31,#FED24D,#C54B86,#70418C);
  --sans:'Rubik',system-ui,-apple-system,sans-serif;
  --serif:'Rubik',system-ui,sans-serif; /* headers use Rubik now, like the campaign page */
  --squiggle:255px 15px 225px 15px / 15px 225px 15px 255px;
  --sqg:url("https://uploads-ssl.webflow.com/65e8e4d8dd233b8f20bfea98/66af5103d3076ed98e01a60a_g30.svg");
  --max:1060px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:74px}
body{font-family:var(--sans);background:var(--navy);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}
a{color:inherit}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}

/* ── top bar ───────────────────────────── */
.bar{position:fixed;top:0;left:0;right:0;z-index:80;height:64px;display:flex;align-items:center;justify-content:space-between;
  padding:0 28px;background:rgba(10,20,40,.72);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);transition:background .3s}
.bar.scrolled{background:rgba(10,20,40,.95)}
.bar .brand{display:flex;align-items:center;gap:14px;font-weight:700;font-size:15px;letter-spacing:.2px}
.bar .brand .tag{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--gold);font-size:14px}
.bar nav{display:flex;gap:6px}
.bar nav a{font-size:13px;color:var(--ink-soft);text-decoration:none;padding:8px 14px;border-radius:7px;transition:.2s}
.bar nav a:hover{color:var(--gold);background:rgba(245,183,49,.12)}
@media(max-width:780px){.bar nav{display:none}.bar .brand .tag{display:none}}

/* ── hero ──────────────────────────────── */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;padding-bottom:7vh;overflow:hidden;background:var(--navy)}
.hero-stage{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-stage svg{position:absolute;inset:-3%;width:106%;height:106%;display:block}
.hero-stage svg path{transform-origin:50% 100%}
.hero-stage svg path:nth-of-type(1){animation:rise .9s cubic-bezier(.22,.7,.18,1) 0s backwards}
.hero-stage svg path:nth-of-type(2){animation:rise .9s cubic-bezier(.22,.7,.18,1) .10s backwards}
.hero-stage svg path:nth-of-type(3){animation:rise .9s cubic-bezier(.22,.7,.18,1) .20s backwards}
.hero-stage svg path:nth-of-type(4){animation:rise .9s cubic-bezier(.22,.7,.18,1) .30s backwards}
.hero-stage svg path:nth-of-type(5){animation:rise .9s cubic-bezier(.22,.7,.18,1) .40s backwards}
.hero-stage svg path:nth-of-type(6){animation:rise 2.6s cubic-bezier(.16,.85,.25,1) .50s backwards}
.hero-stage svg path:nth-of-type(7){animation:rise 2.6s cubic-bezier(.16,.85,.25,1) .60s backwards}
@keyframes rise{0%{transform:translateY(38%) scaleY(.92);opacity:0;filter:brightness(.55) saturate(.85)}55%{opacity:1}100%{transform:translateY(0) scaleY(1);opacity:1;filter:brightness(1) saturate(1)}}
.hero-veil{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(10,20,40,.62) 0%,rgba(10,20,40,.28) 34%,rgba(10,20,40,.55) 62%,rgba(10,20,40,.94) 100%)}
.hero-content{position:relative;z-index:2;width:100%;animation:fade-up 1s cubic-bezier(.22,.7,.18,1) .5s backwards}
@keyframes fade-up{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.hero .eyebrow{font-size:13px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.hero h1{font-family:var(--serif);font-weight:700;font-size:clamp(2.4rem,6.4vw,4.6rem);line-height:1.06;letter-spacing:-.01em;color:#fff;text-shadow:0 2px 34px rgba(0,0,0,.4)}
.hero h1 em{font-style:normal;color:var(--gold-soft)}
.hero .sub{font-size:clamp(18px,2.1vw,25px);font-weight:500;color:rgba(255,255,255,.92);margin:22px 0 24px;max-width:620px;text-shadow:0 1px 16px rgba(0,0,0,.45)}
.hero .rule{width:240px;max-width:55%;height:3px;background:var(--sunset);border-radius:2px;margin-bottom:18px}
.hero .authors{font-size:13px;color:rgba(255,255,255,.62);max-width:560px;margin-bottom:30px}
.hero .authors b{color:rgba(255,255,255,.82);font-weight:600}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.scroll-hint{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.5);animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}

/* ── buttons ───────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:15px;font-weight:600;text-decoration:none;
  padding:14px 26px;border-radius:999px;cursor:pointer;border:2px solid transparent;transition:.2s}
.btn-gold{background:var(--gold);color:#10203c}
.btn-gold:hover{background:var(--gold-soft);transform:translateY(-1px)}
.btn-ghost{border-color:rgba(255,255,255,.28);color:#fff}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}

/* ── section scaffolding ───────────────── */
section.block{position:relative;padding:104px 0}
.block.alt{background:var(--navy-2)}
.block.panel{background:linear-gradient(180deg,var(--navy-3),var(--navy-2))}
.eyebrow{font-size:1rem;font-weight:600;color:var(--gold);margin-bottom:14px}
h2.h{font-family:var(--serif);font-weight:700;font-size:clamp(1.7rem,4vw,2.5rem);line-height:1.12;color:#fff;margin-bottom:18px;max-width:34ch}
h2.h::after{content:"";display:block;width:clamp(96px,14vw,150px);height:14px;margin-top:14px;
  background:var(--sqg) left center/contain no-repeat;filter:brightness(0) invert(1);opacity:.35}
h2.h em{font-style:normal;color:var(--gold-soft)}
/* a *highlighted* word inside a heading keeps the heading weight (just recolours) */
.hero h1 .hl,h2.h .hl{font-weight:inherit}
.lead{font-size:1.05rem;line-height:1.85;color:var(--ink-soft);max-width:66ch;margin-bottom:22px}
.lead b,.lead strong{color:#fff;font-weight:600}
.hl{color:var(--gold-soft);font-weight:600}
.sr{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.sr.vis{opacity:1;transform:none}

/* ── opportunity cards ─────────────────── */
.opp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.opp-card{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:var(--squiggle);padding:32px 28px;position:relative;overflow:hidden}
.opp-card:nth-child(1){transform:rotate(-1deg)}
.opp-card:nth-child(2){transform:rotate(.7deg)}
.opp-card:nth-child(3){transform:rotate(-.5deg)}
.opp-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--sunset)}
.opp-card .big{font-family:var(--serif);font-size:30px;font-weight:600;color:var(--gold);margin-bottom:10px}
.opp-card h3{font-size:17px;font-weight:600;color:#fff;margin-bottom:8px}
.opp-card p{font-size:14.5px;color:var(--ink-soft)}
@media(max-width:780px){.opp-grid{grid-template-columns:1fr}}

/* ── report download card ──────────────── */
.report{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center}
.report-cover{display:block;border-radius:14px;overflow:hidden;border:1px solid var(--line);
  box-shadow:0 26px 60px rgba(0,0,0,.45);line-height:0;transition:transform .25s ease,box-shadow .25s ease}
.report-cover:hover{transform:translateY(-3px);box-shadow:0 34px 70px rgba(0,0,0,.55)}
.report-cover img{display:block;width:100%;height:auto}
.report-form{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:16px;padding:28px}
.report-form h3{font-family:var(--serif);font-size:24px;font-weight:600;color:#fff;margin-bottom:8px}
.report-form p.fm{font-size:14px;color:var(--ink-soft);margin-bottom:18px}
.report-form .row{display:flex;gap:10px;flex-wrap:wrap}
.report-form input[type=email]{flex:1;min-width:180px;background:rgba(0,0,0,.25);border:1px solid var(--line);border-radius:10px;
  padding:14px 16px;color:#fff;font-family:var(--sans);font-size:15px}
.report-form input::placeholder{color:var(--ink-mute)}
.report-optin{display:flex;align-items:flex-start;gap:10px;margin-top:14px;cursor:pointer;
  font-size:13.5px;line-height:1.45;color:var(--ink-soft)}
.report-optin input[type=checkbox]{flex:none;width:18px;height:18px;margin-top:1px;accent-color:var(--gold);cursor:pointer}
.report-form .fine{font-size:12px;color:var(--ink-mute);margin-top:14px;line-height:1.5}
@media(max-width:820px){.report{grid-template-columns:1fr;gap:28px}.report-cover{max-width:340px}}

/* ── chart placeholder ─────────────────── */
.chart-fig{margin-top:38px}
/* lead copy that follows a chart (the EV / hot-water intro blocks) needs breathing room above */
.chart-fig + .lead{margin-top:60px}
/* live chart card (report theme) */
.chart-host{background:rgba(255,255,255,.035);border:1px solid var(--line);border-radius:18px;padding:26px 24px;margin-top:38px}
.chart-host .chart-title{font-family:var(--sans);font-size:1.15rem;font-weight:700;color:#fff;margin-bottom:4px}
.chart-host .chart-sub{font-size:13px;color:var(--ink-mute);margin-bottom:18px;max-width:70ch}
.chart-host .legend{display:flex;flex-wrap:wrap;gap:8px 18px;margin:0 0 18px;font-size:13px}
.chart-host .legend-item{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none;color:var(--ink-soft)}
.chart-host .legend-item[data-dim="true"]{opacity:.35}
.chart-host .swatch{width:12px;height:12px;border-radius:3px;flex-shrink:0}
/* static report-graph cards (white-background figures on the navy page) */
.eh-graph-card{background:#fff;border-radius:18px;padding:20px 22px;margin-top:38px;
  box-shadow:0 18px 44px rgba(0,0,0,.38);overflow:hidden}
.eh-graph-card img{display:block;width:100%;height:auto;border-radius:6px}
/* square/portrait pie figures: cap size + centre so they don't tower over the landscape charts */
.eh-graph-card.is-pie{max-width:520px;margin-left:auto;margin-right:auto}
/* globally hide the small reference/source caption under every chart */
.chart-fig .cap{display:none}
@media(max-width:600px){.eh-graph-card{padding:12px 12px}}
.chart-scroll{width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}
.chart-inner{min-width:480px;height:440px}
/* horizontal-scroll affordance: fade + swipe hint when a chart overflows */
.chart-scroll-wrap{position:relative}
.chart-scroll-fade{position:absolute;top:0;right:0;bottom:0;width:60px;pointer-events:none;z-index:3;
  background:linear-gradient(90deg,rgba(12,24,48,0),rgba(12,24,48,.96));
  display:flex;align-items:center;justify-content:flex-end;padding-right:8px;
  opacity:0;transition:opacity .25s ease}
.chart-scroll-fade svg{color:var(--gold);width:24px;height:24px;animation:nudge 1.4s ease-in-out infinite}
@keyframes nudge{0%,100%{transform:translateX(0)}50%{transform:translateX(5px)}}
.chart-scroll-wrap.is-overflow .chart-scroll-fade{opacity:1}
.chart-scroll-wrap.at-end .chart-scroll-fade{opacity:0}
@media(prefers-reduced-motion:reduce){.chart-scroll-fade svg{animation:none}}
.recharts-cartesian-axis-tick-value{font-family:'Rubik',sans-serif;font-size:12px}
@media(max-width:600px){.chart-inner{min-width:520px;height:380px}.chart-host{padding:18px 14px}}
.chart-ph{border:2px dashed rgba(245,183,49,.42);border-radius:16px;background:rgba(255,255,255,.025);
  padding:46px 30px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}
.chart-ph .ico{color:var(--gold)}
.chart-ph .ct{font-family:var(--serif);font-size:20px;font-weight:600;color:#fff;max-width:46ch}
.chart-ph .cs{font-size:13px;color:var(--ink-mute);max-width:60ch}
.chart-ph .badge{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#10203c;background:var(--gold);padding:5px 13px;border-radius:999px}
.chart-ph .data{margin-top:6px;width:100%;max-width:640px;text-align:left;white-space:pre-wrap;font-size:13px;line-height:1.65;
  color:var(--ink-soft);background:rgba(0,0,0,.22);border-radius:11px;padding:16px 18px;border:1px solid var(--line)}
.cap{margin-top:16px;text-align:center;font-size:14px;color:var(--ink-mute);max-width:72ch;margin-left:auto;margin-right:auto}

/* ── stat band ─────────────────────────── */
.stat-band{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:36px}
.stat{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:var(--squiggle);padding:28px 22px;text-align:center}
.stat:nth-child(1){transform:rotate(-1.4deg)}
.stat:nth-child(2){transform:rotate(1deg)}
.stat:nth-child(3){transform:rotate(-.8deg)}
.stat:nth-child(4){transform:rotate(1.2deg)}
.stat .v{font-family:var(--serif);font-size:clamp(30px,3.6vw,44px);font-weight:700;color:var(--gold);line-height:1}
.stat .c{font-size:13px;color:var(--ink-soft);margin-top:10px}
@media(max-width:780px){.stat-band{grid-template-columns:1fr 1fr}}

/* ── big-number bullets ────────────────── */
.facts{margin-top:30px;display:grid;gap:18px}
.fact{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;padding:22px 0;border-top:1px solid var(--line)}
.fact .n{font-family:var(--serif);font-style:italic;font-size:26px;color:var(--gold)}
.fact p{font-size:15.5px;color:var(--ink-soft)}

/* ── quote ─────────────────────────────── */
.quote{max-width:80ch;margin:0 auto;text-align:center}
.quote .mark{font-family:var(--serif);font-size:80px;line-height:.4;color:var(--gold);height:46px}
.quote blockquote{font-family:var(--serif);font-size:clamp(22px,2.8vw,32px);line-height:1.4;color:#fff;font-weight:500;margin:18px 0 22px}
.quote .who{font-size:14px;color:var(--ink-soft)}
.quote .who b{color:var(--gold)}

/* ── policy / barriers ─────────────────── */
.steps{display:grid;gap:18px;margin-top:38px}
.step{display:grid;grid-template-columns:64px 1fr;gap:24px;align-items:start;background:rgba(255,255,255,.03);
  border:1px solid var(--line);border-radius:16px;padding:28px 30px}
.step .num{font-family:var(--serif);font-size:30px;font-weight:700;color:var(--gold);line-height:1}
.step h3{font-size:18px;font-weight:600;color:#fff;margin-bottom:8px}
.step p{font-size:15px;color:var(--ink-soft)}
@media(max-width:600px){.step{grid-template-columns:1fr;gap:8px}}

/* ── change cards ──────────────────────── */
.change-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:38px}
.change{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:var(--squiggle);padding:30px 26px}
.change:nth-child(1){transform:rotate(-.8deg)}
.change:nth-child(2){transform:rotate(.6deg)}
.change:nth-child(3){transform:rotate(-.4deg)}
.change .k{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--gold);margin-bottom:12px}
.change h3{font-size:16px;font-weight:600;color:#fff;margin-bottom:10px}
.change p{font-size:14px;color:var(--ink-soft)}
@media(max-width:820px){.change-grid{grid-template-columns:1fr}}

/* ── final CTA + footer ────────────────── */
.final{text-align:center;padding:110px 0}
.final h2{font-family:var(--serif);font-size:clamp(30px,4.4vw,52px);font-weight:600;color:#fff;margin-bottom:18px}
.final p{color:var(--ink-soft);max-width:60ch;margin:0 auto 30px}
footer{border-top:1px solid var(--line);padding:40px 0;text-align:center;color:var(--ink-mute);font-size:13px}
footer .fw{font-weight:700;color:var(--gold);letter-spacing:.2px}
.pill-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}
.pill{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:var(--squiggle);font-size:14px;font-weight:600;text-decoration:none;border:2px dashed rgba(245,183,49,.55);color:var(--gold);background:transparent;transition:.2s}
.pill:hover{background:var(--gold);color:#10203c;border-style:solid}
.pill.solid{background:var(--gold);color:#10203c;border-color:var(--gold);border-style:solid}
.video-frame{margin-top:34px;aspect-ratio:16/9;border-radius:16px;overflow:hidden;border:4px solid var(--gold);background:#000;position:relative}
.video-frame iframe{width:100%;height:100%;border:0;display:block}
@media(max-width:780px){
  .opp-card,.stat,.change{transform:none!important}
  section.block{padding:72px 0}
  h2.h{max-width:100%}
}
