/* Cancel Atlas — design system v2 "Accountability Ledger".
   Static, zero-dependency, zero external fonts (CSP + privacy + file:// safe), accessible.
   Aesthetic: investigative data-publication gravitas — system grotesque headlines + a Georgia
   serif evidence body + tabular-figure scores, warm archival ink, hairline rules, overline labels,
   pure-CSS atmosphere. Color encodes data (always paired with the number+letter), never moral
   judgment alone. DOM order == visual order (never reordered) so humans, screen readers, and
   agents read the same thing. */
:root {
  /* warm archival paper + ink */
  --bg: #faf8f4; --bg-elev: #ffffff; --bg-band: #f3efe8;
  --ink: #16130d; --ink-soft: #4c473d; --ink-mute: #6f6757;
  --line: #e7e1d6; --line-strong: #d6cdbd;
  --accent: #1e5d83; --accent-ink: #ffffff; --accent-soft: #e4eef4;
  --signal: #b45309;            /* reserved for the policy↔flow GAP + emphasis */
  --focus: #1565a6;

  --grade-A: #1c8a55; --grade-B: #2c8f86; --grade-C: #b4860f;
  --grade-D: #c96a26; --grade-F: #c5374b;
  --val-good: #1c8a55; --val-mid: #b4860f; --val-bad: #c5374b;

  --radius: 12px; --radius-sm: 8px;
  --shadow: 0 1px 1px rgba(22,19,13,.04), 0 10px 30px -16px rgba(22,19,13,.18);
  --wrap: 1120px; --measure: 66ch;
  --sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --serif: "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, "Times New Roman", serif;
  --mono: ui-monospace, "SF Mono", "Cascadia Code", "Roboto Mono", Menlo, Consolas, monospace;
}
@media (prefers-color-scheme: dark) {
  :root {
    --bg: #100e0b; --bg-elev: #1a1712; --bg-band: #15120d;
    --ink: #f4efe6; --ink-soft: #c6bfb1; --ink-mute: #a39a86;
    --line: #2a261f; --line-strong: #3b362c; --accent: #5fa9d2;
    --accent-ink: #0f0d0a; --accent-soft: #18242c; --signal: #f0a23a; --focus: #6bb2dd;
    --grade-A: #38b06f; --grade-B: #45b3a6; --grade-C: #d6a32a;
    --grade-D: #e08443; --grade-F: #e35666;
    --val-good: #38b06f; --val-mid: #d6a32a; --val-bad: #e35666;
    --shadow: 0 1px 1px rgba(0,0,0,.4), 0 12px 34px -16px rgba(0,0,0,.6);
  }
}
@media (prefers-contrast: more) {
  :root { --line: var(--ink-mute); --line-strong: var(--ink-soft); --ink-soft: var(--ink); }
}

* { box-sizing: border-box; }
/* long tokens (URLs, emails in policy/data-deletion details) must wrap, never force horizontal
   page overflow on narrow screens. */
