/* ============================================================
   SEPIA — one-page editorial redesign
   Design language reverse-engineered from rblln.fr (Rébellion):
   ink-on-paper, oversized all-caps geometric grotesk, one hot
   accent, printer's crop marks, image-trail hero, pixel-wipe intro,
   bottom-docked pill nav, Lenis smooth scroll.

   Type : Space Grotesk (free grotesk closest to Commuters Sans)
   Color: warm bone paper + warm near-black ink + burnt sepia-orange
   ============================================================ */

:root{
  /* surfaces — flat ink on warm paper, no gradients */
  --paper:#EFE7DA;          /* warm bone background */
  --paper-2:#E7DECF;        /* slightly deeper panel */
  --ink:#191512;            /* warm near-black */
  --ink-soft:#241F1A;

  /* ink opacity tiers */
  --ink-2:rgba(25,21,18,.66);
  --ink-3:rgba(25,21,18,.46);
  --ink-4:rgba(25,21,18,.28);

  /* hairlines */
  --line:rgba(25,21,18,.18);
  --line-2:rgba(25,21,18,.34);

  /* accents — burnt sepia-orange primary, amber secondary */
  --accent:#D8431A;
  --accent-ink:#FFF3EC;
  --amber:#E7A33C;
  --ok:#3f7d4f;

  --sans:'Space Grotesk',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;

  --maxw:1320px;
  --gutter:clamp(16px,4vw,52px);

  --r-pill:999px;
  --r-card:6px;          /* tight editorial radius */
}

/* ---------- reset ---------- */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto !important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  font-weight:400;
  line-height:1.45;
  letter-spacing:-.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{background:var(--accent);color:var(--accent-ink)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;color:inherit}

/* ---------- type ---------- */
h1,h2,h3,h4{
  font-family:var(--sans);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:-.04em;
  line-height:.92;
  margin:0;
  color:var(--ink);
}
p{margin:0 0 1em}
.serif{font-style:italic}   /* legacy hook, italic emphasis */

/* display roles */
.display{
  font-weight:700;text-transform:uppercase;letter-spacing:-.045em;
  line-height:.86;
  font-size:clamp(34px,9vw,148px);
  overflow-wrap:break-word;hyphens:none;max-width:100%;
}
.h-sec{
  font-weight:700;text-transform:uppercase;letter-spacing:-.04em;
  line-height:.88;
  font-size:clamp(34px,6.4vw,78px);
}
.h-big{                       /* pull-quote scale */
  font-weight:700;text-transform:uppercase;letter-spacing:-.04em;
  line-height:.92;
  font-size:clamp(28px,4.8vw,60px);
}
.accent{color:var(--accent)}
.amber{color:var(--amber)}

/* labels / eyebrows — all-caps, tight, tracked just enough to read */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-size:12px;font-weight:700;text-transform:uppercase;
  letter-spacing:.02em;color:var(--ink);
}
.eyebrow::before{
  content:"";width:7px;height:7px;border-radius:50%;
  background:var(--accent);flex:none;
}
.lead{font-size:clamp(16px,1.5vw,19px);line-height:1.5;color:var(--ink-2);letter-spacing:-.01em}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
section{padding:clamp(64px,9vw,128px) 0;position:relative}
.sec-line{border-top:1px solid var(--ink)}
.center{text-align:center}

/* section heading block */
.sec-head{margin-bottom:clamp(34px,5vw,64px)}
.sec-head .eyebrow{margin-bottom:18px}
.sec-head .lead{max-width:54ch;margin-top:20px}

