:root{
  --ink:#16130d;
  --ink-2:#22201a;
  --cream:#f6f1e4;
  --cream-2:#ece3cc;
  --paper:#fbf7ed;
  --slate:#4a4536;
  --ash:#8a8270;
  --rule:rgba(22,19,13,0.10);
  --amber:#e8a217;
  --amber-deep:#c78107;
  --amber-soft:rgba(232,162,23,0.14);
  --mint:#7ba87a;
  --forest:#2f4a2c;
  --ease:cubic-bezier(0.22,0.61,0.36,1);
  --spring:cubic-bezier(0.34,1.56,0.64,1);
  --display:'Fraunces',Georgia,serif;
  --body:'Source Sans 3',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  font-size:17px;
  line-height:1.6;
  overflow-x:hidden;
}
img,video,svg{max-width:100%;display:block;}
a{color:inherit;}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;letter-spacing:-0.02em;line-height:1.08;margin:0;}
p{margin:0;}

.container{max-width:1200px;margin:0 auto;padding:0 1.5rem;}
.eyebrow{
  font-family:var(--mono);
  font-size:0.72rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--amber-deep);
  display:inline-flex;align-items:center;gap:0.55rem;
}
.eyebrow::before{
  content:"";
  width:22px;height:1px;background:var(--amber-deep);
}
.eyebrow.is-light{color:var(--amber);}
.eyebrow.is-light::before{background:var(--amber);}

/* -------- Scroll reveal -------- */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity 800ms var(--ease),transform 800ms var(--ease);}
[data-reveal].is-visible{opacity:1;transform:none;}
[data-reveal-delay="1"]{transition-delay:80ms;}
[data-reveal-delay="2"]{transition-delay:160ms;}
[data-reveal-delay="3"]{transition-delay:240ms;}
[data-reveal-delay="4"]{transition-delay:320ms;}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1!important;transform:none!important;}
}

/* -------- Header -------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:color-mix(in oklab,var(--paper) 94%,transparent);
  backdrop-filter:saturate(1.4) blur(14px);
  -webkit-backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid var(--rule);
}
.nav-shell{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 0;gap:1.25rem;flex-wrap:nowrap;}
.brand{display:inline-flex;align-items:center;gap:0.7rem;text-decoration:none;color:var(--ink);flex:0 0 auto;min-width:0;}
.brand-mark{width:38px;height:38px;border-radius:10px;overflow:hidden;display:block;flex:0 0 auto;}
.brand-mark img{width:100%;height:100%;object-fit:cover;}
.brand > span:not(.brand-mark){display:flex;flex-direction:column;white-space:nowrap;flex:0 0 auto;}
.brand-name{font-family:var(--display);font-weight:700;font-size:1.02rem;line-height:1.1;white-space:nowrap;letter-spacing:-0.01em;}
.brand-sub{font-family:var(--mono);font-size:0.66rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--ash);display:block;margin-top:3px;white-space:nowrap;}
.nav-links{display:flex;gap:0.1rem;list-style:none;margin:0;padding:0;align-items:center;flex-wrap:nowrap;}
.nav-links li{flex:0 0 auto;}
.nav-links > li > a{padding:0.55rem 0.8rem;border-radius:8px;text-decoration:none;color:var(--slate);font-weight:500;font-size:0.92rem;white-space:nowrap;transition:color 180ms var(--ease),background 180ms var(--ease);display:inline-block;}
.nav-links > li > a:hover{color:var(--ink);background:rgba(22,19,13,0.04);}
.nav-links > li > a.is-active{color:var(--ink);background:rgba(22,19,13,0.06);font-weight:600;}
.nav-links > li > a.nav-cta{
  display:inline-flex;align-items:center;gap:0.45rem;
  padding:0.65rem 1.1rem;
  background:var(--ink);color:#fff;
  border-radius:999px;font-weight:600;font-size:0.9rem;
  text-decoration:none;white-space:nowrap;
  transition:background 180ms var(--ease),color 180ms,transform 180ms var(--spring),box-shadow 180ms;
}
.nav-links > li > a.nav-cta:hover{background:var(--amber);color:var(--ink);transform:translateY(-1px);box-shadow:0 10px 22px rgba(232,162,23,0.28);}
.nav-cta svg{stroke:currentColor;}
@media(max-width:1180px){
  .nav-links{gap:0;}
  .nav-links > li > a{padding:0.5rem 0.6rem;font-size:0.88rem;}
  .nav-links > li > a.nav-cta{padding:0.6rem 0.95rem;font-size:0.85rem;}
  .brand-sub{display:none;}
}
@media(max-width:1000px) and (min-width:901px){
  .nav-links > li > a{padding:0.45rem 0.5rem;font-size:0.83rem;}
}
.nav-toggle{display:none;width:44px;height:44px;border:1px solid var(--rule);border-radius:10px;background:transparent;position:relative;cursor:pointer;}
.nav-toggle span{position:absolute;left:10px;right:10px;height:2px;background:var(--ink);transition:all 240ms var(--ease);}
.nav-toggle span:nth-child(1){top:14px;}
.nav-toggle span:nth-child(2){top:21px;}
.nav-toggle span:nth-child(3){top:28px;}
.nav-toggle[aria-expanded="true"] span:nth-child(1){top:21px;transform:rotate(45deg);}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.nav-toggle[aria-expanded="true"] span:nth-child(3){top:21px;transform:rotate(-45deg);}
@media(max-width:900px){
  .nav-toggle{display:inline-block;}
  .nav-links{
    position:fixed;inset:64px 0 0;
    flex-direction:column;gap:0;padding:1.5rem;
    background:var(--paper);
    transform:translateX(100%);opacity:0;pointer-events:none;
    transition:transform 280ms var(--ease),opacity 200ms;
    border-top:1px solid var(--rule);
    align-items:stretch;
  }
  .nav-links.is-open{transform:none;opacity:1;pointer-events:auto;}
  .nav-links li{width:100%;}
  .nav-links > li > a{display:block;padding:1rem;font-size:1.1rem;border-radius:12px;}
  .nav-links > li > a.nav-cta{width:100%;justify-content:center;margin-top:0.5rem;padding:1rem;}
}

/* -------- HERO -------- */
.hero{
  position:relative;
  min-height:min(92vh,880px);
  display:grid;align-items:end;
  color:#fff;isolation:isolate;overflow:hidden;
  background:var(--ink);
}
.hero-bg{position:absolute;inset:0;z-index:0;}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 45%;
  animation:kenburns 22s var(--ease) both;}
