/* ─────────────────────────────────────────────────────────────
   Reevia — shared styles
   Luxury-editorial · ivory / ink / jade / gold
   ───────────────────────────────────────────────────────────── */

:root{
  --ivory:#ECE6D8;
  --ivory-deep:#E3DCCB;
  --ink:#14110D;
  --ink-soft:#3C342A;
  --ink-mute:#6B6253;
  --jade:#1F4A3A;
  --jade-soft:#2E6450;
  --gold:#B6873A;
  --oxblood:#5A1A1A;
  --rule:rgba(20,17,13,.18);
  --rule-strong:rgba(20,17,13,.35);
  --card:#F2ECDE;

  --mono:"IBM Plex Mono",ui-monospace,monospace;
  --serif:"Fraunces",ui-serif,Georgia,serif;

  --pad-x:clamp(20px,4vw,56px);
  --pad-y:clamp(40px,5vw,80px);
  --content-max:1320px;
}

*,*::before,*::after{box-sizing:border-box}

html,body{margin:0;padding:0}
body{
  background:var(--ivory);
  color:var(--ink);
  font-family:var(--serif);
  font-feature-settings:"ss01","ss02","liga","dlig","onum";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100vh;
  overflow-x:hidden;
  position:relative;
  isolation:isolate;
  line-height:1.5;
}

/* film grain */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:60;
  opacity:.22;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.92' numOctaves='2' seed='7' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
/* vignette */
body::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:55;
  background:
    radial-gradient(140% 90% at 50% 0%, transparent 55%, rgba(20,17,13,.10) 100%),
    radial-gradient(120% 80% at 50% 100%, transparent 60%, rgba(20,17,13,.14) 100%);
}

/* ─── Top bar ─────────────────────────────────────────────── */
.topbar{
  position:relative;
  z-index:5;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  padding:22px var(--pad-x) 20px;
  border-bottom:1px solid var(--rule);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.mark{
  display:flex;
  align-items:baseline;
  gap:6px;
  font-family:var(--serif);
  font-weight:400;
  font-size:18px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink);
  text-decoration:none;
}
.mark .glyph{
  display:inline-block;
  width:10px;height:10px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #fff8e7 0%, var(--gold) 38%, var(--oxblood) 78%, var(--ink) 100%);
  box-shadow:0 0 14px rgba(182,135,58,.45);
  transform:translateY(-1px);
  margin-right:10px;
}
.mark .tld{font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--ink-soft);font-weight:400;transform:translateY(-6px)}
.centerline{
  justify-self:center;
  font-size:10px;
  letter-spacing:.32em;
}
.centerline em{font-style:italic;letter-spacing:.06em;font-family:var(--serif);text-transform:none;color:var(--ink);font-size:13px;padding:0 6px}
.nav{
  justify-self:end;
  display:flex;
  gap:28px;
}
.nav a{
  position:relative;
  color:var(--ink-soft);
  text-decoration:none;
  padding:4px 0;
  transition:color .35s ease;
}
.nav a::after{
  content:"";
  position:absolute;
  left:0;right:0;
  bottom:-2px;
  height:1px;
  background:var(--ink);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.nav a:hover,
.nav a.active{color:var(--ink)}
.nav a:hover::after,
.nav a.active::after{transform:scaleX(1)}

/* ─── Page generic ───────────────────────────────────────── */
.page{
  position:relative;
  z-index:4;
}
.section{
  padding:var(--pad-y) var(--pad-x);
  border-bottom:1px solid var(--rule);
  position:relative;
}
.section--narrow{max-width:980px;margin:0 auto}
.section--wide{max-width:var(--content-max);margin:0 auto}

.eyebrow{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink-soft);
  display:flex;
  align-items:center;
  gap:14px;
}
.eyebrow::before{
  content:"";
  display:inline-block;
  width:36px;height:1px;background:var(--ink-soft);
}

.h1{
  margin:30px 0 24px;
  font-weight:300;
  font-size:clamp(48px,7vw,118px);
  line-height:.96;
  letter-spacing:-.03em;
  color:var(--ink);
}
.h1 em{
  font-style:italic;
  font-variation-settings:"opsz" 144,"SOFT" 50,"WONK" 1;
  color:var(--jade);
  letter-spacing:-.03em;
}

