@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;700;800;900&display=swap');

:root {
  color-scheme: light;

  /* Ground */
  --parchment: #F3E7D3;
  --parchment-light: #FFF9ED;
  --parchment-dark: #E5D2B5;
  --parchment-deep: #D4BC98;

  /* Ink */
  --ink: #172126;
  --ink-light: #3D4A50;
  --ink-faded: #3F4A56;
  --ink-ghost: #9A8F7C;

  /* Sea / atlas authority */
  --sea: #174C55;
  --sea-light: #486F7A;
  --sea-dark: #0E2F36;
  --sea-faded: rgba(23, 76, 85, 0.12);

  /* Copper / mapwork */
  --copper: #9A5A2E;
  --copper-light: #B8733A;
  --copper-dim: #70401F;

  /* Human residue */
  --orange-peel: #C86A2E;
  --cardamom: #315C45;
  --warm: #9A5A2E;
  --warm-soft: #F5E4CF;

  /* Volume / operation accents */
  --auth-slate: #59626C;
  --price-copper: #9A5A2E;
  --ledger-green: #5F7D5A;
  --score-violet: #67507A;
  --interface-blue: #486F7A;
  --merge-plum: #4B334B;
  --danger-red: #8D3A32;

  /* Rules and surfaces */
  --ruled: #B99F78;
  --ruled-light: #D8C5A5;
  --ruled-dark: #8F7655;
  --plate-border: #8F7655;

  /* Functional aliases used by manuscript shells */
  --paper: var(--parchment);
  --paper-deep: var(--parchment-dark);
  --surface: var(--parchment-light);
  --surface-alt: #F8EAD8;
  --accent: var(--sea);
  --accent-dark: var(--sea-dark);
  --accent-soft: rgba(23, 76, 85, 0.10);
  --accent-dim: var(--copper-dim);
  --ink-soft: var(--ink-light);
  --ink-2: var(--ink-faded);
  --muted: var(--ink-faded);
  --rule: var(--ruled-light);

  /* Tiers / workbook shells */
  --tier1: var(--cardamom);
  --tier1-soft: rgba(49, 92, 69, 0.12);
  --tier2: #8A6420;
  --tier2-soft: rgba(154, 90, 46, 0.14);
  --tier3: var(--score-violet);
  --tier3-soft: rgba(103, 80, 122, 0.14);
  --tier4: var(--danger-red);
  --tier4-soft: rgba(141, 58, 50, 0.14);

  /* Typography */
  --serif: 'Cormorant Garamond', 'Georgia', serif;
  --body: 'Libre Baskerville', 'Georgia', serif;
  --fell: 'IM Fell English', 'Georgia', serif;
  --fell-pica: 'IM Fell DW Pica', 'Georgia', serif;
  --mono: 'JetBrains Mono', monospace;
  --sans: 'DM Sans', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;

  /* Effects */
  --shadow: 0 24px 70px rgba(23, 33, 38, 0.13);
  --shadow-soft: 0 10px 35px rgba(23, 33, 38, 0.08);
  --wang-color: rgba(23, 33, 38, 0.055);
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 16px; }

body { 
  font-family: var(--body); 
  background: var(--parchment);
  color: var(--ink); 
  line-height: 1.78;
  -webkit-font-smoothing: antialiased;
  position: relative;
  transition: background-color 2s ease, font-family 0.3s ease;
  background-image: 
    radial-gradient(ellipse at 20% 50%, rgba(180,150,110,0.08) 0%, transparent 70%),
    radial-gradient(ellipse at 80% 20%, rgba(160,130,90,0.06) 0%, transparent 60%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
}

/* 王 printer's mark watermark */
body::before {
  content: '王';
  position: fixed;
  bottom: 15%;
  right: 8%;
  font-size: 35vw;
  color: var(--wang-color, rgba(138,69,19,0.018));
  pointer-events: none;
  z-index: 0;
  font-family: serif;
  line-height: 1;
  transition: color 2s ease;
}

::selection { background: var(--copper); color: var(--parchment-light); }

/* ═══ ACCESSIBILITY ═══ */
.skip-link {
  position: absolute; left: -999px; top: 0.75rem;
  background: var(--copper); color: var(--parchment-light);
  padding: 0.5rem 0.75rem; font-family: var(--sans);
  font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase;
  z-index: 1001; border-radius: 2px; text-decoration: none;
}
.skip-link:focus { left: 0.75rem; }
a:focus-visible, button:focus-visible { outline: 2px solid var(--copper); outline-offset: 2px; }
section, .claim, .contact { scroll-margin-top: 5rem; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ═══ SHIP'S LOG BAR ═══ */
.system-bar {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: rgba(42,31,20,0.94);
  color: var(--parchment);
  font-family: var(--sans);
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  padding: 0.4rem 1.5rem;
  display: flex; justify-content: space-between; align-items: center;
  z-index: 500;
  backdrop-filter: none;
  border-top: 1px solid var(--ruled-dark);
}
.system-bar-left, .system-bar-right { display: flex; gap: 2rem; align-items: center; }
.system-bar span { opacity: 1; }
.system-bar .witness-count { color: var(--copper-light); opacity: 1; }
.system-bar .glyph { font-family: serif; font-size: 0.95rem; opacity: 0.95; }

/* ═══ NAV (Map Legend Style) ═══ */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  background: rgba(240,230,211,0.95);
  backdrop-filter: blur(10px);
  border-bottom: 2px solid var(--ruled);
  padding: 0.7rem 2.5rem;
  display: flex; justify-content: space-between; align-items: center;
}
nav::after {
  content: '';
  position: absolute; bottom: -4px; left: 0; right: 0;
  border-bottom: 1px solid var(--ruled-light);
}
.nav-title {
  font-family: var(--serif); font-size: 1rem; font-weight: 600;
  color: var(--ink); letter-spacing: 0.14em; text-transform: uppercase; text-decoration: none;
}
.nav-title span { color: var(--copper); }
.nav-links { display: flex; gap: 1.6rem; flex-wrap: wrap; align-items: center; }
.nav-links a {
  font-family: var(--fell); font-size: 0.75rem;
  color: var(--ink-light); text-decoration: none; transition: color 0.3s;
  font-style: italic;
}
.nav-links a:hover { color: var(--copper); }
.lang-toggle {
  font-family: var(--sans); font-size: 0.62rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: #3F3326; background: none;
  border: 1px solid var(--ruled); padding: 0.2rem 0.6rem; cursor: pointer;
  transition: all 0.25s; border-radius: 0;
}
.lang-toggle:hover, .lang-toggle.active { color: var(--copper); border-color: var(--copper); }
.lang-toggle.active { background: var(--copper); color: var(--parchment-light); }

/* Mobile nav hamburger */
.nav-hamburger {
  display: none;
  background: none; border: 1px solid var(--ruled); color: #3F3326;
  font-size: 1.1rem; padding: 0.15rem 0.5rem; cursor: pointer;
  font-family: var(--sans); transition: all 0.2s; line-height: 1;
}
.nav-hamburger:hover { border-color: var(--copper); color: var(--copper); }
.nav-agent { color: var(--copper); }
.nav-agent:hover { color: var(--copper-light); }

/* ═══ LANGUAGE SHIFT OVERLAY ═══ */
.lang-shift-overlay {
  position: fixed; inset: 0;
  background: rgba(42,31,20,0.95);
  z-index: 1000; display: none;
  justify-content: center; align-items: center;
  opacity: 0; transition: opacity 0.25s ease;
}
.lang-shift-text {
  font-family: var(--mono); font-size: 0.7rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--parchment); text-align: center; line-height: 2;
}

/* ═══ PLATE FRAME (reusable bordered section) ═══ */
.plate {
  max-width: 900px;
  margin: 0 auto;
  padding: 3rem 2.5rem;
  position: relative;
}
.plate-framed {
  border: 2px solid var(--ruled);
  background: var(--parchment-light);
  padding: 2.5rem 3rem;
  margin: 2rem auto;
  max-width: 860px;
  position: relative;
  box-shadow: 0 2px 20px rgba(42,31,20,0.06);
}
.plate-framed::before {
  content: '';
  position: absolute;
  inset: 4px;
  border: 1px solid var(--ruled-light);
  pointer-events: none;
}

/* ═══ SECTION DECORATIONS ═══ */
.section-rule {
  display: flex; align-items: center; gap: 1rem;
  margin: 4rem auto 2rem; max-width: 860px;
  padding: 0 2.5rem;
}
.section-rule::before, .section-rule::after {
  content: ''; flex: 1; height: 1px; background: var(--ruled);
}
.section-rule-text {
  font-family: var(--fell); font-size: 0.8rem;
  color: #3F3326; font-style: italic;
  white-space: nowrap;
}

.section-label {
  font-family: var(--sans); font-size: 0.62rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: #3F3326; margin-bottom: 0.5rem;
}

/* ═══ FRONTISPIECE / HERO ═══ */
.frontispiece {
  min-height: 100vh;
  display: flex; flex-direction: column;
  justify-content: center; align-items: center;
  text-align: center;
  padding: 8rem 2rem 6rem;
  position: relative;
  border-bottom: 2px solid var(--ruled);
}
.frontispiece::after {
  content: '';
  position: absolute; bottom: -4px; left: 0; right: 0;
  border-bottom: 1px solid var(--ruled-light);
}




.cartouche {
  border: 2px solid var(--ruled);
  padding: 3rem 4rem;
  position: relative;
  max-width: 700px;
  background: var(--parchment-light);
}
.cartouche::before {
  content: '';
  position: absolute; inset: 5px;
  border: 1px solid var(--ruled-light);
  pointer-events: none;
}
.cartouche::after {
  content: '❧';
  position: absolute; bottom: -14px; left: 50%;
  transform: translateX(-50%);
  background: var(--parchment-light);
  padding: 0 0.8rem;
  color: var(--ruled);
  font-size: 1.2rem;
}

.frontispiece-glyph {
  font-size: 2.5rem;
  color: var(--copper-dim);
  margin-bottom: 1.5rem;
  opacity: 0.6;
}
.frontispiece-atlas {
  font-family: var(--fell); font-size: 0.8rem;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: #3F3326;
  margin-bottom: 1rem;
}
.frontispiece h1 {
  font-family: var(--serif);
  font-size: 2.8rem;
  font-weight: 300;
  letter-spacing: 0.06em;
  line-height: 1.2;
  color: var(--ink);
  margin-bottom: 0.6rem;
}
.frontispiece h1 em { font-style: italic; font-weight: 400; }
.frontispiece-sub {
  font-family: var(--fell);
  font-size: 1.05rem;
  font-style: italic;
  color: var(--ink-light);
  max-width: 520px;
  margin: 0 auto 2rem;
  line-height: 1.7;
}
.frontispiece-long {
  font-family: var(--fell-pica);
  font-size: 0.82rem;
  font-style: italic;
  color: #3F3326;
  max-width: 540px;
  margin: 0 auto 2rem;
  line-height: 1.8;
}
.frontispiece-pitch-teaser {
  font-family: var(--body);
  font-size: 0.92rem;
  color: var(--copper);
  max-width: 440px;
  margin: -0.5rem auto 1.8rem;
  line-height: 1.6;
  letter-spacing: 0.01em;
}
.frontispiece-warning {
  font-family: var(--fell);
  font-size: 0.72rem;
  font-style: italic;
  color: var(--copper-dim);
  margin-top: 1rem;
  opacity: 0.8;
}
.hero-cta { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; margin-top: 1.5rem; }

/* ═══ BUTTONS ═══ */
.btn {
  display: inline-block; font-family: var(--fell); font-size: 0.78rem;
  font-style: italic;
  padding: 0.6rem 1.2rem;
  border: 1px solid var(--ruled);
  color: var(--ink-light); text-decoration: none; cursor: pointer;
  background: transparent; transition: all 0.25s ease;
}
.btn:hover { border-color: var(--copper); color: var(--copper); transform: translateY(-1px); }
.btn-accent { border-color: var(--copper-dim); color: var(--copper); }
.btn-accent:hover { border-color: var(--copper); }
.btn-sm { font-size: 0.72rem; padding: 0.4rem 0.8rem; }

/* ═══ TYPOGRAPHY ═══ */
h2 {
  font-family: var(--serif);
  font-size: 1.8rem;
  font-weight: 400;
  letter-spacing: 0.04em;
  margin-bottom: 1.2rem;
  color: var(--ink);
}
h3 {
  font-family: var(--serif);
  font-size: 1.15rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  margin: 2rem 0 0.8rem;
  color: var(--ink);
}
h4 {
  font-family: var(--fell);
  font-size: 0.95rem;
  font-style: italic;
  margin-bottom: 0.4rem;
  color: var(--copper-dim);
}

