/* ============================================================
   sa-doc.css — design system add-ons for sa-compliance templates
   Loaded after theme.css. Adds spacing/text scales + component
   classes that replace inline-style chaos in mu-plugin templates.
   ============================================================ */

:root {
  /* Spacing scale (8px base) */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;

  /* Type scale */
  --text-xs: 11px;
  --text-sm: 12px;
  --text-base: 14px;
  --text-md: 15px;
  --text-lg: 16px;
  --text-xl: 18px;
  --text-2xl: 22px;
  --text-3xl: 26px;
  --text-4xl: 32px;
  --text-5xl: 40px;

  /* Radius scale */
  --radius-sm: 2px;
  --radius-md: 3px;
  --radius-lg: 6px;
  --radius-xl: 12px;
  --radius-pill: 999px;

  /* Shadow scale */
  --shadow-sm: 0 1px 2px rgba(10,10,10,0.04);
  --shadow-md: 0 2px 6px rgba(10,10,10,0.06);
  --shadow-lg: 0 8px 24px rgba(10,10,10,0.08);

  /* Surface tints (light pastel — see project_simple_over_clever feedback) */
  --color-tint-blue: #f0f7ff;
  --color-tint-amber: #fffbeb;
  --color-tint-green: #ecfdf5;
  --color-tint-red:   #fef2f2;
  --color-tint-purple:#f5f3ff;
  --color-tint-sand:  #fdfaf3;
}

/* ============================================================
   LAYOUT — container + section
   ============================================================ */
.sa-theme .sa-container-doc {
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: var(--space-6) var(--space-5);
}
.sa-theme .sa-container-doc-wide {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: var(--space-6) var(--space-5);
}
/* On homepage strip container vertical padding — sections control their own rhythm */
.sa-theme .sa-home .sa-container-doc,
.sa-theme .sa-home .sa-container-doc-wide,
.sa-theme.sa-home .sa-container-doc,
.sa-theme.sa-home .sa-container-doc-wide {
  padding-top: 0;
  padding-bottom: 0;
}
.sa-theme .sa-error-container {
  max-width: var(--container-content);
  margin: 0 auto;
  padding: var(--space-7) var(--space-5);
  text-align: center;
}
/* Inter-section vertical rhythm — applied via class on the section element */
.sa-theme .sa-section-gap     { margin-top: var(--space-6); }
.sa-theme .sa-section-gap-sm  { margin-top: var(--space-5); }
.sa-theme .sa-section-gap-lg  { margin-top: var(--space-7); }
/* Last section before footer needs bottom breathing room */
.sa-theme main > section:last-of-type { padding-bottom: var(--space-8); }

.sa-theme .sa-prose-narrow { max-width: 72ch; }
.sa-theme .sa-prose-medium { max-width: 65ch; }
.sa-theme .sa-prose-wide   { max-width: 80ch; }

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
.sa-theme .sa-h1-doc {
  font-size: var(--text-4xl);
  font-weight: 600;
  margin: var(--space-2) 0 var(--space-3);
  letter-spacing: -0.01em;
  line-height: 1.2;
}
.sa-theme .sa-h2-doc {
  font-size: var(--text-2xl);
  font-weight: 600;
  margin: 0 0 var(--space-3);
  letter-spacing: -0.01em;
  line-height: 1.3;
  scroll-margin-top: 110px;
}
.sa-theme .sa-h3-doc {
  font-size: var(--text-xl);
  font-weight: 600;
  margin: var(--space-5) 0 var(--space-2);
  line-height: 1.35;
}
.sa-theme .sa-lead-doc {
  font-size: var(--text-xl);
  line-height: 1.6;
  color: var(--color-text-soft);
  max-width: 65ch;
  margin: var(--space-2) 0 var(--space-5);
}
.sa-theme .sa-lead-narrow {
  color: var(--color-text-soft);
  max-width: 60ch;
  margin: var(--space-2) 0 var(--space-5);
}
.sa-theme .sa-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
  margin: var(--space-3) 0 var(--space-6);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.sa-theme .sa-text-mono { font-family: var(--font-mono); }
.sa-theme .sa-text-muted { color: var(--color-text-muted); }
.sa-theme .sa-text-soft { color: var(--color-text-soft); }

/* ============================================================
   TABLES — unified style
   ============================================================ */
.sa-theme .sa-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
}
.sa-theme .sa-table-doc {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-base);
}
.sa-theme .sa-table-doc thead tr {
  background: var(--color-surface);
}
.sa-theme .sa-table-doc th {
  text-align: left;
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  font-weight: 500;
  white-space: nowrap;
  border-bottom: 1px solid var(--color-border);
}
.sa-theme .sa-table-doc td {
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid var(--color-border);
  vertical-align: top;
}
.sa-theme .sa-table-doc tbody tr:hover td { background: var(--color-surface); }
.sa-theme .sa-table-doc-sm th,
.sa-theme .sa-table-doc-sm td { padding: var(--space-2) var(--space-3); }

/* Field-name first-column styling (used in requirements/compare tables) */
.sa-theme .sa-table-doc td.sa-field-cell {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  white-space: nowrap;
  width: 240px;
}

/* ============================================================
   GRIDS — card layouts
   ============================================================ */
