/* ============================================================================
   ANSELM v5 — "Editorial Nocturne" design system
   Site-wide visual language. Hand-authored (not Tailwind). Source of truth for
   tokens + components; see templates/v5/V5_DESIGN_SYSTEM.md for the spec and
   templates/v5/styleguide.html for the living reference.

   Every v5 page extends templates/v5/layout.html, which links this file and the
   fonts (Fraunces / Spectral / Inter / Frank Ruhl Libre). Pages COMPOSE the
   .v5-* components below; page-local CSS is only for layout unique to that page.
   ========================================================================== */

/* ============================ 1. FOUNDATION ============================== */
:root{
  /* ---- BASE INPUTS (a theme sets only these; everything else derives) ---- */
  --bg:#0d0f12; --ink:#f3efe6; --ink-soft:#b3ada1; --brass:#c9a35f; --rubric:#9b3b2f;
  --vig:rgba(0,0,0,.5);        /* edge vignette tint */
  --dim:rgba(5,7,11,.66);      /* cinematic-dim overlay */
  --ghost:.055;                /* depth/ghost chapter-numeral opacity */
  /* how the reading recedes on verse-focus. Dark themes dim toward black (brightness);
     light themes can't — darkening just muddies them — so they dissolve toward the page (opacity). */
  --focus-filter:blur(4px) brightness(.32) saturate(.7);
  /* ---- DERIVED (computed from the base inputs above) ---- */
  --bg-elev:color-mix(in srgb, var(--bg) 86%, var(--ink) 14%);
  --bg-sunk:color-mix(in srgb, var(--bg) 88%, var(--ink) 12%);
  --surface:color-mix(in srgb, var(--ink) 4%, transparent);
  --surface-2:color-mix(in srgb, var(--ink) 7%, transparent);
  --ink-faint:color-mix(in srgb, var(--ink-soft) 60%, var(--bg) 40%);
  --brass-soft:color-mix(in srgb, var(--brass) 70%, #000 30%);
  --brass-dim:color-mix(in srgb, var(--brass) 16%, transparent);
  --line:color-mix(in srgb, var(--ink) 11%, transparent);
  --line-strong:color-mix(in srgb, var(--ink) 19%, transparent);
  --glow:color-mix(in srgb, var(--brass) 9%, transparent);
  --danger:#b0432f; --positive:#6f8f6a; --info:#6d8aa8;

  /* type */
  --font-display:"Fraunces", Georgia, "Times New Roman", serif;
  --font-body:"Spectral", Georgia, serif;
  --font-ui:"Inter", system-ui, -apple-system, sans-serif;
  --font-hebrew:"Frank Ruhl Libre", "Spectral", serif;
  --font-greek:"Spectral", "Times New Roman", serif;

  --fs-display:clamp(2.5rem,6vw,4.25rem);
  --fs-h1:2.4rem; --fs-h2:1.9rem; --fs-h3:1.45rem; --fs-h4:1.15rem;
  --fs-body:1.0625rem; --fs-read:1.25rem; --fs-sm:.875rem; --fs-kicker:.72rem;

  /* space / radius / shadow / motion */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px; --s6:32px;
  --s7:48px; --s8:64px; --s9:72px; --s10:80px;
  --r1:6px; --r2:10px; --r3:16px; --rpill:999px;
  --sh1:0 1px 2px rgba(0,0,0,.3);
  --sh2:0 8px 24px rgba(0,0,0,.35);
  --sh3:0 24px 60px rgba(0,0,0,.5);
  --ease:cubic-bezier(.22,.61,.36,1); --dur:.4s; --dur-fast:.2s; --dur-slow:.7s;

  /* layout */
  --measure:40rem; --content:72rem; --bar-h:60px;
}

/* ---- Themes (mirror the per-user V3 set chosen in Settings) ---- */
/* dark */
[data-theme="midnight"]{--bg:#0f172a;--ink:#e2e8f0;--ink-soft:#94a3b8;--brass:#d4af37}
[data-theme="charcoal"]{--bg:#1a1a2e;--ink:#e2e8f0;--ink-soft:#9ca3af;--brass:#d4af37}
[data-theme="obsidian"]{--bg:#09090b;--ink:#e4e4e7;--ink-soft:#a1a1aa;--brass:#d4af37}
[data-theme="slate"]{--bg:#1e293b;--ink:#e2e8f0;--ink-soft:#94a3b8;--brass:#d4af37}
[data-theme="ink"]{--bg:#0f1419;--ink:#d1d5db;--ink-soft:#9ca3af;--brass:#d4af37}
[data-theme="parchment"]{--bg:#292420;--ink:#e7e5e4;--ink-soft:#a8a29e;--brass:#d4af37}
[data-theme="forest"]{--bg:#0f1a14;--ink:#d4e8de;--ink-soft:#8faa9c;--brass:#c9a860}
[data-theme="burgundy"]{--bg:#1a0f14;--ink:#ebdadf;--ink-soft:#a89398;--brass:#d4af37}
[data-theme="indigo"]{--bg:#0e0d22;--ink:#e0dcee;--ink-soft:#9a93b0;--brass:#d4af37}
[data-theme="espresso"]{--bg:#1c1410;--ink:#ece3da;--ink-soft:#b0a296;--brass:#d4af37}
[data-theme="graphite"]{--bg:#18181b;--ink:#e4e4e7;--ink-soft:#a1a1aa;--brass:#d4af37}
[data-theme="oxblood"]{--bg:#17090b;--ink:#e9d8da;--ink-soft:#a89196;--brass:#d4af37}
/* light */
[data-theme="paper"]{--bg:#f5f5f4;--ink:#1c1917;--ink-soft:#57534e;--brass:#92700a}
[data-theme="snow"]{--bg:#f8fafc;--ink:#0f172a;--ink-soft:#475569;--brass:#7a5a00}
[data-theme="linen"]{--bg:#faf5ee;--ink:#292524;--ink-soft:#78716c;--brass:#92700a}
[data-theme="vellum"]{--bg:#f4ebd8;--ink:#3a2f20;--ink-soft:#7a6a52;--brass:#8a5a00}
[data-theme="porcelain"]{--bg:#f1f4f8;--ink:#1a2838;--ink-soft:#5a6b7e;--brass:#7a5a00}
[data-theme="sandstone"]{--bg:#f1ead9;--ink:#2e2a20;--ink-soft:#766e5c;--brass:#8a5a00}
[data-theme="mist"]{--bg:#ecf0f2;--ink:#1a2428;--ink-soft:#5f6e74;--brass:#7a5a00}
[data-theme="rose"]{--bg:#f9f0ee;--ink:#2a1f22;--ink-soft:#7a6467;--brass:#92500a}
/* light themes: the cinematic atmosphere (ghost numeral, top glow, vignette) was tuned for the
   dark nocturne — on a light canvas it turns into visible patches that muddy the reading and wash
   the text. Dial the atmosphere right down, lift the dim/focus, and darken the faint text tokens. */
[data-theme="paper"],[data-theme="snow"],[data-theme="linen"],[data-theme="vellum"],
[data-theme="porcelain"],[data-theme="sandstone"],[data-theme="mist"],[data-theme="rose"]{
  --vig:rgba(60,50,30,.05);
  --dim:color-mix(in srgb, var(--bg) 78%, #fff 22%);              /* focus scrim = a soft-white wash, not brown mud */
  --ghost:.02;                                                    /* ghost numeral barely there */
  --glow:color-mix(in srgb, var(--brass) 3.5%, transparent);      /* top glow far subtler */
  --ink-faint:color-mix(in srgb, var(--ink-soft) 82%, var(--bg) 18%);   /* keep secondary text legible */
  /* recede the page by dissolving it into the light canvas (a faint ghost), never by darkening */
  --focus-filter:blur(5px) opacity(.14) saturate(.6);
}

*{margin:0;padding:0;box-sizing:border-box}

.v5-root{
  background:var(--bg); color:var(--ink);
  font-family:var(--font-body); font-size:var(--fs-body); line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden; min-height:100vh;
  transition:background var(--dur-slow) ease, color var(--dur-slow) ease;
}
/* exclude .v5-btn so button-links keep their own color (else brass-on-brass = invisible) */
.v5-root a:not(.v5-btn):not(.v5-navbtn){color:var(--brass);text-decoration:none;transition:color var(--dur-fast)}
.v5-root a:not(.v5-btn):not(.v5-navbtn):hover{color:var(--ink)}
.v5-root a.v5-btn{text-decoration:none}
.v5-root a.v5-navbtn{text-decoration:none}
::selection{background:var(--brass-dim);color:var(--ink)}

/* ---- typography helpers ---- */
.v5-display{font-family:var(--font-display);font-weight:300;font-size:var(--fs-display);line-height:1.04;letter-spacing:-.01em}
.v5-display em{font-style:italic;color:var(--brass)}
.v5-h1{font-family:var(--font-display);font-weight:300;font-size:var(--fs-h1);line-height:1.1}
.v5-h2{font-family:var(--font-display);font-weight:300;font-size:var(--fs-h2);line-height:1.15}
.v5-h3{font-family:var(--font-display);font-weight:400;font-size:var(--fs-h3);line-height:1.2}
.v5-j-swap,.vr-title-j{font-family:var(--font-body);font-weight:300;font-size:.96em}
.v5-kicker{font-family:var(--font-ui);font-weight:500;font-size:var(--fs-kicker);letter-spacing:.26em;text-transform:uppercase;color:var(--brass-soft)}
.v5-lead{font-family:var(--font-body);font-size:1.2rem;line-height:1.7;color:var(--ink-soft);font-style:italic}
.v5-muted{color:var(--ink-soft)}
.v5-faint{color:var(--ink-faint)}

/* ---- containers ---- */
.v5-container{max-width:var(--content);margin:0 auto;padding:0 var(--s5)}
.v5-prose-width{max-width:var(--measure);margin:0 auto}

/* ============================ 2. ATMOSPHERE ============================== */
.v5-atmos{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.v5-glow{position:absolute;inset:0;background:radial-gradient(58% 42% at 50% -6%,var(--glow),transparent 62%);animation:v5-breathe 13s ease-in-out infinite}
.v5-vig{position:absolute;inset:0;background:radial-gradient(120% 100% at 50% 38%,transparent 56%,var(--vig))}
/* cinematic dim overlay (pages opt in by toggling body.focus) */
.v5-dim{position:fixed;inset:0;z-index:5;background:transparent;transition:background var(--dur-slow) var(--ease);pointer-events:none}
body.focus .v5-dim,body.na-open .v5-dim{background:var(--dim)}

/* ============================ 3. CHROME ================================= */
.v5-topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:var(--s5);height:var(--bar-h);padding:0 var(--s5);background:color-mix(in srgb,var(--bg-elev) 86%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.v5-brand{display:inline-flex;align-items:center;gap:var(--s2);font-family:var(--font-display);font-weight:400;font-size:1.05rem;letter-spacing:.02em;color:var(--ink)}
.v5-brand:hover{color:var(--ink)}
.v5-brand .dot{width:7px;height:7px;border-radius:50%;background:var(--brass);box-shadow:0 0 12px var(--brass)}
.v5-nav{display:flex;align-items:center;gap:var(--s5)}
.v5-nav a{font-family:var(--font-ui);font-size:.82rem;letter-spacing:.04em;color:var(--ink-soft)}
.v5-nav a:hover,.v5-nav a.current{color:var(--ink)}
.v5-bar-actions{display:flex;align-items:center;gap:var(--s2)}
.v5-bar-title{font-family:var(--font-ui);font-size:.82rem;letter-spacing:.04em;color:var(--ink-soft);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.v5-bar-title b{color:var(--brass);font-weight:600;letter-spacing:.14em;text-transform:uppercase;font-size:.72rem;margin-right:.5em}

/* ---- Menu-panel footer — the site footer lives at the bottom of the Menu side panel ---- */
.v5-menu-foot{flex:none;border-top:1px solid var(--line);padding:var(--s5) var(--s6) var(--s6);font-family:var(--font-ui);display:flex;flex-direction:column;gap:var(--s3)}
.v5-menu-foot__links{display:flex;flex-wrap:wrap;gap:var(--s3) var(--s5)}
.v5-menu-foot__links a{color:var(--ink-soft);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;transition:color var(--dur-fast)}
.v5-menu-foot__links a:hover{color:var(--brass)}
.v5-menu-foot__brand{color:var(--ink-faint);font-size:.7rem;letter-spacing:.06em}

/* ---- Menu header — Navigate/Anselm on the left, the Anselm logo right-justified across ---- */
.v5-menu-head{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--s4)}
.v5-menu-logo{flex:none;line-height:0}
.v5-menu-logo img{height:38px;width:auto;display:block}
.v5-menu-logo .l{display:none}   /* black logo (light themes) hidden by default (dark) */
/* light themes: show the black logo, hide the white one */
[data-theme="paper"] .v5-menu-logo .d,[data-theme="snow"] .v5-menu-logo .d,[data-theme="linen"] .v5-menu-logo .d,[data-theme="vellum"] .v5-menu-logo .d,[data-theme="porcelain"] .v5-menu-logo .d,[data-theme="sandstone"] .v5-menu-logo .d,[data-theme="mist"] .v5-menu-logo .d,[data-theme="rose"] .v5-menu-logo .d{display:none}
[data-theme="paper"] .v5-menu-logo .l,[data-theme="snow"] .v5-menu-logo .l,[data-theme="linen"] .v5-menu-logo .l,[data-theme="vellum"] .v5-menu-logo .l,[data-theme="porcelain"] .v5-menu-logo .l,[data-theme="sandstone"] .v5-menu-logo .l,[data-theme="mist"] .v5-menu-logo .l,[data-theme="rose"] .v5-menu-logo .l{display:block}

/* ---- Shared theme-aware Anselm logo (hero / context heads / anywhere) ---- */
.anselm-logo{display:block;line-height:0}
.anselm-logo img{width:auto;display:block}
.anselm-logo .l{display:none}   /* black logo (light themes) hidden by default (dark) */
[data-theme="paper"] .anselm-logo .d,[data-theme="snow"] .anselm-logo .d,[data-theme="linen"] .anselm-logo .d,[data-theme="vellum"] .anselm-logo .d,[data-theme="porcelain"] .anselm-logo .d,[data-theme="sandstone"] .anselm-logo .d,[data-theme="mist"] .anselm-logo .d,[data-theme="rose"] .anselm-logo .d{display:none}
[data-theme="paper"] .anselm-logo .l,[data-theme="snow"] .anselm-logo .l,[data-theme="linen"] .anselm-logo .l,[data-theme="vellum"] .anselm-logo .l,[data-theme="porcelain"] .anselm-logo .l,[data-theme="sandstone"] .anselm-logo .l,[data-theme="mist"] .anselm-logo .l,[data-theme="rose"] .anselm-logo .l{display:block}

/* ---- Shared CHROME button — one language for every floating control (matches the Menu trigger) ---- */
.v5-chrome{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-ui);font-size:.72rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink);
  background:color-mix(in srgb,var(--bg-elev) 92%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid var(--line-strong);border-radius:var(--r1);padding:.6rem 1.1rem;cursor:pointer;text-decoration:none;
  box-shadow:var(--sh1);transition:border-color var(--dur),box-shadow var(--dur),color var(--dur),background var(--dur);line-height:1}
.v5-chrome:hover,.v5-chrome.on{color:var(--brass);border-color:var(--brass-soft);box-shadow:0 0 20px var(--brass-dim)}
.v5-chrome svg{flex:none}
/* Back-to-parent chrome button, top-left, clearing the Menu trigger — one position for every sub-page */
.v5-back{position:fixed;top:16px;left:156px;z-index:55}
.v5-guest .v5-back{left:286px}

/* ---- SIDE PANEL — one component, identical left & right ----
   The commentary panel (right), Contents (left) and Menu (left) are ALL this.
   Same style, same width, same swing-in. Toggle .open to reveal. */
.v5-spanel{position:fixed;top:0;bottom:0;width:min(42%,460px);z-index:35;display:flex;flex-direction:column;opacity:0;pointer-events:none;transition:transform var(--dur-slow) var(--ease),opacity var(--dur)}
.v5-spanel--right{right:0;background:linear-gradient(285deg,var(--bg-elev),var(--bg) 90%);border-left:1px solid var(--line);transform-origin:right center;transform:perspective(1300px) rotateY(-34deg) translateX(30px)}
.v5-spanel--left{left:0;background:linear-gradient(75deg,var(--bg-elev),var(--bg) 90%);border-right:1px solid var(--line);transform-origin:left center;transform:perspective(1300px) rotateY(34deg) translateX(-30px)}
.v5-spanel.open{transform:perspective(1300px) rotateY(0) translateX(0);opacity:1;pointer-events:auto;box-shadow:var(--sh3)}
.v5-spanel__scroll{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding:var(--s8) var(--s6) var(--s6);transition:opacity .24s var(--ease),transform .24s var(--ease);scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.v5-spanel__scroll::-webkit-scrollbar{width:7px}
.v5-spanel__scroll::-webkit-scrollbar-track{background:transparent}
.v5-spanel__scroll::-webkit-scrollbar-thumb{background:var(--line);border-radius:6px;border:2px solid transparent;background-clip:padding-box}
.v5-spanel__scroll::-webkit-scrollbar-thumb:hover{background:var(--line-strong);background-clip:padding-box}
.v5-spanel__scroll.leaving{opacity:0;transform:translateX(26px)}
.v5-spanel .v5-kicker{display:block}
.v5-spanel .v5-ref{font-family:var(--font-display);font-weight:300;font-size:1.7rem;color:var(--ink);margin:.15em 0 .7em;line-height:1.05}
/* the ONE list-button style used inside panels (Contents pericopes, Menu links). rises in on open. */
.v5-navhead{font-family:var(--font-ui);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-soft);margin:var(--s6) 0 var(--s3)}
.v5-navlist{display:flex;flex-direction:column;gap:var(--s2)}
.v5-navbtn{display:flex;align-items:center;width:100%;justify-content:flex-start;font-family:var(--font-ui);font-size:.74rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);background:var(--surface);border:1px solid var(--line);border-radius:var(--r1);padding:.8rem 1rem;text-decoration:none;transition:color var(--dur-fast),border-color var(--dur-fast),background var(--dur-fast),box-shadow var(--dur-fast);opacity:0;transform:translateY(20px)}
.v5-navbtn:hover{color:var(--brass);border-color:rgba(201,163,95,.35);background:var(--surface-2);box-shadow:0 0 14px rgba(201,163,95,.12)}
.v5-navbtn.current{color:var(--brass);border-color:var(--brass-soft);background:var(--brass-dim)}
.v5-navbtn--fan{color:var(--bg);background:var(--brass);border-color:var(--brass);box-shadow:0 0 18px var(--brass-dim)}
.v5-navbtn--fan span{color:currentColor}
.v5-navbtn--fan:hover{color:var(--bg);background:color-mix(in srgb,var(--brass) 88%,var(--ink) 12%);border-color:var(--brass);box-shadow:0 0 24px var(--brass-dim)}
.v5-spanel.open .v5-navbtn{animation:v5-rise .5s var(--ease) forwards;animation-delay:calc(var(--i,0) * .035s)}
@media(prefers-reduced-motion:reduce){.v5-spanel.open .v5-navbtn{animation:none;opacity:1;transform:none}}
@media(max-width:860px){.v5-spanel{width:100%}}

/* ---- Menu trigger (upper-left). The panel it opens is a .v5-spanel--left. ---- */
.v5-menu{position:fixed;left:16px;top:16px;z-index:240;display:flex;align-items:center;gap:8px}
.v5-menu__btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-ui);font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);background:color-mix(in srgb,var(--bg-elev) 92%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--line-strong);border-radius:var(--r1);padding:.6rem 1.1rem;cursor:pointer;box-shadow:var(--sh1);transition:border-color var(--dur),box-shadow var(--dur),color var(--dur)}
.v5-menu__btn:hover{color:var(--brass);border-color:var(--brass-soft);box-shadow:0 0 20px var(--brass-dim)}
.v5-menu__btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.7;transition:transform var(--dur) var(--ease)}
.v5-menu__btn.open svg{transform:rotate(90deg);color:var(--brass)}
.v5-menu__btn.open{color:var(--brass);border-color:var(--brass)}
.v5-auth-entry{color:var(--bg);background:var(--brass);border-color:var(--brass)}
.v5-auth-entry:hover,.v5-auth-entry.open{color:var(--bg);background:#d9b370;border-color:#d9b370;box-shadow:0 0 22px var(--brass-dim)}
.v5-auth-panel{display:flex;flex-direction:column;gap:var(--s4)}
.v5-auth-copy{font-family:var(--font-body);font-size:1.02rem;line-height:1.62;color:var(--ink-soft);margin-top:calc(var(--s3) * -1)}
.v5-auth-form{display:flex;flex-direction:column;gap:var(--s3);margin-top:var(--s2)}
.v5-auth-row{display:flex;align-items:center;justify-content:space-between;gap:var(--s3);margin-bottom:calc(var(--s2) * -1)}
.v5-auth-link{font-family:var(--font-ui);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);text-decoration:none}
.v5-auth-link:hover{color:var(--brass)}
.v5-auth-check{align-items:flex-start;line-height:1.5;color:var(--ink-soft);font-family:var(--font-body)}
.v5-auth-check a{color:var(--brass)}
.v5-auth-switch{border-top:1px solid var(--line);padding-top:var(--s4);margin-top:var(--s2);display:flex;align-items:center;gap:var(--s3);flex-wrap:wrap;font-family:var(--font-body);color:var(--ink-soft)}

/* ============================ 4. BUTTONS ================================ */
.v5-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s2);font-family:var(--font-ui);font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);background:var(--surface);border:1px solid var(--line);border-radius:var(--r1);padding:.6rem 1.1rem;cursor:pointer;transition:all var(--dur-fast) var(--ease);white-space:nowrap;line-height:1}
.v5-btn:hover{color:var(--brass);border-color:rgba(201,163,95,.35);background:var(--surface-2);box-shadow:0 0 14px rgba(201,163,95,.1)}
.v5-btn:active{transform:translateY(1px)}
.v5-btn:focus-visible{outline:2px solid var(--brass);outline-offset:2px}
.v5-btn.active,.v5-btn[aria-pressed="true"]{color:var(--brass);border-color:rgba(201,163,95,.4)}
.v5-btn.is-icon{width:38px;height:38px;padding:0}
.v5-btn.is-icon svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.6}
.v5-btn--primary{color:var(--bg);background:var(--brass);border-color:var(--brass)}
.v5-btn--primary:hover{color:var(--bg);background:#d9b370;border-color:#d9b370;box-shadow:0 0 20px rgba(201,163,95,.28)}
.v5-btn--ghost{background:transparent;border-color:transparent;color:var(--ink-soft)}
.v5-btn--ghost:hover{color:var(--ink);background:var(--surface);box-shadow:none}
.v5-btn--danger:hover{color:var(--danger);border-color:rgba(176,67,47,.4);box-shadow:0 0 14px rgba(176,67,47,.12)}
.v5-btn--sm{padding:.4rem .75rem;font-size:.66rem}
.v5-btn--lg{padding:.85rem 1.6rem;font-size:.78rem}
.v5-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}

/* ============================ 5. CARDS ================================== */
.v5-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r2);padding:var(--s5);transition:border-color var(--dur-fast),background var(--dur-fast),box-shadow var(--dur-fast)}
.v5-card--interactive{cursor:pointer}
.v5-card--interactive:hover{border-color:var(--line-strong);background:var(--surface-2);box-shadow:var(--sh2)}
.v5-card__head{font-family:var(--font-display);font-size:1.2rem;color:var(--ink);margin-bottom:var(--s2)}
.v5-card__body{color:var(--ink-soft);font-size:var(--fs-sm);line-height:1.65}
.v5-card__foot{margin-top:var(--s4);padding-top:var(--s3);border-top:1px solid var(--line);display:flex;gap:var(--s2);align-items:center}

/* ============================ 6. OVERLAYS =============================== */
.v5-scrim{position:fixed;inset:0;z-index:48;background:rgba(0,0,0,.55);opacity:0;pointer-events:none;transition:opacity var(--dur)}
.v5-scrim.show{opacity:1;pointer-events:auto}
#v5menuScrim{z-index:220}
#v5menuPanel{z-index:230!important}

.v5-drawer{position:fixed;top:0;height:100%;width:340px;max-width:90vw;z-index:50;background:linear-gradient(180deg,var(--bg-elev),var(--bg));border-right:1px solid var(--line);padding:var(--s6) var(--s5);overflow-y:auto;transition:transform var(--dur) var(--ease)}
.v5-drawer--left{left:0;transform:translateX(-104%)}
.v5-drawer--right{right:0;left:auto;border-right:none;border-left:1px solid var(--line);transform:translateX(104%)}
.v5-drawer.show{transform:none}

.v5-panel{position:fixed;top:0;right:0;height:100%;width:min(46%,560px);z-index:50;background:linear-gradient(285deg,var(--bg-elev),var(--bg));border-left:1px solid var(--line);transform:translateX(102%);transition:transform var(--dur-slow) var(--ease);display:flex;flex-direction:column}
.v5-panel.show{transform:none}
.v5-panel__scroll{overflow-y:auto;padding:var(--s7) var(--s6);height:100%}

.v5-sheet{position:fixed;left:0;right:0;bottom:0;z-index:50;max-height:78vh;background:var(--bg-elev);border-top:1px solid var(--line);border-radius:var(--r3) var(--r3) 0 0;box-shadow:var(--sh3);transform:translateY(102%);transition:transform var(--dur) var(--ease);overflow-y:auto;padding:var(--s6) var(--s5)}
.v5-sheet.show{transform:none}
.v5-sheet::before{content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);width:42px;height:4px;border-radius:2px;background:var(--line-strong)}

.v5-modal-wrap{position:fixed;inset:0;z-index:49;display:grid;place-items:center;padding:var(--s5);opacity:0;pointer-events:none;transition:opacity var(--dur)}
.v5-modal-wrap.show{opacity:1;pointer-events:auto}
.v5-modal{width:min(560px,100%);background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--r3);box-shadow:var(--sh3);padding:var(--s6);transform:translateY(12px) scale(.98);transition:transform var(--dur) var(--ease)}
.v5-modal-wrap.show .v5-modal{transform:none}

.v5-close{position:absolute;top:var(--s4);right:var(--s4);width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:transparent;color:var(--ink-soft);cursor:pointer;font-size:20px;line-height:1;transition:all var(--dur-fast)}
.v5-close:hover{color:var(--brass);border-color:var(--brass);transform:rotate(90deg)}

/* ============================ 7. FORMS ================================== */
.v5-field{margin-bottom:var(--s5)}
.v5-label{display:block;font-family:var(--font-ui);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-soft);margin-bottom:var(--s2)}
.v5-input,.v5-textarea,.v5-select{width:100%;font-family:var(--font-ui);font-size:.95rem;color:var(--ink);background:var(--bg-sunk);border:1px solid var(--line);border-radius:var(--r1);padding:.7rem .9rem;transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}
.v5-input::placeholder,.v5-textarea::placeholder{color:var(--ink-faint)}
.v5-input:focus,.v5-textarea:focus,.v5-select:focus{outline:none;border-color:var(--brass-soft);box-shadow:0 0 0 3px var(--brass-dim)}
.v5-textarea{min-height:120px;resize:vertical;line-height:1.6}
.v5-input.invalid,.v5-textarea.invalid{border-color:var(--danger);box-shadow:0 0 0 3px rgba(176,67,47,.18)}
.v5-help{font-family:var(--font-ui);font-size:.75rem;color:var(--ink-faint);margin-top:var(--s2)}
.v5-help.error{color:var(--danger)}

.v5-toggle{position:relative;display:inline-flex;align-items:center;width:46px;height:26px;border-radius:var(--rpill);background:var(--bg-sunk);border:1px solid var(--line);cursor:pointer;transition:background var(--dur-fast),border-color var(--dur-fast)}
.v5-toggle::after{content:"";position:absolute;left:3px;width:18px;height:18px;border-radius:50%;background:var(--ink-soft);transition:transform var(--dur-fast) var(--ease),background var(--dur-fast)}
.v5-toggle[aria-checked="true"]{background:var(--brass-dim);border-color:var(--brass-soft)}
.v5-toggle[aria-checked="true"]::after{transform:translateX(20px);background:var(--brass)}

.v5-range{-webkit-appearance:none;appearance:none;width:100%;height:2px;background:var(--line-strong);border-radius:2px}
.v5-range::-webkit-slider-thumb{-webkit-appearance:none;width:17px;height:17px;border-radius:50%;background:var(--brass);cursor:pointer;box-shadow:0 0 10px var(--brass-dim)}
.v5-range::-moz-range-thumb{width:17px;height:17px;border:none;border-radius:50%;background:var(--brass)}

.v5-check,.v5-radio{display:inline-flex;align-items:center;gap:var(--s2);font-family:var(--font-ui);font-size:.9rem;color:var(--ink-soft);cursor:pointer}
.v5-check input,.v5-radio input{accent-color:var(--brass);width:16px;height:16px}

/* ============================ 8. DATA / FEEDBACK ======================== */
.v5-table{width:100%;border-collapse:collapse;font-family:var(--font-ui);font-size:.9rem}
.v5-table th{text-align:left;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass-soft);font-weight:500;padding:var(--s3) var(--s4);border-bottom:1px solid var(--line-strong)}
.v5-table td{padding:var(--s3) var(--s4);border-bottom:1px solid var(--line);color:var(--ink-soft)}
.v5-table tr:hover td{background:var(--surface);color:var(--ink)}

.v5-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-ui);font-size:.68rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:.28em .7em;border-radius:var(--rpill);background:var(--surface-2);color:var(--ink-soft);border:1px solid var(--line)}
.v5-badge--brass{background:var(--brass-dim);color:var(--brass);border-color:rgba(201,163,95,.35)}
.v5-badge--rubric{background:rgba(155,59,47,.16);color:#d98a7a;border-color:rgba(155,59,47,.4)}
.v5-badge--positive{background:rgba(111,143,106,.16);color:#9bbf93;border-color:rgba(111,143,106,.4)}

.v5-alert{display:flex;gap:var(--s3);align-items:flex-start;font-family:var(--font-ui);font-size:.9rem;line-height:1.55;padding:var(--s4);border-radius:var(--r2);border:1px solid var(--line);background:var(--surface);color:var(--ink-soft)}
.v5-alert::before{content:"";width:3px;align-self:stretch;border-radius:2px;background:var(--ink-faint);flex:none}
.v5-alert--info::before{background:var(--info)}
.v5-alert--success::before{background:var(--positive)}
.v5-alert--warn::before{background:var(--brass)}
.v5-alert--danger::before{background:var(--danger)}
.v5-alert b{color:var(--ink);font-weight:600}

.v5-tabs{display:flex;gap:var(--s5);border-bottom:1px solid var(--line)}
.v5-tab{font-family:var(--font-ui);font-size:.82rem;letter-spacing:.04em;color:var(--ink-soft);background:none;border:none;cursor:pointer;padding:var(--s3) 0;position:relative;transition:color var(--dur-fast)}
.v5-tab:hover{color:var(--ink)}
.v5-tab.active{color:var(--brass)}
.v5-tab.active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--brass)}

.v5-pagination{display:flex;gap:var(--s2);align-items:center;font-family:var(--font-ui)}
.v5-pagination a,.v5-pagination span{min-width:36px;height:36px;display:inline-grid;place-items:center;border:1px solid var(--line);border-radius:var(--r1);color:var(--ink-soft);font-size:.85rem;transition:all var(--dur-fast)}
.v5-pagination a:hover{color:var(--brass);border-color:rgba(201,163,95,.35)}
.v5-pagination .current{color:var(--brass);border-color:var(--brass-soft);background:var(--brass-dim)}

/* ============================ 9. EDITORIAL ============================== */
.v5-pagehead{padding:var(--s8) 0 var(--s6);text-align:center}
.v5-pagehead .v5-kicker{display:block;margin-bottom:var(--s3)}
.v5-pagehead h1{font-family:var(--font-display);font-weight:300;font-size:var(--fs-display);line-height:1.05;color:var(--ink)}
.v5-pagehead .v5-lead{margin:var(--s4) auto 0;max-width:42rem}

.v5-divider{height:1px;background:var(--line);border:none;margin:var(--s6) 0}
.v5-divider--ornate{display:flex;align-items:center;justify-content:center;gap:var(--s4);color:var(--brass-soft);border:none;background:none}
.v5-divider--ornate::before,.v5-divider--ornate::after{content:"";height:1px;width:60px;background:var(--line-strong)}

.v5-sect{margin-bottom:var(--s6);opacity:0;transform:translateY(22px)}
.v5-sect.static{opacity:1;transform:none}
.lit .v5-sect{animation:v5-rise var(--dur-slow) var(--ease) forwards}
.lit .v5-sect:nth-child(2){animation-delay:.08s}
.lit .v5-sect:nth-child(3){animation-delay:.16s}
.lit .v5-sect:nth-child(4){animation-delay:.24s}
.lit .v5-sect:nth-child(5){animation-delay:.32s}
.lit .v5-sect:nth-child(6){animation-delay:.4s}
.v5-sect>h4{font-family:var(--font-ui);font-weight:500;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);margin-bottom:var(--s4);display:flex;align-items:center;gap:var(--s3)}
.v5-sect>h4::after{content:"";flex:1;height:1px;background:var(--line)}
.v5-empty{font-style:italic;color:var(--ink-faint);font-size:.92rem;line-height:1.65}

/* lexicon / reference cards (shared scholarly primitives) */
.v5-cards{display:flex;flex-direction:column;gap:var(--s3)}
.v5-lex{border:1px solid var(--line);border-radius:var(--r2);padding:var(--s3) var(--s4);background:var(--surface);transition:border-color var(--dur-fast)}
.v5-lex:hover{border-color:var(--brass-soft)}
.v5-lex__top{display:flex;align-items:baseline;gap:var(--s3);margin-bottom:6px;flex-wrap:wrap}
.v5-lex__orig{font-family:var(--font-hebrew);font-size:1.5rem;color:var(--brass);direction:rtl;line-height:1}
.v5-lex__orig.greek{font-family:var(--font-greek);direction:ltr}
.v5-lex__tr{font-family:var(--font-body);font-style:italic;color:var(--ink);font-size:.95rem}
.v5-lex__gloss{margin-left:auto;font-family:var(--font-ui);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint)}
.v5-lex__note{font-family:var(--font-ui);font-size:.8rem;line-height:1.55;color:var(--ink-soft)}
.v5-ref-card{display:block;border:1px solid var(--line);border-radius:var(--r2);padding:var(--s3) var(--s4);background:var(--surface);transition:border-color var(--dur-fast),background var(--dur-fast)}
.v5-ref-card:hover{border-color:var(--brass-soft);background:var(--surface-2)}
.v5-ref-card__ref{font-family:var(--font-display);color:var(--brass);font-size:1.02rem}
.v5-ref-card__note{font-family:var(--font-ui);font-size:.8rem;line-height:1.55;color:var(--ink-soft);margin-top:4px}

/* ---- long-form prose (blog / markdown) ---- */
.v5-prose{font-family:var(--font-body);font-size:var(--fs-read);line-height:1.85;color:var(--ink-soft);max-width:var(--measure)}
.v5-prose>*+*{margin-top:1.1em}
.v5-prose h1,.v5-prose h2,.v5-prose h3,.v5-prose h4{font-family:var(--font-display);font-weight:300;color:var(--ink);line-height:1.2;margin-top:1.8em}
.v5-prose h1{font-size:var(--fs-h1)} .v5-prose h2{font-size:var(--fs-h2)}
.v5-prose h3{font-size:var(--fs-h3);font-weight:400} .v5-prose h4{font-size:var(--fs-h4)}
.v5-prose p{color:var(--ink-soft)}
.v5-prose strong{color:var(--ink);font-weight:600}
.v5-prose em{font-style:italic}
.v5-prose a:not(.v5-btn){color:var(--brass);text-decoration:underline;text-decoration-color:var(--brass-soft);text-underline-offset:3px}
.v5-prose a:not(.v5-btn):hover{color:var(--ink)}
.v5-prose blockquote{border-left:2px solid var(--brass-soft);padding-left:var(--s5);font-style:italic;color:var(--ink);font-size:1.3rem;font-family:var(--font-display);font-weight:300;line-height:1.5}
.v5-prose ul,.v5-prose ol{padding-left:1.4em} .v5-prose li{margin-top:.4em}
.v5-prose ul>li::marker{color:var(--brass-soft)} .v5-prose ol>li::marker{color:var(--brass-soft);font-family:var(--font-display)}
.v5-prose hr{border:none;height:1px;background:var(--line);margin:2em 0}
.v5-prose code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85em;background:var(--bg-sunk);border:1px solid var(--line);border-radius:4px;padding:.1em .4em;color:var(--brass)}
.v5-prose pre{background:var(--bg-sunk);border:1px solid var(--line);border-radius:var(--r2);padding:var(--s4);overflow-x:auto}
.v5-prose pre code{background:none;border:none;padding:0;color:var(--ink-soft)}
.v5-prose figure{margin:1.6em 0} .v5-prose img{max-width:100%;border-radius:var(--r2);display:block}
.v5-prose figcaption{font-family:var(--font-ui);font-size:.78rem;color:var(--ink-faint);text-align:center;margin-top:var(--s2)}

/* ============================ 10. MOTION =============================== */
@keyframes v5-rise{to{opacity:1;transform:none}}
@keyframes v5-breathe{0%,100%{opacity:.72}50%{opacity:1}}
@media(prefers-reduced-motion:reduce){
  *{transition-duration:.001ms!important;animation-duration:.001ms!important}
  .v5-sect{opacity:1;transform:none}
}

/* ============================ 11. UTIL ================================= */
.v5-row{display:flex;gap:var(--s3);align-items:center;flex-wrap:wrap}
.v5-stack{display:flex;flex-direction:column;gap:var(--s4)}
.v5-hide-mobile{display:initial}
@media(max-width:860px){
  .v5-hide-mobile{display:none}
  .v5-panel{width:100%}
  .v5-nav{gap:var(--s4)}
}

/* ============================ 12. FRONTISPIECE ========================= */
/* The cinematic landing/section layout: a giant ghost glyph backdrop (the reader's
   "depth" move) + flush-left oversized type + folio-numbered asymmetric sections.
   Shared by the landing (index), About, Privacy, Terms, Support. */
html:has(.fp-depth){scroll-behavior:smooth}   /* scoped to frontispiece pages, not the reader */

/* ghost glyph backdrop — cross-fades through the frontispiece Hebrew/Greek library as sections cross center */
.fp-depth{position:fixed;inset:0;z-index:0;display:grid;place-items:center;pointer-events:none;overflow:hidden}
.fp-depth .glyph{font-family:var(--font-hebrew);font-weight:400;font-size:78vmin;line-height:.78;color:var(--brass);opacity:.05;user-select:none;
  transform:translate3d(8vw, calc(var(--scrolly,0)*-.035px), 0);will-change:transform,opacity;transition:opacity .45s var(--ease)}
.fp-depth .glyph.gr{font-family:var(--font-greek);font-weight:300}

/* reveal mechanics */
.lp-rise{opacity:0;transform:translateY(24px)}
.lit .lp-rise{animation:v5-rise var(--dur-slow) var(--ease) forwards;animation-delay:calc(var(--i,0)*.1s)}
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.lp-rise,.reveal{opacity:1!important;transform:none!important;animation:none!important;transition:none!important}.fp-depth .glyph{transform:translate3d(8vw,0,0)!important}}

.fp{position:relative;z-index:2}
.fpwrap{max-width:74rem;margin:0 auto;padding:0 clamp(var(--s5),7vw,90px)}
/* top-right chrome cluster + a side panel that clears the scrim (shared by sub-pages) */
.rtop{position:fixed;top:16px;right:16px;z-index:55;display:flex;gap:8px}
.v5-spanel--over{z-index:50}
#v5menuScrim{background:transparent}
/* when the site menu is open its panel (z52) sits under page chrome (z55) — hide the chrome so it can't bleed over the menu options */
body:has(#v5menuPanel.open) .v5-chrome,
body:has(#v5menuPanel.open) .rtop{opacity:0;pointer-events:none;transition:opacity var(--dur) var(--ease)}

/* hero — flush-left, oversized */
.fp-hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
  max-width:74rem;margin:0 auto;padding:clamp(var(--s9),14vh,170px) clamp(var(--s5),7vw,90px) clamp(var(--s8),12vh,150px)}
/* sub-page hero: a tall masthead, not a full screen, so content arrives sooner */
.fp-hero--sub{min-height:auto;justify-content:flex-end;padding:clamp(var(--s9),20vh,220px) clamp(var(--s5),7vw,90px) clamp(var(--s6),6vh,70px)}
.fp-hero__logo img{height:clamp(34px,4vw,52px)}
.fp-hero__kick{font-family:var(--font-ui);font-size:.74rem;font-weight:500;letter-spacing:.36em;text-transform:uppercase;color:var(--brass);margin-top:var(--s6)}
.fp-hero--sub .fp-hero__kick{margin-top:0}
.fp-title{font-family:var(--font-display);font-weight:300;font-size:clamp(3.2rem,12vw,9rem);line-height:.9;letter-spacing:-.02em;color:var(--ink);margin:var(--s4) 0 0;text-wrap:balance}
.fp-title em{display:block;font-style:italic;color:var(--brass-soft)}
.fp-hero--sub .fp-title{font-size:clamp(2.8rem,8vw,5.5rem);line-height:.95}
.fp-hero__latin{font-family:var(--font-display);font-style:italic;font-weight:300;font-size:clamp(1.05rem,2.2vw,1.5rem);color:var(--brass-soft);margin-top:var(--s5)}
.fp-hero__dek{font-family:var(--font-body);font-size:clamp(1.1rem,1.7vw,1.35rem);line-height:1.6;color:var(--ink-soft);max-width:42rem;margin-top:var(--s5)}
.fp-updated{font-family:var(--font-ui);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-soft);margin-top:var(--s4)}
.fp-hero__cta{display:flex;gap:var(--s3);flex-wrap:wrap;margin-top:var(--s7)}
.fp-scroll{position:absolute;left:clamp(var(--s5),7vw,90px);bottom:var(--s6);display:flex;align-items:center;gap:10px;
  font-family:var(--font-ui);font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-faint);opacity:.7}
.fp-scroll svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.5;animation:fp-bob 2.4s var(--ease) infinite}
@keyframes fp-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}
@media(prefers-reduced-motion:reduce){.fp-scroll svg{animation:none}}

