/* =========================================================================
   Retract — design system v3 "pressroom"
   A two-ink risograph broadsheet: warm laid stock, ink black, ultramarine
   + a single scarlet alarm ink. Archivo Black poster display, Space Grotesk
   for running text, mono for marginalia.
   Craft: authentic offset registration (not a drop shadow), halftone press
   shadows, laid-paper + dot texture, crop/register marks, drop caps, hairline
   + rule pairs, letterpress buttons. Token-driven — reskin via :root.
   ========================================================================= */

/* ---- Fonts (self-hosted, no external requests) ------------------------ */
@font-face {
  font-family: "Archivo Black";
  src: url("/assets/fonts/archivo-black-latin.woff2") format("woff2");
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Space Grotesk";
  src: url("/assets/fonts/space-grotesk-latin.woff2") format("woff2");
  font-weight: 300 700; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "ArchivoBlack-fallback";
  src: local("Arial Black"), local("Segoe UI Black"), local("Arial Bold");
  size-adjust: 94%; ascent-override: 100%; descent-override: 26%; line-gap-override: 0%;
}

/* ---- Design tokens ----------------------------------------------------- */
:root {
  /* Stock + ink */
  --paper:   #efe6cf;
  --paper-hi:#f6efdd;
  --band:    #e6dabc;
  --sheet:   #fbf5e7;
  --sheet-hi:#fffdf5;
  --line:    #d8cdae;
  --line-2:  #bcae89;
  --rule:    #1c1a15;

  --ink:      #17140e;
  --ink-soft: #3a372e;
  --ink-mute: #6b6656;
  --ink-faint:#9a9377;

  /* Two press inks + one alarm */
  --blue:      #21309c;
  --blue-deep: #182573;
  --blue-bright:#2a3cc4;
  --blue-wash: rgba(33, 48, 156, 0.09);
  --red:       #d5341c;
  --red-deep:  #a72910;
  --red-wash:  rgba(213, 52, 28, 0.10);
  --okink:     #1f6a4a;

  /* Halftone dot screens (press shadows / texture) */
  --dots:     radial-gradient(rgba(23, 20, 14, .26) 1px, transparent 1.5px);
  --dots-red: radial-gradient(rgba(213, 52, 28, .38) 1px, transparent 1.5px);
  --dots-blue:radial-gradient(rgba(33, 48, 156, .34) 1px, transparent 1.5px);

  /* Type */
  --font: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --font-poster: "Archivo Black", "ArchivoBlack-fallback", Arial, sans-serif;
  --font-display: "Space Grotesk", Arial, sans-serif;
  --mono: ui-monospace, "Cascadia Code", "SF Mono", Menlo, Consolas, monospace;

  /* Motion */
  --ease:      cubic-bezier(.22, 1, .36, 1);
  --ease-slam: cubic-bezier(.6, -0.1, .2, 1.35);
  --dur-tap:  .12s;
  --dur-ui:   .3s;
  --dur-scene:.75s;

  /* Edges + press shadows */
  --r-xs: 2px;
  --r:    5px;
  --press:    4px 4px 0 rgba(28, 26, 21, .16);
  --press-lg: 9px 9px 0 rgba(28, 26, 21, .15);
  --press-blue: 5px 5px 0 rgba(33, 48, 156, .24);

  /* Layout */
  --maxw: 1200px;
  --gutter: clamp(1.15rem, 4vw, 2.6rem);
}

/* ---- Reset -------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; scroll-padding-top: 92px; overflow-x: clip; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: .001ms !important; animation-delay: 0s !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important; transition-delay: 0s !important;
  }
}
body {
  margin: 0;
  font-family: var(--font);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.62;
  font-size: clamp(1rem, .97rem + .18vw, 1.06rem);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: 0; }
h1, h2, h3, h4 { line-height: 1.08; margin: 0 0 .55em; text-wrap: balance; }
p { margin: 0 0 1em; text-wrap: pretty; }
ul { margin: 0; padding: 0; list-style: none; }
:focus-visible { outline: 2px solid var(--blue); outline-offset: 3px; border-radius: 2px; }
::selection { background: rgba(33, 48, 156, .22); }

/* ---- Stock: laid paper + faint halftone + warm glow --------------------- */
body::before {
  content: "";
  position: fixed; inset: 0; z-index: -3; pointer-events: none;
  background:
    radial-gradient(120% 75% at 50% -18%, rgba(255, 252, 240, .8), transparent 55%),
    radial-gradient(95% 65% at 50% 118%, rgba(200, 184, 146, .30), transparent 60%),
    var(--paper);
}
/* fine dot screen over the whole page — reads as printed tooth, not noise */
body::after {
  content: "";
  position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background-image: var(--dots);
  background-size: 5px 5px;
  opacity: .35;
  mix-blend-mode: multiply;
}
/* scarlet margin rule + faint laid lines live on a page-level layer */
.pagerule { position: fixed; inset: 0; z-index: -1; pointer-events: none; }
.pagerule::before {
  content: ""; position: absolute; top: 0; bottom: 0;
  left: max(1.15rem, calc((100vw - var(--maxw)) / 2 - 2.5rem));
  width: 1.5px; background: rgba(213, 52, 28, .32);
}
@media (max-width: 900px) { .pagerule::before { display: none; } }

/* ---- Type voices ---------------------------------------------------------- */
h1, h2.h, .poster {
  font-family: var(--font-poster);
  font-weight: 400; text-transform: uppercase;
  letter-spacing: -.014em; line-height: .95;
  font-synthesis-weight: none;
}
h2.h { font-size: clamp(1.75rem, 1.15rem + 2.5vw, 2.9rem); }
.prose h1 { font-family: var(--font-poster); font-weight: 400; text-transform: uppercase; letter-spacing: -.01em; line-height: 1; font-size: clamp(1.7rem, 1.3rem + 1.9vw, 2.5rem); }
.prose h2 { font-family: var(--font-display); font-weight: 700; letter-spacing: -.015em; }
.card h3, .step h3, .docket__row h3, .plan h3, .qa summary, .brief h3 {
  font-family: var(--font-display); font-weight: 600; letter-spacing: -.015em; line-height: 1.14;
}

/* ---- Layout helpers ------------------------------------------------------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: clamp(3.4rem, 7.5vw, 6.5rem); position: relative; }
.section--tight { padding-block: clamp(2.3rem, 4.5vw, 3.6rem); }
.section--band { background: var(--band); border-block: 2.5px solid var(--rule); position: relative; }
.section--band::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image: var(--dots); background-size: 6px 6px; opacity: .16; mix-blend-mode: multiply;
}
.section--band > .wrap { position: relative; }
.center { text-align: center; }
.muted { color: var(--ink-mute); }
.section__head { max-width: 46rem; margin-bottom: clamp(1.9rem, 4.5vw, 3rem); }
.section__head.center { margin-inline: auto; text-align: center; }
.lead { color: var(--ink-soft); font-size: clamp(1.05rem, 1rem + .38vw, 1.22rem); }

/* Section mark: scarlet index square + mono label + rule to the margin */
.mark {
  display: flex; align-items: center; gap: .75rem;
  font-family: var(--mono); font-size: .74rem; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase; color: var(--ink);
  margin-bottom: 1.25rem;
}
.mark::before { content: ""; width: .66em; height: .66em; background: var(--red); flex: none; box-shadow: 2px 2px 0 rgba(213,52,28,.28); }
.mark b { font-weight: 700; color: var(--blue); }
.mark::after { content: ""; height: 2px; flex: 1; max-width: 9rem; background: var(--rule); }

