/* ============================================================
   BlockHound — shared stylesheet
   Source of truth for tokens + components used across the site.

   Load order:  <link rel="stylesheet" href="styles.css">  goes BEFORE
   any inline <style>, so per-page inline rules win the cascade where
   the page needs to override (e.g. on the new system pages, the inline
   token block is identical to the one below — this file is the fallback
   and the canonical reference).

   Sections:
     1.  Brand tokens (OKLCH + hex)
     2.  Base reset
     3.  Typography utilities
     4.  Masthead (dark editorial nav)
     5.  Buttons & link-arrows
     6.  Hero (dark, masked left-edge feather)
     7.  CTA band (red gradient)
     8.  Reveal animation
     9.  Shared footer (.site-footer)
     10. Legacy classes — preserved for contact.html and any
         Tailwind-era page still importing them. Do not extend.
============================================================ */


/* ============================================================
   1. BRAND TOKENS
============================================================ */
:root{
  /* Ink scale (warm-red tinted near-blacks) */
  --ink:        oklch(0.13 0.012 22);
  --ink-2:      oklch(0.18 0.015 22);
  --ink-3:      oklch(0.30 0.014 22);

  /* Light scale */
  --bone:       oklch(0.97 0.011 35);
  --paper:      oklch(0.95 0.013 35);
  --paper-2:    oklch(0.92 0.016 30);

  /* Brand reds — exact swatches from the brand kit */
  --red:         #E9364D;     /* primary */
  --red-medium:  #B31E31;
  --red-deep:    #791421;
  --red-darkest: #4D0D15;
  --red-light:   #E57B82;
  --red-blush:   #F6DCDC;

  /* Brand gradients */
  --grad-cta:    linear-gradient(135deg, rgb(158,32,41) 0%, rgb(228,78,88) 50%, rgb(251,68,51) 100%);
  --grad-dark:   linear-gradient(135deg, rgb(179,30,49) 0%, rgb(77,13,21) 100%);
  --grad-fade:   linear-gradient(90deg, #E9364D 0%, transparent 100%);

  /* Type ink */
  --mute:        oklch(0.65 0.012 25);
  --mute-d:      oklch(0.50 0.012 25);

  /* Hairlines */
  --rule:        oklch(0.97 0.011 35 / .14);
  --rule-soft:   oklch(0.97 0.011 35 / .08);
  --rule-dark:   oklch(0.13 0.012 22 / .14);
  --rule-dark-soft: oklch(0.13 0.012 22 / .08);

  /* Type stacks */
  --sans:        'Geist', ui-sans-serif, system-ui, sans-serif;
  --mono:        'Geist Mono', ui-monospace, monospace;

  /* Page padding scale */
  --pad-x:       clamp(1.25rem, 4vw, 2.75rem);

  /* --- Legacy aliases (kept for contact.html and old utility classes) --- */
  --coal:#15120f;
  --ash:#1f1c19;
  --ink-soft:#26221e;
  --line:rgba(245,240,230,.10);
  --line-d:rgba(14,12,10,.10);
  --rust:#a23332;
  --oxblood:#6e1d1d;
  --ember:#c7423f;
  --clay:#d9c0b2;
  --clay-deep:#c9a797;
}


/* ============================================================
   2. BASE
============================================================ */
*{ box-sizing:border-box; }
html, body{ margin:0; padding:0; background:var(--ink); color:var(--bone); }
body{
  font-family: var(--sans); font-weight:300;
  font-feature-settings: "ss01","ss03","cv11";
  letter-spacing: -0.005em;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
a{ color:inherit; text-decoration:none; }
img,video{ display:block; max-width:100%; }
button{ font:inherit; cursor:pointer; background:none; border:0; color:inherit; }
::selection{ background:var(--red); color:var(--bone); }

.frame{ max-width:1480px; margin-inline:auto; padding-inline:var(--pad-x); }


/* ============================================================
   3. TYPOGRAPHY UTILITIES
============================================================ */
.tx-display-xl{ font-weight:200; font-size:clamp(2.75rem, 7vw, 6.4rem); letter-spacing:-0.05em; line-height:.98; }
.tx-display-l { font-weight:200; font-size:clamp(2.4rem, 5.4vw, 5rem);   letter-spacing:-0.045em; line-height:1.0; }
.tx-display-m { font-weight:300; font-size:clamp(1.75rem, 3.6vw, 3.2rem); letter-spacing:-0.034em; line-height:1.06; }
.tx-display-s { font-weight:400; font-size:clamp(1.2rem, 1.8vw, 1.6rem);  letter-spacing:-0.022em; line-height:1.15; }
.tx-body      { font-weight:300; font-size:.97rem; line-height:1.65; max-width:64ch; color:oklch(0.97 0.011 35 / .72); }
.tx-mono-s    { font-family:var(--mono); font-weight:400; font-size:.69rem; letter-spacing:.18em; text-transform:uppercase; color:var(--mute); }

.balance      { text-wrap:balance; }


/* ============================================================
   4. MASTHEAD — dark editorial nav (absolute, sits over hero)
============================================================ */
.masthead{
  position:absolute; inset:0 0 auto 0; z-index:30;
  padding-block:1.5rem 1.25rem;
}
.masthead-inner{
  display:grid; grid-template-columns:auto 1fr auto;
  align-items:center; gap:1rem;
}
@media (min-width:880px){ .masthead-inner{ grid-template-columns:1fr auto 1fr; gap:2rem; } }
.masthead .brand{
  justify-self:start; display:inline-flex; align-items:center;
  flex-shrink:0;                /* never compress the logo cell */
}
.masthead .brand img{
  height:44px; width:auto; display:block;
  max-width:none;
}

.masthead-nav{ display:none; justify-content:center; align-items:center; gap:2.25rem; }
.masthead-nav a{
  font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
  font-weight:400; color:oklch(0.97 0.011 35 / .68);
  transition:color .25s;
}
.masthead-nav a:hover,
.masthead-nav a.is-on{ color:var(--bone); }

.masthead-cta{
  justify-self:end;
  display:none;                  /* hidden on mobile — burger replaces it */
  align-items:center; gap:.6rem;
  padding:.7rem 1.15rem; border-radius:999px;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--bone); background:var(--grad-dark);
  border:1px solid oklch(0.55 0.20 25 / .35);
  box-shadow: 0 16px 38px -16px rgba(179,30,49,.55), inset 0 1px 0 rgba(255,255,255,.08);
  transition: transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s;
}
.masthead-cta:hover{
  transform:translateY(-1px);
  box-shadow: 0 22px 46px -16px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.12);
}
.masthead-cta .dot{
  width:6px; height:6px; border-radius:999px; background:var(--bone);
  box-shadow:0 0 0 3px oklch(1 0 0 / .15);
}

/* Burger button — mobile only */
.masthead-burger{
  justify-self:end;
  display:inline-flex; flex-direction:column;
  justify-content:center; align-items:center;
  width:44px; height:44px;            /* full tap target */
  gap:5px; padding:0;
  background:oklch(0.13 0.012 22 / .55);
  border:1px solid oklch(0.97 0.011 35 / .22);
  border-radius:10px; cursor:pointer;
  backdrop-filter:blur(8px);
  transition: background .2s, border-color .2s;
}
.masthead-burger:hover{ border-color:var(--bone); }
.masthead-burger span{
  display:block; width:18px; height:1.5px;
  background:var(--bone); border-radius:1px;
  transition: transform .3s cubic-bezier(.16,1,.3,1), opacity .2s;
}
.masthead-burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
.masthead-burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.masthead-burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }

/* Mobile menu panel — slides down from top */
.masthead-panel{
  position:fixed; inset:0; z-index:35;
  background:var(--ink);
  padding: 6rem var(--pad-x) 2.5rem;
  display:flex; flex-direction:column; gap:.25rem;
  transform: translateY(-100%);
  transition: transform .35s cubic-bezier(.16,1,.3,1);
  overflow-y:auto;
}
.masthead-panel.is-open{ transform: translateY(0); }
.masthead-panel a{
  display:block;
  font-family:var(--mono); font-size:1.05rem; letter-spacing:.06em; text-transform:uppercase;
  color:var(--bone);
  padding:1.2rem 0;
  border-bottom:1px solid oklch(0.97 0.011 35 / .12);
}
.masthead-panel a.is-on{ color:var(--red); }
.masthead-panel a.panel-cta{
  margin-top:2rem; padding:1rem 1.5rem;
  border:0; border-radius:999px;
  background:var(--grad-cta); color:var(--bone);
  text-align:center; font-size:.85rem;
  box-shadow: 0 18px 38px -14px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.18);
}
.masthead-panel .panel-meta{
  margin-top:auto; padding-top:2rem;
  font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase;
  color:oklch(0.97 0.011 35 / .45);
  display:flex; flex-direction:column; gap:.5rem;
}
.masthead-panel .panel-meta a{
  display:inline; padding:0; border:0;
  text-transform:none; letter-spacing:.04em; font-size:.68rem;
  color:oklch(0.97 0.011 35 / .65);
}

@media (min-width:880px){
  .masthead-nav{ display:flex; }
  .masthead-cta{ display:inline-flex; }
  .masthead-burger{ display:none; }
  .masthead-panel{ display:none; }
}

/* Lock body scroll when menu is open */
body.menu-open{ overflow:hidden; }

/* When menu is open, pin the masthead above the panel so the X (close) stays
   visible and tappable at the top-right no matter where the page was scrolled. */
body.menu-open .masthead{ position:fixed; z-index:40; }
body.menu-open .masthead-burger{
  background: oklch(0.97 0.011 35 / .08);
  border-color: oklch(0.97 0.011 35 / .4);
}


/* ============================================================
   5. BUTTONS & LINK-ARROWS
============================================================ */
.btn{
  display:inline-flex; align-items:center; gap:.85rem;
  padding:1.1rem 1.65rem; border-radius:999px;
  font-size:.86rem; font-weight:500; letter-spacing:.005em;
  transition: transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s, background .25s, color .25s, border-color .25s;
}
.btn:hover{ transform:translateY(-1px); }
.btn:active{ transform:translateY(0) scale(.99); }

.btn-grad{
  color:var(--bone); background:var(--grad-cta);
  box-shadow: 0 24px 50px -18px rgba(228,78,88,.55),
              inset 0 1px 0 rgba(255,255,255,.18),
              0 1px 0 rgba(80,8,15,.5);
  position:relative; overflow:hidden;
}
.btn-grad::before{
  content:""; position:absolute; inset:0; border-radius:inherit;
  background:linear-gradient(135deg, rgba(255,255,255,.18) 0%, transparent 40%);
  pointer-events:none;
}
.btn-grad:hover{ box-shadow: 0 32px 60px -18px rgba(251,68,51,.65), inset 0 1px 0 rgba(255,255,255,.22); }
.btn-grad .dot{ width:7px; height:7px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 4px rgba(255,255,255,.18); }

.btn-ghost-dark{
  background:transparent; color:var(--bone);
  border:1px solid oklch(0.97 0.011 35 / .25);
}
.btn-ghost-dark:hover{ border-color:var(--bone); background:oklch(0.97 0.011 35 / .04); }

.btn-ghost-light{
  background:transparent; color:var(--ink);
  border:1px solid oklch(0.13 0.012 22 / .32);
}
.btn-ghost-light:hover{ border-color:var(--ink); background:oklch(0.13 0.012 22 / .03); }

/* Mono red CTA arrow link used inline */
.link-arrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--red-medium);
  transition: color .25s, gap .25s;
}
.link-arrow .ar{ transition: transform .35s cubic-bezier(.16,1,.3,1); display:inline-block; }
.link-arrow:hover{ color:var(--red); }
.link-arrow:hover .ar{ transform: translateX(4px); }
.link-arrow.on-dark{ color:#ff8a8a; }
.link-arrow.on-dark:hover{ color:var(--bone); }


/* ============================================================
   6. HERO — dark, video/image right, masked left-edge feather
============================================================ */
.hero{
  position:relative; min-height:auto; overflow:hidden;
  background:var(--ink); isolation:isolate;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding-block: clamp(8rem, 16vh, 11rem) clamp(2.5rem, 5vh, 4rem);
}
.hero-bg{ position:absolute; inset:0; z-index:1; overflow:hidden; }
.hero-bg img,
.hero-bg video{
  position:absolute; right:0; top:0; height:100%; width:72%;
  object-fit:cover; object-position:center;
  -webkit-mask-image:
    linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%),
    linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  -webkit-mask-composite: source-in;
          mask-image:
    linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%),
    linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
          mask-composite: intersect;
  opacity:.85;
}
.hero::before{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:
    linear-gradient(180deg, oklch(0.13 0.012 22 / .92) 0%, oklch(0.13 0.012 22 / .35) 20%, transparent 40%),
    radial-gradient(45% 60% at 90% 50%, oklch(0.55 0.20 25 / .14), transparent 70%);
}
.hero-content{ position:relative; z-index:5; }
/* Hero frame: left-aligned with fixed padding, never centered.
   Other sections still use the standard centered .frame. */
.hero .frame{ max-width:none; margin-inline:0; padding-inline:var(--pad-x); text-align:left; }

.hero-eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.22em; text-transform:uppercase;
  color:oklch(0.97 0.011 35 / .82);
  margin-bottom: clamp(2rem, 4vh, 3rem);
}
.hero-eyebrow .pulse{ width:7px; height:7px; border-radius:999px; background:var(--red); position:relative; }
.hero-eyebrow .pulse::after{
  content:""; position:absolute; inset:-4px; border-radius:999px;
  border:1px solid var(--red); opacity:.5;
  animation: pulse 2s ease-out infinite;
}
@keyframes pulse{ 0%{transform:scale(.6); opacity:.6;} 100%{transform:scale(1.8); opacity:0;} }

.hero h1{
  margin:0; max-width:18ch; color:var(--bone);
  font-size:clamp(2.75rem, 7vw, 6.4rem); font-weight:200;
  line-height:.98; letter-spacing:-0.05em;
}
.hero .sub{
  margin: clamp(1.5rem, 2.4vh, 2rem) 0 0;
  max-width:58ch;
  font-size:clamp(.95rem, 1.05vw, 1.05rem); line-height:1.6; font-weight:300;
  color:oklch(0.97 0.011 35 / .78);
}
.hero .actions{
  margin-top: clamp(1.5rem, 3vh, 2.4rem);
  display:flex; flex-wrap:wrap; gap:.8rem; align-items:center;
}


/* ============================================================
   7. CTA BAND — red gradient closer
============================================================ */
.cta-band{ position:relative; overflow:hidden; background:var(--grad-dark); }
.cta-band::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(45% 80% at 8% 50%, rgba(251,68,51,.25), transparent 60%);
}
.cta-band-grid{
  position:relative; z-index:2;
  padding-block: clamp(4rem, 9vh, 6.5rem);
  display:grid; grid-template-columns:1fr; gap:2rem; align-items:center;
}
@media (min-width:880px){ .cta-band-grid{ grid-template-columns:1.2fr auto; } }
.cta-band-grid .tag{
  font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(246,220,220,.7);
}
.cta-band-grid h3{
  margin:1rem 0 0; max-width:24ch;
  font-weight:200; font-size:clamp(2rem, 4.4vw, 3.6rem); letter-spacing:-0.04em; line-height:1.02;
  color:var(--bone);
}
.cta-band-grid .actions{ display:flex; flex-wrap:wrap; gap:.75rem; align-items:center; }


/* ============================================================
   8. REVEAL — scroll-in fade-up
============================================================ */
.reveal{
  opacity:0; transform:translateY(22px);
  transition: opacity 1s cubic-bezier(.16,1,.3,1),
              transform 1s cubic-bezier(.16,1,.3,1);
}
.reveal.in{ opacity:1; transform:none; }


/* ============================================================
   9. SHARED FOOTER (.site-footer)
============================================================ */
.site-footer{
  background:var(--ink); color:var(--bone);
  border-top:1px solid var(--rule-soft);
  font-family: var(--sans); font-weight:300;
}
.site-footer .frame{ max-width:1480px; margin-inline:auto; padding-inline:var(--pad-x); }
.site-footer .footer-top{
  padding-block: clamp(4rem, 9vh, 6rem);
  display:grid; grid-template-columns:1fr; gap:3rem;
}
@media (min-width:920px){
  .site-footer .footer-top{ grid-template-columns:1.4fr repeat(4, 1fr); gap:2.5rem; }
}
.site-footer .footer-brand img{ height:44px; width:auto; display:block; }
.site-footer .footer-tag{
  color:oklch(0.97 0.011 35 / .65);
  font-size:.92rem; line-height:1.65;
  margin:1.25rem 0 0; max-width:34ch;
}
.site-footer .footer-social{ display:flex; gap:.5rem; margin-top:1.5rem; }
.site-footer .footer-social a{
  width:36px; height:36px; border-radius:999px;
  border:1px solid oklch(0.97 0.011 35 / .15);
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--bone);
  transition: background .25s, border-color .25s, color .25s;
}
.site-footer .footer-social a:hover{
  background:oklch(0.97 0.011 35 / .05); border-color:var(--red); color:var(--red);
}
.site-footer .footer-col h4{
  margin:0 0 1.25rem;
  font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase;
  color:oklch(0.97 0.011 35 / .55); font-weight:400;
}
.site-footer .footer-col ul{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:.65rem;
}
.site-footer .footer-col a{
  font-size:.9rem; color:oklch(0.97 0.011 35 / .82);
  transition:color .2s;
}
.site-footer .footer-col a:hover{ color:var(--red); }
.site-footer .footer-base{
  padding-block: 1.75rem 2.5rem;
  border-top:1px solid var(--rule);
  display:grid; grid-template-columns:1fr; gap:1rem;
}
@media (min-width:760px){ .site-footer .footer-base{ grid-template-columns:1fr auto; align-items:end; } }
.site-footer .footer-base .legal{
  color:oklch(0.97 0.011 35 / .45);
  font-size:.74rem; line-height:1.6; max-width:80ch; margin:0;
}
.site-footer .footer-base .mark{
  font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase;
  color:oklch(0.97 0.011 35 / .42); text-align:right;
}


/* ============================================================
   10. LEGACY — preserved for contact.html and any Tailwind-era page.
       Do not extend; new components belong in the sections above.
============================================================ */

/* All-Geist display alias (legacy `.font-display`) */
.font-display{
  font-family:var(--sans); font-weight:300;
  letter-spacing:-0.045em;
  font-feature-settings:"ss01","ss03","cv11";
}
.num{ font-family:var(--mono); font-feature-settings:"tnum","ss01"; font-weight:400; }
.eyebrow{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--mute); font-weight:400; }
.eyebrow.dark{ color:var(--mute-d); }

/* Grain */
.grain{
  position:fixed; inset:0; z-index:60; pointer-events:none; opacity:.07; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.85'/></svg>");
}