/* ---------- crop marks (printer's registration brackets) ---------- */
/* JS injects four .cm corner spans into every .crop element */
.crop{position:relative}
.cm{position:absolute;width:16px;height:16px;color:var(--ink);pointer-events:none;z-index:3}
.cm svg{width:100%;height:100%;display:block;stroke:currentColor;stroke-width:1;fill:none}
.cm.tl{top:-8px;left:-8px}
.cm.tr{top:-8px;right:-8px}
.cm.bl{bottom:-8px;left:-8px}
.cm.br{bottom:-8px;right:-8px}
.crop.accent-marks .cm{color:var(--accent)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--sans);font-weight:700;font-size:13px;line-height:1;
  text-transform:uppercase;letter-spacing:.01em;
  padding:16px 26px;border:1px solid var(--ink);border-radius:var(--r-pill);
  background:transparent;color:var(--ink);cursor:pointer;white-space:nowrap;
  transition:background .25s ease,color .25s ease,border-color .25s ease,transform .25s ease;
}
.btn:hover{background:var(--ink);color:var(--paper)}
.btn-accent{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
.btn-accent:hover{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.btn-lg{padding:19px 34px;font-size:14px}
.btn svg{width:15px;height:15px;flex:none}

.arrowlink{
  display:inline-flex;align-items:center;gap:9px;
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;
  color:var(--ink);border-bottom:1px solid transparent;padding-bottom:2px;
  transition:gap .2s ease,border-color .2s ease,color .2s ease;
}
.arrowlink:hover{gap:14px;border-color:var(--accent);color:var(--accent)}

/* ============================================================
   INTRO — pixel-grid wipe over the wordmark
   ============================================================ */
.intro{
  position:fixed;inset:0;z-index:9990;background:var(--paper);
  display:grid;place-items:center;
}
.intro-mark{
  font-size:clamp(40px,9vw,120px);font-weight:700;text-transform:uppercase;
  letter-spacing:-.05em;line-height:1;color:var(--ink);
}
.intro-mark .accent{color:var(--accent)}
.intro-sub{
  margin-top:14px;text-align:center;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.34em;color:var(--ink-3);
}
#pixels{
  position:fixed;inset:0;z-index:9991;pointer-events:none;
  display:grid;grid-template-columns:repeat(20,1fr);grid-template-rows:repeat(10,1fr);
}
#pixels i{display:block;background:var(--paper);opacity:0}
.intro-done #pixels,.intro-done .intro{display:none}

/* ============================================================
   NAV — bottom-docked pill + reveal handle
   ============================================================ */
nav.dock{
  position:fixed;left:50%;bottom:22px;transform:translate(-50%,150px);
  z-index:980;display:flex;align-items:center;gap:6px;
  background:var(--ink);color:var(--paper);
  padding:6px 6px 6px 18px;border-radius:var(--r-pill);
  box-shadow:0 18px 50px -16px rgba(0,0,0,.5);
  max-width:calc(100vw - 24px);
  transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
nav.dock.on{transform:translate(-50%,0)}
.dock-brand{
  display:flex;align-items:center;gap:8px;flex:none;
  font-weight:700;text-transform:uppercase;letter-spacing:-.02em;font-size:14px;color:var(--paper);
}
.dock-brand .dot{width:10px;height:10px;border-radius:50%;background:var(--accent);flex:none}
.dock-links{display:flex;align-items:center;gap:4px}
.dock-links a{
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;
  color:rgba(239,231,218,.62);padding:9px 11px;border-radius:var(--r-pill);
  transition:color .2s ease,background .2s ease;white-space:nowrap;
}
.dock-links a:hover,.dock-links a.active{color:var(--paper);background:rgba(239,231,218,.1)}
.dock-cta{
  flex:none;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;
  background:var(--accent);color:var(--accent-ink);padding:10px 16px;border-radius:var(--r-pill);
  transition:background .25s ease;
}
.dock-cta:hover{background:#EE5A2C}
.dock-burger{display:none}

.handle{
  position:fixed;left:50%;bottom:14px;transform:translate(-50%,150px);
  z-index:979;width:200px;height:8px;border-radius:999px;
  background:var(--ink);opacity:.3;
  transition:transform .35s cubic-bezier(.2,.7,.2,1),opacity .3s ease;
}
.handle.on{transform:translate(-50%,0)}

@media(max-width:860px){
  nav.dock{left:12px;right:12px;bottom:12px;transform:translateY(150px);
    width:auto;max-width:none;justify-content:space-between;padding:7px 7px 7px 16px}
  nav.dock.on{transform:translateY(0)}
  .dock-links{
    position:absolute;left:0;right:0;bottom:calc(100% + 10px);
    flex-direction:column;align-items:stretch;gap:2px;padding:8px;
    background:var(--ink);border-radius:18px;
    box-shadow:0 22px 60px -18px rgba(0,0,0,.6);
    opacity:0;visibility:hidden;transform:translateY(12px);pointer-events:none;
    transition:opacity .25s ease,transform .3s ease,visibility .25s;
  }
  .dock-links.open{opacity:1;visibility:visible;transform:none;pointer-events:auto}
  .dock-links a{font-size:13px;padding:14px 14px}
  .dock-burger{
    display:flex;flex-direction:column;justify-content:center;gap:4px;
    width:38px;height:38px;border-radius:50%;background:rgba(239,231,218,.1);
    align-items:center;flex:none;cursor:pointer;order:3;
  }
  .dock-burger span{display:block;width:16px;height:1.6px;background:var(--paper);transition:.25s}
  .dock-burger.open span:nth-child(1){transform:translateY(5.6px) rotate(45deg)}
  .dock-burger.open span:nth-child(2){opacity:0}
  .dock-burger.open span:nth-child(3){transform:translateY(-5.6px) rotate(-45deg)}
  .handle{display:none}
}

/* ============================================================
   HERO — full viewport, centered, image trail
   ============================================================ */
.hero{
  min-height:100svh;display:grid;place-items:center;text-align:center;
  padding:120px 0 96px;position:relative;overflow:hidden;
}
.hero-inner{position:relative;z-index:4;max-width:1100px;margin:0 auto;padding:0 var(--gutter)}
.hero .display{margin:0 auto}
.hero .display em{font-style:normal;color:var(--accent)}
.hero-sub{max-width:50ch;margin:28px auto 0;font-size:clamp(15px,1.4vw,18px);color:var(--ink-2);line-height:1.5}
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:34px}
.hero-micro{margin-top:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-3)}

/* image trail layer */
.trail{position:absolute;inset:0;z-index:1;pointer-events:none}
.trail img{
  position:absolute;top:0;left:0;width:clamp(120px,13vw,190px);aspect-ratio:416/620;
  object-fit:cover;border-radius:4px;opacity:0;will-change:transform,opacity;
  box-shadow:0 24px 50px -22px rgba(0,0,0,.55);
}
.hero-corner{
  position:absolute;z-index:4;font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.14em;color:var(--ink-3);
}
.hero-corner.tl{top:96px;left:var(--gutter)}
.hero-corner.tr{top:96px;right:var(--gutter);text-align:right}
@media(max-width:860px){.hero-corner{display:none}.trail img{width:34vw}}

/* ---------- running tag row ---------- */
.tagstrip{border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);padding:18px 0}
.tagrow{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.tag{
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;
  border:1px solid var(--line-2);color:var(--ink);padding:9px 16px;border-radius:var(--r-pill);
  transition:background .25s ease,color .25s ease,border-color .25s ease;
}
.tag.is-on,.tag:hover{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}

/* ============================================================
   HOW IT WORKS — 2-col label + manifesto, stacked feature rows
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,80px);align-items:start}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:28px}}
.manifesto{font-size:clamp(18px,2vw,26px);line-height:1.32;letter-spacing:-.02em;color:var(--ink);max-width:24ch}
.manifesto em{font-style:normal;color:var(--accent)}

.rows{margin-top:clamp(40px,6vw,72px);border-top:1px solid var(--ink)}
.row{
  display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:baseline;
  padding:clamp(22px,3vw,34px) 0;border-bottom:1px solid var(--line);
  transition:padding-left .3s ease;
}
.row:hover{padding-left:12px}
.row-num{font-size:13px;font-weight:700;color:var(--accent);letter-spacing:.04em}
.row-title{font-size:clamp(26px,4.6vw,56px);font-weight:700;text-transform:uppercase;letter-spacing:-.04em;line-height:.9}
.row-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;max-width:280px}
.row-tags span{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:var(--ink-2);border:1px solid var(--line);padding:6px 11px;border-radius:999px;white-space:nowrap}
@media(max-width:680px){
  .row{grid-template-columns:auto 1fr;gap:14px}
  .row-tags{grid-column:1/-1;justify-content:flex-start;max-width:none;margin-top:6px}
}

/* ============================================================
   PRINCIPLES — repeating label / big quote / paragraph
   ============================================================ */
.principles{display:grid;gap:0;border-top:1px solid var(--ink)}
.principle{
  display:grid;grid-template-columns:200px 1fr;gap:clamp(20px,4vw,56px);
  padding:clamp(34px,5vw,64px) 0;border-bottom:1px solid var(--line);align-items:start;
}
.principle-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);padding-top:10px}
.principle-quote{font-size:clamp(26px,4.4vw,56px);font-weight:700;text-transform:uppercase;letter-spacing:-.04em;line-height:.95;margin:0 0 18px}
.principle-body{font-size:clamp(15px,1.4vw,18px);line-height:1.5;color:var(--ink-2);max-width:56ch}
@media(max-width:760px){.principle{grid-template-columns:1fr;gap:14px;padding:34px 0}}