.h2{
  margin:0 0 22px;
  font-weight:300;
  font-size:clamp(32px,3.4vw,52px);
  line-height:1.05;
  letter-spacing:-.02em;
  color:var(--ink);
}
.h2 em{
  font-style:italic;
  color:var(--jade);
}

.lede{
  max-width:58ch;
  margin:0 0 36px;
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(17px,1.35vw,21px);
  line-height:1.5;
  letter-spacing:.005em;
  color:var(--ink-soft);
}
.lede em{font-style:italic;color:var(--ink)}

p{margin:0 0 16px;color:var(--ink-soft);font-weight:300;font-size:17px;line-height:1.55}
p em{font-style:italic;color:var(--ink)}

.actions{
  display:flex;
  align-items:center;
  gap:32px;
  flex-wrap:wrap;
}

.cta{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:18px;
  padding:18px 30px;
  border:1px solid var(--ink);
  background:transparent;
  color:var(--ink);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  text-decoration:none;
  overflow:hidden;
  transition:color .5s ease,border-color .5s ease;
  cursor:pointer;
}
.cta::before{
  content:"";
  position:absolute;inset:0;
  background:var(--ink);
  transform:translateY(101%);
  transition:transform .55s cubic-bezier(.66,0,.1,1);
  z-index:-1;
}
.cta:hover{color:var(--ivory)}
.cta:hover::before{transform:translateY(0)}
.cta .arrow{display:inline-block;transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.cta:hover .arrow{transform:translateX(6px)}

.cta--invert{color:var(--ivory);border-color:var(--ivory);background:transparent}
.cta--invert::before{background:var(--ivory)}
.cta--invert:hover{color:var(--ink)}

.cta-ghost{
  color:var(--ink-soft);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  text-decoration:none;
  padding:4px 0;
  border-bottom:1px solid var(--rule-strong);
  transition:color .35s,border-color .35s;
}
.cta-ghost:hover{color:var(--ink);border-color:var(--ink)}

::selection{background:var(--ink);color:var(--ivory)}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:1px dashed var(--ink);outline-offset:6px}

/* ─── Hero (home) ────────────────────────────────────────── */
.hero{
  display:grid;
  grid-template-columns:minmax(0,1.55fr) minmax(280px,.7fr);
  min-height:calc(100vh - 64px - 44px);
}
.hero > .col{
  position:relative;
  padding:64px var(--pad-x) 56px;
}
.hero > .col + .col{border-left:1px solid var(--rule)}
.col-main{padding-right:clamp(28px,5vw,72px)}
.col-side{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;text-align:right}
.col-side .meta-block{text-align:right}

/* single-column hero modifier */
.hero--solo{grid-template-columns:1fr}
.hero--solo > .col-main{padding-right:var(--pad-x);max-width:var(--content-max);margin:0 auto;width:100%}

.headline{
  margin:34px 0 28px;
  font-weight:300;
  font-size:clamp(56px,9.4vw,164px);
  line-height:.93;
  letter-spacing:-.035em;
  color:var(--ink);
  font-feature-settings:"ss01","liga","dlig";
}
.headline .line{display:block;position:relative;overflow:hidden}
.headline .line > span{display:inline-block;transform:translateY(105%);will-change:transform}
.headline em{
  font-style:italic;
  font-variation-settings:"opsz" 144,"SOFT" 50,"WONK" 1;
  color:var(--jade);
  letter-spacing:-.03em;
}

.meta-block{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ink-soft);
  line-height:1.55;
  margin-bottom:42px;
}
.meta-block .label{
  display:block;
  color:var(--ink);
  letter-spacing:.32em;
  font-weight:500;
  margin-bottom:10px;
}
.count{
  display:block;
  font-family:var(--serif);
  font-style:italic;
  font-size:64px;
  line-height:1;
  color:var(--ink);
  margin-top:6px;
  letter-spacing:-.01em;
  font-feature-settings:"onum","tnum";
}
.count-cap{
  display:block;
  margin-top:8px;
  font-size:10px;
  letter-spacing:.28em;
}

