/* ============================================================
   MedToo India — "The Dossier"
   Editorial / investigative-activism design system
   Fonts: Fraunces (display) · Archivo (body) · IBM Plex Mono (data)
   ============================================================ */

/* ----------------------------------------------------------
   0. TOKENS
---------------------------------------------------------- */
:root {
  /* ink scale (warm near-black) */
  --ink:        #0b0a09;
  --ink-1:      #100e0c;
  --ink-2:      #16130f;
  --ink-3:      #1e1a15;
  --ink-4:      #2a241d;

  /* bone / text */
  --bone:       #efe9dc;
  --bone-dim:   #c0b8a8;
  --ash:        #877f71;
  --ash-deep:   #5e574c;

  /* alarm (crimson) */
  --blood:      #cf2e26;
  --blood-deep: #911c18;
  --ember:      #e6573f;

  /* healing (teal ribbon from logo) */
  --teal:       #1f8c82;
  --teal-bright:#3fc9b8;
  --teal-deep:  #0f5a54;

  /* lines / strokes */
  --line:       rgba(239, 233, 220, 0.13);
  --line-soft:  rgba(239, 233, 220, 0.07);
  --line-strong:rgba(239, 233, 220, 0.28);

  /* paper (light/inverted sections) */
  --paper:      #ece5d6;
  --paper-2:    #e1d8c5;
  --paper-ink:  #1a1611;

  /* layout */
  --maxw:       1240px;
  --maxw-wide:  1440px;
  --gutter:     clamp(1.15rem, 4vw, 4rem);
  --sec-y:      clamp(4.5rem, 11vw, 9.5rem);

  /* type scale (fluid) */
  --fs-mega:    clamp(3.4rem, 13vw, 12rem);
  --fs-h1:      clamp(2.1rem, 1.4rem + 4.2vw, 5.4rem);
  --fs-h2:      clamp(2rem, 4.3vw, 3.6rem);
  --fs-h3:      clamp(1.42rem, 2.5vw, 2.05rem);
  --fs-h4:      clamp(1.16rem, 1.7vw, 1.4rem);
  --fs-body:    clamp(1rem, 0.96rem + 0.28vw, 1.2rem);
  --fs-lead:    clamp(1.18rem, 1.05rem + 0.7vw, 1.65rem);
  --fs-sm:      0.84rem;
  --fs-label:   0.74rem;

  /* fonts */
  --serif: "Fraunces", "Times New Roman", Georgia, serif;
  --sans:  "Archivo", "Helvetica Neue", Arial, sans-serif;
  --mono:  "IBM Plex Mono", "SFMono-Regular", ui-monospace, monospace;

  /* motion */
  --ease:      cubic-bezier(0.22, 1, 0.36, 1);
  --ease-wipe: cubic-bezier(0.74, 0, 0.18, 1);

  --shadow:    0 24px 60px -28px rgba(0,0,0,0.85);
  --shadow-lg: 0 40px 100px -40px rgba(0,0,0,0.9);

  color-scheme: dark;
}

/* ----------------------------------------------------------
   1. RESET / BASE
---------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: 110px;
}

body {
  font-family: var(--sans);
  font-size: var(--fs-body);
  line-height: 1.65;
  color: var(--bone);
  background: var(--ink);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-optical-sizing: auto;
  overflow-x: hidden;
  position: relative;
}

img, svg, video { display: block; max-width: 100%; }
img { height: auto; }

a { color: inherit; text-decoration: none; }

button { font: inherit; color: inherit; cursor: pointer; background: none; border: none; }

::selection { background: var(--blood); color: var(--bone); }

:focus-visible {
  outline: 2px solid var(--teal-bright);
  outline-offset: 3px;
  border-radius: 2px;
}

/* ----------------------------------------------------------
   2. ATMOSPHERE — grain, vignette, spotlight
---------------------------------------------------------- */
/* film grain */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 9998;
  pointer-events: none;
  opacity: 0.45;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
/* vignette */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 9997;
  pointer-events: none;
  background: radial-gradient(130% 100% at 50% 0%, transparent 55%, rgba(0,0,0,0.55) 100%);
}

/* cursor-follow spotlight (set via JS on hero) */
.spotlight {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background: radial-gradient(420px 420px at var(--mx, 50%) var(--my, 30%),
              rgba(207,46,38,0.14), transparent 70%);
  transition: opacity 0.5s var(--ease);
}

/* ----------------------------------------------------------
   3. LAYOUT PRIMITIVES
---------------------------------------------------------- */
.wrap   { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.wrap--wide { max-width: var(--maxw-wide); }
.section { padding-block: var(--sec-y); position: relative; }

.grid { display: grid; gap: clamp(1.5rem, 3vw, 3rem); }

main { display: block; }

.skip-link {
  position: absolute; left: 1rem; top: -100px;
  background: var(--blood); color: var(--bone);
  padding: 0.7rem 1.2rem; border-radius: 4px;
  z-index: 10001; font: 600 0.85rem/1 var(--mono);
  transition: top 0.25s var(--ease);
}
.skip-link:focus { top: 1rem; }

/* ----------------------------------------------------------
   4. TYPOGRAPHY HELPERS
---------------------------------------------------------- */
.display {
  font-family: var(--serif);
  font-weight: 600;
  line-height: 0.98;
  letter-spacing: -0.018em;
}

h1, h2, h3, h4 { font-family: var(--serif); font-weight: 600; line-height: 1.02; letter-spacing: -0.018em; }

.kicker {
  font-family: var(--mono);
  font-size: var(--fs-label);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--blood);
  display: inline-flex;
  align-items: center;
  gap: 0.7em;
  font-weight: 500;
}
.kicker::before {
  content: "§";
  font-size: 1.1em;
  letter-spacing: 0;
  opacity: 0.9;
}
.kicker--teal { color: var(--teal-bright); }
.kicker--plain::before { content: ""; display: none; }

.lead {
  font-size: var(--fs-lead);
  line-height: 1.4;
  color: var(--bone);
  font-weight: 400;
  max-width: 36ch;
}

.muted { color: var(--bone-dim); }
.meta  { font-family: var(--mono); font-size: var(--fs-sm); color: var(--ash); letter-spacing: 0.02em; }
.serif-it { font-family: var(--serif); font-style: italic; font-weight: 400; }

.alarm { color: var(--blood); }
.heal  { color: var(--teal-bright); }

