:root{
  --bg:#04050a;
  --bg-2:#070912;
  --ink:#e8ecf8;
  --soft:#6b7290;
  --faint:#2a3048;
  --line:rgba(60,90,220,.16);
  --blue:#2b4cff;
  --blue-bright:#5a78ff;
  --blue-glow:#3a5cff;
  --white-hot:#dfe6ff;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
::selection{background:rgba(43,76,255,.35);color:var(--white-hot)}
body{
  background:var(--bg);color:var(--ink);
  font-family:'Geist Mono',monospace;font-weight:300;
  -webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden;line-height:1.6;
}
/* grit + halftone texture overlay */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background-image:
    radial-gradient(rgba(43,76,255,.13) 1px, transparent 1px),
    radial-gradient(rgba(43,76,255,.07) 1px, transparent 1px);
  background-size:3px 3px, 7px 7px;
  background-position:0 0, 1px 2px;
  mix-blend-mode:screen;
}
/* film-grain noise */
body::after{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.06;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
#hero-canvas{display:none}
.wrap{position:relative;z-index:2;max-width:1080px;margin:0 auto;padding:0 32px}

/* ---------- wordmark + nav ---------- */
nav{display:flex;align-items:center;justify-content:space-between;
  padding:30px 0;gap:24px;flex-wrap:wrap;border-bottom:1px solid var(--line);
  opacity:0;animation:fade 1s .1s forwards;}
.word{display:block;text-decoration:none;line-height:0}
.word img{height:26px;width:auto;display:block;
  filter:drop-shadow(0 0 16px rgba(43,76,255,.55));
  transition:filter .3s}
.word:hover img{filter:drop-shadow(0 0 24px rgba(43,76,255,.9))}
.tabs{display:flex;gap:30px}
.tabs a{font-family:'Geist Mono',monospace;font-weight:400;font-size:.66rem;
  letter-spacing:.26em;text-transform:uppercase;color:var(--soft);text-decoration:none;
  transition:color .3s,text-shadow .3s;position:relative;padding:4px 0}
.tabs a::before{content:"+";position:absolute;left:-14px;opacity:0;color:var(--blue);transition:opacity .3s}
.tabs a:hover,.tabs a[aria-current="page"]{color:var(--blue-bright);text-shadow:0 0 12px rgba(43,76,255,.6)}
.tabs a:hover::before,.tabs a[aria-current="page"]::before{opacity:1}

/* ---------- hero ---------- */
.hero{padding:16vh 0 14vh;opacity:0;animation:fade 1.4s .4s forwards;position:relative}
.hero .eyebrow{font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--blue);margin-bottom:2.4rem;display:flex;align-items:center;gap:10px}
.hero .eyebrow::before{content:"";width:30px;height:1px;background:var(--blue);
  box-shadow:0 0 8px var(--blue)}
.hero h1{
  font-family:'Anton',sans-serif;font-weight:400;
  font-size:clamp(2.4rem,6.4vw,4.6rem);line-height:1.02;
  letter-spacing:.005em;max-width:16ch;text-transform:uppercase;
  color:var(--white-hot);
}
.hero h1 em{font-style:normal;color:var(--blue-bright);text-shadow:0 0 28px rgba(43,76,255,.6)}
.hero .lede{margin-top:2.2rem;font-size:.92rem;color:var(--soft);max-width:48ch;
  letter-spacing:.02em;line-height:1.75}

/* tagline strip */
.creed{font-family:'Anton',sans-serif;letter-spacing:.34em;font-size:.8rem;
  color:var(--blue);text-transform:uppercase;margin-top:3rem;opacity:.8}

/* ---------- section label ---------- */
.sec-label{font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;
  color:var(--faint);padding-bottom:2.6rem;display:flex;align-items:center;gap:12px}
.sec-label::before{content:"//";color:var(--blue)}
.sec-label::after{content:"";flex:1;height:1px;background:var(--line)}

section{padding:9vh 0;position:relative}

/* ---------- tenets (principles page) ---------- */
.tenets{display:flex;flex-direction:column}
.tenet{display:grid;grid-template-columns:60px 1fr;gap:28px;align-items:baseline;
  padding:2.4rem 0;border-top:1px solid var(--line);
  transition:padding-left .4s cubic-bezier(.2,.7,.2,1),background .4s;position:relative}