.sa-theme .sa-grid-cards-sm {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--space-2);
}
.sa-theme .sa-grid-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--space-3);
}
.sa-theme .sa-grid-cards-md {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--space-3);
}
.sa-theme .sa-grid-cards-lg {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-4);
}
.sa-theme .sa-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
}
@media (max-width: 720px) {
  .sa-theme .sa-grid-2 { grid-template-columns: 1fr; }
}
.sa-theme .sa-grid-tldr {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-4);
}

/* ============================================================
   PILL VARIANTS — extend existing .sa-pill
   ============================================================ */
.sa-theme .sa-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.02em;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  text-decoration: none;
  white-space: nowrap;
}
.sa-theme .sa-pill-blue   { background: var(--color-tint-blue);   border-color: #cfe1ff; color: #1d4ed8; }
.sa-theme .sa-pill-green  { background: var(--color-tint-green);  border-color: #b7ecd5; color: #047857; }
.sa-theme .sa-pill-yellow { background: var(--color-tint-amber);  border-color: #fcd34d; color: #92400e; }
.sa-theme .sa-pill-red    { background: var(--color-tint-red);    border-color: #fecaca; color: #b91c1c; }
.sa-theme .sa-pill-purple { background: var(--color-tint-purple); border-color: #ddd6fe; color: #6d28d9; }
.sa-theme .sa-pill-sand   { background: var(--color-tint-sand);   border-color: #ead7b6; color: #92580d; }
.sa-theme .sa-pill-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

/* ============================================================
   BUTTON SHARED STYLES (used in compare toolbar, copy-link, etc.)
   ============================================================ */
.sa-theme .sa-btn {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  padding: 6px 12px;
  background: var(--color-bg);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-soft);
  transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.sa-theme .sa-btn:hover {
  background: var(--color-text);
  color: var(--color-bg);
  border-color: var(--color-text);
}
.sa-theme .sa-btn[data-state="ok"] {
  background: var(--color-status-green);
  color: #fff;
  border-color: var(--color-status-green);
}

/* ============================================================
   TOOLBAR — used by compare page and other filter rows
   ============================================================ */
.sa-theme .sa-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
  margin: 0 0 var(--space-5);
  padding: var(--space-3) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
}
.sa-theme .sa-toolbar-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* ============================================================
   CALLOUTS — extend existing
   ============================================================ */
.sa-theme .sa-callout {
  background: var(--color-surface);
  border-left: 3px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  margin: var(--space-5) 0;
}
.sa-theme .sa-callout-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-2);
}
.sa-theme .sa-callout-body { font-size: var(--text-base); line-height: 1.6; color: var(--color-text); }
.sa-theme .sa-callout-tldr { background: var(--color-tint-amber); border-left-color: var(--color-status-yellow); }
.sa-theme .sa-callout-warning { background: var(--color-tint-red); border-left-color: var(--color-status-red); }
.sa-theme .sa-callout-tip { background: var(--color-tint-green); border-left-color: var(--color-status-green); }
.sa-theme .sa-callout-citation { background: var(--color-tint-blue); border-left-color: var(--color-accent); }

/* ============================================================
   CARDS — extend existing
   ============================================================ */
.sa-theme .sa-card-compact {
  display: block;
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: var(--color-text);
  transition: border-color 0.12s, transform 0.12s;
}
.sa-theme .sa-card-compact:hover { border-color: var(--color-text); transform: translateY(-1px); }
.sa-theme .sa-card-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-md);
}
.sa-theme .sa-card-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-1);
}

/* ============================================================
   TINY UTILITIES (use sparingly — not a full tailwind)
   ============================================================ */
.sa-theme .sa-flex { display: flex; }
.sa-theme .sa-flex-wrap { flex-wrap: wrap; }
.sa-theme .sa-flex-center { display: flex; align-items: center; }
.sa-theme .sa-flex-between { display: flex; align-items: center; justify-content: space-between; }
.sa-theme .sa-gap-1 { gap: var(--space-1); }
.sa-theme .sa-gap-2 { gap: var(--space-2); }
.sa-theme .sa-gap-3 { gap: var(--space-3); }
.sa-theme .sa-gap-4 { gap: var(--space-4); }
.sa-theme .sa-mt-3 { margin-top: var(--space-3); }
.sa-theme .sa-mt-5 { margin-top: var(--space-5); }
.sa-theme .sa-mt-6 { margin-top: var(--space-6); }
.sa-theme .sa-mt-7 { margin-top: var(--space-7); }
.sa-theme .sa-mb-3 { margin-bottom: var(--space-3); }
.sa-theme .sa-mb-5 { margin-bottom: var(--space-5); }

/* ============================================================
   COMPARE TABLE — outlier highlighting (replaces inline)
   ============================================================ */