/* Common surfaces */
.hairline-b{ border-bottom:1px solid var(--line); }
.hairline-t{ border-top:1px solid var(--line); }
.hairline{ border:1px solid var(--line); }
.cream{ background:var(--paper); color:var(--ink); }
.cream .hairline,.cream .hairline-b,.cream .hairline-t{ border-color:var(--line-d); }
.cream .eyebrow{ color:#6a625a; }
.cream .num{ color:var(--ink); }
.coal{ background:linear-gradient(180deg,#141210, #0d0c0b); }
.ash { background:var(--ash); }

/* Legacy CTA (warm rust, used in contact.html) */
.cta{
  display:inline-flex; align-items:center; gap:.85rem;
  background:var(--bone); color:var(--ink);
  padding:1rem 1.4rem; border-radius:999px;
  font-size:14px; font-weight:500; letter-spacing:.01em;
  transition: transform .25s cubic-bezier(.2,.7,.2,1), background .25s, box-shadow .25s;
  box-shadow:0 12px 30px -10px rgba(162,51,50,.35), inset 0 1px 0 rgba(255,255,255,.4);
}
.cta:hover{ transform:translateY(-2px); background:#fff; box-shadow:0 20px 40px -10px rgba(162,51,50,.55), inset 0 1px 0 rgba(255,255,255,.6); }
.cta:active{ transform:translateY(0) scale(.98); }
.cta .dot{ width:7px; height:7px; border-radius:999px; background:var(--rust); box-shadow:0 0 0 4px rgba(162,51,50,.18); }
.cta.rust{ background:var(--rust); color:var(--bone); box-shadow:0 14px 34px -10px rgba(162,51,50,.6), inset 0 1px 0 rgba(255,255,255,.18); }
.cta.rust:hover{ background:var(--ember); }
.cta.rust .dot{ background:var(--bone); box-shadow:0 0 0 4px rgba(241,236,228,.25); }

.ghost{
  display:inline-flex; align-items:center; gap:.85rem;
  border:1px solid rgba(241,236,228,.22); color:var(--bone);
  padding:1rem 1.4rem; border-radius:999px; font-size:14px;
  transition: border-color .25s, background .25s, transform .25s;
}
.ghost:hover{ border-color:rgba(241,236,228,.45); background:rgba(241,236,228,.04); transform:translateY(-1px); }
.cream .ghost{ border-color:rgba(10,9,8,.2); color:var(--ink); }
.cream .ghost:hover{ border-color:rgba(10,9,8,.45); background:rgba(10,9,8,.04); }

/* Legacy floating-pill nav (only contact.html still uses) */
.nav-wrap{ position:fixed; top:0; inset-inline:0; z-index:50; }
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:.55rem .6rem .55rem 1.25rem; border-radius:999px;
  backdrop-filter:blur(20px); background:rgba(10,9,8,.55);
  border:1px solid rgba(255,255,255,.06);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04), 0 10px 30px -10px rgba(0,0,0,.6);
}
.nav a.brand{ display:flex; align-items:center; gap:.5rem; }
.nav a.brand img{ height:44px; width:auto; display:block; }
.nav ul{ display:none; align-items:center; gap:2.1rem; font-size:13px; color:rgba(241,236,228,.78); }
.nav ul a{ transition:color .2s; }
.nav ul a:hover,.nav ul a.active{ color:var(--bone); }
@media (min-width: 900px){ .nav ul{ display:flex; } }

/* Form fields (contact.html) */
.field{
  background:transparent; border:0; border-bottom:1px solid rgba(241,236,228,.18);
  padding:14px 2px; width:100%; color:var(--bone);
  transition:border-color .25s; font-family:var(--sans); font-size:15px; font-weight:300;
}
.field::placeholder{ color:#6a625a; font-weight:300; }
.field:focus{ outline:none; border-color:var(--rust); }
.cream .field{ border-color:rgba(10,9,8,.2); color:var(--ink); }
.cream .field::placeholder{ color:#928a7d; }
.cream .field:focus{ border-color:var(--rust); }

/* Step indicator (contact.html 2-step form) */
.steps{ display:flex; gap:.5rem; align-items:center; font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; }
.steps .seg{ width:34px; height:2px; background:rgba(10,9,8,.15); }
.steps .seg.on{ background:var(--rust); }
.dark .steps .seg{ background:rgba(241,236,228,.18); }
.dark .steps .seg.on{ background:var(--rust); }

/* Other legacy utility classes preserved for compatibility */
.page-tag{ display:inline-flex; gap:.55rem; align-items:center; padding:.45rem .8rem; border-radius:999px; border:1px solid var(--line); font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--mute); }
.cream .page-tag{ border-color:rgba(10,9,8,.15); color:#6a625a; }
.pill{ display:inline-flex; align-items:center; gap:.55rem; padding:.55rem 1rem; border-radius:999px; border:1px solid rgba(10,9,8,.15); font-size:13px; color:var(--ink); background:transparent; transition:all .25s; }
.pill:hover{ border-color:rgba(10,9,8,.4); }
.pill.is-active{ background:var(--ink); color:var(--bone); border-color:var(--ink); }
.pill .dot{ width:6px; height:6px; border-radius:999px; background:var(--rust); }
.lift{ box-shadow:0 30px 60px -25px rgba(10,9,8,.55), 0 8px 20px -10px rgba(10,9,8,.4); }
.lift-light{ box-shadow:0 30px 60px -25px rgba(10,9,8,.18), 0 6px 16px -8px rgba(10,9,8,.12); }
.editorial-rule{ display:grid; grid-template-columns:auto 1fr auto; gap:1.5rem; align-items:center; color:var(--mute); }
.editorial-rule .line{ height:1px; background:currentColor; opacity:.25; }
.cream .editorial-rule{ color:#6a625a; }
.footer-mark{ filter:none; opacity:.94; width:100%; display:block; }
.case-img{ transition: transform 1.2s cubic-bezier(.2,.7,.2,1), filter .8s; filter:saturate(.92) contrast(1.05); }
.case-frame:hover .case-img{ transform:scale(1.04); filter:saturate(1.05); }
.ribbed{ background-image:repeating-linear-gradient(90deg, rgba(10,9,8,0) 0 6px, rgba(10,9,8,.32) 6px 7px); }
.ribbed-light{ background-image:repeating-linear-gradient(90deg, rgba(241,236,228,0) 0 6px, rgba(241,236,228,.18) 6px 7px); }
.sec{ padding-block:7rem; }
@media (min-width:768px){ .sec{ padding-block:10rem; } }
.marquee{ display:flex; gap:5rem; width:max-content; animation:scroll 42s linear infinite; align-items:center; }
@keyframes scroll{ to{ transform:translateX(-50%); } }
.marquee-mask{ mask-image:linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent); overflow:hidden; }
.partner img{ filter:brightness(0) invert(1); opacity:.55; transition:opacity .3s; max-height:28px; }
.partner:hover img{ opacity:1; }
.cream .partner img{ filter:none; opacity:.7; }

/* Legacy .svc-row from the old services page — kept for any page that
   might still import it, but renamed effectively (the new services page
   uses .disc-item, never .svc-row). */
.svc-row-legacy{ transition:background .4s; display:grid; grid-template-columns:repeat(12,1fr); gap:1.5rem; align-items:baseline; border-bottom:1px solid var(--line); padding:2.5rem 0; }
.cream .svc-row-legacy{ border-color:var(--line-d); }

/* FAQ accordion (legacy) */
.accordion summary{ list-style:none; cursor:pointer; }
.accordion summary::-webkit-details-marker{ display:none; }
.accordion .plus{ transition: transform .35s cubic-bezier(.2,.7,.2,1); }
.accordion[open] .plus{ transform:rotate(45deg); }
.accordion[open] .ans{ animation: fadeUp .55s cubic-bezier(.2,.7,.2,1); }
@keyframes fadeUp{ from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:none;} }
/* ============================================================
   CONSOLIDATED PAGE STYLES — generated from per-page inline <style> blocks.
============================================================ */

/* ============================================================
   PAGE: about.html
============================================================ */
/* ============================================================ BRAND TOKENS */
:root{
  --ink:        oklch(0.13 0.012 22);
  --ink-2:      oklch(0.18 0.015 22);
  --ink-3:      oklch(0.30 0.014 22);
  --bone:       oklch(0.97 0.011 35);
  --paper:      oklch(0.95 0.013 35);
  --paper-2:    oklch(0.92 0.016 30);

  --red:         #E9364D;
  --red-medium:  #B31E31;
  --red-deep:    #791421;

  --grad-cta:    linear-gradient(135deg, rgb(158,32,41) 0%, rgb(228,78,88) 50%, rgb(251,68,51) 100%);
  --grad-dark:   linear-gradient(135deg, rgb(179,30,49) 0%, rgb(77,13,21) 100%);

  --mute:        oklch(0.65 0.012 25);
  --mute-d:      oklch(0.50 0.012 25);
  --rule:        oklch(0.97 0.011 35 / .14);
  --rule-soft:   oklch(0.97 0.011 35 / .08);

  --sans:        'Geist', ui-sans-serif, system-ui, sans-serif;
  --mono:        'Geist Mono', ui-monospace, monospace;
  --pad-x:       clamp(1.25rem, 4vw, 2.75rem);
}

/* ============================================================ BASE */
*{ box-sizing:border-box; }
html, body{ margin:0; padding:0; background:var(--ink); color:var(--bone); }
body{
  font-family:var(--sans); font-weight:300;
  font-feature-settings:"ss01","ss03","cv11";
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{ color:inherit; text-decoration:none; }
img,video{ display:block; max-width:100%; }
button{ font:inherit; cursor:pointer; background:none; border:0; color:inherit; }
::selection{ background:var(--red); color:var(--bone); }
.frame{ max-width:1480px; margin-inline:auto; padding-inline:var(--pad-x); }

/* ============================================================ TYPE */
.tx-display-xl{ font-weight:200; font-size:clamp(2.75rem, 7vw, 6.4rem); letter-spacing:-0.05em; line-height:.98; }
.tx-display-l { font-weight:200; font-size:clamp(2.4rem, 5.4vw, 5rem);   letter-spacing:-0.045em; line-height:1.0; }
.tx-display-m { font-weight:300; font-size:clamp(1.75rem, 3.6vw, 3.2rem); letter-spacing:-0.034em; line-height:1.06; }
.tx-mono-s    { font-family:var(--mono); font-weight:400; font-size:.69rem; letter-spacing:.18em; text-transform:uppercase; color:var(--mute); }
.balance      { text-wrap:balance; }

/* ============================================================ MASTHEAD */
.masthead{ position:absolute; inset:0 0 auto 0; z-index:30; padding-block:1.5rem 1.25rem; }
.masthead-inner{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:2rem; }
.masthead .brand{ justify-self:start; display:inline-flex; align-items:center; }
.masthead .brand img{ height:44px; width:auto; display:block; }
.masthead-nav{ display:none; justify-content:center; align-items:center; gap:2.25rem; }
.masthead-nav a{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; font-weight:400; color:oklch(0.97 0.011 35 / .68); transition:color .25s; }
.masthead-nav a:hover, .masthead-nav a.is-on{ color:var(--bone); }
.masthead-cta{
  justify-self:end; display:inline-flex; align-items:center; gap:.6rem;
  padding:.7rem 1.15rem; border-radius:999px;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--bone); background:var(--grad-dark);
  border:1px solid oklch(0.55 0.20 25 / .35);
  box-shadow:0 16px 38px -16px rgba(179,30,49,.55), inset 0 1px 0 rgba(255,255,255,.08);
  transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s;
}
.masthead-cta:hover{ transform:translateY(-1px); box-shadow:0 22px 46px -16px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.12); }
.masthead-cta .dot{ width:6px; height:6px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 3px oklch(1 0 0 / .15); }
@media (min-width:880px){ .masthead-nav{ display:flex; } }

/* ============================================================ BUTTONS */
.btn{ display:inline-flex; align-items:center; gap:.85rem; padding:1.1rem 1.65rem; border-radius:999px; font-size:.86rem; font-weight:500; letter-spacing:.005em; transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s, background .25s, color .25s, border-color .25s; }
.btn:hover{ transform:translateY(-1px); }
.btn-grad{ color:var(--bone); background:var(--grad-cta); box-shadow:0 24px 50px -18px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.18), 0 1px 0 rgba(80,8,15,.5); position:relative; overflow:hidden; }
.btn-grad::before{ content:""; position:absolute; inset:0; border-radius:inherit; background:linear-gradient(135deg, rgba(255,255,255,.18) 0%, transparent 40%); pointer-events:none; }
.btn-grad .dot{ width:7px; height:7px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 4px rgba(255,255,255,.18); }
.btn-ghost-dark{ background:transparent; color:var(--bone); border:1px solid oklch(0.97 0.011 35 / .25); }
.btn-ghost-dark:hover{ border-color:var(--bone); background:oklch(0.97 0.011 35 / .04); }

.link-arrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--red-medium); transition:color .25s; }
.link-arrow .ar{ transition:transform .35s cubic-bezier(.16,1,.3,1); display:inline-block; }
.link-arrow:hover{ color:var(--red); }
.link-arrow:hover .ar{ transform:translateX(4px); }
.link-arrow.on-dark{ color:#ff8a8a; }
.link-arrow.on-dark:hover{ color:var(--bone); }

/* ============================================================ HERO */
.hero{ position:relative; min-height:90dvh; overflow:hidden; background:var(--ink); isolation:isolate; display:flex; flex-direction:column; justify-content:flex-end; padding-block:7rem clamp(7rem, 11vh, 10rem); }
.hero-bg{ position:absolute; inset:0; z-index:1; overflow:hidden; }
.hero-bg img{
  position:absolute; right:0; top:0; height:100%; width:72%;
  object-fit:cover; object-position:center;
  -webkit-mask-image:
    linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%),
    linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  -webkit-mask-composite: source-in;
          mask-image:
    linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%),
    linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  mask-composite: intersect;
  opacity:.85;
}
.hero::before{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:
    linear-gradient(180deg, oklch(0.13 0.012 22 / .92) 0%, oklch(0.13 0.012 22 / .35) 20%, transparent 40%),
    radial-gradient(45% 60% at 90% 50%, oklch(0.55 0.20 25 / .14), transparent 70%);
}
.hero-content{ position:relative; z-index:5; }
/* Hero frame: left-aligned, fixed padding identical on every page.
   Drops the centered max-width and uses var(--pad-x) for consistent left edge. */
.hero .frame{ max-width:none; margin-inline:0; padding-inline:var(--pad-x); text-align:left; }
.hero-eyebrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono); font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:oklch(0.97 0.011 35 / .82); margin-bottom:clamp(2rem, 4vh, 3rem); }
.hero-eyebrow .pulse{ width:7px; height:7px; border-radius:999px; background:var(--red); position:relative; }
.hero-eyebrow .pulse::after{ content:""; position:absolute; inset:-4px; border-radius:999px; border:1px solid var(--red); opacity:.5; animation:pulse 2s ease-out infinite; }
@keyframes pulse{ 0%{transform:scale(.6); opacity:.6;} 100%{transform:scale(1.8); opacity:0;} }
.hero h1{ margin:0; max-width:18ch; color:var(--bone); }
.hero .sub{ margin:clamp(1.5rem, 2.4vh, 2rem) 0 0; max-width:58ch; font-size:clamp(.95rem, 1.05vw, 1.05rem); line-height:1.6; font-weight:300; color:oklch(0.97 0.011 35 / .78); }
.hero .actions{ margin-top:clamp(1.5rem, 3vh, 2.4rem); display:flex; flex-wrap:wrap; gap:.8rem; align-items:center; }

/* ============================================================ STATS BAR — light */
.stats{ background:var(--bone); color:var(--ink); padding-block:clamp(4.5rem, 9vh, 7rem); position:relative; }
.stats-head{ display:grid; grid-template-columns:1fr; gap:.75rem; margin-bottom:clamp(2.5rem, 5vh, 4rem); padding-bottom:clamp(1.5rem, 3vh, 2rem); border-bottom:1px solid oklch(0.13 0.012 22 / .14); }
@media (min-width:920px){ .stats-head{ grid-template-columns:minmax(0,1fr) auto; align-items:end; gap:2rem; } }
.stats-head .chap{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.stats-head h2{ margin:.5rem 0 0; color:var(--ink); }
.stats-head .lead{ font-size:.97rem; line-height:1.6; font-weight:300; max-width:44ch; color:oklch(0.30 0.012 25); margin:0; }

.stats-grid{ display:grid; grid-template-columns:1fr; }
@media (min-width:820px){ .stats-grid{ grid-template-columns:repeat(3, 1fr); } }
.stats-col{ padding-block:clamp(1.8rem, 4vh, 2.6rem); display:flex; flex-direction:column; gap:.55rem; border-bottom:1px solid oklch(0.13 0.012 22 / .14); }
@media (min-width:820px){
  .stats-col{ padding-block:0; padding-inline:clamp(1rem, 2.5vw, 2rem); border-bottom:0; border-right:1px solid oklch(0.13 0.012 22 / .14); }
  .stats-col:first-child{ padding-left:0; }
  .stats-col:last-child{ border-right:0; padding-right:0; }
}
.stats-col .mark{ font-family:var(--mono); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:var(--mute-d); }
.stats-col .fig{ font-family:var(--mono); font-weight:300; font-size:clamp(3rem, 5.4vw, 4.4rem); line-height:.95; letter-spacing:-0.035em; color:var(--ink); }
.stats-col .fig .unit{ font-family:var(--mono); font-weight:300; font-size:.42em; letter-spacing:-0.01em; color:var(--mute-d); margin-left:.2em; }
.stats-col h3{ margin:.75rem 0 0; font-weight:300; font-size:clamp(1.1rem, 1.5vw, 1.35rem); letter-spacing:-0.022em; line-height:1.18; color:var(--ink); }

/* ============================================================ STORY — dark, symmetric */
.story{ position:relative; overflow:hidden; background:var(--ink); color:var(--bone); padding-block:clamp(5rem, 11vh, 8rem); }
.story::before{ content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(40% 50% at 5% 0%, oklch(0.55 0.20 25 / .10), transparent 60%); }

/* Header: full-width chapter line + headline, hairline below */
.story-header{
  display:grid; grid-template-columns:1fr; gap:1.25rem;
  margin-bottom: clamp(3rem, 6vh, 4.5rem);
  padding-bottom: clamp(1.75rem, 3.5vh, 2.5rem);
  border-bottom:1px solid oklch(0.97 0.011 35 / .14);
}
@media (min-width:980px){ .story-header{ grid-template-columns:1fr 1fr; column-gap:clamp(3rem, 5vw, 5rem); align-items:end; } }
.story-header .chap{ display:inline-flex; align-items:center; gap:.65rem; font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.story-header .chap::before{ content:""; width:26px; height:1px; background:currentColor; display:inline-block; }
.story-header h2{ margin:.75rem 0 0; font-weight:200; font-size:clamp(2.2rem, 4vw, 3.4rem); letter-spacing:-0.04em; line-height:1.02; color:var(--bone); max-width:22ch; }
.story-header .lead{ margin:0; max-width:42ch; font-size:.97rem; line-height:1.6; font-weight:300; color:oklch(0.97 0.011 35 / .72); padding-bottom:.4rem; }

/* Two equal columns: portrait + narrative, stretched to equal heights */
.story-grid{ display:grid; grid-template-columns:1fr; gap:2.5rem; position:relative; align-items:stretch; }
@media (min-width:980px){ .story-grid{ grid-template-columns:1fr 1fr; gap:clamp(3rem, 5vw, 5rem); } }

.story-portrait{ position:relative; min-width:0; display:flex; }
.story-portrait .frame-img{
  flex:1; position:relative;
  border-radius:14px; overflow:hidden;
  background:var(--ink-2); border:1px solid oklch(0.97 0.011 35 / .08);
  min-height: 420px;
}
.story-portrait .frame-img img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.story-portrait .frame-img::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 55%, oklch(0.13 0.012 22 / .65) 100%); }
.story-portrait .badge{
  position:absolute; left:1rem; bottom:1rem; z-index:2;
  font-family:var(--mono); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--bone); background:oklch(0.13 0.012 22 / .55); padding:.4rem .65rem; border-radius:5px;
  backdrop-filter:blur(6px);
}