body { overflow-wrap: break-word; }
.card, .steps, .trap, .why-body, .sources, .card-meta, .card a { overflow-wrap: anywhere; }
html { scroll-behavior: smooth; }
body {
  margin: 0; background: var(--bg); color: var(--ink);
  font-family: var(--serif); font-size: 17px; line-height: 1.65;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  position: relative;
}
/* pure-CSS atmosphere: a faint warm gradient mesh + a barely-there grain (data-URI, no request) */
body::before {
  content: ""; position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    radial-gradient(60% 50% at 12% -8%, color-mix(in srgb, var(--accent) 10%, transparent), transparent 70%),
    radial-gradient(50% 40% at 100% 0%, color-mix(in srgb, var(--signal) 7%, transparent), transparent 65%);
}
body::after {
  content: ""; position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: .025;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.wrap { max-width: var(--wrap); margin-inline: auto; padding-inline: clamp(18px, 5vw, 44px); }

/* Type: grotesque headlines, serif prose */
h1, h2, h3, h4 { font-family: var(--sans); line-height: 1.1; letter-spacing: -.02em; font-weight: 640; color: var(--ink); }
h1 { font-size: clamp(2.2rem, 5.5vw, 3.6rem); margin: 0 0 .4em; letter-spacing: -.035em; font-weight: 660; }
h2 { font-size: clamp(1.5rem, 3vw, 2.15rem); margin: 0 0 .4em; }
h3 { font-size: 1.12rem; margin: 0 0 .3em; }
p { margin: 0 0 1rem; }
a { color: var(--accent); text-decoration-thickness: 1px; text-underline-offset: 2px; }
a:hover { text-decoration-color: var(--accent); }
.muted { color: var(--ink-mute); }
.accent { color: var(--signal); font-style: italic; }
.footnote { font-size: .82rem; color: var(--ink-mute); margin-top: 1rem; }
code { font-family: var(--mono); font-size: .88em; background: var(--bg-band); padding: .12em .4em; border-radius: 6px; }

/* Overline label — the signature editorial device (file-tab hierarchy) */
.overline { display: inline-block; font-family: var(--sans); font-size: .72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .15em; color: var(--accent); margin: 0 0 .8rem;
  padding-top: .7rem; border-top: 2px solid currentColor; }

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

.skip-link { position: absolute; left: 12px; top: -60px; z-index: 50; background: var(--accent);
  color: var(--accent-ink); padding: 10px 16px; border-radius: 8px; font-weight: 600; font-family: var(--sans);
  transition: top .15s ease; }
.skip-link:focus { top: 12px; }

/* Header */
.site-header { position: sticky; top: 0; z-index: 20; background: color-mix(in srgb, var(--bg) 85%, transparent);
  backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); font-family: var(--sans); }
.header-inner { display: flex; align-items: center; justify-content: center; gap: clamp(10px, 3vw, 28px); padding-block: 12px; flex-wrap: wrap; }
.brand { display: inline-flex; align-items: center; gap: 9px; font-weight: 760; letter-spacing: -.02em; font-size: 1.18rem; color: var(--ink); text-decoration: none; }
.brand-mark { color: var(--accent); font-size: 1.25em; line-height: 1; }
.brand-tagline { margin: 0; color: var(--ink-mute); font-size: .76rem; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; border-left: 1px solid var(--line-strong); padding-left: clamp(10px,3vw,24px); }
.site-nav { display: flex; flex-wrap: wrap; justify-content: center; gap: clamp(12px, 2.2vw, 24px); }
.site-nav a { color: var(--ink-soft); text-decoration: none; font-weight: 560; font-size: .92rem; }
.site-nav a:hover { color: var(--accent); }
@media (max-width: 660px) { .brand-tagline { display: none; } .site-nav { width: 100%; margin-left: 0; } }

/* Notice banner */
.demo-banner { font-family: var(--sans); margin: 16px auto; background: color-mix(in srgb, var(--signal) 8%, var(--bg-elev));
  border: 1px solid color-mix(in srgb, var(--signal) 32%, var(--line)); border-left: 3px solid var(--signal);
  border-radius: var(--radius-sm); padding: 12px 16px; font-size: .9rem; color: var(--ink-soft); }
.demo-banner strong { color: var(--ink); }

/* Hero */
.hero { padding: clamp(40px, 8vw, 92px) 0 clamp(28px, 5vw, 48px); }
.hero h1 { max-width: 18ch; }
.hero .accent { display: inline; }
/* 2-column hero so the wide column fills intentionally: copy left, stats panel right */
.hero-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(28px, 5vw, 60px); align-items: center; }
.hero-copy .lede { margin-bottom: 1.2rem; }
.hero-copy .footnote { margin-top: 0; }
.hero-grid .stat-row { grid-template-columns: 1fr; border: 1px solid var(--line); border-top: 2px solid var(--accent);
  border-radius: var(--radius); background: var(--bg-elev); padding: 2px 22px; box-shadow: var(--shadow); }
