/* ============================================================================
   STRATA — kit.css  (all block/component styles, token-driven)
   Depends on tokens.css. No hardcoded palette values here — only var(--…).
   ========================================================================== */

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--font-system);
  font-size: var(--t-body);
  line-height: var(--lh-body);
  color: var(--c-ink);
  background: var(--c-bg-page);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  transition: background var(--motion), color var(--motion);
}

h1,h2,h3,h4,h5 { margin: 0; line-height: var(--lh-snug); font-weight: 600; }
p { margin: 0 0 1em; }
a { color: inherit; }
img { max-width: 100%; display: block; }

::selection { background: var(--c-metal); color: var(--c-ink-on-metal); }

/* ---- Layout helpers ---- */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.container--narrow { max-width: var(--container-narrow); }
.section { padding-block: var(--p-space-9); }
.section--tight { padding-block: var(--p-space-8); }
.stack > * + * { margin-top: var(--p-space-4); }

/* ---- Typographic roles ---- */
.lineage { font-family: var(--font-lineage); }
.display {
  font-family: var(--font-lineage);
  font-size: var(--t-display);
  line-height: var(--lh-tight);
  font-weight: 500;
  letter-spacing: -0.01em;
}
.display em { font-style: italic; color: var(--c-metal-deep); }
.h1 { font-family: var(--font-lineage); font-size: var(--t-h1); font-weight: 500; line-height: var(--lh-tight); }
.h2 { font-family: var(--font-lineage); font-size: var(--t-h2); font-weight: 500; line-height: var(--lh-snug); }
.h3 { font-family: var(--font-lineage); font-size: var(--t-h3); font-weight: 500; }
.h4 { font-family: var(--font-system); font-size: var(--t-h4); font-weight: 600; }
.lead { font-size: var(--t-lead); color: var(--c-ink-muted); line-height: 1.5; }
.muted { color: var(--c-ink-muted); }
.small { font-size: var(--t-small); }

.eyebrow {
  font-family: var(--font-system);
  font-size: var(--t-micro);
  text-transform: uppercase;
  letter-spacing: var(--ls-eyebrow);
  font-weight: 600;
  color: var(--c-metal-deep);
  display: inline-flex; align-items: center; gap: var(--p-space-2);
}
.eyebrow::before {
  content: ""; width: 22px; height: 1.5px; background: var(--c-metal); display: inline-block;
}
.eyebrow--plain::before { display: none; }

/* ---- Primitives: buttons ---- */
.btn {
  font-family: var(--font-system);
  font-size: var(--t-small);
  font-weight: 600;
  letter-spacing: var(--ls-label);
  padding: var(--btn-pad-y) var(--btn-pad-x);
  border-radius: var(--btn-radius);
  border: 1px solid transparent;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: var(--p-space-2);
  text-decoration: none;
  transition: background var(--motion-fast), color var(--motion-fast),
              border-color var(--motion-fast), transform var(--motion-fast),
              box-shadow var(--motion-fast);
  background: transparent;
}
.btn:active { transform: translateY(1px); }
.btn--primary {
  background: var(--c-metal); color: var(--c-ink-on-metal);
  border-color: var(--c-metal-deep);
  box-shadow: var(--c-elev-1);
}
.btn--primary:hover { background: var(--c-metal-deep); color: var(--c-surface-raised); }
.btn--primary:focus-visible { outline: 2px solid var(--c-metal-deep); outline-offset: 3px; }
.btn--ghost {
  border-color: var(--c-border-strong); color: var(--c-ink);
}
.btn--ghost:hover { border-color: var(--c-metal); color: var(--c-metal-deep); background: var(--c-metal-wash); }
.btn--ghost:focus-visible { outline: 2px solid var(--c-metal); outline-offset: 3px; }
.btn--link { padding-inline: 0; color: var(--c-metal-deep); border: none; }
.btn--link:hover { color: var(--c-ink); }
.btn[disabled] { opacity: 0.45; pointer-events: none; }

