/* ================================================================
   Ekaterina Farion Foundation — style.css
   Constitutional palette, editorial typography, quiet motion,
   phinsys-inspired split-panel engagement, full accessibility.
   ================================================================ */

:root {
  /* Palette */
  --color-bg:        #f6f1e7;
  --color-bg-soft:   #efe7d6;
  --color-surface:   #fbf7ee;
  --color-ink:       #0f1a2e;
  --color-ink-2:     #24314a;
  --color-muted:     #5b6272;
  --color-rule:      rgba(15, 26, 46, 0.12);
  --color-rule-2:    rgba(15, 26, 46, 0.22);
  --color-accent:    #b8862c;
  --color-accent-2:  #8e6620;
  --color-dark-bg:   #0f1a2e;
  --color-dark-fg:   #ece4d1;
  --color-focus:     #b8862c;
  --color-danger:    #a53a2a;
  --color-success:   #2c6a4a;

  /* Type */
  --font-serif: "Newsreader", "Iowan Old Style", "Palatino Linotype", Palatino, "Book Antiqua", Georgia, serif;
  --font-sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-mono:  "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;

  /* Base font size — user-adjustable via a11y toolbar */
  --font-scale: 1;

  /* Fluid type scale (all multiplied by --font-scale) */
  --text-xs:    calc(clamp(0.72rem, 0.68rem + 0.15vw, 0.78rem) * var(--font-scale));
  --text-sm:    calc(clamp(0.86rem, 0.82rem + 0.2vw, 0.94rem) * var(--font-scale));
  --text-base:  calc(clamp(1rem, 0.96rem + 0.25vw, 1.08rem) * var(--font-scale));
  --text-lg:    calc(clamp(1.14rem, 1.06rem + 0.4vw, 1.28rem) * var(--font-scale));
  --text-xl:    calc(clamp(1.4rem, 1.24rem + 0.7vw, 1.7rem) * var(--font-scale));
  --text-2xl:   calc(clamp(1.75rem, 1.5rem + 1.2vw, 2.35rem) * var(--font-scale));
  --text-3xl:   calc(clamp(2.25rem, 1.85rem + 2vw, 3.3rem) * var(--font-scale));
  --text-hero:  calc(clamp(2.7rem, 2rem + 3.6vw, 4.6rem) * var(--font-scale));

  /* Spacing (4px base) */
  --space-1: 0.25rem;  --space-2: 0.5rem;  --space-3: 0.75rem;
  --space-4: 1rem;     --space-6: 1.5rem;  --space-8: 2rem;
  --space-10: 2.5rem;  --space-12: 3rem;   --space-16: 4rem;
  --space-20: 5rem;    --space-24: 6rem;   --space-32: 8rem;

  --radius-sm: 4px;
  --radius: 6px;
  --shadow-sm: 0 1px 2px rgba(15, 26, 46, 0.06);
  --shadow-md: 0 6px 24px -8px rgba(15, 26, 46, 0.18);
  --shadow-lg: 0 20px 40px -20px rgba(15, 26, 46, 0.35);

  --header-h: 76px;
  --container-w: 1200px;
  --prose-w: 66ch;
  --rail-w: 200px;

  /* v0.3 — intro sequence */
  --intro-duration: 3800ms;
  --intro-ease: cubic-bezier(0.16, 1, 0.3, 1);
}

/* Font-size preference classes set by the a11y toolbar */
html.text-small   { --font-scale: 0.92; }
html.text-default { --font-scale: 1; }
html.text-large   { --font-scale: 1.15; }
html.text-xlarge  { --font-scale: 1.3; }

body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--color-ink);
  background: var(--color-bg);
  font-weight: 400;
  letter-spacing: -0.005em;
  background-image:
    radial-gradient(1200px 600px at 10% -10%, rgba(184, 134, 44, 0.06), transparent 60%),
    radial-gradient(900px 500px at 100% 0%, rgba(15, 26, 46, 0.05), transparent 60%),
    linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-soft) 100%);
  background-attachment: fixed;
}

/* ================================================================
   Utilities
   ================================================================ */
.container {
  width: 100%;
  max-width: var(--container-w);
  margin-inline: auto;
  padding-inline: clamp(1.25rem, 4vw, 2.5rem);
}
.container.narrow { max-width: 780px; }

.mono {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Skip links — visible on focus, off-screen otherwise */
.skip-link {
  position: fixed;
  top: 0; left: 0;
  transform: translateY(-120%);
  background: var(--color-ink);
  color: var(--color-bg);
  padding: 0.7rem 1.25rem;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  z-index: 300;
  transition: transform 0.2s ease;
  border-bottom-right-radius: var(--radius);
}
.skip-link:focus { transform: translateY(0); outline: 2px solid var(--color-accent); outline-offset: 3px; }
.skip-link.skip-link-2 { left: 200px; border-bottom-left-radius: var(--radius); }

/* ================================================================
   Scroll progress bar (top of viewport)
   ================================================================ */
.scroll-progress {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: transparent;
  z-index: 250;
  pointer-events: none;
}
.scroll-progress-bar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--color-accent-2), var(--color-accent));
  transition: width 0.1s linear;
}

/* ================================================================
   Header
   ================================================================ */
.site-header {
  position: sticky;
  top: 0; z-index: 100;
  background: rgba(246, 241, 231, 0.82);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color 0.25s ease, background 0.25s ease;
}
.site-header.is-scrolled {
  border-bottom-color: var(--color-rule);
  background: rgba(246, 241, 231, 0.94);
}
.header-inner {
  display: flex; align-items: center; gap: var(--space-6);
  min-height: var(--header-h);
}
.brand { display: inline-flex; align-items: center; gap: 0.75rem; color: var(--color-ink); }
.brand-mark { color: var(--color-ink); flex: none; }
.brand-text { display: flex; flex-direction: column; line-height: 1.1; }
.brand-name {
  font-family: var(--font-serif); font-weight: 500;
  font-size: 1.05rem; letter-spacing: -0.01em;
}
.brand-sub {
  font-family: var(--font-mono);
  font-size: 0.66rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--color-muted);
  margin-top: 2px;
}