.eyebrow-num {
  font-family: var(--mono);
  color: var(--ash);
  font-size: var(--fs-sm);
  letter-spacing: 0.1em;
}

/* redaction reveal */
.redact {
  position: relative;
  white-space: nowrap;
  color: var(--bone);
}
.redact::after {
  content: "";
  position: absolute;
  inset: 0.04em -0.18em 0.06em -0.18em;
  background: #000;
  border-right: 4px solid var(--blood);
  transform: scaleX(0); /* revealed by default — no-JS safe */
  transform-origin: right center;
  transition: transform 0.9s var(--ease-wipe);
}
.js .redact::after { transform: scaleX(1); }      /* covered while JS active */
.js .in .redact::after { transform: scaleX(0); }  /* wipe away when revealed */
.redact--teal::after { border-right-color: var(--teal-bright); }

/* underline-drawn accent */
.mark {
  background-image: linear-gradient(var(--blood), var(--blood));
  background-repeat: no-repeat;
  background-position: 0 92%;
  background-size: 100% 0.14em;
  padding-bottom: 0.02em;
}
.mark--teal { background-image: linear-gradient(var(--teal), var(--teal)); }

/* ----------------------------------------------------------
   5. BUTTONS
---------------------------------------------------------- */
.btn {
  --bg: var(--blood);
  --fg: var(--bone);
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.7em;
  padding: 1.05em 1.8em;
  font: 600 0.96rem/1 var(--sans);
  letter-spacing: 0.01em;
  color: var(--fg);
  background: var(--bg);
  border-radius: 2px;
  overflow: hidden;
  isolation: isolate;
  transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease);
  box-shadow: 0 12px 30px -14px rgba(207,46,38,0.7);
}
.btn::before {
  content: "";
  position: absolute; inset: 0; z-index: -1;
  background: var(--ink);
  transform: translateY(101%);
  transition: transform 0.45s var(--ease-wipe);
}
.btn:hover { transform: translateY(-3px); box-shadow: 0 20px 44px -16px rgba(207,46,38,0.85); }
.btn:hover::before { transform: translateY(0); }
.btn:hover { color: var(--bone); }
.btn .arrow { transition: transform 0.4s var(--ease); }
.btn:hover .arrow { transform: translateX(5px); }

.btn--teal { --bg: var(--teal); box-shadow: 0 12px 30px -14px rgba(31,140,130,0.7); }
.btn--teal:hover { box-shadow: 0 20px 44px -16px rgba(63,201,184,0.75); }

.btn--ghost {
  --bg: transparent;
  --fg: var(--bone);
  border: 1px solid var(--line-strong);
  box-shadow: none;
}
.btn--ghost::before { background: var(--bone); }
.btn--ghost:hover { color: var(--ink); border-color: var(--bone); }

.btn--lg { padding: 1.25em 2.3em; font-size: 1.05rem; }
.btn--sm { padding: 0.7em 1.15em; font-size: 0.82rem; }

.btn--block { display: flex; width: 100%; justify-content: center; }

/* text link with arrow */
.tlink {
  display: inline-flex; align-items: center; gap: 0.45em;
  font-family: var(--mono); font-size: var(--fs-sm);
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--bone);
  border-bottom: 1px solid var(--line-strong);
  padding-bottom: 0.25em;
  transition: color 0.3s var(--ease), border-color 0.3s var(--ease), gap 0.3s var(--ease);
}
.tlink:hover { color: var(--teal-bright); border-color: var(--teal-bright); gap: 0.8em; }

/* ----------------------------------------------------------
   6. HEADER / NAV / TICKER
---------------------------------------------------------- */
.topbar {
  background: var(--ink-1);
  border-bottom: 1px solid var(--line-soft);
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ash);
}
.topbar__row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding-block: 0.55rem; min-height: 34px;
}
.topbar__live { display: inline-flex; align-items: center; gap: 0.6em; color: var(--bone-dim); }
.live-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--blood);
  box-shadow: 0 0 0 0 rgba(207,46,38,0.6);
  animation: pulse 2.1s infinite;
}
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(207,46,38,0.55); }
  70%  { box-shadow: 0 0 0 9px rgba(207,46,38,0); }
  100% { box-shadow: 0 0 0 0 rgba(207,46,38,0); }
}
.topbar__trust { display: none; }
@media (min-width: 720px) { .topbar__trust { display: inline-flex; gap: 0.9em; } }
.topbar__trust span::before { content: "·"; margin-right: 0.9em; color: var(--ash-deep); }
.topbar__trust span:first-child::before { content: ""; margin: 0; }

.site-header {
  position: sticky; top: 0; z-index: 1000;
  background: color-mix(in srgb, var(--ink) 82%, transparent);
  backdrop-filter: blur(14px) saturate(120%);
  -webkit-backdrop-filter: blur(14px) saturate(120%);
  border-bottom: 1px solid var(--line);
  transition: background 0.3s var(--ease), border-color 0.3s var(--ease);
}
.site-header.scrolled { background: color-mix(in srgb, var(--ink) 94%, transparent); }

.nav {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1.2rem; padding-block: 0.85rem;
}
.brand { display: inline-flex; align-items: center; gap: 0.7rem; }
.brand__logo {
  width: 42px; height: 42px; border-radius: 50%;
  object-fit: cover;
  border: 1px solid var(--line-strong);
  box-shadow: 0 0 0 3px var(--ink-2);
  flex-shrink: 0;
}
.brand__txt { line-height: 1; }
.brand__name {
  font-family: var(--serif); font-weight: 600; font-size: 1.2rem;
  letter-spacing: -0.01em; display: block;
}
.brand__name b { color: var(--blood); font-weight: 600; }
.brand__sub {
  font-family: var(--mono); font-size: 0.56rem; letter-spacing: 0.24em;
  text-transform: uppercase; color: var(--ash); display: block; margin-top: 2px;
}

.nav__links { display: none; }
@media (min-width: 980px) {
  .nav__links {
    display: flex; align-items: center; gap: 2rem;
    margin-left: auto; margin-right: 1.4rem;
  }
}
.nav__link {
  font-size: 0.82rem; letter-spacing: 0.04em; font-weight: 500;
  color: var(--bone-dim); position: relative; padding-block: 0.4rem;
  transition: color 0.3s var(--ease);
}
.nav__link::after {
  content: ""; position: absolute; left: 0; bottom: 0;
  width: 100%; height: 1px; background: var(--blood);
  transform: scaleX(0); transform-origin: left;
  transition: transform 0.35s var(--ease);
}
.nav__link:hover, .nav__link[aria-current="page"] { color: var(--bone); }
.nav__link:hover::after, .nav__link[aria-current="page"]::after { transform: scaleX(1); }