/* Heavy heading rule: thick bar + hairline echo (newspaper cutoff) */
.h--ruled { padding-bottom: .42em; position: relative; }
.h--ruled::after {
  content: ""; position: absolute; left: 0; bottom: 0; width: 100%;
  height: 5px; background: var(--rule);
  box-shadow: 0 8px 0 -6.5px var(--rule);
}
.section__head--left { max-width: 44rem; }
.section__head--left .h--ruled::after { width: min(100%, 32rem); }

/* ---- The STAMP ------------------------------------------------------------ */
.stamp {
  display: inline-block;
  font-family: var(--mono); font-weight: 700;
  font-size: .72rem; line-height: 1.3; letter-spacing: .2em; text-transform: uppercase;
  color: var(--red);
  border: 2.5px solid currentColor; border-radius: 3px;
  padding: .4rem .7rem .34rem .9rem;
  transform: rotate(-4deg);
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='40'%3E%3Cfilter id='g'%3E%3CfeTurbulence baseFrequency='.5' numOctaves='2' seed='7'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 .55 .55 .55 0 -.08'/%3E%3C/filter%3E%3Crect width='120' height='40' fill='%23fff' filter='url(%23g)'/%3E%3C/svg%3E");
  -webkit-mask-size: 120px 40px;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='40'%3E%3Cfilter id='g'%3E%3CfeTurbulence baseFrequency='.5' numOctaves='2' seed='7'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 .55 .55 .55 0 -.08'/%3E%3C/filter%3E%3Crect width='120' height='40' fill='%23fff' filter='url(%23g)'/%3E%3C/svg%3E");
  mask-size: 120px 40px;
}
.stamp--ok { color: var(--okink); }
.stamp--pen { color: var(--blue); }
.stamp--lg { font-size: 1rem; border-width: 3px; padding: .55rem 1rem .48rem 1.2rem; }
.js .stamp--slam { opacity: 0; transform: rotate(-4deg) scale(1.9); }
.stamp--slam.is-stamped { opacity: 1; transform: rotate(-4deg) scale(1); transition: transform .32s var(--ease-slam), opacity .18s ease-out; }

/* Struck-through register entries */
.void-item > s { text-decoration: none; position: relative; }
.void-item > s::after {
  content: ""; position: absolute; left: -2%; right: -2%; top: 54%;
  height: 2.5px; background: var(--red); transform: rotate(-.6deg);
}