.hero-grid .stat-row > div { margin-right: 0; padding-right: 0; }
.hero-grid .stat-row > div:last-child { border-bottom: none; }
@media (max-width: 900px) { .hero-grid { grid-template-columns: 1fr; gap: 24px; } }
.lede { font-size: clamp(1.1rem, 2.3vw, 1.34rem); color: var(--ink-soft); max-width: var(--measure); margin: 0 0 2.2rem; line-height: 1.5; }
.stat-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 0; margin: 0; border-top: 1px solid var(--line); }
.stat-row > div { padding: 18px 22px 18px 0; border-bottom: 1px solid var(--line); margin-right: 22px; }
.stat-row dt { font-family: var(--sans); font-size: .78rem; color: var(--ink-mute); margin-bottom: .5rem; line-height: 1.35; }
.stat-row dd { margin: 0; font-family: var(--sans); font-size: 2.2rem; font-weight: 680; letter-spacing: -.03em; font-variant-numeric: tabular-nums; }
.stat-row dd span { display: block; font-size: .76rem; font-weight: 500; color: var(--ink-mute); letter-spacing: 0; margin-top: 4px; font-variant-numeric: normal; }

/* Directory */
.directory { padding-block: clamp(30px,5vw,56px); }
.dir-head { display: flex; align-items: baseline; gap: 16px; flex-wrap: wrap; justify-content: space-between; margin-bottom: 18px; }
.dir-head h2, .dir-head h3 { margin: 0; }
.view-toggle { display: inline-flex; font-family: var(--sans); border: 1px solid var(--line-strong); border-radius: 999px; overflow: hidden; }
.view-toggle button { font: inherit; font-size: .82rem; font-weight: 600; border: none; background: var(--bg); color: var(--ink-soft); padding: 6px 15px; min-height: 24px; cursor: pointer; }
.view-toggle button + button { border-left: 1px solid var(--line); }
.view-toggle button[aria-pressed="true"] { background: var(--accent); color: var(--accent-ink); }
.controls { font-family: var(--sans); display: grid; grid-template-columns: 1.5fr repeat(3, 1fr); gap: 14px; padding: 18px; background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); margin-bottom: 22px; }
@media (max-width: 760px) { .controls { grid-template-columns: 1fr 1fr; } }
@media (max-width: 460px) { .controls { grid-template-columns: 1fr; } }
.control { display: flex; flex-direction: column; gap: 5px; min-width: 0; } /* min-width:0 lets grid columns shrink below field content width (no horizontal overflow) */
.control label { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-mute); }
.control input, .control select { font: inherit; font-family: var(--sans); font-size: .95rem; padding: 9px 11px; border: 1px solid var(--line-strong); border-radius: var(--radius-sm); background: var(--bg); color: var(--ink); width: 100%; min-width: 0; }
.control input:focus, .control select:focus { border-color: var(--accent); }
.results-status { font-family: var(--sans); margin: 0 2px 14px; font-size: .88rem; }