.nav__actions { display: flex; align-items: center; gap: 0.6rem; }
.nav__cta { display: none; }
@media (min-width: 560px) { .nav__cta { display: inline-flex; } }

/* quick exit */
.exit-btn {
  display: inline-flex; align-items: center; gap: 0.45em;
  font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--bone-dim);
  border: 1px solid var(--line-strong); border-radius: 2px;
  padding: 0.62em 0.85em;
  transition: all 0.3s var(--ease);
}
.exit-btn:hover { background: var(--bone); color: var(--ink); border-color: var(--bone); }
.exit-btn svg { width: 13px; height: 13px; }

/* burger */
.burger {
  display: inline-flex; flex-direction: column; gap: 5px;
  width: 44px; height: 44px; align-items: center; justify-content: center;
  border: 1px solid var(--line); border-radius: 2px;
}
@media (min-width: 980px) { .burger { display: none; } }
.burger span { width: 20px; height: 1.6px; background: var(--bone); transition: transform 0.35s var(--ease), opacity 0.2s; }
.burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(6.6px) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6.6px) rotate(-45deg); }

/* mobile menu */
.mobile-menu {
  position: fixed; inset: 0; z-index: 999;
  background: var(--ink-1);
  padding: clamp(7.5rem, 22vw, 9rem) var(--gutter) 3rem;
  display: flex; flex-direction: column;
  transform: translateY(-100%);
  transition: transform 0.5s var(--ease-wipe);
  overflow-y: auto;
}
.mobile-menu.is-open { transform: translateY(0); }
.mobile-menu__link {
  font-family: var(--serif); font-size: clamp(2rem, 9vw, 3rem);
  font-weight: 500; padding-block: 0.5rem; color: var(--bone);
  border-bottom: 1px solid var(--line-soft);
  display: flex; align-items: baseline; gap: 1rem;
}
.mobile-menu__link .n { font-family: var(--mono); font-size: 0.8rem; color: var(--blood); }
.mobile-menu__link:hover { color: var(--blood); }
.mobile-menu__foot { margin-top: auto; padding-top: 2rem; }

/* ----------------------------------------------------------
   7. HERO
---------------------------------------------------------- */
.hero { position: relative; overflow: hidden; padding-top: clamp(3rem, 7vw, 6rem); padding-bottom: clamp(3rem, 7vw, 6rem); }
.hero__bg-word {
  position: absolute; right: -2%; top: 8%; z-index: 0;
  font-family: var(--serif); font-weight: 900;
  font-size: clamp(10rem, 40vw, 34rem); line-height: 0.8;
  color: var(--ink-2);
  letter-spacing: -0.04em; pointer-events: none; user-select: none;
  opacity: 0.6;
}
.hero__grid {
  position: relative; z-index: 1;
  display: grid; gap: clamp(2.5rem, 5vw, 4rem);
  align-items: center;
}
@media (min-width: 940px) {
  .hero__grid { grid-template-columns: 1.15fr 0.85fr; }
}
.hero__headline {
  font-family: var(--serif); font-weight: 500;
  font-size: var(--fs-h1); line-height: 1.02; letter-spacing: -0.02em;
  margin-block: 1.3rem 1.6rem;
  overflow-wrap: break-word;
}
.hero__headline .b { font-weight: 600; }
.hero__lead { color: var(--bone-dim); max-width: 46ch; font-size: var(--fs-lead); line-height: 1.42; }
.hero__cta-row { display: flex; flex-wrap: wrap; align-items: center; gap: 1.2rem; margin-top: 2.2rem; }
.hero__trust { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ash); display: flex; align-items: center; gap: 0.6em; }
.hero__trust .lock { color: var(--teal-bright); }

/* exhibit frame */
.exhibit {
  position: relative;
  border: 1px solid var(--line);
  background: var(--ink-2);
  padding: 0.7rem;
  box-shadow: var(--shadow-lg);
}
.exhibit::before {
  content: attr(data-tag);
  position: absolute; top: -0.85rem; left: 1rem; z-index: 2;
  font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--ink);
  background: var(--blood); padding: 0.35em 0.7em;
}
.exhibit img { width: 100%; }
.exhibit--tilt { transform: rotate(-1.6deg); }
.exhibit--tilt:hover { transform: rotate(0deg) scale(1.01); }
.exhibit { transition: transform 0.6s var(--ease); }
.exhibit__cap {
  font-family: var(--mono); font-size: 0.68rem; color: var(--ash);
  letter-spacing: 0.04em; padding: 0.7rem 0.3rem 0.2rem; display: flex; justify-content: space-between; gap: 1rem;
}
.exhibit--corner::after {
  content: ""; position: absolute; right: -1px; bottom: -1px;
  border-width: 0 0 22px 22px; border-style: solid;
  border-color: transparent transparent var(--blood) transparent;
}

/* ----------------------------------------------------------
   8. MARQUEE / TICKER
---------------------------------------------------------- */
.marquee {
  border-block: 1px solid var(--line);
  background: var(--ink-1);
  overflow: hidden; padding-block: 1.15rem;
  position: relative;
}
.marquee__track {
  display: flex; gap: 2.5rem; width: max-content;
  animation: scroll-x 38s linear infinite;
}
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__item {
  font-family: var(--serif); font-weight: 500; font-style: italic;
  font-size: clamp(1.3rem, 3vw, 2.1rem); color: var(--bone-dim);
  display: inline-flex; align-items: center; gap: 2.5rem; white-space: nowrap;
}
.marquee__item::after {
  content: "✕"; font-family: var(--sans); font-style: normal;
  font-size: 0.7em; color: var(--blood);
}
@keyframes scroll-x { to { transform: translateX(-50%); } }