@keyframes kenburns{from{transform:scale(1.08) translateY(-1%);}to{transform:scale(1) translateY(0);}}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(105deg,rgba(11,9,6,0.60) 0%,rgba(11,9,6,0.38) 35%,rgba(11,9,6,0.12) 65%,rgba(11,9,6,0.02) 100%),
    linear-gradient(180deg,rgba(11,9,6,0.15) 0%,rgba(11,9,6,0.30) 40%,rgba(11,9,6,0.72) 100%);
}
.hero-grain{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:0.07;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/><feColorMatrix values='0 0 0 0 0.9 0 0 0 0 0.8 0 0 0 0 0.6 0 0 0 1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");}
.hero-content{position:relative;z-index:2;padding:clamp(5rem,12vw,9rem) 0 clamp(3rem,6vw,5.5rem);max-width:720px;}
.hero h1{
  font-size:clamp(2.6rem,6.4vw,5.2rem);
  font-weight:700;
  letter-spacing:-0.03em;
  line-height:1.04;
  margin:1.25rem 0 1.75rem;
  color:#fff;
  max-width:14ch;
}
.hero h1 em{font-style:italic;font-weight:500;color:var(--amber);display:block;line-height:1.15;padding-top:0.1em;}
.hero h1 .slant{font-style:italic;font-weight:500;}
.hero-lede{
  font-size:clamp(1.1rem,1.8vw,1.45rem);
  line-height:1.5;
  color:rgba(255,255,255,0.82);
  max-width:640px;
  margin-bottom:2.25rem;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:0.9rem;align-items:center;}
.btn{
  display:inline-flex;align-items:center;gap:0.55rem;
  padding:1.05rem 1.6rem;border-radius:999px;font-weight:600;
  text-decoration:none;font-size:1rem;white-space:nowrap;
  transition:transform 180ms var(--spring),background 180ms var(--ease),box-shadow 180ms var(--ease),color 180ms;
  cursor:pointer;border:0;font-family:inherit;
}
.btn-primary{background:var(--amber);color:var(--ink);box-shadow:0 14px 32px rgba(232,162,23,0.38);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 22px 42px rgba(232,162,23,0.5);background:#f5b337;}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,0.35);}
.btn-ghost:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.6);transform:translateY(-2px);}
.btn-dark{background:var(--ink);color:var(--paper);}
.btn-dark:hover{background:var(--amber);color:var(--ink);transform:translateY(-2px);}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--ink);}
.btn-outline:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px);}
.btn svg{transition:transform 240ms var(--ease);}
.btn:hover svg{transform:translateX(4px);}

.hero-meta{
  position:absolute;bottom:1.5rem;right:1.5rem;z-index:2;
  font-family:var(--mono);font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(255,255,255,0.55);
}
.hero-corner{
  position:absolute;bottom:0;left:0;z-index:2;
  padding:0 1.5rem 1.5rem;
  font-family:var(--mono);font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(255,255,255,0.5);
}

