/* Hallmark · macrostructure: Index-First · nav: N6 masthead · footer: Ft7 newsletter-first
 * theme: custom (vibe: "archival public record, warm paper, oxide stamp"
 *   paper oklch(97.5% 0.007 85) · accent oklch(47% 0.15 28) warm · Fraunces + IBM Plex Sans)
 * axes: light / high-contrast-serif / warm · tone: utilitarian-editorial
 * audience: compliance & GRC professionals · use: look up + cite evidence, subscribe
 * Hallmark · pre-emit critique: P4 H5 E4 S5 R5 V4
 */

:root {
  /* color */
  --color-paper:    oklch(97.5% 0.007 85);
  --color-paper-2:  oklch(95.5% 0.009 85);
  --color-paper-3:  oklch(92.5% 0.012 85);
  --color-ink:      oklch(23% 0.015 75);
  --color-ink-2:    oklch(42% 0.014 75);
  --color-ink-3:    oklch(56% 0.012 75);
  --color-rule:     oklch(85% 0.012 80);
  --color-rule-2:   oklch(70% 0.014 78);
  --color-accent:   oklch(47% 0.15 28);
  --color-accent-2: oklch(40% 0.13 28);
  --color-focus:    oklch(50% 0.16 250);
  /* status tones, muted, registry-grade, not traffic lights */
  --color-good:     oklch(45% 0.10 150);
  --color-good-bg:  oklch(93% 0.025 150);
  --color-gated:    oklch(52% 0.11 75);
  --color-gated-bg: oklch(93% 0.035 85);
  --color-none:     oklch(50% 0.012 75);
  --color-none-bg:  oklch(94% 0.006 85);
  --color-conflict: oklch(50% 0.15 28);
  --color-conflict-bg: oklch(93% 0.03 30);

  /* type */
  --font-display: "Fraunces", ui-serif, Georgia, serif;
  --font-body: "IBM Plex Sans", ui-sans-serif, system-ui, sans-serif;
  --font-data: "IBM Plex Mono", ui-monospace, monospace;

  --text-xs: 0.75rem;
  --text-sm: 0.85rem;
  --text-base: 1rem;
  --text-md: 1.25rem;
  --text-lg: 1.5625rem;
  --text-xl: 1.9531rem;
  --text-2xl: 2.4414rem;
  --text-display: clamp(2rem, 3.5vw + 0.75rem, 3.4rem);

  /* space (4pt) */
  --space-2xs: 0.25rem;
  --space-xs: 0.5rem;
  --space-sm: 0.75rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2.5rem;
  --space-2xl: 4rem;
  --space-3xl: 6rem;

  --rule-hairline: 1px solid var(--color-rule);
  --rule-heavy: 2px solid var(--color-ink);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --dur-short: 140ms;
  --measure: 68ch;
}

* { box-sizing: border-box; }
html, body { overflow-x: clip; }
html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--color-paper);
  color: var(--color-ink);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.55;
  font-variant-numeric: oldstyle-nums;
}

a { color: var(--color-accent); text-decoration-thickness: 1px; text-underline-offset: 2px; }
a:hover { color: var(--color-accent-2); text-decoration-thickness: 2px; }
:focus-visible { outline: 2px solid var(--color-focus); outline-offset: 2px; }

.stale-banner {
  background: var(--color-gated-bg); color: var(--color-gated);
  border-bottom: 1px solid var(--color-rule-2);
  font-family: var(--font-data); font-size: var(--text-xs);
  text-align: center; padding: var(--space-xs) var(--space-md);
}

.visually-hidden {
  position: absolute; width: 1px; height: 1px;
  clip-path: inset(50%); overflow: hidden; white-space: nowrap;
}

.container {
  max-width: 78rem;
  margin-inline: auto;
  padding-inline: clamp(1rem, 4vw, 2rem);
}
.container--prose { max-width: 46rem; }

h1, h2, h3 {
  font-family: var(--font-display);
  font-style: normal;
  font-weight: 640;
  line-height: 1.12;
  letter-spacing: -0.015em;
  margin: 0 0 var(--space-md);
}
h1 { font-size: var(--text-display); }
h2 { font-size: var(--text-lg); margin-top: var(--space-xl); }
h3 { font-size: var(--text-md); margin-top: var(--space-lg); }
p { max-width: var(--measure); }