/* ----------------------------------------------------------
   9. SECTION HEADERS
---------------------------------------------------------- */
.sec-head { max-width: 62ch; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.sec-head__title { font-size: var(--fs-h2); margin-top: 1rem; }
.sec-head--center { margin-inline: auto; text-align: center; }
.sec-head--center .kicker { justify-content: center; }
.sec-head--split { display: grid; gap: 1.5rem; max-width: none; align-items: end; }
@media (min-width: 860px) { .sec-head--split { grid-template-columns: 1fr auto; } }

/* ----------------------------------------------------------
   10. WHY / STATS
---------------------------------------------------------- */
.why { background: linear-gradient(180deg, var(--ink) 0%, var(--ink-1) 100%); }
.why__grid { display: grid; gap: clamp(2.5rem, 5vw, 4.5rem); align-items: center; }
@media (min-width: 940px) { .why__grid { grid-template-columns: 0.82fr 1.18fr; } }

.bigstat { line-height: 0.86; }
.bigstat__num {
  font-family: var(--serif); font-weight: 900;
  font-size: var(--fs-mega); color: var(--blood);
  letter-spacing: -0.03em; display: block;
  text-shadow: 0 0 60px rgba(207,46,38,0.25);
}
.bigstat__num .pct { font-size: 0.45em; vertical-align: super; }
.bigstat__cap { font-size: var(--fs-h4); color: var(--bone); margin-top: 1rem; max-width: 30ch; font-family: var(--serif); font-weight: 400; line-height: 1.25; }
.bigstat__src { margin-top: 1.1rem; }

.pillars { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); margin-top: 2.5rem; }
@media (min-width: 640px) { .pillars { grid-template-columns: repeat(3, 1fr); } }
.pillar { background: var(--ink-2); padding: 1.7rem 1.5rem; transition: background 0.4s var(--ease); min-width: 0; overflow-wrap: break-word; }
.pillar:hover { background: var(--ink-3); }
.pillar__ic { width: 34px; height: 34px; color: var(--blood); margin-bottom: 1rem; }
.pillar:nth-child(3) .pillar__ic { color: var(--teal-bright); }
.pillar__t { font-family: var(--serif); font-size: 1.25rem; font-weight: 600; line-height: 1.15; }
.pillar__d { color: var(--bone-dim); font-size: 0.95rem; margin-top: 0.5rem; }

/* stat strip (the 'evidence' row) */
.evidence { background: var(--ink-1); border-block: 1px solid var(--line); }
.evidence__grid { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); }
@media (min-width: 600px) { .evidence__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .evidence__grid { grid-template-columns: repeat(4, 1fr); } }
.estat { background: var(--ink); padding: 2rem 1.6rem 1.7rem; position: relative; }
.estat__num { font-family: var(--serif); font-weight: 700; font-size: clamp(2.6rem, 5vw, 3.6rem); color: var(--bone); line-height: 1; letter-spacing: -0.02em; }
.estat__num .u { color: var(--blood); }
.estat__lbl { color: var(--bone-dim); font-size: 0.92rem; margin-top: 0.7rem; line-height: 1.35; }
.estat__src { font-family: var(--mono); font-size: 0.62rem; color: var(--ash); letter-spacing: 0.06em; margin-top: 0.9rem; display: block; }

/* ----------------------------------------------------------
   11. COUNTER
---------------------------------------------------------- */
.counter { text-align: center; background:
    radial-gradient(80% 120% at 50% 0%, rgba(31,140,130,0.10), transparent 60%),
    var(--ink); }
.counter__label { justify-content: center; }
.counter__num {
  font-family: var(--serif); font-weight: 900;
  font-size: clamp(4.5rem, 18vw, 15rem);
  line-height: 0.9; letter-spacing: -0.03em;
  color: var(--bone);
  display: inline-flex; align-items: flex-start;
  margin-block: 1rem 0.6rem;
}
.counter__num .hash { color: var(--blood); font-size: 0.42em; margin-top: 0.18em; margin-right: 0.05em; }
.counter__sub { color: var(--bone-dim); max-width: 48ch; margin-inline: auto; font-size: var(--fs-lead); line-height: 1.4; }
.counter__bar { height: 4px; max-width: 520px; margin: 2.3rem auto 0; background: var(--ink-3); border-radius: 4px; overflow: hidden; }
.counter__bar i { display: block; height: 100%; width: 0; background: linear-gradient(90deg, var(--teal), var(--teal-bright)); border-radius: 4px; transition: width 2.4s var(--ease); }
.counter__note { font-family: var(--mono); font-size: 0.7rem; color: var(--ash); letter-spacing: 0.08em; margin-top: 1.3rem; text-transform: uppercase; }

/* ----------------------------------------------------------
   12. STEPS / HOW IT WORKS
---------------------------------------------------------- */
.steps { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); }
@media (min-width: 760px) { .steps { grid-template-columns: repeat(2, 1fr); } }
.step {
  background: var(--ink-1); padding: clamp(1.8rem, 3vw, 2.6rem);
  display: flex; gap: 1.5rem; transition: background 0.4s var(--ease), transform 0.4s var(--ease);
}
.step:hover { background: var(--ink-2); }
.step__n { font-family: var(--mono); font-size: 0.8rem; color: var(--blood); letter-spacing: 0.1em; padding-top: 0.4rem; flex-shrink: 0; }
.step__t { font-family: var(--serif); font-size: var(--fs-h4); font-weight: 600; }
.step__d { color: var(--bone-dim); margin-top: 0.5rem; font-size: 0.97rem; }
.step__chips { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 1rem; }
.chip {
  font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--teal-bright); border: 1px solid var(--teal-deep); border-radius: 100px;
  padding: 0.4em 0.85em; background: rgba(31,140,130,0.08);
}

.eligible {
  margin-top: 2rem; padding: 1.6rem 1.8rem; border: 1px dashed var(--line-strong);
  background: var(--ink-1); display: flex; gap: 1.2rem; align-items: flex-start; border-radius: 3px;
}
.eligible__ic { color: var(--teal-bright); flex-shrink: 0; width: 30px; height: 30px; }
.eligible b { font-family: var(--serif); font-weight: 600; }