/* ---- Primitives: tags / badges / chips / dividers ---- */
.tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-system); font-size: var(--t-micro); font-weight: 600;
  text-transform: uppercase; letter-spacing: var(--ls-label);
  padding: 4px 10px; border-radius: var(--p-radius-pill);
  border: 1px solid var(--c-metal-line); color: var(--c-metal-deep);
  background: var(--c-metal-wash);
}
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: var(--t-micro); font-weight: 600;
  padding: 3px 9px; border-radius: var(--p-radius-sm);
  background: var(--c-surface-overlay); border: 1px solid var(--c-border);
  color: var(--c-ink-muted);
}
.badge--metal { background: var(--c-metal); color: var(--c-ink-on-metal); border-color: var(--c-metal-deep); }
.chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px; border-radius: var(--p-radius-pill);
  border: 1px solid var(--c-border); background: var(--c-surface-raised);
  font-size: var(--t-small); cursor: pointer; color: var(--c-ink);
  transition: border-color var(--motion-fast), background var(--motion-fast), color var(--motion-fast);
}
.chip[aria-pressed="true"], .chip:hover { border-color: var(--c-metal); color: var(--c-metal-deep); background: var(--c-metal-wash); }
.chip .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--c-metal); }
.divider { height: 1px; background: var(--c-hairline); border: 0; margin: 0; }
.rule-metal { height: 2px; width: 56px; background: var(--c-metal); border: 0; border-radius: 2px; }

/* ---- Card primitive ---- */
.card {
  background: var(--c-surface-raised);
  border: 1px solid var(--c-border);
  border-radius: var(--card-radius);
  padding: var(--card-pad);
  box-shadow: var(--c-elev-1);
}
.card--overlay { background: var(--c-surface-overlay); }
.card--sunk { background: var(--c-surface-sunk); }

/* ============================================================================
   EMBLEM — modernized concentric ceremonial mark (abstract ring + triangle)
   Pure SVG, inherits --c-emblem-* from theme/track. NOT the literal Defendo mark.
   ========================================================================== */
.emblem { display: inline-block; line-height: 0; }
.emblem svg { display: block; }
.emblem .ring-outer { fill: none; stroke: var(--c-emblem-ring); }
.emblem .ring-inner { fill: none; stroke: var(--c-emblem-ring); opacity: 0.55; }
.emblem .ring-field { fill: var(--c-emblem-field); }
.emblem .tri { fill: none; stroke: var(--c-emblem-core); stroke-linejoin: round; }
.emblem .core { fill: var(--c-emblem-core); }
.emblem .tick { stroke: var(--c-emblem-ring); opacity: 0.6; }
.emblem--spin .ring-rot { transform-origin: 50% 50%; animation: emblemRot 60s linear infinite; }
@keyframes emblemRot { to { transform: rotate(360deg); } }

/* ============================================================================
   TOP BAR (nav) + controls
   ========================================================================== */
.topbar {
  position: sticky; top: 0; z-index: 40;
  background: color-mix(in srgb, var(--c-surface-base) 88%, transparent);
  backdrop-filter: saturate(1.1);
  border-bottom: 1px solid var(--c-border);
}
.topbar__inner {
  display: flex; align-items: center; gap: var(--p-space-5);
  min-height: 66px; padding-block: var(--p-space-2);
}
.brand { display: inline-flex; align-items: center; gap: 12px; text-decoration: none; color: var(--c-ink); }
.brand__name { font-family: var(--font-system); font-weight: 700; letter-spacing: 0.02em; font-size: var(--t-small); text-transform: uppercase; }
.brand__name b { display: block; font-weight: 700; }
.brand__name span { display: block; font-weight: 500; font-size: var(--t-micro); letter-spacing: var(--ls-eyebrow); color: var(--c-ink-muted); }
.nav-links { display: none; gap: var(--p-space-5); margin-left: var(--p-space-4); }
.nav-links a { text-decoration: none; font-size: var(--t-small); color: var(--c-ink-muted); font-weight: 500; transition: color var(--motion-fast); }
.nav-links a:hover { color: var(--c-metal-deep); }
.topbar__spacer { flex: 1 1 auto; }
.controls { display: flex; align-items: center; gap: var(--p-space-3); }