.tenet:last-child{border-bottom:1px solid var(--line)}
.tenet::before{content:"";position:absolute;left:0;top:-1px;width:0;height:1px;
  background:linear-gradient(90deg,var(--blue),transparent);
  box-shadow:0 0 8px var(--blue);transition:width .5s ease}
.tenet:hover{padding-left:18px;background:rgba(43,76,255,.03)}
.tenet:hover::before{width:55%}
.tenet .n{font-family:'Anton',sans-serif;font-size:.9rem;color:var(--blue);
  letter-spacing:.05em;padding-top:.2rem}
.tenet p{font-family:'Geist Mono',monospace;font-size:1.02rem;line-height:1.6;
  font-weight:300;max-width:46ch}
.tenet p .hl{color:var(--blue-bright);text-shadow:0 0 14px rgba(43,76,255,.4)}

/* quote band */
.band{padding:14vh 0;text-align:center;position:relative}
.band blockquote{font-family:'Anton',sans-serif;font-weight:400;
  font-size:clamp(1.8rem,5vw,3.4rem);line-height:1.12;text-transform:uppercase;
  max-width:18ch;margin:0 auto;color:var(--white-hot);letter-spacing:.01em}
.band blockquote em{font-style:normal;color:var(--blue-bright);
  text-shadow:0 0 30px rgba(43,76,255,.6)}
.band cite{display:block;margin-top:2rem;font-style:normal;
  font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;color:var(--soft)}

/* closing */
.closing{max-width:50ch;padding:2vh 0 0}
.closing p{font-size:1rem;color:var(--soft);line-height:1.8;letter-spacing:.01em}
.closing p strong{color:var(--blue-bright);font-weight:400;
  text-shadow:0 0 14px rgba(43,76,255,.4)}

/* ---------- generic content pages ---------- */
.page{padding:10vh 0 4vh;opacity:0;animation:fade 1.2s .3s forwards}
.page h2{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;
  font-size:clamp(2.2rem,6vw,3.6rem);letter-spacing:.01em;margin-bottom:1.4rem;color:var(--white-hot)}
.page h2 em{font-style:normal;color:var(--blue-bright)}
.page .intro{font-size:.9rem;color:var(--soft);max-width:50ch;margin-bottom:5vh;line-height:1.75}
.rows{display:flex;flex-direction:column}
.r{display:flex;justify-content:space-between;align-items:baseline;gap:24px;
  padding:1.7rem 0;border-top:1px solid var(--line);text-decoration:none;color:var(--ink);
  transition:padding-left .4s cubic-bezier(.2,.7,.2,1),background .4s}
.r:last-child{border-bottom:1px solid var(--line)}
.r:hover{padding-left:14px;color:var(--blue-bright);background:rgba(43,76,255,.03)}
.r .t{font-size:1.05rem;font-weight:300}
.r .m{font-size:.66rem;letter-spacing:.1em;color:var(--soft);text-transform:uppercase}
.r:hover .m{color:var(--blue)}

/* ---------- footer ---------- */
footer{margin-top:12vh;padding:3rem 0 5rem;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
  font-size:.62rem;letter-spacing:.18em;color:var(--soft);text-transform:uppercase}
footer a{color:var(--soft);text-decoration:none;transition:color .3s}
footer a:hover{color:var(--blue)}
.door{cursor:default;color:var(--faint);transition:color .5s,text-shadow .5s;user-select:none;font-size:.9rem}
.door:hover{color:var(--blue);text-shadow:0 0 12px var(--blue)}