.nebula-svg{width:160px;height:auto;opacity:.88;margin-bottom:auto}
.nebula-svg .orbit{fill:none;stroke:var(--ink);stroke-width:.4;opacity:.5}
.nebula-svg .ring{fill:none;stroke:var(--ink-soft);stroke-width:.4;stroke-dasharray:1 3}
.nebula-svg .star{fill:var(--ink)}
.nebula-svg .core{fill:url(#coreGrad)}

.col-quote{
  margin-top:auto;
  max-width:280px;
  text-align:right;
  font-family:var(--serif);
  font-style:italic;
  font-size:15px;
  line-height:1.55;
  color:var(--ink-soft);
}
.col-quote .attrib{
  display:block;
  font-style:normal;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.26em;
  text-transform:uppercase;
  margin-top:14px;
  color:var(--ink);
}

/* inline stats row under hero lede */
.stats-row{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:0;
  margin:48px 0 0;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.stats-row .stat{
  padding:22px 18px 22px 0;
  border-right:1px solid var(--rule);
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.stats-row .stat:last-child{border-right:0}
.stats-row .stat .v{
  display:block;
  font-family:var(--serif);
  font-style:italic;
  font-size:42px;
  line-height:1;
  letter-spacing:-.01em;
  color:var(--ink);
  margin-bottom:10px;
  font-feature-settings:"onum","tnum";
  text-transform:none;
}
.stats-row .stat .v em{color:var(--jade);font-style:italic}

/* ─── Steps (how-it-works) ───────────────────────────────── */
.steps{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:0;
  margin-top:48px;
  border-top:1px solid var(--rule);
}
.step{
  border-right:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  padding:44px clamp(24px,3vw,44px) 44px 0;
  position:relative;
}
.step:nth-child(2n){border-right:0;padding-left:clamp(24px,3vw,44px);padding-right:0}
.step__num{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.32em;
  color:var(--gold);
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  margin-bottom:24px;
}
.step__num .when{color:var(--ink-soft)}
.step__title{
  font-weight:300;
  font-size:clamp(28px,2.6vw,38px);
  line-height:1.1;
  letter-spacing:-.02em;
  margin:0 0 16px;
}
.step__title em{font-style:italic;color:var(--jade)}
.step__body{
  color:var(--ink-soft);
  font-size:16px;
  line-height:1.55;
  font-weight:300;
  max-width:46ch;
}

/* ─── Roles (open-roles) ─────────────────────────────────── */
.filters{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:32px 0 8px;
}
.filter{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  padding:8px 16px;
  border:1px solid var(--rule-strong);
  background:transparent;
  color:var(--ink-soft);
  cursor:pointer;
  transition:all .3s ease;
}
.filter:hover{color:var(--ink);border-color:var(--ink)}
.filter.active{background:var(--ink);color:var(--ivory);border-color:var(--ink)}

.roles{
  border-top:1px solid var(--rule-strong);
  margin-top:32px;
}
.role{
  display:grid;
  grid-template-columns:minmax(0,2.2fr) minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) auto;
  align-items:center;
  gap:24px;
  padding:28px 0;
  border-bottom:1px solid var(--rule);
  text-decoration:none;
  color:inherit;
  transition:padding .35s cubic-bezier(.2,.7,.2,1),background .35s;
  position:relative;
}
.role:hover{padding-left:18px;padding-right:18px;background:var(--ivory-deep)}
.role__title{
  font-size:clamp(20px,1.8vw,26px);
  font-weight:400;
  line-height:1.2;
  letter-spacing:-.01em;
  color:var(--ink);
}
.role__title em{font-style:italic;color:var(--jade)}
.role__firm{
  display:block;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--ink-mute);
  margin-top:8px;
}
.role__meta{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.role__comp{
  font-family:var(--serif);
  font-style:italic;
  font-size:20px;
  color:var(--ink);
  letter-spacing:-.01em;
}
.role__arrow{
  font-family:var(--mono);
  color:var(--ink-soft);
  transition:transform .35s,color .35s;
}
.role:hover .role__arrow{color:var(--ink);transform:translateX(6px)}

/* ─── Pricing tiers ──────────────────────────────────────── */
.tiers{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
  margin-top:48px;
}
.tier{
  background:var(--card);
  border:1px solid var(--rule);
  padding:40px 32px;
  display:flex;
  flex-direction:column;
  gap:22px;
  position:relative;
}
.tier--popular{
  background:var(--ink);
  color:var(--ivory);
  border-color:var(--ink);
}
.tier--popular *{color:inherit}
.tier__badge{
  position:absolute;
  top:-10px;
  left:32px;
  background:var(--gold);
  color:var(--ink);
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  padding:5px 12px;
}
.tier__name{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.tier--popular .tier__name{color:var(--ivory-deep);opacity:.75}
.tier__price{
  font-weight:300;
  font-size:54px;
  line-height:1;
  letter-spacing:-.02em;
}
.tier__price em{
  font-style:italic;
  color:var(--jade);
}
.tier--popular .tier__price em{color:var(--gold)}
.tier__price .small{
  font-size:14px;
  font-style:italic;
  color:var(--ink-soft);
  display:block;
  margin-top:6px;
  letter-spacing:0;
  font-feature-settings:normal;
}
.tier--popular .tier__price .small{color:var(--ivory-deep);opacity:.7}
.tier__desc{
  font-size:14px;
  line-height:1.55;
  color:var(--ink-soft);
  font-weight:300;
}
.tier--popular .tier__desc{color:var(--ivory-deep);opacity:.85}
.tier__list{list-style:none;margin:0;padding:0;display:grid;gap:10px;font-size:14px;font-weight:300}
.tier__list li{display:flex;align-items:flex-start;gap:10px;line-height:1.45}
.tier__list li::before{
  content:"";
  flex-shrink:0;
  width:5px;height:5px;
  background:var(--gold);
  transform:rotate(45deg);
  margin-top:8px;
}
.tier__cta{margin-top:auto;padding-top:8px}

/* faq */
.faq{
  margin-top:64px;
  border-top:1px solid var(--rule);
}
.faq__item{
  border-bottom:1px solid var(--rule);
  padding:24px 0;
}
.faq__q{
  font-weight:400;
  font-size:20px;
  letter-spacing:-.01em;
  margin:0 0 10px;
}
.faq__a{color:var(--ink-soft);font-size:15px;line-height:1.55;margin:0;font-weight:300}

/* ─── Form (book) ────────────────────────────────────────── */
.form{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:24px 32px;
  margin-top:40px;
  max-width:780px;
}
.form .field{display:flex;flex-direction:column;gap:8px}
.form .field--full{grid-column:1 / -1}
.form label{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.form input,
.form select,
.form textarea{
  background:transparent;
  border:0;
  border-bottom:1px solid var(--rule-strong);
  padding:10px 0 12px;
  font-family:var(--serif);
  font-size:18px;
  color:var(--ink);
  width:100%;
  transition:border-color .3s;
}
.form input:focus,
.form select:focus,
.form textarea:focus{
  outline:none;
  border-color:var(--ink);
}
.form textarea{resize:vertical;min-height:90px;font-family:var(--serif)}
.form select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--ink-soft) 50%),linear-gradient(135deg,var(--ink-soft) 50%,transparent 50%);background-position:calc(100% - 14px) center,calc(100% - 8px) center;background-size:6px 6px;background-repeat:no-repeat;padding-right:32px}
.form .submit-row{
  grid-column:1 / -1;
  display:flex;
  align-items:center;
  gap:24px;
  margin-top:16px;
  flex-wrap:wrap;
}
.form .legal{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.18em;
  color:var(--ink-mute);
  max-width:46ch;
}

.thanks{
  display:none;
  padding:32px 0;
  border-top:1px solid var(--rule);
  margin-top:32px;
}
.thanks.show{display:block;animation:fadeUp .8s cubic-bezier(.2,.7,.2,1) forwards}
.thanks .h2{margin-bottom:12px}

/* side panel on book page */
.book-grid{
  display:grid;
  grid-template-columns:minmax(0,1.6fr) minmax(280px,.7fr);
  gap:48px;
  align-items:start;
}
.book-aside{
  position:sticky;
  top:32px;
  background:var(--card);
  border:1px solid var(--rule);
  padding:32px;
}
.book-aside h3{
  margin:0 0 16px;
  font-weight:300;
  font-size:22px;
  letter-spacing:-.01em;
}
.book-aside .checklist{
  list-style:none;margin:0 0 24px;padding:0;
  display:grid;gap:10px;
  font-size:14px;font-weight:300;color:var(--ink-soft);line-height:1.5;
}
.book-aside .checklist li{display:flex;gap:10px;align-items:flex-start}
.book-aside .checklist li::before{content:"";flex-shrink:0;width:5px;height:5px;background:var(--gold);transform:rotate(45deg);margin-top:7px}
.book-aside .mini-quote{
  font-style:italic;
  font-size:14px;
  color:var(--ink-soft);
  line-height:1.5;
  padding-top:20px;
  border-top:1px solid var(--rule);
}
.book-aside .mini-quote .a{display:block;margin-top:10px;font-family:var(--mono);font-style:normal;font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink)}

/* ─── CTA strip section ──────────────────────────────────── */
.cta-strip{
  background:var(--ink);
  color:var(--ivory);
  padding:var(--pad-y) var(--pad-x);
  position:relative;
  overflow:hidden;
}
.cta-strip::after{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(80% 60% at 80% 20%, rgba(182,135,58,.18), transparent 60%);
  pointer-events:none;
}
.cta-strip__inner{
  max-width:var(--content-max);
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:48px;
  flex-wrap:wrap;
  position:relative;
}
.cta-strip h2{
  font-weight:300;
  font-size:clamp(32px,3.6vw,56px);
  line-height:1.05;
  letter-spacing:-.02em;
  margin:0;
  max-width:18ch;
}
.cta-strip h2 em{font-style:italic;color:var(--gold)}

/* ─── Ticker ─────────────────────────────────────────────── */
.ticker{
  position:relative;
  z-index:3;
  border-top:1px solid var(--rule);
  overflow:hidden;
  background:var(--ivory-deep);
}
.ticker__track{
  display:flex;
  gap:64px;
  padding:14px 0;
  white-space:nowrap;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink-soft);
  animation:slide 48s linear infinite;
}
.ticker__track span{display:inline-flex;align-items:center;gap:64px}
.ticker__track .dot{
  width:4px;height:4px;background:var(--ink-soft);
  border-radius:50%;
  display:inline-block;
}
.ticker__track em{font-style:italic;color:var(--ink);font-family:var(--serif);font-size:14px;letter-spacing:.02em;text-transform:none;padding:0 4px}
@keyframes slide{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ─── Footer ─────────────────────────────────────────────── */
.foot{
  position:relative;
  z-index:3;
  padding:48px var(--pad-x) 32px;
  border-top:1px solid var(--rule);
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:32px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-soft);
  max-width:var(--content-max);
  margin:0 auto;
}
.foot h4{
  margin:0 0 16px;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.32em;
  color:var(--ink);
  font-weight:500;
}
.foot ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.foot a{color:var(--ink-soft);text-decoration:none;transition:color .3s}
.foot a:hover{color:var(--ink)}
.foot__brand{
  font-family:var(--serif);
  font-size:18px;
  letter-spacing:.32em;
  color:var(--ink);
  text-transform:uppercase;
  margin-bottom:14px;
}
.foot__legal{
  grid-column:1 / -1;
  padding-top:24px;
  margin-top:24px;
  border-top:1px solid var(--rule);
  display:flex;
  justify-content:space-between;
  gap:24px;
  flex-wrap:wrap;
  font-size:10px;
  letter-spacing:.22em;
  color:var(--ink-mute);
}