.sa-theme .sa-cmp-cell-outlier { background: var(--color-tint-amber); border-left: 2px solid var(--color-status-yellow); }
.sa-theme .sa-cmp-cell-modal { background: #f8fafc; }
.sa-theme .sa-cmp-cell-missing { color: var(--color-text-muted); }
.sa-theme .sa-cmp-table tbody tr[data-hidden="1"] { display: none; }

/* Filter chips */
.sa-theme .sa-chips {
  display: inline-flex;
  gap: 4px;
  padding: 2px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.sa-theme .sa-chip {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  padding: 5px 10px;
  background: transparent;
  border: 0;
  color: var(--color-text-soft);
  cursor: pointer;
  border-radius: var(--radius-sm);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.sa-theme .sa-chip:hover { color: var(--color-text); }
.sa-theme .sa-chip[data-active="1"] { background: var(--color-text); color: var(--color-bg); }

/* ============================================================
   MAP POPOVER — moved from inline
   ============================================================ */
.sa-theme .sa-map-wrap { background: var(--color-surface); position: relative; border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden; margin: var(--space-6) 0 var(--space-3); }
.sa-theme .sa-map { display: block; width: 100%; height: auto; background: #fafafa; }
.sa-theme .sa-map a { cursor: pointer; }
.sa-theme .sa-map .sa-map-dot { transition: r 0.15s, stroke-width 0.15s; }
.sa-theme .sa-map a:hover .sa-map-dot { r: 8.5; stroke-width: 2.5; }
.sa-theme .sa-map a:focus { outline: none; }
.sa-theme .sa-map a:focus .sa-map-dot { r: 8.5; stroke: var(--color-link); stroke-width: 3; }

.sa-theme .sa-map-popover {
  position: absolute;
  z-index: 10;
  background: #0a0a0a;
  color: #fafafa;
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  line-height: 1.4;
  min-width: 200px;
  max-width: 240px;
  box-shadow: var(--shadow-lg);
  pointer-events: none;
  transition: opacity 0.12s;
  opacity: 0;
}
.sa-theme .sa-map-popover[data-show="1"] { opacity: 1; }
.sa-theme .sa-map-popover-title { font-weight: 600; font-size: var(--text-base); margin-bottom: var(--space-2); letter-spacing: -0.01em; }
.sa-theme .sa-map-popover-row { display: flex; justify-content: space-between; gap: 10px; padding: 2px 0; font-family: var(--font-mono); font-size: var(--text-xs); }
.sa-theme .sa-map-popover-label { color: #a1a1aa; text-transform: uppercase; letter-spacing: 0.06em; font-size: 10px; }
.sa-theme .sa-map-popover-iso, .sa-theme .sa-map-popover-consent, .sa-theme .sa-map-popover-strict { color: #fafafa; }
.sa-theme .sa-map-popover-strict[data-strict="aggressive"] { color: #fca5a5; }
.sa-theme .sa-map-popover-strict[data-strict="moderate"] { color: #fcd34d; }
.sa-theme .sa-map-popover-strict[data-strict="pragmatic"] { color: #86efac; }
.sa-theme .sa-map-popover-cta { margin-top: var(--space-2); padding-top: var(--space-2); border-top: 1px solid #27272a; font-family: var(--font-mono); font-size: 10px; color: #a1a1aa; text-transform: uppercase; letter-spacing: 0.06em; }

/* Map legend */
.sa-theme .sa-map-legend {
  position: absolute;
  left: 12px;
  bottom: 12px;
  background: rgba(255,255,255,0.92);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 8px 12px;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  display: flex;
  gap: 14px;
  align-items: center;
}
.sa-theme .sa-map-caption {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin: 0 0 var(--space-6);
}

/* ============================================================
   SEARCH INPUT — used on /countries/ + others
   ============================================================ */
.sa-theme .sa-search {
  width: 100%;
  padding: 10px 14px;
  font-size: var(--text-base);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  background: var(--color-bg);
}
.sa-theme .sa-search:focus { border-color: var(--color-link); outline: none; }

/* ============================================================
   HOMEPAGE — public-utility compliance reference
   ============================================================ */
.sa-theme .sa-home {
  /* Page-level neutralizer in case theme.css adds anything */
}

/* Hero */
.sa-theme .sa-home-hero {
  background:
    radial-gradient(1200px 480px at 50% 0%, rgba(37, 99, 235, 0.05), transparent 70%),
    linear-gradient(180deg, var(--color-bg) 0%, var(--color-surface) 100%);
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-8) var(--space-5) var(--space-7);
  margin-bottom: var(--space-7);
}
.sa-theme .sa-home-hero-inner {
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
}
.sa-theme .sa-home-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  margin: 0 0 var(--space-4);
}
.sa-theme .sa-home-eyebrow::before { content: '// '; color: var(--color-text-faint); }
.sa-theme .sa-home-h1 {
  font-size: clamp(28px, 4.4vw, 48px);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.022em;
  margin: 0 0 var(--space-5);
  color: var(--color-text);
}
.sa-theme .sa-home-sub {
  font-size: clamp(15px, 1.4vw, 19px);
  line-height: 1.55;
  color: var(--color-text-soft);
  max-width: 680px;
  margin: 0 auto var(--space-6);
}
.sa-theme .sa-home-hero-cta {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: center;
  margin-bottom: var(--space-6);
}
.sa-theme .sa-home-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 12px 20px;
  font-size: var(--text-base);
  font-weight: 500;
  border-radius: var(--radius-md);
  text-decoration: none;
  border: 1px solid transparent;
  transition: background 0.12s, color 0.12s, border-color 0.12s, transform 0.12s;
  white-space: nowrap;
}
.sa-theme .sa-home-btn-primary {
  background: var(--color-text);
  color: var(--color-bg);
  border-color: var(--color-text);
}
.sa-theme .sa-home-btn-primary:hover {
  background: var(--color-bg);
  color: var(--color-text);
  transform: translateY(-1px);
}
.sa-theme .sa-home-btn-secondary {
  background: var(--color-bg);
  color: var(--color-text);
  border-color: var(--color-border-strong);
}
.sa-theme .sa-home-btn-secondary:hover {
  background: var(--color-text);
  color: var(--color-bg);
  border-color: var(--color-text);
}
.sa-theme .sa-home-hero-strip {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 0.02em;
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  text-transform: uppercase;
}
.sa-theme .sa-home-hero-strip strong { color: var(--color-text); font-weight: 600; }
.sa-theme .sa-strip-dot { color: var(--color-text-faint); }

/* Pillar tiles */
.sa-theme .sa-pillars {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-4);
  margin: 0;
}
.sa-theme .sa-pillar-card {
  display: flex;
  flex-direction: column;
  padding: var(--space-5) var(--space-5) var(--space-5);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  text-decoration: none;
  color: var(--color-text);
  min-height: 220px;
  transition: border-color 0.15s, transform 0.15s, box-shadow 0.15s;
}
.sa-theme .sa-pillar-card:hover {
  border-color: var(--color-text);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.sa-theme .sa-pillar-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  margin-bottom: var(--space-4);
  background: var(--color-text);
  color: var(--color-bg);
  border-radius: var(--radius-md);
  transition: transform 0.15s, background 0.15s;
}
.sa-theme .sa-pillar-icon svg { display: block; stroke-width: 1.8; }
.sa-theme .sa-pillar-card:hover .sa-pillar-icon {
  transform: scale(1.05);
  background: var(--color-accent);
}
.sa-theme .sa-pillar-title {
  font-size: var(--text-xl);
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0 0 var(--space-2);
  scroll-margin-top: 0;
}
.sa-theme .sa-pillar-desc {
  font-size: var(--text-base);
  line-height: 1.55;
  color: var(--color-text-soft);
  margin: 0 0 var(--space-4);
  flex: 1;
}
.sa-theme .sa-pillar-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-top: auto;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}

/* Section headers (used inside grids) */
.sa-theme .sa-section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}
.sa-theme .sa-section-head .sa-eyebrow,
.sa-theme .sa-section-head .sa-h2-doc { margin: 0; }
.sa-theme .sa-section-head .sa-eyebrow { margin-bottom: var(--space-1); }

/* Map teaser — smaller variant of archive map */
.sa-theme .sa-home-map {
  position: relative;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: #fafafa;
  overflow: hidden;
  margin-top: var(--space-5);
}
.sa-theme .sa-home-map svg.sa-map { display: block; width: 100%; height: auto; max-height: 520px; }
.sa-theme .sa-home-map .sa-map-dot { transition: r 0.12s; }
.sa-theme .sa-home-map a:hover .sa-map-dot { r: 7.5; }

/* Update list — recent changes */
.sa-theme .sa-update-list {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-top: var(--space-3);
}
.sa-theme .sa-update-row {
  display: flex;
  gap: var(--space-3);
  align-items: baseline;
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid var(--color-border);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
}
.sa-theme .sa-update-row:first-child { border-top: 0; }
.sa-theme .sa-update-date { color: var(--color-text-muted); font-weight: 500; min-width: 90px; }
.sa-theme .sa-update-field { color: var(--color-text); flex: 1; }
.sa-theme .sa-update-by { font-size: var(--text-xs); }

/* FAQ */
.sa-theme .sa-faq {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-bg);
}
.sa-theme .sa-faq-item {
  border-top: 1px solid var(--color-border);
}
.sa-theme .sa-faq-item:first-child { border-top: 0; }
.sa-theme .sa-faq-q {
  font-size: var(--text-lg);
  font-weight: 600;
  letter-spacing: -0.005em;
  padding: var(--space-4) var(--space-5);
  cursor: pointer;
  list-style: none;
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-text);
}
.sa-theme .sa-faq-q::-webkit-details-marker { display: none; }
.sa-theme .sa-faq-q::after {
  content: '+';
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 400;
  color: var(--color-text-muted);
  flex: 0 0 24px;
  text-align: right;
  transition: transform 0.15s;
}
.sa-theme .sa-faq-item[open] .sa-faq-q::after {
  content: '−';
  color: var(--color-text);
}
.sa-theme .sa-faq-item:hover .sa-faq-q { background: var(--color-surface); }
.sa-theme .sa-faq-a {
  padding: 0 var(--space-5) var(--space-5);
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--color-text-soft);
  max-width: 70ch;
}

/* ============================================================
   LAW PAGE — rich single-sa_law.php template
   ============================================================ */

/* Hero — asymmetric: title block + key-facts card */
.sa-theme .sa-law-page { display: block; }
.sa-theme .sa-law-hero {
  background:
    radial-gradient(1000px 360px at 100% 0%, rgba(37, 99, 235, 0.04), transparent 70%),
    linear-gradient(180deg, var(--color-bg) 0%, var(--color-surface) 100%);
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-7) var(--space-5);
}
.sa-theme .sa-law-hero-inner {
  max-width: var(--container-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: var(--space-7);
  align-items: start;
}
@media (max-width: 900px) {
  .sa-theme .sa-law-hero-inner { grid-template-columns: 1fr; gap: var(--space-5); }
}
.sa-theme .sa-law-hero-text { min-width: 0; }
.sa-theme .sa-law-h1 {
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin: var(--space-2) 0 var(--space-4);
  color: var(--color-text);
}

/* Editorial regulator glyph — circular dot pattern + monogram */
.sa-theme .sa-law-emblem {
  display: block;
  color: var(--color-text);
  flex-shrink: 0;
}
.sa-theme .sa-law-hero-mark {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
  padding: var(--space-2) var(--space-3) var(--space-2) var(--space-2);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  width: fit-content;
}
.sa-theme .sa-law-hero-mark-label {
  display: flex;
  flex-direction: column;
  line-height: 1.25;
  padding-right: var(--space-2);
}
.sa-theme .sa-law-hero-mark-name {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  font-weight: 500;
}
.sa-theme .sa-law-hero-mark-auth {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  letter-spacing: -0.005em;
}
.sa-theme .sa-law-hero-meta {
  display: flex; flex-wrap: wrap; gap: var(--space-2);
  margin-top: var(--space-4);
}

/* Key-facts card */
.sa-theme .sa-law-fact-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5) var(--space-3);
  box-shadow: var(--shadow-sm);
}
.sa-theme .sa-law-fact-card-title {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-border);
}
.sa-theme .sa-law-fact-list { margin: 0; }
.sa-theme .sa-law-fact-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: var(--space-2) 0;
  gap: var(--space-3);
  border-bottom: 1px dashed var(--color-border);
}
.sa-theme .sa-law-fact-row:last-child { border-bottom: 0; }
.sa-theme .sa-law-fact-row dt {
  font-family: var(--font-mono); font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-transform: uppercase; letter-spacing: 0.05em;
  flex: 0 0 auto;
}
.sa-theme .sa-law-fact-row dd {
  font-size: var(--text-base); font-weight: 600;
  color: var(--color-text);
  margin: 0; text-align: right; min-width: 0;
}