/* folio-numbered sections (asymmetric editorial grid) */
.fp-sec{display:grid;grid-template-columns:7rem minmax(0,1fr);gap:clamp(var(--s5),5vw,var(--s8));
  padding:clamp(var(--s8),12vh,150px) 0;border-top:1px solid var(--line)}
.fp-folio{position:sticky;top:var(--s7);align-self:start;height:max-content}
.fp-folio__n{font-family:var(--font-display);font-weight:300;font-style:italic;font-size:clamp(2.2rem,4vw,3.4rem);line-height:.9;color:var(--brass-soft)}
.fp-folio__l{font-family:var(--font-ui);font-size:.6rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);margin-top:var(--s3);display:block}
.fp-main{min-width:0}
.fp-h{font-family:var(--font-display);font-weight:300;font-size:clamp(1.9rem,4vw,2.9rem);line-height:1.04;color:var(--ink);margin:0 0 var(--s5);text-wrap:balance}
.fp-sec--tight{padding:clamp(var(--s6),6vh,var(--s8)) 0}                 /* dense docs (legal) */
.fp-sec--tight .fp-h{font-size:clamp(1.4rem,3vw,1.9rem);margin-bottom:var(--s4)}
@media(max-width:760px){
  .fp-sec{grid-template-columns:1fr;gap:var(--s4);padding:clamp(var(--s7),9vh,100px) 0}
  .fp-folio{position:static;display:flex;align-items:baseline;gap:var(--s3)}
  .fp-folio__l{margin-top:0}
}