/* track switcher (segmented) */
.trackswitch { display: inline-flex; padding: 3px; gap: 2px; background: var(--c-surface-sunk); border: 1px solid var(--c-border); border-radius: var(--p-radius-pill); }
.trackswitch button {
  border: 0; background: transparent; cursor: pointer; color: var(--c-ink-muted);
  font-family: var(--font-system); font-size: var(--t-micro); font-weight: 600;
  letter-spacing: var(--ls-label); padding: 6px 11px; border-radius: var(--p-radius-pill);
  display: inline-flex; align-items: center; gap: 6px; transition: color var(--motion-fast), background var(--motion-fast);
}
.trackswitch button .dot { width: 9px; height: 9px; border-radius: 50%; }
.trackswitch button[data-track="defendo"] .dot { background: var(--p-bronze); }
.trackswitch button[data-track="kickboxing"] .dot { background: var(--p-copper); }
.trackswitch button[data-track="safekid"] .dot { background: var(--p-sage); }
.trackswitch button[aria-pressed="true"] { background: var(--c-surface-overlay); color: var(--c-ink); box-shadow: var(--c-elev-1); }
.trackswitch button:focus-visible { outline: 2px solid var(--c-metal); outline-offset: 2px; }
.trackswitch .lbl { display: none; }

.theme-toggle {
  width: 40px; height: 40px; border-radius: var(--p-radius-sm);
  border: 1px solid var(--c-border); background: var(--c-surface-raised); cursor: pointer;
  color: var(--c-ink); display: inline-grid; place-items: center;
  transition: border-color var(--motion-fast), color var(--motion-fast), background var(--motion-fast);
}
.theme-toggle:hover { border-color: var(--c-metal); color: var(--c-metal-deep); }
.theme-toggle:focus-visible { outline: 2px solid var(--c-metal); outline-offset: 2px; }
.theme-toggle svg { width: 18px; height: 18px; }
.theme-toggle .i-sun { display: none; }
.theme-toggle .i-moon { display: block; }
[data-theme="dark"] .theme-toggle .i-sun { display: block; }
[data-theme="dark"] .theme-toggle .i-moon { display: none; }

@media (min-width: 880px) {
  .nav-links { display: inline-flex; }
  .trackswitch .lbl { display: inline; }
}

/* ============================================================================
   HERO
   ========================================================================== */
.hero {
  position: relative;
  /* Fill the viewport below the sticky topbar instead of padding down to it.
     min-height (not height) so tall content grows + scrolls, never clips.
     svh keeps it stable against mobile browser-chrome changes. */
  min-height: calc(100svh - var(--header-h));
  display: flex;
  align-items: center;
}
.hero__grid {
  display: grid; gap: var(--p-space-7); align-items: center;
  grid-template-columns: 1fr;
  width: 100%;
  /* modest viewport-relative breathing room; the fill + centering do the vertical work */
  padding-block: clamp(1.5rem, 5vh, 4rem);
}
.hero__copy { max-width: 36rem; }
.hero__media {
  position: relative; border-radius: var(--p-radius-lg); overflow: hidden;
  border: 1px solid var(--c-border); box-shadow: var(--c-elev-3);
  background: var(--c-surface-sunk);
  aspect-ratio: 16 / 11;
}
.media-img { width: 100%; height: 100%; object-fit: cover; filter: var(--c-img-filter); }
.media-tint {
  position: absolute; inset: 0; pointer-events: none;
  background: var(--c-metal); mix-blend-mode: var(--c-img-blend); opacity: var(--c-img-tint-opacity);
}
.media-overlay { position: absolute; inset: 0; pointer-events: none; background: var(--c-img-overlay); }
.media-cap {
  position: absolute; left: var(--p-space-4); bottom: var(--p-space-4); right: var(--p-space-4);
  font-size: var(--t-micro); letter-spacing: var(--ls-label); text-transform: uppercase;
  color: var(--c-ink); font-weight: 600;
}
.hero__meta { display: flex; flex-wrap: wrap; gap: var(--p-space-3); margin-top: var(--p-space-5); }
.hero__cta { display: flex; flex-wrap: wrap; gap: var(--p-space-3); margin-top: var(--p-space-6); }

@media (min-width: 900px) {
  .hero__grid { grid-template-columns: 1.05fr 0.95fr; }
}

/* ============================================================================
   FOUR PRINCIPLES
   ========================================================================== */