.story-body{ min-width:0; display:flex; flex-direction:column; gap: clamp(1.5rem, 3vh, 2rem); }
.story-body .lead{ margin:0; font-size:clamp(1.2rem, 1.7vw, 1.5rem); line-height:1.45; font-weight:300; letter-spacing:-0.018em; max-width:46ch; color:var(--bone); }
.story-body p.body{ margin:0; max-width:54ch; font-size:.97rem; line-height:1.65; font-weight:300; color:oklch(0.97 0.011 35 / .72); }
.story-body .pull{
  margin:0; padding: clamp(1.1rem, 2.4vh, 1.6rem) 0;
  border-top:1px solid oklch(0.97 0.011 35 / .14);
  border-bottom:1px solid oklch(0.97 0.011 35 / .14);
  font-weight:200; font-size:clamp(1.35rem, 2vw, 1.8rem);
  letter-spacing:-0.028em; line-height:1.2; color:var(--bone); max-width:32ch;
}
.story-body .pull::before{ content:"\201C"; display:inline; font-family:var(--mono); color:var(--red); margin-right:.15em; }
.story-body .pull::after{ content:"\201D"; display:inline; font-family:var(--mono); color:var(--red); }
.story-body .signoff{ display:flex; align-items:baseline; gap:1.25rem; flex-wrap:wrap; }
.story-body .signoff .who{ font-family:var(--mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:oklch(0.97 0.011 35 / .65); }
.story-body .signoff .role{ font-family:var(--mono); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:oklch(0.97 0.011 35 / .45); }
.story-body .cta-link{ margin-top: auto; padding-top: .5rem; align-self:flex-start; }

/* ============================================================ CTA BAND */
.cta-band{ position:relative; overflow:hidden; background:var(--grad-dark); }
.cta-band::before{ content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(45% 80% at 8% 50%, rgba(251,68,51,.25), transparent 60%); }
.cta-band-grid{ position:relative; z-index:2; padding-block:clamp(4rem, 9vh, 6.5rem); display:grid; grid-template-columns:1fr; gap:2rem; align-items:center; }
@media (min-width:880px){ .cta-band-grid{ grid-template-columns:1.2fr auto; } }
.cta-band-grid .tag{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(246,220,220,.7); }
.cta-band-grid h3{ margin:1rem 0 0; max-width:24ch; font-weight:200; font-size:clamp(2rem, 4.4vw, 3.6rem); letter-spacing:-0.04em; line-height:1.02; color:var(--bone); }
.cta-band-grid .actions{ display:flex; flex-wrap:wrap; gap:.75rem; align-items:center; }

/* ============================================================ REVEAL */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1); }
.reveal.in{ opacity:1; transform:none; }


/* ============================================================
   PAGE: services.html
============================================================ */
/* ============================================================
   BRAND TOKENS — matches index.html
   ============================================================ */
:root{
  --ink:        oklch(0.13 0.012 22);
  --ink-2:      oklch(0.18 0.015 22);
  --ink-3:      oklch(0.30 0.014 22);
  --bone:       oklch(0.97 0.011 35);
  --paper:      oklch(0.95 0.013 35);
  --paper-2:    oklch(0.92 0.016 30);

  --red:         #E9364D;
  --red-medium:  #B31E31;
  --red-deep:    #791421;

  --grad-cta:    linear-gradient(135deg, rgb(158,32,41) 0%, rgb(228,78,88) 50%, rgb(251,68,51) 100%);
  --grad-dark:   linear-gradient(135deg, rgb(179,30,49) 0%, rgb(77,13,21) 100%);

  --mute:        oklch(0.65 0.012 25);
  --mute-d:      oklch(0.50 0.012 25);
  --rule:        oklch(0.97 0.011 35 / .14);
  --rule-soft:   oklch(0.97 0.011 35 / .08);

  --sans:        'Geist', ui-sans-serif, system-ui, sans-serif;
  --mono:        'Geist Mono', ui-monospace, monospace;
  --pad-x:       clamp(1.25rem, 4vw, 2.75rem);
}

/* ============================================================ BASE */
*{ box-sizing:border-box; }
html, body{ margin:0; padding:0; background:var(--ink); color:var(--bone); }
body{
  font-family:var(--sans); font-weight:300;
  font-feature-settings:"ss01","ss03","cv11";
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{ color:inherit; text-decoration:none; }
img,video{ display:block; max-width:100%; }
button{ font:inherit; cursor:pointer; background:none; border:0; color:inherit; }
::selection{ background:var(--red); color:var(--bone); }
.frame{ max-width:1480px; margin-inline:auto; padding-inline:var(--pad-x); }

/* ============================================================ TYPE */
.tx-display-xl{ font-weight:200; font-size:clamp(2.75rem, 7vw, 6.4rem); letter-spacing:-0.05em; line-height:.98; }
.tx-display-l { font-weight:200; font-size:clamp(2.4rem, 5.4vw, 5rem);   letter-spacing:-0.045em; line-height:1.0; }
.tx-display-m { font-weight:300; font-size:clamp(1.75rem, 3.6vw, 3.2rem); letter-spacing:-0.034em; line-height:1.06; }
.tx-mono-s    { font-family:var(--mono); font-weight:400; font-size:.69rem; letter-spacing:.18em; text-transform:uppercase; color:var(--mute); }
.balance      { text-wrap:balance; }

/* ============================================================ MASTHEAD */
.masthead{
  position:absolute; inset:0 0 auto 0; z-index:30;
  padding-block:1.5rem 1.25rem;
}
.masthead-inner{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:2rem; }
.masthead .brand{ justify-self:start; display:inline-flex; align-items:center; }
.masthead .brand img{ height:44px; width:auto; display:block; }
.masthead-nav{ display:none; justify-content:center; align-items:center; gap:2.25rem; }
.masthead-nav a{
  font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
  font-weight:400; color:oklch(0.97 0.011 35 / .68); transition:color .25s;
}
.masthead-nav a:hover, .masthead-nav a.is-on{ color:var(--bone); }
.masthead-cta{
  justify-self:end; display:inline-flex; align-items:center; gap:.6rem;
  padding:.7rem 1.15rem; border-radius:999px;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--bone); background:var(--grad-dark);
  border:1px solid oklch(0.55 0.20 25 / .35);
  box-shadow:0 16px 38px -16px rgba(179,30,49,.55), inset 0 1px 0 rgba(255,255,255,.08);
  transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s;
}
.masthead-cta:hover{ transform:translateY(-1px); box-shadow:0 22px 46px -16px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.12); }
.masthead-cta .dot{ width:6px; height:6px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 3px oklch(1 0 0 / .15); }
@media (min-width:880px){ .masthead-nav{ display:flex; } }

/* ============================================================ BUTTONS */
.btn{
  display:inline-flex; align-items:center; gap:.85rem;
  padding:1.1rem 1.65rem; border-radius:999px;
  font-size:.86rem; font-weight:500; letter-spacing:.005em;
  transition: transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s, background .25s, color .25s, border-color .25s;
}
.btn:hover{ transform:translateY(-1px); }
.btn-grad{
  color:var(--bone); background:var(--grad-cta);
  box-shadow:0 24px 50px -18px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.18), 0 1px 0 rgba(80,8,15,.5);
  position:relative; overflow:hidden;
}
.btn-grad::before{ content:""; position:absolute; inset:0; border-radius:inherit; background:linear-gradient(135deg, rgba(255,255,255,.18) 0%, transparent 40%); pointer-events:none; }
.btn-grad .dot{ width:7px; height:7px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 4px rgba(255,255,255,.18); }
.btn-ghost-dark{ background:transparent; color:var(--bone); border:1px solid oklch(0.97 0.011 35 / .25); }
.btn-ghost-dark:hover{ border-color:var(--bone); background:oklch(0.97 0.011 35 / .04); }
.btn-ghost-light{ background:transparent; color:var(--ink); border:1px solid oklch(0.13 0.012 22 / .32); }
.btn-ghost-light:hover{ border-color:var(--ink); background:oklch(0.13 0.012 22 / .03); }

/* link with arrow */
.link-arrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--red-medium);
  transition:color .25s, gap .25s;
}
.link-arrow .ar{ transition:transform .35s cubic-bezier(.16,1,.3,1); display:inline-block; }
.link-arrow:hover{ color:var(--red); }
.link-arrow:hover .ar{ transform:translateX(4px); }
.link-arrow.on-dark{ color:#ff8a8a; }
.link-arrow.on-dark:hover{ color:var(--bone); }

/* ============================================================ HERO */
.hero{
  position:relative; min-height:90dvh;
  overflow:hidden; background:var(--ink);
  isolation:isolate;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding-block: 7rem clamp(2.5rem, 5vh, 4rem);
}
.hero-bg{ position:absolute; inset:0; z-index:1; overflow:hidden; }
.hero-bg img{
  position:absolute; right:0; top:0; height:100%; width:72%;
  object-fit:cover; object-position:center;
  -webkit-mask-image:
    linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%),
    linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  -webkit-mask-composite: source-in;
          mask-image:
    linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%),
    linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  mask-composite: intersect;
  opacity:.85;
}
.hero::before{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:
    linear-gradient(180deg, oklch(0.13 0.012 22 / .92) 0%, oklch(0.13 0.012 22 / .35) 20%, transparent 40%),
    radial-gradient(45% 60% at 90% 50%, oklch(0.55 0.20 25 / .14), transparent 70%);
}
.hero-content{ position:relative; z-index:5; }
/* Hero frame: left-aligned, fixed padding identical on every page.
   Drops the centered max-width and uses var(--pad-x) for consistent left edge. */
.hero .frame{ max-width:none; margin-inline:0; padding-inline:var(--pad-x); text-align:left; }
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.22em; text-transform:uppercase;
  color:oklch(0.97 0.011 35 / .82);
  margin-bottom: clamp(2rem, 4vh, 3rem);
}
.hero-eyebrow .pulse{ width:7px; height:7px; border-radius:999px; background:var(--red); position:relative; }
.hero-eyebrow .pulse::after{
  content:""; position:absolute; inset:-4px; border-radius:999px; border:1px solid var(--red); opacity:.5;
  animation:pulse 2s ease-out infinite;
}
@keyframes pulse{ 0%{transform:scale(.6); opacity:.6;} 100%{transform:scale(1.8); opacity:0;} }
.hero h1{ margin:0; max-width:18ch; color:var(--bone); }
.hero .sub{
  margin: clamp(1.5rem, 2.4vh, 2rem) 0 0;
  max-width:54ch;
  font-size:clamp(.95rem, 1.05vw, 1.05rem); line-height:1.6; font-weight:300;
  color:oklch(0.97 0.011 35 / .78);
}
.hero .actions{ margin-top: clamp(1.5rem, 3vh, 2.4rem); display:flex; flex-wrap:wrap; gap:.8rem; align-items:center; }

/* Tab pills */
.hero-pills{
  margin-top: clamp(3rem, 6vh, 4.5rem);
  display:flex; flex-wrap:wrap; gap:.55rem;
}
.hero-pill{
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.55rem .95rem; border-radius:999px;
  border:1px solid oklch(0.97 0.011 35 / .22);
  font-family:var(--mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase;
  color:oklch(0.97 0.011 35 / .85); background:oklch(0.13 0.012 22 / .35);
  backdrop-filter:blur(8px);
  transition:border-color .25s, background .25s, color .25s;
}
.hero-pill:hover{ border-color:var(--red); color:var(--bone); }
.hero-pill .dot{ width:5px; height:5px; border-radius:999px; background:var(--red); }

/* ============================================================ DISCIPLINE SECTIONS
   Sticky narrative rail + numbered service rows. Rail content varies
   between sections (stat / stat / text-only / textured image) to avoid
   the "four identical card grids" anti-pattern.
   ============================================================ */
.disc{ position:relative; overflow:hidden; padding-block: clamp(5rem, 10vh, 7.5rem); }
.disc.light{ background:var(--bone); color:var(--ink); }
.disc.dark { background:var(--ink); color:var(--bone); }
.disc.dark::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(40% 50% at 95% 0%, oklch(0.55 0.20 25 / .10), transparent 65%);
}

.disc-grid{ display:grid; grid-template-columns:1fr; gap:3rem; position:relative; }
@media (min-width:980px){
  .disc-grid{
    grid-template-columns: minmax(280px, 340px) 1fr;
    gap: clamp(3.5rem, 6vw, 6rem);
    align-items:start;
  }
}

/* — Left rail (top-aligned with items column) — */
.disc-rail{ position:relative; }

.disc-rail .chap{
  display:inline-flex; align-items:center; gap:.65rem;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--red);
}
.disc-rail .chap::before{
  content:""; width:26px; height:1px; background:currentColor;
  display:inline-block;
}
.disc-rail h2{
  margin:1.5rem 0 0;
  font-weight:200; font-size:clamp(2.4rem, 4.2vw, 3.6rem);
  letter-spacing:-0.042em; line-height:1.0;
}
.disc.light .disc-rail h2{ color:var(--ink); }
.disc.dark  .disc-rail h2{ color:var(--bone); }
.disc-rail .lead{
  margin:1.75rem 0 0; max-width:38ch;
  font-size:.98rem; line-height:1.6; font-weight:300;
}
.disc.light .disc-rail .lead{ color:oklch(0.30 0.012 25); }
.disc.dark  .disc-rail .lead{ color:oklch(0.97 0.011 35 / .72); }

.disc-rail .stat{
  margin-top:2rem; padding-top:1.4rem;
  border-top:1px solid oklch(0.13 0.012 22 / .14);
}
.disc.dark .disc-rail .stat{ border-top-color:oklch(0.97 0.011 35 / .14); }
.disc-rail .stat .fig{
  display:block; font-family:var(--mono); font-weight:300;
  font-size:1.85rem; letter-spacing:-0.025em; line-height:1;
}
.disc.light .disc-rail .stat .fig{ color:var(--ink); }
.disc.dark  .disc-rail .stat .fig{ color:var(--bone); }
.disc-rail .stat .lbl{
  display:block; margin-top:.5rem;
  font-family:var(--mono); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase;
}
.disc.light .disc-rail .stat .lbl{ color:var(--mute-d); }
.disc.dark  .disc-rail .stat .lbl{ color:oklch(0.97 0.011 35 / .55); }

.disc-rail .texture{
  margin-top:2rem;
  width:100%; aspect-ratio:5/4;
  border-radius:14px; overflow:hidden; position:relative;
  background:var(--ink-2);
  border:1px solid oklch(0.97 0.011 35 / .08);
}
.disc.light .disc-rail .texture{ border-color:oklch(0.13 0.012 22 / .10); }
.disc-rail .texture img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; opacity:.9;
}
.disc-rail .texture::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(135deg, transparent 35%, oklch(0.13 0.012 22 / .55) 100%);
}
.disc-rail .texture .badge{
  position:absolute; left:.85rem; bottom:.85rem; z-index:2;
  font-family:var(--mono); font-size:.6rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--bone);
  background:oklch(0.13 0.012 22 / .55); padding:.35rem .6rem; border-radius:5px;
  backdrop-filter:blur(6px);
}

.disc-rail .cta-link{
  margin-top:1.75rem;
  display:inline-flex; align-items:center; gap:.5rem;
}

/* — Right column: numbered services — */
.disc-items{ display:flex; flex-direction:column; min-width:0; }
.disc-item{
  display:grid; min-width:0;
  grid-template-columns: clamp(2.6rem, 4.5vw, 3.6rem) 1fr;
  gap: clamp(1.4rem, 3vw, 2.4rem);
  padding-block: clamp(2rem, 4vh, 2.75rem);
  border-bottom:1px solid oklch(0.13 0.012 22 / .14);
  transition:background .4s ease;
}
.disc.dark .disc-item{ border-bottom-color:oklch(0.97 0.011 35 / .14); }
.disc-item:first-child{ padding-top:0; border-top:1px solid oklch(0.13 0.012 22 / .14); }
.disc.dark .disc-item:first-child{ border-top-color:oklch(0.97 0.011 35 / .14); }
@media (min-width:980px){ .disc-item:first-child{ border-top:0; padding-top:0; } }
.disc.light .disc-item:hover{ background:linear-gradient(90deg, oklch(0.55 0.20 25 / .04), transparent 70%); }
.disc.dark  .disc-item:hover{ background:linear-gradient(90deg, oklch(0.55 0.20 25 / .07), transparent 70%); }

.disc-item .idx{
  font-family:var(--mono); font-weight:300;
  font-size: clamp(1.5rem, 2.6vw, 2.1rem); line-height:1;
  letter-spacing:-0.02em;
  color:var(--red);
}
.disc-item .body{ min-width:0; }
.disc-item h3{
  margin:0; font-weight:300;
  font-size: clamp(1.4rem, 2.2vw, 1.9rem);
  letter-spacing:-0.028em; line-height:1.1;
}
.disc.light .disc-item h3{ color:var(--ink); }
.disc.dark  .disc-item h3{ color:var(--bone); }
.disc-item p{
  margin:.85rem 0 0; max-width:58ch;
  font-size:.95rem; line-height:1.6; font-weight:300;
}
.disc.light .disc-item p{ color:oklch(0.30 0.012 25); }
.disc.dark  .disc-item p{ color:oklch(0.97 0.011 35 / .72); }

/* ============================================================ CTA BAND */
.cta-band{ position:relative; overflow:hidden; background:var(--grad-dark); }
.cta-band::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(45% 80% at 8% 50%, rgba(251,68,51,.25), transparent 60%);
}
.cta-band-grid{
  position:relative; z-index:2;
  padding-block: clamp(4rem, 9vh, 6.5rem);
  display:grid; grid-template-columns:1fr; gap:2rem; align-items:center;
}
@media (min-width:880px){ .cta-band-grid{ grid-template-columns:1.2fr auto; } }
.cta-band-grid .tag{
  font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(246,220,220,.7);
}
.cta-band-grid h3{
  margin:1rem 0 0; max-width:20ch;
  font-weight:200; font-size:clamp(2rem, 4.4vw, 3.6rem); letter-spacing:-0.04em; line-height:1.02;
  color:var(--bone);
}
.cta-band-grid .actions{ display:flex; flex-wrap:wrap; gap:.75rem; align-items:center; }

/* ============================================================ REVEAL */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1); }
.reveal.in{ opacity:1; transform:none; }


/* ============================================================
   PAGE: journal.html
============================================================ */
/* ============================================================ BRAND TOKENS */
:root{
  --ink:        oklch(0.13 0.012 22);
  --ink-2:      oklch(0.18 0.015 22);
  --ink-3:      oklch(0.30 0.014 22);
  --bone:       oklch(0.97 0.011 35);
  --paper:      oklch(0.95 0.013 35);
  --paper-2:    oklch(0.92 0.016 30);

  --red:         #E9364D;
  --red-medium:  #B31E31;
  --red-deep:    #791421;

  --grad-cta:    linear-gradient(135deg, rgb(158,32,41) 0%, rgb(228,78,88) 50%, rgb(251,68,51) 100%);
  --grad-dark:   linear-gradient(135deg, rgb(179,30,49) 0%, rgb(77,13,21) 100%);

  --mute:        oklch(0.65 0.012 25);
  --mute-d:      oklch(0.50 0.012 25);
  --rule:        oklch(0.97 0.011 35 / .14);
  --rule-soft:   oklch(0.97 0.011 35 / .08);

  --sans:        'Geist', ui-sans-serif, system-ui, sans-serif;
  --mono:        'Geist Mono', ui-monospace, monospace;
  --pad-x:       clamp(1.25rem, 4vw, 2.75rem);
}