/* ============================================================
   GALLERY — stat headline + photo mosaic (parallax)
   ============================================================ */
.statline{font-size:clamp(34px,7vw,96px);font-weight:700;text-transform:uppercase;letter-spacing:-.045em;line-height:.85;text-align:center;max-width:18ch;margin:0 auto clamp(40px,6vw,72px)}
.statline em{font-style:normal;color:var(--accent)}
.mosaic{
  display:grid;grid-template-columns:repeat(6,1fr);gap:12px;
}
.mosaic figure{margin:0;position:relative;overflow:hidden;border-radius:4px;background:var(--paper-2);aspect-ratio:416/620}
.mosaic figure img{width:100%;height:120%;object-fit:cover;will-change:transform}
.mosaic figure.tall{grid-row:span 2;aspect-ratio:416/900}
.mosaic figure.wide{grid-column:span 2}
@media(max-width:880px){.mosaic{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.mosaic{grid-template-columns:repeat(2,1fr)}}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:clamp(34px,5vw,56px)}
@media(max-width:820px){.reviews{grid-template-columns:1fr}}
.review{border:1px solid var(--ink);border-radius:var(--r-card);padding:26px;display:flex;flex-direction:column;gap:14px;background:var(--paper)}
.review .stars{color:var(--accent);letter-spacing:3px;font-size:15px}
.review h4{font-size:18px;font-weight:700;text-transform:uppercase;letter-spacing:-.02em}
.review p{font-size:15px;line-height:1.5;color:var(--ink-2);margin:0;flex:1;text-transform:none;letter-spacing:-.01em}
.review .by{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3)}
.statrow{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-bottom:8px}
.statbox{flex:1 1 200px;max-width:260px;border:1px solid var(--ink);border-radius:var(--r-card);padding:24px 18px;text-align:center}
.statbox .n{font-size:46px;font-weight:700;letter-spacing:-.03em;line-height:1}
.statbox .n .accent{color:var(--accent)}
.statbox .l{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);margin-top:12px}

