@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400&family=Texturina:opsz,wght@12..72,400;12..72,700;12..72,900&family=Vollkorn:ital,wght@0,400;0,600;0,700;0,900;1,400;1,600&display=swap');


/* ── Zarathustra ────────────────────────────────────────── */
@font-face {
  font-family: 'Zarathustra';
  src: url('fonts/zarathustra.woff') format('woff');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* ── PALETTE ─────────────────────────────────────────────
   Every surface is a warm parchment tone.
   No dark backgrounds anywhere except intentional overlays
   on images (semi-transparent only).
──────────────────────────────────────────────────────── */
:root {
  --p0: #faf3e4;   /* lightest — page base          */
  --p1: #f0e4cc;   /* cards, panels, nav, sidebar   */
  --p2: #e4d4b4;   /* deeper panels, breadcrumb     */
  --p3: #d4c09a;   /* borders, rules                */
  --t0: #1c1008;   /* headline text                 */
  --t1: #2e1c0e;   /* body text                     */
  --t2: #5a3820;   /* secondary text                */
  --t3: #8a6038;   /* labels, captions              */
  --au: #9a7010;   /* gold accent                   */
  --ab: #c89828;   /* bright gold                   */
  /* ── Aliases for component compatibility ─────────── */
  --bg0: var(--p0);
  --bg1: var(--p0);
  --bg2: var(--p1);
  --bg3: var(--p2);
  --border: var(--p3);
  --gold: var(--au);
  --nh: 52px;
  --sw: 248px;
  --serif: 'Playfair Display', Georgia, serif;
  --sans:  'DM Sans', system-ui, sans-serif;
}

/* ── RESET ───────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; background-color: #faf3e4; } /* Chrome fix: explicit bg on html */
body {
  font-family: 'Vollkorn', Georgia, serif;
  font-size: 18px;
  line-height: 1.8;
  background: var(--p0);
  color: var(--t1);
  -webkit-font-smoothing: antialiased;
}
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--p1); }
::-webkit-scrollbar-thumb { background: var(--p3); border-radius: 2px; }

/* ── TOP NAV ─────────────────────────────────────────── */
.tnav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 900;
  height: var(--nh);
  background: var(--p1);
  background-color: #f0e4cc; /* Chrome explicit fallback */
  border-bottom: 1px solid var(--p3);
  display: flex; align-items: center;
  padding: 0 1.8rem; gap: 1.2rem;
  transition: transform .25s ease;
}
.tnav.away { transform: translateY(-100%); }

.tnav-brand {
  font-family: 'Texturina', var(--serif); font-optical-sizing: auto; font-size: 1rem; font-weight: 700;
  color: var(--t0); text-decoration: none; letter-spacing: .05em;
  flex-shrink: 0;
  text-shadow: 0 1px 2px rgba(28,16,8,.15);
}
.tnav-rule { width: 1px; height: 14px; background: var(--p3); flex-shrink: 0; margin: 0 .3rem; }

.tnav-vols { display: flex; align-items: center; gap: 1rem; }
.tnav-vol { font-family: 'Zarathustra', var(--serif); font-size: .72rem; font-weight: 400; color: var(--t2); letter-spacing: .06em; }
.tnav-vol:hover    { color: var(--t0); background: var(--p2); border-color: var(--p3); }
.tnav-vol.current { font-family: 'Zarathustra', var(--serif); font-size: .75rem; color: var(--au); letter-spacing: .04em; }
.tnav-vol.soon     { opacity: .35; pointer-events: none; }
.tnav-vol-badge    { font-size: .4rem; letter-spacing: .1em; text-transform: uppercase; }

/* ── SIDEBAR ─────────────────────────────────────────── */
.sidebar {
  position: fixed; top: var(--nh); left: 0; bottom: 0; z-index: 800;
  width: var(--sw);
  background: var(--p1);
  background-color: #f0e4cc; /* Chrome explicit fallback */
  border-right: 1px solid var(--p3);
  display: flex; flex-direction: column;
  overflow-y: auto;
}
.sb-head { padding: 1.3rem 1rem 1rem; border-bottom: 1px solid var(--p3); text-decoration: none; display: block; }
.sb-vol-tag { display: none; }
.sb-vol-name { font-family: 'Texturina', var(--serif); font-optical-sizing: auto; font-size: 1.15rem; font-weight: 700; color: var(--t0); text-shadow: 0 1px 2px rgba(28,16,8,.15); }
.sb-vol-sub { font-family: 'Zarathustra', var(--serif); font-size: .72rem; color: var(--t2); letter-spacing: .02em; }

.sb-nav { flex: 1; padding: .5rem 0; }
.sb-group { display: flex; flex-direction: column; }

.sb-link { font-family: 'Zarathustra', var(--serif); font-size: .85rem; color: var(--t1); text-decoration: none; display: block; padding: .28rem .8rem; }
.sb-link:hover   { color: var(--t0); background: var(--p2); border-left-color: var(--p3); }
.sb-link.active  { color: var(--t0); background: var(--p2); border-left-color: var(--au); font-weight: 500; }
.sb-ico { font-size: .85rem; }
.sb-chev { margin-left: auto; font-size: .6rem; opacity: .38; transition: transform .17s; }
.sb-group.open .sb-chev { transform: rotate(90deg); }

.sb-children { display: none; padding-left: 1.8rem; }
.sb-group.open .sb-children { display: flex; flex-direction: column; }

.sb-child { font-family: 'Zarathustra', var(--serif); font-size: .82rem; color: var(--t1); display: block; padding: .22rem .5rem; border-radius: 2px; text-decoration: none; }
.sb-child:hover  { color: var(--t0); border-left-color: var(--p3); }
.sb-child.active { color: var(--t0); border-left-color: var(--au); font-weight: 400; }

.sb-foot { font-family: 'Zarathustra', var(--serif); font-size: .68rem; color: var(--t3); line-height: 1.6; padding: .8rem 1rem 1rem; }

/* ── LAYOUT WRAPPERS ─────────────────────────────────── */
/* Homepage: full width, below nav */
.layout-home {
  padding-top: var(--nh);
  display: flex; flex-direction: column; min-height: 100vh;
}
/* Volume pages: sidebar + content */
.layout-vol {
  padding-top: var(--nh);
  margin-left: var(--sw);
  display: flex; flex-direction: column;
  min-height: calc(100vh - var(--nh));
}