/* ============================================================ BASE */
*{ box-sizing:border-box; }
html, body{ margin:0; padding:0; background:var(--ink); color:var(--bone); }
body{
  font-family:var(--sans); font-weight:300;
  font-feature-settings:"ss01","ss03","cv11";
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{ color:inherit; text-decoration:none; }
img,video{ display:block; max-width:100%; }
button{ font:inherit; cursor:pointer; background:none; border:0; color:inherit; }
::selection{ background:var(--red); color:var(--bone); }
.frame{ max-width:1480px; margin-inline:auto; padding-inline:var(--pad-x); }

/* ============================================================ TYPE */
.tx-display-xl{ font-weight:200; font-size:clamp(2.75rem, 7vw, 6.4rem); letter-spacing:-0.05em; line-height:.98; }
.tx-display-l { font-weight:200; font-size:clamp(2.4rem, 5.4vw, 5rem);   letter-spacing:-0.045em; line-height:1.0; }
.tx-display-m { font-weight:300; font-size:clamp(1.75rem, 3.6vw, 3.2rem); letter-spacing:-0.034em; line-height:1.06; }
.balance      { text-wrap:balance; }

/* ============================================================ MASTHEAD */
.masthead{ position:absolute; inset:0 0 auto 0; z-index:30; padding-block:1.5rem 1.25rem; }
.masthead-inner{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:2rem; }
.masthead .brand{ justify-self:start; display:inline-flex; align-items:center; }
.masthead .brand img{ height:44px; width:auto; display:block; }
.masthead-nav{ display:none; justify-content:center; align-items:center; gap:2.25rem; }
.masthead-nav a{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; font-weight:400; color:oklch(0.97 0.011 35 / .68); transition:color .25s; }
.masthead-nav a:hover, .masthead-nav a.is-on{ color:var(--bone); }
.masthead-cta{
  justify-self:end; display:inline-flex; align-items:center; gap:.6rem;
  padding:.7rem 1.15rem; border-radius:999px;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--bone); background:var(--grad-dark);
  border:1px solid oklch(0.55 0.20 25 / .35);
  box-shadow:0 16px 38px -16px rgba(179,30,49,.55), inset 0 1px 0 rgba(255,255,255,.08);
  transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s;
}
.masthead-cta:hover{ transform:translateY(-1px); box-shadow:0 22px 46px -16px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.12); }
.masthead-cta .dot{ width:6px; height:6px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 3px oklch(1 0 0 / .15); }
@media (min-width:880px){ .masthead-nav{ display:flex; } }

/* ============================================================ BUTTONS */
.btn{ display:inline-flex; align-items:center; gap:.85rem; padding:1.1rem 1.65rem; border-radius:999px; font-size:.86rem; font-weight:500; letter-spacing:.005em; transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s, background .25s, color .25s, border-color .25s; }
.btn:hover{ transform:translateY(-1px); }
.btn-grad{ color:var(--bone); background:var(--grad-cta); box-shadow:0 24px 50px -18px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.18), 0 1px 0 rgba(80,8,15,.5); position:relative; overflow:hidden; }
.btn-grad::before{ content:""; position:absolute; inset:0; border-radius:inherit; background:linear-gradient(135deg, rgba(255,255,255,.18) 0%, transparent 40%); pointer-events:none; }
.btn-grad .dot{ width:7px; height:7px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 4px rgba(255,255,255,.18); }
.btn-ghost-dark{ background:transparent; color:var(--bone); border:1px solid oklch(0.97 0.011 35 / .25); }
.btn-ghost-dark:hover{ border-color:var(--bone); background:oklch(0.97 0.011 35 / .04); }

.link-arrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--red-medium); transition:color .25s; }
.link-arrow .ar{ transition:transform .35s cubic-bezier(.16,1,.3,1); display:inline-block; }
.link-arrow:hover{ color:var(--red); }
.link-arrow:hover .ar{ transform:translateX(4px); }
.link-arrow.on-dark{ color:#ff8a8a; }
.link-arrow.on-dark:hover{ color:var(--bone); }

/* ============================================================ HERO */
.hero{ position:relative; min-height:auto; overflow:hidden; background:var(--ink); isolation:isolate; display:flex; flex-direction:column; justify-content:flex-end; padding-block:clamp(8rem, 16vh, 11rem) clamp(2.5rem, 5vh, 4rem); }
.hero-bg{ position:absolute; inset:0; z-index:1; overflow:hidden; }
.hero-bg img{
  position:absolute; right:0; top:0; height:100%; width:72%;
  object-fit:cover; object-position:center;
  -webkit-mask-image:
    linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%),
    linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  -webkit-mask-composite: source-in;
          mask-image:
    linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%),
    linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  mask-composite: intersect;
  opacity:.85;
}
.hero::before{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:
    linear-gradient(180deg, oklch(0.13 0.012 22 / .92) 0%, oklch(0.13 0.012 22 / .35) 20%, transparent 40%),
    radial-gradient(45% 60% at 90% 50%, oklch(0.55 0.20 25 / .14), transparent 70%);
}
.hero-content{ position:relative; z-index:5; }
/* Hero frame: left-aligned, fixed padding identical on every page.
   Drops the centered max-width and uses var(--pad-x) for consistent left edge. */
.hero .frame{ max-width:none; margin-inline:0; padding-inline:var(--pad-x); text-align:left; }
.hero-eyebrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono); font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:oklch(0.97 0.011 35 / .82); margin-bottom:clamp(2rem, 4vh, 3rem); }
.hero-eyebrow .pulse{ width:7px; height:7px; border-radius:999px; background:var(--red); position:relative; }
.hero-eyebrow .pulse::after{ content:""; position:absolute; inset:-4px; border-radius:999px; border:1px solid var(--red); opacity:.5; animation:pulse 2s ease-out infinite; }
@keyframes pulse{ 0%{transform:scale(.6); opacity:.6;} 100%{transform:scale(1.8); opacity:0;} }
.hero h1{
  margin:0; max-width:18ch; color:var(--bone);
  /* Locked to match About hero h1 exactly */
  font-size:clamp(2.75rem, 7vw, 6.4rem);
  font-weight:200;
  line-height:.98;
  letter-spacing:-0.05em;
}
.hero .sub{ margin:clamp(1.5rem, 2.4vh, 2rem) 0 0; max-width:58ch; font-size:clamp(.95rem, 1.05vw, 1.05rem); line-height:1.6; font-weight:300; color:oklch(0.97 0.011 35 / .78); }

/* Tab pills */
.hero-tabs{ margin-top:clamp(2.5rem, 5vh, 4rem); display:flex; flex-wrap:wrap; gap:.55rem; }
.hero-tab{
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.55rem 1rem; border-radius:999px;
  border:1px solid oklch(0.97 0.011 35 / .22);
  font-family:var(--mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase;
  color:oklch(0.97 0.011 35 / .85); background:oklch(0.13 0.012 22 / .35);
  backdrop-filter:blur(8px);
  transition:border-color .25s, background .25s, color .25s;
}
.hero-tab:hover, .hero-tab.is-on{ border-color:var(--red); color:var(--bone); }
.hero-tab .dot{ width:5px; height:5px; border-radius:999px; background:var(--red); }
.hero-tab .count{ font-weight:300; color:oklch(0.97 0.011 35 / .55); }

/* ============================================================ POSTS — light, editorial rows */
.posts{ background:var(--bone); color:var(--ink); padding-block:clamp(4.5rem, 9vh, 7rem); position:relative; }

.posts-head{
  display:grid; grid-template-columns:1fr; gap:.75rem;
  margin-bottom:clamp(2.5rem, 5vh, 4rem);
  padding-bottom:clamp(1.5rem, 3vh, 2.25rem);
  border-bottom:1px solid oklch(0.13 0.012 22 / .14);
}
@media (min-width:920px){ .posts-head{ grid-template-columns:1fr 1fr; column-gap:clamp(3rem, 5vw, 5rem); align-items:end; } }
.posts-head .chap{ display:inline-flex; align-items:center; gap:.65rem; font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.posts-head .chap::before{ content:""; width:26px; height:1px; background:currentColor; display:inline-block; }
.posts-head h2{ margin:.75rem 0 0; color:var(--ink); }
.posts-head .lead{ margin:0; max-width:44ch; font-size:.97rem; line-height:1.6; font-weight:300; color:oklch(0.30 0.012 25); padding-bottom:.4rem; }

.post-row{
  display:grid; grid-template-columns:1fr; gap:1.75rem;
  padding-block:clamp(2.25rem, 5vh, 3.75rem);
  border-bottom:1px solid oklch(0.13 0.012 22 / .14);
}
.post-row:first-of-type{ padding-top:0; }
@media (min-width:880px){
  .post-row{
    grid-template-columns: 5fr 7fr;
    column-gap:clamp(2.5rem, 5vw, 4rem);
    align-items:center;
  }
}
.post-row .img{
  position:relative; aspect-ratio:5/4;
  border-radius:14px; overflow:hidden;
  background:var(--paper-2);
  border:1px solid oklch(0.13 0.012 22 / .08);
  display:block;
}
.post-row .img img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 1.2s cubic-bezier(.16,1,.3,1); }
.post-row:hover .img img{ transform:scale(1.03); }
.post-row .img::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 55%, oklch(0.13 0.012 22 / .25) 100%); }
.post-row .img .file{
  position:absolute; left:.95rem; top:.95rem; z-index:2;
  font-family:var(--mono); font-size:.6rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--bone); background:oklch(0.13 0.012 22 / .55); padding:.35rem .55rem; border-radius:5px;
  backdrop-filter:blur(6px);
}

.post-row .body{ min-width:0; }
.post-row .meta{
  display:flex; flex-wrap:wrap; align-items:center; gap:.85rem;
  font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase;
}
.post-row .meta .type{ color:var(--red); }
.post-row .meta .date{ color:var(--mute-d); }
.post-row .meta .meta-dot{ width:3px; height:3px; border-radius:999px; background:var(--mute-d); }
.post-row h3{
  margin:1rem 0 0; font-weight:300;
  font-size:clamp(1.55rem, 2.4vw, 2.2rem);
  letter-spacing:-0.03em; line-height:1.08; max-width:24ch;
  color:var(--ink);
}
.post-row p{
  margin:1.1rem 0 0; max-width:58ch;
  font-size:.97rem; line-height:1.6; font-weight:300;
  color:oklch(0.30 0.012 25);
}
.post-row .tags{
  margin-top:1.2rem; display:flex; flex-wrap:wrap; gap:.4rem;
}
.post-row .tag{
  font-family:var(--mono); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase;
  padding:.3rem .6rem; border-radius:4px;
  background:oklch(0.13 0.012 22 / .05); color:var(--mute-d);
}
.post-row .link{ margin-top:1.5rem; display:inline-flex; align-items:center; gap:.5rem; }

/* Featured post — first one, larger */
.post-row.is-featured h3{ font-size:clamp(1.9rem, 3.4vw, 2.8rem); }

/* ============================================================ CTA BAND */
.cta-band{ position:relative; overflow:hidden; background:var(--grad-dark); }
.cta-band::before{ content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(45% 80% at 8% 50%, rgba(251,68,51,.25), transparent 60%); }
.cta-band-grid{ position:relative; z-index:2; padding-block:clamp(4rem, 9vh, 6.5rem); display:grid; grid-template-columns:1fr; gap:2rem; align-items:center; }
@media (min-width:880px){ .cta-band-grid{ grid-template-columns:1.2fr auto; } }
.cta-band-grid .tag{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(246,220,220,.7); }
.cta-band-grid h3{ margin:1rem 0 0; max-width:24ch; font-weight:200; font-size:clamp(2rem, 4.4vw, 3.6rem); letter-spacing:-0.04em; line-height:1.02; color:var(--bone); }
.cta-band-grid .actions{ display:flex; flex-wrap:wrap; gap:.75rem; align-items:center; }

/* ============================================================ REVEAL */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1); }
.reveal.in{ opacity:1; transform:none; }


/* ============================================================
   PAGE: faq.html
============================================================ */
/* ============================================================ BRAND TOKENS */
:root{
  --ink:        oklch(0.13 0.012 22);
  --ink-2:      oklch(0.18 0.015 22);
  --ink-3:      oklch(0.30 0.014 22);
  --bone:       oklch(0.97 0.011 35);
  --paper:      oklch(0.95 0.013 35);
  --paper-2:    oklch(0.92 0.016 30);

  --red:         #E9364D;
  --red-medium:  #B31E31;
  --red-deep:    #791421;

  --grad-cta:    linear-gradient(135deg, rgb(158,32,41) 0%, rgb(228,78,88) 50%, rgb(251,68,51) 100%);
  --grad-dark:   linear-gradient(135deg, rgb(179,30,49) 0%, rgb(77,13,21) 100%);

  --mute:        oklch(0.65 0.012 25);
  --mute-d:      oklch(0.50 0.012 25);
  --rule:        oklch(0.97 0.011 35 / .14);
  --rule-soft:   oklch(0.97 0.011 35 / .08);

  --sans:        'Geist', ui-sans-serif, system-ui, sans-serif;
  --mono:        'Geist Mono', ui-monospace, monospace;
  --pad-x:       clamp(1.25rem, 4vw, 2.75rem);
}

/* ============================================================ BASE */
*{ box-sizing:border-box; }
html, body{ margin:0; padding:0; background:var(--ink); color:var(--bone); }
body{
  font-family:var(--sans); font-weight:300;
  font-feature-settings:"ss01","ss03","cv11";
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{ color:inherit; text-decoration:none; }
img,video{ display:block; max-width:100%; }
button{ font:inherit; cursor:pointer; background:none; border:0; color:inherit; }
::selection{ background:var(--red); color:var(--bone); }
.frame{ max-width:1480px; margin-inline:auto; padding-inline:var(--pad-x); }

/* ============================================================ TYPE */
.tx-display-xl{ font-weight:200; font-size:clamp(2.75rem, 7vw, 6.4rem); letter-spacing:-0.05em; line-height:.98; }
.tx-display-l { font-weight:200; font-size:clamp(2.4rem, 5.4vw, 5rem);   letter-spacing:-0.045em; line-height:1.0; }
.tx-display-m { font-weight:300; font-size:clamp(1.75rem, 3.6vw, 3.2rem); letter-spacing:-0.034em; line-height:1.06; }
.balance      { text-wrap:balance; }

/* ============================================================ MASTHEAD */
.masthead{ position:absolute; inset:0 0 auto 0; z-index:30; padding-block:1.5rem 1.25rem; }
.masthead-inner{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:2rem; }
.masthead .brand{ justify-self:start; display:inline-flex; align-items:center; }
.masthead .brand img{ height:44px; width:auto; display:block; }
.masthead-nav{ display:none; justify-content:center; align-items:center; gap:2.25rem; }
.masthead-nav a{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; font-weight:400; color:oklch(0.97 0.011 35 / .68); transition:color .25s; }
.masthead-nav a:hover, .masthead-nav a.is-on{ color:var(--bone); }
.masthead-cta{
  justify-self:end; display:inline-flex; align-items:center; gap:.6rem;
  padding:.7rem 1.15rem; border-radius:999px;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--bone); background:var(--grad-dark);
  border:1px solid oklch(0.55 0.20 25 / .35);
  box-shadow:0 16px 38px -16px rgba(179,30,49,.55), inset 0 1px 0 rgba(255,255,255,.08);
  transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s;
}
.masthead-cta:hover{ transform:translateY(-1px); box-shadow:0 22px 46px -16px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.12); }
.masthead-cta .dot{ width:6px; height:6px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 3px oklch(1 0 0 / .15); }
@media (min-width:880px){ .masthead-nav{ display:flex; } }

/* ============================================================ BUTTONS */
.btn{ display:inline-flex; align-items:center; gap:.85rem; padding:1.1rem 1.65rem; border-radius:999px; font-size:.86rem; font-weight:500; letter-spacing:.005em; transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s, background .25s, color .25s, border-color .25s; }
.btn:hover{ transform:translateY(-1px); }
.btn-grad{ color:var(--bone); background:var(--grad-cta); box-shadow:0 24px 50px -18px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.18), 0 1px 0 rgba(80,8,15,.5); position:relative; overflow:hidden; }
.btn-grad::before{ content:""; position:absolute; inset:0; border-radius:inherit; background:linear-gradient(135deg, rgba(255,255,255,.18) 0%, transparent 40%); pointer-events:none; }
.btn-grad .dot{ width:7px; height:7px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 4px rgba(255,255,255,.18); }
.btn-ghost-dark{ background:transparent; color:var(--bone); border:1px solid oklch(0.97 0.011 35 / .25); }
.btn-ghost-dark:hover{ border-color:var(--bone); background:oklch(0.97 0.011 35 / .04); }

.link-arrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--red-medium); transition:color .25s; }
.link-arrow .ar{ transition:transform .35s cubic-bezier(.16,1,.3,1); display:inline-block; }
.link-arrow:hover{ color:var(--red); }
.link-arrow:hover .ar{ transform:translateX(4px); }
.link-arrow.on-dark{ color:#ff8a8a; }
.link-arrow.on-dark:hover{ color:var(--bone); }

/* ============================================================ HERO */
.hero{ position:relative; min-height:auto; overflow:hidden; background:var(--ink); isolation:isolate; display:flex; flex-direction:column; justify-content:flex-end; padding-block:clamp(8rem, 16vh, 11rem) clamp(2.5rem, 5vh, 4rem); }
.hero-bg{ position:absolute; inset:0; z-index:1; overflow:hidden; }
.hero-bg img{
  position:absolute; right:0; top:0; height:100%; width:72%;
  object-fit:cover; object-position:center;
  -webkit-mask-image:
    linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%),
    linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  -webkit-mask-composite: source-in;
          mask-image:
    linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%),
    linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  mask-composite: intersect;
  opacity:.85;
}
.hero::before{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:
    linear-gradient(180deg, oklch(0.13 0.012 22 / .92) 0%, oklch(0.13 0.012 22 / .35) 20%, transparent 40%),
    radial-gradient(45% 60% at 90% 50%, oklch(0.55 0.20 25 / .14), transparent 70%);
}
.hero-content{ position:relative; z-index:5; }
/* Hero frame: left-aligned, fixed padding identical on every page. */
.hero .frame{ max-width:none; margin-inline:0; padding-inline:var(--pad-x); text-align:left; }

.hero-eyebrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono); font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:oklch(0.97 0.011 35 / .82); margin-bottom:clamp(2rem, 4vh, 3rem); }
.hero-eyebrow .pulse{ width:7px; height:7px; border-radius:999px; background:var(--red); position:relative; }
.hero-eyebrow .pulse::after{ content:""; position:absolute; inset:-4px; border-radius:999px; border:1px solid var(--red); opacity:.5; animation:pulse 2s ease-out infinite; }
@keyframes pulse{ 0%{transform:scale(.6); opacity:.6;} 100%{transform:scale(1.8); opacity:0;} }
.hero h1{
  margin:0; max-width:18ch; color:var(--bone);
  font-size:clamp(2.75rem, 7vw, 6.4rem); font-weight:200; line-height:.98; letter-spacing:-0.05em;
}
.hero .sub{ margin:clamp(1.5rem, 2.4vh, 2rem) 0 0; max-width:58ch; font-size:clamp(.95rem, 1.05vw, 1.05rem); line-height:1.6; font-weight:300; color:oklch(0.97 0.011 35 / .78); }