.lead {
  font-size: 1rem;
  line-height: 1.85;
  margin-bottom: 1.5rem;
  color: var(--ink-light);
}

p { margin-bottom: 1rem; }
em { font-style: italic; }
strong { font-weight: 700; }

/* ═══ AGENT BRIEF (as Letter of Introduction) ═══ */
.letter {
  max-width: 780px;
  margin: 0 auto;
  padding: 2.5rem 3rem;
  border: 1px solid var(--ruled-light);
  background: var(--parchment-light);
  position: relative;
}
.letter::before {
  content: '✦';
  position: absolute; top: -10px; left: 50%;
  transform: translateX(-50%);
  background: var(--parchment);
  padding: 0 0.6rem;
  color: var(--ruled);
  font-size: 0.8rem;
}
.letter dt {
  font-family: var(--fell);
  font-size: 0.82rem;
  font-style: italic;
  color: #3F3326;
  margin-top: 0.8rem;
}
.letter dd {
  font-family: var(--body);
  font-size: 0.88rem;
  color: var(--ink-light);
  margin-bottom: 0.4rem;
  margin-left: 0;
}
.letter-title {
  font-family: var(--serif);
  font-size: 1.1rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 1.2rem;
  text-align: center;
}

/* ═══ ARCHITECTURE SECTION ═══ */
.comp-row { display: flex; gap: 2rem; margin: 1.5rem 0; flex-wrap: wrap; }
.comp-col { flex: 1; min-width: 280px; }
.comp-col h4 { font-family: var(--fell); font-style: italic; color: var(--copper-dim); margin-bottom: 0.4rem; }
.comp-col p { font-size: 0.88rem; color: var(--ink-light); }

.map-table {
  width: 100%;
  border-collapse: collapse;
  margin: 1rem 0 2rem;
  font-size: 0.82rem;
}
.map-table th {
  font-family: var(--fell);
  font-style: italic;
  color: var(--copper-dim);
  border-bottom: 2px solid var(--ruled);
  padding: 0.5rem 0.8rem;
  text-align: left;
  font-weight: normal;
}
.map-table td {
  border-bottom: 1px solid var(--ruled-light);
  padding: 0.5rem 0.8rem;
  color: var(--ink-light);
}
.map-table tr:last-child td { border-bottom: none; }

/* ═══ CLAIM / Cartographer's Note ═══ */
.claim {
  text-align: center;
  padding: 3.5rem 2rem;
  border-top: 1px solid var(--ruled);
  border-bottom: 1px solid var(--ruled);
  background: var(--parchment-dark);
  position: relative;
}
.claim::before, .claim::after {
  content: '—'; display: block;
  color: var(--ruled); font-size: 1.2rem;
  margin: 0.5rem 0;
}
.claim-text {
  font-family: var(--fell-pica);
  font-size: 1rem;
  font-style: italic;
  color: var(--ink-light);
  max-width: 680px;
  margin: 0 auto;
  line-height: 1.8;
}

/* ═══ VOLUME CARDS (Map Plates) ═══ */
.volumes-grid { max-width: 900px; margin: 0 auto; display: grid; gap: 1.5rem; }
.volume-card {
  border: 2px solid var(--ruled);
  background: var(--parchment-light);
  padding: 2rem 2.2rem;
  position: relative;
  transition: border-color 0.3s;
}
.volume-card::before {
  content: '';
  position: absolute; inset: 3px;
  border: 1px solid var(--ruled-light);
  pointer-events: none;
}
.volume-card:hover { border-color: var(--copper-dim); }

.vol-header {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 0.6rem; flex-wrap: wrap; gap: 0.5rem;
}
.vol-number {
  font-family: var(--mono); font-size: 0.62rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: #3F3326;
}
.vol-status {
  font-family: var(--mono); font-size: 0.58rem;
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 0.15rem 0.5rem;
  border: 1px solid var(--ruled);
}
.vol-status.done { color: var(--sea); border-color: var(--sea); }
.vol-status.planned { color: #3F3326; border-color: var(--ruled-light); }

.vol-title {
  font-family: var(--serif); font-size: 1.5rem; font-weight: 400;
  letter-spacing: 0.03em; margin-bottom: 0.3rem; color: var(--ink);
}
.vol-subtitle {
  font-family: var(--fell); font-size: 0.85rem;
  font-style: italic; color: #3F3326; margin-bottom: 1rem;
}
.vol-meta {
  display: flex; gap: 1.5rem; flex-wrap: wrap;
  font-family: var(--mono); font-size: 0.6rem;
  letter-spacing: 0.06em; color: #3F3326;
  margin-bottom: 1rem; text-transform: uppercase;
  padding-bottom: 0.8rem;
  border-bottom: 1px solid var(--ruled-light);
}
.vol-desc {
  font-size: 0.9rem; color: var(--ink-light); line-height: 1.75;
}

/* ═══ ENGRAVED MAP PLATES (17th–18th c. style, inline SVG) ═══ */
.plate-wrap{
  margin: 1.1rem 0 1.2rem;
  border: 1px solid var(--ruled-light);
  background: linear-gradient(180deg, rgba(255,255,255,0.25), rgba(0,0,0,0.02));
  padding: 0.75rem;
  position: relative;
}
.plate-wrap::before{
  content:"";
  position:absolute; inset:6px;
  border:1px dashed rgba(120, 90, 50, 0.35);
  pointer-events:none;
}
.plate-caption{
  margin-top: .55rem;
  font-family: var(--mono);
  font-size: .58rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #3F3326;
}
.plate-svg{
  width: 100%;
  height: auto;
  display: block;
}
.plate-legend{
  display:flex; gap:.6rem; flex-wrap:wrap;
  margin-top:.55rem;
  font-family: var(--mono);
  font-size:.56rem;
  letter-spacing:.08em;
  color: #3F3326;
  text-transform: uppercase;
}
.plate-pill{
  padding:.15rem .45rem;
  border:1px solid var(--ruled-light);
  background: rgba(255,255,255,0.35);
}

/* Chapter list as gazetteer */
.chapter-list { margin-top: 1.2rem; border-top: 1px solid var(--ruled-light); padding-top: 0.8rem; }
.chapter-list-header {
  font-family: var(--fell); font-size: 0.72rem;
  font-style: italic; color: #3F3326;
  margin-bottom: 0.5rem;
}
.chapter-item {
  display: flex; gap: 0.8rem; align-items: baseline;
  padding: 0.35rem 0.5rem;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
  border-bottom: 1px dotted var(--ruled-light);
}
.chapter-item:hover { background: var(--parchment-dark); color: var(--copper); }
.ch-num {
  font-family: var(--mono); font-size: 0.6rem;
  color: #3F3326; min-width: 1.8rem;
  letter-spacing: 0.05em;
}
.ch-title {
  font-family: var(--fell); font-size: 0.82rem;
  font-style: italic; flex: 1;
}
.ch-arrow {
  font-size: 0.7rem; color: var(--ruled);
  transition: color 0.2s;
}
.chapter-item:hover .ch-arrow { color: var(--copper); }

/* Special volume card styling */
.vol-recursion { opacity: 0.7; border-style: dashed; }

/* ═══ ARTICLE CARDS (Navigation Charts) ═══ */
.articles-grid {
  max-width: 900px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.2rem;
}
.article-card {
  border: 1px solid var(--ruled);
  background: var(--parchment-light);
  padding: 1.3rem 1.5rem;
  cursor: pointer;
  transition: all 0.25s;
  position: relative;
  text-decoration: none;
  color: inherit;
  display: block;
}
.article-card::before {
  content: '';
  position: absolute; inset: 2px;
  border: 1px solid transparent;
  transition: border-color 0.25s;
  pointer-events: none;
}
.article-card:hover {
  border-color: var(--copper-dim);
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(42,31,20,0.08);
}
.article-card:hover::before { border-color: var(--ruled-light); }

.article-num {
  font-family: var(--mono); font-size: 0.58rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: #3F3326; margin-bottom: 0.4rem;
}
.article-title {
  font-family: var(--serif); font-size: 1.05rem;
  font-weight: 500; color: var(--ink);
  margin-bottom: 0.3rem; line-height: 1.3;
}
.article-sub {
  font-family: var(--fell); font-size: 0.75rem;
  font-style: italic; color: #3F3326;
  line-height: 1.5;
}
.article-card.remainder { border-color: var(--copper-dim); }
.article-card.remainder .article-num { color: var(--copper); }

/* ═══ PHILOSOPHY (Surveyor's Observations) ═══ */
.phil-points { max-width: 860px; margin: 0 auto; }
.phil-point {
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--ruled-light);
}
.phil-point:last-child { border-bottom: none; }
.phil-point h3 {
  font-family: var(--fell); font-size: 0.95rem;
  font-style: italic; color: var(--copper-dim);
  margin-bottom: 0.5rem; font-weight: normal;
}
.phil-point p {
  font-size: 0.88rem; color: var(--ink-light); line-height: 1.8;
}

/* ═══ CONCEPTS (Topographical Features) ═══ */
.concepts-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem; max-width: 860px; margin: 0 auto;
}
.concept-card {
  border: 1px solid var(--ruled-light);
  padding: 1.2rem 1.4rem;
  background: var(--parchment-light);
}
.concept-card h4 {
  font-family: var(--fell); font-size: 0.85rem;
  font-style: italic; color: var(--copper-dim);
  margin-bottom: 0.3rem;
}
.concept-card p {
  font-size: 0.82rem; color: var(--ink-light); line-height: 1.7;
}

/* ═══ SCHATTENDORF (Historical Survey) ═══ */
.timeline { max-width: 860px; margin: 0 auto; }
.timeline-entry {
  display: flex; gap: 1.5rem; padding: 1rem 0;
  border-bottom: 1px dotted var(--ruled-light);
}
.timeline-entry:last-child { border-bottom: none; }
.timeline-date {
  font-family: var(--mono); font-size: 0.68rem;
  color: var(--copper-dim); min-width: 6rem;
  letter-spacing: 0.05em; padding-top: 0.15rem;
}
.timeline-text { flex: 1; }
.timeline-text h4 {
  font-family: var(--fell); font-size: 0.88rem;
  font-style: italic; color: var(--ink);
  margin-bottom: 0.2rem;
}
.timeline-text p {
  font-size: 0.82rem; color: var(--ink-light); line-height: 1.7;
}

/* ═══ BIO (The Cartographer) ═══ */
.bio-grid { max-width: 860px; margin: 0 auto; }
.credential-block {
  padding: 1.2rem 0;
  border-bottom: 1px solid var(--ruled-light);
}
.credential-block:last-child { border-bottom: none; }
.credential-block h4 {
  font-family: var(--fell); font-size: 0.88rem;
  font-style: italic; color: var(--copper-dim);
  margin-bottom: 0.3rem;
}
.credential-block p {
  font-size: 0.88rem; color: var(--ink-light); line-height: 1.75;
}

/* ═══ CONTACT ═══ */
.contact {
  text-align: center; padding: 4rem 2rem 6rem;
  border-top: 1px solid var(--ruled);
}
.contact h2 { margin-bottom: 0.8rem; }
.contact-email {
  font-family: var(--fell); font-size: 1rem;
  font-style: italic; color: var(--copper);
  text-decoration: none; letter-spacing: 0.03em;
}
.contact-email:hover { text-decoration: underline; }
.contact-note {
  font-family: var(--sans);
  font-size: 0.82rem; color: #3F3326;
  margin-top: 0.5rem;
}

/* ═══ FOOTER ═══ */
footer {
  text-align: center; padding: 2rem 2rem 3.5rem;
  font-family: var(--fell); font-size: 0.75rem;
  font-style: italic; color: #3F3326;
  border-top: 1px solid var(--ruled-light);
}
footer .glyph { display: block; font-style: normal; font-size: 1.4rem; margin-bottom: 0.5rem; opacity: 0.3; }