/* Two-column body + scrolling rail */
.sa-theme .sa-law-layout {
  max-width: 1320px;
  margin: 0 auto;
  padding: var(--space-7) var(--space-5);
  display: grid;
  grid-template-columns: minmax(0, 1fr) 260px;
  gap: var(--space-7);
  align-items: start;
}
@media (max-width: 1024px) {
  .sa-theme .sa-law-layout { grid-template-columns: 1fr; gap: var(--space-5); }
  .sa-theme .sa-law-rail { order: -1; }
}
/* Main: NO max-width — fill grid cell.
   Override theme's .sa-prose { max-width: 72ch } so structured sections breathe. */
.sa-theme .sa-law-main.sa-prose,
.sa-theme .sa-law-main { max-width: none !important; min-width: 0; }
/* Constrain text-paragraph width back to readable, but only on free prose. */
.sa-theme .sa-law-main > section > p,
.sa-theme .sa-law-main > section > ul,
.sa-theme .sa-law-main > section > ol { max-width: 76ch; }
.sa-theme .sa-law-main > section { scroll-margin-top: 96px; }
.sa-theme .sa-law-main > section + section { margin-top: var(--space-7); }
.sa-theme .sa-law-main h2.sa-h2-doc { margin-top: 0; }

/* Right rail container — block stack so sticky TOC behaves correctly.
   (display:flex column reportedly suppresses position:sticky in some
   Blink/Webkit cascade situations — keep it simple block.) */