/* ----------------------------------------------------------
   13. RESOURCES
---------------------------------------------------------- */
.resources { background: var(--ink-1); }
.res-grid { display: grid; gap: 1.3rem; }
@media (min-width: 680px) { .res-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1040px) { .res-grid { grid-template-columns: repeat(3, 1fr); } }
.rcard {
  position: relative; background: var(--ink-2);
  border: 1px solid var(--line); border-radius: 3px;
  padding: 1.8rem 1.7rem; display: flex; flex-direction: column;
  transition: transform 0.4s var(--ease), border-color 0.4s var(--ease), background 0.4s var(--ease);
  overflow: hidden;
}
.rcard::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--teal); transform: scaleY(0); transform-origin: top;
  transition: transform 0.45s var(--ease);
}
.rcard:hover { transform: translateY(-5px); border-color: var(--line-strong); background: var(--ink-3); }
.rcard:hover::before { transform: scaleY(1); }
.rcard__top { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.rcard__ic { width: 30px; height: 30px; color: var(--teal-bright); }
.rcard__tag { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ash); border: 1px solid var(--line); padding: 0.3em 0.6em; border-radius: 2px; }
.rcard__name { font-family: var(--serif); font-size: 1.3rem; font-weight: 600; margin-top: 1.2rem; line-height: 1.1; }
.rcard__desc { color: var(--bone-dim); font-size: 0.92rem; margin-top: 0.55rem; flex-grow: 1; }
.rcard__num {
  display: inline-flex; align-items: center; gap: 0.5em; margin-top: 1.3rem;
  font-family: var(--mono); font-size: 1.18rem; font-weight: 600; color: var(--bone);
  letter-spacing: 0.01em; transition: color 0.3s var(--ease);
}
.rcard__num:hover { color: var(--teal-bright); }
.rcard__num svg { width: 16px; height: 16px; color: var(--teal-bright); }

.posh-note {
  margin-top: 1.4rem; padding: 1.5rem 1.7rem; border-radius: 3px;
  background: linear-gradient(120deg, rgba(207,46,38,0.10), rgba(31,140,130,0.06));
  border: 1px solid var(--line); display: flex; gap: 1.1rem; align-items: flex-start;
}
.posh-note svg { color: var(--blood); width: 28px; height: 28px; flex-shrink: 0; }
.posh-note b { font-family: var(--serif); font-weight: 600; }

/* ----------------------------------------------------------
   14. POLL (would you report?)
---------------------------------------------------------- */
.poll { border: 1px solid var(--line); background: var(--ink-2); border-radius: 4px; padding: clamp(1.8rem, 4vw, 3rem); }
.poll__q { font-family: var(--serif); font-size: var(--fs-h3); font-weight: 600; line-height: 1.05; }
.poll__opts { display: grid; gap: 0.8rem; margin-top: 1.7rem; }
.poll__opt {
  position: relative; display: flex; align-items: center; gap: 1rem;
  border: 1px solid var(--line-strong); border-radius: 3px;
  padding: 1.05em 1.3em; text-align: left; overflow: hidden;
  font-family: var(--sans); font-weight: 600; font-size: 1.05rem;
  transition: border-color 0.3s var(--ease), background 0.3s var(--ease), transform 0.3s var(--ease);
}
.poll__opt:hover:not(:disabled) { border-color: var(--bone); transform: translateX(4px); }
.poll__opt .ic { width: 22px; height: 22px; flex-shrink: 0; }
.poll__opt[data-vote="yes"] .ic { color: var(--teal-bright); }
.poll__opt[data-vote="no"] .ic { color: var(--blood); }
.poll__opt[data-vote="unsure"] .ic { color: var(--bone-dim); }
.poll__opt .fill {
  position: absolute; left: 0; top: 0; bottom: 0; width: 0;
  background: rgba(255,255,255,0.06); z-index: -1;
  transition: width 1s var(--ease);
}
.poll__opt .pct { margin-left: auto; font-family: var(--mono); font-size: 0.9rem; color: var(--bone-dim); opacity: 0; transition: opacity 0.5s var(--ease); }
.poll.voted .poll__opt { cursor: default; }
.poll.voted .poll__opt .pct { opacity: 1; }
.poll__after { margin-top: 1.7rem; padding-top: 1.5rem; border-top: 1px solid var(--line); display: none; }
.poll.voted .poll__after { display: block; animation: rise 0.6s var(--ease) both; }
.poll__after .big { font-family: var(--serif); font-size: var(--fs-h3); font-weight: 600; color: var(--bone); line-height: 1.1; }
.poll__after .big .alarm { color: var(--blood); }
@keyframes rise { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }

/* ----------------------------------------------------------
   15. PAPER (light / journal) SECTION
---------------------------------------------------------- */
.paper {
  background: var(--paper);
  color: var(--paper-ink);
  position: relative;
}
.paper::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='p'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23p)' opacity='0.5'/%3E%3C/svg%3E");
  mix-blend-mode: multiply; opacity: 0.06;
}
.paper .kicker { color: var(--blood-deep); }
.paper .muted { color: #574e40; }
.paper a.tlink { color: var(--paper-ink); border-color: rgba(0,0,0,0.25); }
.paper a.tlink:hover { color: var(--teal-deep); border-color: var(--teal-deep); }
.journal {
  border: 1px solid rgba(0,0,0,0.16);
  background: rgba(255,255,255,0.35);
  padding: clamp(1.8rem, 4vw, 3.5rem);
  position: relative; z-index: 1;
  box-shadow: 0 30px 70px -40px rgba(0,0,0,0.4);
}
.journal__head { border-bottom: 2px solid var(--paper-ink); padding-bottom: 1.2rem; margin-bottom: 1.6rem; display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem; align-items: baseline; }
.journal__brand { font-family: var(--serif); font-style: italic; font-size: 1.15rem; }
.journal__meta { font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.04em; color: #574e40; }
.journal__title { font-family: var(--serif); font-size: clamp(1.7rem, 3.6vw, 2.7rem); font-weight: 700; line-height: 1.05; letter-spacing: -0.02em; max-width: 22ch; }
.journal__authors { font-family: var(--mono); font-size: 0.82rem; color: #4a4234; margin-top: 1rem; line-height: 1.6; }
.journal__authors b { color: var(--blood-deep); }
.journal__abstract { columns: 2; column-gap: 2.5rem; margin-top: 1.6rem; font-size: 0.98rem; line-height: 1.6; color: #2e2a22; }
@media (max-width: 680px) { .journal__abstract { columns: 1; } }
.journal__abstract p { margin-bottom: 0.9rem; break-inside: avoid; }
.journal__abstract .firstcap::first-letter { font-family: var(--serif); font-weight: 700; font-size: 3.1em; float: left; line-height: 0.74; padding: 0.06em 0.12em 0 0; color: var(--blood-deep); }
.journal__foot { margin-top: 1.8rem; padding-top: 1.3rem; border-top: 1px solid rgba(0,0,0,0.16); display: flex; flex-wrap: wrap; gap: 1.2rem; justify-content: space-between; align-items: center; }
.kw { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.kw span { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.04em; border: 1px solid rgba(0,0,0,0.25); padding: 0.3em 0.7em; border-radius: 2px; }

.stamp {
  font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--teal-deep); border: 2px solid var(--teal-deep); border-radius: 3px;
  padding: 0.55em 0.9em; transform: rotate(-4deg); display: inline-flex; align-items: center; gap: 0.5em;
  font-weight: 600;
}

/* ----------------------------------------------------------
   16. ABOUT / TEAM / STORY
---------------------------------------------------------- */
.story__grid { display: grid; gap: clamp(2rem, 4vw, 3.5rem); }
@media (min-width: 900px) { .story__grid { grid-template-columns: 1fr 1fr; align-items: start; } }
.prose p { color: var(--bone-dim); margin-bottom: 1.15rem; max-width: 60ch; }
.prose p .serif-it { color: var(--bone); }
.pullquote {
  font-family: var(--serif); font-style: italic; font-weight: 400;
  font-size: clamp(1.5rem, 3.2vw, 2.3rem); line-height: 1.18; color: var(--bone);
  border-left: 3px solid var(--blood); padding-left: 1.5rem; margin-block: 2rem;
}
.pullquote cite { display: block; font-style: normal; font-family: var(--mono); font-size: 0.74rem; letter-spacing: 0.1em; color: var(--ash); margin-top: 1rem; text-transform: uppercase; }

.team { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); }
@media (min-width: 640px) { .team { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .team { grid-template-columns: repeat(3, 1fr); } }
.member { background: var(--ink-2); padding: 1.8rem 1.6rem; transition: background 0.4s var(--ease); }
.member:hover { background: var(--ink-3); }
.member__role { font-family: var(--mono); font-size: 0.64rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--blood); }
.member:nth-child(n+3) .member__role { color: var(--teal-bright); }
.member__name { font-family: var(--serif); font-size: 1.4rem; font-weight: 600; margin-top: 0.8rem; line-height: 1.1; }
.member__aff { color: var(--bone-dim); font-size: 0.88rem; margin-top: 0.5rem; }

.collab { margin-top: 1.5rem; color: var(--bone-dim); font-size: 0.95rem; display: flex; gap: 0.9rem; align-items: center; flex-wrap: wrap; }
.collab .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--teal-bright); }

/* ----------------------------------------------------------
   17. SURVEY PAGE
---------------------------------------------------------- */
.intro-cards { display: grid; gap: 1.3rem; }
@media (min-width: 760px) { .intro-cards { grid-template-columns: repeat(3, 1fr); } }
.icard {
  border: 1px solid var(--line); background: var(--ink-2); border-radius: 3px;
  padding: 1.9rem 1.7rem; position: relative; overflow: hidden;
  transition: transform 0.4s var(--ease), border-color 0.4s;
}
.icard:hover { transform: translateY(-4px); border-color: var(--line-strong); }
.icard__ic { width: 38px; height: 38px; color: var(--teal-bright); margin-bottom: 1.1rem; }
.icard:nth-child(2) .icard__ic { color: var(--blood); }
.icard__t { font-family: var(--serif); font-size: 1.35rem; font-weight: 600; line-height: 1.05; }
.icard__d { color: var(--bone-dim); font-size: 0.93rem; margin-top: 0.6rem; }
.icard__n { position: absolute; right: 1rem; top: 0.6rem; font-family: var(--serif); font-weight: 900; font-size: 3.4rem; color: var(--ink-4); opacity: 0.5; line-height: 1; }

.warning {
  border: 1px solid var(--blood-deep);
  background: linear-gradient(180deg, rgba(207,46,38,0.10), rgba(207,46,38,0.02));
  border-radius: 4px; padding: clamp(1.6rem, 4vw, 2.6rem);
  display: flex; gap: 1.3rem; align-items: flex-start;
}
.warning__ic { color: var(--blood); width: 36px; height: 36px; flex-shrink: 0; }
.warning h3 { font-size: var(--fs-h4); margin-bottom: 0.6rem; }
.warning p { color: var(--bone-dim); max-width: 70ch; }
.warning a { color: var(--teal-bright); border-bottom: 1px solid currentColor; }

/* form embed */
.form-shell {
  border: 1px solid var(--line); border-radius: 4px; overflow: hidden;
  background: var(--ink-1); position: relative; box-shadow: var(--shadow);
}
.form-shell__bar {
  display: flex; align-items: center; gap: 0.6rem; padding: 0.9rem 1.2rem;
  border-bottom: 1px solid var(--line); background: var(--ink-2);
  font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ash);
}
.form-shell__dots { display: flex; gap: 6px; }
.form-shell__dots i { width: 9px; height: 9px; border-radius: 50%; background: var(--ink-4); }
.form-shell__dots i:first-child { background: var(--blood); }
.form-shell__secure { margin-left: auto; display: inline-flex; align-items: center; gap: 0.4em; color: var(--teal-bright); }
.form-shell__secure svg { width: 13px; height: 13px; }
.form-frame-wrap { position: relative; min-height: 600px; background: var(--ink-1); }
.form-frame-wrap iframe { width: 100%; height: 1500px; border: 0; display: block; background: #fff; }
.form-loading {
  position: absolute; inset: 0; display: grid; place-items: center; gap: 1rem;
  background: var(--ink-1); transition: opacity 0.5s var(--ease); text-align: center;
}
.form-loading.hide { opacity: 0; pointer-events: none; }
.spinner { width: 38px; height: 38px; border: 2px solid var(--line-strong); border-top-color: var(--blood); border-radius: 50%; animation: spin 0.9s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.form-fallback { margin-top: 1.2rem; text-align: center; }

/* thank you */
.thanks {
  border: 1px solid var(--teal-deep); border-radius: 4px;
  background: radial-gradient(120% 100% at 50% 0%, rgba(31,140,130,0.12), transparent 70%), var(--ink-2);
  padding: clamp(2rem, 5vw, 3.5rem); text-align: center;
}
.thanks__ic { width: 56px; height: 56px; color: var(--teal-bright); margin: 0 auto 1.3rem; }
.thanks h3 { font-size: var(--fs-h2); }
.thanks p { color: var(--bone-dim); max-width: 56ch; margin: 1rem auto 0; font-size: var(--fs-lead); line-height: 1.4; }

/* share */
.share { background: var(--ink-1); }
.share__grid { display: grid; gap: clamp(2rem, 4vw, 3.5rem); align-items: center; }
@media (min-width: 880px) { .share__grid { grid-template-columns: 1fr 0.9fr; } }
.share__box { display: flex; flex-direction: column; gap: 1.1rem; }
.copyfield {
  display: flex; align-items: stretch; gap: 0; border: 1px solid var(--line-strong);
  border-radius: 3px; overflow: hidden; background: var(--ink-2);
}
.copyfield input {
  flex: 1; min-width: 0; background: none; border: none; color: var(--bone-dim);
  font-family: var(--mono); font-size: 0.85rem; padding: 0 1rem; letter-spacing: 0.01em;
}
.copyfield button { background: var(--bone); color: var(--ink); padding: 0.95em 1.3em; font-weight: 600; font-size: 0.85rem; white-space: nowrap; transition: background 0.3s; display: inline-flex; align-items: center; gap: 0.5em; }
.copyfield button:hover { background: var(--teal-bright); }
.copyfield button.copied { background: var(--teal); color: var(--bone); }
.share__btns { display: flex; flex-wrap: wrap; gap: 0.7rem; }
.sbtn {
  display: inline-flex; align-items: center; gap: 0.55em;
  border: 1px solid var(--line-strong); border-radius: 100px;
  padding: 0.7em 1.2em; font-size: 0.85rem; font-weight: 600; color: var(--bone-dim);
  transition: all 0.3s var(--ease);
}
.sbtn svg { width: 17px; height: 17px; }
.sbtn:hover { color: var(--bone); border-color: var(--bone); transform: translateY(-2px); }
.sbtn--wa:hover { background: #25D366; color: #053; border-color: #25D366; }

/* QR card */
.qr-card {
  border: 1px solid var(--line); background: var(--bone); color: var(--ink);
  border-radius: 6px; padding: 1.6rem; text-align: center; box-shadow: var(--shadow-lg);
  max-width: 320px; margin-inline: auto;
}
.qr-card__img { width: 100%; aspect-ratio: 1; object-fit: contain; background: #fff; border-radius: 3px; }
.qr-card__tag {
  display: inline-flex; align-items: center; gap: 0.5em; margin-top: 1rem;
  font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase;
  background: var(--ink); color: var(--bone); padding: 0.55em 1em; border-radius: 100px;
}
.qr-card__tag svg { width: 13px; height: 13px; color: var(--teal-bright); }

/* ----------------------------------------------------------
   18. CONTACT PAGE
---------------------------------------------------------- */
.contact__grid { display: grid; gap: clamp(2rem, 4vw, 3.5rem); }
@media (min-width: 880px) { .contact__grid { grid-template-columns: 1fr 1fr; } }
.contact-card {
  border: 1px solid var(--line); background: var(--ink-2); border-radius: 4px;
  padding: clamp(1.7rem, 3.5vw, 2.6rem); display: flex; flex-direction: column; gap: 1rem;
  transition: border-color 0.4s var(--ease), transform 0.4s var(--ease);
}
.contact-card:hover { border-color: var(--line-strong); transform: translateY(-4px); }
.contact-card__role { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--blood); }
.contact-card__name { font-family: var(--serif); font-size: 1.7rem; font-weight: 600; line-height: 1; }
.contact-card__line { display: flex; align-items: center; gap: 0.7em; color: var(--bone-dim); font-size: 0.95rem; }
.contact-card__line svg { width: 17px; height: 17px; color: var(--teal-bright); flex-shrink: 0; }
.contact-card__num { font-family: var(--mono); font-size: 1.15rem; color: var(--bone); font-weight: 600; }
.contact-card__num:hover { color: var(--teal-bright); }
.contact-actions { display: flex; flex-wrap: wrap; gap: 0.7rem; margin-top: auto; padding-top: 0.5rem; }

.volunteer {
  background: linear-gradient(135deg, var(--ink-2), var(--ink-1));
  border: 1px solid var(--line); border-radius: 4px;
  padding: clamp(2rem, 5vw, 4rem); position: relative; overflow: hidden;
}
.volunteer__big { font-family: var(--serif); font-size: var(--fs-h2); font-weight: 600; line-height: 1.0; max-width: 20ch; }
.volunteer__icon { position: absolute; right: -3rem; top: 50%; transform: translateY(-50%); width: 280px; height: 280px; color: var(--ink-3); opacity: 0.7; }

/* ----------------------------------------------------------
   19. GALLERY (campaign exhibits)
---------------------------------------------------------- */
.gallery { display: grid; gap: 1.4rem; }
@media (min-width: 760px) { .gallery { grid-template-columns: repeat(2, 1fr); } }
.gframe {
  position: relative; border: 1px solid var(--line); background: var(--ink-2);
  border-radius: 3px; overflow: hidden; transition: transform 0.5s var(--ease), border-color 0.4s;
}
.gframe:hover { transform: translateY(-5px); border-color: var(--line-strong); }
.gframe img { width: 100%; transition: transform 0.7s var(--ease); }
.gframe:hover img { transform: scale(1.03); }
.gframe__cap {
  position: absolute; left: 0; right: 0; bottom: 0; padding: 1.4rem 1.3rem 1.1rem;
  background: linear-gradient(transparent, rgba(11,10,9,0.92));
  font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--bone-dim);
  display: flex; justify-content: space-between; gap: 1rem; align-items: flex-end;
}
.gframe__cap b { color: var(--bone); font-family: var(--serif); font-size: 1rem; letter-spacing: -0.01em; text-transform: none; font-weight: 600; }

/* ----------------------------------------------------------
   20. CTA BAND
---------------------------------------------------------- */
.cta-band {
  position: relative; overflow: hidden;
  background:
    radial-gradient(60% 120% at 80% 20%, rgba(207,46,38,0.18), transparent 60%),
    radial-gradient(50% 100% at 10% 90%, rgba(31,140,130,0.12), transparent 60%),
    var(--ink-1);
  text-align: center;
}
.cta-band__t { font-size: clamp(2.4rem, 6vw, 4.6rem); line-height: 1.0; max-width: 16ch; margin-inline: auto; }
.cta-band__sub { color: var(--bone-dim); max-width: 50ch; margin: 1.3rem auto 2.2rem; font-size: var(--fs-lead); }

/* ----------------------------------------------------------
   21. FOOTER
---------------------------------------------------------- */
.site-footer { background: var(--ink-1); border-top: 1px solid var(--line); padding-top: clamp(3.5rem, 7vw, 6rem); }
.footer__top { display: grid; gap: 2.5rem; padding-bottom: 3rem; border-bottom: 1px solid var(--line); }
@media (min-width: 880px) { .footer__top { grid-template-columns: 1.4fr 1fr 1fr; } }
.footer__brand { display: flex; gap: 1rem; align-items: flex-start; }
.footer__brand img { width: 60px; height: 60px; border-radius: 50%; border: 1px solid var(--line-strong); flex-shrink: 0; }
.footer__tagline { font-family: var(--serif); font-style: italic; font-size: 1.3rem; color: var(--bone); margin-top: 1.3rem; line-height: 1.25; max-width: 26ch; }
.footer__col h4 { font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ash); font-weight: 500; margin-bottom: 1.2rem; }
.footer__col a, .footer__col p { display: block; color: var(--bone-dim); font-size: 0.92rem; margin-bottom: 0.7rem; transition: color 0.3s var(--ease); }
.footer__col a:hover { color: var(--teal-bright); }
.footer__bottom { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between; align-items: center; padding-block: 2rem; }
.footer__cite { font-family: var(--mono); font-size: 0.68rem; color: var(--ash); letter-spacing: 0.02em; max-width: 70ch; line-height: 1.7; }
.footer__cite a { color: var(--bone-dim); border-bottom: 1px solid var(--line-strong); }
.footer__legal { font-family: var(--mono); font-size: 0.66rem; color: var(--ash-deep); letter-spacing: 0.04em; }
.footer__helpbar {
  display: flex; flex-wrap: wrap; gap: 0.6rem 1.5rem; align-items: center;
  padding: 1.2rem 0; border-top: 1px solid var(--line-soft); margin-top: 1rem;
}
.footer__helpbar .lbl { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--blood); }
.footer__helpbar a { font-family: var(--mono); font-size: 0.78rem; color: var(--bone-dim); }
.footer__helpbar a:hover { color: var(--teal-bright); }