/* ═══ COLOPHON ═══ */
.colophon {
  max-width: 640px;
  margin: 0 auto;
  padding: 3rem 2.5rem 4rem;
  text-align: center;
  border-top: 1px solid var(--ruled);
}
.colophon-rule {
  font-family: var(--serif);
  font-size: 0.85rem;
  letter-spacing: 0.3em;
  color: var(--ruled);
  opacity: 0.7;
  margin-bottom: 2rem;
}
.colophon-title {
  font-family: var(--mono);
  font-size: 0.58rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #3F3326;
  margin-bottom: 1.4rem;
  font-style: normal;
}
.colophon-text {
  font-family: var(--fell);
  font-size: 0.82rem;
  font-style: italic;
  line-height: 1.75;
  color: #3F3326;
  margin-bottom: 1rem;
  text-indent: 0;
}
.colophon-legal {
  font-family: var(--mono);
  font-size: 0.58rem;
  font-style: normal;
  letter-spacing: 0.06em;
  color: #3F3326;
  margin-top: 1.8rem;
}
.colophon-wang {
  font-size: 2.2rem;
  font-style: normal;
  opacity: 0.18;
  margin-top: 2rem;
  letter-spacing: 0;
  transition: opacity 2s ease;
}
.colophon:hover .colophon-wang {
  opacity: 0.35;
}

/* ═══ READER OVERLAY ═══ */
.reader-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: var(--parchment);
  overflow-y: auto;
  display: none;
  flex-direction: column;
}
.reader-overlay.active { display: flex; }
.reader-progress {
  position: fixed; top: 0; left: 0; height: 2px;
  background: var(--copper); z-index: 201;
  transition: width 0.1s;
}
.reader-header {
  position: sticky; top: 0; z-index: 201;
  background: rgba(240,230,211,0.95);
  backdrop-filter: blur(10px);
  padding: 0.8rem 2rem;
  display: flex; justify-content: space-between; align-items: center;
  border-bottom: 2px solid var(--ruled);
}
.reader-header::after {
  content: '';
  position: absolute; bottom: -4px; left: 0; right: 0;
  border-bottom: 1px solid var(--ruled-light);
}
.reader-breadcrumb {
  font-family: var(--fell); font-size: 0.78rem;
  font-style: italic; color: #3F3326;
}
.reader-close {
  font-family: var(--fell); font-size: 0.78rem;
  font-style: italic; background: none;
  border: 1px solid var(--ruled); color: #3F3326;
  padding: 0.3rem 0.8rem; cursor: pointer;
  transition: all 0.2s;
}
.reader-close:hover { border-color: var(--copper); color: var(--copper); }
.reader-chapter-title {
  font-family: var(--serif); font-size: 1.8rem;
  font-weight: 400; text-align: center;
  margin: 3rem auto 0.5rem; max-width: 700px;
  color: var(--ink);
}
.reader-chapter-sub {
  font-family: var(--fell); font-size: 0.88rem;
  font-style: italic; text-align: center;
  color: #3F3326; margin-bottom: 2.5rem;
}

#readerBody {
  max-width: 680px; margin: 0 auto;
  padding: 0 2rem 6rem; font-size: 0.95rem;
  line-height: 1.85; color: var(--ink-light);
}
#readerBody p { margin-bottom: 1.2rem; text-indent: 1.5em; }
#readerBody p:first-child, #readerBody h3 + p, #readerBody .section-break + p { text-indent: 0; }
#readerBody h3 {
  font-family: var(--serif); font-size: 1.1rem;
  font-weight: 600; color: var(--ink);
  margin: 2.5rem 0 1rem; text-indent: 0;
}
#readerBody .section-break {
  text-align: center; margin: 2rem 0;
  color: #3F3326; letter-spacing: .5em; font-size: .9rem;
}
#readerBody em { font-style: italic; }
#readerBody strong { font-weight: 700; }
#readerBody blockquote {
  border-left: 2px solid var(--ruled);
  padding-left: 1.5rem; margin: 1.5rem 0;
  font-style: italic; color: #3F3326;
}

.reader-nav {
  display: flex; justify-content: center; gap: 1rem;
  padding: 2rem; border-top: 1px solid var(--ruled-light);
}

/* ═══ CHAPTER ENTRY OVERLAY ═══ */
.chapter-entry-overlay {
  position: fixed; inset: 0; z-index: 300;
  background: rgba(42,31,20,0.95);
  display: flex; justify-content: center; align-items: center;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s;
}
.chapter-entry-overlay.active { opacity: 1; pointer-events: auto; }
.chapter-entry-text {
  font-family: var(--mono); font-size: 0.65rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--parchment); text-align: center; line-height: 2.2;
}
.chapter-entry-text .processing { color: var(--copper-light); }

/* ═══ RESPONSIVE ═══ */
@media (max-width: 768px) {
  .cartouche { padding: 2rem 1.5rem; }
  .frontispiece h1 { font-size: 2rem; }
  .plate-framed { padding: 1.5rem; margin: 1rem; }
  nav { padding: 0.6rem 1rem; flex-wrap: wrap; gap: 0.5rem; }
  .nav-links { gap: 0.8rem; }
  .articles-grid { grid-template-columns: 1fr; }
  .comp-row { flex-direction: column; }
  .timeline-entry { flex-direction: column; gap: 0.3rem; }
  .system-bar { font-size: 0.5rem; padding: 0.3rem 0.8rem; }
  .letter { padding: 1.5rem; }
  .volume-card { padding: 1.5rem; }
  #readerBody { padding: 0 1rem 4rem; }

  /* Mobile nav collapse */
  .nav-hamburger { display: block; }
  .nav-links {
    display: none;
    width: 100%;
    flex-direction: column;
    gap: 0.6rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--ruled-light);
    margin-top: 0.3rem;
  }
  .nav-links.open { display: flex; }
  .nav-links a { padding: 0.3rem 0; }
}

/* ═══ WIDE SECTION ═══ */
section.wide { padding: 3rem 2rem; }
section { max-width: 900px; margin: 0 auto; padding: 3rem 2.5rem; }

/* ═══ EMOTIONAL PITCH ═══ */
.emotional-pitch{
  max-width: 900px;
  margin: 0 auto;
  padding: 2.5rem 2.5rem 1.25rem;
  border-bottom: 1px solid var(--ruled);
  background: linear-gradient(180deg, rgba(247,240,228,0.55), rgba(240,230,211,0));
}
.pitch-lead{
  font-family: var(--serif);
  font-size: 1.35rem;
  font-weight: 300;
  line-height: 1.65;
  letter-spacing: 0.02em;
  color: var(--ink);
  margin-bottom: 1rem;
}
.pitch-sub{
  font-family: var(--fell);
  font-size: 0.88rem;
  font-style: italic;
  line-height: 1.75;
  color: var(--ink-light);
  margin-bottom: 0.5rem;
}
.claim-sub{
  font-family: var(--fell);
  font-style: italic;
  font-size: 0.92rem;
  color: #3F3326;
  margin-top: 1rem;
  text-align: center;
}

/* ═══ FEATURED ARTICLES ═══ */
.featured-articles-label{
  font-family: var(--mono);
  font-size: 0.62rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #3F3326;
  margin: 1.75rem 0 0.9rem;
}
.featured-articles-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
  margin-bottom: 2.1rem;
}
.featured-article-card{
  border: 1px solid var(--ruled);
  background: var(--parchment-light);
  padding: 1.4rem 1.6rem;
  cursor: pointer;
  transition: all 0.25s ease;
  position: relative;
}
.featured-article-card::before{
  content:'';
  position:absolute; inset: 3px;
  border: 1px solid transparent;
  pointer-events:none;
  transition: border-color 0.25s;
}
.featured-article-card:hover{
  border-color: var(--copper-dim);
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(42,31,20,0.08);
}
.featured-article-card:hover::before{ border-color: var(--ruled-light); }
.featured-article-card .fa-num{
  font-family: var(--mono);
  font-size: 0.58rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #3F3326;
  margin-bottom: 0.45rem;
}
.featured-article-card .fa-title{
  font-family: var(--serif);
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 0.35rem;
  line-height: 1.3;
}
.featured-article-card .fa-sub{
  font-family: var(--fell);
  font-size: 0.75rem;
  font-style: italic;
  color: #3F3326;
  line-height: 1.55;
}
.featured-article-card.remainder-card{
  border-color: var(--copper-dim);
  background: rgba(139,69,19,0.03);
}
@media (max-width: 700px){
  .featured-articles-grid{ grid-template-columns: 1fr; }
}


/* ── Pitch additions (append-only) ───────────────────────────────────── */
@media (max-width: 900px){
  .emotional-pitch{ padding: 2rem 1.25rem 1rem; }
  .pitch-lead{ font-size: 1.15rem; }
}
.subhead { margin: 1.25rem 0 .65rem; font-family: var(--fell); letter-spacing: .06em; text-transform: uppercase; font-size: .78rem; color: #3F3326; }
.mechanism-list { margin: .75rem 0 1rem 1.35rem; }
.mechanism-list li { margin: .35rem 0; }
.key-ethic { margin-top: .9rem; font-size: 1.05rem; }
.note { color: #3F3326; font-size: .95rem; }


/* ─── Map section: manuscript links + chapter lists ─── */
.map-table a{ color: var(--copper); text-decoration: none; border-bottom: 1px dotted rgba(139,69,19,0.55); }
.map-table a:hover{ border-bottom-color: var(--copper); }
.mini-link{ font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase; margin-left: 0.45rem; }
.chapter-details{ margin-top: 0.35rem; }
.chapter-details summary{
  cursor: pointer;
  font-family: var(--mono);
  font-size: 0.62rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #3F3326;
}
.chapter-links{ list-style: none; padding-left: 0; margin: 0.35rem 0 0; }
.chapter-links li{ margin: 0.15rem 0; }
.chapter-links a{ display:inline-block; padding-left:0; font-family: var(--serif); font-size: 0.92rem; letter-spacing: 0; text-transform: none; border-bottom: 1px dotted rgba(139,69,19,0.45); transition: padding-left 0.25s ease, color 0.2s, border-bottom-color 0.2s; }
.chapter-links a:hover{ padding-left:0.6rem; color: var(--copper); border-bottom-color: var(--copper); }
.chapter-links a:focus-visible{ outline: 2px solid var(--copper); outline-offset: 2px; }





/* hanging notice */




/* v11: brief clarifier + email/phone reveal */
.aside{ font-style: italic; color: var(--accent-dim); }
.email-js, .phone-js { text-decoration: underline; text-underline-offset: 3px; }

/* v20: Agent QuickStart emphasis */
#agentsEditors {
  border: 2px solid var(--copper-dim);
  background: rgba(255,255,255,0.45);
  padding: 1.8rem 2rem;
  scroll-margin-top: 5rem;
}
#agentsEditors .jp-kicker {
  color: var(--copper);
  font-weight: 600;
}
#agentsEditors .jp-text {
  font-size: 1.05rem;
  color: var(--ink);
}
#agentsEditors .jp-actions {
  flex-wrap: wrap;
}
#agentsEditors .jp-btn {
  border-color: var(--copper-dim);
  color: var(--copper);
}
#agentsEditors .jp-btn:hover {
  background: var(--copper);
  color: var(--parchment-light);
  border-color: var(--copper);
}



/* --- POSITION-BASED CHART LISTS (v13) --- */
.pos-charts-wrap{
  margin-top:.9rem;
}
.pos-charts-sub{
  font-family: var(--mono);
  font-size:.72rem;
  letter-spacing:.12em;
  text-transform: uppercase;
  color: var(--accent-dim);
  margin: .35rem 0 .6rem;
}
.pos-charts-note{
  margin-top:1rem;
  opacity:.78;
  font-size:.86rem;
  line-height:1.35;
  color: var(--ink-2);
}
.pos-tag{
  display:inline-block;
  margin-left:.55rem;
  padding:.16rem .42rem .18rem;
  border:1px solid rgba(120,85,55,.38);
  border-radius:999px;
  font-family: var(--mono);
  font-size:.62rem;
  letter-spacing:.12em;
  text-transform: uppercase;
  color: var(--accent-dim);
  background: rgba(255,255,255,.35);
}
.pos-disabled{
  opacity:.62;
}



/* --- Curator shelf accordion (v15) --- */
.curator-shelf{
  margin-top: .9rem;
}
.curator-shelf-summary{
  list-style:none;
  cursor:pointer;
}
.curator-shelf-summary::-webkit-details-marker{ display:none; }
.curator-shelf-hint{
  margin-left:.6rem;
  opacity:.7;
  font-family: var(--mono);
  font-size:.72rem;
  letter-spacing:.10em;
  text-transform: uppercase;
  color: var(--accent-dim);
}
.curator-shelf[open] .curator-shelf-hint{ opacity:.55; }