/* ── HERO (homepage) ─────────────────────────────────── */
.hero {
  background: var(--p1);
  min-height: 52vh;
  display: flex; align-items: center; justify-content: center;
  text-align: center; padding: 5rem 2rem 4rem;
  position: relative; overflow: hidden;
  border-bottom: 1px solid var(--p3);
}
/* Dot texture overlay — purely decorative, uses parchment colors */
.hero::before {
  content: '';
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, var(--p3) 1px, transparent 1px);
  background-size: 24px 24px;
  opacity: .35;
  pointer-events: none;
}
/* Vignette to soften dot edges */
.hero::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 80% at 50% 50%, transparent 30%, var(--p1) 100%);
  pointer-events: none;
}
.hero-content { position: relative; z-index: 1; }

.hero-eyebrow {
  font-size: .5rem; font-weight: 500; letter-spacing: .42em; text-transform: uppercase;
  color: var(--t3); margin-bottom: 1rem;
  display: flex; align-items: center; justify-content: center; gap: .75rem;
}
.hero-eyebrow::before,
.hero-eyebrow::after { content: ''; display: block; width: 32px; height: 1px; background: var(--p3); }

.hero-title {
  font-family: var(--serif);
  font-size: clamp(3.5rem, 9vw, 6rem);
  font-weight: 900; color: var(--t0);
  letter-spacing: .08em; line-height: .92;
  margin-bottom: .7rem;
  animation: rise .8s cubic-bezier(.16,1,.3,1) both;
}
.hero-ornament {
  display: flex; align-items: center; gap: .6rem;
  justify-content: center; margin-bottom: .7rem;
  animation: rise .6s .08s ease-out both;
}
.hero-ornament-line { width: 40px; height: 1px; background: var(--p3); }
.hero-ornament-gem  { width: 5px; height: 5px; background: var(--au); transform: rotate(45deg); }

.hero-sub {
  font-size: .58rem; letter-spacing: .28em; text-transform: uppercase;
  color: var(--t3); margin-bottom: 1.4rem;
  animation: rise .6s .04s ease-out both;
}
.hero-lede { font-family: 'Vollkorn', Georgia, serif; font-style: italic; }
@keyframes rise {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: none; }
}

/* ── VOLUME CARDS BAND ───────────────────────────────── */
.vol-band {
  background: var(--p0);
  padding: 2.8rem 3.2rem 4.5rem;
  flex: 1;
}
.vol-band-header {
  display: flex; align-items: center; gap: .9rem;
  margin-bottom: 2.2rem;
}
.vol-band-line  { flex: 1; height: 1px; background: var(--p3); }
.vol-band-label {
  font-size: .45rem; font-weight: 500; letter-spacing: .32em; text-transform: uppercase;
  color: var(--t3);
}
.vol-band-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.3rem; }

.wcard {
  background: var(--p1);
  border: 1px solid var(--p3); border-radius: 2px;
  overflow: hidden; display: flex; flex-direction: column;
  text-decoration: none; color: inherit;
  transition: transform .25s cubic-bezier(.16,1,.3,1), box-shadow .25s, border-color .25s;
}
.wcard:not(.locked):hover {
  transform: translateY(-3px) scale(1.008);
  box-shadow: 0 8px 28px rgba(90,56,8,.12), 0 0 0 1.5px var(--au);
  border-color: var(--au);
}
.wcard-img-wrap {
  width: 100%; aspect-ratio: 16/9; overflow: hidden;
  position: relative; flex-shrink: 0;
}
.wcard-img-wrap img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .38s cubic-bezier(.16,1,.3,1);
}
.wcard:not(.locked):hover .wcard-img-wrap img { transform: scale(1.04); }
/* Fade top and bottom of image into card background */
.wcard-img-fade {
  position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(
    to bottom,
    var(--p1) 0%,
    transparent 18%,
    transparent 72%,
    var(--p1) 100%
  );
}
.locked .wcard-img-wrap img { filter: saturate(.08) brightness(.7); }

.wcard-tags {
  position: absolute; top: .5rem; left: .5rem;
  display: flex; gap: .22rem; flex-wrap: wrap;
}
.wcard-tag {
  font-size: .48rem; font-weight: 600; letter-spacing: .07em; text-transform: uppercase;
  padding: .18rem .5rem; border-radius: 2px;
  background: rgba(250,243,228,.96); color: var(--t1);
  border: 1px solid var(--p3);
}
.locked .wcard-tag { opacity: .4; }

.wcard-body { padding: .65rem .95rem 1.05rem; flex: 1; display: flex; flex-direction: column; }
.wcard-name {
  font-family: var(--serif); font-size: 1.35rem; font-weight: 700;
  color: var(--t0); line-height: 1.05; margin-bottom: .12rem;
  transition: color .14s;
}
.wcard:not(.locked):hover .wcard-name { color: var(--au); }
.wcard-tagline {
  font-size: .46rem; font-weight: 500; letter-spacing: .11em; text-transform: uppercase;
  color: var(--t3); margin-bottom: .48rem;
}
.wcard-desc {
  font-size: .82rem; font-weight: 300; color: var(--t2); line-height: 1.76; flex: 1;
}
.wcard-cta {
  margin-top: .65rem; font-size: .44rem; font-weight: 500;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--au); opacity: 0; transform: translateX(-3px);
  transition: opacity .14s, transform .14s;
}
.wcard:not(.locked):hover .wcard-cta { opacity: 1; transform: none; }

/* ── PAGE HEADER (inner pages) ───────────────────────── */
.page-hdr {
  background: var(--p1);
  padding: 2.5rem 3.2rem 2.2rem;
  border-bottom: 1px solid var(--p3);
  position: relative;
}
.page-hdr::after {
  content: ''; position: absolute; bottom: -1px; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--au), transparent);
  opacity: .35;
}
.page-hdr-eye { font-family: 'Zarathustra', var(--serif); font-size: .78rem; color: var(--t2); letter-spacing: .08em; text-transform: uppercase; margin-bottom: .35rem; display: block; }
.page-hdr-title { font-family: 'Texturina', var(--serif); font-optical-sizing: auto; font-size: 2.4rem; font-weight: 900; color: var(--t0); line-height: 1.1; margin-bottom: .6rem; text-shadow: 0 1px 4px rgba(154,112,16,.18), 0 2px 12px rgba(28,16,8,.10); }
.page-hdr-rule { border: none; border-top: 1px solid var(--p3); margin: .5rem 0 .7rem; }
.page-hdr-lede { font-family: 'Vollkorn', Georgia, serif; font-size: 1.02rem; color: var(--t2); line-height: 1.75; margin-top: .4rem; }