/* -------- Outcome band (sticky after hero) -------- */
.outcome-band{
  background:var(--ink);color:var(--paper);
  border-top:1px solid rgba(255,255,255,0.05);
  overflow:hidden;
}
.marquee{
  display:flex;gap:4rem;padding:1.25rem 0;
  white-space:nowrap;
  font-family:var(--display);font-style:italic;font-weight:500;font-size:clamp(1.05rem,1.6vw,1.4rem);
  color:rgba(255,255,255,0.75);
  animation:marquee 38s linear infinite;
  will-change:transform;
}
.marquee span{display:inline-flex;align-items:center;gap:2rem;}
.marquee .dot{width:6px;height:6px;border-radius:50%;background:var(--amber);flex:0 0 auto;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media (prefers-reduced-motion:reduce){.marquee{animation:none;}}

/* -------- Section scaffolding -------- */
.section{padding:clamp(4rem,8vw,8rem) 0;}
.section-cream{background:var(--cream);}
.section-paper{background:var(--paper);}
.section-ink{background:var(--ink);color:var(--paper);}
.section-ink h2,.section-ink h3{color:#fff;}
.section-ink p{color:rgba(255,255,255,0.78);}

.h-display{
  font-size:clamp(2.25rem,4.4vw,3.8rem);
  letter-spacing:-0.025em;line-height:1.05;
}
.h-display em{font-style:italic;font-weight:500;color:var(--amber-deep);}
.section-ink .h-display em{color:var(--amber);}
.h-section{font-size:clamp(1.6rem,2.6vw,2.4rem);}
.lede{font-size:clamp(1.1rem,1.5vw,1.3rem);line-height:1.55;color:var(--slate);max-width:680px;}
.section-ink .lede{color:rgba(255,255,255,0.82);}

/* -------- The Feeling (scene quotes) -------- */
.scene-list{display:grid;grid-template-columns:1fr;gap:0;margin-top:3rem;border-top:1px solid var(--rule);}
.scene{
  display:grid;grid-template-columns:180px 1fr auto;align-items:center;gap:2rem;
  padding:2rem 0;border-bottom:1px solid var(--rule);
  transition:padding 320ms var(--ease);
}
.scene:hover{padding-left:1rem;padding-right:1rem;background:rgba(232,162,23,0.04);}
.scene-time{
  font-family:var(--mono);font-size:0.78rem;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--ash);
}
.scene-line{
  font-family:var(--display);font-weight:500;font-style:italic;
  font-size:clamp(1.4rem,2.4vw,2rem);line-height:1.2;color:var(--ink);
  letter-spacing:-0.015em;
}
.scene-line strong{font-style:normal;font-weight:700;color:var(--amber-deep);}
.scene-tag{font-family:var(--mono);font-size:0.72rem;color:var(--ash);letter-spacing:0.1em;text-transform:uppercase;white-space:nowrap;}
@media(max-width:820px){
  .scene{grid-template-columns:1fr;gap:0.6rem;padding:1.5rem 0;}
  .scene-tag{order:3;}
}

/* -------- Outcomes grid -------- */
.outcomes{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:3.5rem;
}
.outcome-card{
  position:relative;
  padding:2rem 1.75rem 1.75rem;
  background:var(--paper);border:1px solid var(--rule);
  border-radius:20px;
  overflow:hidden;
  display:flex;flex-direction:column;gap:0.75rem;
  min-height:300px;
  transition:transform 320ms var(--ease),box-shadow 320ms var(--ease),border-color 320ms;
}
.outcome-card:hover{transform:translateY(-4px);box-shadow:0 24px 48px rgba(22,19,13,0.08);border-color:rgba(232,162,23,0.4);}
.outcome-card .num{font-family:var(--mono);font-size:0.72rem;letter-spacing:0.14em;color:var(--ash);}
.outcome-card h3{font-size:1.5rem;line-height:1.15;letter-spacing:-0.02em;}
.outcome-card h3 em{font-style:italic;font-weight:500;color:var(--amber-deep);}
.outcome-card p{color:var(--slate);font-size:0.98rem;line-height:1.55;}
.outcome-card .tag{margin-top:auto;padding-top:0.5rem;font-family:var(--mono);font-size:0.7rem;letter-spacing:0.12em;color:var(--ash);text-transform:uppercase;}
.outcome-card.is-ink{background:var(--ink);color:var(--paper);border-color:transparent;}
.outcome-card.is-ink h3{color:#fff;}
.outcome-card.is-ink h3 em{color:var(--amber);}
.outcome-card.is-ink p{color:rgba(255,255,255,0.78);}
.outcome-card.is-ink .num,.outcome-card.is-ink .tag{color:rgba(255,255,255,0.5);}

.outcome-svg{display:none;}

@media(max-width:900px){
  .outcomes{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:600px){
  .outcomes{grid-template-columns:1fr;}
  .outcome-card{min-height:0;}
}

/* -------- Battery install images (custom) -------- */
.battery-install-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin:3rem 0;
}
.battery-install-item{
  border-radius:20px;overflow:hidden;aspect-ratio:4/3;background:var(--cream-2);
  border:1px solid var(--rule);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);color:var(--ash);font-size:0.9rem;
  transition:transform 320ms var(--ease);
}
.battery-install-item:hover{transform:translateY(-4px);}
.battery-install-item img{width:100%;height:100%;object-fit:cover;}
@media(max-width:820px){
  .battery-install-grid{grid-template-columns:1fr;}
}

/* -------- Before / After ledger -------- */
.ledger{
  display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:3rem;
  border:1px solid var(--rule);border-radius:22px;overflow:hidden;
  background:var(--paper);
}
.ledger-col{padding:2.5rem;display:flex;flex-direction:column;gap:1.25rem;}
.ledger-col.before{background:var(--cream-2);}
.ledger-col.after{background:var(--ink);color:var(--paper);position:relative;}
.ledger-col h3{font-size:1.6rem;display:flex;align-items:center;gap:0.6rem;}
.ledger-col.after h3{color:#fff;}
.ledger-col .meta{font-family:var(--mono);font-size:0.72rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--ash);}
.ledger-col.after .meta{color:rgba(255,255,255,0.55);}
.ledger-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0.75rem;}
.ledger-list li{display:flex;gap:0.75rem;align-items:flex-start;padding:0.85rem 0;border-bottom:1px solid rgba(22,19,13,0.08);font-size:1.02rem;}
.ledger-col.after .ledger-list li{border-bottom-color:rgba(255,255,255,0.08);}
.ledger-list li:last-child{border:0;}
.ledger-glyph{
  flex:0 0 auto;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--mono);font-size:0.8rem;font-weight:700;
}
.ledger-col.before .ledger-glyph{background:rgba(22,19,13,0.08);color:var(--slate);}
.ledger-col.after .ledger-glyph{background:var(--amber);color:var(--ink);}
@media(max-width:760px){
  .ledger{grid-template-columns:1fr;}
}

/* -------- Stories -------- */
.stories{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem;}
.story{
  padding:2rem;background:var(--paper);border-radius:20px;border:1px solid var(--rule);
  display:flex;flex-direction:column;gap:1.25rem;
  transition:transform 320ms var(--ease),box-shadow 320ms var(--ease);
}
.story:hover{transform:translateY(-4px);box-shadow:0 20px 44px rgba(22,19,13,0.08);}
.story-quote{font-family:var(--display);font-weight:500;font-style:italic;font-size:1.35rem;line-height:1.3;color:var(--ink);letter-spacing:-0.015em;}
.story-quote::before{content:"\201C";color:var(--amber);font-size:2.4rem;line-height:0.4;display:inline-block;vertical-align:-0.35em;margin-right:0.15em;}
.story-meta{display:flex;align-items:center;gap:0.8rem;margin-top:auto;padding-top:1rem;border-top:1px solid var(--rule);}
.story-av{width:42px;height:42px;border-radius:50%;background:var(--amber);display:grid;place-items:center;font-family:var(--mono);font-weight:700;color:var(--ink);font-size:0.92rem;flex:0 0 auto;}
.story-who{display:flex;flex-direction:column;line-height:1.25;}
.story-who strong{font-weight:700;font-size:0.98rem;}
.story-who span{font-family:var(--mono);font-size:0.72rem;letter-spacing:0.08em;color:var(--ash);text-transform:uppercase;margin-top:3px;}
@media(max-width:900px){.stories{grid-template-columns:1fr;}}

/* -------- Who it's for -------- */
.personas{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:3rem;}
.persona{
  position:relative;padding:2rem;border-radius:22px;overflow:hidden;color:#fff;
  min-height:380px;
  display:flex;flex-direction:column;justify-content:flex-end;gap:0.8rem;
  isolation:isolate;
  transition:transform 320ms var(--ease);
}
.persona:hover{transform:translateY(-4px);}
.persona .bg{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center;}
.persona::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(11,9,6,0.15) 0%,rgba(11,9,6,0.85) 100%);
}
.persona h3{font-size:1.7rem;color:#fff;}
.persona h3 em{font-style:italic;font-weight:500;color:var(--amber);}
.persona p{color:rgba(255,255,255,0.86);font-size:0.98rem;}
.persona .pill{
  position:absolute;top:1.25rem;left:1.25rem;
  font-family:var(--mono);font-size:0.7rem;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--amber);
  padding:0.35rem 0.7rem;border:1px solid rgba(232,162,23,0.5);background:rgba(232,162,23,0.12);
  border-radius:999px;backdrop-filter:blur(6px);
}
@media(max-width:900px){.personas{grid-template-columns:1fr;}}
.persona .bg-illo{display:block;inset:0;position:absolute;z-index:-2;background:var(--cream-2);}
.persona .bg-illo img{width:100%;height:100%;object-fit:cover;}