/* ═══ MAP PLATE LEGEND GRID (numbered reference key) ═══ */
.plate-legend-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:0 2rem;
  padding:0.8rem 1rem;margin-top:0.3rem;
  border-top:1px solid rgba(196,168,130,0.4);
  background:rgba(255,255,255,0.15);
}
.legend-col{
  display:grid;grid-template-columns:auto 1fr;gap:0.15rem 0.35rem;align-items:center;
}
.legend-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:1.15rem;height:1.15rem;border-radius:50%;
  background:rgba(240,230,205,0.8);border:1px solid rgba(90,55,35,0.5);
  font-family:Georgia,serif;font-size:0.6rem;font-weight:bold;
  color:rgba(60,35,15,0.9);flex-shrink:0;
}
.legend-name{
  font-family:var(--fell);font-size:0.72rem;color:var(--ink);
  line-height:1.15rem;
}
@media(max-width:600px){
  .plate-legend-grid{grid-template-columns:1fr;gap:0.3rem 0;}
}

/* ═══ CLICKABLE MAP DOTS & LEGEND LINKS ═══ */
.plate-svg a.map-dot-link { cursor: pointer; }
.plate-svg a.map-dot-link:hover circle:nth-child(2) {
  fill: rgba(196,168,130,0.9);
  stroke: rgba(60,35,15,0.95);
  stroke-width: 1.6;
}
.plate-svg a.map-dot-link:focus { outline: none; }
.plate-svg a.map-dot-link:focus circle:nth-child(2) {
  stroke: var(--copper);
  stroke-width: 2;
}
a.legend-link {
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px dotted rgba(90,55,35,0.3);
  transition: border-color 0.2s, color 0.2s;
}
a.legend-link:hover {
  color: var(--copper);
  border-bottom-color: var(--copper);
  border-bottom-style: solid;
}
a.legend-link:focus-visible {
  outline: 2px solid var(--copper);
  outline-offset: 2px;
}



/* ─── Π COUNCIL SEAL: wax treatment (vNew) ─── */
.pi-seal{
  position:absolute;
  top:-42px;
  right:-42px;
  width:150px;
  height:150px;
  transform: rotate(-8deg);
  z-index: 6;
  opacity: .96;
  user-select:none;
  pointer-events:auto;

  /* wax depth */
  filter: drop-shadow(0 18px 28px rgba(0,0,0,.22));
}
.pi-seal svg{ width:100%; height:100%; display:block; }

.pi-seal::before{
  /* wax body sheen + shadow ring */
  content:"";
  position:absolute;
  inset:-10px;
  border-radius:999px;
  background:
    radial-gradient(circle at 30% 28%, rgba(255,255,255,.78), rgba(255,255,255,0) 46%),
    radial-gradient(circle at 72% 78%, rgba(0,0,0,.28), rgba(0,0,0,0) 56%);
  opacity:.42;
  mix-blend-mode:multiply;
  pointer-events:none;
}
.pi-seal::after{
  /* raised rim */
  content:"";
  position:absolute;
  inset:-3px;
  border-radius:999px;
  box-shadow:
    inset 0 2px 2px rgba(255,255,255,.74),
    inset 0 -5px 7px rgba(0,0,0,.22);
  opacity:.86;
  pointer-events:none;
}
.pi-seal:hover{ transform: rotate(-8deg) scale(1.02); }

/* hanging notice */
.pi-seal-hang{
  position:absolute;
  left:50%;
  top:132px;
  transform: translateX(-50%) rotate(-1.2deg);
  width: 320px;
  pointer-events:none;
}
.pi-seal-ribbon{
  width:2px;
  height:38px;
  margin:0 auto;
  background: linear-gradient(to bottom, rgba(102,68,38,.88), rgba(102,68,38,.32));
  box-shadow: 0 1px 0 rgba(255,255,255,.45);
  opacity:.92;
}
.pi-seal-notice{
  position:relative;
  margin-top:6px;
  padding:14px 14px 12px;
  border:1px solid rgba(120,85,55,.50);
  background: rgba(255,252,246,.90);
  box-shadow:
    0 18px 24px rgba(0,0,0,.12),
    inset 0 1px 0 rgba(255,255,255,.78);
  border-radius:10px;
  backdrop-filter: blur(1px);
}
.pi-seal-notice::before{
  content:"";
  position:absolute;
  left:50%;
  top:-12px;
  transform: translateX(-50%);
  width:10px;
  height:10px;
  border-radius:999px;
  background: rgba(235,228,214,.96);
  border:1px solid rgba(120,85,55,.35);
  box-shadow: inset 0 1px 1px rgba(0,0,0,.12);
}
.pi-seal-notice-title{
  font-variant: small-caps;
  letter-spacing:.12em;
  font-size:11px;
  color: rgba(75,55,35,.90);
  text-align:center;
  margin-bottom:8px;
}
.pi-seal-notice-body{
  font-size:12px;
  line-height:1.35;
  color: rgba(35,25,15,.94);
  text-align:center;
}
.pi-seal-em{ font-variant: small-caps; letter-spacing:.08em; }
.pi-seal-notice-meta{
  margin-top:8px;
  font-size:10px;
  letter-spacing:.06em;
  color: rgba(75,55,35,.74);
  text-align:center;
}

@media (max-width: 640px){
  .pi-seal{ top:1.0rem; right:1.0rem; width:110px; height:110px; }
  .pi-seal-hang{ top:98px; width: 270px; }
}



/* noscript email fallback */
.contact-email-noscript{
  margin-top: .35rem;
  font-style: italic;
  letter-spacing: .02em;
}

/* ═══ ACCESS GATE ═══ */
.auth-gate {
  position: fixed; inset: 0; z-index: 9999;
  background: var(--parchment);
  background-image:
    radial-gradient(ellipse at 30% 20%, rgba(139,69,19,0.04) 0%, transparent 60%),
    radial-gradient(ellipse at 70% 80%, rgba(58,90,92,0.03) 0%, transparent 50%);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 2rem;
  transition: opacity 0.8s ease, transform 0.8s ease;
}
.auth-gate.unlocking {
  opacity: 0; transform: scale(1.02); pointer-events: none;
}
.auth-gate-inner { text-align: center; max-width: 440px; }
.auth-book-wrap {
  position: relative; width: 300px; height: 380px; margin: 0 auto 1.8rem;
}
.auth-book-wrap svg { width: 100%; height: 100%; overflow: visible; }
.auth-book-wrap.unlocked .book-cover {
  transform-origin: 60px 50%;
  animation: bookOpen 1.2s ease-out 0.5s forwards;
}
.lock-hasp {
  transform-origin: 228px 170px;
}
.auth-book-wrap.unlocked .lock-hasp {
  animation: haspOpen 0.4s ease-out forwards;
}
.key-group {
  transform-origin: 247px 236px;
}
.auth-book-wrap.unlocked .key-group {
  animation: keyTurn 0.5s ease-in-out forwards;
}
/* 2D book-open: scaleX simulates cover lifting; opacity drops only at end */
@keyframes bookOpen {
  0% { transform: scaleX(1); opacity: 1; }
  70% { transform: scaleX(0.12); opacity: 1; }
  90% { transform: scaleX(0.05); opacity: 0.5; }
  100% { transform: scaleX(0.03); opacity: 0.1; }
}
@keyframes haspOpen {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(-90deg); opacity: 0; }
}
@keyframes keyTurn {
  0% { transform: rotate(0deg); }
  50% { transform: rotate(-45deg); }
  100% { transform: rotate(-45deg) translate(-20px, -10px); opacity: 0; }
}
.auth-title {
  font-family: var(--serif); font-size: 1.3rem; font-weight: 300;
  letter-spacing: 0.18em; text-transform: uppercase; color: #3F3326;
  margin-bottom: 0.3rem;
}
.auth-subtitle {
  font-family: var(--fell); font-size: 0.82rem; font-style: italic;
  color: #3F3326; margin-bottom: 1.6rem;
}
.auth-field-wrap {
  display: flex; align-items: center; justify-content: center;
  gap: 0.6rem; margin-bottom: 0.8rem;
}
.auth-input {
  font-family: var(--sans); font-size: 0.88rem; letter-spacing: 0.15em;
  text-transform: uppercase; background: transparent; border: none;
  border-bottom: 1px solid var(--ruled); color: var(--ink);
  padding: 0.4rem 0.6rem; width: 180px; text-align: center; outline: none;
  transition: border-color 0.3s;
}
.auth-input::placeholder {
  color: #3F3326; font-size: 0.72rem; letter-spacing: 0.1em; text-transform: none;
}
.auth-input:focus { border-bottom-color: var(--copper); }
.auth-btn {
  font-family: var(--sans); font-size: 0.68rem; letter-spacing: 0.12em;
  text-transform: uppercase; background: none; border: 1px solid var(--ruled);
  color: #3F3326; padding: 0.35rem 0.8rem; cursor: pointer; transition: all 0.25s;
}
.auth-btn:hover { border-color: var(--copper); color: var(--copper); }
.auth-error {
  font-family: var(--sans); font-size: 0.68rem; color: var(--copper);
  letter-spacing: 0.08em; min-height: 1.2rem; opacity: 0; transition: opacity 0.3s;
}
.auth-error.visible { opacity: 1; }
.auth-footer {
  font-family: var(--fell); font-size: 0.7rem; font-style: italic;
  color: #3F3326; margin-top: 1.8rem; opacity: 0.6;
}
.auth-lang-toggle {
  position: fixed; top: 1.2rem; right: 1.2rem;
  font-family: var(--sans); font-size: 0.62rem; letter-spacing: 0.1em;
  background: none; border: 1px solid var(--ruled-light); color: #3F3326;
  padding: 0.25rem 0.5rem; cursor: pointer; transition: all 0.25s; z-index: 10000;
}
.auth-lang-toggle:hover { border-color: var(--copper); color: var(--copper); }
@media (max-width: 640px) {
  .auth-book-wrap { width: 220px; height: 290px; margin-bottom: 1.2rem; }
  .auth-title { font-size: 1.05rem; letter-spacing: 0.12em; }
  .auth-subtitle { font-size: 0.72rem; margin-bottom: 1.2rem; }
  .auth-input { width: 150px; font-size: 0.8rem; }
  .auth-btn { font-size: 0.62rem; }
  .auth-footer { font-size: 0.62rem; margin-top: 1.2rem; }
}
@media (max-width: 380px) {
  .auth-book-wrap { width: 180px; height: 240px; }
  .auth-title { font-size: 0.9rem; }
}




/* Contrast + legibility pass (non-destructive overrides) */
:root{
  --ink: #241b12;
  --ink-faded: #4b3d2f;
  --ink-ghost: #6a5a48;
  --copper: #a07033;
}
html, body{ 
  font-size: 18px;
  line-height: 1.65;
  color: var(--ink);
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
p, li, td, th, blockquote{ line-height: 1.65; }
small, .small, .micro, .meta, .kicker{ letter-spacing: 0.02em; }
table{ color: var(--ink); }
th{ color: var(--ink); font-weight: 600; }
td{ color: var(--ink); }
a{ color: var(--ink); text-decoration-color: rgba(160,112,51,0.6); }
a:hover{ text-decoration-color: rgba(160,112,51,1); }

/* Give key text containers a touch more separation from the parchment texture */
.letter,
.plate-framed,
.volume-card,
.article-card,
.featured-article-card,
.concept-card,
.remainder-card,
#agentsEditors,
#introPlate,
#letterOfIntroduction,
#statusBox,
#schattendorfSection,
#articlesSection{
  background-color: rgba(255,255,255,0.62);
  box-shadow: 0 1px 0 rgba(255,255,255,0.35);
}