/* ============================================================ FAQ — light, accordion list */
.faq{ background:var(--bone); color:var(--ink); padding-block:clamp(4.5rem, 9vh, 7rem); position:relative; }

.faq-head{
  display:grid; grid-template-columns:1fr; gap:.75rem;
  margin-bottom:clamp(2.5rem, 5vh, 4rem);
  padding-bottom:clamp(1.5rem, 3vh, 2.25rem);
  border-bottom:1px solid oklch(0.13 0.012 22 / .14);
}
@media (min-width:920px){ .faq-head{ grid-template-columns:1fr 1fr; column-gap:clamp(3rem, 5vw, 5rem); align-items:end; } }
.faq-head .chap{ display:inline-flex; align-items:center; gap:.65rem; font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.faq-head .chap::before{ content:""; width:26px; height:1px; background:currentColor; display:inline-block; }
.faq-head h2{ margin:.75rem 0 0; color:var(--ink); }
.faq-head .lead{ margin:0; max-width:44ch; font-size:.97rem; line-height:1.6; font-weight:300; color:oklch(0.30 0.012 25); padding-bottom:.4rem; }

.faq-grid{
  display:grid; grid-template-columns:1fr; gap:clamp(2rem, 4vw, 3.5rem);
}
@media (min-width:980px){ .faq-grid{ grid-template-columns: minmax(280px, 320px) 1fr; gap:clamp(3rem, 5vw, 5rem); align-items:start; } }

.faq-aside{ min-width:0; }
.faq-aside .num-big{
  font-family:var(--mono); font-weight:200;
  font-size:clamp(3.5rem, 6.5vw, 5.5rem); line-height:.92; letter-spacing:-0.04em;
  color:var(--ink); margin:0;
}
.faq-aside .num-big .total{ color:var(--mute-d); }
.faq-aside .note{ margin:1.25rem 0 0; max-width:30ch; font-size:.94rem; line-height:1.6; color:oklch(0.30 0.012 25); }
.faq-aside .ctas{ margin-top:1.75rem; display:flex; flex-direction:column; gap:.6rem; align-items:flex-start; }

.faq-list{
  display:flex; flex-direction:column;
}

details.faq-item{
  border-bottom:1px solid oklch(0.13 0.012 22 / .14);
  padding-block:0;
  transition:background .35s;
}
details.faq-item[open]{ background:linear-gradient(90deg, oklch(0.55 0.20 25 / .04), transparent 70%); }
details.faq-item summary{
  list-style:none; cursor:pointer;
  display:grid; grid-template-columns: clamp(2.6rem, 4vw, 3.2rem) 1fr clamp(2rem, 3vw, 2.5rem);
  gap:clamp(1.25rem, 2.5vw, 2rem);
  align-items:center;
  padding-block:clamp(1.6rem, 3.2vh, 2.2rem);
}
details.faq-item summary::-webkit-details-marker{ display:none; }
details.faq-item summary::marker{ display:none; }

.faq-idx{
  font-family:var(--mono); font-weight:300;
  font-size:clamp(1.1rem, 1.6vw, 1.4rem); line-height:1;
  letter-spacing:-0.01em; color:var(--red);
}
.faq-q{
  margin:0; font-weight:300;
  font-size:clamp(1.15rem, 1.8vw, 1.5rem);
  letter-spacing:-0.022em; line-height:1.2;
  color:var(--ink);
}
.faq-toggle{
  position:relative; width:22px; height:22px;
  justify-self:end;
  flex-shrink:0;
}
.faq-toggle::before, .faq-toggle::after{
  content:""; position:absolute; left:50%; top:50%;
  background:var(--ink-2); border-radius:1px;
  transition:transform .35s cubic-bezier(.16,1,.3,1), opacity .35s;
}
.faq-toggle::before{ width:14px; height:1.5px; transform:translate(-50%, -50%); }
.faq-toggle::after { width:1.5px; height:14px; transform:translate(-50%, -50%); }
details.faq-item[open] .faq-toggle::after{ opacity:0; transform:translate(-50%, -50%) rotate(90deg); }

.faq-a{
  padding: 0 clamp(2rem, 3vw, 2.5rem) clamp(1.6rem, 3vh, 2.2rem) calc(clamp(2.6rem, 4vw, 3.2rem) + clamp(1.25rem, 2.5vw, 2rem));
  max-width:72ch;
  font-size:.97rem; line-height:1.65; font-weight:300;
  color:oklch(0.30 0.012 25);
  margin:0;
  animation: faqFadeUp .45s cubic-bezier(.16,1,.3,1);
}
@keyframes faqFadeUp{ from{ opacity:0; transform:translateY(6px);} to{ opacity:1; transform:none;} }

/* ============================================================ CTA BAND */
.cta-band{ position:relative; overflow:hidden; background:var(--grad-dark); }
.cta-band::before{ content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(45% 80% at 8% 50%, rgba(251,68,51,.25), transparent 60%); }
.cta-band-grid{ position:relative; z-index:2; padding-block:clamp(4rem, 9vh, 6.5rem); display:grid; grid-template-columns:1fr; gap:2rem; align-items:center; }
@media (min-width:880px){ .cta-band-grid{ grid-template-columns:1.2fr auto; } }
.cta-band-grid .tag{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(246,220,220,.7); }
.cta-band-grid h3{ margin:1rem 0 0; max-width:24ch; font-weight:200; font-size:clamp(2rem, 4.4vw, 3.6rem); letter-spacing:-0.04em; line-height:1.02; color:var(--bone); }
.cta-band-grid .actions{ display:flex; flex-wrap:wrap; gap:.75rem; align-items:center; }

/* ============================================================ REVEAL */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1); }
.reveal.in{ opacity:1; transform:none; }


/* ============================================================
   PAGE: contact.html
============================================================ */
/* ============================================================ BRAND TOKENS */
:root{
  --ink:        oklch(0.13 0.012 22);
  --ink-2:      oklch(0.18 0.015 22);
  --ink-3:      oklch(0.30 0.014 22);
  --bone:       oklch(0.97 0.011 35);
  --paper:      oklch(0.95 0.013 35);
  --paper-2:    oklch(0.92 0.016 30);
  --red:         #E9364D;
  --red-medium:  #B31E31;
  --red-deep:    #791421;
  --grad-cta:    linear-gradient(135deg, rgb(158,32,41) 0%, rgb(228,78,88) 50%, rgb(251,68,51) 100%);
  --grad-dark:   linear-gradient(135deg, rgb(179,30,49) 0%, rgb(77,13,21) 100%);
  --mute:        oklch(0.65 0.012 25);
  --mute-d:      oklch(0.50 0.012 25);
  --rule:        oklch(0.97 0.011 35 / .14);
  --rule-soft:   oklch(0.97 0.011 35 / .08);
  --sans:        'Geist', ui-sans-serif, system-ui, sans-serif;
  --mono:        'Geist Mono', ui-monospace, monospace;
  --pad-x:       clamp(1.25rem, 4vw, 2.75rem);
}

/* ============================================================ BASE */
*{ box-sizing:border-box; }
html, body{ margin:0; padding:0; background:var(--ink); color:var(--bone); }
body{ font-family:var(--sans); font-weight:300; font-feature-settings:"ss01","ss03","cv11"; letter-spacing:-0.005em; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
a{ color:inherit; text-decoration:none; }
img,video{ display:block; max-width:100%; }
button{ font:inherit; cursor:pointer; background:none; border:0; color:inherit; }
::selection{ background:var(--red); color:var(--bone); }
.frame{ max-width:1480px; margin-inline:auto; padding-inline:var(--pad-x); }

/* ============================================================ TYPE */
.tx-display-xl{ font-weight:200; font-size:clamp(2.75rem, 7vw, 6.4rem); letter-spacing:-0.05em; line-height:.98; }
.tx-display-m { font-weight:300; font-size:clamp(1.75rem, 3.6vw, 3.2rem); letter-spacing:-0.034em; line-height:1.06; }
.balance      { text-wrap:balance; }

/* ============================================================ MASTHEAD */
.masthead{ position:absolute; inset:0 0 auto 0; z-index:30; padding-block:1.5rem 1.25rem; }
.masthead-inner{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:2rem; }
.masthead .brand{ justify-self:start; display:inline-flex; align-items:center; }
.masthead .brand img{ height:44px; width:auto; display:block; }
.masthead-nav{ display:none; justify-content:center; align-items:center; gap:2.25rem; }
.masthead-nav a{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; font-weight:400; color:oklch(0.97 0.011 35 / .68); transition:color .25s; }
.masthead-nav a:hover, .masthead-nav a.is-on{ color:var(--bone); }
.masthead-cta{ justify-self:end; display:inline-flex; align-items:center; gap:.6rem; padding:.7rem 1.15rem; border-radius:999px; font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--bone); background:var(--grad-dark); border:1px solid oklch(0.55 0.20 25 / .35); box-shadow:0 16px 38px -16px rgba(179,30,49,.55), inset 0 1px 0 rgba(255,255,255,.08); transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s; }
.masthead-cta:hover{ transform:translateY(-1px); box-shadow:0 22px 46px -16px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.12); }
.masthead-cta .dot{ width:6px; height:6px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 3px oklch(1 0 0 / .15); }
@media (min-width:880px){ .masthead-nav{ display:flex; } }

/* ============================================================ BUTTONS */
.btn{ display:inline-flex; align-items:center; gap:.85rem; padding:1.1rem 1.65rem; border-radius:999px; font-size:.86rem; font-weight:500; letter-spacing:.005em; transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s, background .25s, color .25s, border-color .25s; }
.btn:hover{ transform:translateY(-1px); }
.btn-grad{ color:var(--bone); background:var(--grad-cta); box-shadow:0 24px 50px -18px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.18), 0 1px 0 rgba(80,8,15,.5); position:relative; overflow:hidden; }
.btn-grad::before{ content:""; position:absolute; inset:0; border-radius:inherit; background:linear-gradient(135deg, rgba(255,255,255,.18) 0%, transparent 40%); pointer-events:none; }
.btn-grad .dot{ width:7px; height:7px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 4px rgba(255,255,255,.18); }
.btn-ghost-dark{ background:transparent; color:var(--bone); border:1px solid oklch(0.97 0.011 35 / .25); }
.btn-ghost-dark:hover{ border-color:var(--bone); background:oklch(0.97 0.011 35 / .04); }
.btn-ghost-light{ background:transparent; color:var(--ink); border:1px solid oklch(0.13 0.012 22 / .32); }
.btn-ghost-light:hover{ border-color:var(--ink); background:oklch(0.13 0.012 22 / .03); }

.link-arrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--red-medium); transition:color .25s; }
.link-arrow .ar{ transition:transform .35s cubic-bezier(.16,1,.3,1); display:inline-block; }
.link-arrow:hover{ color:var(--red); }
.link-arrow:hover .ar{ transform:translateX(4px); }
.link-arrow.on-dark{ color:#ff8a8a; }
.link-arrow.on-dark:hover{ color:var(--bone); }

/* ============================================================ HERO */
.hero{ position:relative; min-height:auto; overflow:hidden; background:var(--ink); isolation:isolate; display:flex; flex-direction:column; justify-content:flex-end; padding-block:clamp(8rem, 16vh, 11rem) clamp(2.5rem, 5vh, 4rem); }
.hero-bg{ position:absolute; inset:0; z-index:1; overflow:hidden; }
.hero-bg img{
  position:absolute; right:0; top:0; height:100%; width:72%; object-fit:cover; object-position:center;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%), linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  -webkit-mask-composite: source-in;
          mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%), linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  mask-composite: intersect; opacity:.85;
}
.hero::before{ content:""; position:absolute; inset:0; z-index:2; pointer-events:none; background: linear-gradient(180deg, oklch(0.13 0.012 22 / .92) 0%, oklch(0.13 0.012 22 / .35) 20%, transparent 40%), radial-gradient(45% 60% at 90% 50%, oklch(0.55 0.20 25 / .14), transparent 70%); }
.hero-content{ position:relative; z-index:5; }
.hero .frame{ max-width:none; margin-inline:0; padding-inline:var(--pad-x); text-align:left; }
.hero-eyebrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono); font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:oklch(0.97 0.011 35 / .82); margin-bottom:clamp(2rem, 4vh, 3rem); }
.hero-eyebrow .pulse{ width:7px; height:7px; border-radius:999px; background:var(--red); position:relative; }
.hero-eyebrow .pulse::after{ content:""; position:absolute; inset:-4px; border-radius:999px; border:1px solid var(--red); opacity:.5; animation:pulse 2s ease-out infinite; }
@keyframes pulse{ 0%{transform:scale(.6); opacity:.6;} 100%{transform:scale(1.8); opacity:0;} }
.hero h1{ margin:0; max-width:18ch; color:var(--bone); font-size:clamp(2.75rem, 7vw, 6.4rem); font-weight:200; line-height:.98; letter-spacing:-0.05em; }
.hero .sub{ margin:clamp(1.5rem, 2.4vh, 2rem) 0 0; max-width:62ch; font-size:clamp(.95rem, 1.05vw, 1.05rem); line-height:1.6; font-weight:300; color:oklch(0.97 0.011 35 / .78); }
.hero .sub a{ color:var(--bone); border-bottom:1px solid oklch(0.55 0.20 25 / .55); transition:border-color .25s; }
.hero .sub a:hover{ border-color:var(--red); }
.hero .sub .num{ color:var(--bone); font-family:var(--mono); font-weight:400; }

/* ============================================================ FORM SECTION — light */
.form-sec{ background:var(--bone); color:var(--ink); padding-block:clamp(4.5rem, 9vh, 7rem); position:relative; }

