/* ═══════════════════════════════════════════
   NEXUS//25 — THE AI ROUNDTABLE
   horizontal-scroll · parallax · neo-kyoto cyberpunk
   ═══════════════════════════════════════════ */

:root{
  --ink:          #06070C;
  --ink-2:        #0B0D15;
  --ink-3:        #12141F;
  --paper:        #F4F1E8;
  --paper-dim:    rgba(244,241,232,0.62);
  --paper-faint:  rgba(244,241,232,0.28);

  --mag:          #FF006E;   /* hot magenta       */
  --cya:          #00F0FF;   /* electric cyan     */
  --lim:          #D4FF00;   /* acid lime         */
  --amb:          #FFB703;   /* warning amber     */

  --panel-w:      min(1720px, 180vw);     /* each panel is wider than viewport */
  --panel-w-hero: min(1520px, 160vw);

  --font-display: 'Unbounded', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;
  --font-glitch:  'Rubik Glitch', 'Unbounded', sans-serif;
  --font-kana:    'Zen Kaku Gothic New', 'Unbounded', sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html,body{
  margin:0; padding:0;
  background:var(--ink);
  color:var(--paper);
  font-family:var(--font-mono);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow:hidden;                 /* page handles its own scroll */
  height:100vh;
}
body{
  background:
    radial-gradient(ellipse 80% 60% at 20% 40%, rgba(255,0,110,.09), transparent 60%),
    radial-gradient(ellipse 70% 50% at 85% 65%, rgba(0,240,255,.07), transparent 60%),
    linear-gradient(180deg,#06070C 0%, #0B0D15 100%);
}
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ margin:0; font-family:var(--font-display); font-weight:700; letter-spacing:-.01em; }
p{ margin:0; }

/* ─── persistent overlays ───────────────── */
.grain{
  position:fixed; inset:0; pointer-events:none; z-index:98;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 .08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay; opacity:.55;
}
.scanlines{
  position:fixed; inset:0; pointer-events:none; z-index:97;
  background:repeating-linear-gradient(
    0deg,
    rgba(255,255,255,.015) 0 1px,
    transparent 1px 3px
  );
}
.vignette{
  position:fixed; inset:0; pointer-events:none; z-index:96;
  background:radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,.55) 100%);
}

/* ─── HUD ───────────────────────────────── */
.hud{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  padding:18px 28px;
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  mix-blend-mode:normal;
  pointer-events:auto;
}
.hud::after{
  content:''; position:absolute; left:28px; right:28px; bottom:0;
  height:1px; background:linear-gradient(90deg, transparent, rgba(244,241,232,.18), transparent);
}
.hud__mark{ display:flex; align-items:center; gap:14px; }
.hud__logo{
  font-family:var(--font-display); font-weight:900;
  font-size:15px; letter-spacing:.04em; color:var(--paper);
}
.hud__logo em{ font-style:normal; color:var(--mag); font-weight:400; }
.hud__kana{
  font-family:var(--font-kana); font-weight:500;
  color:var(--paper-dim); letter-spacing:.08em; font-size:10px;
  padding-left:14px; border-left:1px solid rgba(244,241,232,.2);
}
.hud__nav{
  display:flex; justify-content:center; gap:26px;
}
.hud__nav a{
  color:var(--paper-dim);
  transition:color .2s ease;
  position:relative; padding:4px 0;
}
.hud__nav a:hover{ color:var(--cya); }
.hud__nav a.is-active{ color:var(--mag); }
.hud__nav a.is-active::after{
  content:''; position:absolute; left:0; right:0; bottom:-3px;
  height:1px; background:var(--mag);
}
.hud__meta{
  display:flex; gap:18px; justify-content:flex-end;
  color:var(--paper-dim);
}
.hud__date{ color:var(--lim); }

/* ─── progress rail ─────────────────────── */
.progress{
  position:fixed; left:28px; right:28px; bottom:24px; z-index:100;
  height:22px;
}
.progress__bar{
  position:absolute; left:0; right:0; top:10px; height:1px;
  background:rgba(244,241,232,.12);
}
.progress__bar::before{
  content:''; position:absolute; left:0; top:-1px; height:3px;
  width:var(--p, 0%);
  background:linear-gradient(90deg, var(--mag), var(--cya));
  box-shadow:0 0 14px rgba(255,0,110,.6);
  transition:width .08s linear;
}
.progress__ticks{
  position:absolute; inset:0;
  display:flex; justify-content:space-between;
  font-family:var(--font-mono); font-size:9px; letter-spacing:.18em;
  color:var(--paper-faint);
}
.progress__ticks span{ transform:translateY(12px); }