/* prose + pull-quote */
.fp-prose{font-family:var(--font-body);font-size:1.22rem;line-height:1.85;color:var(--ink-soft);max-width:40rem}
.fp-prose>*+*{margin-top:1.1em}
.fp-prose em{color:var(--ink);font-style:italic}
/* legal/dense prose variant used inside folio sections (reuses .v5-prose for lists/links) */
.fp-main .v5-prose{max-width:46rem;font-size:1.05rem;line-height:1.8}
.fp-main .v5-prose>*:first-child{margin-top:0}
.fp-pull{font-family:var(--font-display);font-weight:300;font-style:italic;font-size:clamp(1.7rem,3.6vw,2.6rem);line-height:1.25;color:var(--ink);
  margin-top:clamp(var(--s7),7vh,80px);max-width:34rem;padding-left:var(--s5);border-left:2px solid var(--brass-soft)}
.fp-pull cite{display:block;font-style:normal;font-family:var(--font-ui);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-soft);margin-top:var(--s4)}

/* big-number graphic */
.fp-num{font-family:var(--font-display);font-weight:300;font-size:clamp(3.4rem,15vw,11rem);line-height:.9;letter-spacing:-.03em;color:var(--brass);
  font-variant-numeric:tabular-nums;margin:0}
.fp-num__lead{font-family:var(--font-display);font-style:italic;font-weight:300;font-size:clamp(1.2rem,2.2vw,1.6rem);color:var(--ink-soft)}
.fp-num__note{font-family:var(--font-body);font-size:1.08rem;line-height:1.65;color:var(--ink-soft);max-width:38rem;margin-top:var(--s5)}