/* ── BREADCRUMB ──────────────────────────────────────── */
.breadcrumb { display: none; }
.breadcrumb a         { color: var(--au); text-decoration: none; transition: color .13s; }
.breadcrumb a:hover   { color: var(--t0); }
.breadcrumb-sep       { opacity: .35; }

/* ── CONTENT AREAS ───────────────────────────────────── */
.content   { padding: 2.4rem 3.2rem; max-width: 800px; flex: 1; }
.content-w { padding: 2.4rem 3.2rem; flex: 1; }
.lore-body { padding: 2.4rem 3.2rem; flex: 1; }

.lore-p  { font-family: 'Vollkorn', Georgia, serif; font-size: 1rem; font-weight: 400; color: var(--t2); line-height: 1.88; margin-bottom: .88rem; }
.lore-h2 { line-height: 1.35; font-family: 'Texturina', var(--serif); font-optical-sizing: auto; font-size: 1.75rem; font-weight: 700; color: var(--t0); margin: 1.9rem 0 .48rem; padding-bottom: .36rem; border-bottom: 1px solid var(--p3); text-shadow: 0 1px 4px rgba(154,112,16,.18), 0 2px 12px rgba(28,16,8,.10); }
.lore-h2:first-child { margin-top: 0; }
.lore-h3 { font-family: 'Vollkorn', Georgia, serif; font-size: 1.15rem; font-weight: 700; color: var(--t1); margin: 1.3rem 0 .3rem; }

.lore-list { list-style: none; padding: 0; margin: .24rem 0 .8rem; }
.lore-list li { font-family: 'Vollkorn', Georgia, serif; font-size: 1rem; font-weight: 400; color: var(--t2); line-height: 1.76; padding: .05rem 0 .05rem 1.1rem; position: relative; }
.lore-list li::before { content: '•'; position: absolute; left: 0; color: var(--au); }

.lore-quote {
  border-left: 3px solid var(--au); margin: 1.2rem 0;
  padding: .72rem 1.1rem; background: var(--p1); border-radius: 0 2px 2px 0;
}
.lore-quote p { font-family: 'Vollkorn', Georgia, serif; font-style: italic; font-size: .98rem; color: var(--t1); margin: 0; line-height: 1.75; }
.lore-quote cite { font-family: 'Zarathustra', var(--serif); font-size: .78rem; color: var(--t2); font-style: normal; letter-spacing: .04em; display: block; margin-top: .4rem; }

/* ── RACE GRID ───────────────────────────────────────── */
.race-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.3rem; margin-top: 1.2rem; }

.rcard {
  position: relative; background: var(--p1);
  border: 1px solid var(--p3); border-radius: 2px; overflow: hidden;
  text-decoration: none; display: block; color: inherit;
  transition: transform .25s cubic-bezier(.16,1,.3,1), box-shadow .25s, border-color .25s;
}
.rcard.live:hover {
  transform: translateY(-3px) scale(1.01);
  box-shadow: 0 8px 28px rgba(90,56,8,.11), 0 0 0 1.5px var(--au);
  border-color: var(--au);
}
.rcard.locked { cursor: default; }

.rcard-img {
  width: 100%; aspect-ratio: 5/4; overflow: hidden; position: relative;
  background: var(--p2);
}
.rcard-img img {
  width: 100%; height: 100%; object-fit: cover; object-position: center center; display: block;
  transition: transform .38s cubic-bezier(.16,1,.3,1);
}
.rcard.live:hover .rcard-img img { transform: scale(1.03); }
/* Portraits have their own designed borders — no CSS fade needed */
.rcard-fade { display: none; }

.rcard.locked .rcard-img img { filter: saturate(.08) brightness(.65); }

.rcard-overlay {
  position: absolute; inset: 0; z-index: 10;
  background: rgba(228,212,180,.55);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .34rem;
  opacity: 0; transition: opacity .18s; pointer-events: none;
}
.rcard.locked:hover .rcard-overlay { opacity: 1; }
.rcard-overlay-icon  { font-size: 1.4rem; }
.rcard-overlay-label { font-size: .4rem; font-weight: 600; letter-spacing: .22em; text-transform: uppercase; color: var(--t2); }

.rcard-body { padding: .5rem .78rem .78rem; }
.rcard-name { font-family: 'Vollkorn', Georgia, serif; font-size: 1.15rem; font-weight: 700; color: var(--t0); margin: .4rem 0 .15rem; letter-spacing: -.01em; }
.rcard.live:hover 
.rcard.locked 

.rcard-rarity { display: inline-flex; align-items: center; gap: .5rem; font-family: 'Zarathustra', var(--serif); font-size: .65rem; letter-spacing: .04em; color: var(--t2); }
.rar-icon { width: 13px; height: 13px; object-fit: contain; flex-shrink: 0; }
.rar-common { font-family: 'Zarathustra', var(--serif); font-size: .65rem; letter-spacing: .06em; }
.rar-uncommon { font-family: 'Zarathustra', var(--serif); font-size: .65rem; letter-spacing: .06em; }
.rar-rare { font-family: 'Zarathustra', var(--serif); font-size: .65rem; letter-spacing: .06em; }
.rar-legendary { font-family: 'Zarathustra', var(--serif); font-size: .65rem; letter-spacing: .06em; }

.rcard-stats { display: flex; flex-direction: column; gap: .12rem; }
.rstat { display: flex; align-items: baseline; justify-content: space-between; gap: .35rem; }
.rstat-label { font-size: .44rem; font-weight: 400; letter-spacing: .07em; text-transform: uppercase; color: var(--t3); }
.rstat-stars { font-size: .78rem; letter-spacing: .04em; flex-shrink: 0; }
.star-on  { color: var(--au); }
.star-off { color: var(--p3); }
.rcard.locked .star-on { color: var(--p3); }

.rcard-cta { display: block; margin-top: .5rem; font-size: .44rem; font-weight: 500; letter-spacing: .18em; text-transform: uppercase; color: var(--au); opacity: 0; transform: translateX(-3px); transition: opacity .14s, transform .14s; }
.rcard.live:hover .rcard-cta { opacity: 1; transform: none; }