/* ---- Buttons: letterpress blocks -------------------------------------------- */
.btn {
  --pad: .82rem 1.4rem;
  position: relative;
  display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  padding: var(--pad);
  border: 2px solid var(--rule); border-radius: var(--r-xs);
  background: var(--sheet); color: var(--ink);
  font-family: var(--font-display); font-weight: 700; font-size: .93rem;
  letter-spacing: .04em; text-transform: uppercase;
  box-shadow: var(--press);
  transition: transform var(--dur-ui) var(--ease), box-shadow var(--dur-ui) var(--ease), background var(--dur-ui);
  white-space: nowrap;
}
.btn svg { width: 1.12em; height: 1.12em; }
.btn--primary { background: var(--rule); color: var(--paper); }
.btn--pen { background: var(--blue); border-color: var(--blue-deep); color: #fff; box-shadow: var(--press-blue); }
.btn--red { background: var(--red); border-color: var(--red-deep); color: #fff; box-shadow: 4px 4px 0 rgba(213, 52, 28, .26); }
/* primary contact = ink-blue letterpress with the Telegram glyph (one blue, on-palette) */
.btn--tg { background: var(--blue); border-color: var(--blue-deep); color: #fff; box-shadow: var(--press-blue); }
.btn--wa { background: #1f9d54; border-color: #14713b; color: #fff; box-shadow: 4px 4px 0 rgba(20, 113, 59, .3); }
.btn--wa2 { background: var(--sheet); border-color: #17713c; color: #145f33; box-shadow: 4px 4px 0 rgba(20, 113, 59, .2); }
.btn--lg { --pad: 1.02rem 1.75rem; font-size: 1rem; }
.btn--ghost { box-shadow: none; background: transparent; }
@media (hover: hover) and (pointer: fine) {
  .btn:hover { transform: translate(-2px, -2px); box-shadow: 7px 7px 0 rgba(28, 26, 21, .18); }
  .btn--pen:hover, .btn--tg:hover { transform: translate(-2px, -2px); box-shadow: 8px 8px 0 rgba(33, 48, 156, .28); }
  .btn--red:hover { box-shadow: 7px 7px 0 rgba(213, 52, 28, .3); }
  .btn--wa:hover, .btn--wa2:hover { box-shadow: 7px 7px 0 rgba(20, 113, 59, .34); }
  .btn--ghost:hover { background: var(--blue-wash); box-shadow: none; }
}
.btn:active { transform: translate(2px, 2px); box-shadow: 1px 1px 0 rgba(28, 26, 21, .2); transition-duration: var(--dur-tap); }

.cta-note {
  margin: .8rem 0 0; font-size: .85rem; color: var(--ink-mute);
  display: flex; align-items: center; gap: .5rem;
}
.cta-note::before { content: "✓"; color: var(--okink); font-weight: 700; font-size: .9em; }
.nobr { white-space: nowrap; }

/* ---- Header: the masthead ------------------------------------------------------ */
.site-header {
  position: sticky; top: 0; z-index: 60;
  background: var(--paper);
  border-bottom: 3px solid var(--rule);
  transition: box-shadow var(--dur-ui);
}
.site-header::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -6px; height: 1px; background: var(--rule);
}
.site-header.is-stuck { box-shadow: 0 12px 30px -22px rgba(28, 26, 21, .6); }
.nav { display: flex; align-items: center; justify-content: space-between; gap: 1rem; height: 74px; }
.brand {
  display: inline-flex; align-items: center; gap: .68rem;
  font-family: var(--font-poster); font-weight: 400; font-size: 1.26rem;
  text-transform: uppercase; letter-spacing: -.01em;
}
.brand__mark {
  width: 37px; height: 37px; border-radius: var(--r-xs); display: grid; place-items: center;
  background: var(--rule); color: var(--paper); flex: none;
  box-shadow: 3px 3px 0 var(--red);
}
.brand__mark svg { width: 22px; height: 22px; }
.brand b { font-weight: 400; color: var(--blue); }
.nav__links { display: flex; align-items: center; gap: .1rem; }
.nav__links a {
  position: relative; padding: .6rem .72rem; color: var(--ink-soft);
  font-family: var(--mono); font-weight: 600; font-size: .735rem;
  letter-spacing: .15em; text-transform: uppercase;
  transition: color .2s;
}
.nav__links a::after {
  content: ""; position: absolute; left: .72rem; right: .72rem; bottom: .32rem;
  height: 2px; background: var(--red); transform: scaleX(0); transform-origin: 0 50%;
  transition: transform var(--dur-ui) var(--ease);
}
.nav__links a:hover, .nav__links a[aria-current="page"] { color: var(--ink); }
.nav__links a:hover::after, .nav__links a[aria-current="page"]::after { transform: scaleX(1); }
.nav__cta { display: flex; align-items: center; gap: .55rem; }
.nav__cta .btn { --pad: .56rem 1rem; font-size: .78rem; }
.nav__tg { display: none; }
.nav__toggle { display: none; width: 44px; height: 44px; border: 2px solid var(--rule); border-radius: var(--r-xs); align-items: center; justify-content: center; background: var(--sheet); box-shadow: var(--press); }
.nav__toggle span, .nav__toggle span::before, .nav__toggle span::after {
  content: ""; display: block; width: 18px; height: 2px; background: var(--ink);
  transition: transform var(--dur-ui) var(--ease), opacity .2s;
}
.nav__toggle span::before { transform: translateY(-6px); }
.nav__toggle span::after { transform: translateY(4px); }
body.nav-open .nav__toggle span { background: transparent; }
body.nav-open .nav__toggle span::before { transform: rotate(45deg); }
body.nav-open .nav__toggle span::after { transform: rotate(-45deg) translateY(-1px); }

/* ---- Contact bar ---------------------------------------------------------------- */
.contactbar { display: flex; flex-wrap: wrap; gap: .7rem; }
/* long contact labels (e.g. the full Telegram handle on /contact/) may wrap to a
   second line on narrow screens rather than overflow — short labels stay one line */
.contactbar .btn { flex: 1 1 auto; min-width: 0; white-space: normal; text-wrap: balance; line-height: 1.2; }

/* ---- Hero: the front page --------------------------------------------------------- */
.hero { padding-block: clamp(2.1rem, 4.5vw, 3.6rem) clamp(2.8rem, 5vw, 4.2rem); position: relative; }
/* crop/register marks in the top corners of the front page */
.hero::before, .hero::after {
  content: ""; position: absolute; top: clamp(1rem, 3vw, 1.9rem); width: 16px; height: 16px; pointer-events: none;
  opacity: .5;
}
.hero::before { left: 0; border-left: 1.5px solid var(--rule); border-top: 1.5px solid var(--rule); }
.hero::after  { right: 0; border-right: 1.5px solid var(--rule); border-top: 1.5px solid var(--rule); }
.dateline {
  display: flex; flex-wrap: wrap; gap: .5rem 1.9rem; align-items: baseline;
  border-bottom: 1.5px solid var(--line-2);
  padding-bottom: .85rem; margin-bottom: clamp(1.7rem, 4vw, 2.9rem);
  font-family: var(--mono); font-size: .73rem; letter-spacing: .16em;
  text-transform: uppercase; color: var(--ink-mute);
}
.dateline b { color: var(--ink); font-weight: 700; }
.dateline .dateline__ed { margin-left: auto; color: var(--red); font-weight: 700; }

/* Poster headline with authentic offset registration (a scarlet ghost plate,
   printed a hair out of register — NOT a drop shadow). */
.hero__title { margin: 0 0 .1em; }
.hero__title .over {
  position: relative; display: block; color: var(--ink);
  font-size: clamp(2.5rem, .4rem + 7vw, 5.6rem); line-height: .93; isolation: isolate;
}
.hero__title .over--blue { color: var(--blue); }
.hero__title .over__ghost {
  position: absolute; inset: 0; z-index: -1;
  color: var(--red); opacity: .16;
  transform: translate(.028em, .036em);
  mix-blend-mode: multiply; pointer-events: none; user-select: none;
}
.hero__deck {
  display: grid; grid-template-columns: minmax(0, 1.22fr) minmax(0, .78fr);
  gap: clamp(1.8rem, 4.5vw, 4rem); align-items: start;
  margin-top: clamp(1.6rem, 3.5vw, 2.6rem);
  position: relative;
}
/* thin column rule between lead and the index — like a newspaper gutter */
@media (min-width: 961px) {
  .hero__deck::before {
    content: ""; position: absolute; top: .2rem; bottom: .2rem;
    left: calc((100% - clamp(1.8rem, 4.5vw, 4rem)) * (1.22 / 2)); /* approx: sits in the gutter */
    left: 62%;
    width: 1.5px; background: var(--line-2);
  }
}
.hero__lead {
  color: var(--ink-soft); font-size: clamp(1.08rem, 1rem + .5vw, 1.3rem);
  max-width: 34rem; margin: 0 0 1.4rem; line-height: 1.55;
}
.hero__lead::first-line { color: var(--ink); }
.hero__cta { max-width: 34rem; }
.hero__trust {
  display: flex; flex-wrap: wrap; gap: .5rem 1.7rem; margin-top: 1.8rem;
  font-family: var(--mono); font-size: .78rem; color: var(--ink-mute);
}
.hero__trust li { display: inline-flex; align-items: center; gap: .45rem; }
.hero__trust li::before { content: "☑"; color: var(--okink); font-size: 1rem; }
.hero__aside { border-top: 4px solid var(--rule); padding-top: 1.05rem; font-size: .93rem; color: var(--ink-mute); }
.hero__aside .mono { font-family: var(--mono); font-size: .7rem; letter-spacing: .18em; text-transform: uppercase; color: var(--ink); display: block; margin-bottom: .7rem; font-weight: 700; }
.hero__aside ol { margin: 0; padding: 0; counter-reset: hx; }
.hero__aside li { counter-increment: hx; display: flex; gap: .75rem; align-items: baseline; padding: .5rem 0; border-bottom: 1px solid var(--line); transition: color .2s; }
.hero__aside li::before { content: counter(hx, decimal-leading-zero); font-family: var(--mono); font-size: .72rem; color: var(--red); font-weight: 700; }
.hero__aside li:last-child { border-bottom: 0; }
.hero__aside a { color: var(--ink-soft); font-weight: 550; }
@media (hover: hover) { .hero__aside li:hover a { color: var(--blue); } }

/* ---- The departures ticker ---------------------------------------------------------- */
.ticker {
  overflow: hidden; position: relative;
  border-block: 2.5px solid var(--rule);
  background: var(--sheet);
  padding-block: .72rem;
}
.ticker::before, .ticker::after { content: ""; position: absolute; top: 0; bottom: 0; width: 64px; z-index: 2; pointer-events: none; }
.ticker::before { left: 0; background: linear-gradient(90deg, var(--sheet), transparent); }
.ticker::after { right: 0; background: linear-gradient(-90deg, var(--sheet), transparent); }
.ticker__track { display: flex; gap: 3rem; width: max-content; animation: tickerscroll 42s linear infinite; }
.ticker:hover .ticker__track { animation-play-state: paused; }
@keyframes tickerscroll { to { transform: translateX(-50%); } }
.ticker__track ul { display: flex; gap: 3rem; align-items: center; }
.ticker li { display: inline-flex; align-items: center; gap: .7rem; white-space: nowrap; font-family: var(--mono); font-size: .76rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); }
.ticker li b { font-weight: 700; color: var(--ink); }
.ticker .t-chip { font-size: .65rem; font-weight: 700; letter-spacing: .14em; border: 1.5px solid currentColor; border-radius: 2px; padding: .16rem .42rem .1rem; }
.ticker .t-ok { color: var(--okink); }
.ticker .t-live { color: var(--blue); }
.ticker .t-hot { color: var(--red); }
@media (prefers-reduced-motion: reduce) { .ticker__track { animation: none; } }

/* ---- The docket index: giant numbered rows, no cards -------------------------------- */
.index { border-top: 4px solid var(--rule); }
.index__row {
  position: relative;
  display: grid;
  grid-template-columns: minmax(5.4rem, 8.2rem) minmax(0, 1.05fr) minmax(0, 1.2fr);
  gap: .4rem clamp(1.3rem, 3vw, 3rem);
  align-items: start;
  padding: clamp(1.4rem, 3vw, 2.1rem) 0 clamp(1.4rem, 3vw, 2.1rem) 0;
  border-bottom: 2px solid var(--rule);
  transition: padding-left var(--dur-ui) var(--ease);
}
/* scarlet marker slides in on hover */
.index__row::before {
  content: ""; position: absolute; left: -.2rem; top: clamp(1.4rem, 3vw, 2.1rem); bottom: clamp(1.4rem, 3vw, 2.1rem);
  width: 4px; background: var(--red); transform: scaleY(0); transform-origin: 50% 0;
  transition: transform var(--dur-ui) var(--ease);
}
.index__n {
  font-family: var(--font-poster);
  font-size: clamp(2.7rem, 2rem + 3.6vw, 5.2rem); line-height: .9;
  color: transparent; -webkit-text-stroke: 2px var(--ink);
  transition: color var(--dur-ui) var(--ease), -webkit-text-stroke-color var(--dur-ui);
  user-select: none;
}
@media (hover: hover) {
  .index__row:hover { padding-left: 1.1rem; }
  .index__row:hover::before { transform: scaleY(1); }
  .index__row:hover .index__n { color: var(--blue); -webkit-text-stroke-color: var(--blue); }
}
.index__row h3 {
  font-family: var(--font-poster); font-weight: 400; text-transform: uppercase;
  font-size: clamp(1.2rem, 1rem + 1.25vw, 1.85rem); letter-spacing: -.005em; line-height: 1;
  margin: .1em 0 .55rem;
}
.index__route { display: block; font-family: var(--mono); font-size: .7rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--blue); }
.index__row > p { color: var(--ink-mute); font-size: .96rem; margin: .2rem 0 0; }
.index__row--hot .index__n { -webkit-text-stroke-color: var(--red); }
.index__row--hot h3 .flag { display: inline-block; vertical-align: .34em; margin-left: .6rem; font-family: var(--mono); font-size: .56rem; font-weight: 700; letter-spacing: .18em; color: #fff; background: var(--red); padding: .24rem .5rem .16rem; border-radius: 2px; box-shadow: 2px 2px 0 rgba(213,52,28,.28); }
@media (hover: hover) { .index__row--hot:hover .index__n { color: var(--red); -webkit-text-stroke-color: var(--red); } }

/* generic arrow link */
.golink { display: inline-flex; align-items: center; gap: .5rem; color: var(--blue); font-family: var(--font-display); font-weight: 700; font-size: .86rem; letter-spacing: .07em; text-transform: uppercase; }
.golink svg { width: 1em; height: 1em; transition: transform .22s var(--ease); }
@media (hover: hover) { .golink:hover svg { transform: translateX(4px); } }

/* ---- The counter: taped slip + live copy ------------------------------------------------ */
.counter { display: grid; grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr); gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.hero__visual { position: relative; transform: rotate(-1.4deg); transition: transform .5s var(--ease); }
@media (hover: hover) and (pointer: fine) { .hero__visual:hover { transform: rotate(0); } }
.slip { position: relative; background: var(--sheet-hi); border: 2px solid var(--rule); padding: 1.4rem 1.55rem 1.75rem; }
.slip::before { content: ""; position: absolute; inset: 0; z-index: -1; transform: translate(13px, 15px); background-image: var(--dots); background-size: 7px 7px; }
.slip::after { content: ""; position: absolute; left: 0; right: 0; bottom: -9px; height: 10px; background: conic-gradient(from 135deg at 50% 0, var(--sheet-hi) 90deg, transparent 0) 0 0 / 14px 10px repeat-x; }
.slip .tape, .slip .tape--r { position: absolute; top: -12px; left: 8%; width: 94px; height: 26px; background: rgba(214, 197, 152, .7); border-inline: 1px dashed rgba(148, 132, 90, .5); transform: rotate(-5deg); }
.slip .tape--r { left: auto; right: 8%; transform: rotate(4deg); }
.slip__head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; border-bottom: 3px double var(--line-2); padding-bottom: .7rem; margin-bottom: .9rem; }
.slip__title { font-family: var(--font-poster); font-size: .92rem; letter-spacing: .05em; text-transform: uppercase; }
.slip__ref { font-family: var(--mono); font-size: .74rem; color: var(--ink-mute); font-variant-numeric: tabular-nums; }
.slip__rows { display: grid; gap: .45rem; margin-bottom: 1.1rem; }
.slip__row { display: flex; align-items: baseline; gap: .8rem; font-size: .92rem; }
.slip__row dt { flex: none; width: 6.2rem; margin: 0; font-family: var(--mono); font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-faint); }
.slip__row dd { margin: 0; font-weight: 550; }
.slip__row dd small { color: var(--ink-mute); font-weight: 400; }
.route { border-top: 1px solid var(--line); padding-top: 1rem; display: grid; gap: .55rem; }
.route__step { display: flex; align-items: center; gap: .7rem; font-size: .9rem; color: var(--ink-mute); }
.route__tick { width: 20px; height: 20px; flex: none; border: 2px solid var(--line-2); border-radius: 2px; display: grid; place-items: center; background: var(--sheet-hi); font-size: .8rem; color: transparent; transition: border-color .25s, color .25s, background .25s; }
.route__step.is-done { color: var(--ink); }
.route__step.is-done .route__tick { border-color: var(--okink); color: var(--okink); background: rgba(31, 106, 74, .08); }
.route__step.is-now { color: var(--blue); font-weight: 600; }
.route__step.is-now .route__tick { border-color: var(--blue); }
.route__step.is-now .route__tick::after { content: ""; width: 8px; height: 8px; background: var(--blue); animation: inkpulse 1.4s var(--ease) infinite; }
@keyframes inkpulse { 0%, 100% { opacity: .35; } 50% { opacity: 1; } }
.route__stamp { position: absolute; right: 1.1rem; bottom: 2.4rem; }
.slip-stub { margin: 1.7rem auto 0; width: 74%; display: flex; justify-content: space-between; align-items: center; gap: 1rem; font-family: var(--mono); font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-faint); border: 1px dashed var(--line-2); padding: .55rem .9rem; background: var(--paper); transform: rotate(1deg); }
.slip-stub b { color: var(--ink-mute); font-weight: 600; }