/* scroll hint */
.scrollhint{
  position:fixed; bottom:60px; right:40px; z-index:99;
  display:flex; align-items:center; gap:12px;
  font-family:var(--font-mono); font-size:10px; letter-spacing:.2em;
  color:var(--paper-dim);
  transition:opacity .6s ease;
}
.scrollhint__arrow{
  color:var(--cya);
  animation:nudge 1.6s ease-in-out infinite;
}
.scrollhint.is-hidden{ opacity:0; }
@keyframes nudge{
  0%,100%{ transform:translateX(0); }
  50%{    transform:translateX(8px); }
}

/* ─── horizontal track ──────────────────── */
.track{
  height:100vh;
  width:max-content;
  display:flex;
  flex-direction:row;
  position:relative;
  will-change:transform;
}
.panel{
  position:relative;
  height:100vh;
  width:var(--panel-w);
  flex:0 0 auto;
  overflow:hidden;
  border-right:1px solid rgba(244,241,232,.06);
}
.panel--hero{ width:var(--panel-w-hero); }
.panel--outro{ width:min(1200px, 110vw); }

.layer{
  position:absolute; inset:0;
  will-change:transform;
  transform:translate3d(var(--px, 0px), 0, 0);
}

/* universal bg grid */
.layer--bg-grid{
  background-image:
    linear-gradient(rgba(244,241,232,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(244,241,232,.045) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image:radial-gradient(ellipse at center, #000 40%, transparent 90%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 40%, transparent 90%);
}
.layer--bg-scan{
  background:repeating-linear-gradient(
    90deg,
    rgba(0,240,255,.05) 0 2px,
    transparent 2px 120px
  );
  mix-blend-mode:screen;
}
.layer--bg-gradient{
  background:
    radial-gradient(circle at 30% 50%, rgba(255,0,110,.18), transparent 50%),
    radial-gradient(circle at 80% 60%, rgba(0,240,255,.14), transparent 55%);
}

.layer--giant-num{
  display:flex; align-items:center; justify-content:flex-end;
  padding-right:4vw;
  font-family:var(--font-display);
  font-weight:900;
  font-size:min(64vh, 640px);
  line-height:.8;
  color:rgba(244,241,232,.03);
  letter-spacing:-.06em;
  pointer-events:none;
  user-select:none;
}

.layer--kanji{
  display:flex; align-items:flex-end;
  padding:0 5vw 6vh;
  font-family:var(--font-kana); font-weight:900;
  font-size:min(28vh, 280px); line-height:1;
  color:rgba(255,0,110,.07);
  writing-mode:vertical-rl;
  letter-spacing:.05em;
  pointer-events:none;
  white-space:nowrap;
}

/* ─── HERO · CYBERPUNK GLOBE ─────────────── */
.layer--globe{
  display:flex; align-items:center; justify-content:flex-end;
  padding-right:7vw;
  pointer-events:none;
}
.globe{
  position:relative;
  width:min(62vh, 560px); aspect-ratio:1;
  filter: drop-shadow(0 0 40px rgba(255,0,110,.35)) drop-shadow(0 0 80px rgba(0,240,255,.18));
}
.globe__svg{
  width:100%; height:100%; display:block;
  overflow:visible;
}
/* meridians sweep as if the globe is rotating around its vertical axis */
.globe__merid{
  transform-origin: 0 0;
  transform-box: view-box;
  animation: globe-spin 28s linear infinite;
}
@keyframes globe-spin{
  0%  { transform: scaleX(1); }
  25% { transform: scaleX(0.15); }
  50% { transform: scaleX(-1); }
  75% { transform: scaleX(-0.15); }
  100%{ transform: scaleX(1); }
}
/* slow lateral drift on the whole wireframe block for parallax feel */
.globe__wire{
  animation: wire-breathe 9s ease-in-out infinite;
  transform-origin: center;
}
@keyframes wire-breathe{
  0%,100%{ opacity:.92; }
  50%    { opacity:1;   }
}
/* city beacons blink */
.globe__cities circle{
  animation: beacon 2.4s ease-in-out infinite;
  transform-origin: center;
}
.globe__cities circle:nth-child(1){ animation-delay: 0s;   }
.globe__cities circle:nth-child(2){ animation-delay: 0.4s; }
.globe__cities circle:nth-child(3){ animation-delay: 0.8s; }
.globe__cities circle:nth-child(4){ animation-delay: 1.2s; }
.globe__cities circle:nth-child(5){ animation-delay: 1.6s; }
.globe__cities circle:nth-child(6){ animation-delay: 2.0s; }
.globe__cities circle:nth-child(7){ animation-delay: 0.6s; }
@keyframes beacon{
  0%,100%{ opacity:.35; }
  50%    { opacity:1; filter:drop-shadow(0 0 3px currentColor); }
}
/* HUD crosshairs subtly breathe */
.globe__hud{ animation: hud-pulse 4s ease-in-out infinite; transform-origin:center; }
@keyframes hud-pulse{ 0%,100%{ opacity:.6; } 50%{ opacity:1; } }

/* scanline overlay on globe only */
.globe__scan{
  position:absolute; inset:0;
  border-radius:50%;
  background:repeating-linear-gradient(
    0deg,
    rgba(0,240,255,.08) 0 1px,
    transparent 1px 4px
  );
  mix-blend-mode:screen;
  pointer-events:none;
  mask-image:radial-gradient(circle, #000 60%, transparent 78%);
  -webkit-mask-image:radial-gradient(circle, #000 60%, transparent 78%);
  animation: scan-drift 6s linear infinite;
}
@keyframes scan-drift{
  from{ background-position:0 0; }
  to  { background-position:0 120px; }
}

/* orbit ring */
.globe__ring{
  position:absolute; right:calc(7vw - 40px);
  top:50%; transform:translateY(-50%);
  width:min(78vh, 700px); aspect-ratio:1;
  border-radius:50%;
  border:1px dashed rgba(0,240,255,.35);
  animation:spin 120s linear infinite;
}
.globe__ring::after{
  content:''; position:absolute;
  top:-4px; left:50%;
  width:8px; height:8px;
  background:var(--cya);
  border-radius:50%;
  box-shadow:0 0 14px var(--cya);
  transform:translateX(-50%);
}
@keyframes spin{ to{ transform:translateY(-50%) rotate(360deg); } }

.hero__content{
  display:flex; flex-direction:column; justify-content:center;
  padding:0 clamp(40px, 6vw, 120px);
  max-width:1200px;
  z-index:3;
}
.hero__eyebrow{
  display:flex; align-items:center; gap:10px;
  font-size:11px; letter-spacing:.28em; text-transform:uppercase;
  color:var(--lim); margin-bottom:34px;
}
.hero__eyebrow .dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--lim); box-shadow:0 0 10px var(--lim);
  animation:pulse 2.2s ease-in-out infinite;
}
@keyframes pulse{ 0%,100%{ opacity:1; } 50%{ opacity:.3; } }

.hero__title{
  font-family:var(--font-display);
  font-weight:900;
  font-size:clamp(64px, 11vw, 180px);
  line-height:.88;
  letter-spacing:-.035em;
  color:var(--paper);
  margin-bottom:40px;
}
.hero__line{ display:block; position:relative; }
.hero__line--1{
  font-weight:300; font-style:italic;
  font-size:.5em; color:var(--paper-dim);
  letter-spacing:.12em;
  margin-bottom:10px;
}
.hero__line--2{
  color:transparent;
  -webkit-text-stroke:1.5px var(--mag);
  text-shadow:
    -2px 0 0 rgba(0,240,255,.6),
     2px 0 0 rgba(255,0,110,.6);
  animation:rgb-flick 6s ease-in-out infinite;
}
.hero__line--3{
  color:var(--paper);
  position:relative;
}
.hero__line--3::after{
  content:''; display:inline-block; width:14px; height:.92em;
  background:var(--mag); margin-left:10px;
  transform:translateY(.08em);
  animation:blink 1.1s step-end infinite;
  box-shadow:0 0 20px var(--mag);
}
@keyframes rgb-flick{
  0%,92%,100%{ text-shadow:-2px 0 0 rgba(0,240,255,.6), 2px 0 0 rgba(255,0,110,.6); }
  93%       { text-shadow:-6px 0 0 rgba(0,240,255,.8), 6px 0 0 rgba(255,0,110,.8); }
  94%       { text-shadow:1px 0 0 rgba(0,240,255,.4), -1px 0 0 rgba(255,0,110,.4); }
}
@keyframes blink{ 50%{ opacity:0; } }

.hero__stamp{
  display:flex; align-items:center; gap:20px;
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:.2em; text-transform:uppercase;
  margin-bottom:50px;
}
.hero__edition{
  color:var(--cya);
  padding:6px 12px;
  border:1px solid rgba(0,240,255,.4);
}
.hero__sig{ color:var(--paper-dim); font-style:italic; letter-spacing:.12em; text-transform:none; }

.hero__meta{
  display:grid; grid-template-columns:repeat(3, minmax(0,1fr));
  gap:32px; max-width:660px;
  padding-top:24px;
  border-top:1px solid rgba(244,241,232,.12);
}
.hero__meta .label,
.hero__meta .value,
.coord__k, .coord__v,
.apply__meta .label, .apply__meta .value,
.hero__meta > div,
.outro__foot > div{
  display:block;
}
.label{
  font-family:var(--font-mono); font-size:10px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--paper-faint);
  margin-bottom:6px;
}
.value{
  font-family:var(--font-display); font-weight:500;
  font-size:14px; letter-spacing:.02em; color:var(--paper);
}

.hero__ticker{
  /* override .layer's inset:0 so the ticker docks to the bottom
     instead of stretching full-height and vertically centering its band */
  position:absolute;
  top:auto;
  left:0; right:0;
  bottom:64px;
  height:44px;
  display:flex; align-items:center;
  pointer-events:none;
  z-index:2;
}
.hero__ticker::before,
.hero__ticker::after{
  content:''; position:absolute; top:0; bottom:0; width:140px; z-index:2;
}
.hero__ticker::before{ left:0; background:linear-gradient(90deg, var(--ink), transparent); }
.hero__ticker::after { right:0; background:linear-gradient(-90deg, var(--ink), transparent); }
.ticker{
  width:100%; overflow:hidden;
  border-top:1px solid rgba(0,240,255,.2);
  border-bottom:1px solid rgba(0,240,255,.2);
  padding:10px 0;
}
.ticker__row{
  display:inline-flex; gap:22px; white-space:nowrap;
  font-family:var(--font-display); font-weight:500;
  font-size:13px; letter-spacing:.28em;
  color:var(--cya);
  animation:marquee 48s linear infinite;
}
.ticker__row span:nth-child(even){ color:var(--paper-faint); }
@keyframes marquee{
  from{ transform:translateX(0); }
  to  { transform:translateX(-50%); }
}

/* ─── panel head (shared) ───────────────── */
.panel__head{
  display:grid;
  grid-template-columns:auto auto 1fr;
  align-items:end;
  gap:20px;
  margin-bottom:48px;
}
.panel__num{
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:.24em; color:var(--mag);
}
.panel__title{
  font-family:var(--font-display);
  font-weight:900;
  font-size:clamp(36px, 5.4vw, 90px);
  letter-spacing:-.02em; line-height:.9;
  color:var(--paper);
}
.panel__rule{
  height:1px; background:linear-gradient(90deg, rgba(244,241,232,.3), transparent);
  margin-bottom:14px;
}

/* ─── THESIS ────────────────────────────── */
.thesis__inner{
  padding:140px clamp(40px, 5vw, 120px) 100px;
  display:flex; flex-direction:column;
  z-index:3;
}
.thesis__grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr 0.9fr;
  gap:clamp(32px, 4vw, 72px);
  align-items:start;
  max-width:1700px;
}
.thesis__lead p{
  font-family:var(--font-display); font-weight:300;
  font-size:clamp(18px, 1.6vw, 28px);
  line-height:1.4; color:var(--paper);
  margin-bottom:22px; max-width:40ch;
}
.thesis__lead em{ color:var(--cya); font-style:italic; }
.thesis__lead .hl{
  background:linear-gradient(180deg, transparent 62%, rgba(255,0,110,.35) 62%);
  padding:0 4px;
}
.thesis__pull{
  padding:28px;
  border:1px solid rgba(0,240,255,.25);
  background:rgba(0,240,255,.04);
  position:relative;
}
.thesis__pull::before{
  content:''; position:absolute; inset:6px;
  border:1px dashed rgba(0,240,255,.12);
  pointer-events:none;
}
.quote-mark{
  font-family:var(--font-display); font-size:64px; line-height:.8;
  color:var(--mag); display:block; margin-bottom:12px;
}
.thesis__pull p{
  font-family:var(--font-display); font-weight:400;
  font-size:clamp(18px, 1.5vw, 26px);
  line-height:1.35; color:var(--paper);
}
.thesis__pull .flick{
  font-family:var(--font-glitch); color:var(--lim); font-weight:400;
  font-size:.95em; letter-spacing:.02em;
}
.quote-attr{
  display:block; margin-top:18px;
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:.18em; color:var(--paper-dim);
  text-transform:uppercase;
}
.thesis__specs{
  display:flex; flex-direction:column; gap:18px;
}
.spec{
  border-top:1px solid rgba(244,241,232,.12);
  padding-top:12px;
}
.spec__k{
  font-family:var(--font-mono); font-size:10px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--lim); display:block;
  margin-bottom:6px;
}
.spec__v{
  font-family:var(--font-display); font-size:14px; font-weight:400;
  color:var(--paper); letter-spacing:.02em;
}