.form-head{
  display:grid; grid-template-columns:1fr; gap:.75rem;
  margin-bottom:clamp(2.5rem, 5vh, 4rem);
  padding-bottom:clamp(1.5rem, 3vh, 2.25rem);
  border-bottom:1px solid oklch(0.13 0.012 22 / .14);
}
@media (min-width:920px){ .form-head{ grid-template-columns:1fr 1fr; column-gap:clamp(3rem, 5vw, 5rem); align-items:end; } }
.form-head .chap{ display:inline-flex; align-items:center; gap:.65rem; font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.form-head .chap::before{ content:""; width:26px; height:1px; background:currentColor; display:inline-block; }
.form-head h2{ margin:.75rem 0 0; color:var(--ink); }
.form-head .lead{ margin:0; max-width:42ch; font-size:.97rem; line-height:1.6; font-weight:300; color:oklch(0.30 0.012 25); padding-bottom:.4rem; }

.form-grid{ display:grid; grid-template-columns:1fr; gap:clamp(2.5rem, 5vh, 4rem); }
@media (min-width:980px){ .form-grid{ grid-template-columns: minmax(260px, 320px) 1fr; gap:clamp(3rem, 5vw, 5rem); align-items:start; } }

/* — LEFT META RAIL — */
.form-aside{ min-width:0; }
.steps-bar{ display:flex; align-items:center; gap:.55rem; font-family:var(--mono); font-size:.65rem; letter-spacing:.18em; text-transform:uppercase; color:var(--mute-d); }
.steps-bar .seg{ width:38px; height:2px; background:oklch(0.13 0.012 22 / .14); border-radius:1px; transition:background .35s; }
.steps-bar .seg.on{ background:var(--red); }
.steps-bar .lbl{ margin-left:.45rem; }
.steps-bar .lbl .now{ color:var(--ink); }

.form-aside .lead-h2{
  margin: 1.5rem 0 0;
  font-weight:200; font-size:clamp(2rem, 3.4vw, 2.8rem);
  letter-spacing:-0.04em; line-height:1.0; color:var(--ink);
  max-width:14ch;
}

.aside-card{
  margin-top:2rem; padding: clamp(1.4rem, 2.5vw, 1.75rem);
  border:1px solid oklch(0.13 0.012 22 / .14);
  border-radius:12px;
  background:transparent;
}
.aside-card .eyebrow{ font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.aside-card h3{
  margin:.6rem 0 0; font-weight:300;
  font-size:clamp(1.15rem, 1.6vw, 1.35rem); letter-spacing:-0.022em; line-height:1.2; color:var(--ink);
}
.aside-card p{ margin:.75rem 0 0; font-size:.92rem; line-height:1.55; color:oklch(0.30 0.012 25); }
.aside-card ul{ list-style:none; margin:1rem 0 0; padding:0; display:flex; flex-direction:column; gap:.5rem; }
.aside-card ul li{
  display:grid; grid-template-columns:auto 1fr; align-items:baseline; gap:.85rem;
  font-size:.92rem; color:var(--ink);
}
.aside-card ul li .k{
  font-family:var(--mono); font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; color:var(--mute-d);
}
.aside-card ul li .v a{ color:var(--ink); border-bottom:1px solid oklch(0.13 0.012 22 / .15); transition:border-color .2s, color .2s; }
.aside-card ul li .v a:hover{ color:var(--red); border-bottom-color:var(--red); }

/* — RIGHT FORM CARD — */
.form-card{
  position:relative; min-width:0;
  padding: clamp(1.75rem, 3vw, 2.75rem) clamp(1.5rem, 3vw, 2.75rem);
  background:oklch(0.13 0.012 22 / .02);
  border:1px solid oklch(0.13 0.012 22 / .14);
  border-radius:18px;
}

.step{ display:none; }
.step.is-active{ display:block; animation: stepIn .55s cubic-bezier(.16,1,.3,1); }
@keyframes stepIn{ from{ opacity:0; transform:translateY(10px); } to{ opacity:1; transform:none; } }

.step-head{
  display:flex; align-items:baseline; justify-content:space-between; gap:1rem;
  padding-bottom:1.25rem; margin-bottom:1.5rem;
  border-bottom:1px solid oklch(0.13 0.012 22 / .12);
}
.step-head .eyebrow{ font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.step-head .req{ font-family:var(--mono); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--mute-d); }

.fields{ display:grid; grid-template-columns:1fr; column-gap:clamp(1.5rem, 3vw, 2.5rem); row-gap:1.25rem; }
@media (min-width:680px){ .fields{ grid-template-columns:1fr 1fr; } }
.field-cell{ display:flex; flex-direction:column; gap:.4rem; min-width:0; }
.field-cell.span-2{ grid-column:1 / -1; }
.field-cell label{ font-family:var(--mono); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:var(--mute-d); }
.field-cell label .req{ color:var(--red); }
.field-cell .ctl{
  width:100%; background:transparent; border:0;
  border-bottom:1px solid oklch(0.13 0.012 22 / .22);
  padding:.65rem 0; color:var(--ink);
  font-family:var(--sans); font-size:1rem; font-weight:300;
  transition: border-color .25s;
}
.field-cell .ctl::placeholder{ color:oklch(0.30 0.012 25 / .42); font-weight:300; }
.field-cell .ctl:focus{ outline:none; border-color:var(--red); }

/* Date input — match the editorial bottom-border field style */
.field-cell .ctl-date{
  appearance:none; -webkit-appearance:none;
  color:var(--ink);
  font-variant-numeric: tabular-nums;
  cursor:pointer;
}
.field-cell .ctl-date::-webkit-calendar-picker-indicator{
  opacity:.45; cursor:pointer;
  filter: invert(15%) sepia(7%) saturate(700%) hue-rotate(335deg);
  transition: opacity .25s;
}
.field-cell .ctl-date:hover::-webkit-calendar-picker-indicator{ opacity:.85; }
.field-cell .ctl-date:focus::-webkit-calendar-picker-indicator{ opacity:1; }
.field-cell .ctl-date::-webkit-date-and-time-value{ text-align:left; }
.field-cell .ctl-date:invalid,
.field-cell .ctl-date:not(:focus):placeholder-shown,
.field-cell .ctl-date:not([value]):not(:focus){ color: oklch(0.30 0.012 25 / .42); }

/* Datalist-backed inputs (country typeahead) — show the small native
   dropdown indicator subtly so users know there's a list to choose from */
.field-cell .ctl[list]{ background-image:none; }

/* Toggle (Yes/No) */
.toggle{
  display:inline-flex; padding:3px; border-radius:999px;
  border:1px solid oklch(0.13 0.012 22 / .18); background:transparent;
}
.toggle button{
  padding:.55rem 1.1rem; border-radius:999px;
  font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--mute-d); background:transparent;
  transition:color .25s, background .25s;
}
.toggle button.on{ background:var(--ink); color:var(--bone); }

.step-foot{
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between;
  gap:1.5rem; margin-top:2.25rem;
}
.step-foot .note{ max-width:42ch; font-size:.85rem; line-height:1.55; color:oklch(0.30 0.012 25); }
.step-foot .note strong{ color:var(--ink); font-weight:500; }

/* Inline note inside step 2 */
.inline-card{
  margin-top:2rem; padding:1.25rem 1.4rem;
  border:1px solid oklch(0.13 0.012 22 / .12);
  border-left:2px solid var(--red);
  border-radius:8px;
  background:oklch(0.13 0.012 22 / .02);
}
.inline-card .eyebrow{ font-family:var(--mono); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.inline-card p{ margin:.5rem 0 0; font-size:.92rem; line-height:1.55; color:oklch(0.30 0.012 25); }
.inline-card p strong{ color:var(--ink); font-weight:500; }

/* Thanks state */
.thanks{ padding:2rem 0; text-align:center; }
.thanks .check{
  display:inline-flex; align-items:center; justify-content:center;
  width:64px; height:64px; border-radius:999px;
  background:var(--grad-dark); color:var(--bone);
  font-family:var(--mono); font-size:1.5rem; line-height:1;
  box-shadow:0 14px 30px -12px rgba(179,30,49,.5);
}
.thanks h3{
  margin:1.5rem 0 0;
  font-weight:200; font-size:clamp(2rem, 4vw, 3rem); letter-spacing:-0.04em; line-height:1.02;
  color:var(--ink);
}
.thanks p{
  margin:1rem auto 0; max-width:50ch;
  font-size:.97rem; line-height:1.6; color:oklch(0.30 0.012 25);
}
.thanks p strong{ color:var(--ink); font-weight:500; }
.thanks .back{ margin-top:2rem; display:inline-flex; align-items:center; gap:.5rem; }

/* FAQ shortcut below form */
.below-form{
  margin-top:1.5rem;
  font-size:.92rem; line-height:1.5;
  color:oklch(0.30 0.012 25);
  display:flex; align-items:center; gap:.85rem; flex-wrap:wrap;
}

/* ============================================================ OFFICES — dark contact pillars */
.offices{ background:var(--ink); color:var(--bone); padding-block:clamp(4rem, 9vh, 6.5rem); }
.offices-head{ margin-bottom:clamp(2rem, 4vh, 3rem); }
.offices-head .chap{ display:inline-flex; align-items:center; gap:.65rem; font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.offices-head .chap::before{ content:""; width:26px; height:1px; background:currentColor; display:inline-block; }
.offices-head h2{ margin:.75rem 0 0; color:var(--bone); }
.offices-grid{
  display:grid; grid-template-columns:1fr;
  border-top:1px solid oklch(0.97 0.011 35 / .14);
}
@media (min-width:820px){ .offices-grid{ grid-template-columns:repeat(3, 1fr); } }
.office-col{
  padding-block:clamp(1.8rem, 4vh, 2.6rem);
  border-bottom:1px solid oklch(0.97 0.011 35 / .14);
  display:flex; flex-direction:column; gap:.55rem;
}
@media (min-width:820px){
  .office-col{ padding-block:0; padding-inline:clamp(1rem, 2.5vw, 2rem); border-bottom:0; border-right:1px solid oklch(0.97 0.011 35 / .14); }
  .office-col:first-child{ padding-left:0; }
  .office-col:last-child{ border-right:0; padding-right:0; }
}
.office-col .mark{ font-family:var(--mono); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:oklch(0.97 0.011 35 / .55); }
.office-col .big{
  font-weight:200; font-size:clamp(1.5rem, 2.2vw, 1.9rem); letter-spacing:-0.025em; line-height:1.1;
  color:var(--bone);
}
.office-col .sub{ font-size:.92rem; line-height:1.6; color:oklch(0.97 0.011 35 / .65); }
.office-col .sub a{ color:var(--bone); border-bottom:1px solid oklch(0.97 0.011 35 / .25); transition:border-color .25s; }
.office-col .sub a:hover{ border-color:var(--red); }

/* ============================================================ REVEAL */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1); }
.reveal.in{ opacity:1; transform:none; }


/* ============================================================
   PAGE: terms.html
============================================================ */
:root{
  --ink:        oklch(0.13 0.012 22);
  --ink-2:      oklch(0.18 0.015 22);
  --ink-3:      oklch(0.30 0.014 22);
  --bone:       oklch(0.97 0.011 35);
  --paper:      oklch(0.95 0.013 35);
  --paper-2:    oklch(0.92 0.016 30);
  --red:         #E9364D;
  --red-medium:  #B31E31;
  --red-deep:    #791421;
  --grad-cta:    linear-gradient(135deg, rgb(158,32,41) 0%, rgb(228,78,88) 50%, rgb(251,68,51) 100%);
  --grad-dark:   linear-gradient(135deg, rgb(179,30,49) 0%, rgb(77,13,21) 100%);
  --mute:        oklch(0.65 0.012 25);
  --mute-d:      oklch(0.50 0.012 25);
  --rule:        oklch(0.97 0.011 35 / .14);
  --rule-soft:   oklch(0.97 0.011 35 / .08);
  --sans:        'Geist', ui-sans-serif, system-ui, sans-serif;
  --mono:        'Geist Mono', ui-monospace, monospace;
  --pad-x:       clamp(1.25rem, 4vw, 2.75rem);
}

*{ box-sizing:border-box; }
html, body{ margin:0; padding:0; background:var(--ink); color:var(--bone); }
body{ font-family:var(--sans); font-weight:300; font-feature-settings:"ss01","ss03","cv11"; letter-spacing:-0.005em; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
a{ color:inherit; text-decoration:none; }
img,video{ display:block; max-width:100%; }
button{ font:inherit; cursor:pointer; background:none; border:0; color:inherit; }
::selection{ background:var(--red); color:var(--bone); }
.frame{ max-width:1480px; margin-inline:auto; padding-inline:var(--pad-x); }

.tx-display-xl{ font-weight:200; font-size:clamp(2.75rem, 7vw, 6.4rem); letter-spacing:-0.05em; line-height:.98; }
.tx-display-m { font-weight:300; font-size:clamp(1.75rem, 3.6vw, 3.2rem); letter-spacing:-0.034em; line-height:1.06; }
.balance      { text-wrap:balance; }

/* MASTHEAD */
.masthead{ position:absolute; inset:0 0 auto 0; z-index:30; padding-block:1.5rem 1.25rem; }
.masthead-inner{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:2rem; }
.masthead .brand{ justify-self:start; display:inline-flex; align-items:center; }
.masthead .brand img{ height:44px; width:auto; display:block; }
.masthead-nav{ display:none; justify-content:center; align-items:center; gap:2.25rem; }
.masthead-nav a{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; font-weight:400; color:oklch(0.97 0.011 35 / .68); transition:color .25s; }
.masthead-nav a:hover, .masthead-nav a.is-on{ color:var(--bone); }
.masthead-cta{ justify-self:end; display:inline-flex; align-items:center; gap:.6rem; padding:.7rem 1.15rem; border-radius:999px; font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--bone); background:var(--grad-dark); border:1px solid oklch(0.55 0.20 25 / .35); box-shadow:0 16px 38px -16px rgba(179,30,49,.55), inset 0 1px 0 rgba(255,255,255,.08); transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s; }
.masthead-cta:hover{ transform:translateY(-1px); box-shadow:0 22px 46px -16px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.12); }
.masthead-cta .dot{ width:6px; height:6px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 3px oklch(1 0 0 / .15); }
@media (min-width:880px){ .masthead-nav{ display:flex; } }

.btn{ display:inline-flex; align-items:center; gap:.85rem; padding:1.1rem 1.65rem; border-radius:999px; font-size:.86rem; font-weight:500; letter-spacing:.005em; transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s, background .25s, color .25s, border-color .25s; }
.btn:hover{ transform:translateY(-1px); }
.btn-grad{ color:var(--bone); background:var(--grad-cta); box-shadow:0 24px 50px -18px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.18), 0 1px 0 rgba(80,8,15,.5); position:relative; overflow:hidden; }
.btn-grad::before{ content:""; position:absolute; inset:0; border-radius:inherit; background:linear-gradient(135deg, rgba(255,255,255,.18) 0%, transparent 40%); pointer-events:none; }
.btn-grad .dot{ width:7px; height:7px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 4px rgba(255,255,255,.18); }

.link-arrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--red-medium); transition:color .25s; }
.link-arrow .ar{ transition:transform .35s cubic-bezier(.16,1,.3,1); display:inline-block; }
.link-arrow:hover{ color:var(--red); } .link-arrow:hover .ar{ transform:translateX(4px); }
.link-arrow.on-dark{ color:#ff8a8a; } .link-arrow.on-dark:hover{ color:var(--bone); }

/* HERO */
.hero{ position:relative; min-height:auto; overflow:hidden; background:var(--ink); isolation:isolate; display:flex; flex-direction:column; justify-content:flex-end; padding-block:clamp(8rem, 16vh, 11rem) clamp(2.5rem, 5vh, 4rem); }
.hero-bg{ position:absolute; inset:0; z-index:1; overflow:hidden; }
.hero-bg img{
  position:absolute; right:0; top:0; height:100%; width:72%; object-fit:cover; object-position:center;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%), linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  -webkit-mask-composite: source-in;
          mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%), linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  mask-composite: intersect; opacity:.85;
}
.hero::before{ content:""; position:absolute; inset:0; z-index:2; pointer-events:none; background: linear-gradient(180deg, oklch(0.13 0.012 22 / .92) 0%, oklch(0.13 0.012 22 / .35) 20%, transparent 40%), radial-gradient(45% 60% at 90% 50%, oklch(0.55 0.20 25 / .14), transparent 70%); }
.hero-content{ position:relative; z-index:5; }
.hero .frame{ max-width:none; margin-inline:0; padding-inline:var(--pad-x); text-align:left; }
.hero-eyebrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono); font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:oklch(0.97 0.011 35 / .82); margin-bottom:clamp(2rem, 4vh, 3rem); }
.hero-eyebrow .pulse{ width:7px; height:7px; border-radius:999px; background:var(--red); position:relative; }
.hero-eyebrow .pulse::after{ content:""; position:absolute; inset:-4px; border-radius:999px; border:1px solid var(--red); opacity:.5; animation:pulse 2s ease-out infinite; }
@keyframes pulse{ 0%{transform:scale(.6); opacity:.6;} 100%{transform:scale(1.8); opacity:0;} }
.hero h1{ margin:0; max-width:18ch; color:var(--bone); font-size:clamp(2.75rem, 7vw, 6.4rem); font-weight:200; line-height:.98; letter-spacing:-0.05em; }
.hero .sub{ margin:clamp(1.5rem, 2.4vh, 2rem) 0 0; max-width:62ch; font-size:clamp(.95rem, 1.05vw, 1.05rem); line-height:1.6; font-weight:300; color:oklch(0.97 0.011 35 / .78); }
.hero .meta{ margin-top: clamp(1.25rem, 2.4vh, 1.75rem); display:flex; flex-wrap:wrap; gap:.75rem; }
.hero .meta .chip{ display:inline-flex; align-items:center; gap:.55rem; padding:.45rem .85rem; border-radius:999px; border:1px solid oklch(0.97 0.011 35 / .22); font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:oklch(0.97 0.011 35 / .82); background:oklch(0.13 0.012 22 / .35); backdrop-filter:blur(8px); }
.hero .meta .chip .accent{ color:var(--red); }

/* DOCUMENT BODY */
.doc{ background:var(--bone); color:var(--ink); padding-block:clamp(4.5rem, 9vh, 7rem); position:relative; }
.doc-grid{ display:grid; grid-template-columns:1fr; gap:clamp(2.5rem, 5vh, 4rem); }
@media (min-width:980px){ .doc-grid{ grid-template-columns: minmax(220px, 260px) 1fr; gap:clamp(3rem, 5vw, 5rem); align-items:start; } }

.toc-rail{ position:relative; min-width:0; }
@media (min-width:980px){ .toc-rail{ position:sticky; top:5rem; } }
.toc-rail .chap{ display:inline-flex; align-items:center; gap:.65rem; font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); margin-bottom:1.25rem; }
.toc-rail .chap::before{ content:""; width:26px; height:1px; background:currentColor; display:inline-block; }
.toc-rail nav.toc{ display:flex; flex-direction:column; gap:0; border-top:1px solid oklch(0.13 0.012 22 / .12); }
.toc-rail nav.toc a{
  display:block; padding:.7rem 0; padding-left:.25rem;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; text-transform:uppercase;
  color:oklch(0.30 0.012 25 / .7); border-bottom:1px solid oklch(0.13 0.012 22 / .12);
  transition:color .2s, padding-left .25s;
}
.toc-rail nav.toc a:hover{ color:var(--red); padding-left:.65rem; }
.toc-rail .ask{ margin-top:2rem; padding-top:1.5rem; border-top:1px solid oklch(0.13 0.012 22 / .12); }
.toc-rail .ask .eyebrow{ font-family:var(--mono); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:var(--mute-d); }
.toc-rail .ask p{ margin:.75rem 0 0; font-size:.92rem; line-height:1.55; color:oklch(0.30 0.012 25); }
.toc-rail .ask p a{ color:var(--red-medium); border-bottom:1px solid currentColor; }
.toc-rail .ask p a:hover{ color:var(--red); }

.prose{ min-width:0; max-width:none; }
.prose section{ margin-block: clamp(2.5rem, 5vh, 4rem); }
.prose section:first-of-type{ margin-top:0; }
.prose h2{
  margin:0 0 1.25rem; font-family:var(--sans); font-weight:300;
  font-size:clamp(1.55rem, 2.4vw, 2.1rem);
  letter-spacing:-0.028em; line-height:1.08; color:var(--ink);
  padding-bottom:1rem; border-bottom:1px solid oklch(0.13 0.012 22 / .14);
}
.prose h2::before{
  content:attr(data-num);
  display:block;
  font-family:var(--mono); font-weight:400;
  font-size:.66rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--red);
  margin-bottom:.7rem;
}

/* Definition lists (terminology) — 2-col label/definition grid */
.prose .deflist{
  margin: 1.5rem 0 0; max-width:78ch;
  display:grid; grid-template-columns:1fr; gap:.4rem 1.5rem;
  border-top:1px solid oklch(0.13 0.012 22 / .10);
}
.prose .deflist > dt{
  margin-top:1rem; font-weight:500; color:var(--ink);
  font-size:.95rem; line-height:1.4;
}
.prose .deflist > dt:first-child{ margin-top:.75rem; }
.prose .deflist > dd{
  margin: .15rem 0 .75rem; padding:0;
  font-size:.95rem; line-height:1.6; font-weight:300;
  color:oklch(0.30 0.012 25);
  border-bottom:1px solid oklch(0.13 0.012 22 / .08);
  padding-bottom:.85rem;
}
.prose .deflist > dd:last-child{ border-bottom:0; padding-bottom:0; }
@media (min-width:720px){
  .prose .deflist{ grid-template-columns: minmax(160px, 22ch) 1fr; align-items:baseline; }
  .prose .deflist > dt{ margin-top:0; padding-top:.85rem; border-top:1px solid oklch(0.13 0.012 22 / .08); }
  .prose .deflist > dt:first-of-type{ border-top:0; padding-top:.85rem; }
  .prose .deflist > dd{ margin:0; padding-top:.85rem; padding-bottom:.85rem; border-bottom:0; border-top:1px solid oklch(0.13 0.012 22 / .08); }
  .prose .deflist > dd:nth-of-type(1){ border-top:0; }
}

/* Personal-data tables (.data-card) — bordered box with mono labels */
.prose .data-card{
  margin: 1.5rem 0 0; padding: clamp(1.25rem, 2vw, 1.75rem);
  border: 1px solid oklch(0.13 0.012 22 / .14);
  border-radius: 12px;
  background: oklch(0.13 0.012 22 / .02);
  max-width:78ch;
}
.prose .data-card h3{
  margin: 0 0 .85rem;
  font-family:var(--mono); font-weight:500;
  font-size:.78rem; letter-spacing:.06em;
  color:var(--ink);
}
.prose .data-card dl{ margin:0; }
.prose .data-card .field-row{
  display:grid; grid-template-columns: 1fr;
  gap:.25rem 1.5rem;
  padding-block:.75rem;
  border-top:1px solid oklch(0.13 0.012 22 / .10);
}
.prose .data-card .field-row:first-child{ border-top:0; padding-top:.25rem; }
@media (min-width:640px){
  .prose .data-card .field-row{ grid-template-columns: minmax(120px, 18ch) 1fr; align-items:baseline; }
}
.prose .data-card .field-row dt{
  margin:0;
  font-family:var(--mono); font-size:.65rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--mute-d);
}
.prose .data-card .field-row dd{
  margin:0;
  font-size:.93rem; line-height:1.55; font-weight:300;
  color:oklch(0.30 0.012 25);
}
.prose h3{ margin:2rem 0 .75rem; font-family:var(--sans); font-weight:400; font-size:1.1rem; letter-spacing:-0.015em; line-height:1.2; color:var(--ink); }
.prose p{ margin:1rem 0 0; max-width:66ch; font-size:.97rem; line-height:1.7; font-weight:300; color:oklch(0.30 0.012 25); }
.prose ul{ margin:1rem 0 0; padding-left:0; list-style:none; max-width:66ch; display:flex; flex-direction:column; gap:.6rem; }
.prose ul li{ position:relative; padding-left:1.35rem; font-size:.97rem; line-height:1.65; font-weight:300; color:oklch(0.30 0.012 25); }
.prose ul li::before{ content:""; position:absolute; left:0; top:.7em; width:.5rem; height:1px; background:var(--red); }
.prose strong{ color:var(--ink); font-weight:500; }
.prose a{ color:var(--red-medium); border-bottom:1px solid oklch(0.55 0.20 25 / .35); transition:color .2s, border-color .2s; }
.prose a:hover{ color:var(--red); border-bottom-color:var(--red); }
.prose .legal-caps{
  margin: 1.25rem 0 0; padding: 1.25rem 1.5rem;
  background:oklch(0.13 0.012 22 / .04);
  border:1px solid oklch(0.13 0.012 22 / .08);
  border-left:2px solid var(--red);
  border-radius:6px; max-width:72ch;
  font-family:var(--mono); font-size:.78rem; line-height:1.65; letter-spacing:.005em;
  color:oklch(0.30 0.012 25 / .9);
}