/* -------- Process (How) -------- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:3rem;border-top:1px solid rgba(255,255,255,0.12);}
.process-step{
  padding:2.25rem 1.5rem;border-right:1px solid rgba(255,255,255,0.12);border-bottom:1px solid rgba(255,255,255,0.12);
  display:flex;flex-direction:column;gap:0.8rem;
  position:relative;
  transition:background 240ms var(--ease);
}
.process-step:hover{background:rgba(232,162,23,0.06);}
.process-step:last-child{border-right:0;}
.process-num{font-family:var(--mono);font-size:0.78rem;letter-spacing:0.2em;color:var(--amber);}
.process-step h3{font-size:1.3rem;color:#fff;letter-spacing:-0.015em;}
.process-step p{color:rgba(255,255,255,0.72);font-size:0.98rem;}
@media(max-width:900px){
  .process{grid-template-columns:1fr;}
  .process-step{border-right:0;}
}

/* -------- Safety block -------- */
.safety{
  display:grid;grid-template-columns:6fr 5fr;gap:3rem;align-items:center;
}
.safety-media{
  aspect-ratio:3/4;border-radius:22px;overflow:hidden;position:relative;background:var(--ink);
}
.safety-media img{width:100%;height:100%;object-fit:cover;}
.safety-media .overlay{
  position:absolute;inset:auto 0 0;padding:1.25rem;background:linear-gradient(180deg,transparent,rgba(11,9,6,0.88));
  color:#fff;font-family:var(--mono);font-size:0.8rem;letter-spacing:0.1em;
}
.safety-list{list-style:none;padding:0;margin:1.75rem 0 0;display:flex;flex-direction:column;gap:0.6rem;}
.trust-copy .eyebrow{display:inline-flex;}
.safety-list li{display:flex;gap:0.85rem;align-items:flex-start;padding:1rem 0;border-bottom:1px solid var(--rule);font-size:1rem;}
.safety-list li:last-child{border:0;}
.safety-check{
  flex:0 0 auto;width:26px;height:26px;border-radius:50%;
  background:var(--amber);color:var(--ink);
  display:grid;place-items:center;
}
.safety-check svg{width:14px;height:14px;}
.safety-list strong{display:block;font-size:1.05rem;margin-bottom:2px;letter-spacing:-0.01em;}
.safety-list span{color:var(--slate);font-size:0.95rem;line-height:1.45;}
@media(max-width:900px){
  .safety{grid-template-columns:1fr;gap:2rem;}
}

/* -------- FAQ -------- */
.faq{max-width:820px;margin:3rem auto 0;}
.faq-item{border-bottom:1px solid var(--rule);}
.faq-summary{
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1.35rem 0;cursor:pointer;font-family:var(--display);font-weight:600;font-size:1.2rem;letter-spacing:-0.015em;
}
.faq-summary::-webkit-details-marker{display:none;}
.faq-icon{
  width:30px;height:30px;border-radius:50%;background:var(--cream-2);flex:0 0 auto;
  display:grid;place-items:center;position:relative;transition:background 240ms var(--ease),transform 240ms var(--spring);
}
.faq-icon::before,.faq-icon::after{content:"";position:absolute;background:var(--ink);}
.faq-icon::before{width:12px;height:2px;}
.faq-icon::after{width:2px;height:12px;transition:transform 240ms var(--ease);}
.faq-item[open] .faq-icon{background:var(--amber);transform:rotate(90deg);}
.faq-item[open] .faq-icon::after{transform:scaleY(0);}
.faq-body{padding:0 0 1.5rem;color:var(--slate);font-size:1.02rem;line-height:1.6;max-width:720px;}

/* -------- Closing CTA -------- */
.closing{
  position:relative;overflow:hidden;
  background:var(--ink);color:var(--paper);
  padding:clamp(4rem,8vw,7rem) 0;
}
.closing::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 82% 20%,rgba(232,162,23,0.22),transparent 40%),
    radial-gradient(circle at 10% 90%,rgba(232,162,23,0.12),transparent 45%);
  pointer-events:none;
}
.closing .wrap{position:relative;display:grid;grid-template-columns:6fr 5fr;gap:3rem;align-items:center;}
.closing h2{font-size:clamp(2.4rem,5vw,4.5rem);line-height:0.98;letter-spacing:-0.03em;color:#fff;}
.closing h2 em{font-style:italic;font-weight:500;color:var(--amber);}
.closing p{color:rgba(255,255,255,0.78);font-size:1.15rem;max-width:460px;margin-top:1.25rem;}
.closing-actions{display:flex;flex-wrap:wrap;gap:0.9rem;margin-top:2rem;}
.closing-card{
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.14);
  border-radius:22px;padding:2rem;backdrop-filter:blur(8px);
  font-family:var(--mono);
}
.closing-card .row{display:flex;justify-content:space-between;padding:0.7rem 0;border-bottom:1px solid rgba(255,255,255,0.1);font-size:0.9rem;}
.closing-card .row:last-child{border:0;}
.closing-card .row span:first-child{color:rgba(255,255,255,0.55);letter-spacing:0.08em;text-transform:uppercase;font-size:0.72rem;}
.closing-card .row span:last-child{color:#fff;text-align:right;font-weight:700;}
.closing-card .row.big span:last-child{color:var(--amber);font-size:1rem;}
@media(max-width:900px){.closing .wrap{grid-template-columns:1fr;}}

/* -------- Footer -------- */
.site-footer{background:var(--paper);border-top:1px solid var(--rule);padding:3.5rem 0 2rem;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;}
.footer-grid h4{font-size:0.78rem;font-family:var(--mono);text-transform:uppercase;letter-spacing:0.16em;color:var(--ash);font-weight:600;margin-bottom:0.9rem;}
.footer-grid ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0.55rem;}
.footer-grid a{color:var(--slate);text-decoration:none;font-size:0.95rem;transition:color 180ms;}
.footer-grid a:hover{color:var(--amber-deep);}
.footer-brand p{color:var(--slate);font-size:0.95rem;max-width:340px;margin-top:0.75rem;}
.footer-bottom{
  margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--rule);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  font-family:var(--mono);font-size:0.75rem;color:var(--ash);letter-spacing:0.06em;
}
@media(max-width:720px){.footer-grid{grid-template-columns:1fr 1fr;}}