.race-legend { display: flex; gap: 1.3rem; align-items: center; flex-wrap: wrap; margin-bottom: 1.1rem; }
.race-legend-label { font-family: 'Zarathustra', var(--serif); font-size: .72rem; color: var(--t2); letter-spacing: .06em; }
.race-legend span  { display: inline-flex; align-items: center; gap: .25rem; font-size: .52rem; color: var(--t2); }
.dot { width: 5px; height: 5px; border-radius: 50%; display: inline-block; }

/* ── ANCESTRY HERO ───────────────────────────────────── */
.anc-hero {
  background: var(--p2);
  padding: 1.2rem 3.2rem 1.2rem;
  display: grid; grid-template-columns: 240px 1fr; gap: 2.6rem; align-items: start;
  border-bottom: 1px solid var(--p3);
  position: relative;
}
.anc-hero::after {
  content: ''; position: absolute; bottom: -1px; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--au), transparent);
  opacity: .4;
}
.anc-portrait {
  width: 240px; border-radius: 2px; overflow: hidden;
  box-shadow: 0 4px 16px rgba(90,56,8,.16);
  border: 1px solid var(--p3);
}
.anc-portrait img { width: 100%; display: block; object-fit: cover; object-position: center top; aspect-ratio: 3/4; }

.anc-info { display: flex; flex-direction: column; gap: .34rem; }
.anc-eyebrow { font-family: 'Zarathustra', var(--serif); font-size: .73rem; color: var(--t2); letter-spacing: .12em; text-transform: uppercase; margin-bottom: .2rem; }
.anc-title   { font-family: 'Vollkorn', Georgia, serif; font-size: 2.7rem; font-weight: 900; color: var(--t0); line-height: 1.05; }