/* ----------------------------------------------------------
   22. PAGE HEADER (inner pages)
---------------------------------------------------------- */
.pagehead { position: relative; overflow: hidden; padding-top: clamp(3.5rem, 7vw, 6rem); padding-bottom: clamp(2.5rem, 5vw, 4rem); border-bottom: 1px solid var(--line); }
.pagehead__num { position: absolute; right: var(--gutter); top: 1rem; font-family: var(--serif); font-weight: 900; font-size: clamp(5rem, 16vw, 13rem); color: var(--ink-2); line-height: 1; z-index: 0; pointer-events: none; }
.pagehead__inner { position: relative; z-index: 1; max-width: 60ch; }
.pagehead__title { font-size: var(--fs-h1); margin-top: 1.1rem; }
.pagehead__lead { color: var(--bone-dim); font-size: var(--fs-lead); line-height: 1.4; margin-top: 1.3rem; max-width: 52ch; }

/* ----------------------------------------------------------
   23. REVEAL ANIMATIONS
---------------------------------------------------------- */
.reveal { transition: opacity 0.9s var(--ease), transform 0.9s var(--ease); }
.js .reveal { opacity: 0; transform: translateY(28px); }
.reveal.in { opacity: 1; transform: none; }
.reveal[data-delay="1"] { transition-delay: 0.08s; }
.reveal[data-delay="2"] { transition-delay: 0.16s; }
.reveal[data-delay="3"] { transition-delay: 0.24s; }
.reveal[data-delay="4"] { transition-delay: 0.32s; }
.reveal[data-delay="5"] { transition-delay: 0.40s; }
.reveal[data-delay="6"] { transition-delay: 0.48s; }

