: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}}


/* ---------- central pyramid hero ---------- */
.monument{position:relative;display:flex;justify-content:center;align-items:flex-start;
  padding:4vh 0 0;opacity:0;animation:fade 1.6s .3s forwards}
.monument-img{position:relative;width:min(680px,92%);}
.monument-img img{width:100%;display:block;
  -webkit-mask-image:radial-gradient(120% 100% at 50% 35%, #000 55%, transparent 92%);
  mask-image:radial-gradient(120% 100% at 50% 35%, #000 55%, transparent 92%);
  filter:contrast(1.08) brightness(1.04);}
/* subtle apex glow bloom layered over the image */
.monument-img::after{content:"";position:absolute;left:50%;top:8%;
  width:200px;height:200px;transform:translate(-50%,-30%);
  background:radial-gradient(circle, rgba(90,120,255,.45), transparent 65%);
  filter:blur(8px);pointer-events:none;
  animation:apexPulse 4s ease-in-out infinite}
@keyframes apexPulse{0%,100%{opacity:.6;transform:translate(-50%,-30%) scale(calc(1*var(--amp,1)))}
  50%{opacity:1;transform:translate(-50%,-30%) scale(calc(1.12*var(--amp,1)))}}

/* hero text sits below/over the monument */
.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}
.hero .creed{margin-top:3rem}

/* ============================================================
   FX LAYER — boot, cursor, scanlines, grain, HUD, konami, vault
   ============================================================ */

/* hide native cursor when custom reticle active (desktop only) */
@media (hover:hover) and (pointer:fine){
  body.fx-cursor, body.fx-cursor a, body.fx-cursor .door{cursor:none}
}

/* --- custom reticle cursor --- */
#reticle{position:fixed;top:0;left:0;width:30px;height:30px;z-index:9999;
  pointer-events:none;transform:translate(-50%,-50%);mix-blend-mode:screen;
  opacity:0;transition:opacity .4s, width .18s, height .18s}
#reticle.on{opacity:1}
#reticle::before,#reticle::after{content:"";position:absolute;background:var(--blue-bright);
  box-shadow:0 0 8px var(--blue)}
#reticle::before{left:50%;top:0;width:1px;height:100%;transform:translateX(-50%)}
#reticle::after{top:50%;left:0;height:1px;width:100%;transform:translateY(-50%)}
#reticle .ring{position:absolute;inset:6px;border:1px solid rgba(90,120,255,.6);border-radius:50%}
#reticle.click{width:18px;height:18px}
#reticle.hot .ring{border-color:var(--blue-bright);inset:3px}

/* --- 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,.22) 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:.62}99%{opacity:.42}}
#crt::after{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 120% at 50% 50%, transparent 70%, rgba(0,0,0,.35));}

/* --- animated grain (re-positioned each frame via JS variable) --- */
#grain{position:fixed;inset:-50%;z-index:8001;pointer-events:none;opacity:.05;
  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}

/* --- chromatic aberration on the monument --- */
.monument-img.aberr img{animation:none}
.monument-img .ghost{position:absolute;inset:0;pointer-events:none;
  -webkit-mask-image:radial-gradient(120% 100% at 50% 35%, #000 55%, transparent 92%);
  mask-image:radial-gradient(120% 100% at 50% 35%, #000 55%, transparent 92%);}
.monument-img .ghost img{width:100%;display:block}
.monument-img .ghost.r{mix-blend-mode:screen;opacity:.5}
.monument-img .ghost.b{mix-blend-mode:screen;opacity:.5}

/* --- boot overlay --- */
#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)}
#boot .cur{display:inline-block;width:.6em;height:1.05em;background:var(--blue-bright);
  vertical-align:-.15em;animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

/* --- 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:.7}
#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}}

/* --- audio toggle --- */
#audio-toggle{position:fixed;left:18px;bottom:16px;z-index:7000;
  font-family:'Geist Mono',monospace;font-size:.56rem;letter-spacing:.18em;
  color:var(--soft);text-transform:uppercase;cursor:pointer;user-select:none;
  border:1px solid var(--line);padding:6px 10px;background:rgba(8,10,18,.6);
  transition:color .3s,border-color .3s;opacity:0;animation:fade 1s 2s forwards}
#audio-toggle:hover{color:var(--blue-bright);border-color:var(--blue)}
#audio-toggle.live{color:var(--blue-bright);border-color:var(--blue)}

/* --- konami / vault overlay --- */
#portal{position:fixed;inset:0;z-index:9500;background:rgba(2,3,8,.96);visibility:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;
  opacity:0;pointer-events:none;transition:opacity .8s ease}
#portal.on{opacity:1;pointer-events:auto;visibility:visible}
#portal .emblems{display:flex;gap:40px;align-items:center;flex-wrap:wrap;justify-content:center}
#portal .emblems figure{margin:0;width:min(360px,40vw);position:relative;
  opacity:0;transform:translateY(20px) scale(.96);
  transition:opacity 1s ease, transform 1s cubic-bezier(.2,.7,.2,1)}
#portal.on .emblems figure{opacity:1;transform:none}
#portal.on .emblems figure:nth-child(2){transition-delay:.25s}
#portal .emblems img{width:100%;display:block;
  filter:brightness(1.05) contrast(1.1) drop-shadow(0 0 30px rgba(43,76,255,.4))}
#portal .pcap{font-family:'Geist Mono',monospace;font-size:.6rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--soft);text-align:center;margin-top:1rem}
#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;transition:all .3s;
  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 .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{display:none}#crt,#grain{display:none}
  #reticle{display:none}
}
@media (hover:none),(pointer:coarse){
  #reticle{display:none}
}

/* --- dramatic vault unlock overlay --- */
#unlock{position:fixed;inset:0;z-index:9800;background:var(--bg);visibility:hidden;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .5s}
#unlock.on{opacity:1;pointer-events:auto;visibility:visible}
#unlock .beam{position:absolute;left:50%;top:0;width:2px;height:0;
  background:linear-gradient(var(--white-hot),var(--blue),transparent);
  transform:translateX(-50%);box-shadow:0 0 30px var(--blue)}
#unlock.on .beam{animation:beamShoot 1.2s .3s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes beamShoot{to{height:100%}}
#unlock .core{width:8px;height:8px;border-radius:50%;background:var(--white-hot);
  box-shadow:0 0 0 0 rgba(90,120,255,.7)}
#unlock.on .core{animation:coreBlast 2s .4s ease-out forwards}
@keyframes coreBlast{
  0%{box-shadow:0 0 0 0 rgba(90,120,255,.7);transform:scale(1)}
  40%{box-shadow:0 0 60px 20px rgba(43,76,255,.5);transform:scale(2)}
  100%{box-shadow:0 0 200px 120px rgba(43,76,255,0);transform:scale(40)}}
#unlock .ulabel{position:absolute;bottom:18%;left:0;right:0;text-align:center;
  font-family:'Geist Mono',monospace;font-size:.66rem;letter-spacing:.34em;
  text-transform:uppercase;color:var(--blue-bright);opacity:0}
#unlock.on .ulabel{animation:fade .6s 1s forwards}

#portal .enter.sealed{color:var(--soft);border-color:var(--line);cursor:default}
#portal .enter.sealed:hover{background:transparent;color:var(--soft);box-shadow:none}