/* If the site uses “ghost” text classes, make them readable */
.muted, .dim, .ghost, .faded{ color: #3F3326 !important; }
.plate-caption, .plate-legend, .meta, .kicker, .note{
  color: #3F3326 !important;
}

/* Tighten extremely light italic pull-quote strips */
.pull-quote, .pullquote, .midquote{
  color: var(--ink) !important;
  text-shadow: 0 1px 0 rgba(255,255,255,0.35);
}

/* Table gridlines slightly darker for legibility */
table tr{ border-color: rgba(160,112,51,0.35) !important; }
table thead tr{ border-color: rgba(160,112,51,0.55) !important; }

/* ─── NAVIGATION CHARTS: TRAVELLER DECLARATION ─── */
.jurisdiction-panel{
  max-width: 720px;
  margin: 2rem auto 2.5rem;
  padding: 1.6rem 1.8rem;
  border: 1px solid var(--ruled);
  background: rgba(255,255,255,0.35);
}
.jp-kicker{
  font-family: var(--sans);
  font-size: 0.62rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #3F3326;
  margin-bottom: 0.8rem;
}
.jp-text{
  font-family: var(--serif);
  font-size: 1.02rem;
  line-height: 1.7;
  color: var(--ink-light);
  margin-bottom: 1.2rem;
  text-indent: 0 !important;
}
.jp-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.6rem 1.2rem;
  margin-bottom: 1.1rem;
}
.rp-item{
  font-family: var(--sans);
  font-size: 0.78rem;
  color: #3F3326;
  display: flex;
  align-items: center;
  gap: 0.6rem;
}
.rp-item input{ accent-color: var(--copper); }
.jp-status{
  font-family: var(--sans);
  font-size: 0.62rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #3F3326;
  margin-bottom: 0.9rem;
}
.jp-actions{ display: flex; gap: 0.8rem; }
.jp-btn{
  font-family: var(--fell);
  font-size: 0.78rem;
  font-style: italic;
  background: none;
  border: 1px solid var(--ruled);
  color: #3F3326;
  padding: 0.35rem 0.9rem;
  cursor: pointer;
  transition: all 0.2s;
}
.jp-btn:hover{ border-color: var(--copper); color: var(--copper); }
.jp-btn.ghost{ opacity: 0.85; }

/* Agent panel At a Glance grid */
.agent-grid dt { font-family: var(--sans); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: #3F3326; margin-bottom: 0.2rem; }
.agent-grid dd { font-family: var(--sans); font-size: 0.82rem; color: var(--ink-light); line-height: 1.5; }

/* ─── ACCESS GATE ─── */
.gate-overlay{
  position: fixed; inset: 0;
  z-index: 350;
  background: rgba(42,31,20,0.92);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
}
.gate-overlay.active{ display: flex; }
.gate-box{
  max-width: 560px;
  width: 100%;
  background: rgba(240,230,211,0.96);
  border: 2px solid var(--ruled);
  padding: 1.6rem 1.8rem 1.3rem;
  box-shadow: 0 20px 60px rgba(0,0,0,0.35);
}
.gate-title{
  font-family: var(--mono);
  font-size: 0.62rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #3F3326;
  margin-bottom: 1rem;
}
.gate-body{
  font-family: var(--serif);
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--ink);
}
.gate-body p{ margin-bottom: 1rem; text-indent: 0; }
.gate-actions{
  display: flex;
  gap: 0.8rem;
  justify-content: flex-end;
  margin-top: 1.2rem;
}
.gate-btn{
  font-family: var(--fell);
  font-size: 0.78rem;
  font-style: italic;
  background: none;
  border: 1px solid var(--ruled);
  color: #3F3326;
  padding: 0.35rem 0.9rem;
  cursor: pointer;
  transition: all 0.2s;
}
.gate-btn:hover{ border-color: var(--copper); color: var(--copper); }
.gate-btn.ghost{ opacity: 0.85; }

/* ─── ARTICLE BADGES ─── */
.article-card{ position: relative; }
.article-card.gated{ opacity: 0.78; }
.article-badge{
  position: absolute;
  top: 1.1rem;
  right: 1.1rem;
  font-family: var(--mono);
  font-size: 0.56rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--copper);
  border: 1px solid rgba(160,112,51,0.35);
  padding: 0.2rem 0.45rem;
  background: rgba(255,255,255,0.35);
}
.article-badge.gated{
  color: #3F3326;
  border-color: rgba(40,30,20,0.18);
}

/* ─── ARTICLE BODY (DOCX EMBEDS) ─── */
#readerBody p.article-subtitle,
#readerBody p.article-byline,
#readerBody p.jurisdiction-notice{ text-indent: 0; }

#readerBody p.article-subtitle{
  margin-top: 0;
  margin-bottom: 0.4rem;
  color: var(--ink);
  font-size: 1.05rem;
}

#readerBody p.article-byline{
  margin-bottom: 0.8rem;
  font-family: var(--fell);
  font-size: 0.82rem;
  font-style: italic;
  color: #3F3326;
}

#readerBody p.jurisdiction-notice{
  margin: 0 0 1.4rem;
  padding: 0.8rem 1rem;
  border-left: 2px solid var(--copper);
  background: rgba(255,255,255,0.35);
  font-family: var(--mono);
  font-size: 0.62rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #3F3326;
}

#readerBody .article-break{
  text-align: center;
  margin: 2.2rem 0;
  color: #3F3326;
  letter-spacing: 0.5em;
  font-size: 0.9rem;
}

#readerBody h4.article-section{
  font-family: var(--serif);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--ink);
  margin: 2.5rem 0 1rem;
  text-indent: 0;
}

#readerBody .article-emdash{
  text-align: center;
  margin: 2.5rem 0 1rem;
  color: #3F3326;
}

#readerBody .article-footer-line{
  text-align: center;
  font-family: var(--fell);
  font-size: 0.78rem;
  font-style: italic;
  color: #3F3326;
  margin: 0.2rem 0;
  text-indent: 0;
}

/* --- Academic apparatus --- */
#readerBody .article-abstract {
  margin: 1.2rem 0 2rem;
  padding: 1rem 1.4rem;
  border-left: 2px solid var(--ruled);
  background: rgba(255,255,255,0.3);
  font-size: 0.88rem;
  line-height: 1.65;
  font-style: italic;
  color: var(--ink-light);
  text-indent: 0;
}
#readerBody .article-abstract strong {
  font-style: normal;
  font-weight: 600;
}
#readerBody sup.fn-ref {
  font-size: 0.65em;
  line-height: 0;
  vertical-align: super;
  color: var(--copper);
  cursor: pointer;
  font-family: var(--mono);
  padding: 0 1px;
}
#readerBody sup.fn-ref:hover {
  color: var(--copper-light);
  text-decoration: underline;
}
#readerBody .article-endnotes {
  margin-top: 2.5rem;
  padding-top: 1.2rem;
  border-top: 1px solid var(--ruled-light);
}
#readerBody .article-endnotes h4 {
  font-family: var(--mono);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #3F3326;
  margin-bottom: 0.8rem;
  text-indent: 0;
}
#readerBody .endnote {
  font-size: 0.82rem;
  line-height: 1.55;
  margin-bottom: 0.5rem;
  padding-left: 1.6rem;
  text-indent: -1.6rem;
  color: var(--ink-light);
}
#readerBody .endnote .fn-num {
  font-family: var(--mono);
  font-size: 0.72rem;
  color: var(--copper-dim);
  margin-right: 0.4rem;
}
#readerBody .article-bibliography {
  margin-top: 2rem;
  padding-top: 1rem;
  border-top: 1px solid var(--ruled-light);
}
#readerBody .article-bibliography h4 {
  font-family: var(--mono);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #3F3326;
  margin-bottom: 0.8rem;
  text-indent: 0;
}
#readerBody .bib-entry {
  font-size: 0.82rem;
  line-height: 1.55;
  margin-bottom: 0.45rem;
  padding-left: 2rem;
  text-indent: -2rem;
  color: var(--ink-light);
}
#readerBody .xref {
  font-style: italic;
  color: var(--copper-dim);
  font-size: 0.88em;
}

/* ═══ #3 SCROLL-TRIGGERED ENTRANCE ANIMATIONS ═══ */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
/* Entrance animations — applied by IntersectionObserver, never hides content */
@keyframes sectionEnter {
  from { opacity: 0.3; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}
.entered {
  animation: sectionEnter 0.65s cubic-bezier(0.22,1,0.36,1) both;
}
@media (prefers-reduced-motion: reduce) {
  .entered { animation: none; }
}

/* ═══ #4 SECTION DIVIDERS ═══ */
section + section::before {
  content: "· · ·   ◆   · · ·";
  display: block;
  text-align: center;
  font-family: var(--serif);
  font-size: 0.85rem;
  letter-spacing: 0.3em;
  color: var(--ruled);
  padding: 1.2rem 0 2.5rem;
  opacity: 0.7;
}
/* No divider before the first section or the articles section (has its own header) */
section:first-of-type::before,
section.wide + section::before { content: none; }

/* ═══ #5 PLATE HOVER ENRICHMENT ═══ */
.plate-wrap {
  transition: box-shadow 0.4s ease, transform 0.4s ease;
}
.plate-wrap:hover {
  box-shadow: 0 8px 32px rgba(90,55,35,0.12), 0 2px 8px rgba(90,55,35,0.08);
  transform: translateY(-2px);
}

/* ═══ #9 王 BREATHING PULSE ═══ */
@keyframes wangBreathe {
  0%, 100% { opacity: 0.018; }
  50%      { opacity: 0.032; }
}
body::before {
  animation: wangBreathe 10s ease-in-out infinite;
}
@media (prefers-reduced-motion: reduce) {
  body::before { animation: none; }
}

/* ═══ #2 PRINT STYLESHEET ═══ */
@media print {
  body { background: white !important; color: #1a1a1a !important; font-size: 11pt; }
  body::before { display: none !important; }
  .pi-seal, .pi-seal-hang, .lang-bar, .skip-link,
  .reader-overlay, .gate-overlay, .hero-cta,
  #witnessCounter { display: none !important; }
  /* v21: Show QuickStart in print with black border instead of copper */
  #agentsEditors { display: block !important; border-color: #3F3326 !important; }
  .jurisdiction-panel:not(#agentsEditors):not(#readingPositionPanel) { display: none !important; }
  /* v21: Force open Volume 0 chapter details and At a Glance details */
  details.curator-shelf { display: block !important; }
  details.curator-shelf > summary { display: none !important; }
  details.curator-shelf > * { display: block !important; }
  details.at-a-glance-details { display: block !important; }
  details.at-a-glance-details[open] > * { display: block !important; }
  details.at-a-glance-details > summary { display: none !important; }
  details.at-a-glance-details > * { display: block !important; }
  section { break-inside: avoid; page-break-inside: avoid; padding: 1.5rem 0; }
  .plate-wrap { break-inside: avoid; box-shadow: none !important; border: 1px solid #ccc; }
  a { color: #1a1a1a !important; text-decoration: underline; }
  a[href]::after { content: " (" attr(href) ")"; font-size: 8pt; color: #3F3326; }
  .volume-card { border: 1px solid #ccc; break-inside: avoid; }
}



/* ═══ BILLION-DOLLAR PASS ═══ */

/* --- Drop caps on key prose sections --- */
.emotional-pitch .pitch-lead::first-letter {
  font-family: var(--serif);
  font-size: 3.8em;
  float: left;
  line-height: 0.78;
  margin: 0.08em 0.12em 0 -0.04em;
  color: var(--copper-dim);
  font-weight: 600;
}

#readerBody > p:first-child::first-letter {
  font-family: var(--serif);
  font-size: 3.4em;
  float: left;
  line-height: 0.78;
  margin: 0.08em 0.1em 0 -0.03em;
  color: var(--copper-dim);
  font-weight: 600;
}

/* --- Frontispiece: staggered entrance --- */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.frontispiece .cartouche {
  animation: fadeInUp 1.2s cubic-bezier(0.22, 1, 0.36, 1) 0.15s both;
}
.frontispiece-glyph {
  animation: fadeIn 1.8s ease 0.6s both;
}
.frontispiece-atlas {
  animation: fadeInUp 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.5s both;
}
.frontispiece h1 {
  animation: fadeInUp 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.7s both;
}
.frontispiece-sub {
  animation: fadeInUp 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.9s both;
}
.frontispiece-long {
  animation: fadeInUp 0.9s cubic-bezier(0.22, 1, 0.36, 1) 1.1s both;
}
.frontispiece-pitch-teaser {
  animation: fadeIn 1.2s ease 0.95s both;
}
.frontispiece-warning {
  animation: fadeIn 1.4s ease 1.6s both;
}
.hero-cta {
  animation: fadeInUp 0.8s cubic-bezier(0.22, 1, 0.36, 1) 1.4s both;
}
.pi-seal {
  animation: fadeIn 1.8s ease 1.8s both;
}

@media (prefers-reduced-motion: reduce) {
  .frontispiece .cartouche,
  .frontispiece-glyph,
  .frontispiece-atlas,
  .frontispiece h1,
  .frontispiece-sub,
  .frontispiece-pitch-teaser,
  .frontispiece-long,
  .frontispiece-warning,
  .hero-cta,
  .pi-seal { animation: none; }
}

/* --- Section dividers: refined ornament --- */
.section-rule::before, .section-rule::after {
  background: linear-gradient(90deg, transparent, var(--ruled), transparent);
  height: 1px;
}

/* --- Volume cards: hover depth + stagger --- */
.volume-card {
  transition: border-color 0.3s, box-shadow 0.4s ease, transform 0.4s ease;
}
.volume-card:hover {
  border-color: var(--copper-dim);
  box-shadow: 0 8px 32px rgba(42,31,20,0.10), 0 2px 8px rgba(42,31,20,0.06);
  transform: translateY(-3px);
}

/* --- Chapter items: refined interaction --- */
.chapter-item {
  transition: background 0.2s, color 0.2s, padding-left 0.25s ease;
}
.chapter-item:hover {
  padding-left: 0.8rem;
}

/* --- Article cards: refined depth on hover --- */
.article-card:hover, .featured-article-card:hover {
  box-shadow: 0 8px 28px rgba(42,31,20,0.10), 0 2px 8px rgba(42,31,20,0.05);
}

/* --- Claim/blockquote section: ornamental rules --- */
.claim::before { content: '⸻'; letter-spacing: 0.25em; font-size: 0.9rem; }
.claim::after { content: '⸻'; letter-spacing: 0.25em; font-size: 0.9rem; }

/* --- Bio full toggle button --- */
.bio-full-toggle-wrap {
  margin-top: 1.5rem;
  padding-top: 1rem;
  border-top: 1px solid var(--ruled-light);
}
.bio-full-toggle {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.4rem 0;
  transition: color 0.2s;
}
.bio-full-toggle:hover .bio-accordion-label,
.bio-full-toggle:hover .bio-accordion-arrow {
  color: var(--copper);
}
.bio-full-toggle .bio-accordion-arrow {
  transition: transform 0.3s ease, color 0.2s;
}

/* --- Bio accordion (inside bioFull) --- */
.bio-accordion {
  margin-top: 2rem;
  border-top: 2px solid var(--ruled);
  padding-top: 0.8rem;
}
.bio-accordion-summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.8rem 1rem;
  border: 1px solid var(--ruled);
  background: rgba(255,255,255,0.4);
  transition: all 0.25s;
}
.bio-accordion-summary::-webkit-details-marker { display: none; }
.bio-accordion-summary:hover {
  border-color: var(--copper);
  background: rgba(255,255,255,0.6);
}
.bio-accordion-label {
  font-family: var(--fell);
  font-size: 0.88rem;
  font-style: italic;
  letter-spacing: 0.04em;
  color: var(--ink-light);
  transition: color 0.2s;
}
.bio-accordion-arrow {
  font-size: 0.8rem;
  color: var(--copper);
  transition: transform 0.3s ease, color 0.2s;
}
.bio-accordion[open] .bio-accordion-arrow {
  transform: rotate(90deg);
}
.bio-accordion-summary:hover .bio-accordion-label {
  color: var(--copper);
}
.bio-accordion-body {
  padding: 1.5rem 0 0;
}

/* --- Refined scrollbar (webkit) --- */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--parchment-dark); }
::-webkit-scrollbar-thumb { 
  background: var(--ruled); 
  border-radius: 4px;
  border: 2px solid var(--parchment-dark);
}
::-webkit-scrollbar-thumb:hover { background: var(--copper-dim); }

/* Firefox scrollbar */
html {
  scrollbar-width: thin;
  scrollbar-color: var(--ruled) var(--parchment-dark);
}

/* --- Reader overlay: refined entrance --- */
@keyframes readerEnter {
  from { opacity: 0; }
  to { opacity: 1; }
}
.reader-overlay.active {
  animation: readerEnter 0.3s ease both;
}

/* --- Navigation: active section indicator --- */
nav a.nav-active {
  color: var(--copper) !important;
  border-bottom: 1px solid var(--copper);
  padding-bottom: 0.1rem;
}

/* --- Table: refined cell hover --- */
.map-table tbody tr {
  transition: background 0.2s;
}
.map-table tbody tr:hover {
  background: rgba(139,69,19,0.04);
}

/* --- Plate wraps: subtle parallax-like depth --- */
.plate-wrap {
  position: relative;
  overflow: hidden;
}
.plate-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.08) 0%, transparent 30%, transparent 70%, rgba(0,0,0,0.03) 100%);
  pointer-events: none;
}