/* -------- Section header (centered by default) -------- */
.section-header{max-width:760px;margin:0 auto;text-align:center;}
.section-header .lede{margin-left:auto;margin-right:auto;}
.section-header > *+*{margin-top:1.1rem;}
.section-header.left{margin-left:0;margin-right:auto;text-align:left;}
.section-header.left .lede{margin-left:0;margin-right:0;}

/* -------- Small util -------- */
.mt-4{margin-top:1rem;}.mt-5{margin-top:1.5rem;}.mt-6{margin-top:2rem;}
.text-center{text-align:center;}


/* ===================================================== */
/*  SUBPAGE STYLES                                       */
/* ===================================================== */

/* -------- Page hero (non-home) -------- */
.page-hero{
  position:relative;
  padding:clamp(5rem,10vw,8rem) 0 clamp(3rem,6vw,5rem);
  background:var(--ink);color:#fff;isolation:isolate;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(circle at 85% 10%,rgba(232,162,23,0.22),transparent 45%),
    radial-gradient(circle at 10% 80%,rgba(232,162,23,0.10),transparent 50%),
    linear-gradient(180deg,#1a1610 0%,var(--ink) 100%);
}
.page-hero::after{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:0.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/><feColorMatrix values='0 0 0 0 0.9 0 0 0 0 0.8 0 0 0 0 0.6 0 0 0 1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
.page-hero .eyebrow{color:var(--amber);}
.page-hero .eyebrow::before{background:var(--amber);}
.page-hero h1{
  font-size:clamp(2.4rem,5.5vw,4.4rem);
  letter-spacing:-0.025em;line-height:1.02;
  margin:1rem 0 1.25rem;color:#fff;
  max-width:14ch;
}
.page-hero h1 em{font-style:italic;font-weight:500;color:var(--amber);}
.page-hero .lead{
  font-size:clamp(1.1rem,1.6vw,1.35rem);line-height:1.5;
  color:rgba(255,255,255,0.82);max-width:56ch;
}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,0.9fr);gap:3rem;align-items:end;}
.hero-aside{margin:0;border-radius:24px;overflow:hidden;aspect-ratio:4/3;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);}
.hero-aside img{width:100%;height:100%;object-fit:cover;display:block;}
.hero-aside img[src$=".svg"]{object-fit:cover;background:#16130d;}
@media(max-width:820px){.hero-grid{grid-template-columns:1fr;gap:2rem;}.hero-aside{aspect-ratio:16/10;}}

/* -------- Breadcrumb -------- */
.breadcrumb{font-family:var(--mono);font-size:0.72rem;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.5);margin-bottom:0.5rem;}
.breadcrumb ol{list-style:none;display:flex;gap:0.5rem;margin:0;padding:0;flex-wrap:wrap;}
.breadcrumb li+li::before{content:"/";margin-right:0.5rem;color:rgba(255,255,255,0.3);}
.breadcrumb a{color:rgba(255,255,255,0.7);text-decoration:none;border-bottom:1px solid rgba(255,255,255,0.15);padding-bottom:1px;transition:color 180ms;}
.breadcrumb a:hover{color:var(--amber);}

/* -------- Prose blocks -------- */
.prose{max-width:70ch;margin:0 auto;font-size:1.08rem;line-height:1.68;color:var(--slate);}
.prose p{margin-bottom:1.2rem;}
.prose p:last-child{margin-bottom:0;}
.prose strong{color:var(--ink);font-weight:600;}
.prose a{color:var(--amber-deep);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;}
.prose h2,.prose h3{color:var(--ink);margin:2rem 0 1rem;}
.prose h3{font-size:1.4rem;}
.prose ul{padding-left:1.25rem;margin:1rem 0;}
.prose li{margin-bottom:0.4rem;}
.section-ink .prose{color:rgba(255,255,255,0.82);}
.section-ink .prose strong{color:#fff;}

/* -------- Pull quote / lede big -------- */
.lede-big{
  font-family:var(--display);font-weight:500;font-style:italic;
  font-size:clamp(1.4rem,2.4vw,1.9rem);line-height:1.35;letter-spacing:-0.015em;
  color:var(--ink);max-width:42ch;margin:0 auto;text-align:center;
}
.lede-big em{font-style:normal;font-weight:700;color:var(--amber-deep);}

/* -------- Director card -------- */
.director{
  display:grid;grid-template-columns:1fr 1.4fr;gap:3rem;align-items:center;
  background:var(--paper);border:1px solid var(--rule);border-radius:24px;
  padding:2.5rem;
}
.director .portrait{
  aspect-ratio:1;border-radius:20px;overflow:hidden;background:var(--ink);
  display:grid;place-items:center;font-family:var(--display);font-style:italic;font-weight:500;
  color:var(--amber);font-size:4rem;letter-spacing:-0.03em;
  position:relative;
}
.director .portrait img{width:100%;height:100%;object-fit:cover;display:block;}
.director .portrait-caption{
  position:absolute;bottom:0;left:0;right:0;
  padding:0.75rem 1rem;
  background:linear-gradient(180deg,transparent,rgba(11,9,6,0.85));
  font-family:var(--mono);font-size:0.68rem;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(255,255,255,0.85);
}
.director .creds{font-family:var(--mono);font-size:0.72rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--amber-deep);}
.director h3{font-size:2rem;letter-spacing:-0.02em;margin:0.6rem 0 1rem;}
.director p{color:var(--slate);font-size:1.02rem;line-height:1.6;margin-bottom:0.9rem;}
.director p:last-child{margin-bottom:0;}
@media(max-width:820px){.director{grid-template-columns:1fr;padding:1.75rem;}}

