/* Hallmark · pre-emit critique: P5 H5 E5 S4 R5 V4
 * macrostructure: Marquee Hero (editorial-magazine family) · genre: editorial (dark canvas)
 * tone: high-gloss digital magazine, male 18–35 · anchor hue: coral/sunset (warm ~38°)
 * theme: custom — paper oklch(15.5% .012 65) · accent oklch(70% .185 38) · Archivo + Inter + Space Mono
 * PALM BEACH PETE — "The Official Dispatch" design system
 * ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* paper / ink */
  --color-paper:    oklch(15.5% 0.012 65);
  --color-paper-2:  oklch(19%   0.014 65);
  --color-paper-3:  oklch(24%   0.016 65);
  --color-ink:      oklch(94%   0.012 85);
  --color-ink-2:    oklch(74%   0.018 75);
  --color-ink-3:    oklch(58%   0.020 70);
  --color-rule:     oklch(31%   0.014 65);
  --color-rule-2:   oklch(40%   0.016 65);
  /* accent */
  --color-accent:     oklch(70% 0.185 38);
  --color-accent-2:   oklch(77% 0.150 46);
  --color-accent-ink: oklch(17% 0.030 50);
  --color-focus:      oklch(83% 0.130 44);
  /* glows / tints */
  --tint-accent:  oklch(70% 0.185 38 / .14);
  --tint-accent-2:oklch(70% 0.185 38 / .07);

  /* type */
  --font-display:"Archivo","Arial Black",system-ui,sans-serif;
  --font-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --font-mono:"Space Mono",ui-monospace,"SF Mono",Menlo,Consolas,monospace;

  /* fluid type scale */
  --text-xs:.74rem; --text-sm:.85rem; --text-base:1.0rem; --text-md:1.12rem;
  --text-lg:1.33rem; --text-xl:1.75rem; --text-2xl:2.3rem;
  --text-display-s:clamp(2.6rem,6.2vw,4.6rem);
  --text-display:  clamp(3.4rem,12vw,11rem);

  /* spacing (4pt) */
  --space-3xs:.25rem; --space-2xs:.5rem; --space-xs:.75rem; --space-sm:1rem;
  --space-md:1.5rem; --space-lg:2rem; --space-xl:3rem; --space-2xl:4.5rem;
  --space-3xl:7rem; --space-4xl:9.5rem;

  /* misc */
  --maxw:1240px;
  --rule:1px solid var(--color-rule);
  --radius-card:14px; --radius-pill:999px; --radius-input:10px;
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-in:cubic-bezier(.5,0,.75,0);
  --ease-in-out:cubic-bezier(.65,.05,.36,1);
  --dur-fast:160ms; --dur:260ms; --dur-slow:520ms;
  --shadow-pop:0 24px 60px -18px oklch(0% 0 0 / .65);
}

/* ---------- Reset ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--color-paper);color:var(--color-ink);
  font-family:var(--font-body);font-size:17px;line-height:1.65;
  overflow-x:clip;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--color-accent);color:var(--color-accent-ink)}

h1,h2,h3,h4{
  font-family:var(--font-display);font-weight:900;color:var(--color-ink);
  text-transform:uppercase;line-height:.9;letter-spacing:-.02em;
  margin:0 0 .4em;overflow-wrap:anywhere;min-width:0;
}
h1{font-size:var(--text-display)}
h2{font-size:clamp(2.3rem,6vw,4.6rem)}
h3{font-size:var(--text-xl);line-height:1.02}
h4{font-size:var(--text-md);letter-spacing:.0em}
p{margin:0 0 1.15em}
strong{color:var(--color-ink);font-weight:600}

/* ---------- Layout ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,44px)}
.section{padding:var(--space-3xl) 0}
.section--tight{padding:var(--space-2xl) 0}
.bleed{position:relative}
.hr{height:1px;background:var(--color-rule);border:0;margin:0}

/* ---------- Eyebrow / labels ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);
  font-weight:700;font-size:var(--text-xs);letter-spacing:.24em;text-transform:uppercase;
  color:var(--color-accent);margin:0 0 var(--space-md);
}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--color-accent)}
.eyebrow--plain::before{display:none}
.eyebrow--muted{color:var(--color-ink-2)}
.lede{font-size:var(--text-lg);line-height:1.5;color:var(--color-ink-2);max-width:54ch}

/* ---------- Top ticker ---------- */
.ticker{
  background:var(--color-accent);color:var(--color-accent-ink);
  font-family:var(--font-mono);font-weight:700;font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;overflow:hidden;white-space:nowrap;border-bottom:1px solid var(--color-accent-ink);
}
.ticker__row{display:inline-flex;gap:0;padding:7px 0;animation:tick 32s linear infinite;will-change:transform}
.ticker__row span{padding:0 18px;position:relative}
.ticker__row span::after{content:"◆";position:absolute;right:-4px;opacity:.5}
@keyframes tick{to{transform:translateX(-50%)}}