/* ============================================================
   PRICING (interactive participant selector) — light theme
   ============================================================ */
.pricer{
  max-width:640px;margin:0 auto;border:1px solid var(--ink);border-radius:10px;
  background:var(--paper);padding:34px 34px 30px;
  transition:border-color .3s ease,background .3s ease;
}
.pricer.is-free{border-color:var(--ink)}
.pricer-top{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;flex-wrap:wrap}
.pricer-head{font-size:clamp(24px,4vw,34px);font-weight:700;text-transform:uppercase;letter-spacing:-.03em;line-height:1;margin:0;max-width:10ch}
.pricer-pricebox{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:9px}
.pricer-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);border:1px solid var(--accent);padding:5px 10px;border-radius:999px;white-space:nowrap}
.pricer.is-free .pricer-badge{color:var(--ok);border-color:var(--ok)}
.pricer-price{font-size:clamp(40px,7vw,58px);font-weight:700;line-height:1;letter-spacing:-.03em;color:var(--ink)}

.pricer-slider{margin:30px 0 0}
.pricer-range{
  -webkit-appearance:none;appearance:none;width:100%;height:4px;border-radius:999px;outline:none;cursor:pointer;margin:0;
  background:linear-gradient(90deg,var(--accent) var(--pct,0%),var(--line-2) var(--pct,0%));
}
.pricer.is-free .pricer-range{background:linear-gradient(90deg,var(--ok) var(--pct,0%),var(--line-2) var(--pct,0%))}
.pricer-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:var(--ink);border:2px solid var(--paper);box-shadow:0 0 0 1px var(--ink);cursor:grab}
.pricer-range::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--ink);border:2px solid var(--paper);box-shadow:0 0 0 1px var(--ink);cursor:grab}
.pricer-range:active::-webkit-slider-thumb{cursor:grabbing}
.pricer-stops{position:relative;height:24px;margin-top:16px}
.pricer-stop{position:absolute;top:0;transform:translateX(-50%);white-space:nowrap;font-size:12.5px;font-weight:700;color:var(--ink-3);background:none;border:none;padding:4px 5px;cursor:pointer;transition:color .18s ease,transform .18s ease}
.pricer-stop:last-child{font-size:17px;line-height:.8}
.pricer-stop:hover{color:var(--ink)}
.pricer-stop.on{color:var(--ink);transform:translateX(-50%) translateY(-2px)}
.pricer.is-free .pricer-stop.on{color:var(--ok)}
.pricer-max{margin-top:22px;font-size:14.5px;color:var(--ink-2);text-transform:none;letter-spacing:-.01em}
.pricer-max b{color:var(--ink)}