.sa-theme .sa-law-rail { display: block; }
.sa-theme .sa-law-rail > * + * { margin-top: var(--space-4); }
@media (max-width: 1024px) {
  .sa-theme .sa-law-rail {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
  }
  .sa-theme .sa-law-rail > * { flex: 1 1 240px; margin-top: 0; }
}

/* TOC — flows naturally with the rail (no sticky, no overlap). */
.sa-theme .sa-law-toc {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
}

/* Generic rail card — used for compare/topics/templates/jurisdictions/sources */
.sa-theme .sa-law-rail-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  padding: var(--space-3) var(--space-4);
}
.sa-theme .sa-law-rail-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  font-weight: 500;
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-2);
}
.sa-theme .sa-law-rail-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.sa-theme .sa-law-rail-list li { margin: 0; }
.sa-theme .sa-law-rail-list a {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text);
  text-decoration: none;
  padding: 7px 0;
  border-bottom: 1px dashed transparent;
  transition: color 0.12s, border-color 0.12s;
}
.sa-theme .sa-law-rail-list li + li a { border-top: 1px dashed var(--color-border); }
.sa-theme .sa-law-rail-list a:hover { color: var(--color-link); }
.sa-theme .sa-law-rail-list a > span {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  flex-shrink: 0;
}
.sa-theme .sa-law-rail-list-flag a {
  justify-content: flex-start;
  gap: var(--space-2);
}
.sa-theme .sa-law-rail-list-flag .sa-rail-flag {
  display: inline-block;
  font-size: 15px;
  font-family: inherit;
  color: inherit;
  flex-shrink: 0;
  width: 18px;
  text-align: center;
}
.sa-theme .sa-law-rail-card-sources {
  background: var(--color-surface);
}
.sa-theme .sa-law-rail-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin: var(--space-3) 0 0;
  padding-top: var(--space-2);
  border-top: 1px dashed var(--color-border);
  line-height: 1.4;
}
.sa-theme .sa-law-toc-details summary {
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  padding: var(--space-2) 0;
  list-style: none;
}
.sa-theme .sa-law-toc-details summary::-webkit-details-marker { display: none; }
.sa-theme .sa-law-toc-details ul {
  list-style: none;
  margin: var(--space-2) 0 0;
  padding: 0;
  border-left: 1px solid var(--color-border);
}
.sa-theme .sa-law-toc-details li { margin: 0; }
.sa-theme .sa-law-toc-details a {
  display: block;
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  text-decoration: none;
  padding: 6px 12px;
  margin-left: -1px;
  border-left: 2px solid transparent;
  transition: color 0.12s, border-color 0.12s;
}
.sa-theme .sa-law-toc-details a:hover { color: var(--color-text); }
.sa-theme .sa-law-toc-details a.is-active {
  color: var(--color-text);
  border-left-color: var(--color-text);
  font-weight: 500;
}
@media (min-width: 1025px) {
  .sa-theme .sa-law-toc-details { all: revert; }
  .sa-theme .sa-law-toc-details summary { padding-bottom: var(--space-3); }
  .sa-theme .sa-law-toc-details[open] summary { border-bottom: 1px solid var(--color-border); margin-bottom: var(--space-2); }
}