.principles { display: grid; gap: var(--p-space-4); grid-template-columns: 1fr; }
.principle {
  border: 1px solid var(--c-border); border-radius: var(--card-radius);
  padding: var(--p-space-6); background: var(--c-surface-raised);
  position: relative; overflow: hidden;
  transition: border-color var(--motion), transform var(--motion), box-shadow var(--motion);
}
.principle::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--c-metal); opacity: 0.7;
}
.principle:hover { border-color: var(--c-metal-line); transform: translateY(-2px); box-shadow: var(--c-elev-2); }
.principle__no { font-family: var(--font-lineage); font-style: italic; font-size: var(--t-h3); color: var(--c-metal-deep); }
.principle__title { font-family: var(--font-system); font-weight: 700; font-size: var(--t-h4); margin: var(--p-space-2) 0 var(--p-space-3); }
@media (min-width: 720px) { .principles { grid-template-columns: 1fr 1fr; } }

/* ============================================================================
   LINEAGE AS EVIDENCE — the master line + sticky master card
   ========================================================================== */
.lineage-block { display: grid; gap: var(--p-space-7); grid-template-columns: 1fr; }
.lineage-line { position: relative; padding-left: var(--p-space-6); }
.lineage-line::before { content: ""; position: absolute; left: 9px; top: 6px; bottom: 6px; width: 2px; background: linear-gradient(var(--c-metal), var(--c-border)); }
.lineage-node { position: relative; padding: var(--p-space-4) 0; }
.lineage-node::before {
  content: ""; position: absolute; left: -1.95rem; top: 1.4rem;
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--c-surface-base); border: 3px solid var(--c-metal);
}
.lineage-node--now::before { background: var(--c-metal); }
.lineage-node__role { font-size: var(--t-micro); text-transform: uppercase; letter-spacing: var(--ls-eyebrow); color: var(--c-metal-deep); font-weight: 700; }
.lineage-node__name { font-family: var(--font-lineage); font-size: var(--t-h3); margin: 2px 0 4px; }
.master-card {
  position: sticky; top: 88px;
  border: 1px solid var(--c-border); border-radius: var(--card-radius);
  background: var(--c-surface-overlay); box-shadow: var(--c-elev-2); overflow: hidden;
}
.master-card__media { position: relative; aspect-ratio: 3 / 2; background: var(--c-surface-sunk); }
.master-card__body { padding: var(--p-space-6); }
.master-card__stat { display: flex; gap: var(--p-space-6); margin-top: var(--p-space-4); flex-wrap: wrap; }
.master-card__stat b { font-family: var(--font-lineage); font-size: var(--t-h3); display: block; color: var(--c-metal-deep); }
.master-card__stat span { font-size: var(--t-micro); text-transform: uppercase; letter-spacing: var(--ls-label); color: var(--c-ink-muted); }
@media (min-width: 920px) { .lineage-block { grid-template-columns: 1.1fr 0.9fr; } }

/* creed cells */
.creed { display: grid; gap: 1px; background: var(--c-border); border: 1px solid var(--c-border); border-radius: var(--card-radius); overflow: hidden; grid-template-columns: 1fr; }
.creed__cell { background: var(--c-surface-raised); padding: var(--p-space-5); }
.creed__cell q { font-family: var(--font-lineage); font-style: italic; font-size: var(--t-lead); display: block; color: var(--c-ink); }
@media (min-width: 700px) { .creed { grid-template-columns: 1fr 1fr; } }

/* ============================================================================
   CERTIFY-TO-TEACH TRACK CARDS + track feature header (re-skins per accent)
   ========================================================================== */
.track-feature {
  position: relative; border-radius: var(--p-radius-lg); overflow: hidden;
  border: 1px solid var(--c-border); box-shadow: var(--c-elev-2);
  background: var(--c-surface-sunk); min-height: 320px; display: grid; align-items: end;
}
.track-feature__media { position: absolute; inset: 0; }
.track-feature__body { position: relative; padding: var(--p-space-7) var(--p-space-6); }
.track-feature__body .h2 { color: var(--c-ink); }