/* -------- Spec grid (our-tech) -------- */
.spec-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:3rem;
}
.spec-card{
  background:var(--paper);border:1px solid var(--rule);border-radius:20px;
  padding:1.75rem;display:flex;flex-direction:column;gap:0.6rem;
  transition:border-color 240ms,transform 240ms var(--ease);
}
.spec-card:hover{border-color:rgba(232,162,23,0.45);transform:translateY(-3px);}
.spec-card .label{font-family:var(--mono);font-size:0.72rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--amber-deep);}
.spec-card h3{font-size:1.3rem;letter-spacing:-0.015em;}
.spec-card p{color:var(--slate);font-size:0.98rem;line-height:1.55;}
@media(max-width:720px){.spec-grid{grid-template-columns:1fr;}}

/* -------- Pillars (3-col numbered, used on tech + about) -------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:3rem;}
.pillar{
  padding:2rem 1.75rem;background:var(--paper);border:1px solid var(--rule);border-radius:20px;
  display:flex;flex-direction:column;gap:0.8rem;
  transition:transform 240ms var(--ease),box-shadow 240ms var(--ease);
}
.pillar:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(22,19,13,0.06);}
.pillar .n{font-family:var(--display);font-style:italic;font-weight:500;font-size:3rem;line-height:1;color:var(--amber);}
.pillar h3{font-size:1.3rem;letter-spacing:-0.015em;}
.pillar p{color:var(--slate);font-size:0.98rem;line-height:1.55;}
@media(max-width:820px){.pillars{grid-template-columns:1fr;}}

/* -------- Assessment tiers -------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:3rem;}
.tier{
  background:var(--paper);border:1px solid var(--rule);border-radius:20px;padding:2rem;
  display:flex;flex-direction:column;gap:1rem;
}
.tier .badge{
  align-self:flex-start;font-family:var(--mono);font-size:0.72rem;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--ink);background:var(--amber);padding:0.35rem 0.7rem;border-radius:999px;
}
.tier h3{font-size:1.35rem;letter-spacing:-0.015em;}
.tier p{color:var(--slate);font-size:0.98rem;line-height:1.5;}
.tier ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0.5rem;}
.tier ul li{font-size:0.95rem;padding-left:1.2rem;position:relative;color:var(--slate);}
.tier ul li::before{content:"";position:absolute;left:0;top:0.62em;width:7px;height:7px;border-radius:50%;background:var(--amber);}
@media(max-width:820px){.tiers{grid-template-columns:1fr;}}

/* -------- Battery cards -------- */
.battery-grid{display:flex;flex-direction:column;gap:2rem;margin-top:3rem;}
.battery-card{
  display:grid;grid-template-columns:1.2fr 1fr;gap:0;
  background:var(--paper);border:1px solid var(--rule);border-radius:24px;overflow:hidden;
  transition:transform 320ms var(--ease),box-shadow 320ms var(--ease),border-color 320ms;
}
.battery-card:hover{transform:translateY(-4px);box-shadow:0 30px 60px rgba(22,19,13,0.1);border-color:rgba(232,162,23,0.4);}
.battery-card.is-featured{border-color:rgba(232,162,23,0.5);box-shadow:0 14px 36px rgba(232,162,23,0.08);}
.battery-card.is-featured::before{content:"⚡ Complete bundle";position:absolute;}
.battery-media{position:relative;background:var(--cream-2);overflow:hidden;min-height:360px;}
.battery-media img{width:100%;height:100%;object-fit:cover;}
.battery-media .tag{
  position:absolute;top:1.25rem;left:1.25rem;
  font-family:var(--mono);font-size:0.7rem;letter-spacing:0.14em;text-transform:uppercase;
  background:rgba(22,19,13,0.85);color:var(--amber);padding:0.4rem 0.8rem;border-radius:999px;backdrop-filter:blur(6px);
  white-space:nowrap;
}
.battery-body{padding:2.25rem;display:flex;flex-direction:column;gap:1rem;}
.battery-kicker{font-family:var(--mono);font-size:0.72rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--ash);}
.battery-name{font-size:clamp(2rem,3vw,2.6rem);letter-spacing:-0.02em;line-height:1;}
.battery-name em{font-style:italic;font-weight:500;color:var(--amber-deep);}
.battery-specs{display:grid;grid-template-columns:auto 1fr;gap:0.4rem 1.2rem;margin:0;padding:1rem 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);font-size:0.95rem;}
.battery-specs dt{font-family:var(--mono);font-size:0.7rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--ash);align-self:center;white-space:nowrap;}
.battery-specs dd{margin:0;font-weight:600;color:var(--ink);}
.health-score{display:flex;flex-direction:column;gap:0.4rem;}
.health-score-header{display:flex;justify-content:space-between;font-size:0.85rem;}
.health-score-label{font-family:var(--mono);font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--ash);white-space:nowrap;}
.health-score-value{font-family:var(--display);font-weight:700;color:var(--ink);}
.health-score-bar{height:6px;background:var(--cream-2);border-radius:999px;overflow:hidden;}
.health-score-fill{height:100%;background:linear-gradient(90deg,var(--amber),var(--amber-deep));border-radius:999px;transition:width 1200ms var(--ease);}
.battery-price{font-family:var(--display);font-weight:700;font-size:2rem;letter-spacing:-0.02em;margin:0;color:var(--ink);line-height:1;}
.battery-price .suffix{font-size:0.9rem;color:var(--ash);font-family:var(--mono);font-weight:500;letter-spacing:0.08em;margin-left:0.5rem;}
.battery-blurb{color:var(--slate);font-size:0.98rem;line-height:1.55;}
.battery-actions{display:flex;flex-wrap:wrap;gap:0.7rem;margin-top:auto;padding-top:0.5rem;}
.chip-row{display:flex;flex-wrap:wrap;gap:0.4rem;}
.chip{
  font-family:var(--mono);font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;
  padding:0.35rem 0.7rem;background:var(--cream-2);border-radius:999px;color:var(--slate);
}
@media(max-width:820px){
  .battery-card{grid-template-columns:1fr;}
  .battery-media{min-height:260px;aspect-ratio:16/10;}
}

/* -------- Stock notice -------- */
.stock-notice{
  display:inline-flex;align-items:center;gap:0.75rem;
  background:rgba(123,168,122,0.14);color:var(--forest);
  padding:0.85rem 1.25rem;border-radius:999px;
  font-size:0.92rem;border:1px solid rgba(123,168,122,0.3);
  white-space:nowrap;max-width:100%;
}
@media(max-width:540px){
  .stock-notice{white-space:normal;text-align:left;border-radius:16px;}
}
.stock-notice .pulse{
  width:10px;height:10px;border-radius:50%;background:var(--mint);
  box-shadow:0 0 0 4px rgba(123,168,122,0.25);
  animation:pulse 1.8s ease-in-out infinite;
}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(123,168,122,0.15);}50%{box-shadow:0 0 0 7px rgba(123,168,122,0.05);}}