/* ---------- Header / nav (N6 — masthead bar) ---------- */
.site-header{position:sticky;top:0;z-index:60;background:oklch(15.5% .012 65 / .82);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:var(--rule)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);height:72px}
.brand{display:flex;align-items:center;gap:12px;color:var(--color-ink)}
.brand .seal{width:38px;height:38px;flex:none}
.brand .wm{font-family:var(--font-display);font-weight:900;font-size:1.12rem;letter-spacing:-.01em;
  text-transform:uppercase;line-height:.92;color:var(--color-ink)}
.brand .wm b{color:var(--color-accent);font-weight:900}
.nav-links{display:flex;gap:var(--space-2xs);align-items:center;list-style:none;margin:0;padding:0}
.nav-links a:not(.btn){
  position:relative;color:var(--color-ink-2);font-family:var(--font-mono);font-weight:700;
  font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;padding:9px 14px;
  transition:color var(--dur-fast) var(--ease-out);
}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:14px;right:14px;bottom:3px;height:2px;
  background:var(--color-accent);transform:scaleX(0);transform-origin:left;
  transition:transform var(--dur) var(--ease-out)}
.nav-links a:not(.btn):hover{color:var(--color-ink)}
.nav-links a:not(.btn):hover::after,.nav-links a:not(.btn).active::after{transform:scaleX(1)}
.nav-links a:not(.btn).active{color:var(--color-ink)}
.nav-links .btn{color:var(--fg)}
.nav-cta{margin-left:6px}
.nav-toggle{display:none;background:none;border:1px solid var(--color-rule-2);border-radius:8px;
  color:var(--color-ink);width:42px;height:42px;font-size:1.3rem;cursor:pointer;line-height:1;align-items:center;justify-content:center}

/* ---------- Buttons (8 states) ---------- */
.btn{
  --bg:transparent;--fg:var(--color-ink);--bd:var(--color-rule-2);
  display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-weight:700;
  font-size:.8rem;letter-spacing:.13em;text-transform:uppercase;cursor:pointer;white-space:nowrap;
  padding:15px 26px;border:1.5px solid var(--bd);background:var(--bg);color:var(--fg);
  border-radius:var(--radius-pill);transition:transform var(--dur-fast) var(--ease-out),
  background var(--dur) var(--ease-out),color var(--dur) var(--ease-out),border-color var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease-out);
}
.btn .arr{transition:transform var(--dur) var(--ease-out)}
.btn:hover .arr{transform:translateX(4px)}
.btn--accent{--bg:var(--color-accent);--fg:var(--color-accent-ink);--bd:var(--color-accent)}
.btn--accent:hover{--bg:var(--color-accent-2);--bd:var(--color-accent-2);box-shadow:0 12px 30px -10px var(--tint-accent);transform:translateY(-2px)}
.btn--ghost{--bg:transparent;--fg:var(--color-ink);--bd:var(--color-rule-2)}
.btn--ghost:hover{--bd:var(--color-ink);--bg:var(--color-paper-3);transform:translateY(-2px)}
.btn--line{--bd:var(--color-accent);--fg:var(--color-accent)}
.btn--line:hover{--bg:var(--color-accent);--fg:var(--color-accent-ink)}
.btn--sm{padding:11px 18px;font-size:.72rem}
.btn:focus-visible{outline:2px solid var(--color-focus);outline-offset:3px}
.btn:active{transform:translateY(0) scale(.985)}
.btn[disabled],.btn[aria-disabled="true"]{opacity:.45;pointer-events:none;cursor:not-allowed}
.btn[data-state="loading"]{color:transparent;position:relative;pointer-events:none}
.btn[data-state="loading"]::after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;
  border:2px solid currentColor;border-top-color:transparent;color:var(--color-accent-ink);
  animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Hero (Marquee cover) ---------- */