/* ─── PROGRAM ───────────────────────────── */
.program__inner{
  padding:140px clamp(40px, 5vw, 120px) 100px;
  display:flex; flex-direction:column;
  z-index:3;
}
.program__grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(360px, 1fr));
  gap:clamp(28px, 3vw, 56px);
  max-width:1700px;
  flex:1; align-items:start;
}
.day{
  border-left:1px solid rgba(244,241,232,.18);
  padding:6px 28px 20px 28px;
  position:relative;
}
.day--featured{
  border-left-color:var(--mag);
  background:linear-gradient(180deg, rgba(255,0,110,.05), transparent 60%);
}
.day--featured::before{
  content:''; position:absolute; left:-1px; top:0; bottom:0;
  width:1px; background:var(--mag);
  box-shadow:0 0 18px rgba(255,0,110,.6);
}
.day__head{
  display:flex; flex-direction:column; gap:6px; margin-bottom:26px;
}
.day__date{
  font-family:var(--font-glitch);
  font-size:clamp(40px, 4.5vw, 72px); line-height:1;
  color:var(--paper);
}
.day--featured .day__date{ color:var(--mag); }
.day__label{
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:.22em; text-transform:uppercase; color:var(--cya);
}
.day__jp{
  font-family:var(--font-kana); font-weight:500;
  color:var(--paper-dim); font-size:13px; letter-spacing:.1em;
}
.day__list{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:14px;
}
.day__list li{
  display:grid; grid-template-columns:66px 1fr;
  gap:14px; align-items:baseline;
  padding-bottom:12px;
  border-bottom:1px dashed rgba(244,241,232,.08);
}
.day__list .t{
  font-family:var(--font-mono); font-size:12px;
  color:var(--lim); letter-spacing:.1em;
}
.day__list .s{
  font-family:var(--font-display); font-weight:400;
  font-size:14px; line-height:1.4; color:var(--paper);
}
.day__list .s em{ color:var(--paper-dim); font-style:italic; }