/* Article-number badge — used on principles, lawful bases, rights */
.sa-theme .sa-eyebrow-art {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--color-text-muted);
  background: var(--color-surface);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  letter-spacing: 0.02em;
}

/* Seven principles — numbered list */
.sa-theme .sa-principles-list {
  list-style: none;
  margin: var(--space-4) 0;
  padding: 0;
  display: grid;
  gap: var(--space-3);
}
.sa-theme .sa-principles-list > li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
}
.sa-theme .sa-principles-num {
  font-family: var(--font-mono);
  font-size: var(--text-3xl);
  font-weight: 500;
  color: var(--color-text-faint);
  letter-spacing: -0.02em;
  align-self: start;
  line-height: 1;
}
.sa-theme .sa-principles-body { min-width: 0; }
.sa-theme .sa-principles-head {
  display: flex; flex-wrap: wrap; gap: var(--space-2);
  align-items: center;
  margin-bottom: var(--space-1);
}
.sa-theme .sa-principles-head strong { font-size: var(--text-lg); font-weight: 600; }
.sa-theme .sa-principles-body p {
  margin: 0;
  color: var(--color-text-soft);
  font-size: var(--text-base);
  line-height: 1.55;
}

/* Lawful-bases card grid (3x2) */
.sa-theme .sa-lawful-base-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-3);
  margin: var(--space-4) 0;
}
@media (max-width: 768px) {
  .sa-theme .sa-lawful-base-grid { grid-template-columns: 1fr; }
}
.sa-theme .sa-lawful-base-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  background: var(--color-bg);
  display: flex; flex-direction: column;
  gap: var(--space-2);
  transition: border-color 0.15s;
}
.sa-theme .sa-lawful-base-card:hover { border-color: var(--color-text); }
.sa-theme .sa-lawful-base-card h3 {
  font-size: var(--text-lg);
  font-weight: 600;
  margin: 0;
  letter-spacing: -0.005em;
}
.sa-theme .sa-lawful-base-card p {
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--color-text-soft);
  margin: 0;
}
.sa-theme .sa-lawful-base-tag {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: auto;
  padding-top: var(--space-2);
  border-top: 1px dashed var(--color-border);
  line-height: 1.4;
}
.sa-theme .sa-lawful-base-tag strong {
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 500;
}

/* Rights table — extends sa-table-doc */
.sa-theme .sa-rights-table tbody tr td:first-child { width: 240px; }
.sa-theme .sa-rights-table tbody tr td { vertical-align: top; }

