/* Local inscription capitals — Trajan-like. font-display:swap so a CDN/file miss
   never blocks render; the Cinzel/Cormorant fallback in --display keeps titles
   readable if RomanSD.ttf 404s. */
@font-face{
  font-family:"Roman SD";
  src:url("../assets/fonts/RomanSD.ttf") format("truetype");
  font-weight:400 700;
  font-style:normal;
  font-display:swap;
}
/* =============================================================
   IMPERIVM ROMANVM — Editorial minimalism, restrained 3D.
   North star: award-winning print magazine with a few quiet
   marble moments. Negative space, commanding serif type,
   hairline rules, ONE 3D object per scene. Never busy.
   ============================================================= */

:root{
  --bg:        #0B0A0D;   /* deep warm-dark */
  --bg-soft:   #100E12;
  --ink:       #E8E3D8;   /* marble-white body */
  --ink-dim:   #9A9489;   /* muted */
  --ink-faint: #7A7468;   /* muted text — raised for WCAG contrast (was #5C574E ~2.6:1) */
  --gold:      #C9A961;   /* accent only */
  --gold-deep: #A98843;
  --rule:      rgba(232,227,216,0.14);
  --rule-soft: rgba(232,227,216,0.07);

  --serif:  "Cormorant Garamond", Georgia, serif;
  --display:"Roman SD", "Cinzel", "Cormorant Garamond", serif;
  /* Legible system monospace. Space Mono's O/0/D glyphs garble badly at
     small size + gold-on-dark + wide tracking (DOI 10 → DDI 1D, FİLOZOF →
     FİLDZDF), so we drop it entirely for a clean mono stack that keeps the
     technical feel while rendering 0/O/D unambiguously. */
  --mono:   ui-monospace, "SFMono-Regular", "Cascadia Code", "Roboto Mono", Menlo, Consolas, "Liberation Mono", monospace;
  /* SMALL UPPERCASE labels (eyebrows, nav, kickers, CTAs, era names).
     Roman SD leads so every label reads as carved inscription; Cinzel
     follows so the Turkish glyphs Roman SD lacks (İ ı ş ğ Ş Ğ → mixed-font
     per-glyph fallback) still render as clean caps, never as tofu. These
     are ALWAYS uppercase (text-transform:uppercase on every consumer), so
     Roman SD's caps-first inscription character carries the whole UI. */
  --label:  "Roman SD", "Cinzel", "Cormorant Garamond", Georgia, serif;

  --pad: clamp(22px, 5.5vw, 90px);
  --maxw: 1500px;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(17px,1.15vw,20px);
  line-height:1.62;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.no-scroll{ overflow:hidden; height:100vh; }
/* while actively drag-orbiting the bust, suppress the browser's touch
   scroll/gesture so the drag rotates instead of scrolling the page */
body.dragging-bust{ touch-action:none; }

::selection{ background:rgba(201,169,97,.28); color:#fff; }

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

/* subtle warmth overlay to avoid flat black */
body::before{
  content:"";
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(120% 90% at 78% 8%, rgba(201,169,97,.05), transparent 55%),
    radial-gradient(100% 80% at 12% 95%, rgba(120,90,50,.05), transparent 60%);
}

/* ---------- shared 3D canvas ---------- */
#bg-canvas{
  position:fixed; inset:0;
  width:100%; height:100%;
  z-index:1;
  pointer-events:none;
  opacity:0;
  transition:opacity 1.4s ease;
}
#bg-canvas.ready{ opacity:1; }
body.nowebgl #bg-canvas{ display:none; }

/* ===========================================================
   LOADER
   =========================================================== */
#loader{
  position:fixed; inset:0; z-index:1000;
  background:var(--bg);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center;
  padding:var(--pad);
  transition:opacity 1s ease, visibility 1s ease;
}
#loader.hidden{ opacity:0; visibility:hidden; pointer-events:none; }
#loader .l-eyebrow{
  font-family:var(--label);
  font-size:11px; letter-spacing:.4em; text-transform:uppercase;
  color:var(--gold); margin-bottom:34px; padding-left:.5em;
}
#loader .l-title{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(30px,7vw,72px);
  letter-spacing:.12em;
  color:var(--ink);
  line-height:1.05;
}
#loader .l-latin{
  font-family:var(--label);
  font-size:clamp(10px,1vw,12.5px);
  letter-spacing:.46em; text-transform:uppercase;
  color:var(--gold); opacity:.9;
  margin-top:20px; padding-left:.5em;
}
#loader .l-sub{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(16px,2.2vw,22px);
  color:var(--ink-dim);
  margin-top:18px;
}
.l-bar-wrap{
  width:min(340px,70vw);
  margin:54px auto 14px;
  height:1px; background:var(--rule);
  position:relative; overflow:hidden;
}
.l-bar{
  position:absolute; left:0; top:0; height:100%;
  width:0%; background:var(--gold);
  transition:width .5s ease;
}
.l-pct{
  font-family:var(--serif);   /* serif, never mono — narrow glyphs garble */
  font-size:15px; letter-spacing:.18em;
  color:var(--ink-dim);
}
#enterBtn{
  margin-top:44px;
  font-family:var(--display);
  font-size:13px; letter-spacing:.4em; text-transform:uppercase;
  color:var(--bg);
  background:var(--gold);
  border:none;
  padding:16px 42px;
  cursor:not-allowed;
  opacity:.35;
  transition:opacity .5s ease, background .35s ease, transform .35s ease;
  pointer-events:none;
}
#enterBtn.live{
  opacity:1; cursor:pointer; pointer-events:auto;
}
#enterBtn.live:hover{ background:var(--ink); transform:translateY(-2px); }

/* ===========================================================
   NAV
   =========================================================== */
header.nav{
  position:fixed; top:0; left:0; right:0; z-index:300;
  display:flex; align-items:center; justify-content:space-between;
  padding:24px var(--pad);
  transition:background .5s ease, padding .5s ease;
}
header.nav.solid{
  background:linear-gradient(to bottom, rgba(11,10,13,.92), rgba(11,10,13,0));
}
.nav .brand{
  font-family:var(--display);
  font-size:14px; letter-spacing:.34em;
  color:var(--ink); white-space:nowrap;
}
.nav .brand b{ color:var(--gold); font-weight:600; }
.nav-right{ display:flex; align-items:center; gap:26px; }
.nav nav{ display:flex; gap:26px; }
.nav nav a{
  font-family:var(--label);
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-dim);
  transition:color .3s ease;
}
.nav nav a:hover{ color:var(--gold); }

.lang-toggle{
  /* TR / EN are pure Latin caps — carve them in Roman SD so the toggle
     matches the inscription nav; mono kept only as a last-resort fallback. */
  font-family:var(--display);
  font-size:11px; letter-spacing:.22em;
  border:1px solid var(--rule);
  border-radius:2px;
  display:flex; overflow:hidden;
}
.lang-toggle button{
  background:none; border:none; cursor:pointer;
  color:var(--ink-dim);
  padding:6px 12px;
  font-family:inherit; font-size:inherit; letter-spacing:inherit;
  transition:background .3s, color .3s;
}
.lang-toggle button.active{ background:var(--gold); color:var(--bg); }

.nav-burger{ display:none; }

/* Mobile menu overlay is hidden on desktop. Without this base rule the
   overlay's nav links fell into normal flow at the very top of <body> and
   overlapped the IMPERIVM ROMANVM wordmark on entry. The mobile media query
   below re-styles it into the full-screen menu. */
.nav-overlay{ display:none; }

/* ===========================================================
   LAYOUT PRIMITIVES — editorial grid, hairlines, margins
   =========================================================== */
main{ position:relative; z-index:5; }

.movement{
  position:relative;
  min-height:auto;
  padding:clamp(72px,11vh,118px) var(--pad);
  display:flex; flex-direction:column; justify-content:center;
}
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; }

/* margin section number, e.g. 01 — 06 */
.sec-no{
  position:absolute;
  top:clamp(80px,12vh,130px); left:var(--pad);
  font-family:var(--mono);
  font-size:11px; letter-spacing:.3em;
  color:var(--gold);
}
.sec-no .of{ color:var(--ink-faint); }
.sec-label{
  font-family:var(--label);
  font-size:12px; letter-spacing:.26em; text-transform:uppercase;
  color:var(--ink-dim);
  margin-bottom:30px;
}