.hero{position:relative;overflow:clip;border-bottom:var(--rule);
  background:
    radial-gradient(120% 90% at 88% -10%, var(--tint-accent) 0%, transparent 55%),
    radial-gradient(80% 70% at 0% 110%, var(--tint-accent-2) 0%, transparent 60%);
}
.hero__inner{padding:clamp(40px,7vw,96px) 0 clamp(48px,7vw,104px);position:relative;z-index:2}
.hero__top{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-md);
  font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.2em;text-transform:uppercase;
  color:var(--color-ink-3);border-bottom:var(--rule);padding-bottom:var(--space-sm);margin-bottom:clamp(22px,4vw,46px)}
.hero__top b{color:var(--color-accent)}
.hero__title{font-size:var(--text-display);line-height:.82;margin:0 0 .12em;letter-spacing:-.03em}
.hero__title .ln{display:block}
.hero__title .red{color:var(--color-accent);position:relative}
.hero__grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(0,.8fr);gap:clamp(24px,4vw,56px);align-items:end}
.hero__lede{font-size:clamp(1.1rem,1.7vw,1.4rem);line-height:1.5;color:var(--color-ink-2);max-width:50ch;margin:var(--space-md) 0 var(--space-lg)}
.hero__lede strong{color:var(--color-ink)}
.hero__cta{display:flex;gap:var(--space-xs);flex-wrap:wrap}
.hero__seal{display:flex;justify-content:flex-end;align-items:flex-end}
.hero__seal svg{width:min(230px,46vw);height:auto;animation:rotate 60s linear infinite}
@keyframes rotate{to{transform:rotate(360deg)}}
.hero__credit{margin-top:var(--space-lg);font-family:var(--font-mono);font-size:var(--text-xs);
  letter-spacing:.18em;text-transform:uppercase;color:var(--color-ink-3)}

/* ---------- Ledger (stat strip) ---------- */
.ledger{border-bottom:var(--rule);background:var(--color-paper-2)}
.ledger .container{display:grid;grid-template-columns:repeat(3,1fr)}
.ledger .cell{padding:clamp(22px,3vw,34px) clamp(16px,2.4vw,30px);border-left:var(--rule)}
.ledger .cell:first-child{border-left:0}
.ledger .k{font-family:var(--font-display);font-weight:900;font-size:clamp(2rem,4vw,3rem);line-height:.9;
  color:var(--color-ink);text-transform:uppercase}
.ledger .k em{color:var(--color-accent);font-style:normal}
.ledger .v{margin-top:10px;font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.18em;
  text-transform:uppercase;color:var(--color-ink-2)}

/* ---------- Section heads ---------- */
.shead{max-width:62ch}
.shead--center{margin:0 auto;text-align:center}
.shead--center .eyebrow{justify-content:center}
.shead .lede{margin-top:var(--space-sm)}
.shead--center .lede{margin-left:auto;margin-right:auto}

/* ---------- Feature rows ---------- */
.feature{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(28px,5vw,72px);align-items:center}
.feature--rev .feature__media{order:2}
.feature__media{position:relative}
.feature ul.platform{list-style:none;padding:0;margin:var(--space-lg) 0 0}
.feature .platform li{display:flex;gap:var(--space-md);align-items:baseline;padding:var(--space-md) 0;border-top:var(--rule)}
.feature .platform li:last-child{border-bottom:var(--rule)}
.feature .platform .n{font-family:var(--font-mono);font-weight:700;font-size:.85rem;color:var(--color-accent);flex:none;width:34px}
.feature .platform .t{color:var(--color-ink);font-size:var(--text-md)}

/* ---------- Photo frames (placeholders) ---------- */
.frame{position:relative;background:var(--color-paper-2);border:var(--rule);overflow:hidden;border-radius:var(--radius-card)}
.frame::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 0 0 1px oklch(94% .012 85 / .04);pointer-events:none}
.frame__mono{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:900;font-size:clamp(2.6rem,7vw,5rem);color:var(--color-rule-2);letter-spacing:-.02em}
.frame__cap{position:absolute;left:0;right:0;bottom:16px;text-align:center;font-family:var(--font-mono);
  font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--color-ink-3);z-index:2}
.frame img{width:100%;height:100%;object-fit:cover}
.frame--sq{aspect-ratio:1/1}
.frame--port{aspect-ratio:4/5}
.frame--wide{aspect-ratio:16/11}

/* ---------- Numbered editorial cards ---------- */
.numgrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;background:var(--color-rule);
  border:var(--rule);border-radius:var(--radius-card);overflow:hidden;margin-top:var(--space-2xl)}