.primary-nav { margin-left: auto; }
.primary-nav ul {
  display: flex; align-items: center;
  gap: clamp(1rem, 2vw, 1.75rem);
}
.primary-nav a {
  font-size: 0.9rem; font-weight: 500;
  color: var(--color-ink-2);
  padding: 0.5rem 0;
  position: relative;
  transition: color 0.2s ease;
}
.primary-nav a::after {
  content: ""; position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 1px; background: var(--color-accent);
  transform: scaleX(0); transform-origin: left center;
  transition: transform 0.25s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.primary-nav a:hover, .primary-nav a.is-active,
.primary-nav a[aria-current="location"] { color: var(--color-ink); }
.primary-nav a:hover::after, .primary-nav a.is-active::after,
.primary-nav a[aria-current="location"]::after { transform: scaleX(1); }
.primary-nav a.nav-cta {
  color: var(--color-ink);
  border: 1px solid var(--color-rule-2);
  padding: 0.5rem 0.95rem;
  border-radius: var(--radius);
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.primary-nav a.nav-cta::after { display: none; }
.primary-nav a.nav-cta:hover,
.primary-nav a.nav-cta:focus-visible {
  background: var(--color-ink); color: var(--color-bg);
  border-color: var(--color-ink);
}

/* Mobile nav toggle */
.nav-toggle {
  display: none; margin-left: auto;
  width: 44px; height: 44px;
  align-items: center; justify-content: center;
  flex-direction: column; gap: 5px;
  border-radius: var(--radius);
}
.nav-toggle-bar {
  display: block; width: 22px; height: 1.5px;
  background: var(--color-ink);
  transition: transform 0.25s ease, opacity 0.25s ease;
}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

@media (max-width: 900px) {
  .nav-toggle { display: inline-flex; }
  .primary-nav {
    position: fixed;
    top: var(--header-h); right: 0; left: 0;
    width: 100vw;
    height: calc(100vh - var(--header-h));
    height: calc(100dvh - var(--header-h));
    z-index: 90;
    margin-left: 0;
    background: var(--color-bg);
    background-image: linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-soft) 100%);
    padding: var(--space-8) clamp(1.25rem, 5vw, 2.5rem);
    transform: translateY(-8px);
    opacity: 0; visibility: hidden; pointer-events: none;
    transition: opacity 0.25s ease, transform 0.25s ease, visibility 0s linear 0.25s;
    border-top: 1px solid var(--color-rule);
    overflow-y: auto;
  }
  .primary-nav.is-open {
    opacity: 1; transform: translateY(0);
    visibility: visible; pointer-events: auto;
    transition: opacity 0.25s ease, transform 0.25s ease, visibility 0s linear 0s;
  }
  .primary-nav ul { flex-direction: column; align-items: flex-start; gap: var(--space-6); margin: 0; }
  .primary-nav li { width: 100%; }
  .primary-nav a {
    display: block; width: 100%;
    font-family: var(--font-serif);
    font-size: 1.75rem; font-weight: 500;
    letter-spacing: -0.01em;
    padding: 0.25rem 0;
    min-height: 44px; /* larger touch target */
  }
  .primary-nav a.nav-cta {
    display: inline-block; width: auto;
    padding: 0.85rem 1.5rem; margin-top: var(--space-4);
    font-size: 0.95rem;
    font-family: var(--font-sans); font-weight: 500;
  }
}

/* ================================================================
   Chapter rail (desktop sticky navigation — phinsys-inspired)
   ================================================================ */
.chapter-nav {
  position: fixed;
  left: max(1.25rem, calc((100vw - var(--container-w)) / 2 - var(--rail-w) - 1rem));
  top: 50%;
  transform: translateY(-50%);
  z-index: 40;
  width: var(--rail-w);
  padding: var(--space-4) 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
}
.chapter-nav.is-ready { opacity: 1; pointer-events: auto; }

.chapter-nav-title {
  color: var(--color-muted);
  margin-bottom: var(--space-4);
  padding-left: 1.5rem;
}
.chapter-nav ol {
  display: flex;
  flex-direction: column;
  gap: 2px;
  border-left: 1px solid var(--color-rule);
}
.chapter-nav a {
  display: flex; align-items: baseline; gap: 0.6rem;
  padding: 0.4rem 0 0.4rem 1.5rem;
  font-size: 0.78rem;
  font-family: var(--font-sans);
  color: var(--color-muted);
  position: relative;
  transition: color 0.2s ease, padding-left 0.25s ease;
  min-height: 32px;
}
.chapter-nav a::before {
  content: "";
  position: absolute;
  left: -1px; top: 50%;
  transform: translateY(-50%);
  width: 2px; height: 12px;
  background: transparent;
  transition: background 0.2s ease, height 0.25s ease;
}
.chapter-nav a:hover {
  color: var(--color-ink-2);
  padding-left: 1.75rem;
}
.chapter-nav a.is-active,
.chapter-nav a[aria-current="location"] {
  color: var(--color-ink);
  padding-left: 1.75rem;
}
.chapter-nav a.is-active::before,
.chapter-nav a[aria-current="location"]::before {
  background: var(--color-accent);
  height: 20px;
}
.cn-num {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  color: var(--color-accent-2);
  min-width: 2ch;
}
.cn-label {
  font-weight: 500;
  letter-spacing: 0.01em;
}

/* Hide the chapter rail on viewports too narrow to keep it clear of the container.
   Rail (200px) + 16px gutter must sit outside the 1200px container.
   Threshold: container (1200) + 2 * (rail 200 + gutter 16 + margin 20) ≈ 1672px.
   Below that, the rail's left position clamps to 1.25rem and overlaps content.
   1520px is a pragmatic hide threshold: keeps rail on wide desktops (≥1600),
   hides it on typical laptops (1280–1440) where it would otherwise overlap. */
@media (max-width: 1519px) {
  .chapter-nav { display: none; }
}

/* ================================================================
   Accessibility toolbar (floating button + panel)
   ================================================================ */
.a11y-bar {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: 120;
}
.a11y-toggle {
  width: 48px; height: 48px;
  border-radius: 999px;
  background: var(--color-ink);
  color: var(--color-bg);
  box-shadow: var(--shadow-md);
  display: inline-flex; align-items: center; justify-content: center;
  transition: transform 0.2s ease, background 0.2s ease;
}
.a11y-toggle:hover { transform: translateY(-1px); background: var(--color-ink-2); }
.a11y-toggle[aria-expanded="true"] { background: var(--color-accent-2); }