.hairline{ height:1px; background:var(--rule); border:0; width:100%; }
.hairline.soft{ background:var(--rule-soft); }

/* commanding serif headings */
h2.title{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(34px,6.2vw,82px);
  line-height:1.02;
  letter-spacing:.015em;
  color:var(--ink);
}
.lead{
  font-size:clamp(20px,2.4vw,30px);
  line-height:1.5;
  font-weight:300;
  color:var(--ink);
}
.body-col{
  max-width:30em;
  color:var(--ink);
  font-size:clamp(17px,1.26vw,21px);
  /* a touch more air so the Cormorant running text breathes like a printed
     page — the "vibe" in body copy comes from generous leading + the carved
     lead-in / drop-cap below, NOT from setting sentences in inscription caps */
  line-height:1.72;
}
.body-col p + p{ margin-top:1.18em; }
.dim{ color:var(--ink-dim); }
.gold{ color:var(--gold); }
.it{ font-style:italic; }

/* ---- Roman lead-in: first WORD of a key paragraph carved in Roman SD,
   in gold, uppercase — gives the paragraph an inscription "opening" while
   every following sentence stays in readable Cormorant. Applied via a
   <span class="lead-in"> wrapper so glyph fallback (İ/ş→Cinzel) is safe. */
.body-col .lead-in,
.lead .lead-in{
  font-family:var(--display);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--gold);
  /* nudge the carved caps onto the serif baseline so the line stays even */
  font-size:1.04em;
}

/* ---- Drop-cap: large carved Roman SD initial on the opening paragraph of a
   movement. .drop-cap on the <p>; readability preserved because only the
   single initial changes face — the sentence remains Cormorant. */
.body-col p.drop-cap::first-letter{
  font-family:var(--display);
  font-weight:600;
  color:var(--gold);
  float:left;
  font-size:3.1em;
  line-height:.82;
  padding:.04em .14em .02em 0;
  margin-top:.02em;
}

/* kinetic clip-reveal for big headings */
.reveal-mask{ overflow:hidden; display:block; }
.reveal-mask > span{ display:block; will-change:transform; }

/* ===========================================================
   01 — COVER
   =========================================================== */
#cover{ justify-content:flex-end; min-height:100vh; padding-top:clamp(120px,18vh,200px); padding-bottom:clamp(40px,7vh,80px); }
/* canvas-art movements get a touch more breathing room so the 3D model frames well */
#soul, #akademia{ min-height:92vh; }
#cover .kicker{
  font-family:var(--label);
  font-size:12px; letter-spacing:.28em; text-transform:uppercase;
  color:var(--gold); margin-bottom:28px;
}
#cover h1{
  font-family:var(--display);
  font-weight:600;
  font-size:clamp(46px,12.5vw,180px);
  line-height:.92;
  letter-spacing:.02em;
  color:var(--ink);
}
#cover h1 .l2{ color:var(--gold); }
#cover .motto-latin{
  margin-top:26px;
  font-family:var(--display);
  font-size:clamp(11px,1.05vw,14px);
  letter-spacing:.46em;
  text-transform:uppercase;
  color:var(--gold);
  opacity:.92;
}
#cover .motto{
  margin-top:36px;
  font-style:italic;
  font-size:clamp(20px,3vw,38px);
  font-weight:300;
  color:var(--ink);
  max-width:18em;
}
#cover .motto .alt{
  display:block;
  font-size:clamp(14px,1.5vw,18px);
  font-style:normal;
  letter-spacing:.04em;
  color:var(--ink-dim);
  margin-top:8px;
}
#cover .cover-foot{
  display:flex; justify-content:space-between; align-items:flex-end;
  flex-wrap:wrap; gap:16px;
  margin-top:clamp(40px,9vh,90px);
  padding-top:22px;
  border-top:1px solid var(--rule);
}
#cover .cover-foot .meta{
  font-family:var(--label);
  font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-dim);
}
.scroll-hint{
  font-family:var(--label);
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-dim);
  display:flex; align-items:center; gap:12px;
}
.scroll-hint .line{
  width:46px; height:1px; background:var(--gold);
  transform-origin:left; animation:pulseLine 2.6s ease-in-out infinite;
}
@keyframes pulseLine{ 0%,100%{transform:scaleX(.4);opacity:.5} 50%{transform:scaleX(1);opacity:1} }

/* ===========================================================
   02 — THE SOUL (asymmetric: text left, bust right in canvas)
   =========================================================== */
#soul .soul-grid{
  display:grid;
  grid-template-columns:minmax(0,0.92fr) minmax(0,1.08fr);
  gap:clamp(30px,6vw,80px);
  align-items:center;
}
#soul .soul-text{ max-width:34em; }
#soul .soul-art{ min-height:42vh; } /* empty — bust lives in canvas */
#soul .motto-line{
  margin-top:40px;
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(18px,2.1vw,26px);
  letter-spacing:.05em;
  color:var(--gold);
}

/* ===========================================================
   03 — THE EXCHANGE
   =========================================================== */
#exchange .dialogue{
  margin-top:46px;
  max-width:46em;
}
.turn{
  padding:26px 0;
  border-top:1px solid var(--rule-soft);
}
.turn .who{
  font-family:var(--label);
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-dim);
  margin-bottom:10px;
}
.turn.a .who{ color:var(--gold); }
.turn .said{
  font-size:clamp(18px,1.9vw,25px);
  line-height:1.55;
  font-weight:300;
}
.turn.a .said{ font-style:italic; color:var(--ink); }

.tryit{
  margin-top:60px;
  max-width:44em;
}
.tryit .ti-label{
  font-family:var(--label);
  font-size:12px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold); margin-bottom:18px;
}
.ti-row{
  display:flex; align-items:flex-end; gap:14px;
  border-bottom:1px solid var(--rule);
  padding-bottom:10px;
}
.ti-row input{
  flex:1;
  background:none; border:none; outline:none;
  font-family:var(--serif);
  font-size:clamp(18px,2vw,26px);
  font-weight:300; font-style:italic;
  color:var(--ink);
  padding:6px 0;
}
.ti-row input::placeholder{ color:var(--ink-faint); font-style:italic; }
.ti-row button{
  background:none; border:none; cursor:pointer;
  font-family:var(--label);
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold);
  padding:8px 4px; white-space:nowrap;
  transition:color .3s, transform .3s;
}
.ti-row button:hover{ color:var(--ink); transform:translateX(3px); }
.ti-answer{
  margin-top:30px;
  overflow:hidden;
  max-height:0;
  opacity:0;
  transition:max-height .7s ease, opacity .7s ease;
}
.ti-answer.show{ max-height:600px; opacity:1; }
.ti-answer .ti-who{
  font-family:var(--label);
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold); margin-bottom:12px;
}
.ti-answer .ti-said{
  font-size:clamp(18px,2vw,26px);
  line-height:1.55; font-style:italic; font-weight:300;
  border-left:1px solid var(--gold);
  padding-left:22px;
}

/* ===========================================================
   04 — CONCILIVM · 21 SES  (living senate / illuminated index)
   A presiding principle, an era-band timeline, a carved index of
   names that "fall silent" as one voice is promoted, and a focus
   panel revealing that philosopher's character + interrogating
   question in their own typographic voice. NOT cards.
   =========================================================== */
#council{ overflow:hidden; }

/* — the shared principle, pinned above the council — */
.conc-principle{
  margin-top:34px;
  max-width:30em;
  font-style:italic; font-weight:300;
  font-size:clamp(18px,2vw,26px);
  line-height:1.5;
  color:var(--ink);
  border-left:1px solid var(--gold);
  padding-left:24px;
}