.numcard{background:var(--color-paper);padding:clamp(26px,3vw,40px);transition:background var(--dur) var(--ease-out)}
.numcard:hover{background:var(--color-paper-2)}
.numcard .num{font-family:var(--font-mono);font-weight:700;font-size:.8rem;letter-spacing:.2em;color:var(--color-accent);display:block;margin-bottom:var(--space-md)}
.numcard h3{margin-bottom:.5em}
.numcard p{color:var(--color-ink-2);font-size:var(--text-base);margin:0}

/* ---------- Pull quote ---------- */
.quote{border-top:var(--rule);border-bottom:var(--rule);background:var(--color-paper-2);text-align:center}
.quote .container{padding-top:var(--space-3xl);padding-bottom:var(--space-3xl)}
.quote blockquote{font-family:var(--font-display);font-weight:900;text-transform:uppercase;
  font-size:clamp(2.4rem,8vw,6rem);line-height:.88;letter-spacing:-.03em;margin:0 auto var(--space-md);max-width:14ch}
.quote blockquote em{color:var(--color-accent);font-style:normal}
.quote cite{font-family:var(--font-mono);font-style:normal;font-size:var(--text-xs);letter-spacing:.24em;text-transform:uppercase;color:var(--color-ink-2)}

/* ---------- Cards (articles) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-md)}
.card{display:flex;flex-direction:column;background:var(--color-paper-2);border:var(--rule);
  border-radius:var(--radius-card);overflow:hidden;transition:transform var(--dur) var(--ease-out),border-color var(--dur) var(--ease-out)}
.card:hover{transform:translateY(-5px);border-color:var(--color-rule-2)}
.card__media{position:relative;aspect-ratio:16/10;background:var(--color-paper-3);overflow:hidden}
.card__media .frame__mono{font-size:clamp(2rem,5vw,3rem)}
.card__media img{width:100%;height:100%;object-fit:cover}
.card__tag{position:absolute;top:14px;left:14px;background:var(--color-paper);color:var(--color-accent);
  font-family:var(--font-mono);font-weight:700;font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;padding:6px 11px;border-radius:var(--radius-pill);border:1px solid var(--color-rule-2);z-index:2}
.card__body{padding:var(--space-lg) var(--space-lg) var(--space-xl);display:flex;flex-direction:column;flex:1}
.card h3{margin-bottom:.45em}
.card p{color:var(--color-ink-2);font-size:var(--text-base);margin:0}
.card__more{margin-top:auto;padding-top:var(--space-md);font-family:var(--font-mono);font-weight:700;font-size:.72rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--color-accent);display:inline-flex;gap:8px;align-items:center}
.card:hover .card__more .arr{transform:translateX(4px)}
.card__more .arr{transition:transform var(--dur) var(--ease-out)}

/* ---------- Products ---------- */
.products{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-md)}
.product{display:flex;flex-direction:column;background:var(--color-paper-2);border:var(--rule);
  border-radius:var(--radius-card);overflow:hidden;transition:transform var(--dur) var(--ease-out),border-color var(--dur) var(--ease-out)}
.product:hover{transform:translateY(-5px);border-color:var(--color-rule-2)}
.product__media{position:relative;aspect-ratio:1/1;background:var(--color-paper-3);display:flex;align-items:center;justify-content:center}
.product__media .frame__mono{color:var(--color-rule-2)}
.product__media img{width:100%;height:100%;object-fit:cover}
.product__soon{position:absolute;top:14px;right:14px;background:var(--color-accent);color:var(--color-accent-ink);
  font-family:var(--font-mono);font-weight:700;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;padding:5px 10px;border-radius:var(--radius-pill)}
.product__body{padding:var(--space-md) var(--space-lg) var(--space-lg);border-top:var(--rule)}
.product__name{font-family:var(--font-display);font-weight:900;font-size:1.05rem;text-transform:uppercase;letter-spacing:-.01em;line-height:1;display:block;margin-bottom:14px;color:var(--color-ink)}
.product__row{display:flex;align-items:center;justify-content:space-between}
.product__price{font-family:var(--font-mono);font-weight:700;font-size:1.2rem;color:var(--color-accent)}
.product__link{font-family:var(--font-mono);font-weight:700;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-ink-2);transition:color var(--dur-fast) var(--ease-out)}
.product:hover .product__link{color:var(--color-ink)}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-md);margin-top:var(--space-2xl)}
.step{padding:clamp(24px,3vw,36px);background:var(--color-paper-2);border:var(--rule);border-radius:var(--radius-card)}
.step .num{font-family:var(--font-display);font-weight:900;font-size:2.4rem;color:var(--color-accent);line-height:1;display:block;margin-bottom:12px}
.step h3{margin-bottom:.4em}
.step p{color:var(--color-ink-2);font-size:var(--text-base);margin:0}