.pricer-addon{display:flex;align-items:center;gap:14px;cursor:pointer;margin-top:22px;padding:15px 17px;border:1px solid var(--line);border-radius:8px;transition:border-color .25s ease}
.pricer-addon:hover{border-color:var(--ink)}
.pricer-addon-check{position:absolute;opacity:0;width:0;height:0}
.pricer-addon-box{flex:none;width:22px;height:22px;border-radius:5px;border:1.5px solid var(--line-2);position:relative;transition:.2s}
.pricer-addon-box::after{content:"";position:absolute;left:7px;top:3px;width:5px;height:9px;border:solid var(--paper);border-width:0 2px 2px 0;transform:rotate(42deg) scale(0);transition:transform .18s ease}
.pricer-addon-check:checked + .pricer-addon-box{background:var(--accent);border-color:var(--accent)}
.pricer-addon-check:checked + .pricer-addon-box::after{transform:rotate(42deg) scale(1)}
.pricer-addon-text{display:flex;flex-direction:column;gap:2px;line-height:1.35}
.pricer-addon-text b{font-size:14.5px;font-weight:700;text-transform:none;letter-spacing:-.01em}
.pricer-addon-text span{font-size:13px;color:var(--ink-3);text-transform:none;letter-spacing:-.01em}
.pricer-addon-price{margin-left:auto;flex:none;align-self:flex-start;font-size:13px;font-weight:700;color:var(--accent)}