.anc-meta { display: flex; gap: .75rem; align-items: center; flex-wrap: wrap; margin-top: .15rem; }
.anc-badge { font-family: 'Zarathustra', var(--serif); font-size: .6rem; font-weight: 400; letter-spacing: .1em; text-transform: uppercase; padding: .18rem .58rem; border-radius: 1px; border: 1px solid currentColor; display: inline-flex; align-items: center; gap: .45rem; }
.badge-common   { color: var(--t3); }
.badge-uncommon { color: #357a35; }
.badge-rare     { color: #285888; }
.badge-legendary { color: #8b5e00; }
.anc-meta-sep { font-family: 'Zarathustra', var(--serif); font-size: .76rem; color: var(--t3); }
.anc-meta-item { font-family: 'Zarathustra', var(--serif); font-size: .76rem; color: var(--t2); }
.anc-meta-item strong { color: var(--t1); font-weight: 500; }

.anc-stats { display: flex; flex-direction: column; gap: .4rem; margin-top: .6rem; padding-top: .6rem; border-top: 1px solid var(--p3); }
.astat { display: grid; grid-template-columns: 140px auto 1fr; align-items: baseline; gap: .48rem; }
.astat-label { font-family: 'Zarathustra', var(--serif); font-size: .62rem; color: var(--t3); text-transform: uppercase; letter-spacing: .1em; font-weight: 400; }
.astat-stars { font-size: .88rem; letter-spacing: .07em; white-space: nowrap; }
.astar-on  { color: var(--au); }
.astar-off { color: var(--p3); }
.astat-desc { font-family: 'Vollkorn', Georgia, serif; font-size: .76rem; font-weight: 400; color: var(--t2); font-style: italic; }

/* Quote as blockquote — no max-width cap, fills the info column */
.anc-quote {
  margin: .65rem 0 0; padding-top: .65rem;
  border-top: 1px solid var(--p3);
  font-family: 'Vollkorn', Georgia, serif; font-style: italic;
  color: var(--t2); line-height: 1.75;
}
.anc-quote p { font-family: 'Vollkorn', Georgia, serif; font-style: italic; font-size: .98rem; color: var(--t1); line-height: 1.75; }
.anc-quote cite { font-family: 'Zarathustra', var(--serif); font-size: .78rem; color: var(--t2); font-style: normal; letter-spacing: .04em; display: block; margin-top: .3rem; }


/* ── AFFINITY TABLE ──────────────────────────────────── */
.aff-table { width: 100%; border-collapse: collapse; margin: .85rem 0 1.2rem; max-width: 350px; }
.aff-table th { font-size: .4rem; font-weight: 600; letter-spacing: .17em; text-transform: uppercase; color: var(--t3); padding: .4rem .48rem; border-bottom: 2px solid var(--p3); text-align: left; }
.aff-table th:last-child { text-align: right; }
.aff-table td { font-size: .92rem; font-weight: 300; color: var(--t2); padding: .27rem .48rem; border-bottom: 1px solid var(--p2); }
.aff-table td:last-child { text-align: right; color: var(--au); font-weight: 500; }

/* ── INFO PANELS ─────────────────────────────────────── */
.info-panels { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: .85rem; }
.info-panel  { background: var(--p1); border: 1px solid var(--p3); padding: .85rem 1.05rem; border-radius: 2px; }
.info-panel-title { font-size: .4rem; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--au); margin-bottom: .5rem; }
.info-panel ul { list-style: none; padding: 0; margin: 0; }
.info-panel li { font-size: .78rem; font-weight: 300; color: var(--t2); padding: .22rem 0; border-bottom: 1px solid var(--p2); display: flex; justify-content: space-between; align-items: baseline; }
.info-panel li:last-child { border-bottom: none; }
.info-panel li span { color: var(--t3); font-style: italic; font-size: .68rem; }

/* ── FOOTER ──────────────────────────────────────────── */
.site-footer {
  background: var(--p2);
  border-top: 1px solid var(--p3);
  padding: .78rem 2rem;
  text-align: center;
  margin-top: auto; flex-shrink: 0;
}
.site-footer p { font-size: .54rem; font-weight: 300; color: var(--t3); letter-spacing: .05em; }

/* ── RESPONSIVE ──────────────────────────────────────── */

/* ── Section ornament dividers ──────────────────────────── */
.lore-ornament { display: none; }
.lore-ornament::before, .lore-ornament::after { display: none; content: ''; }
.lore-ornament-glyph { display: none; }

@media (max-width: 1060px) {
  .vol-band-grid { grid-template-columns: repeat(2, 1fr); }
  .race-grid     { grid-template-columns: repeat(2, 1fr); }
  .info-panels   { grid-template-columns: 1fr; }
}
@media (max-width: 740px) {
  .sidebar { transform: translateX(-100%); transition: transform .22s ease; }
  .sidebar.open { transform: translateX(0); }
  .layout-vol { margin-left: 0; }
  .vol-band-grid, .race-grid { grid-template-columns: 1fr; }
  .anc-hero { grid-template-columns: 1fr; }
  .anc-portrait { width: 135px; }
  .content, .content-w, .lore-body { padding: 1.7rem 1.2rem; }
  .page-hdr, .breadcrumb, .vol-band { padding-left: 1.2rem; padding-right: 1.2rem; }
}

/* ── ETHNIC PORTRAIT GALLERY ─────────────────────────── */
.ethnic-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1.2rem;
  margin: .9rem 0 1.6rem;
}
.ethnic-card {
  background: var(--p1);
  border: 1px solid var(--p3);
  border-radius: 2px;
  overflow: hidden;
}
.ethnic-img {
  width: 100%; aspect-ratio: 3/4; overflow: hidden; position: relative;
}
.ethnic-img img {
  width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block;
  transition: transform .35s cubic-bezier(.16,1,.3,1);
}
.ethnic-card:hover .ethnic-img img { transform: scale(1.04); }
.ethnic-caption {
  padding: .55rem .75rem .65rem;
  border-top: 1px solid var(--p3);
  display: flex; flex-direction: column; gap: .1rem;
}
.ethnic-name {
   font-size: 1rem; font-weight: 700; color: var(--t0);
 font-family: 'Vollkorn', Georgia, serif; font-weight: 700;}
.ethnic-region {
  font-size: .55rem; font-weight: 400; letter-spacing: .1em; text-transform: uppercase;
  color: var(--t3);
}

/* ── ILLUSTRATED LORE SECTIONS ───────────────────────── */
.lore-illus {
  display: grid;
  gap: 2rem;
  align-items: start;
  margin: 1.2rem 0 1.8rem;
}
.lore-illus--right { grid-template-columns: 1fr 360px; }
.lore-illus--left  { grid-template-columns: 360px 1fr; }

.lore-illus-fig {
  margin: 0;
  display: flex; flex-direction: column; gap: .4rem;
}
.lore-illus-fig img {
  width: 100%; border-radius: 2px;
  border: 1px solid var(--p3);
  display: block;
}
.lore-illus-fig figcaption {
  font-size: .55rem; font-weight: 400; letter-spacing: .06em;
  color: var(--t3); text-align: center; font-style: italic;
}
.lore-illus-text .lore-h2 { margin-top: 0; }

.anc-quote-cite {
  display: block; margin-top: .5rem;
  font-size: .58rem; letter-spacing: .08em;
  font-style: normal; color: var(--t3);
}

@media (max-width: 740px) {
  .lore-illus--right,
  .lore-illus--left { grid-template-columns: 1fr; }
  .lore-illus--left .lore-illus-fig { order: -1; }
}

/* ── LORE CALLOUT BOX ────────────────────────────────── */
.lore-callout {
  margin: 1.1rem 0 .2rem;
  padding: .85rem 1.1rem;
  background: var(--p1);
  border: 1px solid var(--p3);
  border-left: 3px solid var(--au);
  border-radius: 0 2px 2px 0;
}
.lore-callout-title {
  font-size: .44rem; font-weight: 700; letter-spacing: .22em;
  text-transform: uppercase; color: var(--au);
  margin-bottom: .42rem;
}
.lore-callout p {
  font-size: .88rem; font-weight: 300; color: var(--t2);
  line-height: 1.76; margin: 0;
}

/* ── LINGUISTICS PAGE ───────────────────────────────── */

/* Hero banner for linguistics (no portrait — conceptual page) */
.ling-hero {
  background: var(--p1);
  border-bottom: 1px solid var(--p3);
  padding: 2.2rem 2.4rem 1.8rem;
  display: flex; flex-direction: column; gap: .6rem;
}
.ling-hero-eyebrow { font-size: .58rem; font-weight: 500; letter-spacing: .22em; text-transform: uppercase; color: var(--t3); }
.ling-hero-title { font-family: 'Texturina', var(--serif); font-size: 2.7rem; font-weight: 900; color: var(--t0); line-height: 1; }
.ling-hero-sub     { font-size: .72rem; font-weight: 300; color: var(--t2); max-width: 680px; }
.ling-hero-axiom {
  margin-top: .6rem; padding: .85rem 1.2rem;
  background: var(--p0); border: 1px solid var(--p3);
  border-left: 3px solid var(--au);
   font-style: italic;
  font-size: 1rem; color: var(--t1); line-height: 1.7;
  max-width: 700px;
 font-family: 'Vollkorn', Georgia, serif; font-style: italic;}
.ling-hero-axiom span { display: block; margin-top: .35rem; font-size: .65rem; font-style: normal; letter-spacing: .07em; color: var(--t3); }

/* Category heading with rule */
.ling-cat-head {
  display: flex; align-items: center; gap: .9rem;
  margin: 2.4rem 0 1.1rem;
}
.ling-cat-label {
  font-size: .58rem; font-weight: 700; letter-spacing: .22em;
  text-transform: uppercase; color: var(--au); white-space: nowrap;
}
.ling-cat-rule { flex: 1; height: 1px; background: var(--p3); }
.ling-cat-count { font-size: .54rem; font-weight: 400; color: var(--t3); letter-spacing: .1em; white-space: nowrap; }

/* Language card grid */
.lang-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
  margin-bottom: 1.4rem;
}

/* Full-width variant for featured entries */
.lang-grid--wide { grid-template-columns: 1fr; }
.lang-grid--two  { grid-template-columns: repeat(auto-fill, minmax(380px, 1fr)); }

.lang-card {
  background: var(--p1);
  border: 1px solid var(--p3);
  border-radius: 3px;
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: box-shadow .18s, border-color .18s;
}
.lang-card:hover { border-color: var(--au); box-shadow: 0 3px 14px rgba(90,56,8,.1); }

.lang-card-head {
  padding: .75rem 1rem .6rem;
  border-bottom: 1px solid var(--p3);
  display: flex; align-items: flex-start; justify-content: space-between; gap: .5rem;
}
.lang-card-name {
   font-size: 1.15rem; font-weight: 700;
  color: var(--t0); line-height: 1.15;
 font-family: 'Vollkorn', Georgia, serif; font-weight: 700;}