.reveal-x { transition: opacity 0.9s var(--ease), transform 0.9s var(--ease); }
.js .reveal-x { opacity: 0; transform: translateX(-30px); }
.reveal-x.in { opacity: 1; transform: none; }

/* rise-in reveal for framed images (opacity/transform — reliable cross-browser) */
.clip-rise { transition: opacity 1s var(--ease), transform 1.1s var(--ease-wipe); }
.js .clip-rise { opacity: 0; transform: translateY(38px) scale(0.985); }
.clip-rise.in { opacity: 1; transform: none; }

/* ----------------------------------------------------------
   24. UTILITIES
---------------------------------------------------------- */
.center { text-align: center; }
.mt-1 { margin-top: 1rem; } .mt-2 { margin-top: 2rem; } .mt-3 { margin-top: 3rem; }
.divider { height: 1px; background: var(--line); border: none; margin-block: var(--sec-y); }
.hr-rule { display: flex; align-items: center; gap: 1rem; color: var(--ash); font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; }
.hr-rule::before, .hr-rule::after { content: ""; height: 1px; background: var(--line); flex: 1; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

/* ----------------------------------------------------------
   25. RESPONSIVE TWEAKS
---------------------------------------------------------- */
@media (max-width: 940px) {
  .hero__bg-word { font-size: clamp(8rem, 50vw, 18rem); opacity: 0.4; top: auto; bottom: 0; }
  .volunteer__icon { opacity: 0.4; right: -5rem; }
}
@media (max-width: 560px) {
  :root { --sec-y: clamp(3.5rem, 14vw, 5rem); }
  .journal__abstract { columns: 1; }
  .footer__bottom { flex-direction: column; align-items: flex-start; }
}

/* ----------------------------------------------------------
   26. REDUCED MOTION
---------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
  .reveal, .reveal-x, .clip-rise { opacity: 1 !important; transform: none !important; }
  .clip-rise { clip-path: none !important; }
  .redact::after { transform: scaleX(0) !important; }
  .marquee__track { animation: none !important; }
  .spotlight { display: none !important; }
  body::before { opacity: 0.3; }
}

/* ----------------------------------------------------------
   27. PRINT
---------------------------------------------------------- */
@media print {
  body::before, body::after, .site-header, .topbar, .mobile-menu, .marquee, .cta-band, .exit-btn { display: none !important; }
  body { background: #fff; color: #000; }
}