.a11y-panel {
  position: absolute;
  right: 0; bottom: calc(48px + 0.75rem);
  width: 280px;
  background: var(--color-surface);
  border: 1px solid var(--color-rule-2);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  padding: var(--space-6);
  display: grid;
  gap: var(--space-4);
}
.a11y-panel[hidden] { display: none; }
.a11y-panel-title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 1.05rem;
  color: var(--color-ink);
  margin-bottom: -0.25rem;
}
.a11y-group legend {
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 0.5rem;
}
.a11y-radio-row {
  display: flex; gap: 0.4rem; flex-wrap: wrap;
}
.a11y-chip {
  min-width: 40px;
  height: 40px;
  padding: 0 0.85rem;
  border: 1px solid var(--color-rule-2);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  color: var(--color-ink);
  font-family: var(--font-serif);
  font-size: 1rem;
  font-weight: 500;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.a11y-chip[data-text-size] { font-family: var(--font-serif); }
.a11y-chip.a11y-chip-lg { font-size: 1.15rem; }
.a11y-chip.a11y-chip-xl { font-size: 1.3rem; }
.a11y-chip[data-contrast], .a11y-chip[data-motion] {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  padding: 0 0.85rem;
}
.a11y-chip:hover { border-color: var(--color-ink); }
.a11y-chip.is-active,
.a11y-chip[aria-pressed="true"] {
  background: var(--color-ink);
  color: var(--color-bg);
  border-color: var(--color-ink);
}
.a11y-reset {
  margin-top: 0.25rem;
  padding: 0.5rem 0.75rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-muted);
  border-top: 1px solid var(--color-rule);
  padding-top: var(--space-4);
  text-align: left;
}
.a11y-reset:hover { color: var(--color-ink); }

@media (max-width: 500px) {
  .a11y-panel { width: calc(100vw - 2rem); right: 0; }
}

/* ================================================================
   Buttons — with animated arrow on hover
   ================================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 0.55rem;
  padding: 0.85rem 1.5rem;
  min-height: 44px;
  font-family: var(--font-sans);
  font-size: 0.92rem; font-weight: 500;
  letter-spacing: 0.01em;
  border-radius: var(--radius);
  border: 1px solid transparent;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
  cursor: pointer;
}
.btn svg { transition: transform 0.25s cubic-bezier(0.2, 0.7, 0.2, 1); }
.btn:hover svg { transform: translateX(3px); }
.btn-primary { background: var(--color-ink); color: var(--color-bg); border-color: var(--color-ink); }
.btn-primary:hover,
.btn-primary:focus-visible { background: var(--color-ink-2); border-color: var(--color-ink-2); }
.btn-ghost { background: transparent; color: var(--color-ink); border-color: var(--color-rule-2); }
.btn-ghost:hover,
.btn-ghost:focus-visible { background: var(--color-ink); color: var(--color-bg); border-color: var(--color-ink); }
.btn-block { width: 100%; }

/* ================================================================
   Hero
   ================================================================ */
.hero {
  position: relative;
  padding: clamp(4rem, 10vw, 8rem) 0 clamp(4rem, 8vw, 6rem);
  overflow: hidden;
}
.hero-glow {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 900px 500px at 15% 30%, rgba(184, 134, 44, 0.15), transparent 65%),
    radial-gradient(ellipse 700px 400px at 85% 80%, rgba(15, 26, 46, 0.08), transparent 65%);
  pointer-events: none;
  z-index: 0;
}
.hero-pattern {
  position: absolute;
  right: -8%; top: 10%;
  width: 55%;
  max-width: 720px;
  color: var(--color-accent);
  opacity: 0.35;
  pointer-events: none;
  z-index: 0;
}
.hero-pattern svg { width: 100%; height: auto; }

.hero-inner { position: relative; z-index: 1; max-width: 1000px; }

.eyebrow {
  display: inline-flex; align-items: center; gap: 0.75rem;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--color-accent-2);
  margin-bottom: var(--space-6);
}
.eyebrow-rule {
  width: 40px; height: 1px;
  background: var(--color-accent);
}

.hero-headline {
  font-family: var(--font-serif); font-weight: 400;
  font-size: var(--text-hero); line-height: 1.02;
  letter-spacing: -0.02em; color: var(--color-ink);
  max-width: 20ch; margin-bottom: var(--space-8);
}
.hero-headline em { font-style: italic; font-weight: 300; color: var(--color-accent-2); }
/* Programmatic focus after intro (tabindex=-1) should not show a visible outline;
   :focus-visible keeps keyboard focus indication intact. */
.hero-headline:focus { outline: none; }
.hero-headline:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 6px;
  border-radius: 2px;
}
.hero-lede {
  font-family: var(--font-serif); font-weight: 300;
  font-size: clamp(1.15rem, 0.98rem + 0.6vw, 1.4rem);
  line-height: 1.55; color: var(--color-ink-2);
  max-width: 60ch; margin-bottom: var(--space-10);
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-bottom: var(--space-16); }
.hero-meta { display: flex; align-items: center; gap: 1rem; color: var(--color-muted); }
.hero-meta .rule { flex: 1; height: 1px; background: var(--color-rule); max-width: 320px; }

/* Scroll hint chevron (phinsys homage) */
.scroll-hint {
  position: absolute;
  left: 50%; bottom: 1.5rem;
  transform: translateX(-50%);
  display: inline-flex; flex-direction: column; align-items: center;
  gap: 0.5rem;
  color: var(--color-muted);
  font-size: 0.7rem;
  padding: 0.5rem 0.75rem;
  z-index: 2;
}
.scroll-hint-label { color: var(--color-muted); }
.scroll-hint-arrow {
  display: inline-block;
  animation: scroll-bounce 2.4s ease-in-out infinite;
}
@keyframes scroll-bounce {
  0%, 100% { transform: translateY(0); opacity: 0.6; }
  50% { transform: translateY(6px); opacity: 1; }
}
.scroll-hint:hover, .scroll-hint:focus-visible { color: var(--color-ink); }
@media (max-width: 700px) { .scroll-hint { display: none; } }