/* RELATED */
.prose .related{ margin-top:clamp(3rem, 6vh, 4.5rem); padding-top:clamp(2rem, 4vh, 3rem); border-top:1px solid oklch(0.13 0.012 22 / .14); }
.prose .related .eyebrow{ font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.prose .related-grid{ margin-top:1.5rem; display:grid; grid-template-columns:1fr; gap:.75rem; }
@media (min-width:760px){ .prose .related-grid{ grid-template-columns:1fr 1fr; gap:1rem; } }
.prose .related-grid a{
  display:block; padding:1.4rem 1.5rem; border-radius:12px;
  border:1px solid oklch(0.13 0.012 22 / .14); background:transparent;
  transition:border-color .25s, background .25s, transform .25s;
}
.prose .related-grid a:hover{ border-color:var(--ink); background:oklch(0.13 0.012 22 / .03); transform:translateY(-1px); }
.prose .related-grid .num{ font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.prose .related-grid .label{ display:block; margin-top:.5rem; font-weight:300; font-size:1.35rem; letter-spacing:-0.025em; line-height:1.1; color:var(--ink); }

/* REVEAL */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1); }
.reveal.in{ opacity:1; transform:none; }


/* ============================================================
   PAGE: privacy.html
============================================================ */
:root{
  --ink:        oklch(0.13 0.012 22);
  --ink-2:      oklch(0.18 0.015 22);
  --ink-3:      oklch(0.30 0.014 22);
  --bone:       oklch(0.97 0.011 35);
  --paper:      oklch(0.95 0.013 35);
  --paper-2:    oklch(0.92 0.016 30);
  --red:         #E9364D;
  --red-medium:  #B31E31;
  --red-deep:    #791421;
  --grad-cta:    linear-gradient(135deg, rgb(158,32,41) 0%, rgb(228,78,88) 50%, rgb(251,68,51) 100%);
  --grad-dark:   linear-gradient(135deg, rgb(179,30,49) 0%, rgb(77,13,21) 100%);
  --mute:        oklch(0.65 0.012 25);
  --mute-d:      oklch(0.50 0.012 25);
  --rule:        oklch(0.97 0.011 35 / .14);
  --rule-soft:   oklch(0.97 0.011 35 / .08);
  --sans:        'Geist', ui-sans-serif, system-ui, sans-serif;
  --mono:        'Geist Mono', ui-monospace, monospace;
  --pad-x:       clamp(1.25rem, 4vw, 2.75rem);
}

*{ box-sizing:border-box; }
html, body{ margin:0; padding:0; background:var(--ink); color:var(--bone); }
body{ font-family:var(--sans); font-weight:300; font-feature-settings:"ss01","ss03","cv11"; letter-spacing:-0.005em; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
a{ color:inherit; text-decoration:none; }
img,video{ display:block; max-width:100%; }
button{ font:inherit; cursor:pointer; background:none; border:0; color:inherit; }
::selection{ background:var(--red); color:var(--bone); }
.frame{ max-width:1480px; margin-inline:auto; padding-inline:var(--pad-x); }

.tx-display-xl{ font-weight:200; font-size:clamp(2.75rem, 7vw, 6.4rem); letter-spacing:-0.05em; line-height:.98; }
.tx-display-m { font-weight:300; font-size:clamp(1.75rem, 3.6vw, 3.2rem); letter-spacing:-0.034em; line-height:1.06; }
.balance      { text-wrap:balance; }

/* MASTHEAD */
.masthead{ position:absolute; inset:0 0 auto 0; z-index:30; padding-block:1.5rem 1.25rem; }
.masthead-inner{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:2rem; }
.masthead .brand{ justify-self:start; display:inline-flex; align-items:center; }
.masthead .brand img{ height:44px; width:auto; display:block; }
.masthead-nav{ display:none; justify-content:center; align-items:center; gap:2.25rem; }
.masthead-nav a{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; font-weight:400; color:oklch(0.97 0.011 35 / .68); transition:color .25s; }
.masthead-nav a:hover, .masthead-nav a.is-on{ color:var(--bone); }
.masthead-cta{ justify-self:end; display:inline-flex; align-items:center; gap:.6rem; padding:.7rem 1.15rem; border-radius:999px; font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--bone); background:var(--grad-dark); border:1px solid oklch(0.55 0.20 25 / .35); box-shadow:0 16px 38px -16px rgba(179,30,49,.55), inset 0 1px 0 rgba(255,255,255,.08); transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s; }
.masthead-cta:hover{ transform:translateY(-1px); box-shadow:0 22px 46px -16px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.12); }
.masthead-cta .dot{ width:6px; height:6px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 3px oklch(1 0 0 / .15); }
@media (min-width:880px){ .masthead-nav{ display:flex; } }

.btn{ display:inline-flex; align-items:center; gap:.85rem; padding:1.1rem 1.65rem; border-radius:999px; font-size:.86rem; font-weight:500; letter-spacing:.005em; transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s, background .25s, color .25s, border-color .25s; }
.btn:hover{ transform:translateY(-1px); }
.btn-grad{ color:var(--bone); background:var(--grad-cta); box-shadow:0 24px 50px -18px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.18), 0 1px 0 rgba(80,8,15,.5); position:relative; overflow:hidden; }
.btn-grad::before{ content:""; position:absolute; inset:0; border-radius:inherit; background:linear-gradient(135deg, rgba(255,255,255,.18) 0%, transparent 40%); pointer-events:none; }
.btn-grad .dot{ width:7px; height:7px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 4px rgba(255,255,255,.18); }

.link-arrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--red-medium); transition:color .25s; }
.link-arrow .ar{ transition:transform .35s cubic-bezier(.16,1,.3,1); display:inline-block; }
.link-arrow:hover{ color:var(--red); } .link-arrow:hover .ar{ transform:translateX(4px); }
.link-arrow.on-dark{ color:#ff8a8a; } .link-arrow.on-dark:hover{ color:var(--bone); }

/* HERO */
.hero{ position:relative; min-height:auto; overflow:hidden; background:var(--ink); isolation:isolate; display:flex; flex-direction:column; justify-content:flex-end; padding-block:clamp(8rem, 16vh, 11rem) clamp(2.5rem, 5vh, 4rem); }
.hero-bg{ position:absolute; inset:0; z-index:1; overflow:hidden; }
.hero-bg img{
  position:absolute; right:0; top:0; height:100%; width:72%; object-fit:cover; object-position:center;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%), linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  -webkit-mask-composite: source-in;
          mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%), linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  mask-composite: intersect; opacity:.85;
}
.hero::before{ content:""; position:absolute; inset:0; z-index:2; pointer-events:none; background: linear-gradient(180deg, oklch(0.13 0.012 22 / .92) 0%, oklch(0.13 0.012 22 / .35) 20%, transparent 40%), radial-gradient(45% 60% at 90% 50%, oklch(0.55 0.20 25 / .14), transparent 70%); }
.hero-content{ position:relative; z-index:5; }
.hero .frame{ max-width:none; margin-inline:0; padding-inline:var(--pad-x); text-align:left; }
.hero-eyebrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono); font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:oklch(0.97 0.011 35 / .82); margin-bottom:clamp(2rem, 4vh, 3rem); }
.hero-eyebrow .pulse{ width:7px; height:7px; border-radius:999px; background:var(--red); position:relative; }
.hero-eyebrow .pulse::after{ content:""; position:absolute; inset:-4px; border-radius:999px; border:1px solid var(--red); opacity:.5; animation:pulse 2s ease-out infinite; }
@keyframes pulse{ 0%{transform:scale(.6); opacity:.6;} 100%{transform:scale(1.8); opacity:0;} }
.hero h1{ margin:0; max-width:18ch; color:var(--bone); font-size:clamp(2.75rem, 7vw, 6.4rem); font-weight:200; line-height:.98; letter-spacing:-0.05em; }
.hero .sub{ margin:clamp(1.5rem, 2.4vh, 2rem) 0 0; max-width:62ch; font-size:clamp(.95rem, 1.05vw, 1.05rem); line-height:1.6; font-weight:300; color:oklch(0.97 0.011 35 / .78); }
.hero .meta{ margin-top: clamp(1.25rem, 2.4vh, 1.75rem); display:flex; flex-wrap:wrap; gap:.75rem; }
.hero .meta .chip{ display:inline-flex; align-items:center; gap:.55rem; padding:.45rem .85rem; border-radius:999px; border:1px solid oklch(0.97 0.011 35 / .22); font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:oklch(0.97 0.011 35 / .82); background:oklch(0.13 0.012 22 / .35); backdrop-filter:blur(8px); }
.hero .meta .chip .accent{ color:var(--red); }

/* DOCUMENT BODY */
.doc{ background:var(--bone); color:var(--ink); padding-block:clamp(4.5rem, 9vh, 7rem); position:relative; }
.doc-grid{ display:grid; grid-template-columns:1fr; gap:clamp(2.5rem, 5vh, 4rem); }
@media (min-width:980px){ .doc-grid{ grid-template-columns: minmax(220px, 260px) 1fr; gap:clamp(3rem, 5vw, 5rem); align-items:start; } }

.toc-rail{ position:relative; min-width:0; }
@media (min-width:980px){ .toc-rail{ position:sticky; top:5rem; } }
.toc-rail .chap{ display:inline-flex; align-items:center; gap:.65rem; font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); margin-bottom:1.25rem; }
.toc-rail .chap::before{ content:""; width:26px; height:1px; background:currentColor; display:inline-block; }
.toc-rail nav.toc{ display:flex; flex-direction:column; gap:0; border-top:1px solid oklch(0.13 0.012 22 / .12); }
.toc-rail nav.toc a{
  display:block; padding:.7rem 0; padding-left:.25rem;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; text-transform:uppercase;
  color:oklch(0.30 0.012 25 / .7); border-bottom:1px solid oklch(0.13 0.012 22 / .12);
  transition:color .2s, padding-left .25s;
}
.toc-rail nav.toc a:hover{ color:var(--red); padding-left:.65rem; }
.toc-rail .ask{ margin-top:2rem; padding-top:1.5rem; border-top:1px solid oklch(0.13 0.012 22 / .12); }
.toc-rail .ask .eyebrow{ font-family:var(--mono); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:var(--mute-d); }
.toc-rail .ask p{ margin:.75rem 0 0; font-size:.92rem; line-height:1.55; color:oklch(0.30 0.012 25); }
.toc-rail .ask p a{ color:var(--red-medium); border-bottom:1px solid currentColor; }
.toc-rail .ask p a:hover{ color:var(--red); }

.prose{ min-width:0; max-width:none; }
.prose section{ margin-block: clamp(2.5rem, 5vh, 4rem); }
.prose section:first-of-type{ margin-top:0; }
.prose h2{
  margin:0 0 1.25rem; font-family:var(--sans); font-weight:300;
  font-size:clamp(1.55rem, 2.4vw, 2.1rem);
  letter-spacing:-0.028em; line-height:1.08; color:var(--ink);
  padding-bottom:1rem; border-bottom:1px solid oklch(0.13 0.012 22 / .14);
}
.prose h2::before{
  content:attr(data-num);
  display:block;
  font-family:var(--mono); font-weight:400;
  font-size:.66rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--red);
  margin-bottom:.7rem;
}

/* Definition lists (terminology) — 2-col label/definition grid */
.prose .deflist{
  margin: 1.5rem 0 0; max-width:78ch;
  display:grid; grid-template-columns:1fr; gap:.4rem 1.5rem;
  border-top:1px solid oklch(0.13 0.012 22 / .10);
}
.prose .deflist > dt{
  margin-top:1rem; font-weight:500; color:var(--ink);
  font-size:.95rem; line-height:1.4;
}
.prose .deflist > dt:first-child{ margin-top:.75rem; }
.prose .deflist > dd{
  margin: .15rem 0 .75rem; padding:0;
  font-size:.95rem; line-height:1.6; font-weight:300;
  color:oklch(0.30 0.012 25);
  border-bottom:1px solid oklch(0.13 0.012 22 / .08);
  padding-bottom:.85rem;
}
.prose .deflist > dd:last-child{ border-bottom:0; padding-bottom:0; }
@media (min-width:720px){
  .prose .deflist{ grid-template-columns: minmax(160px, 22ch) 1fr; align-items:baseline; }
  .prose .deflist > dt{ margin-top:0; padding-top:.85rem; border-top:1px solid oklch(0.13 0.012 22 / .08); }
  .prose .deflist > dt:first-of-type{ border-top:0; padding-top:.85rem; }
  .prose .deflist > dd{ margin:0; padding-top:.85rem; padding-bottom:.85rem; border-bottom:0; border-top:1px solid oklch(0.13 0.012 22 / .08); }
  .prose .deflist > dd:nth-of-type(1){ border-top:0; }
}

/* Personal-data tables (.data-card) — bordered box with mono labels */
.prose .data-card{
  margin: 1.5rem 0 0; padding: clamp(1.25rem, 2vw, 1.75rem);
  border: 1px solid oklch(0.13 0.012 22 / .14);
  border-radius: 12px;
  background: oklch(0.13 0.012 22 / .02);
  max-width:78ch;
}
.prose .data-card h3{
  margin: 0 0 .85rem;
  font-family:var(--mono); font-weight:500;
  font-size:.78rem; letter-spacing:.06em;
  color:var(--ink);
}
.prose .data-card dl{ margin:0; }
.prose .data-card .field-row{
  display:grid; grid-template-columns: 1fr;
  gap:.25rem 1.5rem;
  padding-block:.75rem;
  border-top:1px solid oklch(0.13 0.012 22 / .10);
}
.prose .data-card .field-row:first-child{ border-top:0; padding-top:.25rem; }
@media (min-width:640px){
  .prose .data-card .field-row{ grid-template-columns: minmax(120px, 18ch) 1fr; align-items:baseline; }
}
.prose .data-card .field-row dt{
  margin:0;
  font-family:var(--mono); font-size:.65rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--mute-d);
}
.prose .data-card .field-row dd{
  margin:0;
  font-size:.93rem; line-height:1.55; font-weight:300;
  color:oklch(0.30 0.012 25);
}
.prose h3{ margin:2rem 0 .75rem; font-family:var(--sans); font-weight:400; font-size:1.1rem; letter-spacing:-0.015em; line-height:1.2; color:var(--ink); }
.prose p{ margin:1rem 0 0; max-width:66ch; font-size:.97rem; line-height:1.7; font-weight:300; color:oklch(0.30 0.012 25); }
.prose ul{ margin:1rem 0 0; padding-left:0; list-style:none; max-width:66ch; display:flex; flex-direction:column; gap:.6rem; }
.prose ul li{ position:relative; padding-left:1.35rem; font-size:.97rem; line-height:1.65; font-weight:300; color:oklch(0.30 0.012 25); }
.prose ul li::before{ content:""; position:absolute; left:0; top:.7em; width:.5rem; height:1px; background:var(--red); }
.prose strong{ color:var(--ink); font-weight:500; }
.prose a{ color:var(--red-medium); border-bottom:1px solid oklch(0.55 0.20 25 / .35); transition:color .2s, border-color .2s; }
.prose a:hover{ color:var(--red); border-bottom-color:var(--red); }
.prose .legal-caps{
  margin: 1.25rem 0 0; padding: 1.25rem 1.5rem;
  background:oklch(0.13 0.012 22 / .04);
  border:1px solid oklch(0.13 0.012 22 / .08);
  border-left:2px solid var(--red);
  border-radius:6px; max-width:72ch;
  font-family:var(--mono); font-size:.78rem; line-height:1.65; letter-spacing:.005em;
  color:oklch(0.30 0.012 25 / .9);
}

/* RELATED */
.prose .related{ margin-top:clamp(3rem, 6vh, 4.5rem); padding-top:clamp(2rem, 4vh, 3rem); border-top:1px solid oklch(0.13 0.012 22 / .14); }
.prose .related .eyebrow{ font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.prose .related-grid{ margin-top:1.5rem; display:grid; grid-template-columns:1fr; gap:.75rem; }
@media (min-width:760px){ .prose .related-grid{ grid-template-columns:1fr 1fr; gap:1rem; } }
.prose .related-grid a{
  display:block; padding:1.4rem 1.5rem; border-radius:12px;
  border:1px solid oklch(0.13 0.012 22 / .14); background:transparent;
  transition:border-color .25s, background .25s, transform .25s;
}
.prose .related-grid a:hover{ border-color:var(--ink); background:oklch(0.13 0.012 22 / .03); transform:translateY(-1px); }
.prose .related-grid .num{ font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.prose .related-grid .label{ display:block; margin-top:.5rem; font-weight:300; font-size:1.35rem; letter-spacing:-0.025em; line-height:1.1; color:var(--ink); }

/* REVEAL */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1); }
.reveal.in{ opacity:1; transform:none; }


/* ============================================================
   PAGE: cookie.html
============================================================ */
:root{
  --ink:        oklch(0.13 0.012 22);
  --ink-2:      oklch(0.18 0.015 22);
  --ink-3:      oklch(0.30 0.014 22);
  --bone:       oklch(0.97 0.011 35);
  --paper:      oklch(0.95 0.013 35);
  --paper-2:    oklch(0.92 0.016 30);
  --red:         #E9364D;
  --red-medium:  #B31E31;
  --red-deep:    #791421;
  --grad-cta:    linear-gradient(135deg, rgb(158,32,41) 0%, rgb(228,78,88) 50%, rgb(251,68,51) 100%);
  --grad-dark:   linear-gradient(135deg, rgb(179,30,49) 0%, rgb(77,13,21) 100%);
  --mute:        oklch(0.65 0.012 25);
  --mute-d:      oklch(0.50 0.012 25);
  --rule:        oklch(0.97 0.011 35 / .14);
  --rule-soft:   oklch(0.97 0.011 35 / .08);
  --sans:        'Geist', ui-sans-serif, system-ui, sans-serif;
  --mono:        'Geist Mono', ui-monospace, monospace;
  --pad-x:       clamp(1.25rem, 4vw, 2.75rem);
}

*{ box-sizing:border-box; }
html, body{ margin:0; padding:0; background:var(--ink); color:var(--bone); }
body{ font-family:var(--sans); font-weight:300; font-feature-settings:"ss01","ss03","cv11"; letter-spacing:-0.005em; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
a{ color:inherit; text-decoration:none; }
img,video{ display:block; max-width:100%; }
button{ font:inherit; cursor:pointer; background:none; border:0; color:inherit; }
::selection{ background:var(--red); color:var(--bone); }
.frame{ max-width:1480px; margin-inline:auto; padding-inline:var(--pad-x); }

.tx-display-xl{ font-weight:200; font-size:clamp(2.75rem, 7vw, 6.4rem); letter-spacing:-0.05em; line-height:.98; }
.tx-display-m { font-weight:300; font-size:clamp(1.75rem, 3.6vw, 3.2rem); letter-spacing:-0.034em; line-height:1.06; }
.balance      { text-wrap:balance; }

/* MASTHEAD */
.masthead{ position:absolute; inset:0 0 auto 0; z-index:30; padding-block:1.5rem 1.25rem; }
.masthead-inner{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:2rem; }
.masthead .brand{ justify-self:start; display:inline-flex; align-items:center; }
.masthead .brand img{ height:44px; width:auto; display:block; }
.masthead-nav{ display:none; justify-content:center; align-items:center; gap:2.25rem; }
.masthead-nav a{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; font-weight:400; color:oklch(0.97 0.011 35 / .68); transition:color .25s; }
.masthead-nav a:hover, .masthead-nav a.is-on{ color:var(--bone); }
.masthead-cta{ justify-self:end; display:inline-flex; align-items:center; gap:.6rem; padding:.7rem 1.15rem; border-radius:999px; font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--bone); background:var(--grad-dark); border:1px solid oklch(0.55 0.20 25 / .35); box-shadow:0 16px 38px -16px rgba(179,30,49,.55), inset 0 1px 0 rgba(255,255,255,.08); transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s; }
.masthead-cta:hover{ transform:translateY(-1px); box-shadow:0 22px 46px -16px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.12); }
.masthead-cta .dot{ width:6px; height:6px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 3px oklch(1 0 0 / .15); }
@media (min-width:880px){ .masthead-nav{ display:flex; } }