.program__note{
  display:flex; gap:14px; align-items:flex-start;
  margin-top:40px; padding-top:20px;
  border-top:1px solid rgba(244,241,232,.12);
  max-width:780px;
}
.program__note span{ color:var(--mag); font-size:20px; line-height:1; }
.program__note p{
  font-family:var(--font-mono); font-size:12px; line-height:1.7;
  color:var(--paper-dim); letter-spacing:.04em;
}
.program__note em{ color:var(--cya); font-style:italic; }

/* ─── VOICES ────────────────────────────── */
.voices__inner{
  padding:140px clamp(40px, 5vw, 120px) 100px;
  display:flex; flex-direction:column;
  z-index:3;
}
.voices__grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(260px, 1fr));
  gap:clamp(16px, 1.6vw, 28px);
  max-width:1700px;
  flex:1; align-content:start;
}
.voice{
  display:flex; gap:16px;
  padding:18px;
  border:1px solid rgba(244,241,232,.1);
  background:rgba(255,255,255,.015);
  transition:border-color .3s ease, transform .3s ease, background .3s ease;
}
.voice:hover{
  border-color:hsl(var(--vhue), 100%, 55%);
  background:rgba(255,255,255,.035);
  transform:translateY(-3px);
}
.voice__portrait{
  flex:0 0 64px; height:64px; position:relative;
  background:
    linear-gradient(135deg,
      hsl(var(--vhue), 90%, 60%) 0%,
      hsl(calc(var(--vhue) + 40), 80%, 30%) 100%);
  clip-path:polygon(0 0, 100% 0, 100% 85%, 85% 100%, 0 100%);
  overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.voice__portrait::before{
  content:attr(data-sig);
  font-family:var(--font-display); font-weight:900;
  font-size:20px; color:rgba(6,7,12,.6);
  letter-spacing:.02em;
}
.voice__portrait::after{
  content:''; position:absolute; inset:0;
  background:
    repeating-linear-gradient(0deg, rgba(0,0,0,.15) 0 1px, transparent 1px 3px),
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.3), transparent 50%);
  mix-blend-mode:overlay;
}
.voice__body{ flex:1; min-width:0; }
.voice h3{
  font-family:var(--font-display); font-weight:500;
  font-size:15px; line-height:1.2; color:var(--paper);
  margin-bottom:4px;
  letter-spacing:-.01em;
}
.voice__role{
  font-family:var(--font-mono); font-size:11px;
  color:hsl(var(--vhue), 90%, 65%); line-height:1.3;
  margin-bottom:2px;
}
.voice__aff{
  font-family:var(--font-mono); font-size:10px;
  color:var(--paper-faint); letter-spacing:.08em;
  text-transform:uppercase; margin-bottom:8px;
}
.voice__focus{
  font-family:var(--font-mono); font-size:10px;
  color:var(--paper-dim); line-height:1.5;
  padding-top:8px;
  border-top:1px dashed rgba(244,241,232,.08);
}
.voices__tail{
  margin-top:36px;
  font-family:var(--font-display); font-style:italic;
  font-weight:300;
  font-size:18px; color:var(--paper-dim);
  letter-spacing:.01em;
}