/* Cards — flatter, hairline, the score is the hero */
.card-grid { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 18px; }
/* list view (toggle): single full-width rows, denser, share pill hidden, summary clamped */
.card-grid.as-list { grid-template-columns: 1fr; gap: 12px; }
.card-grid.as-list .card { padding: 16px 20px; }
.card-grid.as-list .card-share { display: none; }
.card-grid.as-list .steps { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
/* sponsored slot — labeled + visually distinct from graded cards; never affects a score */
.card.sponsored { border: 1px dashed var(--line-strong); border-left: 3px dashed var(--ink-mute);
  background: var(--bg-band); box-shadow: none; }
.card.sponsored:hover { transform: none; box-shadow: none; }
.sponsored-tag { font-family: var(--sans); font-size: .62rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .14em; color: var(--ink-mute); margin: 0; }
.sponsored-note { font-family: var(--sans); font-size: .72rem; color: var(--ink-mute); margin: 0; font-style: italic; }
/* featured supporter slot — pinned above the rankings, accent-tinted, higher-value inventory */
.featured-slot { margin-bottom: 18px; }
.featured-slot:empty { display: none; }
.card.sponsored.featured { border: 1px solid var(--accent); border-left: 3px solid var(--accent);
  background: color-mix(in srgb, var(--accent) 7%, var(--bg-elev)); box-shadow: var(--shadow); }
.card.sponsored.featured .sponsored-tag { color: var(--accent); }
.card.sponsored.featured .card-name { font-size: 1.32rem; }
/* support section */
.support-ways { list-style: none; padding: 0; margin: 0 0 1rem; display: grid; gap: 10px; font-family: var(--sans); max-width: var(--measure); }
.support-ways li { font-size: .95rem; color: var(--ink-soft); }
.footer-links a { color: var(--accent); }
/* rate card */
.rate-card { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 16px; margin: 8px 0 24px; }
.rate-tier { border: 1px solid var(--line); border-top: 2px solid var(--accent); border-radius: var(--radius); background: var(--bg-elev); padding: 18px; box-shadow: var(--shadow); display: flex; flex-direction: column; gap: 8px; }
.rate-tier .overline { margin: 0; }
.rate-tier h3 { font-family: var(--sans); margin: 0; font-size: 1.1rem; }
.rate-price { font-family: var(--sans); font-size: 1.7rem; font-weight: 720; letter-spacing: -.03em; margin: 0; color: var(--ink); font-variant-numeric: tabular-nums; }
.rate-price span { display: block; font-size: .72rem; font-weight: 500; color: var(--ink-mute); letter-spacing: 0; margin-top: 2px; }
.rate-desc { font-family: var(--sans); font-size: .86rem; color: var(--ink-soft); margin: 0; flex: 1; line-height: 1.45; }
.rate-cta { font-family: var(--sans); font-size: .85rem; font-weight: 600; text-decoration: none; color: var(--accent); margin-top: auto; }
.support-donate { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; border: 1px dashed var(--line-strong); border-radius: var(--radius); padding: 16px 20px; margin: 0 0 18px; }
.support-donate h3 { font-family: var(--sans); margin: 0 0 2px; font-size: 1.05rem; }
.donate-btn { font-family: var(--sans); font-weight: 700; text-decoration: none; background: var(--accent); color: var(--accent-ink); padding: 10px 20px; border-radius: 999px; white-space: nowrap; }
.donate-btn:hover { filter: brightness(1.05); }
/* Backer tiers — quiet, editorial; never a flashy pricing grid (neutral-index tone) */
.backer-tiers { margin: 0 0 18px; }
.backer-tiers > .muted { max-width: 70ch; margin: 4px 0 14px; }
.backer-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
@media (max-width: 620px) { .backer-row { grid-template-columns: 1fr; } }
.backer-opt { display: flex; flex-direction: column; gap: 4px; border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 14px 16px; background: var(--bg-elev); }
.backer-opt .b-name { font-family: var(--sans); font-weight: 700; font-size: .95rem; }
.backer-opt .b-price { font-family: var(--sans); font-size: 1.35rem; font-weight: 800; letter-spacing: -.01em; }
.backer-opt .b-price span { font-size: .8rem; font-weight: 600; color: var(--ink-mute); letter-spacing: 0; }
.backer-opt .b-perk { font-size: .82rem; color: var(--ink-soft); min-height: 2.4em; }
.backer-opt .b-cta { margin-top: 6px; align-self: flex-start; font-family: var(--sans); font-weight: 660; font-size: .85rem; text-decoration: none; color: var(--accent); border: 1px solid var(--line-strong); border-radius: 999px; padding: 7px 16px; }
.backer-opt .b-cta:hover { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 8%, transparent); }
.backer-opt .b-annual { margin-top: 6px; font-size: .78rem; color: var(--ink-mute); text-decoration: none; }
.backer-opt .b-annual:hover { color: var(--accent); text-decoration: underline; }
.sponsor-enquiry { margin: 0 0 22px; padding-top: 18px; border-top: 1px solid var(--line); scroll-margin-top: 96px; }
.sponsor-enquiry h3 { font-family: var(--sans); margin: 2px 0 6px; font-size: 1.1rem; }
.sponsor-enquiry > .muted { max-width: 72ch; margin: 0 0 14px; }
.supporters-block { margin: 0 0 18px; }
.supporters-block .overline { margin: 0 0 10px; }
.supporters-wall { display: flex; flex-wrap: wrap; gap: 10px; margin: 0 0 8px; }
.supporter { font-family: var(--sans); font-size: .9rem; font-weight: 600; color: var(--ink-soft); text-decoration: none; background: var(--bg-elev); border: 1px solid var(--line); border-radius: 999px; padding: 7px 16px; line-height: 1.2; transition: border-color .18s ease, color .18s ease, transform .18s ease; }
a.supporter:hover { color: var(--accent); border-color: var(--accent); transform: translateY(-1px); }
a.supporter:focus-visible { outline: 3px solid var(--focus); outline-offset: 2px; }
.supporter.has-logo { padding: 8px 14px; display: inline-flex; align-items: center; }
.supporter-logo { height: 24px; width: auto; max-width: 130px; display: block; object-fit: contain; }
/* Sticky "Backed by" bar — labelled, dismissible, pausable; logos flip to cycle the list. */
.backer-bar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 50; display: flex; align-items: center; justify-content: center; gap: 14px; padding: 8px clamp(14px, 4vw, 28px); background: var(--bg-elev); border-top: 1px solid var(--line); box-shadow: 0 -6px 24px -18px rgba(22,19,13,.5); }
.backer-bar[hidden] { display: none; }
.backer-bar-label { flex: 0 0 auto; font-family: var(--sans); font-size: .72rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-mute); }
.backer-bar-slots { display: flex; align-items: center; gap: 10px; flex: 0 1 auto; overflow: hidden; min-width: 0; }
.backer-slot { flex: 0 0 100px; width: 100px; perspective: 420px; } /* fixed footprint -> exact, clip-proof fit math */
.backer-flip { display: flex; justify-content: center; width: 100%; transition: transform .28s ease, opacity .28s ease; transform-origin: center; backface-visibility: hidden; }
.backer-flip.out { transform: rotateX(90deg); opacity: 0; }
.backer-flip.in { transform: rotateX(-90deg); opacity: 0; transition: none; }
.backer-bar .supporter { font-size: .82rem; }
.backer-bar .supporter.has-logo { width: 100%; box-sizing: border-box; justify-content: center; padding: 4px 8px; }
.backer-bar .supporter-logo { height: 18px; width: 100%; max-width: 100%; object-fit: contain; }
@media (prefers-reduced-motion: reduce) { .backer-flip, .backer-flip.out, .backer-flip.in { transition: none; transform: none; opacity: 1; } }
@media (max-width: 520px) { .backer-bar-label { display: none; } }
.card { background: var(--bg-elev); border: 1px solid var(--line); border-left: 3px solid var(--line-strong); border-radius: var(--radius); padding: 22px; box-shadow: var(--shadow); display: flex; flex-direction: column; gap: 11px; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.card:hover { transform: translateY(-2px); box-shadow: 0 2px 2px rgba(22,19,13,.05), 0 18px 40px -20px rgba(22,19,13,.32); }
.card.gb-A { border-left-color: var(--grade-A); } .card.gb-B { border-left-color: var(--grade-B); }
.card.gb-C { border-left-color: var(--grade-C); } .card.gb-D { border-left-color: var(--grade-D); }
.card.gb-F { border-left-color: var(--grade-F); }
.card-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; }
.card-name { font-family: var(--sans); margin: 0 0 6px; font-size: 1.2rem; letter-spacing: -.02em; }
.tags { display: flex; gap: 6px; flex-wrap: wrap; margin: 0; font-family: var(--sans); }
.tag { font-size: .7rem; font-weight: 600; padding: 3px 8px; border-radius: 999px; background: var(--bg-band); color: var(--ink-soft); }
.tag-jur { background: var(--accent-soft); color: var(--accent); }
.scores-cluster { flex-shrink: 0; display: flex; flex-direction: column; gap: 6px; min-width: 108px; font-family: var(--sans); }
.score-badge { border-radius: 10px; padding: 7px 11px; color: #fff; line-height: 1.1; display: flex; flex-direction: column; gap: 3px; }
.badge-label { font-size: .6rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; opacity: .96; display: flex; align-items: center; gap: 4px; }
.badge-icon { font-size: .85rem; }
.score-row { display: flex; align-items: baseline; gap: 6px; }
.score-num { font-size: 1.55rem; font-weight: 720; letter-spacing: -.04em; font-variant-numeric: tabular-nums; }
.score-grade { font-size: .72rem; font-weight: 700; opacity: .95; }
.grade-A { background: var(--grade-A); } .grade-B { background: var(--grade-B); }
.grade-C { background: var(--grade-C); } .grade-D { background: var(--grade-D); } .grade-F { background: var(--grade-F); }
.steps { margin: 0; font-size: .98rem; color: var(--ink-soft); }
.trap { margin: 0; font-size: .92rem; }
.trap-label { font-family: var(--sans); font-size: .64rem; font-weight: 700; text-transform: uppercase; letter-spacing: .09em; color: var(--grade-D); margin-right: 6px; }
.card-meta { font-family: var(--sans); font-size: .76rem; margin: 0; color: var(--ink-mute); }
.conf { font-weight: 600; }
.card-share { margin: 2px 0 0; }
.share-link { font-family: var(--sans); font-size: .76rem; font-weight: 600; text-decoration: none;
  display: inline-flex; align-items: center; min-height: 24px; padding: 4px 12px; border: 1px solid var(--line, #e3ded3); border-radius: 999px;
  color: var(--accent); background: transparent; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }
.share-link:hover, .share-link:focus-visible { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 8%, transparent); }
.conf-documented { color: var(--grade-C); }
.conf-crowd_verified { color: var(--grade-B); }
.conf-editor_verified { color: var(--grade-A); }

/* Gap signal (the one place the signal/amber lives) + policy-only notice */
.gap-chip { font-family: var(--sans); margin: 2px 0 0; font-size: .82rem; padding: 8px 11px; border-radius: 8px; line-height: 1.4; }
.gap-bad { background: color-mix(in srgb, var(--signal) 10%, transparent); color: var(--ink-soft); border: 1px solid color-mix(in srgb, var(--signal) 28%, transparent); }
.gap-label { font-weight: 700; color: var(--signal); margin-right: 4px; }
.gap-pending { background: var(--bg-band); color: var(--ink-mute); font-style: italic; }

/* Why-this-score */
.why { border-top: 1px solid var(--line); padding-top: 10px; margin-top: 2px; font-family: var(--sans); }
.why summary { cursor: pointer; font-size: .84rem; font-weight: 640; color: var(--accent); list-style: none; display: flex; align-items: center; gap: 6px; }
.why summary::-webkit-details-marker { display: none; }
.why summary:focus-visible { outline: 3px solid var(--focus); outline-offset: 2px; border-radius: 4px; }
.why .chev { transition: transform .18s ease; display: inline-block; }
.why[open] .chev { transform: rotate(90deg); }
.why-body { padding-top: 12px; display: flex; flex-direction: column; gap: 14px; }
.why-group { display: flex; flex-direction: column; gap: 8px; }
.why-group h4 { font-size: .88rem; margin: 0; }
.why-group + .why-group { border-top: 1px dashed var(--line); padding-top: 14px; }
.dims { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 7px; }
.dims li { display: grid; grid-template-columns: 1fr 90px 30px; align-items: center; gap: 10px; font-size: .8rem; }
.dim-label { color: var(--ink-soft); }
.bar { height: 6px; background: var(--bg-band); border-radius: 99px; overflow: hidden; }
.bar-fill { display: block; height: 100%; border-radius: 99px; }
.val-good { background: var(--val-good); } .val-mid { background: var(--val-mid); } .val-bad { background: var(--val-bad); }
.dim-val { text-align: right; font-variant-numeric: tabular-nums; font-weight: 680; font-size: .8rem; }
.receipt { font-size: .78rem; }
.dp-chips { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 6px; }
.dp-chip { font-size: .67rem; padding: 2px 7px; border-radius: 6px; background: color-mix(in srgb, var(--grade-F) 12%, transparent); color: var(--grade-F); font-weight: 600; }
.sources { font-size: .78rem; }

/* Bands & sections */
.band { background: var(--bg-band); border-block: 1px solid var(--line); margin-top: clamp(40px,6vw,76px); padding-block: clamp(38px,6vw,68px); }
section, #main { scroll-margin-top: 96px; }
#agents { padding-block: clamp(38px,6vw,68px); }
.section-lede { font-size: 1.08rem; color: var(--ink-soft); max-width: var(--measure); margin: 0 0 1.8rem; line-height: 1.55; }

.method-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 14px; font-family: var(--sans); }
.method-item { background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px 18px; }
.method-item .w { float: right; font-weight: 760; color: var(--accent); font-size: 1.05rem; font-variant-numeric: tabular-nums; }
.method-item h4 { font-size: 1rem; margin: 0 0 6px; padding-right: 40px; }
.method-item p { margin: 0; font-size: .86rem; color: var(--ink-soft); }
.two-rubrics { display: grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: clamp(20px, 3vw, 34px); }
.rubric > h3 { font-size: 1.1rem; margin-bottom: 4px; font-family: var(--sans); }
.rubric > p.muted { margin: 0 0 14px; font-size: .9rem; }
.gap-pill { display: inline-block; font-family: var(--sans); font-size: .72rem; font-weight: 700; padding: 2px 8px; border-radius: 999px; background: color-mix(in srgb, var(--signal) 14%, transparent); color: var(--signal); margin-right: 6px; vertical-align: middle; }