/* ---- Reveal system (JS-gated) --------------------------------------------------------- */
.js .reveal { opacity: 0; transform: translateY(15px); }
.reveal { transition: opacity var(--dur-scene) var(--ease), transform var(--dur-scene) var(--ease); transition-delay: calc(var(--i, 0) * 65ms); }
.in .reveal, .reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .js .reveal { opacity: 1 !important; transform: none !important; } }

/* ---- OFFICIAL NOTICE (AEO answer) with a drop cap ------------------------------------- */
.memo {
  max-width: 50rem; margin-inline: auto; position: relative;
  background: var(--sheet-hi);
  border-block: 4px double var(--rule); border-inline: 0;
  padding: 1.8rem clamp(1.3rem, 3vw, 2.4rem) 1.5rem;
}
.memo::after { content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none; background-image: var(--dots); background-size: 6px 6px; opacity: .1; mix-blend-mode: multiply; }
.memo > * { position: relative; z-index: 1; }
.memo__meta { display: flex; flex-wrap: wrap; gap: .3rem 1.9rem; margin: 0 0 1rem; font-family: var(--mono); font-size: .7rem; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-faint); }
.memo__meta b { color: var(--red); font-weight: 700; }
.answer, .memo__body { font-size: clamp(1.1rem, 1rem + .48vw, 1.28rem); line-height: 1.58; color: var(--ink); margin: 0; }
.memo .answer::first-letter {
  float: left; font-family: var(--font-poster); font-weight: 400;
  font-size: 3.5em; line-height: .78; margin: .06em .12em 0 0; color: var(--blue);
}
.answer strong { color: var(--blue-deep); font-weight: 600; }
.answer em { font-style: normal; border-bottom: 3px solid rgba(213, 52, 28, .5); }