.btn{ display:inline-flex; align-items:center; gap:.85rem; padding:1.1rem 1.65rem; border-radius:999px; font-size:.86rem; font-weight:500; letter-spacing:.005em; transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s, background .25s, color .25s, border-color .25s; }
.btn:hover{ transform:translateY(-1px); }
.btn-grad{ color:var(--bone); background:var(--grad-cta); box-shadow:0 24px 50px -18px rgba(228,78,88,.55), inset 0 1px 0 rgba(255,255,255,.18), 0 1px 0 rgba(80,8,15,.5); position:relative; overflow:hidden; }
.btn-grad::before{ content:""; position:absolute; inset:0; border-radius:inherit; background:linear-gradient(135deg, rgba(255,255,255,.18) 0%, transparent 40%); pointer-events:none; }
.btn-grad .dot{ width:7px; height:7px; border-radius:999px; background:var(--bone); box-shadow:0 0 0 4px rgba(255,255,255,.18); }

.link-arrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--red-medium); transition:color .25s; }
.link-arrow .ar{ transition:transform .35s cubic-bezier(.16,1,.3,1); display:inline-block; }
.link-arrow:hover{ color:var(--red); } .link-arrow:hover .ar{ transform:translateX(4px); }
.link-arrow.on-dark{ color:#ff8a8a; } .link-arrow.on-dark:hover{ color:var(--bone); }

/* HERO */
.hero{ position:relative; min-height:auto; overflow:hidden; background:var(--ink); isolation:isolate; display:flex; flex-direction:column; justify-content:flex-end; padding-block:clamp(8rem, 16vh, 11rem) clamp(2.5rem, 5vh, 4rem); }
.hero-bg{ position:absolute; inset:0; z-index:1; overflow:hidden; }
.hero-bg img{
  position:absolute; right:0; top:0; height:100%; width:72%; object-fit:cover; object-position:center;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%), linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  -webkit-mask-composite: source-in;
          mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.15) 14%, rgba(0,0,0,.55) 30%, #000 52%), linear-gradient(180deg, #000 60%, rgba(0,0,0,.4) 92%, transparent 100%);
  mask-composite: intersect; opacity:.85;
}
.hero::before{ content:""; position:absolute; inset:0; z-index:2; pointer-events:none; background: linear-gradient(180deg, oklch(0.13 0.012 22 / .92) 0%, oklch(0.13 0.012 22 / .35) 20%, transparent 40%), radial-gradient(45% 60% at 90% 50%, oklch(0.55 0.20 25 / .14), transparent 70%); }
.hero-content{ position:relative; z-index:5; }
.hero .frame{ max-width:none; margin-inline:0; padding-inline:var(--pad-x); text-align:left; }
.hero-eyebrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono); font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:oklch(0.97 0.011 35 / .82); margin-bottom:clamp(2rem, 4vh, 3rem); }
.hero-eyebrow .pulse{ width:7px; height:7px; border-radius:999px; background:var(--red); position:relative; }
.hero-eyebrow .pulse::after{ content:""; position:absolute; inset:-4px; border-radius:999px; border:1px solid var(--red); opacity:.5; animation:pulse 2s ease-out infinite; }
@keyframes pulse{ 0%{transform:scale(.6); opacity:.6;} 100%{transform:scale(1.8); opacity:0;} }
.hero h1{ margin:0; max-width:18ch; color:var(--bone); font-size:clamp(2.75rem, 7vw, 6.4rem); font-weight:200; line-height:.98; letter-spacing:-0.05em; }
.hero .sub{ margin:clamp(1.5rem, 2.4vh, 2rem) 0 0; max-width:62ch; font-size:clamp(.95rem, 1.05vw, 1.05rem); line-height:1.6; font-weight:300; color:oklch(0.97 0.011 35 / .78); }
.hero .meta{ margin-top: clamp(1.25rem, 2.4vh, 1.75rem); display:flex; flex-wrap:wrap; gap:.75rem; }
.hero .meta .chip{ display:inline-flex; align-items:center; gap:.55rem; padding:.45rem .85rem; border-radius:999px; border:1px solid oklch(0.97 0.011 35 / .22); font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:oklch(0.97 0.011 35 / .82); background:oklch(0.13 0.012 22 / .35); backdrop-filter:blur(8px); }
.hero .meta .chip .accent{ color:var(--red); }

/* DOCUMENT BODY */
.doc{ background:var(--bone); color:var(--ink); padding-block:clamp(4.5rem, 9vh, 7rem); position:relative; }
.doc-grid{ display:grid; grid-template-columns:1fr; gap:clamp(2.5rem, 5vh, 4rem); }
@media (min-width:980px){ .doc-grid{ grid-template-columns: minmax(220px, 260px) 1fr; gap:clamp(3rem, 5vw, 5rem); align-items:start; } }

.toc-rail{ position:relative; min-width:0; }
@media (min-width:980px){ .toc-rail{ position:sticky; top:5rem; } }
.toc-rail .chap{ display:inline-flex; align-items:center; gap:.65rem; font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); margin-bottom:1.25rem; }
.toc-rail .chap::before{ content:""; width:26px; height:1px; background:currentColor; display:inline-block; }
.toc-rail nav.toc{ display:flex; flex-direction:column; gap:0; border-top:1px solid oklch(0.13 0.012 22 / .12); }
.toc-rail nav.toc a{
  display:block; padding:.7rem 0; padding-left:.25rem;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; text-transform:uppercase;
  color:oklch(0.30 0.012 25 / .7); border-bottom:1px solid oklch(0.13 0.012 22 / .12);
  transition:color .2s, padding-left .25s;
}
.toc-rail nav.toc a:hover{ color:var(--red); padding-left:.65rem; }
.toc-rail .ask{ margin-top:2rem; padding-top:1.5rem; border-top:1px solid oklch(0.13 0.012 22 / .12); }
.toc-rail .ask .eyebrow{ font-family:var(--mono); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:var(--mute-d); }
.toc-rail .ask p{ margin:.75rem 0 0; font-size:.92rem; line-height:1.55; color:oklch(0.30 0.012 25); }
.toc-rail .ask p a{ color:var(--red-medium); border-bottom:1px solid currentColor; }
.toc-rail .ask p a:hover{ color:var(--red); }

.prose{ min-width:0; max-width:none; }
.prose section{ margin-block: clamp(2.5rem, 5vh, 4rem); }
.prose section:first-of-type{ margin-top:0; }
.prose h2{
  margin:0 0 1.25rem; font-family:var(--sans); font-weight:300;
  font-size:clamp(1.55rem, 2.4vw, 2.1rem);
  letter-spacing:-0.028em; line-height:1.08; color:var(--ink);
  padding-bottom:1rem; border-bottom:1px solid oklch(0.13 0.012 22 / .14);
}
.prose h2::before{
  content:attr(data-num);
  display:block;
  font-family:var(--mono); font-weight:400;
  font-size:.66rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--red);
  margin-bottom:.7rem;
}

/* Definition lists (terminology) — 2-col label/definition grid */
.prose .deflist{
  margin: 1.5rem 0 0; max-width:78ch;
  display:grid; grid-template-columns:1fr; gap:.4rem 1.5rem;
  border-top:1px solid oklch(0.13 0.012 22 / .10);
}
.prose .deflist > dt{
  margin-top:1rem; font-weight:500; color:var(--ink);
  font-size:.95rem; line-height:1.4;
}
.prose .deflist > dt:first-child{ margin-top:.75rem; }
.prose .deflist > dd{
  margin: .15rem 0 .75rem; padding:0;
  font-size:.95rem; line-height:1.6; font-weight:300;
  color:oklch(0.30 0.012 25);
  border-bottom:1px solid oklch(0.13 0.012 22 / .08);
  padding-bottom:.85rem;
}
.prose .deflist > dd:last-child{ border-bottom:0; padding-bottom:0; }
@media (min-width:720px){
  .prose .deflist{ grid-template-columns: minmax(160px, 22ch) 1fr; align-items:baseline; }
  .prose .deflist > dt{ margin-top:0; padding-top:.85rem; border-top:1px solid oklch(0.13 0.012 22 / .08); }
  .prose .deflist > dt:first-of-type{ border-top:0; padding-top:.85rem; }
  .prose .deflist > dd{ margin:0; padding-top:.85rem; padding-bottom:.85rem; border-bottom:0; border-top:1px solid oklch(0.13 0.012 22 / .08); }
  .prose .deflist > dd:nth-of-type(1){ border-top:0; }
}

/* Personal-data tables (.data-card) — bordered box with mono labels */
.prose .data-card{
  margin: 1.5rem 0 0; padding: clamp(1.25rem, 2vw, 1.75rem);
  border: 1px solid oklch(0.13 0.012 22 / .14);
  border-radius: 12px;
  background: oklch(0.13 0.012 22 / .02);
  max-width:78ch;
}
.prose .data-card h3{
  margin: 0 0 .85rem;
  font-family:var(--mono); font-weight:500;
  font-size:.78rem; letter-spacing:.06em;
  color:var(--ink);
}
.prose .data-card dl{ margin:0; }
.prose .data-card .field-row{
  display:grid; grid-template-columns: 1fr;
  gap:.25rem 1.5rem;
  padding-block:.75rem;
  border-top:1px solid oklch(0.13 0.012 22 / .10);
}
.prose .data-card .field-row:first-child{ border-top:0; padding-top:.25rem; }
@media (min-width:640px){
  .prose .data-card .field-row{ grid-template-columns: minmax(120px, 18ch) 1fr; align-items:baseline; }
}
.prose .data-card .field-row dt{
  margin:0;
  font-family:var(--mono); font-size:.65rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--mute-d);
}
.prose .data-card .field-row dd{
  margin:0;
  font-size:.93rem; line-height:1.55; font-weight:300;
  color:oklch(0.30 0.012 25);
}
.prose h3{ margin:2rem 0 .75rem; font-family:var(--sans); font-weight:400; font-size:1.1rem; letter-spacing:-0.015em; line-height:1.2; color:var(--ink); }
.prose p{ margin:1rem 0 0; max-width:66ch; font-size:.97rem; line-height:1.7; font-weight:300; color:oklch(0.30 0.012 25); }
.prose ul{ margin:1rem 0 0; padding-left:0; list-style:none; max-width:66ch; display:flex; flex-direction:column; gap:.6rem; }
.prose ul li{ position:relative; padding-left:1.35rem; font-size:.97rem; line-height:1.65; font-weight:300; color:oklch(0.30 0.012 25); }
.prose ul li::before{ content:""; position:absolute; left:0; top:.7em; width:.5rem; height:1px; background:var(--red); }
.prose strong{ color:var(--ink); font-weight:500; }
.prose a{ color:var(--red-medium); border-bottom:1px solid oklch(0.55 0.20 25 / .35); transition:color .2s, border-color .2s; }
.prose a:hover{ color:var(--red); border-bottom-color:var(--red); }
.prose .legal-caps{
  margin: 1.25rem 0 0; padding: 1.25rem 1.5rem;
  background:oklch(0.13 0.012 22 / .04);
  border:1px solid oklch(0.13 0.012 22 / .08);
  border-left:2px solid var(--red);
  border-radius:6px; max-width:72ch;
  font-family:var(--mono); font-size:.78rem; line-height:1.65; letter-spacing:.005em;
  color:oklch(0.30 0.012 25 / .9);
}

/* RELATED */
.prose .related{ margin-top:clamp(3rem, 6vh, 4.5rem); padding-top:clamp(2rem, 4vh, 3rem); border-top:1px solid oklch(0.13 0.012 22 / .14); }
.prose .related .eyebrow{ font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.prose .related-grid{ margin-top:1.5rem; display:grid; grid-template-columns:1fr; gap:.75rem; }
@media (min-width:760px){ .prose .related-grid{ grid-template-columns:1fr 1fr; gap:1rem; } }
.prose .related-grid a{
  display:block; padding:1.4rem 1.5rem; border-radius:12px;
  border:1px solid oklch(0.13 0.012 22 / .14); background:transparent;
  transition:border-color .25s, background .25s, transform .25s;
}
.prose .related-grid a:hover{ border-color:var(--ink); background:oklch(0.13 0.012 22 / .03); transform:translateY(-1px); }
.prose .related-grid .num{ font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.prose .related-grid .label{ display:block; margin-top:.5rem; font-weight:300; font-size:1.35rem; letter-spacing:-0.025em; line-height:1.1; color:var(--ink); }

/* REVEAL */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1); }
.reveal.in{ opacity:1; transform:none; }


/* ============================================================
   PAGE: journal post template (journal/<slug>.html)
============================================================ */

/* Post hero — smaller than the section heroes; tighter top padding */
.post-hero{
  padding-block: clamp(8rem, 14vh, 11rem) clamp(3rem, 5vh, 4rem) !important;
}
.post-hero .back-link{
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase;
  color:oklch(0.97 0.011 35 / .55);
  transition:color .25s;
  margin-bottom:1.5rem;
}
.post-hero .back-link:hover{ color:var(--bone); }
.post-hero h1{
  margin:1rem 0 0; max-width:22ch;
  font-size:clamp(2rem, 5vw, 3.8rem); font-weight:200;
  line-height:1.04; letter-spacing:-0.04em; color:var(--bone);
}
.post-hero .post-meta{
  display:flex; flex-wrap:wrap; gap:1rem; align-items:center;
  margin-top: clamp(1.5rem, 3vh, 2rem);
  font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase;
  color:oklch(0.97 0.011 35 / .55);
}
.post-hero .post-meta .type{ color:var(--red); }
.post-hero .post-meta .meta-dot{ width:3px; height:3px; border-radius:999px; background:oklch(0.97 0.011 35 / .35); }

/* Post body — light bg, sidebar + content grid */
.post-body{ background:var(--bone); color:var(--ink); padding-block: clamp(4rem, 9vh, 6.5rem); position:relative; }
.post-grid{ display:grid; grid-template-columns:1fr; gap: clamp(2.5rem, 5vh, 4rem); }
@media (min-width: 980px){
  .post-grid{ grid-template-columns: minmax(280px, 340px) 1fr; gap: clamp(3rem, 5vw, 5rem); align-items:start; }
}

/* Sidebar */
.post-sidebar{ min-width:0; }
@media (min-width:980px){ .post-sidebar{ position:sticky; top: 5rem; } }
.post-sidebar .post-img{
  position:relative; aspect-ratio: 4/5;
  border-radius:14px; overflow:hidden;
  background:var(--paper-2);
  border:1px solid oklch(0.13 0.012 22 / .08);
}
.post-sidebar .post-img img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.post-sidebar .post-img::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 55%, oklch(0.13 0.012 22 / .55) 100%); }
.post-sidebar .post-img .file-badge{
  position:absolute; left:.95rem; bottom:.95rem; z-index:2;
  font-family:var(--mono); font-size:.6rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--bone); background:oklch(0.13 0.012 22 / .55); padding:.35rem .6rem; border-radius:5px;
  backdrop-filter:blur(6px);
}
.post-sidebar .post-stats{
  margin-top:1.75rem; padding-top:1.5rem;
  border-top:1px solid oklch(0.13 0.012 22 / .14);
  display:flex; flex-direction:column; gap:1.1rem;
}
.post-sidebar .post-stats .stat-row{ display:flex; flex-direction:column; gap:.25rem; }
.post-sidebar .post-stats .fig{
  font-family:var(--mono); font-weight:300;
  font-size:1.85rem; letter-spacing:-0.025em; line-height:1;
  color:var(--ink);
}
.post-sidebar .post-stats .lbl{
  font-family:var(--mono); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--mute-d);
}
.post-sidebar .post-tags{
  margin-top:1.75rem; padding-top:1.5rem;
  border-top:1px solid oklch(0.13 0.012 22 / .14);
  display:flex; flex-wrap:wrap; gap:.4rem;
}
.post-sidebar .post-tags .tag{
  font-family:var(--mono); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase;
  padding:.3rem .6rem; border-radius:4px;
  background:oklch(0.13 0.012 22 / .05); color:var(--mute-d);
}
.post-sidebar .post-cta{
  margin-top: 1.75rem; padding-top: 1.5rem;
  border-top: 1px solid oklch(0.13 0.012 22 / .14);
  display:flex; flex-direction:column; gap:.65rem; align-items:flex-start;
}
.post-sidebar .post-cta .link-arrow{ font-size:.74rem; }

/* Article content */
.post-content{ min-width:0; }
.post-content h2{
  margin: clamp(2.5rem, 5vh, 3.5rem) 0 1rem;
  font-family:var(--sans); font-weight:300;
  font-size:clamp(1.45rem, 2.3vw, 1.95rem);
  letter-spacing:-0.028em; line-height:1.1; color:var(--ink);
}
.post-content h2:first-of-type{ margin-top:0; }
.post-content h2::before{
  content:""; display:block; width:32px; height:1px;
  background:var(--red); margin-bottom:1rem;
}
.post-content p{
  margin: 1.1rem 0 0; max-width:62ch;
  font-size:1.02rem; line-height:1.7; font-weight:300;
  color:oklch(0.30 0.012 25);
}
.post-content ul{
  margin: 1.1rem 0 0; padding-left:0; list-style:none; max-width:62ch;
  display:flex; flex-direction:column; gap:.85rem;
}
.post-content ul li{
  position:relative; padding-left:1.5rem;
  font-size:1rem; line-height:1.6; font-weight:300;
  color:oklch(0.30 0.012 25);
}
.post-content ul li::before{
  content:""; position:absolute; left:0; top:.7em;
  width:.6rem; height:1px; background:var(--red);
}
.post-content .closing{
  margin-top: clamp(2.5rem, 5vh, 3.5rem);
  padding: clamp(1.5rem, 3vw, 2rem) 0;
  border-top:1px solid oklch(0.13 0.012 22 / .14);
  border-bottom:1px solid oklch(0.13 0.012 22 / .14);
  font-weight:300; font-style:italic;
  font-size:1.15rem; line-height:1.5; color:var(--ink-3); max-width:54ch;
}

/* "Other cases" cross-promotion at the bottom of each article */
.post-also{
  margin-top: clamp(3rem, 6vh, 4rem); padding-top: clamp(2rem, 4vh, 3rem);
  border-top:1px solid oklch(0.13 0.012 22 / .14);
}
.post-also .chap{
  display:inline-flex; align-items:center; gap:.65rem;
  font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--red);
}
.post-also .chap::before{ content:""; width:26px; height:1px; background:currentColor; display:inline-block; }
.post-also .grid{ margin-top:1.5rem; display:grid; grid-template-columns:1fr; gap:1rem; }
@media (min-width:760px){ .post-also .grid{ grid-template-columns:1fr 1fr; gap:1rem; } }
.post-also .grid a{
  display:block; padding:1.4rem 1.5rem; border-radius:12px;
  border:1px solid oklch(0.13 0.012 22 / .14);
  transition: border-color .25s, transform .25s;
}
.post-also .grid a:hover{ border-color:var(--ink); transform: translateY(-1px); }
.post-also .grid .meta{
  font-family:var(--mono); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:var(--mute-d);
}
.post-also .grid .title{
  display:block; margin-top:.5rem; font-weight:300; font-size:1.2rem;
  letter-spacing:-0.025em; line-height:1.15; color:var(--ink);
}