/* — era-band index: an elegant segmented timeline — */
.conc-eras{
  margin:46px 0 8px;
  display:flex; flex-wrap:wrap; gap:0;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule-soft);
}
.conc-era{
  flex:1 1 auto;
  background:none; border:0; cursor:pointer;
  text-align:left;
  padding:16px clamp(10px,1.4vw,20px) 14px;
  border-right:1px solid var(--rule-soft);
  position:relative;
  transition:background .4s ease;
  outline:none;
}
.conc-era:last-child{ border-right:0; }
.conc-era .era-no{
  font-family:var(--mono);
  font-size:10px; letter-spacing:.2em; color:var(--gold);
  display:block; margin-bottom:8px; opacity:.7;
}
.conc-era .era-name{
  font-family:var(--label);
  font-size:clamp(10.5px,1vw,12.5px); letter-spacing:.13em; text-transform:uppercase;
  color:var(--ink-dim); line-height:1.3;
  transition:color .35s ease;
}
.conc-era::after{
  content:""; position:absolute; left:0; bottom:-1px; height:1px; width:100%;
  background:var(--gold); transform:scaleX(0); transform-origin:left center;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.conc-era:hover .era-name{ color:var(--ink); }
.conc-era.active .era-name{ color:var(--gold); }
.conc-era.active::after{ transform:scaleX(1); }

/* — the stage: index of names (left) + focus panel (right) — */
.conc-stage{
  margin-top:34px;
  display:grid;
  grid-template-columns:minmax(0,0.96fr) minmax(0,1.04fr);
  gap:clamp(30px,5vw,72px);
  align-items:start;
}

/* carved index of names — three columns, lots of negative space */
.conc-index{
  display:grid;
  grid-template-columns:1fr 1fr;
  column-gap:clamp(20px,3vw,46px);
  row-gap:2px;
}
.phil{
  position:relative;
  display:flex; align-items:baseline; gap:12px;
  padding:9px 2px 9px 0;
  cursor:pointer; outline:none;
  border:0;
  transition:opacity .5s ease, transform .45s cubic-bezier(.2,.7,.2,1);
  opacity:.46;                 /* default = "silent" / receded */
}
.phil .phil-mono{
  font-family:var(--mono);
  font-size:10px; letter-spacing:.1em;
  color:var(--ink-faint);
  flex:0 0 auto; width:1.6em; text-align:right;
  transition:color .4s ease;
}
.phil-name{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(17px,1.7vw,24px);
  letter-spacing:.03em; line-height:1.12;
  color:var(--ink);
  transition:color .4s ease, letter-spacing .4s ease;
}
/* hairline that draws under the promoted name */
.phil .phil-uline{
  position:absolute; left:0; right:0; bottom:4px; height:1px;
  background:var(--gold); transform:scaleX(0); transform-origin:left center;
  opacity:0; transition:transform .5s cubic-bezier(.2,.7,.2,1), opacity .5s ease;
}
.phil:hover, .phil:focus{ opacity:.92; transform:translateX(4px); }
.phil:hover .phil-mono, .phil:focus .phil-mono{ color:var(--gold); }
/* the one promoted voice */
.phil.is-active{ opacity:1; transform:translateX(6px); }
.phil.is-active .phil-name{ color:var(--gold); letter-spacing:.05em; }
.phil.is-active .phil-mono{ color:var(--gold); }
.phil.is-active .phil-uline{ transform:scaleX(1); opacity:.7; }
/* when a voice is promoted, the rest dim further ("fall silent") */
.conc-index.has-active .phil:not(.is-active){ opacity:.28; }
.conc-index.has-active .phil:not(.is-active):hover{ opacity:.7; }
/* era filtering — out-of-era names recede to near-silence */
.phil.era-dim{ opacity:.12 !important; pointer-events:none; transform:none; }

/* — FOCUS PANEL: portrait/medallion + carved name + voice — */
.conc-focus{
  position:relative;
  border-left:1px solid var(--rule);
  padding-left:clamp(24px,3vw,44px);
  min-height:340px;
}
.cf-top{ display:flex; align-items:flex-start; gap:clamp(18px,2.4vw,30px); }
/* the duotone portrait / typographic medallion */
.cf-portrait{
  position:relative; flex:0 0 auto;
  width:clamp(96px,11vw,132px); height:clamp(96px,11vw,132px);
  border-radius:50%;
  border:1px solid rgba(201,169,97,.55);
  display:grid; place-items:center;
  overflow:hidden;
  background:
    radial-gradient(120% 120% at 35% 25%, rgba(201,169,97,.10), transparent 60%),
    #100E12;
  box-shadow:0 14px 40px rgba(0,0,0,.5), inset 0 0 0 4px rgba(11,10,13,.9);
}
.cf-portrait::after{   /* faint grain + inner vignette so it reads as one marble set */
  content:""; position:absolute; inset:0; border-radius:50%;
  background:radial-gradient(120% 120% at 50% 40%, transparent 52%, rgba(11,10,13,.55) 100%);
  pointer-events:none;
}
/* monogram medallion (default + fallback) */
.cf-monogram{
  font-family:var(--display); font-weight:500;
  font-size:clamp(38px,4.6vw,58px);
  color:var(--gold); letter-spacing:.02em; line-height:1;
}
/* duotone portrait image — UNIFORM treatment so 21 sources read as one set */
.cf-img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover;
  filter:grayscale(1) contrast(1.05) brightness(.92) sepia(.42) hue-rotate(-8deg) saturate(1.4);
  opacity:0; transition:opacity .8s ease;
  mix-blend-mode:luminosity;
}
.cf-portrait.has-img .cf-img{ opacity:.9; mix-blend-mode:normal; }
.cf-portrait.has-img .cf-monogram{ opacity:0; }
.cf-portrait .cf-tint{   /* warm gold tint laid over the photo for cohesion */
  position:absolute; inset:0; border-radius:50%;
  background:linear-gradient(160deg, rgba(201,169,97,.18), rgba(11,10,13,.30));
  mix-blend-mode:overlay; opacity:0; transition:opacity .8s ease; pointer-events:none;
}
.cf-portrait.has-img .cf-tint{ opacity:1; }

.cf-id{ flex:1 1 auto; min-width:0; }
.cf-era{
  font-family:var(--label);
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold); margin-bottom:12px;
}
.cf-name{
  font-family:var(--display); font-weight:500;
  font-size:clamp(30px,3.8vw,52px);
  line-height:1.02; letter-spacing:.02em;
  color:var(--ink);
}
.cf-origin{
  margin-top:10px;
  font-family:var(--label);
  font-size:11.5px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-faint);
}
.cf-char{
  margin-top:22px;
  font-size:clamp(16px,1.45vw,20px);
  line-height:1.55; font-weight:300;
  color:var(--ink-dim);
  max-width:34em;
}
/* the interrogating question — typeset in each voice's distinct register.
   Base style; per-voice modifiers below give each philosopher a feel. */
.cf-q-label{
  margin-top:30px;
  font-family:var(--label);
  font-size:10.5px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--gold);
}
.cf-q{
  margin-top:14px;
  font-family:var(--serif);
  font-size:clamp(20px,2.1vw,30px);
  line-height:1.42; font-weight:400; font-style:italic;
  color:var(--ink);
  border-left:1px solid rgba(201,169,97,.5);
  padding-left:22px;
  min-height:2.6em;
}
/* the typing caret while a question is revealed */
.cf-q .caret{
  display:inline-block; width:2px; height:1em; vertical-align:-0.12em;
  background:var(--gold); margin-left:2px;
  animation:cfCaret 1s steps(1) infinite;
}
@keyframes cfCaret{ 0%,50%{opacity:1} 50.01%,100%{opacity:0} }

/* per-voice typographic registers (set via data-voice on .cf-q) */
.cf-q[data-voice="blunt"]{ font-style:normal; font-weight:600; letter-spacing:.005em; }   /* Diogenes — hard, blunt */
.cf-q[data-voice="systematic"]{ font-style:normal; font-weight:300; line-height:1.55; }    /* Platon — flowing, systematic */
.cf-q[data-voice="bold"]{ font-style:normal; font-weight:700; letter-spacing:.04em; }       /* Nietzsche — provocative, wide */
.cf-q[data-voice="poetic"]{ font-style:italic; font-weight:300; letter-spacing:.01em; }     /* Mevlânâ — soft, poetic */
.cf-q[data-voice="riddle"]{ font-style:italic; font-weight:400; letter-spacing:.05em; }     /* Herakleitos — riddling, spaced */
.cf-q[data-voice="logic"]{ font-style:normal; font-weight:400; letter-spacing:.01em; }      /* Aristoteles — measured */

.cf-footnote{
  margin-top:30px; padding-top:14px;
  border-top:1px solid var(--rule-soft);
  font-family:var(--mono);
  font-size:10.5px; letter-spacing:.06em; line-height:1.7;
  color:var(--ink-faint); max-width:34em;
}

.conc-hint{
  margin-top:26px;
  font-family:var(--label);
  font-size:10.5px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-faint);
}

/* ===========================================================
   05 — METAMORPHOSIS / AKADEMIA
   =========================================================== */