/* ---- Giant numerals band --------------------------------------------------------------- */
.numerals { display: flex; border-block: 4px double var(--rule); }
.numerals .n { flex: 1 1 0; text-align: center; padding: clamp(1.3rem, 3vw, 2.1rem) .8rem; border-right: 2px solid var(--rule); position: relative; }
.numerals .n::before { content: ""; position: absolute; inset: 0; pointer-events: none; background-image: var(--dots); background-size: 6px 6px; opacity: .08; mix-blend-mode: multiply; }
.numerals .n:last-child { border-right: 0; }
.numerals b { display: block; font-family: var(--font-poster); font-weight: 400; font-size: clamp(2.4rem, 1.6rem + 3.6vw, 4.8rem); line-height: 1; letter-spacing: -.02em; font-variant-numeric: lining-nums; position: relative; }
.numerals .n--blue b { color: var(--blue); }
.numerals .n--red b { color: var(--red); }
.numerals .n--ok b { color: var(--okink); }
.numerals span { font-family: var(--mono); font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-mute); display: block; margin-top: .55rem; position: relative; }

/* ---- The paper trail: vertical route down the page ------------------------------------- */
.papertrail { position: relative; max-width: 58rem; margin-inline: auto; padding-block: .5rem; }
.papertrail::before { content: ""; position: absolute; top: 0; bottom: 0; left: 50%; border-left: 2px dashed var(--line-2); }
.tstep { position: relative; width: calc(50% - clamp(1.7rem, 4vw, 3rem)); background: var(--sheet); border: 2px solid var(--rule); padding: 1.35rem 1.45rem 1.15rem; margin-bottom: clamp(1.3rem, 3vw, 2.1rem); box-shadow: var(--press); }
.tstep:nth-child(even) { margin-left: auto; }
.tstep h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.15rem; letter-spacing: -.01em; margin: 0 0 .35rem; }
.tstep p { color: var(--ink-mute); font-size: .93rem; margin: 0; }
.tstep::before { content: attr(data-n); position: absolute; top: 1.1rem; z-index: 1; width: 2.1rem; height: 2.1rem; display: grid; place-items: center; font-family: var(--mono); font-weight: 700; font-size: .8rem; color: var(--paper); background: var(--blue); border-radius: 50%; box-shadow: 0 0 0 4px var(--paper); }
.tstep:nth-child(odd)::before { right: calc(-1 * clamp(1.7rem, 4vw, 3rem) - 1.05rem); }
.tstep:nth-child(even)::before { left: calc(-1 * clamp(1.7rem, 4vw, 3rem) - 1.05rem); }
.tstep:last-child::before { background: var(--red); }
.tstep::after { content: ""; position: absolute; top: 1.95rem; width: clamp(1.7rem, 4vw, 3rem); height: 0; border-top: 2px dashed var(--line-2); }
.tstep:nth-child(odd)::after { right: calc(-1 * clamp(1.7rem, 4vw, 3rem)); }
.tstep:nth-child(even)::after { left: calc(-1 * clamp(1.7rem, 4vw, 3rem)); }

/* ---- Split + registers ---------------------------------------------------------------------- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 3.5rem); align-items: start; }
.dolist li { display: flex; gap: .7rem; align-items: flex-start; padding: .5rem 0; color: var(--ink-soft); }
.dolist li::before { content: "☑"; color: var(--okink); font-size: 1.1rem; line-height: 1.35; flex: none; }
.notecard { background: var(--red-wash); border: 1.5px solid rgba(213, 52, 28, .4); border-radius: var(--r-xs); padding: 1rem 1.2rem; color: var(--ink-soft); font-size: .93rem; }
.notecard strong { color: var(--red-deep); }
.notecard--pen { background: var(--blue-wash); border-color: rgba(33, 48, 156, .35); }
.notecard--pen strong { color: var(--blue-deep); }

/* ---- NOTICE OF REFUSAL: the red document ------------------------------------------------------ */
.refusal { position: relative; }
.refusal::before { content: ""; position: absolute; inset: 0; z-index: -1; transform: translate(15px, 17px); background-image: var(--dots-red); background-size: 7px 7px; }
.refusal__doc { background: var(--sheet-hi); border: 3px solid var(--red); padding: 0 0 1.1rem; }
.refusal__head { display: flex; justify-content: space-between; align-items: center; gap: 1rem; background: var(--red); color: #fff; font-family: var(--mono); font-weight: 700; font-size: .72rem; letter-spacing: .22em; text-transform: uppercase; padding: .62rem 1.2rem .52rem; }
.refusal__head span:last-child { opacity: .82; letter-spacing: .1em; }
.refusal__doc ol { margin: 0; padding: .4rem 0 0; counter-reset: rf; }
.refusal__doc li { counter-increment: rf; display: grid; grid-template-columns: 2.6rem 1fr; gap: .2rem .6rem; padding: .88rem 1.2rem; border-bottom: 1px solid var(--line); }
.refusal__doc li:last-child { border-bottom: 0; }
.refusal__doc li::before { content: counter(rf) "."; font-family: var(--mono); font-weight: 700; color: var(--red); font-size: .9rem; padding-top: .1rem; }
.refusal__doc .void-item > s { font-family: var(--font-display); font-weight: 600; color: var(--ink); font-size: .99rem; }
.refusal__doc small { grid-column: 2; display: block; color: var(--ink-mute); font-size: .85rem; }
.refusal__stamp { position: absolute; top: -1.3rem; right: -0.9rem; transform: rotate(8deg); z-index: 1; }

/* ---- The airmail envelope (CTA) ----------------------------------------------------------------- */
.envelope {
  position: relative; max-width: 54rem; margin-inline: auto;
  background: var(--sheet-hi);
  border: 11px solid transparent;
  border-image: repeating-linear-gradient(-45deg, var(--red) 0 13px, var(--sheet-hi) 13px 25px, var(--blue) 25px 38px, var(--sheet-hi) 38px 50px) 11;
  box-shadow: var(--press-lg);
  padding: clamp(1.9rem, 5vw, 3.1rem);
}
.envelope__postmark { position: absolute; top: 1.3rem; right: clamp(1.2rem, 4vw, 2.3rem); }
.envelope h2 { font-family: var(--font-poster); font-weight: 400; text-transform: uppercase; letter-spacing: -.01em; line-height: .98; font-size: clamp(1.55rem, 1.1rem + 2vw, 2.5rem); max-width: 18ch; }
.envelope .lead { max-width: 34rem; }
.envelope .contactbar { max-width: 30rem; margin-top: 1.6rem; }
.envelope__meta { margin: 1.4rem 0 0; font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-faint); }