/* ---------- Page hero (interior) ---------- */
.page-hero{border-bottom:var(--rule);background:radial-gradient(120% 120% at 80% -30%,var(--tint-accent) 0,transparent 55%)}
.page-hero .container{padding-top:clamp(48px,7vw,96px);padding-bottom:clamp(40px,6vw,80px);text-align:center}
.page-hero h1{font-size:var(--text-display-s);letter-spacing:-.02em;margin-bottom:.25em}
.page-hero p{color:var(--color-ink-2);font-size:var(--text-lg);max-width:60ch;margin:0 auto}
.page-hero .eyebrow{justify-content:center}

/* ---------- FAQ ---------- */
.faq{max-width:880px;margin:0 auto}
.faq details{border:var(--rule);border-radius:var(--radius-card);margin-bottom:12px;background:var(--color-paper-2);overflow:hidden}
.faq details[open]{border-color:var(--color-rule-2)}
.faq summary{cursor:pointer;list-style:none;padding:var(--space-lg) calc(var(--space-2xl) + 8px) var(--space-lg) var(--space-lg);
  font-family:var(--font-display);font-weight:900;font-size:1.18rem;text-transform:uppercase;letter-spacing:-.01em;
  color:var(--color-ink);position:relative;transition:color var(--dur-fast) var(--ease-out)}
.faq summary:hover{color:var(--color-accent)}
.faq summary:focus-visible{outline:2px solid var(--color-focus);outline-offset:-2px;border-radius:8px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"";position:absolute;right:24px;top:50%;width:14px;height:14px;
  background:
    linear-gradient(var(--color-accent),var(--color-accent)) center/14px 2px no-repeat,
    linear-gradient(var(--color-accent),var(--color-accent)) center/2px 14px no-repeat;
  transform:translateY(-50%);transition:transform var(--dur) var(--ease-out)}
.faq details[open] summary::after{transform:translateY(-50%) rotate(135deg)}
.faq__a{padding:0 var(--space-lg) var(--space-lg);color:var(--color-ink-2);font-size:var(--text-base)}
.faq__a a{color:var(--color-accent);border-bottom:1px solid var(--color-rule-2)}
.faq__a a:hover{border-color:var(--color-accent)}

/* ---------- Forms (8 states) ---------- */
.form{display:flex;flex-direction:column;gap:var(--space-md);max-width:520px}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:var(--font-mono);font-weight:700;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--color-ink-2)}
.field input,.field select,.field textarea{
  font-family:var(--font-body);font-size:1rem;color:var(--color-ink);background:var(--color-paper-2);
  border:1.5px solid var(--color-rule);border-radius:var(--radius-input);padding:13px 15px;width:100%;
  transition:border-color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out);
}
.field textarea{min-height:130px;resize:vertical}
.field input::placeholder,.field textarea::placeholder{color:var(--color-ink-3)}
.field input:hover,.field select:hover,.field textarea:hover{border-color:var(--color-rule-2)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--tint-accent);background:var(--color-paper)}
.field input:focus-visible{outline:none}
.field input:disabled,.field textarea:disabled{opacity:.5;cursor:not-allowed}
.field input:user-invalid,.field textarea:user-invalid{border-color:oklch(62% .18 25)}
.field [data-ok]{border-color:oklch(70% .14 150)}
.field select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--color-ink-2) 50%),linear-gradient(135deg,var(--color-ink-2) 50%,transparent 50%);
  background-position:calc(100% - 20px) 19px,calc(100% - 14px) 19px;background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:42px}
.ok{display:none;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;color:oklch(78% .14 150);
  border:1px solid oklch(50% .1 150);border-radius:var(--radius-input);padding:12px 14px;background:oklch(70% .14 150 / .08)}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:clamp(32px,5vw,72px)}
.contact-list{list-style:none;padding:0;margin:0}
.contact-list li{padding:var(--space-md) 0;border-top:var(--rule)}
.contact-list li:last-child{border-bottom:var(--rule)}
.contact-list .k{font-family:var(--font-mono);font-weight:700;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--color-ink-3);margin-bottom:4px}
.contact-list .v{font-family:var(--font-body);font-size:1.1rem;color:var(--color-ink)}