/* Contribute / intake form */
#contribute { padding-block: clamp(38px,6vw,68px); }
.contribute-form { font-family: var(--sans); max-width: 640px; display: flex; flex-direction: column; gap: 14px; margin-top: 8px; }
.contribute-form .control { display: flex; flex-direction: column; gap: 5px; }
.contribute-form label { font-size: .8rem; font-weight: 620; color: var(--ink-soft); }
.contribute-form input, .contribute-form select, .contribute-form textarea {
  font: inherit; font-family: var(--sans); font-size: .95rem; padding: 9px 11px; border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm); background: var(--bg-elev); color: var(--ink); width: 100%; }
.contribute-form textarea { resize: vertical; }
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 540px) { .cf-row { grid-template-columns: 1fr; } }
#claim-fields, #report-fields { display: flex; flex-direction: column; gap: 14px; }
.cf-submit { align-self: flex-start; background: var(--accent); color: var(--accent-ink); border: 0;
  font-weight: 680; font-size: .95rem; padding: 11px 22px; border-radius: var(--radius-sm); cursor: pointer; transition: filter .15s ease; }
.cf-submit:hover { filter: brightness(1.08); }
.contribute-status { margin: 0; font-size: .9rem; }
.contribute-status.ok { color: var(--grade-A); }
.contribute-status.err { color: var(--grade-F); }