/* ================================================================
   Sections
   ================================================================ */
.section {
  padding: clamp(4rem, 9vw, 7rem) 0;
  position: relative;
}
.section + .section { border-top: 1px solid var(--color-rule); }

/* Section rule title (phinsys ————— TITLE ————— treatment) */
.section-rule {
  display: flex; align-items: center; justify-content: center;
  gap: 1rem;
  color: var(--color-accent-2);
  margin-bottom: var(--space-10);
  text-align: center;
}
.section-rule > span:not(.section-rule-line) {
  white-space: nowrap;
  padding: 0 0.25rem;
}
.section-rule-line {
  flex: 1;
  height: 1px;
  max-width: 140px;
  background: var(--color-rule-2);
}
.section-rule.light { color: rgba(236, 228, 209, 0.72); }
.section-rule.light .section-rule-line { background: rgba(236, 228, 209, 0.28); }

.section-heading {
  font-family: var(--font-serif); font-weight: 400;
  font-size: var(--text-3xl); line-height: 1.1;
  letter-spacing: -0.02em; color: var(--color-ink);
  max-width: 22ch; margin-bottom: var(--space-6);
}
.section-heading.centered { margin-inline: auto; text-align: center; }
.section-heading.display {
  font-size: clamp(2.5rem, 2rem + 2.5vw, 4rem);
  font-style: italic; font-weight: 300;
  max-width: none;
}

.two-col {
  display: grid;
  grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
}
@media (max-width: 800px) {
  .two-col { grid-template-columns: 1fr; gap: var(--space-8); }
}
.col-heading .section-heading { margin-bottom: var(--space-6); }
.centered-heading { text-align: center; max-width: 900px; margin: 0 auto var(--space-16); }

.prose {
  font-size: var(--text-lg); line-height: 1.65;
  color: var(--color-ink-2);
  max-width: var(--prose-w);
}
.prose.centered { margin-inline: auto; text-align: center; }
.prose.wide { max-width: 62ch; }
.prose.muted { color: var(--color-muted); margin-top: var(--space-4); font-size: var(--text-base); }
.prose.light { color: rgba(236, 228, 209, 0.85); }

.lead {
  font-family: var(--font-serif); font-style: italic; font-weight: 400;
  font-size: var(--text-lg); color: var(--color-ink-2);
}

/* ================================================================
   Statements accordion (Why section)
   ================================================================ */
.statements {
  border-top: 1px solid var(--color-rule);
}
.stmt {
  border-bottom: 1px solid var(--color-rule);
}
.stmt-trigger {
  display: grid;
  grid-template-columns: 3.5rem 1fr 2rem;
  gap: 1rem;
  width: 100%;
  padding: var(--space-4) 0;
  align-items: center;
  text-align: left;
  color: var(--color-ink);
  font-family: var(--font-serif);
  font-size: clamp(1.15rem, 1rem + 0.4vw, 1.4rem);
  font-weight: 400;
  min-height: 60px;
  transition: color 0.2s ease;
}
.stmt-trigger:hover { color: var(--color-accent-2); }
.stmt-num {
  color: var(--color-accent-2);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  align-self: center;
}
.stmt-text { line-height: 1.3; }
.stmt-icon {
  width: 20px; height: 20px;
  position: relative;
  justify-self: end;
}
.stmt-icon::before,
.stmt-icon::after {
  content: "";
  position: absolute;
  background: var(--color-ink-2);
  transition: transform 0.3s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.stmt-icon::before { /* horizontal */
  left: 2px; right: 2px; top: 50%;
  height: 1.5px; margin-top: -0.75px;
}
.stmt-icon::after { /* vertical */
  top: 2px; bottom: 2px; left: 50%;
  width: 1.5px; margin-left: -0.75px;
}
.stmt-trigger[aria-expanded="true"] .stmt-icon::after {
  transform: rotate(90deg);
}
.stmt-trigger[aria-expanded="true"] { color: var(--color-accent-2); }

.stmt-panel {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.35s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.stmt-panel[hidden] { display: block; max-height: 0; }
.stmt-panel.is-open {
  max-height: 240px;
}
.stmt-panel p {
  padding: 0 0 var(--space-6) 4.5rem;
  color: var(--color-ink-2);
  font-size: var(--text-base);
  line-height: 1.6;
  max-width: 60ch;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 300;
}
@media (max-width: 600px) {
  .stmt-trigger { grid-template-columns: 2.5rem 1fr 1.75rem; }
  .stmt-panel p { padding-left: 3.5rem; }
}

.statement-hint {
  margin-top: var(--space-6);
  display: inline-flex; align-items: center; gap: 0.75rem;
  color: var(--color-muted);
  font-family: var(--font-serif); font-style: italic;
  font-size: 0.95rem;
}
.statement-hint .mono {
  color: var(--color-accent-2);
  padding: 2px 8px;
  border: 1px solid var(--color-rule-2);
  border-radius: 999px;
  font-style: normal;
}

/* ================================================================
   Inheritance
   ================================================================ */
.section-inheritance {
  text-align: center;
  background: radial-gradient(600px 300px at 50% 0%, rgba(184, 134, 44, 0.08), transparent 70%);
}
.pullquote {
  font-family: var(--font-serif); font-style: italic; font-weight: 300;
  font-size: clamp(1.5rem, 1.2rem + 1.4vw, 2.1rem);
  line-height: 1.4; color: var(--color-ink);
  max-width: 28ch;
  margin: var(--space-10) auto 0;
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-rule);
  position: relative;
}
.pullquote::before {
  content: ""; position: absolute;
  top: -1px; left: 50%; transform: translateX(-50%);
  width: 40px; height: 1px; background: var(--color-accent);
}

/* ================================================================
   Progress (dark band)
   ================================================================ */
.section-progress {
  background: var(--color-dark-bg); color: var(--color-dark-fg);
  padding-block: clamp(5rem, 11vw, 9rem);
  position: relative; overflow: hidden;
  border-top: 0;
}
.section + .section-progress { border-top: 0; }
.progress-glow {
  position: absolute; inset: 0;
  background:
    radial-gradient(700px 400px at 50% 100%, rgba(184, 134, 44, 0.15), transparent 60%),
    radial-gradient(500px 300px at 20% 0%, rgba(255,255,255,0.04), transparent 70%);
  pointer-events: none;
}
.section-progress > * { position: relative; }
.section-progress .section-heading {
  color: var(--color-dark-fg);
  text-align: center; margin-inline: auto;
  margin-bottom: var(--space-8);
}

/* ================================================================
   Standard cards
   ================================================================ */
.standard-cards {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
@media (max-width: 800px) { .standard-cards { grid-template-columns: 1fr; } }
.std-card {
  background: var(--color-surface);
  border: 1px solid var(--color-rule);
  padding: var(--space-8);
  border-radius: var(--radius);
  transition: transform 0.3s cubic-bezier(0.2, 0.7, 0.2, 1), box-shadow 0.3s ease, border-color 0.3s ease;
  cursor: default;
  position: relative;
}
.std-card::after {
  content: "";
  position: absolute; left: 0; top: 0;
  width: 3px; height: 100%;
  background: var(--color-accent);
  transform: scaleY(0);
  transform-origin: top center;
  transition: transform 0.35s cubic-bezier(0.2, 0.7, 0.2, 1);
  border-radius: var(--radius) 0 0 var(--radius);
}
.std-card:hover,
.std-card:focus-visible {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-rule-2);
  outline: none;
}
.std-card:hover::after,
.std-card:focus-visible::after { transform: scaleY(1); }
.std-num { color: var(--color-accent-2); margin-bottom: var(--space-6); }
.std-title {
  font-family: var(--font-serif); font-weight: 400; font-style: italic;
  font-size: var(--text-xl); color: var(--color-ink);
  margin-bottom: var(--space-3);
}
.std-body { color: var(--color-ink-2); font-size: var(--text-base); line-height: 1.55; }

/* ================================================================
   Closing
   ================================================================ */
.section-closing {
  text-align: center;
  background: radial-gradient(500px 250px at 50% 100%, rgba(184, 134, 44, 0.08), transparent 70%);
}
.closing-actions {
  margin-top: var(--space-10);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}

/* ================================================================
   Contact
   ================================================================ */
.section-contact { background: var(--color-bg-soft); }
.contact-direct {
  margin-top: var(--space-8);
  display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap;
  font-family: var(--font-serif); font-size: var(--text-lg);
}
.contact-label { color: var(--color-muted); }
.contact-direct a {
  color: var(--color-ink);
  border-bottom: 1px solid var(--color-accent);
  transition: color 0.2s ease, border-color 0.2s ease;
  padding-bottom: 2px;
}
.contact-direct a:hover,
.contact-direct a:focus-visible { color: var(--color-accent-2); border-bottom-color: var(--color-accent-2); }

.contact-form {
  background: var(--color-surface);
  padding: clamp(1.5rem, 3vw, 2.5rem);
  border: 1px solid var(--color-rule);
  border-radius: var(--radius);
  display: grid; gap: var(--space-4);
}
.field { display: grid; gap: 0.4rem; }
.field label {
  font-family: var(--font-mono);
  font-size: 0.7rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--color-muted);
}
.field .req { color: var(--color-accent-2); margin-left: 0.15em; }
.field input, .field textarea {
  width: 100%;
  padding: 0.85rem 1rem;
  background: var(--color-bg);
  border: 1px solid var(--color-rule-2);
  border-radius: var(--radius-sm);
  color: var(--color-ink);
  font-size: 1rem;
  min-height: 44px;
  transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}