/* ---------- N6 masthead ---------- */
.masthead { border-bottom: 3px double var(--color-rule-2); }
.masthead__inner {
  display: flex; flex-wrap: wrap; align-items: baseline; gap: var(--space-xs) var(--space-lg);
  padding-block: var(--space-lg) var(--space-md);
}
.masthead__wordmark {
  font-family: var(--font-display);
  font-weight: 700; font-size: var(--text-xl);
  letter-spacing: -0.02em;
  color: var(--color-ink); text-decoration: none;
}
.masthead__wordmark:hover { color: var(--color-ink); }
.masthead__issue {
  font-family: var(--font-data); font-size: var(--text-xs);
  color: var(--color-ink-2); letter-spacing: 0.04em;
}
.masthead__nav { margin-left: auto; display: flex; gap: var(--space-lg); flex-wrap: wrap; }
.masthead__nav a {
  color: var(--color-ink-2); text-decoration: none;
  font-size: var(--text-sm); white-space: nowrap;
}
.masthead__nav a:hover, .masthead__nav a[aria-current="page"] {
  color: var(--color-ink); text-decoration: underline;
  text-decoration-thickness: 2px; text-underline-offset: 4px;
  text-decoration-color: var(--color-accent);
}

/* ---------- index lede ---------- */
.lede { padding-block: var(--space-xl) var(--space-lg); }
.lede h1 { max-width: 26ch; }
.lede p { color: var(--color-ink-2); font-size: var(--text-md); max-width: 58ch; margin: 0; }
.lede .disclaimer-line {
  font-family: var(--font-data); font-size: var(--text-xs);
  color: var(--color-ink-3); margin-top: var(--space-sm);
}

/* ---------- the registry table ---------- */
.tablewrap { overflow-x: auto; border-top: var(--rule-heavy); padding-bottom: var(--space-xs); }
.registry {
  border-collapse: collapse; width: 100%;
  font-size: var(--text-sm);
  font-variant-numeric: tabular-nums lining-nums;
}
.registry th, .registry td { padding: var(--space-xs) var(--space-sm); text-align: left; }
.registry thead .groups th {
  font-family: var(--font-data); font-size: var(--text-xs); font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--color-ink-2);
  border-bottom: var(--rule-hairline);
  border-left: var(--rule-hairline);
  padding-top: var(--space-md);
}
.registry thead .groups th:first-child { border-left: none; }
.registry thead .dims th {
  font-weight: 600; font-size: var(--text-xs);
  vertical-align: bottom; border-bottom: var(--rule-hairline);
  color: var(--color-ink-2);
}
.registry tbody tr { border-bottom: var(--rule-hairline); }
.registry tbody tr:hover { background: var(--color-paper-2); }
.registry .offering-cell { white-space: nowrap; }
.registry .offering-cell a {
  color: var(--color-ink); font-weight: 600; text-decoration: none;
}
.registry .offering-cell a:hover { text-decoration: underline; text-decoration-color: var(--color-accent); }
.registry .offering-cell .via {
  display: block; font-size: var(--text-xs); color: var(--color-ink-3); font-weight: 400;
}
.registry td.group-start, .registry thead .dims th.group-start { border-left: var(--rule-hairline); }

.cell { font-family: var(--font-data); font-size: var(--text-xs); white-space: nowrap; }
.cell a { text-decoration: none; color: inherit; display: inline-block; padding: 1px 4px; border-radius: 3px; }
.cell a:hover { outline: 1px solid var(--color-rule-2); }
.cell .glyph { display: inline-block; width: 1.1em; }
.tone-good     { color: var(--color-good); }
.tone-gated    { color: var(--color-gated); }
.tone-none     { color: var(--color-none); }
.tone-na       { color: var(--color-ink-3); }
.tone-conflict { color: var(--color-conflict); }

/* legend */
.legend {
  display: flex; flex-wrap: wrap; gap: var(--space-xs) var(--space-lg);
  padding-block: var(--space-md);
  font-family: var(--font-data); font-size: var(--text-xs); color: var(--color-ink-2);
}
.legend .glyph { width: 1.2em; display: inline-block; }