/* Click-to-Cancel Challenge */
.challenge-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: clamp(20px,3vw,34px); margin: 14px 0 30px; }
@media (max-width: 720px) { .challenge-grid { grid-template-columns: 1fr; } }
.challenge-standard, .challenge-legend { background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius); padding: 20px 22px; }
.challenge-standard h3, .challenge-legend h3 { font-size: 1.05rem; margin-bottom: 10px; font-family: var(--sans); }
.criteria { list-style: none; padding: 0; margin: 0 0 10px; display: flex; flex-direction: column; gap: 8px; }
.criteria li { position: relative; padding-left: 24px; font-size: .94rem; color: var(--ink-soft); }
.criteria li::before { content: "✓"; position: absolute; left: 0; color: var(--grade-A); font-weight: 700; }
.challenge-legend p { font-size: .92rem; margin: .45rem 0; color: var(--ink-soft); }
.cstate { display: inline-block; font-family: var(--sans); font-size: .68rem; font-weight: 700; padding: 3px 9px; border-radius: 999px; text-transform: uppercase; letter-spacing: .05em; }
.cstate-pledged { background: color-mix(in srgb, var(--grade-C) 16%, transparent); color: var(--grade-C); }
.cstate-verified { background: color-mix(in srgb, var(--grade-A) 16%, transparent); color: var(--grade-A); }
.cstate-failed { background: color-mix(in srgb, var(--grade-F) 14%, transparent); color: var(--grade-F); }