/* ---- Mobile contact dock ---------------------------------------------------------------------------- */
.dock {
  position: fixed; left: .55rem; right: .55rem;
  bottom: calc(.55rem + env(safe-area-inset-bottom, 0px)); z-index: 70;
  display: none; align-items: stretch; gap: .45rem; padding: .5rem;
  background: var(--sheet-hi); border: 2px solid var(--rule); border-radius: var(--r);
  box-shadow: 5px 5px 0 rgba(28, 26, 21, .24);
  transform: translateY(135%); opacity: 0;
  transition: transform .38s var(--ease), opacity .28s;
}
.dock.is-in { transform: none; opacity: 1; }
.dock__main { flex: 1 1 auto; min-height: 52px; justify-content: flex-start; text-align: left; text-transform: none; letter-spacing: 0; }
.dock__main span { display: flex; flex-direction: column; line-height: 1.15; }
.dock__main small { font-weight: 500; font-size: .72rem; opacity: .9; }
.dock__alt { flex: 0 0 52px; width: 52px; padding: 0; }
.dock__close { flex: 0 0 44px; border: 1.5px solid var(--line-2); border-radius: var(--r-xs); color: var(--ink-mute); background: var(--paper); }
@media (max-width: 700px) {
  body.dock-on .dock { display: flex; }
  body.dock-on .site-footer { padding-bottom: calc(88px + env(safe-area-inset-bottom, 0px)); }
}
/* very narrow phones (≤400px): shrink the dock so all three controls fit */
@media (max-width: 400px) {
  .dock { gap: .4rem; padding: .45rem; }
  .dock__main { min-width: 0; font-size: .86rem; padding-inline: .7rem; }
  .dock__main span { min-width: 0; }
  .dock__main small { font-size: .68rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }
  .dock__alt { flex: 0 0 46px; width: 46px; }
  .dock__close { flex: 0 0 40px; }
}
@media (prefers-reduced-motion: reduce) { .dock { transition: none; } }

/* ---- Footer: the colophon ----------------------------------------------------------------------------- */
.site-footer { margin-top: clamp(3rem, 8vw, 5.5rem); border-top: 4px double var(--rule); background: var(--band); padding-block: clamp(2.5rem, 5vw, 3.5rem) 1.9rem; position: relative; }
.site-footer::before { content: ""; position: absolute; inset: 0; pointer-events: none; background-image: var(--dots); background-size: 6px 6px; opacity: .14; mix-blend-mode: multiply; }
.site-footer > .wrap { position: relative; }
.footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 2rem; }
.footer__brand p { color: var(--ink-mute); font-size: .92rem; max-width: 26rem; margin-top: 1rem; }
.site-footer .footer__grid h3 { font-family: var(--mono); font-size: .7rem; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 1rem; font-weight: 700; }
.site-footer .footer__grid li { margin-bottom: .55rem; overflow-wrap: anywhere; }
.site-footer .footer__grid a { color: var(--ink-mute); font-size: .93rem; transition: color .2s; }
.site-footer .footer__grid a:hover { color: var(--blue); }
.footer__bottom { display: flex; flex-wrap: wrap; gap: .8rem 1.5rem; justify-content: space-between; align-items: center; margin-top: 2.4rem; padding-top: 1.3rem; border-top: 1px dashed var(--line-2); color: var(--ink-faint); font-size: .85rem; }
.footer__bottom a { color: var(--ink-faint); }
.footer__bottom a:hover { color: var(--blue); }
.footer__ref { font-family: var(--mono); font-size: .72rem; letter-spacing: .1em; display: inline-flex; align-items: center; gap: .8rem; }
.footer__ref::before { content: ""; width: 74px; height: 1.35em; opacity: .75; background: repeating-linear-gradient(90deg, var(--ink) 0 2px, transparent 2px 4px, var(--ink) 4px 5px, transparent 5px 9px, var(--ink) 9px 12px, transparent 12px 14px, var(--ink) 14px 15px, transparent 15px 18px); }
.footer__bottom--bare { margin-top: 0; border-top: 0; }

/* ---- Docket ledger (takedowns / process pages) ---------------------------------------------------------- */
.docket { border-top: 4px solid var(--rule); }
.docket__row { display: grid; grid-template-columns: 5.4rem minmax(13rem, .75fr) 1.25fr; grid-template-areas: "n h p" "n r p"; column-gap: clamp(1.2rem, 3vw, 2.8rem); padding-block: clamp(1.5rem, 3vw, 2.1rem); border-bottom: 2px solid var(--rule); align-items: start; transition: padding-left var(--dur-ui) var(--ease); }
.docket__n { grid-area: n; font-family: var(--font-poster); font-size: 1.05rem; letter-spacing: .02em; color: transparent; -webkit-text-stroke: 1.2px var(--ink-mute); padding-top: .45em; text-transform: uppercase; transition: -webkit-text-stroke-color .25s; }
.docket__row h3 { grid-area: h; font-size: clamp(1.25rem, 1.05rem + .8vw, 1.5rem); margin: 0; }
.docket__route { grid-area: r; margin-top: .55rem; font-family: var(--mono); font-size: .7rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--blue); }
.docket__row p { grid-area: p; color: var(--ink-mute); font-size: .95rem; margin: 0; }
@media (hover: hover) { .docket__row:hover { padding-left: .8rem; background: rgba(251, 245, 231, .7); } .docket__row:hover .docket__n { -webkit-text-stroke-color: var(--blue); } }

/* Index-tab platform chips */
.tabs { display: flex; flex-wrap: wrap; gap: .55rem; justify-content: center; }
.tab { font-family: var(--mono); font-size: .78rem; letter-spacing: .06em; border: 2px solid var(--rule); border-radius: var(--r-xs); background: var(--sheet); padding: .5rem .85rem .42rem; box-shadow: 3px 3px 0 rgba(28, 26, 21, .12); transition: transform .2s var(--ease), box-shadow .2s var(--ease); }
@media (hover: hover) { .tab:hover { transform: translate(-2px, -2px); box-shadow: 5px 5px 0 rgba(33, 48, 156, .2); } }

/* ---- Ledger totals with dotted leaders (subpages) --------------------------------------------------------- */
.totals { max-width: 44rem; border-top: 4px solid var(--rule); border-bottom: 1px solid var(--line-2); padding-block: .4rem; }
.totals li { display: flex; align-items: baseline; gap: .8rem; padding: .58rem .1rem; font-size: .95rem; }
.totals li + li { border-top: 1px solid var(--line); }
.totals li::after { content: ""; flex: 1; border-bottom: 2px dotted var(--line-2); transform: translateY(-.22em); order: 2; }
.totals .k { order: 1; color: var(--ink-soft); }
.totals .v { order: 3; font-family: var(--font-poster); font-size: 1.05rem; text-transform: uppercase; }
.totals .v--pen { color: var(--blue); }
.totals .v--stamp { color: var(--red); }
.totals .v--ok { color: var(--okink); }