/* --- Colophon: refined spacing --- */
.colophon {
  position: relative;
}
.colophon::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 60px;
  height: 1px;
  background: var(--copper-dim);
  opacity: 0.5;
}

/* --- Contact section: refined layout --- */
.contact {
  position: relative;
}
.contact::before {
  content: '✦';
  position: absolute;
  top: -0.7rem;
  left: 50%;
  transform: translateX(-50%);
  background: var(--parchment);
  padding: 0 0.8rem;
  color: var(--ruled);
  font-size: 0.7rem;
}

/* --- System bar: refined pulse --- */
@keyframes barPulse {
  0%, 100% { opacity: 0.6; }
  50% { opacity: 0.85; }
}
.system-bar .witness-count {
  animation: barPulse 4s ease-in-out infinite;
}
@media (prefers-reduced-motion: reduce) {
  .system-bar .witness-count { animation: none; }
}

/* --- Smooth section transitions for IntersectionObserver --- */
@keyframes sectionEnterRefined {
  from { opacity: 0; transform: translateY(22px); }
  to { opacity: 1; transform: translateY(0); }
}
.entered {
  animation: sectionEnterRefined 0.75s cubic-bezier(0.22, 1, 0.36, 1) both;
}

/* --- Emotional pitch: subtle left border accent --- */
.emotional-pitch {
  border-left: 2px solid rgba(139,69,19,0.15);
  border-bottom: 1px solid var(--ruled);
}

/* --- Philosophy points: numbered marker feel --- */
.phil-point {
  position: relative;
  padding-left: 0;
}
.phil-point h3 {
  position: relative;
}

/* --- Keyboard activation for onclick cards --- */
.article-card[role="button"],
.featured-article-card[role="button"] {
  cursor: pointer;
}

/* --- Print refinements --- */
@media print {
  details.bio-accordion:not([open]) > :not(summary){ display:block !important; }
  .bio-accordion-summary { display: none; }
  .bio-accordion-body { display: block !important; }
  #bioFull { display: block !important; }
  .bio-full-toggle-wrap { display: none; }
  a[href]::after { content: none !important; }
  a.mini-link[href]::after { content: " (" attr(href) ")"; font-size: 7pt; }
}

/* --- Subtle page-edge vignette --- */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background: radial-gradient(ellipse at center, transparent 65%, rgba(42,31,20,0.06) 100%);
}

/* --- Double-spaces in sections fixed via style --- */
section { scroll-margin-top: 5rem; }