/* question links strip */
.questions { padding-block: var(--space-xl); border-top: var(--rule-hairline); margin-top: var(--space-xl); }
.questions h2 { margin-top: 0; }
.questions ul { list-style: none; margin: 0; padding: 0; columns: 2; column-gap: var(--space-2xl); max-width: 60rem; }
.questions li { margin-bottom: var(--space-xs); break-inside: avoid; }
@media (max-width: 40rem) { .questions ul { columns: 1; } }

/* ---------- watch-outs (the catches, surfaced) ---------- */
.watchout-badge {
  font-family: var(--font-data); font-size: var(--text-xs);
  color: var(--color-gated); text-decoration: none;
  white-space: nowrap;
}
.watchout-badge:hover { color: var(--color-accent-2); text-decoration: underline; }

.watchouts {
  border: 1px solid var(--color-rule-2); border-left: 3px solid var(--color-gated);
  background: var(--color-paper-2); border-radius: 4px;
  padding: var(--space-md) var(--space-lg); margin: var(--space-lg) 0;
}
.watchouts h2 { margin: 0 0 var(--space-2xs); font-size: var(--text-md); }
.watchouts__n {
  font-family: var(--font-data); font-size: var(--text-sm); font-weight: 500;
  color: var(--color-paper); background: var(--color-gated);
  border-radius: 999px; padding: 0 var(--space-xs); vertical-align: middle;
}
.watchouts__lead { color: var(--color-ink-2); font-size: var(--text-sm); margin: 0 0 var(--space-sm); }
.watchouts ul { list-style: none; margin: 0; padding: 0; }
.watchouts li { padding: var(--space-xs) 0; border-top: var(--rule-hairline); }
.watchouts li:first-child { border-top: none; }
.watchouts__dim { font-family: var(--font-data); font-size: var(--text-sm); font-weight: 600; text-decoration: none; }
.watchouts__dim:hover { text-decoration: underline; }
.watchouts__caveat { display: block; font-size: var(--text-sm); color: var(--color-ink-2); margin-top: 2px; }

/* ---------- evidence blocks (offering + question pages) ---------- */
.crumb { font-family: var(--font-data); font-size: var(--text-xs); color: var(--color-ink-3); padding-top: var(--space-lg); }
.crumb a { color: var(--color-ink-3); }

.offering-head { padding-block: var(--space-lg) var(--space-md); }
.offering-head .meta {
  font-family: var(--font-data); font-size: var(--text-xs); color: var(--color-ink-2);
  display: flex; flex-wrap: wrap; gap: var(--space-md);
}

.evidence { border-top: var(--rule-heavy); }
.evidence__group {
  font-family: var(--font-data); font-size: var(--text-xs); font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-ink-2);
  padding: var(--space-lg) 0 var(--space-xs);
}
.evidence__row {
  display: grid; grid-template-columns: 11rem 11rem 1fr;
  gap: var(--space-md); padding-block: var(--space-md);
  border-top: var(--rule-hairline);
}
.evidence__dim { font-weight: 600; font-size: var(--text-sm); }
.evidence__dim .q { display: block; font-weight: 400; color: var(--color-ink-3); font-size: var(--text-xs); margin-top: 2px; }
.evidence__status { font-family: var(--font-data); font-size: var(--text-sm); }
.evidence__status .conf { display: block; color: var(--color-ink-3); font-size: var(--text-xs); margin-top: 2px; }
.evidence__detail { font-size: var(--text-sm); color: var(--color-ink-2); min-width: 0; }
.evidence__detail p { margin: 0 0 var(--space-2xs); }
.evidence__srcline { font-family: var(--font-data); font-size: var(--text-xs); word-break: break-all; }
.evidence__facts { font-family: var(--font-data); font-size: var(--text-xs); color: var(--color-ink-3); }
@media (max-width: 60rem) {
  .evidence__row { grid-template-columns: 1fr; gap: var(--space-2xs); }
}

