/* ============================================================
   PDPC Grievance Site — design system
   Documentary / institutional. Serif for reading, sans for UI.
   No web fonts, no gradients, no shadows beyond hairlines.
   ============================================================ */

/* --- Tokens --- */
:root {
  /* Colour */
  --paper:        #f7f4ee;   /* warm off-white */
  --paper-raised: #fffdf8;   /* cards/panels */
  --ink:          #1c1b19;   /* near-black body */
  --ink-soft:     #403d38;
  --muted:        #6b675f;   /* captions, meta */
  --rule:         #d9d2c5;   /* hairlines */
  --rule-strong:  #b9b0a0;
  --navy:         #1f3a5f;   /* links, institutional headings */
  --navy-deep:    #14283f;
  --accent:       #7a1f2b;   /* oxblood — emphasis, "the record" */
  --accent-soft:  #f0e3e2;   /* oxblood tint panel */
  --panel-grey:   #ece8df;   /* "the narrative" neutral panel */
  --ok:           #2f5d3a;

  /* Type scale (1.20 ratio, base 1.125rem = 18px) */
  --fs-xs:   0.78rem;
  --fs-sm:   0.9rem;
  --fs-base: 1.125rem;
  --fs-md:   1.35rem;
  --fs-lg:   1.62rem;
  --fs-xl:   1.95rem;
  --fs-2xl:  2.6rem;
  --lh-tight: 1.2;
  --lh-body:  1.65;

  /* Fonts */
  --serif: Georgia, "Iowan Old Style", "Palatino Linotype", "Times New Roman", serif;
  --sans:  system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;

  /* Spacing scale */
  --sp-1: 0.25rem;
  --sp-2: 0.5rem;
  --sp-3: 0.75rem;
  --sp-4: 1rem;
  --sp-5: 1.5rem;
  --sp-6: 2rem;
  --sp-7: 3rem;
  --sp-8: 4.5rem;

  /* Layout */
  --measure: 42rem;     /* reading column */
  --wide:    62rem;     /* tables/cards */
  --nav-h:   3.25rem;
}

/* --- Reset --- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--serif);
  font-size: var(--fs-base);
  line-height: var(--lh-body);
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--navy); text-underline-offset: 2px; }
a:hover { color: var(--navy-deep); }
:focus-visible { outline: 3px solid var(--navy); outline-offset: 2px; }

/* --- Headings (serif, content) --- */
h1, h2, h3, h4 { font-family: var(--serif); line-height: var(--lh-tight); color: var(--ink); font-weight: 700; }
h1 { font-size: var(--fs-2xl); margin: 0 0 var(--sp-4); }
h2 { font-size: var(--fs-xl); margin: 0 0 var(--sp-4); }
h3 { font-size: var(--fs-lg); margin: 0 0 var(--sp-3); }
h4 { font-size: var(--fs-md); margin: 0 0 var(--sp-2); }
p  { margin: 0 0 var(--sp-4); max-width: var(--measure); }
strong { font-weight: 700; }