/* ─── Reveal animations ──────────────────────────────────── */
.reveal{opacity:0;transform:translateY(14px);transition:opacity 1s ease,transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.headline.in .line > span{animation:rise 1.05s cubic-bezier(.2,.7,.2,1) forwards}
.headline.in .line:nth-child(1) > span{animation-delay:.10s}
.headline.in .line:nth-child(2) > span{animation-delay:.26s}
.headline.in .line:nth-child(3) > span{animation-delay:.42s}
@keyframes rise{from{transform:translateY(105%)}to{transform:translateY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.parallax{
  display:inline-block;
  transform:translate3d(var(--px,0),var(--py,0),0);
  transition:transform .6s cubic-bezier(.2,.7,.2,1);
  will-change:transform;
}

/* ─── Responsive ─────────────────────────────────────────── */
@media (max-width:1024px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero > .col + .col{border-left:0;border-top:1px solid var(--rule)}
  .col-side{align-items:flex-start;text-align:left}
  .col-side .meta-block,.col-quote{text-align:left}
  .col-quote{max-width:none}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .stats-row .stat:nth-child(2n){border-right:0}
  .steps{grid-template-columns:1fr}
  .step,.step:nth-child(2n){border-right:0;padding-right:0;padding-left:0}
  .tiers{grid-template-columns:1fr;gap:16px}
  .book-grid{grid-template-columns:1fr}
  .book-aside{position:static}
  .form{grid-template-columns:1fr}
  .role{grid-template-columns:1fr;gap:6px;padding:22px 0}
  .role:hover{padding-left:0;padding-right:0;background:transparent}
  .foot{grid-template-columns:1fr 1fr;gap:24px}
}
@media (max-width:640px){
  .topbar{grid-template-columns:auto auto;gap:12px;padding:18px var(--pad-x)}
  .centerline{display:none}
  .nav{gap:16px;font-size:10px}
  .headline{font-size:clamp(48px,13vw,84px)}
  .h1{font-size:clamp(40px,11vw,68px)}
  .cta-strip__inner{flex-direction:column;align-items:flex-start}
  .foot{grid-template-columns:1fr}
}

/* ─── City cycle (centerline) ────────────────────────────── */
.city-cycle{
  display:inline-block;
  position:relative;
  min-width:12ch;
  text-align:left;
  vertical-align:baseline;
  font-style:italic;
  font-family:var(--serif);
  text-transform:none;
  color:var(--ink);
  letter-spacing:.04em;
  font-size:13px;
  padding-left:6px;
}
.city-cycle .city-text{
  display:inline-block;
  transition:opacity .35s ease, transform .35s cubic-bezier(.2,.7,.2,1);
}
.city-cycle.fade .city-text{opacity:0;transform:translateY(-4px)}

/* ─── Legal prose (privacy page) ─────────────────────────── */
.legal-prose{
  max-width:64ch;
  color:var(--ink-soft);
  font-weight:300;
  font-size:17px;
  line-height:1.62;
  counter-reset:legalsection;
  margin-top:24px;
}
.legal-prose h2{
  margin:56px 0 18px;
  font-weight:300;
  font-size:clamp(22px,2.2vw,32px);
  letter-spacing:-.01em;
  color:var(--ink);
  counter-increment:legalsection;
}
.legal-prose h2::before{
  content:counter(legalsection,decimal-leading-zero) " · ";
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.28em;
  color:var(--gold);
  text-transform:uppercase;
  padding-right:6px;
  display:inline-block;
  transform:translateY(-4px);
}
.legal-prose h2 em{font-style:italic;color:var(--jade)}
.legal-prose p{margin:0 0 16px;color:var(--ink-soft)}
.legal-prose ul{margin:0 0 20px;padding-left:0;list-style:none;display:grid;gap:8px}
.legal-prose ul li{padding-left:20px;position:relative;color:var(--ink-soft);line-height:1.5}
.legal-prose ul li::before{content:"";position:absolute;left:0;top:11px;width:5px;height:5px;background:var(--gold);transform:rotate(45deg)}
.legal-prose strong{color:var(--ink);font-weight:500}
.legal-prose a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.legal-prose .meta-line{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--ink-mute);
  display:block;
  margin:8px 0 32px;
}
.legal-prose .addr{
  font-family:var(--mono);
  background:var(--card);
  border-left:2px solid var(--gold);
  padding:18px 22px;
  margin:8px 0 28px;
  font-size:13px;
  letter-spacing:.06em;
  line-height:1.75;
  color:var(--ink);
  text-transform:none;
}
.legal-prose .addr .l{display:block}
.legal-prose .addr .k{display:block;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:8px}
.legal-prose .toc{
  list-style:none;padding:0;margin:24px 0 40px;
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 32px;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  padding:18px 0;
}
.legal-prose .toc li{padding-left:0}
.legal-prose .toc li::before{display:none}
.legal-prose .toc a{
  font-family:var(--mono);
  text-decoration:none;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-soft);
  display:flex;
  gap:10px;
  padding:4px 0;
}
.legal-prose .toc a:hover{color:var(--ink)}
.legal-prose .toc a .num{color:var(--gold)}
@media (max-width:640px){
  .legal-prose .toc{grid-template-columns:1fr}
}