@keyframes fade{to{opacity:1}}
@media (max-width:680px){
  nav{justify-content:center}
  .tabs{gap:18px;order:3;width:100%;justify-content:center;flex-wrap:wrap}
  .tenet{grid-template-columns:1fr;gap:8px}
  #hero-canvas{opacity:.7}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;opacity:1!important}#hero-canvas{display:none}}




/* ============================================================
   FRAMED IMAGERY — electric-blue HUD frame (true to references)
   ============================================================ */
.framed{position:relative;display:block}
.framed img{width:100%;display:block;filter:contrast(1.05) brightness(1.02)}
/* hairline border */
.framed::before{content:"";position:absolute;inset:0;
  border:1px solid rgba(60,90,220,.28);pointer-events:none}
/* corner brackets */
.framed .cnr{position:absolute;width:22px;height:22px;pointer-events:none;
  border-color:var(--blue);border-style:solid;border-width:0}
.framed .cnr.tl{top:-1px;left:-1px;border-top-width:2px;border-left-width:2px;
  box-shadow:-2px -2px 12px rgba(43,76,255,.4)}
.framed .cnr.tr{top:-1px;right:-1px;border-top-width:2px;border-right-width:2px;
  box-shadow:2px -2px 12px rgba(43,76,255,.4)}
.framed .cnr.bl{bottom:-1px;left:-1px;border-bottom-width:2px;border-left-width:2px;
  box-shadow:-2px 2px 12px rgba(43,76,255,.4)}
.framed .cnr.br{bottom:-1px;right:-1px;border-bottom-width:2px;border-right-width:2px;
  box-shadow:2px 2px 12px rgba(43,76,255,.4)}
/* tiny tick label top-left + readout bottom-right */
.framed .tick{position:absolute;font-family:'Geist Mono',monospace;font-size:.5rem;
  letter-spacing:.24em;text-transform:uppercase;color:var(--blue);opacity:.7;pointer-events:none}
.framed .tick.tag{top:8px;left:12px}
.framed .tick.read{bottom:8px;right:12px;color:var(--soft)}

/* ---------- central pyramid hero (framed, no fade) ---------- */
.monument{position:relative;display:flex;justify-content:center;padding:4vh 0 0;
  opacity:0;animation:fade 1.6s .3s forwards}
.monument-img{position:relative;width:min(660px,92%)}
.monument-img img{transition:transform .2s ease-out}
.monument-img .apexglow{position:absolute;left:50%;top:11%;width:180px;height:180px;
  transform:translate(-50%,-40%);pointer-events:none;
  background:radial-gradient(circle, rgba(90,120,255,.5), transparent 64%);
  filter:blur(6px);animation:apexPulse 4s ease-in-out infinite}
@keyframes apexPulse{0%,100%{opacity:.55;transform:translate(-50%,-40%) scale(calc(1*var(--amp,1)))}
  50%{opacity:1;transform:translate(-50%,-40%) scale(calc(1.1*var(--amp,1)))}}

.hero{padding:6vh 0 12vh;text-align:center;opacity:0;animation:fade 1.4s .5s forwards;position:relative}
.hero .eyebrow{justify-content:center}
.hero h1{margin:0 auto}
.hero .lede{margin-left:auto;margin-right:auto}

/* ============================================================
   FX LAYER — underscore cursor · cli · scanlines · grain · hud
   · vortex glyph · konami/portal · vault unlock
   ============================================================ */

/* --- underscore cursor (Arch-cli style), site-wide --- */
@media (hover:hover) and (pointer:fine){
  body.fx-cursor, body.fx-cursor *{cursor:none !important}
}
#uscore{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;
  width:13px;height:3px;background:var(--blue-bright);
  box-shadow:0 0 8px var(--blue),0 0 16px rgba(43,76,255,.6);
  transform:translate(-50%,8px);opacity:0;transition:opacity .3s;
  animation:ublink 1.1s steps(1) infinite}
#uscore.on{opacity:1}
#uscore.hot{background:#fff;box-shadow:0 0 12px #fff,0 0 22px var(--blue);width:16px}
@keyframes ublink{50%{opacity:0}}

/* --- scanlines + CRT --- */
#crt{position:fixed;inset:0;z-index:8000;pointer-events:none;
  background:repeating-linear-gradient(0deg,
    rgba(0,0,0,0) 0px,rgba(0,0,0,0) 2px,rgba(0,0,0,.20) 3px,rgba(0,0,0,0) 4px);
  mix-blend-mode:multiply;opacity:.5;animation:crtFlicker 7s infinite steps(60)}
@keyframes crtFlicker{0%,97%,100%{opacity:.5}98%{opacity:.6}99%{opacity:.42}}
#crt::after{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 120% at 50% 50%, transparent 70%, rgba(0,0,0,.32))}

/* --- animated grain --- */
#grain{position:fixed;inset:-50%;z-index:8001;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");will-change:transform}