/* -------- Checklist -------- */
.checklist{
  max-width:780px;margin:0 auto;
  background:var(--paper);border:1px solid var(--rule);border-radius:24px;
  padding:clamp(1.5rem,3vw,2.5rem);
}
.checklist-progress-label{
  display:flex;justify-content:space-between;margin-bottom:0.75rem;
  font-family:var(--mono);font-size:0.78rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--ash);
}
.checklist-progress-label strong{color:var(--amber-deep);font-family:var(--display);font-style:italic;font-size:1rem;letter-spacing:-0.01em;}
.checklist-bar{height:8px;background:var(--cream-2);border-radius:999px;overflow:hidden;margin-bottom:2rem;}
.checklist-bar-fill{height:100%;background:linear-gradient(90deg,var(--amber),var(--amber-deep));width:0%;transition:width 500ms var(--ease);border-radius:999px;}
.checklist-item{
  border-bottom:1px solid var(--rule);
  transition:background 240ms var(--ease);
}
.checklist-item:last-of-type{border-bottom:0;}
.checklist-item.is-checked{background:rgba(232,162,23,0.04);}
.checklist-item-header{
  display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:center;
  padding:1.25rem 0.5rem;cursor:pointer;user-select:none;
}
.checklist-checkbox{
  flex:0 0 auto;width:26px;height:26px;border:2px solid var(--ash);border-radius:8px;
  display:grid;place-items:center;transition:all 240ms var(--ease);
}
.checklist-item.is-checked .checklist-checkbox{background:var(--amber);border-color:var(--amber-deep);}
.checklist-checkbox svg{width:14px;height:14px;stroke:var(--ink);opacity:0;transition:opacity 200ms;}
.checklist-item.is-checked .checklist-checkbox svg{opacity:1;}
.checklist-title{font-family:var(--display);font-weight:600;font-size:1.1rem;letter-spacing:-0.015em;color:var(--ink);}
.checklist-toggle{
  width:30px;height:30px;border-radius:50%;background:var(--cream-2);border:0;cursor:pointer;
  display:grid;place-items:center;color:var(--ink);font-size:1.2rem;font-weight:600;
  transition:background 240ms,transform 240ms var(--spring);
}
.checklist-toggle:hover{background:var(--amber);}
.checklist-item.is-open .checklist-toggle{transform:rotate(45deg);background:var(--amber);}
.checklist-body{
  display:grid;grid-template-rows:0fr;transition:grid-template-rows 320ms var(--ease);
  color:var(--slate);font-size:0.98rem;line-height:1.6;
}
.checklist-body > div{overflow:hidden;padding:0 0.5rem;}
.checklist-item.is-open .checklist-body{grid-template-rows:1fr;}
.checklist-item.is-open .checklist-body > div{padding:0 0.5rem 1.5rem;}
.checklist-body p{margin-bottom:0.8rem;}
.checklist-body ul{padding-left:1.2rem;margin:0.5rem 0;}
.checklist-body li{margin-bottom:0.35rem;}
.checklist-result{
  margin-top:2rem;padding:1.75rem;border-radius:18px;
  background:var(--ink);color:var(--paper);
  transition:background 400ms,color 400ms;
}
.checklist-result.is-ready{background:var(--amber);color:var(--ink);}
.checklist-result h3{font-size:1.4rem;letter-spacing:-0.015em;margin-bottom:0.5rem;}
.checklist-result.is-ready h3{color:var(--ink);}
.checklist-result p{opacity:0.85;font-size:1rem;line-height:1.5;}
.checklist-actions{display:flex;flex-wrap:wrap;gap:0.6rem;margin-top:1rem;}