/* --- Sans UI helpers --- */
.eyebrow {
  font-family: var(--sans);
  font-size: var(--fs-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
  margin: 0 0 var(--sp-2);
}
.lede { font-size: var(--fs-md); color: var(--ink-soft); }
.meta { font-family: var(--sans); font-size: var(--fs-sm); color: var(--muted); }

/* --- Layout primitives --- */
.container { width: 100%; max-width: var(--measure); margin-inline: auto; padding-inline: var(--sp-5); }
.container--wide { max-width: var(--wide); }
.section { padding-block: var(--sp-8); border-top: 1px solid var(--rule); }
.section:first-of-type { border-top: none; }
section[id] { scroll-margin-top: calc(var(--nav-h) + var(--sp-4)); }

.grid { display: grid; gap: var(--sp-5); }
@media (min-width: 720px) {
  .grid--2 { grid-template-columns: 1fr 1fr; }
  .grid--3 { grid-template-columns: repeat(3, 1fr); }
}

/* --- Buttons / link-buttons (sans, square, hairline) --- */
.btn {
  display: inline-block;
  font-family: var(--sans);
  font-size: var(--fs-sm);
  font-weight: 600;
  line-height: 1.2;
  padding: var(--sp-3) var(--sp-5);
  border: 1px solid var(--navy);
  color: var(--navy);
  background: transparent;
  text-decoration: none;
  border-radius: 2px;
  cursor: pointer;
}
.btn:hover { background: var(--navy); color: #fff; }
.btn--accent { border-color: var(--accent); color: var(--accent); }
.btn--accent:hover { background: var(--accent); color: #fff; }

/* --- Source-link chip (sans) --- */
.source-link {
  font-family: var(--sans);
  font-size: var(--fs-sm);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
}
.source-link::before { content: "\01F4C4"; } /* page emoji as document marker */

/* --- Skip link --- */
.skip-link {
  position: absolute; left: -999px; top: 0;
  background: var(--navy); color: #fff; padding: var(--sp-2) var(--sp-4);
  font-family: var(--sans); z-index: 100;
}
.skip-link:focus { left: var(--sp-3); top: var(--sp-3); }

/* === Sticky nav === */
.sitenav {
  position: sticky; top: 0; z-index: 50;
  background: var(--paper-raised);
  border-bottom: 1px solid var(--rule-strong);
}
.sitenav__inner {
  max-width: var(--wide);
  margin-inline: auto;
  height: var(--nav-h);
  display: flex; align-items: center; gap: var(--sp-5);
  padding-inline: var(--sp-5);
}
.sitenav__brand {
  font-family: var(--sans); font-weight: 700; font-size: var(--fs-sm);
  letter-spacing: 0.04em; color: var(--ink); text-decoration: none; white-space: nowrap;
}
.sitenav__links {
  list-style: none; margin: 0; padding: 0;
  display: flex; gap: var(--sp-4);
  overflow-x: auto;            /* horizontal scroll on narrow screens */
  -webkit-overflow-scrolling: touch;
}
.sitenav__links a {
  font-family: var(--sans); font-size: var(--fs-sm); color: var(--ink-soft);
  text-decoration: none; white-space: nowrap; padding-block: var(--sp-1);
  border-bottom: 2px solid transparent;
}
.sitenav__links a:hover { color: var(--ink); }
.sitenav__links a.is-active { color: var(--accent); border-bottom-color: var(--accent); }

/* === Hook === */
.hook { padding-top: var(--sp-7); }
.hook__statement { font-size: var(--fs-2xl); max-width: 22ch; }
.hook__irony { font-size: var(--fs-md); color: var(--accent); max-width: var(--measure); }
.hook__open { max-width: var(--measure); }
@media (max-width: 600px) { .hook__statement { font-size: var(--fs-xl); max-width: none; } }

/* === CTA cards === */
.cta-grid { margin-top: var(--sp-6); }
.cta-card {
  display: flex; flex-direction: column; gap: var(--sp-2);
  padding: var(--sp-5);
  background: var(--paper-raised);
  border: 1px solid var(--rule-strong);
  border-top: 3px solid var(--accent);
  text-decoration: none; color: var(--ink);
}
.cta-card:hover { border-color: var(--accent); background: var(--accent-soft); }
.cta-card__tag { font-family: var(--sans); font-size: var(--fs-xs); letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); font-weight: 600; }
.cta-card__title { font-family: var(--serif); font-size: var(--fs-md); font-weight: 700; }
.cta-card__desc { font-family: var(--sans); font-size: var(--fs-sm); color: var(--ink-soft); }
.cta-card__go { font-family: var(--sans); font-size: var(--fs-sm); font-weight: 600; color: var(--navy); margin-top: auto; }

/* === Two cases === */
.case-card { background: var(--paper-raised); border: 1px solid var(--rule-strong); padding: var(--sp-5); }
.case-card__head { border-bottom: 2px solid var(--accent); padding-bottom: var(--sp-3); margin-bottom: var(--sp-4); }
.case-card__head h3 { margin: 0; }
.case-dl { display: grid; grid-template-columns: 1fr; gap: var(--sp-1) 0; margin: 0; }
.case-dl dt { font-family: var(--sans); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); margin-top: var(--sp-3); }
.case-dl dd { margin: 0; }
.cases__note { margin-top: var(--sp-5); max-width: var(--wide); }

/* === Narrative vs Record === */
.contrast-list { list-style: none; margin: var(--sp-6) 0 0; padding: 0; }
.contrast { padding-block: var(--sp-5); border-top: 1px solid var(--rule); }
.contrast__title { font-size: var(--fs-md); }
.contrast__cols { display: grid; gap: var(--sp-4); }
@media (min-width: 720px) { .contrast__cols { grid-template-columns: 1fr 1fr; } }
.contrast__narrative, .contrast__record { padding: var(--sp-4); border: 1px solid var(--rule); }
.contrast__narrative { background: var(--panel-grey); }
.contrast__record { background: var(--accent-soft); border-left: 3px solid var(--accent); }
.contrast__label { font-family: var(--sans); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600; display: block; margin-bottom: var(--sp-2); }
.contrast__narrative .contrast__label { color: var(--muted); }
.contrast__record .contrast__label { color: var(--accent); }
.contrast__narrative p, .contrast__record p { margin: 0; }

/* === Callouts (reused by §5a) === */
.callout { margin-top: var(--sp-6); padding: var(--sp-5); background: var(--paper-raised); border: 1px solid var(--rule-strong); border-left: 4px solid var(--accent); }
.callout__title { font-size: var(--fs-md); margin-top: 0; }
.callout p:last-child { margin-bottom: 0; }

/* === Plain lists in callouts === */
.plain-list { margin: 0 0 var(--sp-4); padding-left: var(--sp-5); }
.plain-list li { margin-bottom: var(--sp-1); max-width: var(--measure); }

/* === Reform asks === */
.asks { list-style: none; margin: var(--sp-6) 0; padding: 0; display: grid; gap: var(--sp-4); }
.ask { padding: var(--sp-5); background: var(--paper-raised); border: 1px solid var(--rule-strong); border-left: 4px solid var(--navy); }
.ask__n { font-family: var(--sans); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600; color: var(--navy); }
.ask__h { font-size: var(--fs-md); margin: var(--sp-1) 0 var(--sp-2); }
.ask p { margin: 0; }
.reform__qh { margin-top: var(--sp-6); }
.questions { margin: 0 0 var(--sp-6); padding-left: var(--sp-5); }
.questions li { margin-bottom: var(--sp-3); max-width: var(--measure); }
.btn + .btn { margin-left: var(--sp-3); }

/* === Failures accordion === */
.accordion { margin-top: var(--sp-5); border-top: 1px solid var(--rule-strong); }
.failure { border-bottom: 1px solid var(--rule-strong); background: var(--paper-raised); }
.failure > summary {
  list-style: none; cursor: pointer;
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: var(--sp-4);
  padding: var(--sp-4) var(--sp-5);
  font-family: var(--sans); font-weight: 600;
}
.failure > summary::-webkit-details-marker { display: none; }
.failure > summary::after { content: "+"; font-size: var(--fs-md); color: var(--accent); justify-self: end; }
.failure[open] > summary::after { content: "\2013"; } /* en dash */
.failure > summary:hover { background: var(--accent-soft); }
.failure__num { font-family: var(--sans); font-weight: 700; color: var(--accent); width: 1.6em; }
.failure__title { font-size: var(--fs-base); }
.failure__sec { font-family: var(--sans); font-size: var(--fs-xs); color: var(--muted); border: 1px solid var(--rule-strong); padding: 2px 8px; border-radius: 2px; white-space: nowrap; }
.failure__body { padding: 0 var(--sp-5) var(--sp-5); }
.failure__body p { margin: 0 0 var(--sp-3); }
.failure__lbl { font-family: var(--sans); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600; color: var(--accent); display: block; }
@media (max-width: 560px) {
  .failure > summary { grid-template-columns: auto 1fr; }
  .failure__sec { display: none; }
}

/* === Timeline === */
.timeline { list-style: none; margin: var(--sp-6) 0; padding: 0; position: relative; border-left: 2px solid var(--rule-strong); }
.tl { position: relative; padding: 0 0 var(--sp-5) var(--sp-6); }
.tl::before { content: ""; position: absolute; left: calc(-1 * var(--sp-1) - 3px); top: 6px; width: 11px; height: 11px; background: var(--accent); border: 2px solid var(--paper); border-radius: 50%; }
.tl__date { font-family: var(--sans); font-size: var(--fs-sm); font-weight: 700; color: var(--navy); display: block; }
.tl__text { margin: var(--sp-1) 0 0; }

/* === Verify embeds === */
.verify-grid { margin-top: var(--sp-6); align-items: start; }
.video-frame { position: relative; aspect-ratio: 16 / 9; background: #000; border: 1px solid var(--rule-strong); }
.video-frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.verify-item h3 { margin-bottom: var(--sp-3); }

/* === Evidence appendix === */
.evidence-grid { margin-top: var(--sp-6); align-items: start; }
.evidence-group h3 { font-size: var(--fs-md); border-bottom: 1px solid var(--rule-strong); padding-bottom: var(--sp-2); }
.doc-list { list-style: none; margin: 0; padding: 0; }
.doc-list li { padding: var(--sp-2) 0; border-bottom: 1px solid var(--rule); }
.doc-list a { font-family: var(--sans); font-size: var(--fs-sm); }

/* === Footer === */
.sitefoot { background: var(--navy-deep); color: #eee; padding-block: var(--sp-8); margin-top: var(--sp-8); }
.sitefoot .eyebrow { color: #e7b9bf; }
.sitefoot a { color: #cfe0f5; }
.disclaimer { font-family: var(--serif); font-size: var(--fs-lg); font-style: italic; border-left: 4px solid var(--accent); margin: 0 0 var(--sp-5); padding-left: var(--sp-5); max-width: var(--measure); color: #fff; }
.contact { margin: var(--sp-5) 0; }
.contact p { margin: 0 0 var(--sp-1); }
.contact__name { font-weight: 700; }
.sitefoot .meta { color: #b9c2cf; }

/* === Responsive pass === */
@media (max-width: 720px) {
  :root { --fs-2xl: 2.0rem; --fs-xl: 1.55rem; --sp-8: 3rem; --sp-7: 2.25rem; }
  .container { padding-inline: var(--sp-4); }
  .sitenav__inner { gap: var(--sp-3); padding-inline: var(--sp-4); }
  .sitenav__brand { font-size: var(--fs-xs); }
  .btn { display: block; text-align: center; }
  .btn + .btn { margin-left: 0; margin-top: var(--sp-3); }
}
@media (max-width: 420px) {
  :root { --fs-base: 1.06rem; }
  .hook__statement { font-size: var(--fs-lg); }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

/* === A11y helpers === */
.visually-hidden { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }
.failure > summary:focus-visible, .cta-card:focus-visible { outline: 3px solid var(--navy); outline-offset: 2px; }

/* === Print === */
@media print {
  :root { --paper: #fff; --paper-raised: #fff; --ink: #000; --accent: #000; --navy: #000; }
  body { font-size: 11pt; line-height: 1.45; color: #000; background: #fff; }
  .sitenav, .skip-link, #toggle-all, .video-frame, .btn { display: none !important; }
  .section { border-top: 1px solid #999; padding-block: 12pt; break-inside: avoid-page; }
  h1, h2, h3 { break-after: avoid; }
  .cta-grid, .verify-grid { display: block; }
  .cta-card, .case-card, .ask, .callout, .failure { break-inside: avoid; border-color: #999; }
  .contrast__cols { grid-template-columns: 1fr 1fr; }
  .failure[open] > summary::after, .failure > summary::after { content: ""; }
  .doc-list a::after, .source-link a::after { content: " (" attr(href) ")"; font-size: 9pt; color: #333; word-break: break-all; }
  a { text-decoration: underline; }
  .sitefoot { background: #fff; color: #000; }
  .sitefoot a, .sitefoot .meta, .sitefoot .eyebrow { color: #000; }
  .disclaimer { color: #000; border-left-color: #000; }
}

/* ============================================================
   Evidence document pages (evidence/*.html)
   ============================================================ */
.doc { padding-block: var(--sp-6) var(--sp-8); }
.doc__back { font-family: var(--sans); font-size: var(--fs-sm); margin-bottom: var(--sp-5); }
.doc__kicker { margin-bottom: var(--sp-2); }
.doc h1 { font-size: var(--fs-xl); max-width: var(--measure); }
.doc__note {
  font-family: var(--sans); font-size: var(--fs-sm); color: var(--muted);
  border-left: 3px solid var(--rule-strong); padding-left: var(--sp-3);
  margin: var(--sp-3) 0 var(--sp-5);
}
.doc__rule { border: none; border-top: 1px solid var(--rule); margin: 0 0 var(--sp-6); }
.doc h2 { font-size: var(--fs-lg); margin: var(--sp-6) 0 var(--sp-3); }
.doc h3 { font-size: var(--fs-md); margin: var(--sp-5) 0 var(--sp-2); }
.doc__head {
  font-family: var(--sans); font-size: var(--fs-sm); color: var(--ink-soft);
  background: var(--panel-grey); padding: var(--sp-3) var(--sp-4);
  border-radius: 4px; margin-bottom: var(--sp-5); line-height: 1.5;
}
.doc__head dt { display: inline; font-weight: 700; }
.doc__head dd { display: inline; margin: 0; }
.doc__head div { margin-bottom: var(--sp-1); }
.doc blockquote {
  border-left: 3px solid var(--accent); margin: 0 0 var(--sp-4);
  padding: var(--sp-1) 0 var(--sp-1) var(--sp-4); color: var(--ink-soft);
}
.doc ul, .doc ol { max-width: var(--measure); padding-left: var(--sp-5); margin: 0 0 var(--sp-4); }
.doc li { margin-bottom: var(--sp-2); }
.doc__summary-tag {
  font-family: var(--sans); font-size: var(--fs-xs); text-transform: uppercase;
  letter-spacing: 0.1em; font-weight: 600; color: var(--navy);
}

/* ============================================================
   Enforcement index page (enforcement-index.html)
   ============================================================ */

/* --- Headline stat band --- */
.stat-band {
  display: grid; gap: var(--sp-4);
  grid-template-columns: 1fr;
  margin: var(--sp-6) 0 var(--sp-3);
}
@media (min-width: 640px) { .stat-band { grid-template-columns: repeat(3, 1fr); } }
.stat {
  background: var(--paper-raised); border: 1px solid var(--rule-strong);
  border-top: 3px solid var(--navy); padding: var(--sp-5);
}
.stat--accent { border-top-color: var(--accent); background: var(--accent-soft); }
.stat__num { font-family: var(--serif); font-weight: 700; font-size: var(--fs-2xl); line-height: 1.05; display: block; color: var(--navy); }
.stat--accent .stat__num { color: var(--accent); }
.stat__lbl { font-family: var(--sans); font-size: var(--fs-sm); color: var(--ink-soft); display: block; margin-top: var(--sp-2); }

/* --- Breakdown bars --- */
.bars { margin: var(--sp-6) 0 var(--sp-3); }
.bar-row {
  display: grid; grid-template-columns: 11rem 1fr 5.5rem; align-items: center;
  gap: var(--sp-3); padding: var(--sp-1) 0;
}
.bar-row__lbl { font-family: var(--sans); font-size: var(--fs-sm); }
.bar-track { background: var(--panel-grey); height: 1.1rem; border: 1px solid var(--rule); }
.bar-fill { display: block; height: 100%; background: var(--navy); min-width: 2px; }
.bar-row__n { font-family: var(--sans); font-size: var(--fs-sm); font-weight: 700; color: var(--ink-soft); text-align: right; white-space: nowrap; }
.bar-row--access .bar-row__lbl,
.bar-row--access .bar-row__n { color: var(--accent); font-weight: 700; }
.bar-row--access .bar-track { border-color: var(--accent); background: var(--accent-soft); }
@media (max-width: 560px) {
  .bar-row { grid-template-columns: 8rem 1fr 4rem; gap: var(--sp-2); }
  .bar-row__lbl { font-size: var(--fs-xs); }
}

/* --- Filters --- */
.filters {
  display: flex; flex-wrap: wrap; gap: var(--sp-3) var(--sp-4);
  align-items: flex-end; margin: var(--sp-5) 0;
  padding: var(--sp-4); background: var(--paper-raised); border: 1px solid var(--rule-strong);
}
.filter { display: flex; flex-direction: column; gap: var(--sp-1); }
.filter--grow { flex: 1 1 12rem; }
.filter__lbl { font-family: var(--sans); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); font-weight: 600; }
.filter select, .filter input {
  font-family: var(--sans); font-size: var(--fs-sm); color: var(--ink);
  padding: var(--sp-2) var(--sp-3); background: var(--paper); border: 1px solid var(--rule-strong); border-radius: 2px;
}
.filters .btn { padding-block: var(--sp-2); }

/* --- Register table --- */
.ix-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; border: 1px solid var(--rule-strong); }
.ix-table { width: 100%; border-collapse: collapse; font-family: var(--sans); font-size: var(--fs-sm); background: var(--paper-raised); }
.ix-table th, .ix-table td { text-align: left; padding: var(--sp-3) var(--sp-3); border-bottom: 1px solid var(--rule); vertical-align: top; }
.ix-table thead th { background: var(--panel-grey); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.06em; color: var(--ink-soft); white-space: nowrap; }
.ix-table tbody tr:hover { background: var(--paper); }
.ix-title { font-family: var(--serif); font-size: var(--fs-base); max-width: 26rem; }
.ix-tags { min-width: 12rem; }
.ix-empty { text-align: center; color: var(--muted); padding: var(--sp-6); }
.ix-src { white-space: nowrap; font-weight: 600; }

.tag { display: inline-block; font-size: var(--fs-xs); padding: 2px 7px; margin: 1px 0; border: 1px solid var(--rule-strong); border-radius: 2px; color: var(--ink-soft); background: var(--paper); }
.tag--access { color: var(--accent); border-color: var(--accent); background: var(--accent-soft); font-weight: 700; }
.tag--muted { color: var(--muted); border-style: dashed; }

.pill { display: inline-block; font-size: var(--fs-xs); font-weight: 700; padding: 2px 8px; border-radius: 2px; white-space: nowrap; }
.pill--breach { color: var(--accent); background: var(--accent-soft); }
.pill--ok { color: var(--ok); background: #e6efe7; }
.pill--neutral { color: var(--ink-soft); background: var(--panel-grey); }

@media print {
  .filters, .ix-table thead th { position: static; }
  .ix-table-wrap { overflow: visible; }
  .ix-src { display: none; }
}

/* ============================================================
   "Seven Contradictions" section (index.html#contradictions)
   ============================================================ */

/* --- Section hero (reuses .eyebrow + .lede) --- */
.cd-hero { margin: 0 0 var(--sp-5); }
.cd-hero__statement {
  font-family: var(--serif); font-weight: 700;
  font-size: var(--fs-xl); line-height: 1.25; color: var(--accent);
  max-width: 38ch; margin: 0 0 var(--sp-4);
}
@media (max-width: 720px) { .cd-hero__statement { font-size: var(--fs-lg); } }

/* --- In-page TOC (one row per contradiction) --- */
.cd-toc {
  list-style: none; margin: 0 0 var(--sp-6); padding: 0;
  display: grid; gap: var(--sp-1);
  border-top: 1px solid var(--rule);
  padding-top: var(--sp-4);
}
.cd-toc li { display: flex; gap: var(--sp-3); align-items: baseline; }
.cd-toc__num { font-family: var(--sans); font-weight: 700; color: var(--accent); min-width: 1.6em; }
.cd-toc a { font-family: var(--sans); font-size: var(--fs-sm); text-decoration: none; color: var(--ink-soft); }
.cd-toc a:hover { color: var(--navy); text-decoration: underline; }

/* --- Card container --- */
.cd-list { display: grid; gap: var(--sp-5); margin: 0; padding: 0; list-style: none; }
.cd-card {
  background: var(--paper-raised);
  border: 1px solid var(--rule-strong);
  border-top: 3px solid var(--accent);
}
.cd-card__head {
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--rule);
  display: grid; grid-template-columns: auto 1fr; align-items: baseline; gap: var(--sp-3);
}
.cd-card__num { font-family: var(--sans); font-weight: 700; color: var(--accent); font-size: var(--fs-md); }
.cd-card__title { font-family: var(--serif); font-weight: 700; font-size: var(--fs-md); margin: 0; }

/* --- 4-column grid (1 column below 720px) --- */
.cd-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
}
@media (min-width: 960px) {
  .cd-grid { grid-template-columns: repeat(4, 1fr); gap: var(--sp-4); }
}
.cd-col {
  border: 1px solid var(--rule);
  padding: var(--sp-4);
  display: flex; flex-direction: column; gap: var(--sp-2);
}
.cd-col__lbl {
  font-family: var(--sans); font-size: var(--fs-xs);
  text-transform: uppercase; letter-spacing: 0.08em;
  font-weight: 600; color: var(--ink-soft);
  display: block;
}
.cd-col p { margin: 0; max-width: none; }
.cd-col blockquote { margin: 0; padding: 0; font-family: var(--serif); color: var(--ink); font-size: var(--fs-base); }
.cd-col--guideline { background: var(--panel-grey); }
.cd-col--decision { background: var(--accent-soft); border-left: 3px solid var(--accent); }
.cd-col--response { border-style: dashed; font-style: italic; }
.cd-col--response .cd-col__missing {
  display: block; color: var(--accent); font-weight: 700; font-style: normal;
  font-family: var(--sans); font-size: var(--fs-xs); margin-top: var(--sp-2);
  text-transform: uppercase; letter-spacing: 0.06em;
}

/* --- Card footer (source-reference line) --- */
.cd-card__foot {
  padding: var(--sp-3) var(--sp-5);
  border-top: 1px solid var(--rule);
  font-family: var(--sans); font-size: var(--fs-sm); color: var(--muted);
}
.cd-card__foot a { color: var(--navy); }

/* --- Footnotes block (at end of section) --- */
.cd-fn-list {
  list-style: decimal; margin: var(--sp-5) 0 0; padding-left: var(--sp-5);
  font-family: var(--sans); font-size: var(--fs-sm); color: var(--ink-soft);
}
.cd-fn-list li { margin-bottom: var(--sp-3); max-width: var(--measure); }
.cd-fn-list sup a { color: var(--navy); text-decoration: none; }
.cd-fn { color: var(--navy); text-decoration: none; }

/* --- Section-level bridge (small link between sections) --- */
.cd-bridge { font-family: var(--sans); font-size: var(--fs-sm); color: var(--ink-soft); margin-top: var(--sp-5); }

/* --- Print --- */
@media print {
  .cd-toc, .cd-card__foot, .cd-card__num { color: #000; }
  .cd-card, .cd-col { break-inside: avoid; border-color: #999; }
  .cd-grid { display: block; padding: 0; }
  .cd-col { margin-bottom: 6pt; }
  .cd-col--guideline, .cd-col--decision, .cd-col--response {
    background: #fff; border-color: #999; border-left-color: #999; font-style: normal;
  }
  .cd-fn::after { content: " (p. " attr(data-page) ")"; }
}