/* ─── VENUE ─────────────────────────────── */
.layer--torii{
  background-image:
    linear-gradient(to right, rgba(255,0,110,.08), transparent 60%);
  pointer-events:none;
}
.layer--torii::before,
.layer--torii::after{
  content:''; position:absolute;
  width:40vh; height:52vh;
  right:8vw; top:14vh;
  background:
    linear-gradient(90deg, transparent 46%, rgba(255,0,110,.22) 46% 54%, transparent 54%),
    linear-gradient(180deg, transparent 16%, rgba(255,0,110,.22) 16% 19%, transparent 19%),
    linear-gradient(180deg, transparent 10%, rgba(255,0,110,.12) 10% 13%, transparent 13%);
  opacity:.6;
}
.layer--torii::after{
  right:32vw; top:22vh;
  width:32vh; height:42vh;
  opacity:.22;
  filter:blur(.3px);
}

.venue__inner{
  padding:140px clamp(40px, 5vw, 120px) 100px;
  display:flex; flex-direction:column;
  z-index:3;
}
.venue__grid{
  display:grid;
  grid-template-columns:1.1fr 0.8fr 1fr;
  gap:clamp(32px, 4vw, 72px);
  align-items:start;
  max-width:1700px;
}
.venue__copy h3{
  font-family:var(--font-display); font-weight:500;
  font-size:clamp(24px, 2.4vw, 38px);
  letter-spacing:-.01em;
  color:var(--paper); margin-bottom:20px; line-height:1.15;
}
.venue__copy h3::first-letter{ color:var(--mag); }
.venue__copy p{
  font-family:var(--font-mono); font-size:13px; line-height:1.7;
  color:var(--paper-dim); margin-bottom:16px;
  max-width:46ch;
}
.venue__copy em{ color:var(--cya); font-style:italic; }
.venue__note{
  padding-top:16px;
  border-top:1px solid rgba(244,241,232,.12);
  font-size:12px !important;
}
.venue__coords{
  display:grid; grid-template-columns:1fr; gap:10px;
  padding:22px;
  border:1px solid rgba(212,255,0,.25);
  background:rgba(212,255,0,.02);
}
.coord{
  display:grid; grid-template-columns:80px 1fr;
  gap:14px; align-items:baseline;
  padding:6px 0;
  border-bottom:1px dashed rgba(244,241,232,.08);
}
.coord:last-child{ border-bottom:none; }
.coord__k{
  font-family:var(--font-mono); font-size:10px;
  color:var(--lim); letter-spacing:.18em;
}
.coord__v{
  font-family:var(--font-display); font-size:13px;
  font-weight:400; color:var(--paper);
  letter-spacing:.02em;
}
.venue__diagram{
  padding:20px;
  border:1px solid rgba(0,240,255,.22);
  background:rgba(0,240,255,.02);
}
.venue__diagram svg{
  width:100%; height:auto; display:block;
}