/* ---------- compare ---------- */
.compare-table { width: 100%; border-collapse: collapse; border-top: var(--rule-heavy); font-size: var(--text-sm); }
.compare-table th, .compare-table td { padding: var(--space-sm); border-bottom: var(--rule-hairline); text-align: left; vertical-align: top; }
.compare-table thead th { font-family: var(--font-display); font-size: var(--text-md); }
.compare-table .dimcol { width: 12rem; font-weight: 600; }
.compare-table .note { display: block; font-size: var(--text-xs); color: var(--color-ink-3); font-family: var(--font-body); white-space: normal; }

/* ---------- changelog ---------- */
.log { border-top: var(--rule-heavy); }
.log__entry { display: grid; grid-template-columns: 8rem 1fr; gap: var(--space-md); padding-block: var(--space-md); border-top: var(--rule-hairline); }
.log__date { font-family: var(--font-data); font-size: var(--text-xs); color: var(--color-ink-2); padding-top: 3px; }
.log__body p { margin: 0; }
@media (max-width: 40rem) { .log__entry { grid-template-columns: 1fr; gap: var(--space-2xs); } }

/* ---------- prose pages ---------- */
.prose { padding-block: var(--space-lg) var(--space-2xl); }
.prose ul { max-width: var(--measure); padding-left: 1.2em; }
.prose li { margin-bottom: var(--space-2xs); }
.prose code, .prose .mono { font-family: var(--font-data); font-size: 0.9em; background: var(--color-paper-3); padding: 0 4px; border-radius: 3px; }
.prose table { border-collapse: collapse; font-size: var(--text-sm); }
.prose table th, .prose table td { border: var(--rule-hairline); padding: var(--space-xs) var(--space-sm); text-align: left; }

/* ---------- Ft7 newsletter-first footer ---------- */
.footer { margin-top: var(--space-3xl); border-top: 3px double var(--color-rule-2); background: var(--color-paper-2); }
.footer__inner { padding-block: var(--space-xl); }
.footer__form-label {
  font-family: var(--font-display); font-weight: 640;
  font-size: var(--text-lg); letter-spacing: -0.01em;
  display: block; margin-bottom: var(--space-2xs); max-width: 30ch;
}
.footer__form-sub { color: var(--color-ink-2); font-size: var(--text-sm); margin: 0 0 var(--space-md); max-width: 52ch; }
.subscribe { display: flex; gap: var(--space-xs); max-width: 30rem; flex-wrap: wrap; }
.subscribe input[type="email"] {
  flex: 1 1 16rem; min-width: 0;
  font: inherit; font-size: var(--text-sm);
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid var(--color-rule-2); border-radius: 3px;
  background: var(--color-paper); color: var(--color-ink);
}
.subscribe input[type="email"]:focus-visible { outline: 2px solid var(--color-focus); outline-offset: 1px; }
.subscribe input[type="email"][aria-invalid="true"] { border-color: var(--color-conflict); }
.subscribe button {
  font: inherit; font-size: var(--text-sm); font-weight: 600; white-space: nowrap;
  padding: var(--space-xs) var(--space-lg);
  background: transparent; color: var(--color-accent);
  border: 1px solid var(--color-accent); border-radius: 3px;
  cursor: pointer;
  transition: background-color var(--dur-short) var(--ease-out), color var(--dur-short) var(--ease-out);
}
.subscribe button:hover { background: var(--color-accent); color: var(--color-paper); }
.subscribe button:active { transform: translateY(1px); }
.subscribe button:disabled { opacity: 0.55; cursor: default; }
.subscribe__msg { font-size: var(--text-sm); margin-top: var(--space-xs); min-height: 1.4em; }
.subscribe__msg.ok { color: var(--color-good); }
.subscribe__msg.err { color: var(--color-conflict); }

.footer__meta {
  margin-top: var(--space-xl); padding-top: var(--space-md);
  border-top: var(--rule-hairline);
  font-family: var(--font-data); font-size: var(--text-xs); color: var(--color-ink-3);
  display: flex; flex-wrap: wrap; gap: var(--space-xs) var(--space-lg);
}
.footer__meta a { color: var(--color-ink-2); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition-duration: 1ms !important; animation-duration: 1ms !important; }
}