/* ---------- Socials ---------- */
.socials{display:flex;flex-wrap:wrap;gap:8px;margin-top:var(--space-md)}
.socials a{font-family:var(--font-mono);font-weight:700;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--color-ink-2);border:1px solid var(--color-rule);border-radius:var(--radius-pill);padding:8px 14px;
  transition:color var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out)}
.socials a:hover{color:var(--color-accent-ink);background:var(--color-accent);border-color:var(--color-accent)}
.socials a:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}

/* ---------- CTA ---------- */
.cta{text-align:center;border-top:var(--rule);
  background:radial-gradient(100% 140% at 50% 120%,var(--tint-accent) 0,transparent 60%)}
.cta .container{padding-top:var(--space-3xl);padding-bottom:var(--space-3xl)}
.cta h2{font-size:clamp(2.6rem,7vw,5.5rem);margin-bottom:.2em}
.cta p{color:var(--color-ink-2);font-size:var(--text-lg);max-width:48ch;margin:0 auto var(--space-lg)}

/* ---------- Footer ---------- */
.site-footer{border-top:var(--rule);background:var(--color-paper-2);padding:var(--space-3xl) 0 var(--space-xl)}
.footer-mark{font-family:var(--font-display);font-weight:900;text-transform:uppercase;line-height:.82;
  font-size:clamp(3rem,13vw,11rem);letter-spacing:-.04em;color:var(--color-ink);margin:0 0 var(--space-2xl)}
.footer-mark em{color:var(--color-accent);font-style:normal}
.footer-grid{display:grid;grid-template-columns:minmax(0,1.6fr) repeat(2,minmax(0,1fr));gap:var(--space-xl)}
.footer-brand p{color:var(--color-ink-2);font-size:var(--text-base);max-width:42ch}
.site-footer h4{font-family:var(--font-mono);font-weight:700;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--color-ink-3);margin:0 0 var(--space-sm)}
.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.footer-links a{color:var(--color-ink-2);font-size:.96rem;transition:color var(--dur-fast) var(--ease-out)}
.footer-links a:hover{color:var(--color-accent)}
.footer-bottom{display:flex;justify-content:space-between;gap:var(--space-md);flex-wrap:wrap;
  margin-top:var(--space-2xl);padding-top:var(--space-lg);border-top:var(--rule);
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-ink-3)}

/* ---------- Disclaimer ---------- */
.disclaimer{margin-top:var(--space-2xl);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.04em;
  line-height:1.7;color:var(--color-ink-3);max-width:80ch;border-left:2px solid var(--color-rule-2);padding-left:var(--space-md)}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-slow) var(--ease-out)}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .hero__grid{grid-template-columns:1fr}
  .hero__seal{justify-content:flex-start;margin-top:var(--space-lg)}
  .hero__seal svg{width:160px}
}
@media (max-width:860px){
  .nav-links{position:fixed;inset:72px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--color-paper);border-bottom:var(--rule);padding:var(--space-xs) 0;
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:opacity var(--dur) var(--ease-out),transform var(--dur) var(--ease-out)}
  .nav-links.open{transform:none;opacity:1;pointer-events:auto}
  .nav-links a:not(.btn){padding:14px clamp(20px,4vw,44px);font-size:.85rem}
  .nav-links a:not(.btn)::after{display:none}
  .nav-cta{margin:8px clamp(20px,4vw,44px) 8px;display:block}
  .nav-cta .btn{width:100%;justify-content:center}
  .nav-toggle{display:inline-flex}
  .feature,.contact-grid{grid-template-columns:1fr}
  .feature--rev .feature__media{order:0}
  .numgrid,.cards,.products,.steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media (max-width:560px){
  body{font-size:16px}
  .ledger .container{grid-template-columns:1fr}
  .ledger .cell{border-left:0;border-top:var(--rule)}
  .ledger .cell:first-child{border-top:0}
  .footer-grid{grid-template-columns:1fr}
  .hero__top{flex-direction:column;gap:6px}
  .footer-bottom{flex-direction:column;gap:8px}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important}
  .reveal{transition:opacity 150ms linear;transform:none}
  html{scroll-behavior:auto}
  .ticker__row{animation:none}
  .hero__seal svg{animation:none}
}