/* ---- Pricing: the rate sheets ------------------------------------------------------------------------------ */
.plans { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.7rem 1.2rem; align-items: stretch; }
.plan { position: relative; display: flex; flex-direction: column; background: var(--sheet); border: 2px solid var(--rule); padding: 1.7rem 1.5rem 1.5rem; }
.plan::before { content: ""; position: absolute; inset: 0; z-index: -1; transform: translate(10px, 11px); background-image: var(--dots); background-size: 7px 7px; }
.plan--feature { border-width: 3px; border-color: var(--blue-deep); }
.plan--feature::before { background-image: none; background: rgba(33, 48, 156, .12); transform: translate(9px, 10px); }
.plan__flag { position: absolute; top: -1rem; left: 1.2rem; font-family: var(--mono); font-size: .64rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: #fff; background: var(--blue); padding: .3rem .6rem .24rem; box-shadow: 2px 2px 0 rgba(28, 26, 21, .2); }
.plan h3 { font-size: 1.28rem; margin-bottom: .2rem; }
.plan__price { font-family: var(--font-poster); letter-spacing: -.015em; font-size: clamp(2.1rem, 1.8rem + 1.2vw, 2.8rem); font-variant-numeric: lining-nums; margin: .35rem 0 .05rem; }
.plan__price .cur { font-size: .46em; color: var(--ink-mute); vertical-align: super; margin-right: .06em; }
.plan__price small { font-family: var(--mono); font-size: .62rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-faint); margin-left: .35rem; }
.plan__desc { color: var(--ink-mute); font-size: .92rem; min-height: 2.6em; }
.plan ul { margin: 1.1rem 0 1.3rem; display: grid; gap: .55rem; }
.plan li { display: flex; gap: .6rem; align-items: flex-start; color: var(--ink-soft); font-size: .92rem; }
.plan li::before { content: "—"; color: var(--blue); font-weight: 700; flex: none; }
.plan .btn { margin-top: auto; }
.vow { display: flex; gap: .55rem; align-items: flex-start; max-width: 34rem; margin: 0 0 1.3rem; color: var(--ink-soft); font-size: .95rem; }
.vow::before { content: "☑"; color: var(--okink); flex: none; font-size: 1.05rem; }

/* ---- FAQ: flat numbered broadsheet Q&A ------------------------------------------------------------------------- */
.faq { max-width: 47rem; counter-reset: q; border-top: 4px solid var(--rule); }
.faq--center { margin-inline: auto; }
.qa { border-bottom: 2px solid var(--rule); background: transparent; }
.qa summary { list-style: none; cursor: pointer; padding: 1.15rem .2rem; display: flex; align-items: baseline; gap: 1rem; font-size: 1.04rem; transition: color .2s; }
.qa summary::-webkit-details-marker { display: none; }
.qa summary::before { counter-increment: q; content: counter(q, decimal-leading-zero); flex: none; font-family: var(--font-poster); font-size: 1rem; color: transparent; -webkit-text-stroke: 1px var(--ink-mute); transform: translateY(-.05em); transition: color .25s, -webkit-text-stroke-color .25s; }
.qa[open] summary::before, .qa summary:hover::before { color: var(--red); -webkit-text-stroke-color: var(--red); }
.qa[open] summary { color: var(--blue-deep); }
.qa summary::after { content: "+"; margin-left: auto; font-family: var(--mono); font-weight: 600; font-size: 1.28rem; color: var(--ink-mute); line-height: 1; transition: transform .4s var(--ease), color .2s; flex: none; }
.qa[open] summary::after { transform: rotate(45deg); color: var(--red); }
.qa__panel { display: grid; grid-template-rows: 0fr; }
.qa__panel > .qa__body { overflow: hidden; min-height: 0; }
.qa[open] .qa__panel { grid-template-rows: 1fr; transition: grid-template-rows .4s var(--ease); }
@starting-style { .qa[open] .qa__panel { grid-template-rows: 0fr; } }
.qa.closing .qa__panel { grid-template-rows: 0fr; transition: grid-template-rows .35s var(--ease); }
.qa__body { padding: 0 .2rem 1.2rem 3.1rem; color: var(--ink-mute); }
.qa__body p:last-child { margin-bottom: 0; }
.qa__body a { color: var(--blue-deep); text-decoration: underline; text-underline-offset: 3px; }

/* ---- Blog hub + prose ------------------------------------------------------------------------------------------------ */
.cat { display: flex; align-items: baseline; flex-wrap: wrap; gap: .5rem 1.1rem; border-bottom: 4px solid var(--rule); padding-bottom: .9rem; margin-bottom: 1.7rem; }
.cat h2 { font-family: var(--font-poster); font-weight: 400; text-transform: uppercase; letter-spacing: -.005em; font-size: clamp(1.35rem, 1.1rem + 1.2vw, 1.8rem); margin: 0; }
.cat__count { font-family: var(--mono); font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-faint); }
.cat__desc { flex-basis: 100%; color: var(--ink-mute); font-size: .95rem; margin: .2rem 0 0; }
.briefgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem 1.2rem; }
a.brief { position: relative; display: flex; flex-direction: column; background: var(--sheet); border: 2px solid var(--rule); padding: 1.4rem 1.3rem 1.2rem; box-shadow: var(--press); transition: transform var(--dur-ui) var(--ease), box-shadow var(--dur-ui) var(--ease); }
@media (hover: hover) { a.brief:hover { transform: translate(-2px, -2px); box-shadow: 7px 7px 0 rgba(33, 48, 156, .2); } }
.brief__meta { font-family: var(--mono); font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-faint); margin: 0 0 .55rem; }
.brief h3 { font-size: 1.2rem; margin-bottom: .45rem; }
.brief p { color: var(--ink-mute); font-size: .93rem; }
.brief .golink { margin-top: auto; padding-top: .9rem; }
.briefgrid__empty { color: var(--ink-mute); font-size: .95rem; }
.briefgrid__empty a { color: var(--blue-deep); text-decoration: underline; text-underline-offset: 3px; }

.prose { max-width: 43rem; margin-inline: auto; }
.prose h2 { font-size: clamp(1.4rem, 1.2rem + 1vw, 1.8rem); margin-top: 2.2rem; }
.prose h3 { font-family: var(--font-display); font-weight: 600; font-size: 1.18rem; margin-top: 1.6rem; }
.prose p, .prose li { color: var(--ink-soft); }
.prose ul { margin: 0 0 1em; padding-left: 1.2rem; list-style: square; }
.prose ul li { margin-bottom: .4rem; }
.prose ul li::marker { color: var(--red); }
.prose a { color: var(--blue-deep); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(33, 48, 156, .4); }
.prose a:hover { text-decoration-color: var(--blue); }
.prose > .answer { background: var(--sheet-hi); border-block: 4px double var(--rule); padding: 1.2rem 1.4rem; font-size: clamp(1.05rem, 1rem + .35vw, 1.18rem); margin-bottom: 1.4rem; }
.prose .inline-cta { margin: 1.6rem 0 2rem; padding: 1.3rem 1.4rem; border: 2px solid var(--rule); background: var(--band); box-shadow: var(--press); }
.prose .inline-cta h3 { font-size: 1.1rem; margin: 0 0 .4rem; }
.prose .inline-cta p { color: var(--ink-soft); font-size: .95rem; margin: 0 0 1rem; }
.inline-cta__btns { display: flex; flex-wrap: wrap; gap: .6rem; }
.inline-cta__btns .btn { flex: 1 1 auto; min-width: 12rem; }
.prose table { width: 100%; border-collapse: collapse; margin: 1.5rem 0; font-size: .93rem; display: block; overflow-x: auto; }
.prose thead th { text-align: left; font-family: var(--font-display); font-weight: 700; color: var(--ink); border-bottom: 3px solid var(--rule); padding: .55rem .7rem; white-space: nowrap; background: var(--band); }
.prose td { border-bottom: 1px solid var(--line); padding: .55rem .7rem; color: var(--ink-soft); vertical-align: top; }
.prose tbody tr:last-child td { border-bottom: 0; }