.field textarea { resize: vertical; min-height: 120px; line-height: 1.55; }
.field input:focus, .field textarea:focus {
  outline: none;
  border-color: var(--color-ink);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(184, 134, 44, 0.18);
}
.field.has-error input, .field.has-error textarea {
  border-color: var(--color-danger); background: #fbf1ee;
}
.field-error {
  font-family: var(--font-mono);
  font-size: 0.72rem; letter-spacing: 0.05em;
  color: var(--color-danger);
}
.field-help {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 0.85rem;
  color: var(--color-muted);
  margin-top: 0.2rem;
}
.field-help-count {
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  text-align: right;
  margin-top: 0.35rem;
  font-variant-numeric: tabular-nums;
}
.form-status { font-family: var(--font-mono); font-size: 0.78rem; min-height: 1.2em; }
.form-status.is-success { color: var(--color-success); }
.form-status.is-error { color: var(--color-danger); }
.form-status.is-info { color: var(--color-ink-muted, var(--color-ink)); }

/* Statement accordion — open state on wrapper (for icon rotation) */
.stmt.is-open .stmt-icon { transform: rotate(45deg); }
.stmt-trigger.is-open .stmt-icon { transform: rotate(45deg); }

/* Lock body scroll when mobile nav is open */
html.nav-open, body.nav-open { overflow: hidden; }
@media (min-width: 900px) {
  html.nav-open, body.nav-open { overflow: auto; }
}
.form-note {
  color: var(--color-muted);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 0.92rem;
  line-height: 1.5;
  margin-top: var(--space-3);
  max-width: 46ch;
}

/* ================================================================
   Footer
   ================================================================ */
.site-footer {
  background: var(--color-ink); color: var(--color-dark-fg);
  padding: var(--space-16) 0 var(--space-10);
}
.footer-inner {
  display: grid; grid-template-columns: 2fr 1fr;
  gap: var(--space-8); align-items: end;
}
@media (max-width: 700px) { .footer-inner { grid-template-columns: 1fr; } }
.footer-name {
  font-family: var(--font-serif);
  font-size: var(--text-xl); font-weight: 400;
  color: #fff; margin-bottom: var(--space-2);
}
.footer-tag { color: rgba(236, 228, 209, 0.72); max-width: 44ch; font-size: var(--text-base); }
.footer-meta { color: rgba(236, 228, 209, 0.55); }
.footer-meta p + p { margin-top: 0.35rem; }
.footer-copy { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.06em; }

/* ================================================================
   Motion: gentle staggered fade-in
   ================================================================ */
.js-motion .reveal {
  opacity: 0;
  transform: translateY(12px);
  transition:
    opacity 0.7s cubic-bezier(0.2, 0.7, 0.2, 1),
    transform 0.7s cubic-bezier(0.2, 0.7, 0.2, 1);
  will-change: opacity, transform;
}
.js-motion .reveal.is-visible {
  opacity: 1;
  transform: none;
}