/* Fine timeline — vertical list with bar chart */
.sa-theme .sa-fine-timeline {
  list-style: none;
  margin: var(--space-4) 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.sa-theme .sa-fine-row {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: var(--space-4);
  align-items: start;
}
@media (max-width: 600px) {
  .sa-theme .sa-fine-row { grid-template-columns: 1fr; gap: var(--space-2); }
}
.sa-theme .sa-fine-meta {
  display: flex; flex-direction: column;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.sa-theme .sa-fine-year { font-size: var(--text-sm); color: var(--color-text-muted); }
.sa-theme .sa-fine-amount { font-size: var(--text-xl); font-weight: 600; color: var(--color-text); margin-top: 2px; }
.sa-theme .sa-fine-body { min-width: 0; }
.sa-theme .sa-fine-bar {
  height: 6px;
  background: linear-gradient(90deg, var(--color-text) 0%, var(--color-text-soft) 100%);
  border-radius: var(--radius-pill);
  margin-bottom: var(--space-2);
  min-width: 6px;
}
.sa-theme .sa-fine-label {
  display: flex; flex-wrap: wrap; gap: var(--space-2);
  align-items: baseline;
  margin-bottom: 4px;
  font-size: var(--text-base);
}
.sa-theme .sa-fine-label strong { font-weight: 600; }
.sa-theme .sa-fine-label .sa-text-muted {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
}
.sa-theme .sa-fine-summary {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  line-height: 1.5;
  margin: 0;
}

/* National addons — table extension */
.sa-theme tr[data-stricter="1"] td:first-child { box-shadow: inset 3px 0 0 var(--color-status-yellow); }

/* Compare CTA row — pill cluster after a section */
.sa-theme .sa-compare-cta-row {
  display: flex; flex-wrap: wrap; gap: var(--space-2);
  align-items: center;
}

/* ============================================================
   REGION HEADERS — used on /countries/ grouped grids
   ============================================================ */
.sa-theme .sa-region-head {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  margin: var(--space-6) 0 var(--space-3);
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 6px;
}

/* ============================================================
   LAW PAGE v2 redesign — sharp tags, colored cards, lively tables
   (overrides earlier styles)
   ============================================================ */

/* === Pills as editorial tags: sharp 2px, leading accent bar, mono caps === */
.sa-theme .sa-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px 4px 8px;
  border-radius: 2px;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-left-width: 3px;
  border-left-color: var(--color-text);
  color: var(--color-text);
  text-decoration: none;
  white-space: nowrap;
  line-height: 1.4;
}
.sa-theme .sa-pill .sa-pill-dot { display: none; }
.sa-theme .sa-pill-blue   { background: var(--color-tint-blue);   border-color: #cfe1ff;  border-left-color: #2563eb;  color: #1d4ed8; }
.sa-theme .sa-pill-green  { background: var(--color-tint-green);  border-color: #b7ecd5;  border-left-color: #10b981;  color: #047857; }
.sa-theme .sa-pill-yellow { background: var(--color-tint-amber);  border-color: #fcd34d;  border-left-color: #f59e0b;  color: #92400e; }
.sa-theme .sa-pill-red    { background: var(--color-tint-red);    border-color: #fecaca;  border-left-color: #dc2626;  color: #b91c1c; }
.sa-theme .sa-pill-purple { background: var(--color-tint-purple); border-color: #ddd6fe;  border-left-color: #7c3aed;  color: #6d28d9; }
.sa-theme .sa-pill-sand   { background: var(--color-tint-sand);   border-color: #ead7b6;  border-left-color: #b45309;  color: #92580d; }
a.sa-pill:hover { transform: translateY(-1px); transition: transform .12s; }

/* === Editorial-research callout: kill blue bar, use mono dash bracket === */
.sa-theme .sa-callout.sa-callout-citation {
  background:
    repeating-linear-gradient(135deg,
      rgba(0,0,0,0.012) 0,
      rgba(0,0,0,0.012) 6px,
      transparent 6px,
      transparent 12px),
    var(--color-surface-2, #f4f4f2);
  border: 0;
  border-top: 1px dashed var(--color-text-muted);
  border-bottom: 1px dashed var(--color-text-muted);
  border-radius: 0;
  padding: var(--space-4) var(--space-5);
  margin: var(--space-5) 0;
}
.sa-theme .sa-callout.sa-callout-citation .sa-callout-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text);
  font-weight: 600;
  margin-bottom: var(--space-2);
}
.sa-theme .sa-callout.sa-callout-citation .sa-callout-label::before { content: '— '; color: var(--color-text-muted); }
.sa-theme .sa-callout.sa-callout-citation .sa-callout-label::after  { content: ' —';  color: var(--color-text-muted); }
.sa-theme .sa-callout.sa-callout-citation .sa-callout-body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--color-text);
}

/* === Article-reference badge: subtle slate code-tag (no shouty black) === */
.sa-theme .sa-eyebrow-art {
  display: inline-block;
  border-radius: 2px;
  background: #eef1f5;
  color: #475569;
  border: 1px solid #d6dde6;
  padding: 2px 7px;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.4;
}

/* === Lawful-bases: color-coded top stripe + colored eyebrow === */
.sa-theme .sa-lawful-base-card {
  position: relative;
  overflow: hidden;
  border-radius: 2px;
  border-color: var(--color-border);
  padding-top: calc(var(--space-4) + 6px);
  transition: transform .15s, box-shadow .15s, border-color .15s;
}
.sa-theme .sa-lawful-base-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: var(--lb-accent, var(--color-text));
}
.sa-theme .sa-lawful-base-card .sa-eyebrow-art {
  background: var(--lb-accent, var(--color-text));
  color: #fff;
}
.sa-theme .sa-lawful-base-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 18px rgba(10,10,10,0.06);
  border-color: var(--lb-accent, var(--color-text));
}
.sa-theme .sa-lawful-base-grid > .sa-lawful-base-card:nth-child(1) { --lb-accent: #4a6789; } /* steel blue */
.sa-theme .sa-lawful-base-grid > .sa-lawful-base-card:nth-child(2) { --lb-accent: #6b8466; } /* sage */
.sa-theme .sa-lawful-base-grid > .sa-lawful-base-card:nth-child(3) { --lb-accent: #76708a; } /* lavender gray */
.sa-theme .sa-lawful-base-grid > .sa-lawful-base-card:nth-child(4) { --lb-accent: #99644f; } /* terracotta */
.sa-theme .sa-lawful-base-grid > .sa-lawful-base-card:nth-child(5) { --lb-accent: #997b3a; } /* mustard */
.sa-theme .sa-lawful-base-grid > .sa-lawful-base-card:nth-child(6) { --lb-accent: #587878; } /* slate teal */

.sa-theme .sa-lawful-base-card h3 { margin-top: var(--space-2); }
.sa-theme .sa-lawful-base-tag {
  background: var(--color-surface);
  margin: var(--space-2) calc(var(--space-4) * -1) calc(var(--space-4) * -1);
  padding: var(--space-2) var(--space-4);
  border-top: 1px solid var(--color-border);
  border-radius: 0;
}

/* === Principles: large mono number gets accent fill === */
.sa-theme .sa-principles-list > li {
  border-radius: 2px;
  padding: var(--space-3) var(--space-4) var(--space-3) 0;
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  position: relative;
  overflow: hidden;
  transition: transform .15s, border-color .15s;
}
.sa-theme .sa-principles-list > li:hover { transform: translateX(2px); border-color: var(--p-accent, var(--color-text)); }
.sa-theme .sa-principles-num {
  background: var(--p-accent, var(--color-text));
  color: #fff;
  font-size: var(--text-xl);
  font-weight: 700;
  letter-spacing: 0;
  padding: var(--space-3) var(--space-4);
  margin: calc(var(--space-3) * -1) 0 calc(var(--space-3) * -1) 0;
  align-self: stretch;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 60px;
  font-family: var(--font-mono);
}
.sa-theme .sa-principles-list > li:nth-child(1) { --p-accent: #4a6789; }
.sa-theme .sa-principles-list > li:nth-child(2) { --p-accent: #6b8466; }
.sa-theme .sa-principles-list > li:nth-child(3) { --p-accent: #76708a; }
.sa-theme .sa-principles-list > li:nth-child(4) { --p-accent: #99644f; }
.sa-theme .sa-principles-list > li:nth-child(5) { --p-accent: #997b3a; }
.sa-theme .sa-principles-list > li:nth-child(6) { --p-accent: #587878; }
.sa-theme .sa-principles-list > li:nth-child(7) { --p-accent: #6e5b85; }
.sa-theme .sa-principles-body { padding: 0 var(--space-3); }

/* === Tables redesign: sharp corners, zebra rows, colored header, hover === */
.sa-theme .sa-table-wrap {
  border-radius: 2px;
  border-color: var(--color-border);
}
.sa-theme .sa-table-doc { border-radius: 0; }
.sa-theme .sa-table-doc thead tr {
  background: linear-gradient(180deg, #fafafa 0%, #f4f4f2 100%);
}
.sa-theme .sa-table-doc thead th {
  font-weight: 600;
  color: var(--color-text);
  border-bottom: 2px solid var(--color-text);
  padding: var(--space-3) var(--space-4);
}
.sa-theme .sa-table-doc tbody tr:nth-child(even) td { background: #fbfbfa; }
.sa-theme .sa-table-doc tbody tr:hover td { background: #f6f4ef; }
.sa-theme .sa-table-doc tbody tr td { padding: var(--space-3) var(--space-4); transition: background .12s; }

/* Rights-table — Article col always dark slate w/ white text;
   higher specificity than the generic tr:hover td rule above. */
.sa-theme .sa-rights-table tbody tr td:nth-child(2),
.sa-theme .sa-rights-table tbody tr:hover td:nth-child(2) {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: #fff;
  background: #475569;
  font-weight: 500;
  border-radius: 0;
  letter-spacing: 0.02em;
}
.sa-theme .sa-rights-table tbody tr:hover td:nth-child(2) { background: #334155; }

/* Response column — warm sand, dark text, narrow accent strip */
.sa-theme .sa-rights-table tbody tr td:nth-child(3),
.sa-theme .sa-rights-table tbody tr:hover td:nth-child(3) {
  font-family: var(--font-mono);
  font-weight: 500;
  color: #6b5d3a;
  background: #faf6ec;
  border-left: 2px solid #c8a25a;
}
.sa-theme .sa-rights-table tbody tr:hover td:nth-child(3) { background: #f6efde; }

/* National-addons table — muted "stricter" row indicator */
.sa-theme tr[data-stricter="1"] td:first-child {
  box-shadow: inset 3px 0 0 #c8a25a;
  background: #faf6ec;
}
.sa-theme tr[data-stricter="1"]:hover td:first-child { background: #f6efde; }

/* === Fine timeline: muted tier accent on amount === */
.sa-theme .sa-fine-amount { font-size: var(--text-xl); font-weight: 700; }
.sa-theme .sa-fine-row[data-tier="mega"] .sa-fine-amount { color: #99644f; }    /* €1B+ — terracotta */
.sa-theme .sa-fine-row[data-tier="huge"] .sa-fine-amount { color: #997b3a; }    /* €100M+ — mustard */
.sa-theme .sa-fine-row[data-tier="big"]  .sa-fine-amount { color: #4a6789; }    /* €10M+ — steel blue */
.sa-theme .sa-fine-row[data-tier="med"]  .sa-fine-amount { color: var(--color-text); }
.sa-theme .sa-fine-bar {
  background: linear-gradient(90deg, var(--color-text) 0%, #475569 100%);
  border-radius: 0;
  height: 6px;
  opacity: 0.85;
}

/* === Compare cards on law page === */
.sa-theme .sa-card { border-radius: 2px; transition: transform .15s, border-color .15s; }
.sa-theme .sa-card:hover { transform: translateY(-2px); border-color: var(--color-text); }

/* === Card-compact (where-it-applies grid) === */
.sa-theme .sa-card-compact { border-radius: 2px; }

/* === Hero pills, hero-mark chip — sharper === */
.sa-theme .sa-law-hero-mark { border-radius: 2px; }
.sa-theme .sa-law-fact-card { border-radius: 2px; }
.sa-theme .sa-law-toc { border-radius: 2px; }
.sa-theme .sa-law-rail-card { border-radius: 2px; }

/* === FAQ container: sharper === */
.sa-theme .sa-faq { border-radius: 2px; }