.grade-key { margin-top: 26px; }
.grade-key ul { list-style: none; padding: 0; margin: 10px 0 0; display: flex; flex-direction: column; gap: 8px; }
.grade-key li { display: flex; gap: 10px; align-items: baseline; font-size: .95rem; color: var(--ink-soft); }
.grade { font-family: var(--sans); flex-shrink: 0; width: 26px; height: 26px; border-radius: 7px; display: grid; place-items: center; color: #fff; font-weight: 700; font-size: .82rem; }

.agent-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; }
.agent-card { background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px; }
.agent-card h3 { font-size: 1rem; }
.agent-card p { margin: 0 0 6px; font-size: .9rem; color: var(--ink-soft); }
.code-link { text-decoration: none; font-family: var(--sans); }
.code-link code { background: var(--accent-soft); color: var(--accent); }

.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px,5vw,48px); }
@media (max-width: 720px) { .about-grid { grid-template-columns: 1fr; } }
.about-grid p { color: var(--ink-soft); margin: 0; }
abbr { text-decoration: underline dotted; text-underline-offset: 2px; cursor: help; }

/* Footer */
.site-footer { border-top: 1px solid var(--line); margin-top: clamp(40px,6vw,76px); padding-block: 32px; font-family: var(--sans); }
.footer-inner p { margin: 0 0 6px; font-size: .88rem; }

/* Motion — one-time staggered reveal of major sections on load; reduced-motion turns it all off */
@media (prefers-reduced-motion: no-preference) {
  main > section, .hero { animation: ca-rise .6s cubic-bezier(.2,.7,.2,1) both; }
  main > section:nth-of-type(1) { animation-delay: .04s; }
  main > section:nth-of-type(2) { animation-delay: .10s; }
  main > section:nth-of-type(3) { animation-delay: .16s; }
  main > section:nth-of-type(4) { animation-delay: .22s; }
  main > section:nth-of-type(n+5) { animation-delay: .26s; }
}
@keyframes ca-rise { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } * { transition: none !important; animation: none !important; } }
/* legal pages (terms / privacy) — narrow readable column */
.legal-doc { max-width: 760px; padding-block: 28px 64px; }
.legal-doc h1 { margin-top: .3em; }
.legal-doc h2 { margin-top: 1.7em; font-size: 1.15rem; }
.legal-doc p { color: var(--ink-soft); }