.lang-card-alias {
  font-size: .64rem; font-weight: 300; color: var(--t3);
  font-style: italic; margin-top: .1rem;
}
.lang-badge {
  font-size: .48rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  padding: .18rem .54rem; border-radius: 99px; white-space: nowrap; flex-shrink: 0;
  margin-top: .12rem;
}
.lang-badge--diplomata { background: #2a5a2a; color: #c8e8c8; }
.lang-badge--standard  { background: #3a4a6a; color: #c8d4f0; }
.lang-badge--racial    { background: #5a3820; color: #f0ddc8; }
.lang-badge--divine    { background: #5a4a18; color: #f0e4a0; }
.lang-badge--secret    { background: #3a2a4a; color: #d8c8f0; }

.lang-card-body { padding: .7rem 1rem .9rem; display: flex; flex-direction: column; gap: .52rem; }

.lang-field { display: flex; flex-direction: column; gap: .1rem; }
.lang-field-label {
  font-size: .48rem; font-weight: 600; letter-spacing: .18em;
  text-transform: uppercase; color: var(--t3);
}
.lang-field-val {
  font-size: .82rem; font-weight: 300; color: var(--t2); line-height: 1.55;
}
.lang-field-val strong { color: var(--t1); font-weight: 500; }

/* The "What Diplomata misses" field — gets special treatment */
.lang-field--misses .lang-field-label { color: var(--au); }
.lang-field--misses .lang-field-val {
  font-style: italic; color: var(--t1);
  padding: .45rem .65rem;
  background: var(--p0); border-left: 2px solid var(--au);
  border-radius: 0 2px 2px 0; line-height: 1.6;
}

/* Diplomata featured card — spans full width, slightly elevated */
.lang-card--featured {
  border-left: 3px solid var(--au);
  background: var(--p0);
}
.lang-card--featured .lang-card-head { background: var(--p1); }

/* Secret language card — subdued palette */
.lang-card--secret { border-color: var(--p3); opacity: .92; }
.lang-card--secret .lang-card-name { color: var(--t1);  font-family: 'Vollkorn', Georgia, serif; font-weight: 700;}

/* Acquisition field for secret languages */
.lang-field--acquire .lang-field-label { color: #7a5a9a; }
.lang-field--acquire .lang-field-val {
  padding: .4rem .6rem;
  background: #f5eeff; border-left: 2px solid #b090d8;
  border-radius: 0 2px 2px 0; font-size: .8rem;
}

/* Verbum callout — full width, politically toned */
.verbum-block {
  margin: 1.4rem 0;
  padding: 1.1rem 1.3rem;
  background: var(--p1); border: 1px solid var(--p3);
  border-top: 3px solid var(--t3);
  border-radius: 0 0 3px 3px;
}
.verbum-block-title {
  font-size: .58rem; font-weight: 700; letter-spacing: .2em;
  text-transform: uppercase; color: var(--t2); margin-bottom: .5rem;
}
.verbum-block p {
  font-size: .86rem; font-weight: 300; color: var(--t2);
  line-height: 1.76; margin-bottom: .6rem;
}
.verbum-block p:last-child { margin-bottom: 0; }

/* Immune badge for secret languages */
.lang-immune {
  display: inline-flex; align-items: center; gap: .3rem;
  font-size: .52rem; font-weight: 600; letter-spacing: .14em;
  text-transform: uppercase; color: #7a5a9a;
}
.lang-immune::before { content: '⊘'; font-size: .7rem; }

@media (max-width: 700px) {
  .lang-grid, .lang-grid--two { grid-template-columns: 1fr; }
  .ling-hero { padding: 1.4rem 1.1rem 1.2rem; }
  .ling-cat-head { margin-top: 1.8rem; }
}

/* ── SCROLL REVEAL ───────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .55s cubic-bezier(.16,1,.3,1), transform .55s cubic-bezier(.16,1,.3,1);
}
.reveal.visible {
  opacity: 1;
  transform: none;
}
.reveal-delay-1 { transition-delay: .1s; }
.reveal-delay-2 { transition-delay: .2s; }
.reveal-delay-3 { transition-delay: .3s; }

/* Portrait hover glow */
.lore-illus-fig img {
  transition: transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s;
}
.lore-illus-fig:hover img {
  transform: scale(1.02);
  box-shadow: 0 8px 28px rgba(90,56,8,.18), 0 0 0 2px var(--au);
}

/* Sidebar plain link (non-expandable section links) */
.sb-link-plain { font-family: 'Zarathustra', var(--serif); font-size: .85rem; color: var(--t1); text-decoration: none; display: flex; align-items: center; gap: .35rem; padding: .28rem .8rem; }
.sb-link-plain:hover { color: var(--t0); background: var(--p2); border-left-color: var(--p3); }
.sb-link-plain.active { color: var(--t0); background: var(--p2); border-left-color: var(--au); font-weight: 500; }

/* Sidebar expandable label (non-link) */
.sb-link[data-expand] { cursor: pointer; }

/* Locked child entries in sidebar */


/* Sidebar group header: label navigates, chevron toggles expand/collapse */
.sb-group-head { font-family: 'Zarathustra', var(--serif); font-size: .85rem; color: var(--t1); font-weight: 400; cursor: pointer; display: flex; justify-content: space-between; align-items: center; padding: .28rem .8rem; width: 100%; }
.sb-group-head .sb-link { font-family: 'Zarathustra', var(--serif); font-size: .85rem; color: var(--t1); text-decoration: none; display: block; padding: .18rem .4rem; }
.sb-toggle {
  background: none;
  border: none;
  cursor: pointer;
  padding: .25rem .4rem;
  color: var(--t3);
  font-size: .7rem;
  line-height: 1;
  transition: color .14s, transform .2s;
  flex-shrink: 0;
}
.sb-toggle:hover { color: var(--t0); }
.sb-group.open .sb-toggle { transform: rotate(90deg); }

/* Sidebar section labels (Mortal Sphere / Divine Sphere / Institutions / Factions) */
.sb-section-label { font-family: 'Zarathustra', var(--serif); font-size: .68rem; font-weight: 400; color: var(--t2); text-transform: uppercase; letter-spacing: .1em; margin: .8rem 0 .2rem .8rem; display: block; }
.sb-section-label:first-child { margin-top: 0; }
.sb-child--locked { opacity: .45; pointer-events: none; }

/* TBD / Varies text in rstat rows */
.rstat-stars-text { font-size: .62rem; color: var(--t3); font-style: italic; flex-shrink: 0; }

/* ── MOBILE SIDEBAR TOGGLE ───────────────────────────── */
.mob-menu-btn {
  display: none;
  align-items: center; justify-content: center;
  width: 32px; height: 32px;
  background: none; border: 1px solid var(--p3);
  border-radius: 2px; cursor: pointer;
  flex-shrink: 0; color: var(--t1);
  transition: background .15s, color .15s;
}
.mob-menu-btn:hover { background: var(--p2); color: var(--t0); }
.mob-menu-btn svg { display: block; pointer-events: none; }

/* Backdrop — tapping it closes the sidebar */
.sb-backdrop {
  display: none;
  position: fixed; inset: 0; z-index: 790;
  background: rgba(60, 40, 10, 0.42);
  backdrop-filter: blur(1px);
  opacity: 0;
  transition: opacity .22s ease;
}
.sb-backdrop.visible {
  opacity: 1;
}

@media (max-width: 740px) {
  .mob-menu-btn { display: flex; }

  /* Sidebar overlays content — make sure it's always on top */
  .sidebar {
    z-index: 800;
    top: var(--nh);
    box-shadow: 4px 0 24px rgba(60,40,10,.18);
  }

  /* Prevent body scroll when sidebar is open */
  body.sb-open { overflow: hidden; }

  /* Backdrop active */
  body.sb-open .sb-backdrop { display: block; }

  /* Push top nav brand slightly right to accommodate button */
  .tnav { gap: .8rem; padding-left: 1rem; }
}

/* ── MOBILE FIXES (v2.26) ────────────────────────────── */

/* Wrap affinity tables so they scroll horizontally on tiny screens */
.aff-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

@media (max-width: 740px) {
  /* Top nav: hide "Soon" volume badges to save space */
  .tnav-vol.soon { display: none; }

  /* Anchor hero: fix padding on mobile */
  .anc-hero {
    padding: 1.6rem 1.2rem 1.4rem;
    gap: 1.2rem;
  }

  /* Page header: fix padding on mobile */
  .page-hdr {
    padding: 1.6rem 1.2rem 1.4rem;
  }

  /* Scale down section headings slightly on mobile */
  .lore-h2 { font-size: 1.35rem; }
  .lore-h3 { font-size: 1rem; }

  /* Info panels: single column on mobile */
  .info-panels { grid-template-columns: 1fr; }

  /* Subrace grid: single column on mobile (Åel page) */
  .subrace-grid { grid-template-columns: 1fr !important; }

  /* Ael page inline style override for subrace grid */
  .subrace-card { min-width: 0; }

  /* anc-meta: allow items to wrap tightly */
  .anc-meta { gap: .4rem .6rem; }
  .anc-meta-sep { font-family: 'Zarathustra', var(--serif); font-size: .76rem; color: var(--t3); }
  .anc-meta-item { font-family: 'Zarathustra', var(--serif); font-size: .76rem; color: var(--t2); }

  /* Prevent horizontal overflow on the whole page */
  body { overflow-x: hidden; }
  .layout-vol { overflow-x: hidden; }

  /* Affinity table: full width, no max-width cap */
  .aff-table { max-width: 100%; }

  /* Breadcrumb: smaller text */
  .breadcrumb { font-family: 'Zarathustra', var(--serif); font-size: .75rem; color: var(--t2); display: flex; align-items: center; gap: .3rem; padding: .6rem 0 .4rem; flex-wrap: wrap; }

  /* Footer padding */
  .site-footer { padding: 1.2rem; }
}

/* ═══════════════════════════════════════════════════════════════
   SUB-GROUP GRID  (unified for all ancestry sub-type/clan/sub-clan cards)
   Usage: <div class="sub-grid sub-grid--2"> or sub-grid--3
   ═══════════════════════════════════════════════════════════════ */
.sub-grid {
  display: grid;
  gap: 1.2rem;
  margin: 1rem 0 1.8rem;
}
.sub-grid--2 { grid-template-columns: repeat(2, 1fr); }
.sub-grid--3 { grid-template-columns: repeat(3, 1fr); }
.sub-grid--4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 900px) {
  .sub-grid--3 { grid-template-columns: repeat(2, 1fr); }
  .sub-grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
  .sub-grid--2, .sub-grid--3, .sub-grid--4 { grid-template-columns: 1fr; }
}

.sub-card {
  background: var(--p2);
  border: 1px solid var(--p3);
  border-radius: 4px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.sub-card-img {
  width: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--p3);
}
.sub-card-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}
.sub-card-header { font-family: 'Vollkorn', Georgia, serif; font-size: 1rem; font-weight: 700; color: var(--t0); }
.sub-card-name {
  
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--t0);
  line-height: 1.2;
 font-family: 'Vollkorn', Georgia, serif; font-weight: 700;}
.sub-card-epithet { font-family: 'Vollkorn', Georgia, serif; font-size: .88rem; font-style: italic; color: var(--t2); }
.sub-card-body { font-family: 'Vollkorn', Georgia, serif; font-size: .93rem; color: var(--t2); line-height: 1.7; }
.sub-card-tag { font-family: 'Zarathustra', var(--serif); font-size: .62rem; letter-spacing: .04em; padding: .1rem .4rem; border: 1px solid var(--p3); border-radius: 1px; }
.sub-card-desc {
  font-size: .82rem;
  color: var(--t1);
  line-height: 1.55;
}
/* ══════════════════════════════════════════════
   QUALITY IMPROVEMENTS — v2.49
══════════════════════════════════════════════ */

/* ── Text selection ──────────────────────── */
::selection {
  background: rgba(196,157,99,.25);
  color: var(--t0);
}

/* ── Focus visible (keyboard nav) ────────── */
a:focus-visible,
button:focus-visible {
  outline: 2px solid var(--au);
  outline-offset: 2px;
  border-radius: 2px;
}

/* ── Affinity table row hover ────────────── */
.aff-table tbody tr:hover td {
  background: rgba(255,255,255,.04);
}
.aff-table tbody tr td:first-child {
  font-weight: 500;
}
.aff-table tbody tr td:last-child {
  font-variant-numeric: tabular-nums;
  text-align: right;
  color: var(--au);
}

/* ── Skit participant role subtle ────────── */
.skit-participant-role {
  font-size: .58rem;
  color: var(--t3);
  font-weight: 300;
  letter-spacing: .04em;
}

/* ── Lore body: tighter paragraph spacing ── */
.lore-body .lore-p + .lore-p {
  margin-top: .1rem;
}

/* ── Sub-card tag uppercase refinement ───── */
.sub-card-tag { font-family: 'Zarathustra', var(--serif); font-size: .62rem; letter-spacing: .04em; padding: .1rem .4rem; border: 1px solid var(--p3); border-radius: 1px; }

/* ── Info panel list item spacing ─────────── */
.info-panel ul li + li {
  margin-top: .3rem;
}

/* ── Ancestry hero: portrait shadow ─────── */
.anc-portrait {
  box-shadow: 0 4px 24px rgba(0,0,0,.45);
}

/* ── Race card: smoother hover transition ── */
.rcard.live {
  transition: border-color .18s, box-shadow .18s, transform .18s;
}
.rcard.live:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,.35);
}

/* ── Breadcrumb: slightly more visible sep ── */
.breadcrumb-sep {
  opacity: .5;
  margin: 0 .2rem;
}

/* ── Skit post: slightly more breathing room */
.skit-post-text p {
  text-indent: 0;
  orphans: 3;
  widows: 3;
}

/* ── Narrator block: left-border accent ──── */
.skit-narrator-body {
  border-left: 2px solid var(--p3);
  padding-left: .8rem;
  margin-left: 0;
}

/* ── Print: hide sidebar and nav ────────── */
@media print {
  .tnav, .sidebar, .breadcrumb, .skit-meta { display: none !important; }
  .layout-vol { display: block; }
  .lore-body, .skit-reader { max-width: 100%; padding: 0; }
  .anc-hero { flex-direction: column; }
  a { color: inherit; text-decoration: none; }
}

/* Nested sub-group inside sb-children (e.g. Realmfall: Foundations) */
.sb-sub-group { margin: .1rem 0; }
.sb-sub-group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 .4rem 0 .6rem;
}
.sb-sub-link {
  display: block;
  font-size: .68rem;
  font-weight: 500;
  color: var(--t2);
  text-decoration: none;
  padding: .25rem .4rem .25rem 0;
  flex: 1;
  transition: color .14s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sb-sub-link:hover { color: var(--t0); }
.sb-sub-link.active { color: var(--au); font-weight: 600; }
.sb-sub-toggle {
  background: none;
  border: none;
  cursor: pointer;
  padding: .2rem .3rem;
  color: var(--t3);
  font-size: .62rem;
  line-height: 1;
  flex-shrink: 0;
  transition: color .14s, transform .2s;
}
.sb-sub-toggle:hover { color: var(--t0); }
.sb-sub-group.open .sb-sub-toggle { transform: rotate(90deg); }
.sb-sub-children { display: none; }
.sb-sub-group.open .sb-sub-children { display: block; }
.sb-grandchild {
  display: block;
  font-size: .66rem;
  font-weight: 300;
  color: var(--t3);
  text-decoration: none;
  padding: .22rem .4rem .22rem 1.6rem;
  transition: color .14s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sb-grandchild:hover { color: var(--t1); }
.sb-grandchild.active { color: var(--au); font-weight: 500; }
.sb-grandchild.sb-child--locked { opacity: .45; pointer-events: none; }

.rar-icon {
  width: 14px;
  height: 14px;
  object-fit: contain;
  flex-shrink: 0;
  vertical-align: middle;
}
.rcard-rarity { display: inline-flex; align-items: center; gap: .5rem; font-family: 'Zarathustra', var(--serif); font-size: .65rem; letter-spacing: .04em; color: var(--t2); }


/* ── Zarathustra — captions & sidebar ──────────────────── */
.expr-strip-label { font-family: 'Zarathustra', var(--serif); font-size: .68rem; color: var(--t2); text-transform: uppercase; letter-spacing: .12em; margin-bottom: .2rem; display: block; }
.expr-strip-name { font-family: 'Vollkorn', Georgia, serif; font-size: 1.55rem; font-weight: 700; color: var(--t0); margin: .1rem 0 .15rem; line-height: 1.15; }
.expr-strip-epithet { font-family: 'Vollkorn', Georgia, serif; font-size: .92rem; font-style: italic; color: var(--t2); margin-bottom: .5rem; }
.expr-strip-desc { font-family: 'Vollkorn', Georgia, serif; font-size: 1rem; color: var(--t2); line-height: 1.75; margin-bottom: .5rem; }
.subrace-title { font-family: 'Zarathustra', var(--serif); font-size: .65rem; color: var(--t2); text-transform: uppercase; letter-spacing: .12em; margin: .6rem 0 .25rem; }
.cx-stat-key { font-family: 'Zarathustra', var(--serif); font-size: .78rem; font-weight: 400; color: var(--t1); letter-spacing: .04em; padding-right: 1rem; width: 110px; flex-shrink: 0; }
.cx-stat-val { font-family: 'Vollkorn', Georgia, serif; font-size: .95rem; color: var(--t2); line-height: 1.65; }
.bc-link { font-family: 'Zarathustra', var(--serif); font-size: .75rem; color: var(--t2); text-decoration: none; }
.bc-cur { font-family: 'Zarathustra', var(--serif); font-size: .75rem; color: var(--t1); }
.rcard-tag { font-family: 'Zarathustra', var(--serif); font-size: .62rem; letter-spacing: .04em; padding: .1rem .4rem; border: 1px solid var(--p3); border-radius: 1px; }
.rcard-era { font-family: 'Zarathustra', var(--serif); font-size: .65rem; color: var(--t2); letter-spacing: .04em; }
.rcard-origin { font-family: 'Zarathustra', var(--serif); font-size: .65rem; color: var(--t2); letter-spacing: .04em; }
.cx-stat-block-head { font-family: 'Texturina', var(--serif); font-optical-sizing: auto; font-size: 1rem; font-weight: 700; color: var(--t0); text-shadow: 0 1px 4px rgba(154,112,16,.18), 0 2px 12px rgba(28,16,8,.10); }
.lore-trivia p { font-family: 'Vollkorn', Georgia, serif; font-size: .93rem; color: var(--t2); line-height: 1.72; }
.kw-tip { font-family: 'Zarathustra', var(--serif); font-size: .76rem; letter-spacing: .02em; }