/* left-aligned editorial list (commitments, etc.) */
.fp-tenet{display:grid;grid-template-columns:2.6rem 1fr;gap:var(--s4);padding:var(--s5) 0;border-bottom:1px solid var(--line)}
.fp-tenet:first-child{border-top:1px solid var(--line)}
.fp-tenet__n{font-family:var(--font-display);font-weight:300;font-style:italic;font-size:1.4rem;color:var(--brass-soft);line-height:1.2}
.fp-tenet__t{font-family:var(--font-display);font-weight:300;font-size:1.45rem;line-height:1.1;color:var(--ink)}
.fp-tenet__d{font-family:var(--font-body);font-size:1.02rem;line-height:1.6;color:var(--ink-soft);margin-top:var(--s2)}

/* card grid for cross-linking (writing) */
.fp-journal{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--s5)}
.fp-post{display:flex;flex-direction:column;text-decoration:none;background:var(--surface);border:1px solid var(--line);border-radius:var(--r2);overflow:hidden;transition:border-color var(--dur-fast),box-shadow var(--dur-fast),transform var(--dur-fast)}
.fp-post:hover{border-color:var(--line-strong);box-shadow:var(--sh2);transform:translateY(-3px)}
.fp-post__media{aspect-ratio:16/9;overflow:hidden;background:linear-gradient(135deg,var(--brass-dim),transparent 70%),var(--bg-elev)}
.fp-post__media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur-slow) var(--ease)}
.fp-post:hover .fp-post__media img{transform:scale(1.04)}
.fp-post__body{padding:var(--s5);display:flex;flex-direction:column;gap:var(--s2);flex:1}
.fp-post__kick{font-family:var(--font-ui);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-soft)}
.fp-post__title{font-family:var(--font-display);font-weight:300;font-size:1.4rem;line-height:1.2;color:var(--ink)}
.fp-post__dek{font-family:var(--font-body);font-size:.95rem;line-height:1.6;color:var(--ink-soft)}