.frontispiece{background:radial-gradient(circle at 50% 18%,rgba(139,69,19,.14),transparent 24rem),linear-gradient(180deg,rgba(240,230,211,.82),rgba(228,213,190,.96));}.cartouche{box-shadow:0 28px 80px rgba(42,31,20,.18), inset 0 0 0 1px rgba(255,255,255,.35)}.jurisdiction-panel,.volume-card,.article-card,.letter{background:linear-gradient(180deg,var(--parchment-light),#efe0c6);box-shadow:0 12px 40px rgba(42,31,20,.11)}.volume-card:nth-child(2n){background:linear-gradient(180deg,#f6ead6,#e7d3b2)}.volume-card:nth-child(3n){background:linear-gradient(180deg,#edf2ed,#dccfb6)}.article-card:nth-child(4n+1){border-color:var(--copper);}.article-card:nth-child(4n+2){border-color:var(--sea);}.article-card:nth-child(4n+3){border-color:#6b4e8a;}.article-card:nth-child(4n+4){border-color:#8a5a34;}.coda-nav-link{border:1px solid var(--copper);padding:.2rem .55rem;background:rgba(139,69,19,.08)}.anchor-alias{position:relative;top:-5rem;display:block;height:0;overflow:hidden}.mini-link{font-family:var(--mono);font-size:.62rem;margin-left:.4rem;color:var(--copper)}

/* Article page additions */
.article-page-shell{max-width:900px;margin:0 auto;padding:7rem 1.5rem 6rem;position:relative;z-index:1}.article-folio{border:2px solid var(--ruled);background:linear-gradient(180deg,var(--parchment-light),#efe0c6);padding:3rem;box-shadow:0 20px 70px rgba(42,31,20,.14);position:relative}.article-folio:before{content:"";position:absolute;inset:7px;border:1px solid var(--ruled-light);pointer-events:none}.article-folio h1{font-family:var(--serif);font-size:2.4rem;font-weight:400;line-height:1.15;margin:0 0 1rem;color:var(--ink)}.article-folio h2{font-size:1.4rem;margin-top:2rem}.article-folio h3{font-size:.92rem;letter-spacing:.12em;text-transform:uppercase;color:var(--copper-dim);font-family:var(--mono)}.article-folio p,.article-folio li{font-size:.98rem;color:var(--ink-light)}.article-kicker{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:#3F3326;margin-bottom:.6rem}.article-navline{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin:0 0 1.2rem}.article-navline a{font-family:var(--fell);font-style:italic;color:var(--copper);text-decoration:none}.article-mark{font-size:2.5rem;text-align:center;color:var(--copper);opacity:.55;margin:1rem 0}.site-map-list{columns:2;column-gap:2rem}.site-map-list li{break-inside:avoid}.download-card{border:1px solid var(--ruled);background:rgba(255,255,255,.25);padding:1rem 1.2rem;margin:1rem 0}.download-card a{font-family:var(--mono);font-size:.78rem;color:var(--copper)}
@media(max-width:700px){.article-folio{padding:2rem 1.25rem}.article-page-shell{padding-top:5rem}.site-map-list{columns:1}}


/* Load-order note: atlantic-palette.css governs final render; this file also carries the new root variables for inspection. */


/* ═══ FULL CRITICAL ARTICLE BODY (journal-style companion articles) ═══ */
.article-folio.full-article { max-width: 920px; }
.article-folio.full-article h1 { margin-bottom: 0.75rem; }
.article-folio.full-article p { text-indent: 0; }
.article-folio.full-article p.article-subtitle,
.article-folio.full-article p.article-byline,
.article-folio.full-article p.jurisdiction-notice { text-indent: 0; }
.article-folio.full-article p.article-subtitle {
  margin: 0 0 0.4rem;
  color: var(--ink);
  font-size: 1.08rem;
}
.article-folio.full-article p.article-byline {
  margin-bottom: 0.9rem;
  font-family: var(--fell);
  font-size: 0.86rem;
  font-style: italic;
  color: #3F3326;
}
.article-folio.full-article p.jurisdiction-notice {
  margin: 0 0 1.5rem;
  padding: 0.8rem 1rem;
  border-left: 2px solid var(--copper);
  background: rgba(255,255,255,0.35);
  font-family: var(--mono);
  font-size: 0.62rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #3F3326;
}
.article-folio.full-article .article-abstract {
  margin: 1.2rem 0 2rem;
  padding: 1rem 1.4rem;
  border-left: 2px solid var(--ruled);
  background: rgba(255,255,255,0.3);
  font-size: 0.9rem;
  line-height: 1.7;
  font-style: italic;
  color: var(--ink-light);
  text-indent: 0;
}
.article-folio.full-article .article-abstract strong { font-style: normal; font-weight: 600; }
.article-folio.full-article .article-break {
  text-align: center;
  margin: 2.4rem 0;
  color: #3F3326;
  letter-spacing: 0.5em;
  font-size: 0.9rem;
}
.article-folio.full-article h4.article-section {
  font-family: var(--serif);
  font-size: 1.18rem;
  font-weight: 600;
  color: var(--ink);
  margin: 2.6rem 0 1rem;
  text-indent: 0;
}
.article-folio.full-article .article-emdash { text-align:center; margin:2.5rem 0 1rem; color: #3F3326; }
.article-folio.full-article .article-footer-line {
  text-align: center;
  font-family: var(--fell);
  font-size: 0.8rem;
  font-style: italic;
  color: #3F3326;
  margin: 0.2rem 0;
  text-indent: 0;
}
.article-folio.full-article sup.fn-ref {
  font-size: 0.65em;
  line-height: 0;
  vertical-align: super;
  color: var(--copper);
  font-family: var(--mono);
  padding: 0 1px;
}
.article-folio.full-article .article-endnotes,
.article-folio.full-article .article-bibliography {
  margin-top: 2.5rem;
  padding-top: 1.2rem;
  border-top: 1px solid var(--ruled-light);
}
.article-folio.full-article .article-endnotes h4,
.article-folio.full-article .article-bibliography h4 {
  font-family: var(--mono);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #3F3326;
  margin-bottom: 0.8rem;
  text-indent: 0;
}
.article-folio.full-article .endnote {
  font-size: 0.84rem;
  line-height: 1.58;
  margin-bottom: 0.5rem;
  padding-left: 1.6rem;
  text-indent: -1.6rem;
  color: var(--ink-light);
}
.article-folio.full-article .endnote .fn-num {
  font-family: var(--mono);
  font-size: 0.72rem;
  color: var(--copper-dim);
  margin-right: 0.4rem;
}
.article-folio.full-article .bib-entry {
  font-size: 0.84rem;
  line-height: 1.58;
  margin-bottom: 0.45rem;
  padding-left: 2rem;
  text-indent: -2rem;
  color: var(--ink-light);
}
.article-folio.full-article .xref { font-style: italic; color: var(--copper-dim); font-size: 0.88em; }
@media (max-width: 700px) {
  .article-folio.full-article { padding-left: 1.1rem; padding-right: 1.1rem; }
  .article-folio.full-article .article-abstract { padding: .85rem 1rem; }
}


/* === Copyright-page and cover-art integration pass — 2026-06-16 === */
.volume-cover-art {
  width: min(46vw, 260px);
  max-width: 80%;
  height: auto;
  display: block;
  margin: 0 auto 1.7rem;
  border: 1px solid rgba(35, 74, 115, 0.22);
  box-shadow: 0 18px 45px rgba(23, 33, 38, 0.13);
  border-radius: 4px;
  background: #0E2F36;
}
.copyright-page {
  max-width: 44rem;
  margin: 0 auto;
  padding: 4rem 2rem 5rem;
  page-break-before: always;
  page-break-after: always;
  break-before: page;
  break-after: page;
  color: var(--ink, #1a1a1a);
  background: transparent;
  font-family: var(--body, var(--serif, Georgia, serif));
  line-height: 1.72;
}
.copyright-page .copyright-kicker {
  font-family: var(--sans, system-ui, sans-serif);
  font-size: .68rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted, var(--ink-faded, #3F3326));
  margin-bottom: 1.1rem;
}
.copyright-page h2 {
  font-family: var(--serif, Georgia, serif);
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  line-height: 1.12;
  font-weight: 500;
  color: var(--accent-dark, var(--ink, #1a1a1a));
  margin: 0 0 1.4rem;
  border: 0;
  padding: 0;
}
.copyright-page p { text-indent: 0 !important; text-align: left; margin: 0 0 .8rem; }
.copyright-page .copyright-rule { border: 0; border-top: 1px solid var(--rule, rgba(0,0,0,.18)); margin: 1.5rem 0; }
.copyright-page .rights-note { font-size: .92rem; color: var(--ink-soft, #3D4A50); }
.copyright-page .intertextual-notice {
  margin-top: 1.4rem;
  padding: 1rem 1.15rem;
  border-left: 3px solid var(--accent, #174C55);
  background: rgba(255,255,255,.38);
}
.copyright-page h3 {
  font-family: var(--sans, system-ui, sans-serif);
  font-size: .76rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent-dark, #174C55);
  margin: 0 0 .65rem;
}
.site-copyright-footer {
  margin: 3rem auto 0;
  padding: 1.25rem 1rem 2.4rem;
  max-width: 900px;
  text-align: center;
  border-top: 1px solid var(--ruled-light, var(--rule, rgba(0,0,0,.16)));
  color: var(--ink-faded, var(--muted, #3F3326));
  font-family: var(--sans, system-ui, sans-serif);
  font-size: .72rem;
  line-height: 1.55;
  letter-spacing: .04em;
}
.site-copyright-footer p { margin: .15rem 0; text-indent: 0 !important; text-align: center !important; }
.volume-cover-thumb {
  display: block;
  width: 100%;
  max-width: 420px;
  height: auto;
  margin: 0 auto 1.25rem;
  border: 1px solid var(--ruled, var(--rule, rgba(0,0,0,.18)));
  box-shadow: 0 16px 42px rgba(23, 33, 38, .12);
  background: var(--sea-dark, #0E2F36);
  border-radius: 3px;
}
@media (max-width: 640px) {
  .volume-cover-art { width: min(72vw, 230px); }
  .copyright-page { padding: 3rem 1.2rem 4rem; }
}


/* === CRISP GREEN-BAR LEGIBILITY PATCH — 2026-06-16 ===
   Removes faux-bold italic + text-shadow blur on dark green/teal bars.
*/
.map-table thead th,
table.map-table th {
  background: linear-gradient(180deg, #0E2F36 0%, #174C55 100%) !important;
  color: #FFF9ED !important;
  font-family: var(--sans) !important;
  font-style: normal !important;
  font-weight: 600 !important;
  font-size: 0.70rem !important;
  letter-spacing: 0.09em !important;
  text-transform: uppercase !important;
  text-shadow: none !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  text-rendering: optimizeLegibility !important;
  border-color: rgba(255, 249, 237, 0.42) !important;
}
.map-table thead th *,
table.map-table th * { color: inherit !important; font-family: inherit !important; font-style: inherit !important; font-weight: inherit !important; text-shadow: none !important; }
.chapter-summary,
.reader-guide-card summary,
details.reader-guide-card > summary,
.chapter-card.full-guide .chapter-summary,
.chapter-card.residue-guide .chapter-summary,
.chapter-card.orientation-guide .chapter-summary,
.chapter-card.withheld-guide .chapter-summary { color: #FFF9ED !important; text-shadow: none !important; -webkit-font-smoothing: antialiased !important; -moz-osx-font-smoothing: grayscale !important; }
.chapter-summary *,
.reader-guide-card summary *,
.chapter-card.full-guide .chapter-summary *,
.chapter-card.residue-guide .chapter-summary *,
.chapter-card.orientation-guide .chapter-summary *,
.chapter-card.withheld-guide .chapter-summary * { color: inherit !important; text-shadow: none !important; }
.chapter-chip,
.chapter-summary-meta { color: #F3E7D3 !important; text-shadow: none !important; }


/* Final crisp green-bar override */
.map-table thead th, table.map-table th{background:#174C55!important;color:#FFF9ED!important;text-shadow:none!important;font-family:var(--sans)!important;font-style:normal!important;font-weight:600!important;letter-spacing:.04em!important;-webkit-font-smoothing:antialiased!important;text-rendering:geometricPrecision!important;}
.map-table thead th *, table.map-table th *{color:inherit!important;text-shadow:none!important;}
.chapter-summary,.reader-guide-card summary,details.reader-guide-card>summary,.chapter-card.full-guide .chapter-summary,.chapter-card.residue-guide .chapter-summary,.chapter-card.orientation-guide .chapter-summary,.chapter-card.withheld-guide .chapter-summary{color:#FFF9ED!important;text-shadow:none!important;font-weight:600!important;-webkit-font-smoothing:antialiased!important;text-rendering:geometricPrecision!important;}
.chapter-summary *,.reader-guide-card summary *,.chapter-card.full-guide .chapter-summary *,.chapter-card.residue-guide .chapter-summary *,.chapter-card.orientation-guide .chapter-summary *,.chapter-card.withheld-guide .chapter-summary *{color:inherit!important;text-shadow:none!important;}
.chapter-chip,.chapter-summary-meta{color:#EAF6F2!important;text-shadow:none!important;}
#atlasContent.auth-locked{filter:none!important;}

/* === FOOTER + FIXED SYSTEM BAR READABILITY PATCH — 2026-06-16 === */
.site-copyright-footer {
  color: #4B3D2F !important;
  font-family: var(--sans, 'DM Sans', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif) !important;
  font-size: 0.74rem !important;
  line-height: 1.55 !important;
  letter-spacing: 0.025em !important;
  font-style: normal !important;
  font-weight: 500 !important;
  opacity: 1 !important;
  text-shadow: none !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  text-rendering: geometricPrecision !important;
}
.site-copyright-footer p {
  color: #4B3D2F !important;
  font-style: normal !important;
  font-weight: 500 !important;
  opacity: 1 !important;
  text-shadow: none !important;
}
.system-bar {
  background: #174C55 !important;
  color: #FFF9ED !important;
  font-family: var(--sans, 'DM Sans', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif) !important;
  font-size: 0.70rem !important;
  line-height: 1.45 !important;
  letter-spacing: 0.04em !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-top: 1px solid rgba(255, 249, 237, 0.45) !important;
  text-shadow: none !important;
}
.system-bar span,
.system-bar-left span,
.system-bar-right span,
.system-bar .witness-count {
  color: #FFF9ED !important;
  opacity: 1 !important;
  font-family: inherit !important;
  font-style: normal !important;
  font-weight: 600 !important;
  text-shadow: none !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  text-rendering: geometricPrecision !important;
}
.system-bar .witness-count {
  color: #F3E7D3 !important;
  animation: none !important;
}
.system-bar .glyph {
  color: #F3E7D3 !important;
  opacity: 0.95 !important;
  font-family: serif !important;
  font-weight: 400 !important;
  font-size: 0.95rem !important;
}
@media (max-width: 768px) {
  .system-bar {
    font-size: 0.62rem !important;
    line-height: 1.35 !important;
    padding: 0.38rem 0.75rem !important;
  }
}


/* FINAL READABILITY PASS
   No faint UI fonts. No ghosted footer. No translucent system-bar text.
   Green/teal bars use the same readable sans treatment everywhere. */
:root{
  --ink:#21180F!important;
  --ink-light:#2B2117!important;
  --ink-soft:#2F261C!important;
  --ink-faded:#3F3326!important;
  --ink-ghost:#3F3326!important;
  --muted:#3F4A56!important;
  --sea:#174C55!important;
  --sea-dark:#0E2F36!important;
  --accent-dark:#0E2F36!important;
}
html,body{color:#21180F!important;}
p,li,td,dd,dt,blockquote{color:#21180F;}
/* General formerly-faint interface text. */
.section-label,.section-rule-text,.frontispiece-atlas,.frontispiece-long,.frontispiece-warning,
.vol-number,.vol-meta,.vol-status,.vol-subtitle,.article-num,.article-sub,.fa-num,.fa-sub,
.plate-caption,.plate-legend,.plate-legend-grid,.legend-name,.timeline-date,.timeline-text p,
.credential-block p,.contact-note,.note,.meta,.kicker,.small-note,.article-kicker,.article-byline,
.article-subtitle,.article-abstract,.article-footer-line,.endnote,.bib-entry,.copyright-page,
.copyright-page p,.rights-notice,.rights-notice p,.chapter-number,.chapter-subtitle,.scene-break,
.title-page .series-title,.title-page .author,.title-page .subtitle,.form-label,.toc-num,
.block-meta,.thread-label,.toc a,.toc-scenes a,.sidebar-brand span,.search-status,
.cover .subtitle,.cover .designation,.path-desc,.use-line,.pi-filing,.pi-filing::before,
.chapter-chip,.chapter-summary-meta,.ch-num,.ch-arrow,.chapter-list-header,.mobile-title,
.auth-title,.auth-subtitle,.auth-footer,.auth-error,.lang-toggle,.auth-lang-toggle,
.reader-breadcrumb,.reader-chapter-sub,.map-group p,.workbook-section-card p,.tier-card p,
.sequence-card p,.spoiler-card p,.reader-card p,.formation-card p,.guide-card p,.withheld-card p{
  color:#2F261C!important;
  opacity:1!important;
  text-shadow:none!important;
  -webkit-font-smoothing:antialiased!important;
  -moz-osx-font-smoothing:grayscale!important;
  text-rendering:optimizeLegibility!important;
}
.section-label,.article-num,.fa-num,.vol-number,.vol-meta,.chapter-number,.toc-num,
.block-meta,.thread-label,.chapter-list-header,.form-label,.pi-filing::before{
  font-family:var(--sans,"DM Sans",system-ui,-apple-system,"Segoe UI",Arial,sans-serif)!important;
  font-style:normal!important;
  font-weight:700!important;
  letter-spacing:.07em!important;
}
/* Inline old gray text cannot override this pass. */
[style*="color: #666"],[style*="color:#666"],[style*="color: #777"],[style*="color:#777"],
[style*="color: #3F3326"],[style*="color:#3F3326"],
[style*="color: #4A3B2B"],[style*="color:#4A3B2B"],
[style*="color: var(--muted)"],[style*="color:var(--muted)"]{
  color:#2F261C!important;
  opacity:1!important;
  text-shadow:none!important;
}
/* Bottom system bar and copyright footer: readable green-bar treatment. */
.system-bar,.system-bar-left,.system-bar-right,.site-copyright-footer{
  background:#174C55!important;
  color:#FFF9ED!important;
  opacity:1!important;
  filter:none!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
  text-shadow:none!important;
  border-color:#0E2F36!important;
}
.system-bar,.system-bar *,.site-copyright-footer,.site-copyright-footer *{
  color:#FFF9ED!important;
  opacity:1!important;
  font-family:var(--sans,"DM Sans",system-ui,-apple-system,"Segoe UI",Arial,sans-serif)!important;
  font-style:normal!important;
  font-weight:600!important;
  letter-spacing:.06em!important;
  line-height:1.55!important;
  text-shadow:none!important;
  filter:none!important;
  -webkit-font-smoothing:antialiased!important;
  -moz-osx-font-smoothing:grayscale!important;
  text-rendering:geometricPrecision!important;
}
.site-copyright-footer{
  max-width:none!important;
  width:100%!important;
  margin:0!important;
  padding:1rem 1.25rem 2.25rem!important;
  border-top:2px solid #0E2F36!important;
  text-align:center!important;
}
.site-copyright-footer p{margin:.1rem 0!important;text-indent:0!important;text-align:center!important;}
.system-bar .glyph{color:#FFF9ED!important;opacity:1!important;font-weight:500!important;}
.system-bar .witness-count{color:#FFE8B8!important;opacity:1!important;font-weight:800!important;}
/* All dark table / accordion / guide bars. */
.map-table thead th,table.map-table th,th,
.chapter-summary,.reader-guide-card summary,details.reader-guide-card>summary,
.functional-translation>summary,.german-term-index>summary,.toc a.active,
.chapter-card.full-guide .chapter-summary,.chapter-card.residue-guide .chapter-summary,
.chapter-card.orientation-guide .chapter-summary,.chapter-card.withheld-guide .chapter-summary{
  background:#174C55!important;
  color:#FFF9ED!important;
  opacity:1!important;
  text-shadow:none!important;
  font-family:var(--sans,"DM Sans",system-ui,-apple-system,"Segoe UI",Arial,sans-serif)!important;
  font-style:normal!important;
  font-weight:700!important;
  letter-spacing:.035em!important;
  -webkit-font-smoothing:antialiased!important;
  -moz-osx-font-smoothing:grayscale!important;
  text-rendering:geometricPrecision!important;
}
.map-table thead th *,table.map-table th *,th *,
.chapter-summary *,.reader-guide-card summary *,details.reader-guide-card>summary *,
.functional-translation>summary *,.german-term-index>summary *,.toc a.active *{
  color:inherit!important;
  opacity:1!important;
  text-shadow:none!important;
  font-family:inherit!important;
  font-style:inherit!important;
  font-weight:inherit!important;
}
.chapter-chip,.chapter-summary-meta{color:#F3E7D3!important;opacity:1!important;text-shadow:none!important;font-weight:700!important;}
/* Colophons stay literary, but they are no longer ghost text. */
footer:not(.site-copyright-footer),.colophon,.colophon *{
  color:#2B2117!important;
  opacity:1!important;
  text-shadow:none!important;
}
.colophon-title,.colophon-legal{
  font-family:var(--sans,"DM Sans",system-ui,-apple-system,"Segoe UI",Arial,sans-serif)!important;
  font-style:normal!important;
  font-weight:600!important;
  letter-spacing:.045em!important;
}
.colophon-text{
  color:#2B2117!important;
  font-weight:400!important;
  line-height:1.75!important;
}
/* Search/sidebar/link microtext. */
.sidebar,.sidebar *:not(.toc a.active),.mobile-topbar,.mobile-topbar *{
  opacity:1!important;
  text-shadow:none!important;
}
.sidebar .toc a,.sidebar-brand span,.search-status,.search-results a,.search-result-snippet{
  color:#2F261C!important;
  font-weight:500!important;
}
/* Covers: never render title art under/over the readable title plaque. */
.volume-cover-thumb,.volume-cover-art{
  background:#0E2F36!important;
}
#atlasContent.auth-locked{filter:none!important;}



/* DEFINITIVE NOVEL MENU BAR FIX
   All top-level sidebar / TOC menu bars have cream text on dark teal.
   This overrides earlier passes, visited states, active states, and browser text-fill quirks. */

/* Top-level menu bars: Title Page, Author’s Preface, Chapters, Kapitel, etc. */
html body aside.sidebar nav.toc ol.toc-list > li > a,
html body aside.sidebar nav.toc ol.toc-list > li > a:link,
html body aside.sidebar nav.toc ol.toc-list > li > a:visited,
html body aside.sidebar nav.toc ol.toc-list > li > a:hover,
html body aside.sidebar nav.toc ol.toc-list > li > a:focus,
html body aside.sidebar nav.toc ol.toc-list > li > a:active,
html body nav.toc ol.toc-list > li > a,
html body nav.toc ol.toc-list > li > a:link,
html body nav.toc ol.toc-list > li > a:visited,
html body nav.toc ol.toc-list > li > a:hover,
html body nav.toc ol.toc-list > li > a:focus,
html body nav.toc ol.toc-list > li > a:active,
html body .toc-list > li > a,
html body .toc-list > li > a:link,
html body .toc-list > li > a:visited,
html body .toc-list > li > a:hover,
html body .toc-list > li > a:focus,
html body .toc-list > li > a:active {
  display: block !important;
  margin: 0 0 7px 0 !important;
  padding: 7px 10px !important;
  border-radius: 10px !important;
  background: #174C55 !important;
  background-image: none !important;
  color: #FFF9ED !important;
  -webkit-text-fill-color: #FFF9ED !important;
  caret-color: #FFF9ED !important;
  opacity: 1 !important;
  font-family: var(--sans, "DM Sans", system-ui, -apple-system, "Segoe UI", Arial, sans-serif) !important;
  font-style: normal !important;
  font-size: .84rem !important;
  font-weight: 800 !important;
  letter-spacing: .015em !important;
  line-height: 1.28 !important;
  text-transform: none !important;
  text-decoration: none !important;
  text-decoration-color: #FFF9ED !important;
  text-shadow: none !important;
  filter: none !important;
  border: 1px solid #0E2F36 !important;
  box-shadow: none !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  text-rendering: geometricPrecision !important;
}

/* Active top-level menu item: darker border/selection but still readable. */
html body aside.sidebar nav.toc ol.toc-list > li > a.active,
html body nav.toc ol.toc-list > li > a.active,
html body .toc-list > li > a.active {
  background: #0E2F36 !important;
  background-image: none !important;
  color: #FFF9ED !important;
  -webkit-text-fill-color: #FFF9ED !important;
  border-color: #D8C5A5 !important;
  box-shadow: inset 0 0 0 2px rgba(255,249,237,.18) !important;
}

/* Any nested content inside top-level bars. */
html body aside.sidebar nav.toc ol.toc-list > li > a *,
html body nav.toc ol.toc-list > li > a *,
html body .toc-list > li > a * {
  color: #FFF9ED !important;
  -webkit-text-fill-color: #FFF9ED !important;
  opacity: 1 !important;
  font-family: inherit !important;
  font-style: normal !important;
  font-weight: inherit !important;
  text-shadow: none !important;
}

/* Beat/scene links: plain subordinate text, except active scene. */
html body aside.sidebar nav.toc ol.toc-list > li > ol.toc-scenes,
html body nav.toc ol.toc-list > li > ol.toc-scenes,
html body .toc-scenes,
html body .chapter-toc {
  margin: 2px 0 10px 14px !important;
  padding-left: 9px !important;
  border-left: 1px dashed rgba(23,76,85,.42) !important;
}

html body aside.sidebar nav.toc ol.toc-list > li > ol.toc-scenes a,
html body nav.toc ol.toc-list > li > ol.toc-scenes a,
html body .toc-scenes a,
html body .chapter-toc a {
  display: block !important;
  margin: 0 0 2px 0 !important;
  padding: 4px 8px !important;
  border-radius: 6px !important;
  background: transparent !important;
  background-image: none !important;
  color: #21180F !important;
  -webkit-text-fill-color: #21180F !important;
  opacity: 1 !important;
  font-family: var(--sans, "DM Sans", system-ui, -apple-system, "Segoe UI", Arial, sans-serif) !important;
  font-style: normal !important;
  font-size: .78rem !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 1.25 !important;
  text-transform: none !important;
  text-decoration: none !important;
  text-shadow: none !important;
  border: 0 !important;
  box-shadow: none !important;
}

html body aside.sidebar nav.toc ol.toc-list > li > ol.toc-scenes a.active,
html body nav.toc ol.toc-list > li > ol.toc-scenes a.active,
html body .toc-scenes a.active,
html body .chapter-toc a.active {
  background: #174C55 !important;
  background-image: none !important;
  color: #FFF9ED !important;
  -webkit-text-fill-color: #FFF9ED !important;
  border: 1px solid #0E2F36 !important;
  font-weight: 750 !important;
}

/* Volume II internal labeled bars. */
html body .thread-label,
html body .thread-block .thread-label {
  background: #174C55 !important;
  background-image: none !important;
  color: #FFF9ED !important;
  -webkit-text-fill-color: #FFF9ED !important;
  opacity: 1 !important;
  display: inline-block !important;
  padding: 4px 10px !important;
  border-radius: 999px !important;
  border: 1px solid #0E2F36 !important;
  font-family: var(--sans, "DM Sans", system-ui, -apple-system, "Segoe UI", Arial, sans-serif) !important;
  font-style: normal !important;
  font-size: .72rem !important;
  font-weight: 800 !important;
  letter-spacing: .075em !important;
  line-height: 1.35 !important;
  text-transform: uppercase !important;
  text-shadow: none !important;
}
html body .thread-label *,
html body .thread-block .thread-label * {
  color: #FFF9ED !important;
  -webkit-text-fill-color: #FFF9ED !important;
  opacity: 1 !important;
}

/* Final bottom green-bar readability pass.
   This specifically fixes the copyright/footer band above the fixed system bar. */
html body .site-copyright-footer,
html body footer.site-copyright-footer,
html body .site-copyright-footer * {
  background: #174C55 !important;
  background-image: none !important;
  color: #FFF9ED !important;
  -webkit-text-fill-color: #FFF9ED !important;
  opacity: 1 !important;
  text-shadow: none !important;
  filter: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  font-family: var(--sans, "DM Sans", system-ui, -apple-system, "Segoe UI", Arial, sans-serif) !important;
  font-style: normal !important;
  font-weight: 700 !important;
  letter-spacing: .045em !important;
  line-height: 1.55 !important;
  text-align: center !important;
  text-decoration: none !important;
}
html body .site-copyright-footer {
  display: block !important;
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 1rem 1.25rem 2.35rem !important;
  border-top: 2px solid #0E2F36 !important;
  border-bottom: 1px solid #0E2F36 !important;
  box-shadow: none !important;
}
html body .site-copyright-footer p,
html body .site-copyright-footer div,
html body .site-copyright-footer span {
  margin: .1rem 0 !important;
  padding: 0 !important;
  color: #FFF9ED !important;
  -webkit-text-fill-color: #FFF9ED !important;
  opacity: 1 !important;
  text-indent: 0 !important;
}
/* Fixed bottom system bar stays readable too. */
html body .system-bar,
html body .system-bar * {
  background-color: #174C55 !important;
  color: #FFF9ED !important;
  -webkit-text-fill-color: #FFF9ED !important;
  opacity: 1 !important;
  text-shadow: none !important;
  filter: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  font-family: var(--sans, "DM Sans", system-ui, -apple-system, "Segoe UI", Arial, sans-serif) !important;
  font-style: normal !important;
  font-weight: 700 !important;
  letter-spacing: .055em !important;
}
html body .system-bar {
  border-top: 2px solid #0E2F36 !important;
}
html body .system-bar .witness-count {
  color: #FFE8B8 !important;
  -webkit-text-fill-color: #FFE8B8 !important;
  font-weight: 900 !important;
}