/* --- command-line on the logo --- */
.word{display:flex;align-items:center;text-decoration:none;line-height:0;min-height:30px}
.word img{height:26px;width:auto;display:block;
  filter:drop-shadow(0 0 16px rgba(43,76,255,.55));transition:filter .3s,opacity .2s}
.word:hover img{filter:drop-shadow(0 0 24px rgba(43,76,255,.9))}
.word.cli img{display:none}
/* un-typing + typing: terminal mono font, same blue */
.untype{display:none;font-family:'Geist Mono',monospace;font-weight:500;font-size:1.15rem;
  letter-spacing:.02em;color:var(--blue-bright);text-shadow:0 0 14px rgba(43,76,255,.6);line-height:26px}
.word.untyping .untype{display:inline-flex;align-items:center}
.word.untyping .untype::after{content:"_";color:var(--blue-bright);animation:ublink 1.1s steps(1) infinite;margin-left:1px}
.cli-line{display:none;align-items:center;font-family:'Geist Mono',monospace;
  font-size:1.05rem;color:var(--blue-bright);letter-spacing:.02em;height:26px;white-space:nowrap}
.word.typing .cli-line, .word.ready .cli-line{display:flex}
/* while typing the prompt, hide input+caret until ready */
.word.typing #cli-input, .word.typing .cli-line .cur{display:none}
.word.typing .cli-line .prompt::after{content:"_";animation:ublink 1.1s steps(1) infinite}
.cli-line .prompt{color:var(--soft);margin-right:.4em}
.cli-line #cli-input{background:transparent;border:0;outline:0;color:var(--blue-bright);
  font:inherit;letter-spacing:inherit;width:8ch;caret-color:transparent;padding:0}
.cli-line .cur{display:inline-block;width:11px;height:18px;background:var(--blue-bright);
  margin-left:1px;animation:ublink 1.1s steps(1) infinite;box-shadow:0 0 8px var(--blue)}
.cli-line.err{color:#ff5a6a}
.cli-line.err .prompt{color:#ff5a6a}

/* --- live HUD --- */
#hud{position:fixed;right:18px;bottom:16px;z-index:7000;font-family:'Geist Mono',monospace;
  font-size:.56rem;letter-spacing:.12em;color:var(--soft);text-transform:uppercase;
  text-align:right;line-height:1.85;pointer-events:none;opacity:0;transition:opacity 1s;user-select:none}
#hud.on{opacity:.65}
#hud b{color:var(--blue);font-weight:400}
#hud .dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--blue);
  box-shadow:0 0 6px var(--blue);margin-left:6px;animation:hudPulse 1.6s ease-in-out infinite}
@keyframes hudPulse{50%{opacity:.3}}

/* --- vortex glyph (animated) replaces the footer diamond --- */
.glyph-vortex{display:inline-block;width:26px;height:26px;cursor:pointer;vertical-align:middle;
  filter:drop-shadow(0 0 6px rgba(43,76,255,.6))}
.glyph-vortex svg{display:block;width:100%;height:100%}
.glyph-vortex .spin{transform-origin:50% 50%;animation:vspin 9s linear infinite}
.glyph-vortex .spin2{transform-origin:50% 50%;animation:vspin 6s linear infinite reverse}
.glyph-vortex .core{transform-origin:50% 50%;animation:vcore 2.4s ease-in-out infinite}
@keyframes vspin{to{transform:rotate(360deg)}}
@keyframes vcore{0%,100%{opacity:.6;transform:scale(.8)}50%{opacity:1;transform:scale(1.15)}}

/* --- boot --- */
#boot{position:fixed;inset:0;z-index:10000;background:var(--bg);display:flex;
  align-items:center;justify-content:center;font-family:'Geist Mono',monospace;
  color:var(--blue-bright);transition:opacity .7s ease}
#boot.done{opacity:0;pointer-events:none}
#boot .boot-inner{width:min(640px,86%);font-size:.82rem;line-height:1.9;letter-spacing:.04em}
#boot .l{opacity:0;white-space:pre-wrap}#boot .l.show{opacity:1}
#boot .ok{color:var(--blue-bright)}#boot .dim{color:var(--soft)}

/* --- konami/cli portal: eye + hands --- */
#portal{position:fixed;inset:0;z-index:9500;background:rgba(2,3,8,.97);visibility:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;
  opacity:0;pointer-events:none;transition:opacity .8s ease;padding:24px}