/* -------- Contact form -------- */
.contact{display:grid;grid-template-columns:1.3fr 1fr;gap:2.5rem;align-items:flex-start;}
.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.contact-form .full{grid-column:1 / -1;}
.field label{
  display:block;font-family:var(--mono);font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--slate);margin-bottom:0.4rem;font-weight:600;
}
.field input,.field select,.field textarea{
  width:100%;padding:0.9rem 1rem;border:1px solid var(--rule);background:var(--paper);border-radius:12px;
  font-family:var(--body);font-size:1rem;color:var(--ink);
  transition:border-color 180ms,box-shadow 180ms,background 180ms;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:0;border-color:var(--amber);background:#fff;box-shadow:0 0 0 4px rgba(232,162,23,0.15);
}
.field textarea{resize:vertical;min-height:140px;font-family:var(--body);}
.contact-aside{
  background:var(--ink);color:var(--paper);border-radius:22px;padding:2rem;
  display:flex;flex-direction:column;gap:1rem;
}
.contact-aside h3{color:#fff;font-size:1.35rem;letter-spacing:-0.015em;}
.contact-aside .row{display:flex;justify-content:space-between;gap:1rem;padding:0.9rem 0;border-bottom:1px solid rgba(255,255,255,0.1);font-size:0.95rem;}
.contact-aside .row:last-child{border:0;}
.contact-aside .label{font-family:var(--mono);font-size:0.7rem;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.55);}
.contact-aside .val{color:#fff;text-align:right;font-weight:500;}
.contact-aside a{color:var(--amber);text-decoration:none;border-bottom:1px solid rgba(232,162,23,0.4);}
@media(max-width:900px){.contact{grid-template-columns:1fr;}.contact-form{grid-template-columns:1fr;}}

/* -------- FAQ page list (smaller variant) -------- */
.faq-list{max-width:820px;margin:0 auto;}

/* ===================================================== */
/*  MOBILE POLISH                                        */
/* ===================================================== */

@media(max-width:640px){
  body{font-size:16px;}
  .container{padding:0 1.1rem;}
  .section{padding:3.5rem 0;}

  /* Hero */
  .hero{min-height:auto;}
  .hero-content{padding:4rem 0 3rem;}
  .hero h1{font-size:clamp(2.2rem,10vw,3.2rem);margin:0.75rem 0 1rem;}
  .hero-lede{font-size:1.05rem;margin-bottom:1.5rem;}
  .hero-actions{flex-direction:column;align-items:stretch;width:100%;}
  .hero-actions .btn{justify-content:center;width:100%;}
  .hero-corner{display:none;}
  .hero-meta{display:none;}

  /* Marquee - a touch smaller */
  .marquee{gap:2.5rem;padding:1rem 0;font-size:1rem;}
  .marquee span{gap:1.25rem;}

  /* Typography */
  .h-display{font-size:clamp(1.9rem,7vw,2.4rem);}
  .lede{font-size:1.02rem;}
  .section-header{text-align:left;}
  .section-header .lede{margin-left:0;margin-right:0;}

  /* Scenes */
  .scene{padding:1.25rem 0;gap:0.4rem;}
  .scene-line{font-size:1.25rem;line-height:1.25;}
  .scene:hover{padding-left:0;padding-right:0;background:transparent;}

  /* Outcome cards */
  .outcome-card{padding:1.5rem 1.25rem 1.25rem;border-radius:16px;}
  .outcome-card h3{font-size:1.25rem;}

  /* Ledger */
  .ledger-col{padding:1.75rem 1.25rem;gap:0.9rem;}
  .ledger-col h3{font-size:1.25rem;}
  .ledger-list li{font-size:0.96rem;padding:0.65rem 0;}

  /* Personas */
  .persona{min-height:300px;padding:1.5rem;border-radius:18px;}
  .persona h3{font-size:1.4rem;}
  .persona .pill{top:1rem;left:1rem;}

  /* Process */
  .process-step{padding:1.75rem 1.25rem;}
  .process-step h3{font-size:1.18rem;}

  /* Safety */
  .safety{gap:1.5rem;}
  .safety-list li{padding:0.8rem 0;gap:0.7rem;}
  .safety-list strong{font-size:1rem;}

  /* Stories */
  .story{padding:1.5rem;border-radius:16px;}
  .story-quote{font-size:1.15rem;}

  /* FAQ */
  .faq-summary{font-size:1.02rem;padding:1.1rem 0;gap:0.75rem;}
  .faq-body{font-size:0.98rem;}
  .faq-icon{width:26px;height:26px;}

  /* Closing */
  .closing{padding:3rem 0;}
  .closing h2{font-size:clamp(2rem,8vw,2.8rem);}
  .closing p{font-size:1rem;}
  .closing-actions{flex-direction:column;align-items:stretch;}
  .closing-actions .btn{justify-content:center;width:100%;}
  .closing-card{padding:1.5rem;border-radius:18px;}
  .closing-card .row{padding:0.6rem 0;font-size:0.85rem;}

  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:1.75rem;}
  .footer-brand p{max-width:none;}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:0.5rem;}

  /* Page heroes */
  .page-hero{padding:3.5rem 0 2.5rem;}
  .page-hero h1{font-size:clamp(2rem,9vw,2.8rem);}
  .page-hero .lead{font-size:1.02rem;}

  /* Director */
  .director{padding:1.5rem;gap:1.5rem;border-radius:18px;}
  .director h3{font-size:1.5rem;}
  .director p{font-size:0.98rem;}

  /* Spec / pillar / tier / battery */
  .spec-card,.pillar,.tier{padding:1.5rem 1.25rem;border-radius:16px;}
  .pillar .n{font-size:2.4rem;}
  .battery-card{border-radius:18px;}
  .battery-media{min-height:220px;}
  .battery-body{padding:1.5rem 1.25rem;gap:0.85rem;}
  .battery-name{font-size:1.7rem;}
  .battery-price{font-size:1.65rem;}
  .battery-specs{padding:0.75rem 0;font-size:0.9rem;}
  .battery-actions{flex-direction:column;align-items:stretch;}
  .battery-actions .btn{justify-content:center;}

  /* Checklist */
  .checklist-item-header{padding:1rem 0.25rem;gap:0.75rem;}
  .checklist-title{font-size:1rem;line-height:1.3;}
  .checklist-checkbox{width:22px;height:22px;}
  .checklist-body{font-size:0.96rem;}
  .checklist-result{padding:1.25rem;}
  .checklist-actions{flex-direction:column;align-items:stretch;}
  .checklist-actions .btn{justify-content:center;}

  /* Contact */
  .contact{gap:1.5rem;}
  .contact-aside{padding:1.5rem;border-radius:18px;}
  .field input,.field select,.field textarea{padding:0.8rem 0.9rem;font-size:16px;}

  /* About portrait caption visibility */
  .director .portrait{max-width:240px;margin:0 auto;}

  /* Breadcrumb */
  .breadcrumb{font-size:0.68rem;}
}

/* Tablet midrange */
@media(min-width:641px) and (max-width:900px){
  .hero-content{padding:5rem 0 3.5rem;}
  .section{padding:4.5rem 0;}
  .scene{padding:1.5rem 0;}
}

/* -------- Brand logo image -------- */
.brand-logo{height:64px;width:auto;display:block;}
@media(max-width:640px){.brand-logo{height:48px;}}

/* -------- Form feedback -------- */
.form-msg{
  padding:0.9rem 1.1rem;
  border-radius:8px;
  font-size:0.95rem;
  display:none;
  margin-top:0.5rem;
}
.form-msg.is-success{
  display:block;
  background:rgba(123,168,122,0.15);
  border:1px solid var(--mint);
  color:var(--forest);
}
.form-msg.is-error{
  display:block;
  background:rgba(220,60,60,0.08);
  border:1px solid #c0392b;
  color:#7b1a1a;
}

/* -------- Photo strips -------- */
.photo-strip{display:grid;gap:4px;overflow:hidden;}
.photo-strip.cols-2{grid-template-columns:1fr 1fr;}
.photo-strip.cols-3{grid-template-columns:1fr 1fr 1fr;}
.photo-strip img{width:100%;height:580px;object-fit:cover;display:block;}
.photo-strip.is-portrait img{height:800px;}
.photo-full img{width:100%;height:640px;object-fit:cover;display:block;}
@media(max-width:700px){
  .photo-strip.cols-2,.photo-strip.cols-3{grid-template-columns:1fr;}
  .photo-strip img{height:320px;}
  .photo-strip.is-portrait img{height:480px;}
  .photo-full img{height:360px;}
}