/* Stagger children reveal */
.js-motion .stagger > *:nth-child(1) { transition-delay: 0.05s; }
.js-motion .stagger > *:nth-child(2) { transition-delay: 0.12s; }
.js-motion .stagger > *:nth-child(3) { transition-delay: 0.19s; }
.js-motion .stagger > *:nth-child(4) { transition-delay: 0.26s; }
.js-motion .stagger > *:nth-child(5) { transition-delay: 0.33s; }
.js-motion .stagger > *:nth-child(6) { transition-delay: 0.4s; }
.js-motion .stagger > *:nth-child(7) { transition-delay: 0.47s; }
.js-motion .stagger > *:nth-child(8) { transition-delay: 0.54s; }

@media (prefers-reduced-motion: reduce) {
  .js-motion .reveal { opacity: 1; transform: none; transition: none; }
  .scroll-hint-arrow { animation: none; }
}
html.motion-reduced .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
html.motion-reduced .scroll-hint-arrow { animation: none !important; }

/* ================================================================
   v0.3 — Intro sequence
   Full-viewport ceremonial numeral animation. Plays once per load.
   ================================================================ */
html.eff-intro-active { overflow: hidden; }

.eff-intro {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: grid;
  place-items: center;
  background: var(--color-bg);
  background-image:
    radial-gradient(1000px 700px at 50% 40%, rgba(184, 134, 44, 0.07), transparent 65%),
    linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-soft) 100%);
  opacity: 0;
  transition: opacity 520ms ease;
}
.eff-intro.is-visible { opacity: 1; }
.eff-intro.is-leaving { opacity: 0; transition: opacity 420ms ease; }
.eff-intro[hidden] { display: none !important; }

.eff-intro-stage {
  position: relative;
  width: min(76vw, 660px);
  height: min(76vw, 660px);
  max-height: 80vh;
}

.eff-intro-ring {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  color: var(--color-accent);
  opacity: 0;
  transition: opacity 900ms ease;
}
.eff-intro-ring circle {
  stroke-dasharray: 289;      /* ~2*pi*46 */
  stroke-dashoffset: 289;
  transition: stroke-dashoffset 1400ms var(--intro-ease);
}
.eff-intro-ring.is-drawn { opacity: 0.4; }
.eff-intro-ring.is-drawn circle { stroke-dashoffset: 0; }
.eff-intro-stage.is-breathing .eff-intro-ring { opacity: 0.4; }
.eff-intro-stage.is-breathing .eff-intro-ring circle { stroke-dashoffset: 0; }

.eff-intro-numeral {
  position: absolute;
  top: 50%;
  left: 50%;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.5rem, 3.6vw, 2.6rem);
  color: rgba(15, 26, 46, 0.88);
  line-height: 1;
  /* Enter from a random offscreen offset, faded out. */
  transform: translate(calc(-50% + var(--sx, 0)), calc(-50% + var(--sy, 0))) scale(0.6);
  opacity: 0;
  transition:
    transform 1200ms var(--intro-ease),
    opacity 900ms ease;
  transition-delay: var(--delay, 0ms);
  will-change: transform, opacity;
}
/* Settle onto the ring at the target angle/radius.
   Phase classes live on the parent .eff-intro-stage. */
.eff-intro-stage.is-settling .eff-intro-numeral {
  --radius: min(34vw, 290px);
  transform:
    translate(
      calc(-50% + var(--tx, 0) * var(--radius)),
      calc(-50% + var(--ty, 0) * var(--radius))
    )
    scale(1);
  opacity: 0.92;
}
/* Gentle breathe once settled. */
.eff-intro-stage.is-breathing .eff-intro-numeral {
  transition:
    transform 1400ms ease-in-out,
    opacity 1400ms ease-in-out;
  transition-delay: 0ms;
  --radius: min(34vw, 290px);
  transform:
    translate(
      calc(-50% + var(--tx, 0) * var(--radius)),
      calc(-50% + var(--ty, 0) * var(--radius))
    )
    scale(1.04);
  opacity: 1;
}
/* Dissolve outward. */
.eff-intro-stage.is-dissolving .eff-intro-numeral {
  transition:
    transform 1000ms var(--intro-ease),
    opacity 900ms ease;
  transition-delay: calc(var(--i, 1) * 30ms);
  --radius: min(52vw, 460px);
  transform:
    translate(
      calc(-50% + var(--tx, 0) * var(--radius)),
      calc(-50% + var(--ty, 0) * var(--radius))
    )
    scale(0.85);
  opacity: 0;
}

.eff-intro-skip {
  position: fixed;
  right: var(--space-6);
  bottom: var(--space-6);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-muted);
  background: transparent;
  border: 1px solid var(--color-rule-2);
  border-radius: var(--radius-sm);
  padding: 0.5rem 0.85rem;
  cursor: pointer;
  transition: color 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}
.eff-intro-skip:hover,
.eff-intro-skip:focus-visible {
  color: var(--color-ink);
  border-color: var(--color-ink);
  background: rgba(15, 26, 46, 0.04);
}

/* ================================================================
   v0.3 — Atmosphere layer
   Fixed background wash that gently shifts hue per active section.
   ================================================================ */
#atmosLayer {
  position: fixed;
  inset: 0;
  z-index: -1;
  background-color: var(--color-bg);
  transition: background-color 1200ms ease-out;
  pointer-events: none;
}

/* ================================================================
   v0.3 — Statement spotlight (single-open accordion)
   ================================================================ */
.statements.is-spotlighting .stmt:not(.is-open) {
  opacity: 0.36;
  filter: saturate(0.5);
  transition: opacity 320ms ease, filter 320ms ease;
}
.statements.is-spotlighting .stmt:not(.is-open):hover {
  opacity: 0.72;
}
.stmt.is-open {
  --stmt-num-scale: 1.15;
  background-color: color-mix(in oklab, var(--color-bg), var(--color-accent) 6%);
  border-left: 3px solid var(--color-accent);
  transition: background-color 320ms ease, border-color 320ms ease;
}
.stmt.is-open .stmt-num {
  transform: scale(var(--stmt-num-scale, 1));
  color: var(--color-accent-2);
  transition: transform 320ms var(--intro-ease), color 320ms ease;
}