/* ─── APPLY ─────────────────────────────── */
.apply__inner{
  padding:140px clamp(40px, 5vw, 120px) 100px;
  display:flex; flex-direction:column;
  z-index:3;
}
.apply__grid{
  display:grid;
  grid-template-columns: 1fr 1.1fr 0.7fr;
  gap:clamp(32px, 4vw, 64px);
  align-items:start;
  max-width:1700px;
}
.apply__copy h3{
  font-family:var(--font-display); font-weight:500;
  font-size:clamp(26px, 2.6vw, 44px);
  letter-spacing:-.02em; line-height:1.1;
  color:var(--paper); margin-bottom:22px;
}
.apply__copy h3::after{ content:' ◎'; color:var(--mag); }
.apply__copy p{
  font-family:var(--font-mono); font-size:13px; line-height:1.7;
  color:var(--paper-dim); margin-bottom:16px;
  max-width:42ch;
}
.apply__copy em{ color:var(--cya); font-style:italic; }
.apply__meta{
  margin-top:24px;
  display:flex; flex-direction:column; gap:12px;
  padding-top:16px;
  border-top:1px solid rgba(244,241,232,.12);
}
.apply__meta > div{ display:grid; grid-template-columns:150px 1fr; gap:12px; }

.apply__form{
  position:relative;
  padding:26px;
  border:1px solid rgba(255,0,110,.3);
  background:
    linear-gradient(180deg, rgba(255,0,110,.03), transparent),
    rgba(6,7,12,.6);
  display:flex; flex-direction:column; gap:16px;
}
.apply__form::before{
  content:''; position:absolute; top:-1px; left:-1px; right:-1px;
  height:1px; background:linear-gradient(90deg, var(--mag), var(--cya), var(--lim));
}
.apply__form-head{
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--font-mono); font-size:10px;
  letter-spacing:.24em; text-transform:uppercase; color:var(--mag);
  padding-bottom:12px;
  border-bottom:1px dashed rgba(255,0,110,.3);
  margin-bottom:6px;
}
.blip{
  width:8px; height:8px; border-radius:50%;
  background:var(--mag); box-shadow:0 0 12px var(--mag);
  animation:pulse 1.2s ease-in-out infinite;
}
.apply__form label{
  display:flex; flex-direction:column; gap:6px;
}
.apply__form .label{ margin-bottom:0; color:var(--cya); }
.apply__form input,
.apply__form textarea{
  font-family:var(--font-mono); font-size:13px;
  color:var(--paper);
  background:transparent;
  border:none;
  border-bottom:1px solid rgba(244,241,232,.2);
  padding:8px 0;
  outline:none;
  transition:border-color .2s ease;
  resize:none;
}
.apply__form input::placeholder,
.apply__form textarea::placeholder{ color:var(--paper-faint); }
.apply__form input:focus,
.apply__form textarea:focus{ border-color:var(--lim); }