/* closing + colophon */
.fp-closing{border-top:1px solid var(--line);padding:clamp(var(--s8),12vh,150px) 0 0}
.fp-closing__h{font-family:var(--font-display);font-weight:300;font-size:clamp(2.2rem,6vw,4rem);line-height:1;color:var(--ink);max-width:18ch}
.fp-closing__p{font-family:var(--font-body);font-size:1.1rem;line-height:1.7;color:var(--ink-soft);max-width:40rem;margin-top:var(--s4)}
.fp-closing__cta{display:flex;gap:var(--s3);flex-wrap:wrap;margin-top:var(--s6)}
.fp-colophon{margin-top:clamp(var(--s9),12vh,140px);padding:var(--s7) 0 clamp(var(--s8),10vh,110px);border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:var(--s5);flex-wrap:wrap}
.fp-colophon__brand{display:flex;align-items:center;gap:var(--s4)}
.fp-colophon__logo img{height:26px}
.fp-colophon__latin{font-family:var(--font-display);font-style:italic;font-weight:300;font-size:1.05rem;color:var(--brass-soft)}
.fp-colophon__links{display:flex;gap:var(--s5);flex-wrap:wrap}
.fp-colophon__links a{font-family:var(--font-ui);font-size:.76rem;letter-spacing:.06em;color:var(--ink-soft);text-decoration:none;transition:color var(--dur-fast)}
.fp-colophon__links a:hover{color:var(--brass)}
.fp-colophon__copy{font-family:var(--font-ui);font-size:.68rem;letter-spacing:.08em;color:var(--ink-faint);width:100%}