#akademia .meta-grid{
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  gap:clamp(30px,6vw,80px);
  align-items:center;
}
#akademia .meta-art{ min-height:44vh; } /* apollo in canvas */
#akademia .src-list{ margin-top:40px; }
.src{
  border-top:1px solid var(--rule-soft);
  padding:16px 0;
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px; align-items:baseline;
}
.src .src-title{
  font-size:clamp(16px,1.5vw,20px);
  line-height:1.4; color:var(--ink);
}
.src .src-doi{
  font-family:var(--mono);
  font-size:10px; letter-spacing:.12em;
  color:var(--gold); white-space:nowrap;
}
.src .src-meta{
  grid-column:1 / -1;
  font-family:var(--label);
  font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-faint);
}
.principle{
  margin-top:46px;
  font-style:italic; font-weight:300;
  font-size:clamp(18px,2.1vw,26px);
  line-height:1.5;
  color:var(--ink);
  max-width:32em;
  border-left:1px solid var(--gold);
  padding-left:24px;
}

/* ===========================================================
   06 — THE ARCHITECT
   =========================================================== */
#architect .stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  margin:50px 0 10px;
  border-top:1px solid var(--rule);
}
.stat{
  padding:30px clamp(8px,2vw,28px) 26px;
  border-bottom:1px solid var(--rule-soft);
}
.stat:not(:nth-child(3n)){ border-right:1px solid var(--rule-soft); }
.stat .num{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(28px,4.4vw,58px);
  line-height:1; color:var(--gold);
  letter-spacing:.01em;
}
.stat .cap{
  font-family:var(--label);
  font-size:11.5px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-dim);
  margin-top:14px;
}
.ideas{
  margin-top:56px;
  display:grid;
  grid-template-columns:1fr 1fr;
  column-gap:clamp(40px,7vw,90px);
}
.idea{
  border-top:1px solid var(--rule-soft);
  padding:18px 0;
  display:flex; gap:16px; align-items:baseline;
}
.idea .idx{
  font-family:var(--label);
  font-size:13px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--gold); flex:0 0 auto;
}
.idea .txt{ color:var(--ink); font-size:clamp(16px,1.4vw,20px); line-height:1.45; }
.idea .txt b{ font-weight:600; color:var(--ink); }

.stackline{
  margin-top:50px;
  font-family:var(--mono);
  font-size:12px; letter-spacing:.12em;
  color:var(--ink-dim);
  line-height:2.1;
}
.stackline .gold{ color:var(--gold); }

.signature{
  margin-top:64px;
  padding-top:30px;
  border-top:1px solid var(--rule);
  display:flex; justify-content:space-between; align-items:flex-end;
  flex-wrap:wrap; gap:20px;
}
.signature .sig-name{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(24px,3vw,40px);
  letter-spacing:.04em; color:var(--ink);
}
.signature .sig-name .role{
  display:block;
  font-family:var(--label);
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--gold); margin-bottom:10px;
}
.signature a.gh{
  font-family:var(--mono);
  font-size:12px; letter-spacing:.18em;
  color:var(--ink-dim);
  border-bottom:1px solid var(--rule);
  padding-bottom:4px;
  transition:color .3s, border-color .3s;
}
.signature a.gh:hover{ color:var(--gold); border-color:var(--gold); }

/* ---- Discord CTA (primary gold action, echoes #enterBtn) ---- */
.cta-block{
  margin-top:54px;
  display:flex; flex-wrap:wrap; align-items:center; gap:20px 26px;
}
a.cta-discord{
  display:inline-block;
  font-family:var(--display);
  font-size:13px; letter-spacing:.34em; text-transform:uppercase;
  color:var(--bg); background:var(--gold);
  padding:16px 40px;
  transition:background .35s ease, transform .35s ease, color .35s ease;
}
a.cta-discord:hover{ background:var(--ink); color:var(--bg); transform:translateY(-2px); }
.cta-note{
  font-family:var(--label);
  font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-faint);
  max-width:22em;
}
/* subtle secondary CTA in the hero */
a.cta-hero{
  display:inline-block; margin-top:30px;
  font-family:var(--label);
  font-size:12px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold);
  border-bottom:1px solid var(--rule);
  padding-bottom:5px;
  transition:color .3s, border-color .3s;
}
a.cta-hero:hover{ color:var(--ink); border-color:var(--gold); }

/* ---- refined socials row (architect footer) ---- */
.socials{
  margin-top:40px;
  display:flex; flex-wrap:wrap; gap:14px 30px; align-items:baseline;
}
.socials a, .socials .soc-item{
  font-family:var(--label);
  font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-dim);
  transition:color .3s ease, border-color .3s ease;
}
.socials a{ border-bottom:1px solid var(--rule); padding-bottom:4px; }
.socials a:hover{ color:var(--gold); border-color:var(--gold); }
.socials .soc-item{ color:var(--ink-faint); }
.socials .soc-item b{ color:var(--ink-dim); font-weight:400; }

.credit{
  margin-top:40px;
  font-family:var(--mono);
  font-size:10px; letter-spacing:.14em;
  color:var(--ink-faint);
  line-height:1.9;
}

/* ===========================================================
   custom cursor (desktop, subtle)
   =========================================================== */
#cursor{
  position:fixed; top:0; left:0; z-index:900;
  width:7px; height:7px; border-radius:50%;
  background:var(--gold);
  pointer-events:none;
  transform:translate(-50%,-50%);
  transition:width .25s, height .25s, opacity .3s, background .25s;
  mix-blend-mode:difference;
  opacity:0;
}
#cursor.ring{ width:34px; height:34px; background:transparent; border:1px solid var(--gold); }

.fx{ opacity:1; }

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:900px){
  body{ font-size:17px; }
  header.nav{ padding:18px var(--pad); }
  .nav nav{ display:none; }
  .nav-burger{
    display:block; background:none; border:none; cursor:pointer;
    font-family:var(--mono); font-size:11px; letter-spacing:.2em;
    text-transform:uppercase; color:var(--ink);
  }
  .nav-overlay{
    position:fixed; inset:0; z-index:290;
    background:var(--bg);
    display:flex; flex-direction:column;
    align-items:center; justify-content:center; gap:30px;
    opacity:0; visibility:hidden; transition:opacity .5s, visibility .5s;
  }
  .nav-overlay.open{ opacity:1; visibility:visible; }
  .nav-overlay a{
    font-family:var(--display); font-size:24px; letter-spacing:.1em;
    color:var(--ink);
  }
  #cover h1{ font-size:clamp(44px,16vw,90px); }
  #soul .soul-grid,
  #akademia .meta-grid{ grid-template-columns:1fr; gap:30px; }
  #soul .soul-art, #akademia .meta-art{ min-height:42vh; order:-1; }
  /* CONCILIVM: stack the stage, focus panel above the index on touch */
  .conc-eras{ flex-wrap:nowrap; overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .conc-era{ flex:0 0 auto; min-width:42%; }
  .conc-stage{ grid-template-columns:1fr; gap:34px; }
  .conc-focus{ order:-1; border-left:0; border-top:1px solid var(--rule); padding-left:0; padding-top:26px; min-height:0; }
  .conc-index{ grid-template-columns:1fr 1fr; }
  .phil{ opacity:.8; }
  .conc-index.has-active .phil:not(.is-active){ opacity:.5; }
  .cf-name{ font-size:clamp(28px,8vw,40px); }
  .ideas{ grid-template-columns:1fr; }
  #architect .stats{ grid-template-columns:1fr; }
  .stat:not(:nth-child(3n)){ border-right:none; }
  #cursor{ display:none; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
  html{ scroll-behavior:auto; }
  #bg-canvas{ transition:none; }
}

/* ===========================================================
   CINEMATIC MOTION LAYER  (additions — does not alter base)
   All reveal start-states are applied by JS only (gsap.set),
   never in CSS, so no-GSAP / reduced-motion shows everything.
   =========================================================== */

/* word-level split inside the existing overflow:hidden masks */
.reveal-mask .word{ display:inline-block; white-space:pre; will-change:transform; }

/* a thin gold rule that wipes in beneath eyebrows / numbers */
.kin-rule{
  display:block; height:1px; width:0; background:var(--gold);
  margin:14px 0 0; transform-origin:left center;
}

/* full-viewport light-sweep / scrim used at section boundaries */
#scrim{
  position:fixed; inset:0; z-index:6; pointer-events:none;
  opacity:0; will-change:opacity, background-position;
  background:linear-gradient(115deg,
     rgba(201,169,97,0) 38%,
     rgba(201,169,97,.10) 50%,
     rgba(201,169,97,0) 62%);
  background-size:280% 280%;
  background-position:0% 0%;
}