#portal.on{opacity:1;pointer-events:auto;visibility:visible}
#portal .emblems{display:flex;gap:36px;align-items:center;flex-wrap:wrap;justify-content:center}
#portal .emblems .framed{width:min(420px,42vw);opacity:0;transform:translateY(20px) scale(.96);
  transition:opacity 1s ease,transform 1s cubic-bezier(.2,.7,.2,1)}
#portal.on .emblems .framed{opacity:1;transform:none}
#portal.on .emblems .framed:nth-child(2){transition-delay:.25s}
#portal .verdict{font-family:'Anton',sans-serif;font-size:clamp(1.4rem,4vw,2.4rem);
  text-transform:uppercase;color:var(--white-hot);letter-spacing:.02em;text-align:center;
  opacity:0;transition:opacity 1s .6s}
#portal.on .verdict{opacity:1}
#portal .verdict em{font-style:normal;color:var(--blue-bright);text-shadow:0 0 24px rgba(43,76,255,.6)}
#portal .enter{font-family:'Geist Mono',monospace;font-size:.7rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--blue-bright);text-decoration:none;border:1px solid var(--blue);
  padding:14px 28px;opacity:0;transition:opacity 1s .9s,background .3s,color .3s}
#portal.on .enter{opacity:1}
#portal .enter:hover{background:var(--blue);color:#02030a;box-shadow:0 0 30px rgba(43,76,255,.5)}
#portal .enter.sealed{color:var(--soft);border-color:var(--line)}
#portal .enter.sealed:hover{background:transparent;color:var(--soft);box-shadow:none}
#portal .close{position:absolute;top:24px;right:28px;color:var(--soft);font-family:'Geist Mono',monospace;
  font-size:.7rem;letter-spacing:.2em;cursor:pointer;text-transform:uppercase}
#portal .close:hover{color:var(--blue-bright)}

@media (prefers-reduced-motion:reduce){#boot,#crt,#grain,#uscore{display:none}}
@media (hover:none),(pointer:coarse){#uscore{display:none}}


/* --- audio: waveform glyph, bottom-left --- */
#audio-toggle{position:fixed;left:18px;bottom:16px;z-index:7000;cursor:pointer;user-select:none;
  display:flex;align-items:flex-end;gap:3px;height:18px;width:30px;
  opacity:0;animation:fade 1s 2s forwards;-webkit-tap-highlight-color:transparent}
#audio-toggle .bar{width:3px;background:var(--soft);height:5px;transition:background .3s}
#audio-toggle:hover .bar{background:var(--blue-bright)}
#audio-toggle.live .bar{background:var(--blue)}
/* animate bars only when live */
#audio-toggle.live .bar{animation:wave 1.1s ease-in-out infinite}
#audio-toggle.live .bar:nth-child(1){animation-delay:0s}
#audio-toggle.live .bar:nth-child(2){animation-delay:.15s}
#audio-toggle.live .bar:nth-child(3){animation-delay:.3s}
#audio-toggle.live .bar:nth-child(4){animation-delay:.45s}
#audio-toggle.live .bar:nth-child(5){animation-delay:.2s}
@keyframes wave{0%,100%{height:4px}50%{height:16px}}

/* --- portal modes: show only the relevant emblem + its bulletin --- */
#portal .emblems .framed{display:none}
#portal[data-mode="eye"]   .emblems .framed.eye{display:block}
#portal[data-mode="hands"] .emblems .framed.hands{display:block}
#portal .bulletin{display:none;text-align:center;max-width:52ch;margin:0 auto}
#portal[data-mode="eye"]   .bulletin.eye{display:block}
#portal[data-mode="hands"] .bulletin.hands{display:block}
#portal .bulletin .head{font-family:'Anton',sans-serif;font-size:clamp(1.2rem,3.4vw,1.9rem);
  text-transform:uppercase;letter-spacing:.04em;color:var(--white-hot);margin-bottom:1rem}
#portal .bulletin .head em{font-style:normal;color:var(--blue-bright);text-shadow:0 0 22px rgba(43,76,255,.6)}
#portal .bulletin .detail{font-family:'Geist Mono',monospace;font-size:.66rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--soft);line-height:2}