.track-cards { display: grid; gap: var(--p-space-4); grid-template-columns: 1fr; }
.track-card {
  border: 1px solid var(--c-border); border-radius: var(--card-radius);
  padding: var(--p-space-6); background: var(--c-surface-raised);
  display: flex; flex-direction: column; gap: var(--p-space-3);
  transition: border-color var(--motion), box-shadow var(--motion), transform var(--motion);
}
.track-card[data-self] { border-color: var(--c-metal); box-shadow: var(--c-elev-2); }
.track-card:hover { transform: translateY(-2px); box-shadow: var(--c-elev-2); border-color: var(--c-metal-line); }
.track-card__top { display: flex; align-items: center; justify-content: space-between; gap: var(--p-space-3); }
.track-card__dot { width: 12px; height: 12px; border-radius: 50%; }
.track-card[data-track-dot="defendo"] .track-card__dot { background: var(--p-bronze); }
.track-card[data-track-dot="kickboxing"] .track-card__dot { background: var(--p-copper); }
.track-card[data-track-dot="safekid"] .track-card__dot { background: var(--p-sage); }
.track-card[data-track-dot="grappling"] .track-card__dot { background: var(--p-belt-4); }
.track-card[data-track-dot="krav"] .track-card__dot { background: var(--p-belt-5); }
.track-card__name { font-family: var(--font-lineage); font-size: var(--t-h4); }
.track-card ul { margin: 0; padding-left: 1.1rem; color: var(--c-ink-muted); font-size: var(--t-small); }
.track-card li { margin-bottom: 4px; }
@media (min-width: 760px) { .track-cards { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1040px) { .track-cards { grid-template-columns: repeat(3, 1fr); } }

/* ============================================================================
   STRATA — signature progression mechanic (lineage / involvement hierarchy)
   Bands Master(root) → Home Class(surface), interactive hover/focus,
   plus a 5-belt scale bronze→obsidian.
   ========================================================================== */
.strata {
  display: grid; gap: var(--p-space-6); grid-template-columns: 1fr;
}
.strata__stack {
  border: 1px solid var(--c-border); border-radius: var(--card-radius);
  overflow: hidden; background: var(--c-surface-sunk); box-shadow: var(--c-elev-1);
}
.band {
  --band-fill: var(--c-surface-raised);
  position: relative; width: 100%; text-align: left; cursor: pointer;
  border: 0; border-bottom: 1px solid var(--c-border);
  background: var(--band-fill); color: var(--c-ink);
  padding: var(--p-space-5) var(--p-space-6);
  display: grid; grid-template-columns: 2.2rem 1fr auto; align-items: center; gap: var(--p-space-4);
  font-family: var(--font-system);
  transition: background var(--motion), padding var(--motion), color var(--motion);
}
.band:last-child { border-bottom: 0; }
/* depth tint: deeper layers darker via belt scale, surface layer lightest */
.band[data-depth="0"] { --band-fill: color-mix(in srgb, var(--p-belt-5) 16%, var(--c-surface-raised)); }
.band[data-depth="1"] { --band-fill: color-mix(in srgb, var(--p-belt-4) 14%, var(--c-surface-raised)); }
.band[data-depth="2"] { --band-fill: color-mix(in srgb, var(--p-belt-3) 12%, var(--c-surface-raised)); }
.band[data-depth="3"] { --band-fill: color-mix(in srgb, var(--p-belt-2) 14%, var(--c-surface-raised)); }
.band[data-depth="4"] { --band-fill: color-mix(in srgb, var(--p-belt-1) 26%, var(--c-surface-raised)); }
.band__idx {
  width: 2.2rem; height: 2.2rem; border-radius: 50%;
  display: grid; place-items: center; font-family: var(--font-lineage); font-style: italic;
  border: 1.5px solid var(--c-metal-line); color: var(--c-metal-deep); background: var(--c-surface-base);
  font-size: var(--t-small);
}
.band__main { min-width: 0; }
.band__title { font-weight: 700; font-size: var(--t-h4); font-family: var(--font-system); }
.band__sub { font-size: var(--t-small); color: var(--c-ink-muted); }
.band__count { text-align: right; font-family: var(--font-lineage); }
.band__count b { display: block; font-size: var(--t-h4); color: var(--c-metal-deep); line-height: 1; }
.band__count span { font-size: var(--t-micro); text-transform: uppercase; letter-spacing: var(--ls-label); color: var(--c-ink-muted); }
.band__unlock {
  grid-column: 1 / -1;
  max-height: 0; overflow: hidden; opacity: 0;
  transition: max-height var(--motion-slow), opacity var(--motion), margin var(--motion);
}
.band__unlock-inner {
  border-top: 1px dashed var(--c-metal-line); margin-top: var(--p-space-4); padding-top: var(--p-space-4);
  display: grid; gap: var(--p-space-2);
}
.band__unlock-inner .lbl { font-size: var(--t-micro); text-transform: uppercase; letter-spacing: var(--ls-eyebrow); color: var(--c-metal-deep); font-weight: 700; }
.band__unlock-inner ul { margin: 0; padding-left: 1.1rem; color: var(--c-ink); font-size: var(--t-small); }
.band.is-open { background: color-mix(in srgb, var(--c-metal-wash) 60%, var(--band-fill)); }
.band.is-open .band__idx { background: var(--c-metal); color: var(--c-ink-on-metal); border-color: var(--c-metal-deep); }
.band.is-open .band__unlock { max-height: 320px; opacity: 1; }
.band:hover { background: color-mix(in srgb, var(--c-metal-wash) 35%, var(--band-fill)); }
.band:focus-visible { outline: 2px solid var(--c-metal); outline-offset: -2px; }

/* belt scale */
.belt-scale { border: 1px solid var(--c-border); border-radius: var(--card-radius); padding: var(--p-space-6); background: var(--c-surface-raised); }
.belt-row { display: flex; align-items: center; gap: var(--p-space-3); padding: 8px 0; }
.belt-swatch { width: 38px; height: 18px; border-radius: 3px; flex: none; border: 1px solid rgba(0,0,0,0.12); box-shadow: inset 0 1px 0 rgba(255,255,255,0.18); }
.belt-1 { background: var(--p-belt-1); }
.belt-2 { background: var(--p-belt-2); }
.belt-3 { background: var(--p-belt-3); }
.belt-4 { background: var(--p-belt-4); }
.belt-5 { background: var(--p-belt-5); }
.belt-row b { font-weight: 700; font-size: var(--t-small); }
.belt-row span { font-size: var(--t-small); color: var(--c-ink-muted); }
@media (min-width: 940px) { .strata { grid-template-columns: 1.4fr 0.85fr; align-items: start; } }

/* ============================================================================
   STAT / FOOTPRINT STRIP
   ========================================================================== */
.footprint {
  border-block: 1px solid var(--c-border);
  background: var(--c-surface-base);
}
.footprint__grid { display: grid; gap: var(--p-space-6); grid-template-columns: repeat(2, 1fr); padding-block: var(--p-space-7); }
.stat b { font-family: var(--font-lineage); font-size: var(--t-h1); color: var(--c-ink); display: block; line-height: 1; }
.stat b em { font-style: normal; color: var(--c-metal-deep); }
.stat span { font-size: var(--t-micro); text-transform: uppercase; letter-spacing: var(--ls-label); color: var(--c-ink-muted); margin-top: 6px; display: block; }
@media (min-width: 820px) { .footprint__grid { grid-template-columns: repeat(4, 1fr); } }

/* ============================================================================
   CREDENTIAL / QUOTE
   ========================================================================== */
.quote {
  border: 1px solid var(--c-border); border-radius: var(--card-radius);
  background: var(--c-surface-overlay); padding: var(--p-space-7);
  position: relative;
}
.quote::before { content: "\201C"; font-family: var(--font-lineage); font-size: 5rem; line-height: 0.6; color: var(--c-metal); opacity: 0.35; position: absolute; top: 1.4rem; left: 1.2rem; }
.quote blockquote { margin: 0; font-family: var(--font-lineage); font-style: italic; font-size: var(--t-h3); line-height: 1.3; }
.quote figcaption { margin-top: var(--p-space-4); font-size: var(--t-small); color: var(--c-ink-muted); }
.quote figcaption b { color: var(--c-ink); font-style: normal; }

/* ============================================================================
   CTA BANDS
   ========================================================================== */
.cta {
  border-radius: var(--p-radius-lg); padding: var(--p-space-8) var(--gutter);
  background: var(--c-surface-overlay); border: 1px solid var(--c-border);
  position: relative; overflow: hidden; text-align: center;
}
.cta--metal {
  background: var(--c-cta-metal-bg);
  color: var(--c-cta-metal-ink); border-color: var(--c-cta-metal-border);
}
.cta--metal .h1, .cta--metal .h2, .cta--metal .lead, .cta--metal .eyebrow { color: var(--c-cta-metal-ink); }
.cta--metal .eyebrow::before { background: var(--c-cta-metal-ink); }
/* primary "face" button sitting on the band (theme-aware; overrides inline fallbacks) */
.cta--metal .btn--primary {
  background: var(--c-cta-metal-btn-bg); color: var(--c-cta-metal-btn-ink);
  border-color: transparent; box-shadow: var(--c-elev-1);
}
.cta--metal .btn--ghost { border-color: var(--c-cta-metal-ghost-border); color: var(--c-cta-metal-ghost-ink); }
.cta--metal .btn--ghost:hover { background: var(--c-cta-metal-ghost-hover); color: var(--c-cta-metal-ghost-ink); }
.cta__actions { display: flex; gap: var(--p-space-3); justify-content: center; flex-wrap: wrap; margin-top: var(--p-space-5); }

/* ============================================================================
   PHOTO + CAPTION (documentary, treated)
   ========================================================================== */
.figure { border-radius: var(--p-radius-lg); overflow: hidden; border: 1px solid var(--c-border); position: relative; background: var(--c-surface-sunk); }
.figure__media { position: relative; aspect-ratio: 4 / 3; }
.figure figcaption { padding: var(--p-space-4) var(--p-space-5); font-size: var(--t-small); color: var(--c-ink-muted); background: var(--c-surface-raised); }
.figure figcaption b { color: var(--c-ink); }

/* ============================================================================
   SPLIT (content + media)
   ========================================================================== */
.split { display: grid; gap: var(--p-space-7); grid-template-columns: 1fr; align-items: center; }
.split--reverse .split__media { order: -1; }
.split__media { border-radius: var(--p-radius-lg); overflow: hidden; border: 1px solid var(--c-border); position: relative; aspect-ratio: 3 / 2; background: var(--c-surface-sunk); box-shadow: var(--c-elev-2); }
@media (min-width: 860px) { .split { grid-template-columns: 1fr 1fr; } .split--reverse .split__media { order: 0; } }

/* ============================================================================
   FAQ / ACCORDION
   ========================================================================== */
.faq { border: 1px solid var(--c-border); border-radius: var(--card-radius); overflow: hidden; background: var(--c-surface-raised); }
.faq__item { border-bottom: 1px solid var(--c-border); }
.faq__item:last-child { border-bottom: 0; }
.faq__q {
  width: 100%; text-align: left; border: 0; background: transparent; cursor: pointer;
  padding: var(--p-space-5) var(--p-space-6); display: flex; align-items: center; justify-content: space-between; gap: var(--p-space-4);
  font-family: var(--font-system); font-weight: 600; font-size: var(--t-lead); color: var(--c-ink);
}
.faq__q:hover { color: var(--c-metal-deep); }
.faq__q:focus-visible { outline: 2px solid var(--c-metal); outline-offset: -2px; }
.faq__icon { flex: none; width: 22px; height: 22px; position: relative; }
.faq__icon::before, .faq__icon::after { content: ""; position: absolute; background: var(--c-metal); transition: transform var(--motion); }
.faq__icon::before { left: 0; right: 0; top: 10px; height: 2px; }
.faq__icon::after { top: 0; bottom: 0; left: 10px; width: 2px; }
.faq__item.is-open .faq__icon::after { transform: scaleY(0); }
.faq__a { max-height: 0; overflow: hidden; transition: max-height var(--motion-slow); }
.faq__a-inner { padding: 0 var(--p-space-6) var(--p-space-5); color: var(--c-ink-muted); }
.faq__item.is-open .faq__a { max-height: 240px; }

/* ============================================================================
   FOOTER
   ========================================================================== */
.footer { background: var(--c-surface-base); border-top: 1px solid var(--c-border); padding-block: var(--p-space-8) var(--p-space-6); }
.footer__grid { display: grid; gap: var(--p-space-6); grid-template-columns: 1fr; }
.footer__col h5 { font-size: var(--t-micro); text-transform: uppercase; letter-spacing: var(--ls-eyebrow); color: var(--c-metal-deep); margin-bottom: var(--p-space-3); }
.footer__col a { display: block; text-decoration: none; color: var(--c-ink-muted); font-size: var(--t-small); padding: 4px 0; }
.footer__col a:hover { color: var(--c-metal-deep); }
.footer__bottom { display: flex; flex-wrap: wrap; gap: var(--p-space-3); justify-content: space-between; align-items: center; margin-top: var(--p-space-7); padding-top: var(--p-space-5); border-top: 1px solid var(--c-border); font-size: var(--t-micro); color: var(--c-ink-faint); }
@media (min-width: 760px) { .footer__grid { grid-template-columns: 1.6fr 1fr 1fr 1fr; } }

/* ============================================================================
   KIT SHOWCASE scaffolding (index.html)
   ========================================================================== */
.kit-head { padding-block: var(--p-space-8) var(--p-space-6); }
.kit-section { padding-block: var(--p-space-7); border-top: 1px solid var(--c-border); }
.kit-section__label { display: flex; align-items: baseline; gap: var(--p-space-4); flex-wrap: wrap; margin-bottom: var(--p-space-6); }
.kit-section__label .n { font-family: var(--font-lineage); font-style: italic; color: var(--c-metal-deep); font-size: var(--t-lead); }

/* paired light/dark frames */
.pair { display: grid; gap: var(--p-space-5); grid-template-columns: 1fr; }
.frame { border: 1px solid var(--c-border); border-radius: var(--card-radius); overflow: hidden; background: var(--c-bg-page); }
.frame__bar { display: flex; align-items: center; gap: 8px; padding: 8px 14px; font-size: var(--t-micro); text-transform: uppercase; letter-spacing: var(--ls-label); font-weight: 700; color: var(--c-ink-muted); border-bottom: 1px solid var(--c-border); background: var(--c-surface-base); }
.frame__bar .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--c-metal); }
.frame__body { padding: var(--p-space-6); }
@media (min-width: 980px) { .pair { grid-template-columns: 1fr 1fr; } }