/* (council per-row sweep retired — the new CONCILIVM index has its own
   carved promote/recede choreography in the 04 block above) */

/* ===========================================================
   CINEMATIC INTRO VEIL (Feature 1) — near-black opening overlay
   with a single warm rim of light, sitting above the canvas but
   below all UI. Driven entirely by JS/GSAP; if GSAP is missing or
   reduced-motion is set, JS never shows it and the cover is normal.
   =========================================================== */
#introVeil{
  position:fixed; inset:0; z-index:5; pointer-events:none;
  opacity:0; visibility:hidden;
  background:radial-gradient(120% 120% at 72% 42%,
     rgba(11,10,13,.55) 30%, rgba(7,6,8,.97) 78%);
}
#introVeil.run{ visibility:visible; }
#introVeil .iv-rim{
  position:absolute; top:0; bottom:0; right:0; width:46%;
  opacity:0;
  background:radial-gradient(60% 70% at 62% 50%,
     rgba(201,169,97,.20), rgba(201,169,97,.06) 45%, transparent 70%);
  mix-blend-mode:screen;
}

/* soft breathing vignette layered over the hero on entrance */
#vignette{
  position:fixed; inset:0; z-index:4; pointer-events:none; opacity:0;
  background:radial-gradient(120% 120% at 50% 50%,
     transparent 52%, rgba(11,10,13,.55) 100%);
}

/* body paragraph blur-to-sharp helper (cleared after reveal) */
.kin-soft{ filter:blur(6px); }

@media (max-width:900px){
  /* lighter motion on mobile: no edge x-shift jank */
  .phil:hover, .phil:focus{ transform:none; }
}

@media (prefers-reduced-motion:reduce){
  #scrim, #vignette, #introVeil{ display:none; }
  .kin-rule{ width:100% !important; }
  .reveal-mask .word{ transform:none !important; }
  .kin-soft{ filter:none !important; }
}

/* ===========================================================
   VOX — hotspots + quote panel (Feature 2)
   Gold dots projected over the active bust; calm dark card.
   =========================================================== */
#hotspots{
  position:fixed; inset:0; z-index:7; pointer-events:none;
}
.hotspot{
  position:absolute; left:0; top:0;
  width:18px; height:18px; margin:-9px 0 0 -9px;
  border-radius:50%;
  cursor:pointer; pointer-events:auto;
  opacity:0; visibility:hidden;
  transition:opacity .6s ease, visibility .6s ease;
}
.hotspot.show{ opacity:1; visibility:visible; }
.hotspot .dot{
  position:absolute; inset:5px;
  border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 8px rgba(201,169,97,.9);
}
.hotspot .ring{
  position:absolute; inset:0;
  border-radius:50%;
  border:1px solid var(--gold);
  opacity:.7;
  animation:hsPulse 2.4s ease-out infinite;
}
@keyframes hsPulse{
  0%{ transform:scale(.6); opacity:.8; }
  70%{ transform:scale(1.9); opacity:0; }
  100%{ transform:scale(1.9); opacity:0; }
}
.hotspot.active .dot{ background:#fff; box-shadow:0 0 14px rgba(201,169,97,1); }

#quotePanel{
  position:fixed; z-index:8; pointer-events:none;
  max-width:min(380px, 78vw);
  background:rgba(13,12,15,.92);
  border:1px solid rgba(201,169,97,.55);
  border-radius:2px;
  padding:24px 26px 22px;
  box-shadow:0 18px 60px rgba(0,0,0,.55);
  opacity:0; visibility:hidden; transform:translateY(10px);
  transition:opacity .5s ease, transform .5s ease, visibility .5s ease;
}
#quotePanel.show{ opacity:1; visibility:visible; transform:translateY(0); }
#quotePanel .q-line{
  font-family:var(--serif);
  font-style:italic; font-weight:400;
  font-size:clamp(18px,1.8vw,23px);
  line-height:1.5;
  color:var(--ink);
}
#quotePanel .q-attr{
  margin-top:16px; padding-top:12px;
  border-top:1px solid rgba(201,169,97,.35);
  font-family:var(--label);
  font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--gold);
}
@media (max-width:900px){
  #quotePanel{ left:var(--pad) !important; right:var(--pad);
    bottom:24px; top:auto !important; max-width:none; }
}
@media (prefers-reduced-motion:reduce){
  .hotspot .ring{ animation:none; opacity:.5; }
}

/* ===========================================================
   SOUND TOGGLE — elegant mono/gold corner control (Feature 2)
   Default OFF. Web Audio synthesized; nothing persisted.
   =========================================================== */
#soundToggle{
  position:fixed; right:var(--pad); bottom:22px; z-index:310;
  display:flex; align-items:center; gap:9px;
  background:rgba(13,12,15,.82);
  border:1px solid var(--rule);
  border-radius:2px;
  padding:8px 14px 8px 12px;
  cursor:pointer;
  font-family:var(--label);
  font-size:10.5px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink-dim);
  transition:color .35s ease, border-color .35s ease, background .35s ease, opacity .8s ease;
  opacity:0; pointer-events:none;
}
#soundToggle.avail{ opacity:1; pointer-events:auto; }
#soundToggle:hover{ color:var(--gold); border-color:var(--rule); }
#soundToggle .s-ico{
  position:relative; width:14px; height:14px; flex:0 0 auto;
}
/* three rising "bars" suggesting sound; muted = dimmed + slash */
#soundToggle .s-ico .b{
  position:absolute; bottom:1px; width:2px; background:var(--ink-faint);
  transition:background .35s ease, height .35s ease;
}
#soundToggle .s-ico .b1{ left:1px;  height:5px; }
#soundToggle .s-ico .b2{ left:6px;  height:9px; }
#soundToggle .s-ico .b3{ left:11px; height:13px; }
#soundToggle.on .s-ico .b{ background:var(--gold); }
#soundToggle.on .s-ico .b1{ animation:sBar1 1.4s ease-in-out infinite; }
#soundToggle.on .s-ico .b2{ animation:sBar2 1.1s ease-in-out infinite; }
#soundToggle.on .s-ico .b3{ animation:sBar3 1.7s ease-in-out infinite; }
@keyframes sBar1{ 0%,100%{height:4px} 50%{height:8px} }
@keyframes sBar2{ 0%,100%{height:6px} 50%{height:12px} }
@keyframes sBar3{ 0%,100%{height:9px} 50%{height:13px} }
#soundToggle .s-lbl-on{ display:none; }
#soundToggle.on .s-lbl-off{ display:none; }
#soundToggle.on .s-lbl-on{ display:inline; color:var(--gold); }
@media (max-width:900px){
  #soundToggle{ bottom:auto; top:14px; right:14px; padding:7px 11px; font-size:9.5px; }
}
@media (prefers-reduced-motion:reduce){
  #soundToggle.on .s-ico .b{ animation:none !important; }
}

/* ===========================================================
   ORACLE FOCUS — in-page council experience (.ora-*)
   Lives INSIDE #council in normal flow (~100vh). NOT fixed,
   does NOT hijack page scroll. Portrait in a breathing circular
   spotlight + orbiting gold ring + radial glow; the question
   types out with a gold caret; carved name + era; a rail of all 21
   selectable by click + arrow keys. Reuses site vars/fonts.
   =========================================================== */