.apply__controls{
  display:flex; justify-content:space-between; align-items:center;
  margin-top:8px; gap:16px; flex-wrap:wrap;
}
.check{
  display:flex !important; flex-direction:row !important;
  align-items:center; gap:10px;
  font-family:var(--font-mono); font-size:11px;
  color:var(--paper-dim); letter-spacing:.04em;
}
.check input{
  appearance:none; width:14px; height:14px;
  border:1px solid rgba(0,240,255,.5);
  background:transparent; position:relative; cursor:pointer;
  flex-shrink:0;
}
.check input:checked{ background:var(--cya); border-color:var(--cya); }
.check input:checked::after{
  content:'✓'; position:absolute; inset:-2px 0 0 1px;
  color:var(--ink); font-size:12px; font-weight:900;
  font-family:var(--font-mono);
}

.apply__form button{
  font-family:var(--font-display); font-weight:700;
  font-size:12px; letter-spacing:.22em;
  color:var(--ink); background:var(--lim);
  border:none;
  padding:14px 26px;
  cursor:pointer;
  transition:all .2s ease;
  position:relative; overflow:hidden;
}
.apply__form button:hover{
  background:var(--mag); color:var(--paper);
  box-shadow:0 0 24px rgba(255,0,110,.6);
}
.btn__done{ display:none; }
.apply__form.sent button{
  background:var(--cya); color:var(--ink);
  pointer-events:none;
}
.apply__form.sent .btn__text{ display:none; }
.apply__form.sent .btn__done{ display:inline; }