/* ============================ 13. MOBILE SYSTEM ========================= */
@media(max-width:760px){
  :root{
    --fs-display:clamp(2.25rem,13vw,3.6rem);
    --fs-h1:clamp(1.9rem,9vw,2.45rem);
    --fs-h2:clamp(1.55rem,7vw,2rem);
    --fs-h3:clamp(1.22rem,5.5vw,1.5rem);
    --fs-read:1.08rem;
    --fs-body:1rem;
    --content:100vw;
  }
  html,body{max-width:100%;overflow-x:hidden;-webkit-text-size-adjust:100%}
  img,video,canvas,svg{max-width:100%}
  .v5-container,.fpwrap{padding-left:var(--s4);padding-right:var(--s4)}
  .v5-display,.v5-h1,.v5-h2,.v5-h3,.v5-pagehead h1,
  .fp-title,.fp-h,.fp-pull,.fp-closing__h,
  .v5-prose h1,.v5-prose h2,.v5-prose h3,
  .v5-spanel .v5-ref{overflow-wrap:break-word;text-wrap:balance}
  .v5-prose{font-size:var(--fs-read);line-height:1.75}
  .v5-prose blockquote{font-size:1.15rem;padding-left:var(--s4)}
  .v5-table{display:block;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}

  .v5-menu{top:max(10px,env(safe-area-inset-top));left:max(10px,env(safe-area-inset-left))}
  .v5-menu__btn,.v5-chrome{
    min-height:40px;
    padding:.58rem .76rem;
    gap:6px;
    font-size:.62rem;
    letter-spacing:.09em;
    line-height:1;
    white-space:nowrap;
    max-width:calc(100vw - 20px);
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .v5-menu__btn svg,.v5-chrome svg{width:14px!important;height:14px!important}
  .v5-chrome svg{display:none!important}
  .v5-btn svg,.v5-navbtn svg{display:none!important}
  .v5-menu__btn svg{display:block!important}
  .v5-back,
  .ltop,
  [style*="top:16px"][style*="left:152px"],
  [style*="top:16px"][style*="left:156px"]{
    top:max(10px,env(safe-area-inset-top))!important;
    left:104px!important;
    z-index:55!important;
  }
  .v5-guest .v5-back{
    top:calc(max(10px,env(safe-area-inset-top)) + 48px)!important;
    left:max(10px,env(safe-area-inset-left))!important;
  }
  .ltop{display:flex;gap:6px;max-width:calc(100vw - 116px);overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .ltop::-webkit-scrollbar,.rtop::-webkit-scrollbar{display:none}
  .rtop{
    top:max(10px,env(safe-area-inset-top))!important;
    right:max(10px,env(safe-area-inset-right))!important;
    gap:6px!important;
    max-width:calc(100vw - 112px);
    overflow-x:auto;
    justify-content:flex-end;
    scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
  }
  body:has(.v5-back) .rtop{max-width:calc(100vw - 212px)}
  .ctop{
    position:fixed!important;
    top:58px!important;
    left:var(--s4)!important;
    right:var(--s4)!important;
    z-index:55!important;
    display:flex;
    justify-content:center;
    pointer-events:none;
  }
  .ctop .v5-chrome{pointer-events:auto}
  .v5-spanel{width:100%!important;max-width:100vw!important;overflow:hidden;box-sizing:border-box}
  .v5-spanel__scroll{box-sizing:border-box;padding:calc(var(--s8) + env(safe-area-inset-top)) clamp(1.35rem,5vw,1.75rem) var(--s6);max-width:100%;overflow-x:hidden}
  .v5-spanel--right .v5-spanel__scroll{padding-left:clamp(1.65rem,6vw,2.15rem)}
  .v5-spanel--left .v5-spanel__scroll{padding-right:clamp(1.65rem,6vw,2.15rem)}
  .v5-spanel *{max-width:100%;overflow-wrap:break-word}
  .v5-spanel .v5-navbtn,.v5-spanel .v5-card,.v5-spanel .pd-card,.v5-spanel .pd-pick,.v5-spanel .pd-follow,.v5-spanel .arch-row{box-sizing:border-box;min-width:0}
  .v5-spanel input,.v5-spanel textarea,.v5-spanel select{min-width:0}
  .v5-spanel .v5-btn,.v5-spanel .v5-chrome{white-space:normal}
  .v5-menu-foot{padding:var(--s5) var(--s4) calc(var(--s6) + env(safe-area-inset-bottom))}
  .v5-panel{width:100%;max-width:100vw}
  .v5-modal-wrap{padding:var(--s4)}
  .v5-modal{max-width:100%;padding:var(--s5)}
  .v5-card{padding:var(--s4)}
  .v5-row{gap:var(--s2)}
  .cf-card:not(.is-active)>*{opacity:0!important}
  .cf-card.is-active>*{opacity:1}

  .fp-depth .glyph{font-size:86vmin;transform:translate3d(18vw,calc(var(--scrolly,0)*-.02px),0)}
  .fp-hero{min-height:92vh;min-height:92dvh;padding:clamp(6.8rem,17vh,9rem) var(--s4) clamp(var(--s7),9vh,6rem)}
  .fp-hero--sub{padding:clamp(6.6rem,16vh,8.5rem) var(--s4) var(--s6)}
  .fp-title{font-size:clamp(3rem,18vw,5.4rem);line-height:.92}
  .fp-hero--sub .fp-title{font-size:clamp(2.6rem,14vw,4.4rem)}
  .fp-hero__kick{letter-spacing:.24em}
  .fp-hero__dek{font-size:1.08rem;line-height:1.55}
  .fp-scroll{left:var(--s4);bottom:var(--s5)}
  .fp-pull{padding-left:var(--s4)}
  .fp-journal{grid-template-columns:1fr}
  .fp-colophon{align-items:flex-start}
}

@media(max-width:430px){
  .v5-menu__btn{width:40px;height:40px;padding:0;justify-content:center}
  .v5-menu__btn span{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
  .v5-back,
  .ltop,
  [style*="top:16px"][style*="left:152px"],
  [style*="top:16px"][style*="left:156px"]{left:58px!important}
  .ltop{max-width:calc(100vw - 70px)}
  .rtop{max-width:calc(100vw - 68px)}
  body:has(.v5-back) .rtop{max-width:calc(100vw - 166px)}
  .v5-chrome{max-width:8.4rem;padding:.58rem .66rem;font-size:.58rem;letter-spacing:.075em}
  .rtop .v5-chrome{max-width:7.4rem}
  .v5-btn{white-space:normal;text-align:center;line-height:1.15}
}