.ora{
  position:relative;
  margin-top:40px;
  min-height:94vh;
  overflow:hidden;
  isolation:isolate;
  perspective:1500px;
}
/* giant ghost name — deep background texture (c2-06) */
.ora-ghost{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  display:flex; align-items:center; justify-content:flex-end; overflow:hidden;
}
.ora-ghost span{
  font-family:var(--display); font-weight:700;
  font-size:32vw; line-height:.8; letter-spacing:.02em;
  color:rgba(201,169,97,.05); white-space:nowrap; text-transform:uppercase;
  transform:translateX(6%);
}
/* breathing radial glow behind the portrait */
.ora-glow{
  position:absolute; top:46%; right:8%;
  width:min(64vh,560px); height:min(64vh,560px);
  transform:translate(18%,-50%);
  z-index:1; pointer-events:none;
  background:radial-gradient(circle, rgba(201,169,97,.20), rgba(201,169,97,.05) 45%, transparent 70%);
  filter:blur(8px); will-change:transform,opacity;
}
/* PORTRAIT — tall, bleeds off the right edge, soft-masked */
.ora-stage{
  position:absolute; top:50%; right:2vw;
  transform:translateY(-50%);
  height:118%; aspect-ratio:3/4; max-width:44vw;
  z-index:2; pointer-events:none; will-change:transform;
}
.ora-ring{ display:none; }
.ora-oracle{ position:relative; z-index:2; width:100%; height:100%; }
.ora-oracle .ora-pimg,
.ora-oracle .ora-medallion{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:50% 20%;
  -webkit-mask-image:radial-gradient(78% 82% at 56% 42%, #000 40%, rgba(0,0,0,.55) 64%, transparent 84%);
          mask-image:radial-gradient(78% 82% at 56% 42%, #000 40%, rgba(0,0,0,.55) 64%, transparent 84%);
}
.ora-pimg{ filter:grayscale(1) sepia(.46) brightness(.98) contrast(1.05); opacity:1; will-change:transform; }
.ora-oracle::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(74% 60% at 50% 26%, transparent 42%, rgba(11,10,13,.62) 100%);
  mix-blend-mode:multiply;
}
.ora-medallion{
  display:flex; align-items:center; justify-content:center;
  background:radial-gradient(circle at 50% 38%, #26231d, #0a0908);
  -webkit-mask-image:radial-gradient(118% 92% at 50% 32%, #000 56%, transparent 90%);
          mask-image:radial-gradient(118% 92% at 50% 32%, #000 56%, transparent 90%);
}
.ora-medallion span{ font-family:var(--display); font-weight:500; font-size:18vh; color:var(--gold); line-height:1; }
/* TEXT — left, above everything */
.ora-text{
  position:absolute; top:50%; left:0; transform:translateY(-50%);
  z-index:3; max-width:32em; will-change:transform;
}
.ora-era{
  font-family:var(--label);
  font-size:11px; letter-spacing:.32em; text-transform:uppercase;
  color:var(--gold); margin-bottom:16px; display:flex; align-items:center; gap:14px;
}
.ora-era::before{
  content:""; display:inline-block; width:30px; height:1px;
  background:var(--gold); opacity:.6; flex:0 0 auto;
}
.ora-name{
  font-family:var(--display); font-weight:600;
  font-size:clamp(2.4rem,6vw,5.4rem);
  line-height:.96; letter-spacing:.04em; text-transform:uppercase;
  color:var(--ink);
}
.ora-q-label{
  margin-top:1.8rem;
  font-family:var(--label);
  font-size:10.5px; letter-spacing:.28em; text-transform:uppercase;
  color:rgba(201,169,97,.78); margin-bottom:.8rem;
}
.ora-q{
  font-family:var(--serif);
  font-style:italic; font-weight:500;
  font-size:clamp(1.3rem,2.1vw,2rem);
  line-height:1.34; color:rgba(232,227,216,.96);
  min-height:2.6em; max-width:24em;
  border-left:1px solid rgba(201,169,97,.5);
  padding-left:22px;
}
.ora-q .ora-caret{
  display:inline-block; width:2px; height:1em; vertical-align:-0.12em;
  background:var(--gold); margin-left:2px;
  box-shadow:0 0 8px rgba(201,169,97,.8);
  animation:oraCaret 1s steps(1) infinite;
}
@keyframes oraCaret{ 0%,50%{opacity:1} 50.01%,100%{opacity:0} }
.ora-foot{
  margin-top:1.7rem;
  font-family:var(--serif);
  font-style:italic; font-size:.92rem;
  color:rgba(201,169,97,.55); max-width:22em;
}
/* DUST overlay */
.ora-dust{ position:absolute; inset:0; z-index:4; pointer-events:none; overflow:hidden; }
.ora-dust i{ position:absolute; width:2px; height:2px; border-radius:50%; background:var(--gold); opacity:0; }
/* RAIL of all 21 — single horizontal strip, never grows tall */
.ora-rail{
  position:absolute; left:0; right:0; bottom:18px; z-index:5;
  display:flex; gap:.5rem; flex-wrap:nowrap; align-items:center;
  overflow-x:auto; overflow-y:hidden;
  padding:14px 1vw 10px;
  scrollbar-width:none;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
          mask-image:linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
}
.ora-rail::-webkit-scrollbar{ display:none; }
.ora-chip{
  flex:0 0 auto;
  font-family:var(--label);
  font-size:10px; letter-spacing:.13em; text-transform:uppercase;
  color:rgba(232,227,216,.46);
  border:1px solid rgba(201,169,97,.16);
  padding:.42rem .68rem; border-radius:2px;
  cursor:pointer; white-space:nowrap;
  background:rgba(20,20,22,.4);
  transition:color .4s cubic-bezier(.22,1,.36,1), border-color .4s, transform .4s, background .4s;
  outline:none;
}
.ora-chip:hover, .ora-chip:focus{ color:var(--ink); border-color:rgba(201,169,97,.5); transform:translateY(-2px); }
.ora-chip.active{ color:var(--bg); background:var(--gold); border-color:var(--gold); }
.ora-counter{
  flex:0 0 auto; margin-left:14px;
  font-family:var(--mono);
  font-size:11px; letter-spacing:.2em; color:var(--ink-faint);
  align-self:center;
}
@media (prefers-reduced-motion:reduce){
  .ora-glow, .ora-ring{ animation:none !important; }
  .ora-q .ora-caret{ display:none; }
  .ora-ghost span{ transform:none; }
}
@media (max-width:900px){
  /* Mobile: stack as a clean COLUMN. Chips first so the tap target is obvious;
     tapping one updates the portrait + name + quote right below, in place.
     Portrait is height-capped (was ballooning to ~98vw via aspect-ratio and
     leaving a dead void under the rail). No giant min-height, no arrow-key hint. */
  .ora{ min-height:auto; padding-bottom:34px; display:flex; flex-direction:column; align-items:center; }
  .ora-rail{
    order:-2; position:relative; left:auto; right:auto; bottom:auto; top:auto;
    margin:0 0 26px; width:100%; justify-content:flex-start;
  }
  .ora-stage{
    order:-1; position:relative; top:auto; right:auto; transform:none;
    height:40vh; width:auto; aspect-ratio:3/4; max-width:72vw;
    margin:0 auto 20px; opacity:1;
  }
  .ora-text{ order:0; position:relative; top:auto; transform:none; max-width:none; padding-right:0; text-align:center; }
  .ora-era{ justify-content:center; }
  .ora-name{ letter-spacing:.05em; }
  .ora-q{ border-left:none; border-top:1px solid rgba(201,169,97,.4); padding-left:0; padding-top:14px; max-width:32em; margin:0 auto; }
  .ora-foot{ margin-left:auto; margin-right:auto; }
  .ora-ghost{ display:none; }            /* giant ghost letter only adds noise on phones */
  .ora-glow{ right:50%; transform:translate(50%,-50%); }
  .conc-hint{ display:none; }            /* chips at top are self-evident; arrow-keys are desktop-only */
}

/* ===========================================================
   PORTA MAXIMA — server / community section (.porta-*)
   Monumental gate that opens on scroll into the city → senate →
   12 laws → forums → apply CTA. Integrates with the EXISTING
   GSAP/ScrollTrigger + Lenis (no competing scroller). SVG/CSS only.
   =========================================================== */
#civitas{ padding:0; min-height:auto; display:block; overflow:hidden; }
#civitas .wrap{ max-width:none; }
.porta-gold{ color:var(--gold); }
/* ACT I — THE GATE (sticky scrub) */
.porta-gate-scroll{ position:relative; height:520vh; }
.porta-gate-stage{
  position:sticky; top:0; height:100vh; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.porta-city{
  position:absolute; inset:0; z-index:1;
  display:flex; align-items:center; justify-content:center;
  background:radial-gradient(75% 85% at 50% 62%, #16140d 0%, var(--bg) 72%);
}
.porta-city svg{ width:min(135vmin,1300px); height:auto; opacity:.92; }
.porta-cityglow{
  position:absolute; inset:0; z-index:1;
  background:radial-gradient(42% 52% at 50% 56%, rgba(201,169,97,.18), transparent 62%);
}
.porta-atmo{ position:absolute; inset:0; z-index:2; pointer-events:none; }
.porta-atmo i{
  position:absolute; width:3px; height:3px; border-radius:50%;
  background:#e3c987; opacity:0;
}
.porta-door{
  position:absolute; top:0; bottom:0; width:50.6%; z-index:6;
  background:linear-gradient(180deg, #22202a, #141319 58%, #0c0b10);
  border-top:7px solid rgba(201,169,97,.28); will-change:transform;
}
.porta-door.left{ left:0; transform-origin:left center; border-right:1px solid rgba(0,0,0,.65); box-shadow:inset -40px 0 80px rgba(0,0,0,.65); }
.porta-door.right{ right:0; transform-origin:right center; border-left:1px solid rgba(0,0,0,.65); box-shadow:inset 40px 0 80px rgba(0,0,0,.65); }
.porta-door-face{
  position:absolute; inset:0; opacity:.5;
  background-image:
    repeating-linear-gradient(0deg, transparent 0 80px, rgba(0,0,0,.4) 80px 84px),
    repeating-linear-gradient(90deg, transparent 0 66px, rgba(0,0,0,.33) 66px 69px);
}
.porta-studs{ position:absolute; inset:0; }
.porta-stud{
  position:absolute; width:15px; height:15px; border-radius:50%;
  background:radial-gradient(circle at 35% 35%, #e3c987, #6b5a30 70%, #2a2418);
  box-shadow:0 1px 4px rgba(0,0,0,.6);
}
.porta-door .porta-ornament{ position:absolute; top:50%; transform:translateY(-50%); width:150px; height:auto; opacity:.85; }
.porta-door.left .porta-ornament{ right:30px; }
.porta-door.right .porta-ornament{ left:30px; }
.porta-seam{
  position:absolute; top:0; bottom:0; left:50%; width:3px; transform:translateX(-50%); z-index:7;
  background:linear-gradient(180deg, transparent, #e3c987, transparent);
  box-shadow:0 0 40px 8px rgba(227,201,135,.55); opacity:0;
}
.porta-frame{
  position:absolute; top:0; left:0; right:0; z-index:9; text-align:center;
  padding:clamp(18px,3vh,42px) 0;
  background:linear-gradient(180deg, rgba(11,10,13,.92), transparent);
}
.porta-frame .porta-inscr{
  font-family:var(--display); letter-spacing:.44em; font-size:clamp(13px,1.6vw,21px);
  color:var(--gold); text-transform:uppercase;
}
.porta-frame .porta-inscr small{ display:block; font-size:10px; letter-spacing:.3em; color:var(--ink-dim); margin-top:7px; }
.porta-hero{ position:absolute; z-index:8; text-align:center; width:92%; max-width:800px; will-change:opacity,transform; }
.porta-hero .porta-pre{
  font-family:var(--display); letter-spacing:.5em; font-size:11px; color:var(--gold);
  text-transform:uppercase; margin-bottom:24px;
}
.porta-hero h2{
  font-family:var(--display); font-weight:600;
  font-size:clamp(36px,7.4vw,102px); line-height:1.0;
  color:var(--ink);
}
.porta-hero h2 em{
  display:block; font-family:var(--serif); font-style:italic; font-weight:400;
  color:#e3c987; font-size:.4em; margin-top:.28em;
}
.porta-hero .porta-motto{ margin-top:28px; font-style:italic; color:#e3c987; font-size:clamp(16px,2vw,22px); }
.porta-hero .porta-motto span{ display:block; font-style:normal; color:var(--ink-dim); font-size:12px; letter-spacing:.14em; text-transform:uppercase; margin-top:6px; }
.porta-hero .porta-down{
  margin-top:36px; font-family:var(--display); letter-spacing:.3em; font-size:10px; color:var(--ink-dim);
  text-transform:uppercase; animation:portaBob 2.4s ease-in-out infinite;
}
@keyframes portaBob{ 0%,100%{opacity:.5} 50%{opacity:1} }
.porta-beyond{
  position:absolute; bottom:clamp(34px,8vh,84px); left:50%; transform:translateX(-50%); z-index:8;
  text-align:center; width:92%; opacity:0; will-change:opacity;
}
.porta-beyond .porta-lab{ font-family:var(--display); letter-spacing:.34em; font-size:11px; color:var(--gold); text-transform:uppercase; }
.porta-beyond .porta-row{ display:flex; gap:clamp(20px,4vw,64px); justify-content:center; margin-top:16px; flex-wrap:wrap; }
.porta-beyond .porta-row b{ font-family:var(--display); font-weight:500; color:var(--ink); font-size:clamp(15px,2vw,22px); letter-spacing:.05em; }
.porta-beyond .porta-row b small{ display:block; font-family:var(--serif); font-style:italic; color:var(--ink-dim); font-size:14px; letter-spacing:0; margin-top:3px; }
.porta-creed{ position:absolute; z-index:8; width:92%; max-width:820px; text-align:center; opacity:0; will-change:opacity,transform; }
.porta-creed p{ font-family:var(--serif); font-style:italic; font-size:clamp(22px,3.6vw,46px); line-height:1.25; color:var(--ink); }
.porta-creed p b{ font-style:normal; color:#e3c987; font-weight:600; }
/* ACT II — LAYERS */
.porta-layer{ padding:clamp(90px,15vh,180px) var(--pad); border-top:1px solid var(--line); position:relative; overflow:hidden; }
.porta-kicker{ font-family:var(--label); letter-spacing:.4em; font-size:11px; color:var(--gold); text-transform:uppercase; text-align:center; }
.porta-layer h2{ font-family:var(--display); font-weight:600; font-size:clamp(28px,4.6vw,58px); text-align:center; margin-top:16px; line-height:1.06; color:var(--ink); }
.porta-layer .porta-sub{ text-align:center; color:var(--ink-dim); font-size:clamp(16px,1.8vw,20px); margin-top:14px; font-style:italic; }
.porta-ladder{ max-width:560px; margin:54px auto 0; display:flex; flex-direction:column; gap:12px; }
.porta-rung{
  display:flex; align-items:center; gap:20px; padding:16px 26px;
  border:1px solid var(--line); background:linear-gradient(90deg, rgba(201,169,97,.05), transparent); position:relative;
}
.porta-rung .porta-rk{ font-family:var(--display); color:var(--gold); font-size:12px; letter-spacing:.2em; width:30px; text-align:center; flex:0 0 auto; }
.porta-rung b{ font-family:var(--display); font-weight:500; font-size:clamp(15px,2vw,20px); color:var(--ink); }
.porta-rung small{ display:block; font-style:italic; color:var(--ink-dim); font-size:14px; margin-top:2px; }
.porta-rung:nth-child(1){ margin-inline:0; }
.porta-rung:nth-child(2){ margin-inline:24px; }
.porta-rung:nth-child(3){ margin-inline:48px; }
.porta-rung:nth-child(4){ margin-inline:72px; }
.porta-rung:nth-child(5){ margin-inline:96px; }
.porta-tablets{ display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:14px; max-width:1080px; margin:54px auto 0; }
.porta-tab{
  border:1px solid var(--line); padding:22px 18px;
  background:linear-gradient(180deg, rgba(232,227,216,.03), transparent);
  text-align:center; transition:border-color .4s, background .4s, transform .4s;
}
.porta-tab:hover{ border-color:rgba(201,169,97,.5); background:linear-gradient(180deg, rgba(201,169,97,.08), transparent); transform:translateY(-4px); }
.porta-tab .porta-num{ font-family:var(--display); color:#e3c987; font-size:20px; letter-spacing:.1em; }
.porta-tab .porta-nm{ font-family:var(--display); font-size:12px; letter-spacing:.08em; margin-top:10px; color:var(--ink); line-height:1.35; }
.porta-tab .porta-nm small{ color:var(--ink-dim); font-style:italic; font-family:var(--serif); }
.porta-forums-wrap{
  margin-top:54px; overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
  mask-image:linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}
.porta-forums{ display:flex; gap:18px; width:max-content; animation:portaScrollx 38s linear infinite; }
.porta-forums span{ font-family:var(--display); letter-spacing:.14em; font-size:clamp(15px,2vw,22px); color:var(--ink-dim); white-space:nowrap; padding:0 4px; }
.porta-forums span::after{ content:'·'; color:var(--gold); margin-left:18px; }
@keyframes portaScrollx{ to{ transform:translateX(-50%); } }
.porta-stats{ display:flex; gap:clamp(24px,6vw,90px); justify-content:center; flex-wrap:wrap; margin-top:48px; }
.porta-stat{ text-align:center; }
.porta-stat b{ display:block; font-family:var(--display); font-size:clamp(30px,5vw,52px); color:#e3c987; }
.porta-stat small{ color:var(--ink-dim); font-size:14px; letter-spacing:.12em; text-transform:uppercase; }
/* ACT III — APPLY */
.porta-entry{
  text-align:center; padding:clamp(100px,18vh,220px) var(--pad) clamp(80px,12vh,140px);
  border-top:1px solid var(--line);
  background:radial-gradient(70% 90% at 50% 0%, rgba(201,169,97,.07), transparent 60%);
}
.porta-entry .porta-pre{ font-family:var(--display); letter-spacing:.4em; font-size:11px; color:var(--gold); text-transform:uppercase; margin-bottom:22px; }
.porta-entry h2{ font-family:var(--display); font-weight:600; font-size:clamp(30px,5vw,66px); line-height:1.05; color:var(--ink); }
.porta-entry .porta-lat{ font-style:italic; color:#e3c987; font-size:clamp(17px,2vw,23px); margin-top:18px; max-width:660px; margin-inline:auto; line-height:1.5; }
.porta-entry p.porta-body{ margin-top:26px; color:var(--ink-dim); font-size:clamp(17px,2vw,21px); max-width:660px; margin-inline:auto; line-height:1.6; }
.porta-entry p.porta-body b{ color:var(--ink); }
.porta-cta{
  display:inline-flex; align-items:center; gap:12px; margin-top:42px;
  font-family:var(--display); letter-spacing:.18em; font-size:13px; text-transform:uppercase;
  color:var(--bg); background:var(--gold); padding:19px 48px;
  transition:background .35s, box-shadow .35s, transform .35s;
}
.porta-cta:hover{ background:#e3c987; box-shadow:0 8px 24px rgba(0,0,0,.32); transform:translateY(-2px); }
.porta-dev{ margin:50px auto 0; font-size:15px; color:var(--ink-dim); line-height:1.65; max-width:640px; }
.porta-dev b{ color:var(--ink); font-weight:500; }
@media (max-width:700px){
  .porta-gate-scroll{ height:440vh; }
  .porta-door .porta-ornament{ width:96px; }
  .porta-rung:nth-child(n){ margin-inline:0; }
}
@media (prefers-reduced-motion:reduce){
  .porta-gate-scroll{ height:auto; }
  .porta-gate-stage{ position:relative; height:auto; min-height:88vh; padding:14vh 0; }
  .porta-door, .porta-seam{ display:none; }
  .porta-beyond, .porta-creed{ opacity:1; position:relative; transform:none; margin-top:40px; }
  .porta-hero{ position:relative; }
  .porta-forums{ animation:none; }
  .porta-down{ animation:none !important; }
}

/* ===========================================================
   CINEMATIC INTRO — loader becomes the centered spinning coin
   (only on the WebGL/motion path; the no-webgl fallback keeps the
   classic text loader + ENTER button untouched).
   =========================================================== */
body.cinematic-intro #loader{ background:transparent; cursor:pointer; }
body.cinematic-intro #loader .l-eyebrow,
body.cinematic-intro #loader .l-title,
body.cinematic-intro #loader .l-latin,
body.cinematic-intro #loader .l-sub,
body.cinematic-intro #loader #enterBtn{ display:none; }
body.cinematic-intro #loader .l-bar-wrap{ position:fixed; left:50%; bottom:12vh; transform:translateX(-50%); margin:0; }
body.cinematic-intro #loader .l-pct{ position:fixed; left:0; right:0; bottom:8.4vh; text-align:center; margin:0; }
body.cinematic-intro #loader .l-touch{
  position:fixed; left:0; right:0; bottom:9vh; text-align:center; opacity:0;
  font-family:var(--label); letter-spacing:.42em; font-size:10px; text-transform:uppercase;
  color:rgba(201,169,97,.62); transition:opacity .8s ease; pointer-events:none;
}
body.cinematic-intro #loader.can-enter .l-bar-wrap,
body.cinematic-intro #loader.can-enter .l-pct{ opacity:0; transition:opacity .5s ease; }
body.cinematic-intro #loader.can-enter .l-touch{ opacity:1; }
body.intro-active #nav{ opacity:0 !important; pointer-events:none; }
body.intro-active #cover{ opacity:0; }
/* non-cinematic-intro loader keeps the touch hint hidden */
#loader .l-touch{ display:none; }
body.cinematic-intro #loader .l-touch{ display:block; }

/* ===========================================================
   ACCESSIBILITY — keyboard focus ring (keyboard nav only) + skip link
   =========================================================== */
a:focus-visible, button:focus-visible, input:focus-visible,
[tabindex]:focus-visible, .phil:focus-visible, .ora-chip:focus-visible,
.lang-toggle button:focus-visible, #enterBtn:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
  border-radius: 2px;
}
.skip-link{
  position:fixed; top:8px; left:8px; z-index:2000;
  background:var(--gold); color:#0b0a0d;
  font-family:var(--label); font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  padding:10px 16px; border-radius:3px; text-decoration:none;
  transform:translateY(-160%); transition:transform .2s ease;
}
.skip-link:focus{ transform:translateY(0); }

/* ===========================================================
   MICRO-INTERACTIONS — animated nav underline + smoother hovers
   =========================================================== */
.nav nav a{ position:relative; }
.nav nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:-5px; height:1px;
  background:var(--gold); transform:scaleX(0); transform-origin:left center;
  transition:transform .38s cubic-bezier(.6,0,.2,1);
}
.nav nav a:hover::after,
.nav nav a:focus-visible::after{ transform:scaleX(1); }
/* primary CTAs: gentler, springier lift */
a.cta-hero, a.cta-discord, .porta-cta, #enterBtn{
  transition: color .35s ease, background .35s ease, border-color .35s ease,
              transform .45s cubic-bezier(.2,.9,.25,1), box-shadow .45s ease;
}
/* academic / footer text links: soft gold wash on hover */
.signature a.gh{ transition: color .3s ease, border-color .3s ease; }

/* ===========================================================
   PHONE TIER (<=520px) — conservative polish on top of the
   existing <=900/<=700 layout. Scoped to small screens only;
   desktop is untouched.
   =========================================================== */
@media (max-width:520px){
  body{ font-size:16px; }
  /* wide letter-spacing overflows narrow phones -> tighten labels/headings */
  .l-eyebrow, .sec-label, #cover .kicker,
  .porta-inscr, .porta-pre, .porta-kicker, .porta-lab,
  .stat .cap, .cf-era, .ora-era, .conc-counter, .skip-link{
    letter-spacing:.24em;
  }
  #cover h1{ font-size:clamp(38px,14.5vw,62px); letter-spacing:.02em; }
  #cover .motto{ font-size:clamp(17px,5vw,22px); }
  /* 21-name council: one per row -> bigger tap targets, no cramping */
  .conc-index{ grid-template-columns:1fr; }
  .stat .num{ font-size:clamp(28px,10vw,40px); }
  /* footer rows stack cleanly */
  .signature{ flex-direction:column; align-items:flex-start; gap:14px; }
  .socials{ flex-direction:column; gap:12px; }
  .cta-block{ flex-direction:column; align-items:flex-start; gap:12px; }
  /* comfortable tap height on overlay nav */
  .nav-overlay a{ padding:8px 0; }
  /* keep the bust from eating the whole stacked viewport */
  #soul .soul-art, #akademia .meta-art{ min-height:38vh; }
}

/* phone: the bust is the section's HERO up top; the text sits on a CRISP solid
   page beneath it. The panel is FULL-BLEED (100vw) so the centered marble can
   never peek into the side gutters behind the body copy — a single hairline
   gold rule marks the marble→type transition, like a museum plinth. Editorial. */
@media (max-width:900px){
  #soul .soul-art, #akademia .meta-art{ min-height:48vh; }
  #soul .soul-text, #akademia .meta-text, #exchange .wrap{
    position:relative;
    background:var(--bg);
    width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
    padding-left:var(--pad);
    padding-right:var(--pad);
    padding-top:32px;
    border-top:1px solid rgba(201,169,97,.22);
  }
}