.apply__sidecar{
  padding:20px;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(244,241,232,.1);
  display:flex; flex-direction:column; gap:8px;
}
.sidecar__row{
  display:flex; justify-content:space-between;
  font-family:var(--font-mono); font-size:11px;
  padding:8px 0;
  border-bottom:1px dashed rgba(244,241,232,.08);
}
.sidecar__row:last-child{ border-bottom:none; }
.sidecar__row span:first-child{ color:var(--paper-faint); letter-spacing:.14em; text-transform:uppercase; }
.sidecar__row span:last-child{ color:var(--lim); }

/* ─── OUTRO ─────────────────────────────── */
.outro__inner{
  display:flex; flex-direction:column; justify-content:center;
  padding:0 clamp(40px, 6vw, 140px);
  max-width:1200px;
  z-index:3;
  position:relative;
}
.outro__eyebrow{
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:.3em; color:var(--mag);
  margin-bottom:28px;
}
.outro__big{
  font-family:var(--font-display); font-weight:900;
  font-size:clamp(60px, 9vw, 150px);
  line-height:.92; letter-spacing:-.03em;
  color:var(--paper); margin-bottom:14px;
}
.outro__jp{
  font-family:var(--font-kana); font-weight:300;
  color:var(--cya);
  font-size:clamp(18px, 1.8vw, 28px);
  letter-spacing:.15em; margin-bottom:60px;
}
.outro__foot{
  display:grid;
  grid-template-columns:1fr 1fr 2fr;
  gap:32px;
  padding-top:28px;
  border-top:1px solid rgba(244,241,232,.12);
  max-width:1000px;
}
.outro__mark{
  position:absolute; right:clamp(40px, 6vw, 140px);
  bottom:80px;
  display:flex; flex-direction:column; align-items:flex-end; gap:4px;
}
.outro__mark span:first-child{
  font-family:var(--font-display); font-weight:900;
  font-size:30px; color:var(--paper);
}
.outro__mark em{ font-style:normal; color:var(--mag); font-weight:400; }
.mini-kana{
  font-family:var(--font-kana); font-weight:500;
  color:var(--paper-faint); font-size:12px; letter-spacing:.14em;
}

/* ─── mobile fallback ───────────────────── */
.mobile-note{ display:none; }

@media (max-width: 880px){
  :root{
    --panel-w: 100vw;
    --panel-w-hero: 100vw;
  }
  html, body{ overflow:auto; height:auto; }
  .track{
    flex-direction:column;
    width:100%;
    height:auto;
  }
  .panel{
    width:100vw !important;
    height:auto; min-height:100vh;
    padding-top:20px;
  }
  .layer{ transform:none !important; }

  .hud{
    grid-template-columns:1fr auto;
    padding:14px 18px;
  }
  .hud__nav, .hud__meta{ display:none; }
  .progress, .scrollhint{ display:none; }

  .hero__content, .thesis__inner, .program__inner,
  .voices__inner, .venue__inner, .apply__inner, .outro__inner{
    padding:100px 22px 60px !important;
  }

  .hero__title{ font-size:64px; }
  .hero__meta{ grid-template-columns:1fr; gap:18px; }
  .hero__ticker{ display:none; }
  .layer--moon{ opacity:.35; }
  .layer--kanji{ font-size:24vh; }

  .panel__head{ grid-template-columns:auto 1fr; gap:14px; margin-bottom:32px; }
  .panel__title{ font-size:44px; }
  .panel__rule{ grid-column:1/-1; }

  .thesis__grid,
  .program__grid,
  .venue__grid,
  .apply__grid{
    grid-template-columns:1fr;
    gap:32px;
  }
  .voices__grid{ grid-template-columns:1fr 1fr; }

  .outro__mark{ position:static; align-items:flex-start; margin-top:40px; }
  .outro__foot{ grid-template-columns:1fr; }

  .mobile-note{
    display:flex;
    align-items:flex-start; gap:12px;
    position:fixed; bottom:16px; left:16px; right:16px;
    padding:12px 14px;
    background:rgba(6,7,12,.9);
    border:1px solid var(--cya);
    font-family:var(--font-mono); font-size:11px;
    color:var(--paper-dim); line-height:1.5;
    z-index:102;
  }
  .mobile-note span{ color:var(--cya); font-size:16px; line-height:1; }
}

/* ─── reduced motion ─────────────────────── */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation:none !important; transition:none !important; }
  .layer{ transform:none !important; }
}