/* token board */
.ramp { display: flex; flex-wrap: wrap; gap: var(--p-space-3); }
.swatch { border-radius: var(--p-radius-sm); border: 1px solid var(--c-border); overflow: hidden; width: 116px; }
.swatch__chip { height: 56px; }
.swatch__meta { padding: 6px 8px; font-size: var(--t-micro); background: var(--c-surface-raised); }
.swatch__meta b { display: block; }
.swatch__meta code { color: var(--c-ink-muted); }

.specimen > * { margin: 0 0 4px; }
.scale-row { display: flex; align-items: baseline; gap: var(--p-space-4); border-bottom: 1px dashed var(--c-hairline); padding: 8px 0; }
.scale-row code { font-size: var(--t-micro); color: var(--c-ink-muted); min-width: 72px; }

.token-grid { display: grid; gap: var(--p-space-4); grid-template-columns: repeat(auto-fill, minmax(150px,1fr)); }
.token-cell { border: 1px solid var(--c-border); border-radius: var(--p-radius-sm); padding: var(--p-space-4); background: var(--c-surface-raised); font-size: var(--t-micro); }
.token-cell .box { height: 40px; border-radius: var(--p-radius-sm); margin-bottom: 8px; }

.elev-demo { display: flex; gap: var(--p-space-5); flex-wrap: wrap; }
.elev-demo > div { width: 120px; height: 72px; border-radius: var(--p-radius-md); background: var(--c-surface-overlay); display: grid; place-items: center; font-size: var(--t-micro); color: var(--c-ink-muted); }

.btn-row { display: flex; flex-wrap: wrap; gap: var(--p-space-3); align-items: center; }

/* utility */
.flow > * + * { margin-top: var(--p-space-5); }
.tight > * + * { margin-top: var(--p-space-3); }
.center { text-align: center; }
.grid-2 { display: grid; gap: var(--p-space-6); grid-template-columns: 1fr; }
@media (min-width: 820px) { .grid-2 { grid-template-columns: 1fr 1fr; } }
.maxw { max-width: 46rem; }
.mt-0 { margin-top: 0; }
.skip-link { position: absolute; left: -999px; }
.skip-link:focus { left: var(--gutter); top: 8px; background: var(--c-metal); color: var(--c-ink-on-metal); padding: 8px 14px; border-radius: var(--p-radius-sm); z-index: 100; }