/* ================================================================
   v0.3 — Glyphs (chapter rail + section rules)
   ================================================================ */
.section-rule-glyph {
  display: inline-block;
  vertical-align: middle;
  color: var(--color-accent-2);
  fill: none;
  stroke: currentColor;
  opacity: 0.85;
  flex-shrink: 0;
}
.section-rule.light .section-rule-glyph { color: rgba(236, 228, 209, 0.7); }

.cn-glyph {
  display: inline-block;
  vertical-align: middle;
  margin-right: 0.4em;
  color: var(--color-accent-2);
  fill: none;
  stroke: currentColor;
  flex-shrink: 0;
  opacity: 0.55;
  transition: opacity 0.25s ease, color 0.25s ease;
}
#chapter-nav a.is-active .cn-glyph,
#chapter-nav a:hover .cn-glyph,
#chapter-nav a:focus-visible .cn-glyph {
  opacity: 1;
  color: var(--color-accent);
}

/* Flip rail colors when overlaying dark section band (Progress) */
.chapter-nav.is-on-dark { color: var(--color-dark-fg); }
.chapter-nav.is-on-dark .chapter-nav-title { color: rgba(236, 228, 209, 0.55); }
.chapter-nav.is-on-dark a { color: rgba(236, 228, 209, 0.7); }
.chapter-nav.is-on-dark a:hover,
.chapter-nav.is-on-dark a.is-active,
.chapter-nav.is-on-dark a[aria-current="location"] { color: var(--color-dark-fg); }
.chapter-nav.is-on-dark .cn-num { color: rgba(236, 228, 209, 0.55); }
.chapter-nav.is-on-dark a.is-active .cn-num { color: var(--color-accent); }

/* ================================================================
   v0.3 — Reflection invitation panel (inside #why)
   ================================================================ */
.reflect-panel {
  margin-top: var(--space-10);
  padding: var(--space-8);
  background: var(--color-surface);
  border: 1px solid var(--color-rule);
  border-left: 3px solid var(--color-accent);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.reflect-heading {
  font-family: var(--font-serif);
  font-size: var(--text-xl);
  font-weight: 400;
  color: var(--color-ink);
  margin-bottom: var(--space-2);
}
.reflect-lede {
  color: var(--color-muted);
  font-size: var(--text-base);
  margin-bottom: var(--space-6);
  max-width: 52ch;
}
.reflect-start { display: inline-flex; }

/* ================================================================
   v0.3 — Reflection modal
   ================================================================ */
html.reflect-open { overflow: hidden; }

.reflect-modal {
  position: fixed;
  inset: 0;
  z-index: 2100;
  display: grid;
  place-items: center;
  padding: var(--space-6);
  opacity: 0;
  pointer-events: none;
  transition: opacity 300ms ease;
}
.reflect-modal[hidden] { display: none !important; }
.reflect-modal.is-visible {
  opacity: 1;
  pointer-events: auto;
}
.reflect-modal-scrim {
  position: absolute;
  inset: 0;
  background: rgba(15, 26, 46, 0.55);
  backdrop-filter: blur(2px);
}
.reflect-modal-inner {
  position: relative;
  width: min(640px, 100%);
  max-height: min(88vh, 760px);
  overflow-y: auto;
  background: var(--color-surface);
  border: 1px solid var(--color-rule-2);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  padding: var(--space-12) var(--space-10) var(--space-10);
  transform: translateY(14px);
  transition: transform 340ms var(--intro-ease);
}
.reflect-modal.is-visible .reflect-modal-inner { transform: none; }

.reflect-close {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  color: var(--color-muted);
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}
.reflect-close:hover,
.reflect-close:focus-visible {
  color: var(--color-ink);
  background: rgba(15, 26, 46, 0.05);
  border-color: var(--color-rule);
}

.reflect-progress {
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-accent-2);
  margin-bottom: var(--space-4);
}
.reflect-statement {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-2xl);
  font-weight: 400;
  line-height: 1.25;
  color: var(--color-ink);
  margin-bottom: var(--space-4);
}
.reflect-prompt {
  display: block;
  font-size: var(--text-base);
  color: var(--color-ink-2);
  margin-bottom: var(--space-3);
}
.reflect-answer {
  width: 100%;
  min-height: 120px;
  resize: vertical;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: 1.55;
  color: var(--color-ink);
  background: var(--color-bg);
  border: 1px solid var(--color-rule-2);
  border-radius: var(--radius-sm);
  padding: 0.75rem 0.85rem;
}
.reflect-answer:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(184, 134, 44, 0.18);
}
.reflect-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-top: var(--space-6);
}
.reflect-actions .reflect-skip { margin-right: auto; }

/* Reflection end card */
.reflect-endcard-title {
  font-family: var(--font-serif);
  font-size: var(--text-2xl);
  font-weight: 400;
  color: var(--color-ink);
  margin-bottom: var(--space-2);
}
.reflect-endcard-meta {
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  color: var(--color-muted);
  margin-bottom: var(--space-6);
}
.reflect-list { margin: 0 0 var(--space-4); }
.reflect-list-term {
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-accent-2);
  margin-top: var(--space-5);
}
.reflect-list-desc {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  line-height: 1.5;
  color: var(--color-ink);
  margin: 0.35rem 0 0;
  padding-left: 0;
}
.reflect-list-desc.is-blank {
  font-style: italic;
  color: var(--color-muted);
}
.reflect-endcard-actions { justify-content: flex-end; }

/* ================================================================
   v0.3 — Pledge section
   ================================================================ */
.section-pledge .pledge-form,
.section-stories .story-form {
  max-width: 560px;
  margin: var(--space-10) auto 0;
  display: grid;
  gap: var(--space-6);
}
.section-pledge .pledge-form[hidden],
.section-stories .story-form[hidden] { display: none !important; }
.field-opt {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: var(--color-muted);
  text-transform: none;
}

/* ================================================================
   v0.3 — Stories: theme chips
   ================================================================ */