.pricer-feats{list-style:none;padding:0;margin:22px 0 26px;display:grid;gap:11px}
.pricer-feats li{position:relative;padding-left:26px;color:var(--ink-2);font-size:14.5px;line-height:1.5;text-transform:none;letter-spacing:-.01em}
.pricer-feats li::before{content:"";position:absolute;left:0;top:3px;width:16px;height:16px;border-radius:50%;border:1px solid var(--accent)}
.pricer-feats li::after{content:"";position:absolute;left:5px;top:6px;width:5px;height:8px;border:solid var(--accent);border-width:0 1.6px 1.6px 0;transform:rotate(42deg)}
.pricer.is-free .pricer-feats li::before{border-color:var(--ok)}
.pricer.is-free .pricer-feats li::after{border-color:var(--ok)}
.pricer-cta{width:100%}
@media(max-width:560px){.pricer{padding:26px 22px 24px}.pricer-stop{font-size:11px;padding:4px 3px}}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:880px;margin:0 auto;border-top:1px solid var(--ink)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;text-align:left;background:none;border:none;cursor:pointer;color:var(--ink);
  font-weight:700;font-size:clamp(16px,2vw,22px);text-transform:uppercase;letter-spacing:-.02em;
  padding:24px 0;display:flex;align-items:center;gap:16px;
}
.faq-q .pm{flex:none;width:16px;height:16px;position:relative;margin-left:auto;color:var(--accent)}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:currentColor;transition:.28s}
.faq-q .pm::before{left:0;top:7px;width:16px;height:2px}
.faq-q .pm::after{left:7px;top:0;width:2px;height:16px}
.faq-item.open .faq-q .pm::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .34s cubic-bezier(.4,0,.2,1)}
.faq-a-inner{padding:0 0 24px;color:var(--ink-2);font-size:16px;line-height:1.6;text-transform:none;letter-spacing:-.01em;max-width:70ch}
.faq-a-inner a{color:var(--accent);border-bottom:1px solid var(--accent)}

/* ============================================================
   CLOSING CTA band
   ============================================================ */
.closing{text-align:center}
.closing .display em{font-style:normal;color:var(--accent)}
.closing .lead{max-width:46ch;margin:24px auto 0}
.closing .hero-cta{margin-top:36px}

/* ============================================================
   FOOTER
   ============================================================ */
footer.site{border-top:1px solid var(--ink);padding:clamp(48px,7vw,84px) 0 40px}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:clamp(24px,4vw,48px)}
@media(max-width:820px){.foot-top{grid-template-columns:1fr 1fr}}
.foot-brand .bmark{display:flex;align-items:center;gap:9px;font-size:22px;font-weight:700;text-transform:uppercase;letter-spacing:-.03em;margin-bottom:16px}
.foot-brand .bmark .dot{width:12px;height:12px;border-radius:50%;background:var(--accent)}
.foot-brand p{color:var(--ink-2);font-size:14px;max-width:30ch;text-transform:none;letter-spacing:-.01em}
.foot-brand .ig{display:inline-flex;gap:8px;align-items:center;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-top:18px;border-bottom:1px solid var(--line-2);padding-bottom:3px}
.foot-brand .ig:hover{border-color:var(--accent);color:var(--accent)}
.foot-col h5{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-3);margin:0 0 16px}
.foot-col ul{list-style:none;padding:0;margin:0;display:grid;gap:11px}
.foot-col a{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.01em;color:var(--ink)}
.foot-col a:hover{color:var(--accent)}
.foot-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:clamp(40px,6vw,64px);padding-top:28px;border-top:1px solid var(--line)}
.foot-tags span{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:var(--ink-3)}
.foot-tags span:hover{color:var(--accent)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;margin-top:32px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3)}

/* ============================================================
   LEGAL pages (privacy / terms)
   ============================================================ */
.phero{text-align:center;padding:140px 0 0}
.phero .eyebrow{margin-bottom:18px}
.phero h1{font-size:clamp(40px,8vw,96px);font-weight:700;text-transform:uppercase;letter-spacing:-.045em;line-height:.88}
.legal{max-width:780px;margin:0 auto}
.legal .updated{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);margin-bottom:8px}
.legal h2{font-size:22px;font-weight:700;text-transform:uppercase;letter-spacing:-.02em;margin:40px 0 12px}
.legal h3{font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:-.01em;margin:26px 0 8px}
.legal p,.legal li{color:var(--ink-2);font-size:16px;line-height:1.7;text-transform:none;letter-spacing:-.01em}
.legal strong{color:var(--ink)}
.legal a{color:var(--accent);border-bottom:1px solid var(--accent)}
.legal ul{padding-left:22px}

/* ============================================================
   scroll reveal — subtle fade-up
   ============================================================ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}

@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .btn,.tag,.row,.arrowlink{transition:none}
  .mosaic figure img{height:100%}
  #pixels,.intro{display:none}
}