/* ---- Breadcrumbs / misc -------------------------------------------------------------------------------------------------- */
.crumbs { display: flex; flex-wrap: wrap; gap: .4rem; align-items: center; font-family: var(--mono); font-size: .74rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 1.4rem; }
.crumbs a { color: var(--ink-mute); }
.crumbs a:hover { color: var(--blue); }
.crumbs span { color: var(--ink-faint); }
.postmeta { font-family: var(--mono); font-size: .76rem; color: var(--ink-mute); letter-spacing: .04em; }

.voidpage { text-align: left; max-width: 40rem; }
.voidpage .stamp--lg { margin-bottom: 1.4rem; }

/* ---- Utilities ------------------------------------------------------------------------------------------------------------------ */
.section--flush-b { padding-bottom: 0; }
.section--flush-t { padding-top: 0; }
.section--snug-t { padding-top: 1.4rem; }
.mt-0 { margin-top: 0; }
.mt-sm { margin-top: .8rem; }
.mt { margin-top: 1.4rem; }
.mt-lg { margin-top: 1.8rem; }
.mt-xl { margin-top: 2.4rem; }
.small { font-size: .92rem; }

.skip { position: absolute; left: -999px; top: .5rem; z-index: 100; padding: .6rem 1rem; border-radius: 3px; background: var(--blue); color: #fff; font-weight: 600; }
.skip:focus { left: .5rem; }
.sr { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }

.nav__panel { display: contents; }

/* =========================================================================
   Responsive
   ========================================================================= */
@media (max-width: 960px) {
  .hero__deck { grid-template-columns: 1fr; align-items: start; }
  .hero__aside { max-width: 30rem; }
  .counter { grid-template-columns: 1fr; }
  .counter .hero__visual { max-width: 460px; }
  .plans { grid-template-columns: 1fr; max-width: 26rem; }
  .split { grid-template-columns: 1fr; }
  .refusal { margin-top: 2.2rem; }
  .footer__grid { grid-template-columns: 1fr 1fr; gap: 2rem 1.5rem; }
  .footer__brand { grid-column: 1 / -1; }
  .briefgrid { grid-template-columns: repeat(2, 1fr); }
  .numerals { flex-wrap: wrap; }
  .numerals .n { flex: 1 1 40%; border-bottom: 2px solid var(--rule); }
  .numerals .n:nth-child(2n) { border-right: 0; }
  .numerals .n:nth-child(n+3) { border-bottom: 0; }

  .papertrail::before { left: 1.05rem; }
  .tstep, .tstep:nth-child(even) { width: auto; margin-left: 2.9rem; }
  .tstep::before, .tstep:nth-child(odd)::before, .tstep:nth-child(even)::before { left: -2.9rem; right: auto; }
  .tstep::after, .tstep:nth-child(odd)::after, .tstep:nth-child(even)::after { left: -1.85rem; right: auto; width: 1.85rem; }

  .index__row { grid-template-columns: minmax(3.6rem, 5rem) 1fr; }
  .index__row > p { grid-column: 2; }

  .nav__toggle { display: inline-flex; }
  .nav__panel {
    display: flex; position: fixed; inset: 74px 0 auto; z-index: 55;
    flex-direction: column; gap: .3rem; padding: 1rem var(--gutter) 1.5rem;
    background: var(--paper); border-bottom: 3px solid var(--rule);
    box-shadow: 0 18px 30px -18px rgba(28, 26, 21, .4);
    transition: transform var(--dur-ui) var(--ease), opacity var(--dur-ui), visibility var(--dur-ui);
  }
  .js .nav__panel { transform: translateY(-8px); opacity: 0; visibility: hidden; }
  body.nav-open .nav__panel { transform: none; opacity: 1; visibility: visible; }
  body.nav-open { overflow: hidden; }
  html:not(.js) .nav { height: auto; flex-wrap: wrap; padding-block: .6rem; }
  html:not(.js) .nav__panel { position: static; background: none; border-bottom: 0; box-shadow: none; padding: .4rem 0 .6rem; flex-basis: 100%; }
  html:not(.js) .nav__toggle { display: none; }
  .nav__links { flex-direction: column; align-items: stretch; gap: .1rem; }
  .nav__links a { padding: .9rem .4rem; font-size: .82rem; border-bottom: 1px solid var(--line); }
  .nav__links a::after { display: none; }
  .nav__panel .nav__cta { flex-direction: column; align-items: stretch; margin-top: .9rem; }
  .nav__panel .btn { width: 100%; }
}
@media (max-width: 760px) {
  .docket__row { grid-template-columns: 1fr; grid-template-areas: "n" "h" "p" "r"; row-gap: .3rem; }
  .docket__n { padding-top: 0; }
}
@media (max-width: 700px) {
  .nav { height: 62px; justify-content: flex-start; gap: .5rem; }
  .nav__panel { inset: 62px 0 auto; }
  .brand { font-size: 1.1rem; }
  .brand__mark { width: 31px; height: 31px; }
  .nav__tg { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; margin-left: auto; border: 2px solid var(--blue-deep); border-radius: var(--r-xs); color: #fff; background: var(--blue); box-shadow: 3px 3px 0 rgba(33, 48, 156, .28); }
  .nav__tg svg { width: 20px; height: 20px; }
}
@media (max-width: 560px) {
  .briefgrid { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr; }
  .hero__cta .btn, .contactbar .btn { width: 100%; }
  .nav__cta .btn--ghost { display: none; }
  .hero { padding-block: 1rem 2rem; }
  .hero::before, .hero::after { display: none; }
  .dateline { margin-bottom: 1.1rem; padding-bottom: .55rem; gap: .3rem 1rem; font-size: .62rem; }
  .hero__title .over { font-size: clamp(2.1rem, 11vw, 2.7rem); }
  .hero__deck { margin-top: .9rem; gap: 1.4rem; }
  .hero__lead { font-size: .98rem; line-height: 1.5; margin-bottom: .9rem; max-width: 36ch; }
  .hero__lead-ext { display: none; }
  .hero__aside { display: none; }
  .btn--lg { --pad: .85rem 1.3rem; }
  .hero__trust { margin-top: 1rem; gap: .4rem 1rem; font-size: .72rem; }
  .hero__visual { transform: none; }
  .slip-stub { width: 100%; }
  .numerals .n { flex: 1 1 40%; }
  .numerals b { font-size: 2rem; }
  .envelope { border-width: 9px; }
  .envelope__postmark { position: static; display: inline-block; margin-bottom: 1rem; }
  .memo { padding: 1.4rem 1.15rem 1.1rem; }
  .memo .answer::first-letter { font-size: 3em; }
  .qa__body { padding-left: .2rem; }
  .refusal__stamp { top: -1rem; right: .4rem; }
  .index__n { -webkit-text-stroke-width: 1.4px; }
}