.story-theme {
  border: none;
  padding: 0;
  margin: 0;
}
.story-theme legend {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--color-ink-2);
  margin-bottom: var(--space-3);
  padding: 0;
}
.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.chip {
  display: inline-flex;
  align-items: center;
  font-size: 0.86rem;
  color: var(--color-ink-2);
  background: var(--color-bg);
  border: 1px solid var(--color-rule-2);
  border-radius: 999px;
  padding: 0.42rem 0.9rem;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.chip:hover { border-color: var(--color-accent); }
.chip input {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
}
.chip:has(input:checked) {
  background: color-mix(in oklab, var(--color-bg), var(--color-accent) 14%);
  border-color: var(--color-accent);
  color: var(--color-ink);
  font-weight: 500;
}
.chip:has(input:focus-visible) {
  outline: 2px solid var(--color-focus);
  outline-offset: 2px;
}

/* ================================================================
   v0.3 — Ceremony confirmation cards (pledge + story)
   ================================================================ */
.pledge-confirm,
.story-confirm {
  max-width: 560px;
  margin: var(--space-10) auto 0;
}
.ceremony-card {
  text-align: center;
  padding: var(--space-12) var(--space-8);
  background: var(--color-surface);
  border: 1px solid var(--color-rule);
  border-top: 3px solid var(--color-accent);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
}
.ceremony-lead {
  font-family: var(--font-serif);
  font-size: var(--text-xl);
  font-weight: 400;
  color: var(--color-ink);
  margin-bottom: var(--space-3);
}
.ceremony-meta,
.ceremony-ref {
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  color: var(--color-muted);
}
.ceremony-ref {
  color: var(--color-accent-2);
  margin-top: 0.35rem;
}
.ceremony-thanks {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  color: var(--color-ink-2);
  margin-top: var(--space-5);
}
.ceremony-signoff {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--color-muted);
  margin-top: var(--space-2);
}
.pledge-again { margin-top: var(--space-6); }

/* ================================================================
   v0.3 — Weekly reflection poll (inside #learning)
   ================================================================ */
.weekly-poll {
  margin-top: var(--space-10);
  padding: var(--space-8);
  background: var(--color-surface);
  border: 1px solid var(--color-rule);
  border-left: 3px solid var(--color-accent);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.poll-eyebrow {
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-accent-2);
  margin-bottom: var(--space-2);
}
.poll-heading {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  font-weight: 400;
  color: var(--color-ink);
  margin-bottom: var(--space-5);
}
.poll-options {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-2);
}
.poll-option {
  width: 100%;
  text-align: left;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--color-ink-2);
  background: var(--color-bg);
  border: 1px solid var(--color-rule-2);
  border-radius: var(--radius-sm);
  padding: 0.7rem 0.95rem;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.poll-option:hover { border-color: var(--color-accent); }
.poll-option.is-chosen {
  background: color-mix(in oklab, var(--color-bg), var(--color-accent) 12%);
  border-color: var(--color-accent);
  color: var(--color-ink);
  font-weight: 500;
}
.poll-result { margin-top: var(--space-6); }
.poll-tag {
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-accent-2);
  margin-bottom: var(--space-2);
}
.poll-your-answer {
  color: var(--color-ink-2);
  font-size: var(--text-base);
}
.poll-change {
  margin-top: var(--space-3);
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.04em;
  color: var(--color-muted);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--color-rule-2);
  padding: 0 0 0.15rem;
  cursor: pointer;
  transition: color 0.2s ease, border-color 0.2s ease;
}
.poll-change:hover,
.poll-change:focus-visible {
  color: var(--color-ink);
  border-color: var(--color-ink);
}

/* ================================================================
   v0.3 — Closing secondary link
   ================================================================ */
.closing-secondary {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  letter-spacing: 0.005em;
  font-weight: 500;
  color: var(--color-ink-2, var(--color-muted));
  text-decoration: none;
  border-bottom: 1px solid var(--color-rule-2);
  padding-bottom: 3px;
  transition: color 0.2s ease, border-color 0.2s ease;
}
.closing-secondary:hover,
.closing-secondary:focus-visible {
  color: var(--color-accent);
  border-color: var(--color-accent);
}

/* ================================================================
   v0.3 — Reduced-motion overrides for all new animation
   ================================================================ */
@media (prefers-reduced-motion: reduce) {
  .eff-intro,
  .eff-intro.is-leaving { transition: none; }
  .eff-intro-numeral,
  .eff-intro-ring,
  .eff-intro-ring circle { transition: none; }
  #atmosLayer { transition: none; }
  .statements.is-spotlighting .stmt:not(.is-open) { transition: none; }
  .stmt.is-open,
  .stmt.is-open .stmt-num { transition: none; }
  .reflect-modal,
  .reflect-modal-inner { transition: none; }
  .reflect-modal-inner { transform: none; }
}
html.motion-reduced .eff-intro,
html.motion-reduced .eff-intro.is-leaving,
html.motion-reduced .eff-intro-numeral,
html.motion-reduced .eff-intro-ring,
html.motion-reduced .eff-intro-ring circle,
html.motion-reduced #atmosLayer,
html.motion-reduced .statements.is-spotlighting .stmt:not(.is-open),
html.motion-reduced .stmt.is-open,
html.motion-reduced .stmt.is-open .stmt-num,
html.motion-reduced .reflect-modal,
html.motion-reduced .reflect-modal-inner {
  transition: none !important;
}
html.motion-reduced .reflect-modal-inner { transform: none !important; }

/* ================================================================
   v0.3 — Print: reflection card only
   When printing a reflection, hide everything else and show the card.
   ================================================================ */
@media print {
  html.printing-reflection body > *:not(.reflect-modal) { display: none !important; }
  html.printing-reflection .reflect-modal {
    position: static;
    display: block;
    opacity: 1;
    padding: 0;
  }
  html.printing-reflection .reflect-modal-scrim,
  html.printing-reflection .reflect-close,
  html.printing-reflection .reflect-prompt-view,
  html.printing-reflection .reflect-endcard-actions { display: none !important; }
  html.printing-reflection .reflect-modal-inner {
    box-shadow: none;
    border: none;
    max-height: none;
    overflow: visible;
    transform: none;
    padding: 0;
  }
  html.printing-reflection .reflect-endcard { display: block !important; }
  html.printing-reflection .reflect-list-desc { color: #000; }
}
