/* =====================================================================
   DISCLOSION — Styles
   Deep-space, glass, glow. Modern + bold.
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  --bg:#05060a;
  --bg-2:#0a0c16;
  --panel:rgba(18,21,38,.55);
  --panel-solid:#0d1020;
  --line:rgba(140,160,255,.14);
  --text:#e8ecff;
  --muted:#9aa3c7;
  --dim:#6b7298;

  --cyan:#38e0ff;
  --violet:#9a6bff;
  --magenta:#ff5cdb;
  --green:#3dffa8;
  --amber:#ffb454;

  --grad: linear-gradient(120deg,var(--cyan),var(--violet) 55%,var(--magenta));
  --grad-soft: linear-gradient(120deg,rgba(56,224,255,.15),rgba(154,107,255,.15));

  --r-lg:22px;
  --r-md:16px;
  --r-sm:10px;
  --shadow:0 30px 80px -30px rgba(0,0,0,.8);
  --glow-cyan:0 0 40px rgba(56,224,255,.35);
  --maxw:1160px;
  --ease:cubic-bezier(.22,1,.36,1);
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:"Inter",system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img{max-width:100%}
::selection{background:var(--violet);color:#fff}

/* ---------- Background layers ---------- */
#space{
  position:fixed;inset:0;width:100%;height:100%;
  z-index:-3;display:block;
}
.nebula{
  position:fixed;inset:-20%;z-index:-2;pointer-events:none;
  background:
    radial-gradient(40% 35% at 20% 18%, rgba(154,107,255,.22), transparent 60%),
    radial-gradient(45% 40% at 82% 30%, rgba(56,224,255,.16), transparent 60%),
    radial-gradient(50% 45% at 60% 85%, rgba(255,92,219,.12), transparent 60%);
  filter:blur(30px);
  animation:drift 28s ease-in-out infinite alternate;
}
@keyframes drift{
  0%{transform:translate3d(0,0,0) scale(1)}
  100%{transform:translate3d(-3%,2%,0) scale(1.08)}
}
.grain{
  position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.04;
  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='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Scroll progress ---------- */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0;z-index:100;
  background:var(--grad);
  box-shadow:var(--glow-cyan);
}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:90;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(18px,4vw,46px);
  transition:background .4s var(--ease),backdrop-filter .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(7,8,14,.72);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:10px;font-family:"Space Grotesk",sans-serif;font-weight:700;letter-spacing:.18em;font-size:.95rem}
.brand-mark{
  font-size:1.25rem;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:spin 12s linear infinite;display:inline-block;
}
@keyframes spin{to{transform:rotate(360deg)}}
.nav-links{display:flex;gap:28px}
.nav-links a{
  font-size:.82rem;letter-spacing:.06em;color:var(--muted);position:relative;
  transition:color .25s;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;
  background:var(--grad);transition:width .3s var(--ease);
}
.nav-links a:hover{color:var(--text)}
.nav-links a:hover::after{width:100%}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:.3s var(--ease)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:100px;font-weight:600;font-size:.92rem;
  cursor:pointer;border:1px solid transparent;transition:transform .25s var(--ease),box-shadow .25s,background .25s;
  letter-spacing:.02em;
}
.btn-primary{background:var(--grad);color:#06070d;box-shadow:var(--glow-cyan)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 0 50px rgba(56,224,255,.55)}
.btn-ghost{border-color:var(--line);color:var(--text);background:rgba(255,255,255,.02)}
.btn-ghost:hover{background:rgba(255,255,255,.07);transform:translateY(-3px)}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateY(3px)}

/* ---------- Glass ---------- */
.glass{
  background:var(--panel);
  backdrop-filter:blur(18px);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow);
}

/* ---------- Layout ---------- */
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(70px,11vh,140px) clamp(18px,4vw,40px)}
.section-head{max-width:760px;margin-bottom:54px}
.eyebrow{
  font-family:"Space Mono",monospace;font-size:.78rem;letter-spacing:.22em;
  color:var(--cyan);text-transform:uppercase;display:inline-block;margin-bottom:18px;
  padding:6px 14px;border:1px solid var(--line);border-radius:100px;background:rgba(56,224,255,.05);
}
.section-title{
  font-family:"Space Grotesk",sans-serif;font-weight:700;
  font-size:clamp(2rem,5vw,3.4rem);line-height:1.05;letter-spacing:-.02em;margin-bottom:18px;
}
.section-lede{font-size:clamp(1rem,2vw,1.18rem);color:var(--muted);max-width:62ch}
.section-foot{text-align:center;margin-top:50px;font-size:1.15rem;color:var(--muted);max-width:60ch;margin-left:auto;margin-right:auto}
.glow-text{
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 24px rgba(56,224,255,.35));
}

/* ---------- Hero ---------- */
.hero{
  min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:120px clamp(18px,4vw,40px) 80px;position:relative;
}
.hero-inner{max-width:880px}
.badge-pill{
  display:inline-flex;align-items:center;gap:10px;
  font-family:"Space Mono",monospace;font-size:.74rem;letter-spacing:.2em;
  padding:9px 18px;border:1px solid var(--line);border-radius:100px;
  color:var(--muted);background:rgba(255,255,255,.03);margin-bottom:34px;
}
.dot-live{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 12px var(--green);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.hero-title{
  font-family:"Space Grotesk",sans-serif;font-weight:700;
  font-size:clamp(3.4rem,15vw,10rem);line-height:.92;letter-spacing:-.03em;
  display:flex;gap:.18em;justify-content:center;flex-wrap:wrap;margin-bottom:30px;
}
.hero-sub{font-size:clamp(1.02rem,2.2vw,1.32rem);color:var(--muted);max-width:60ch;margin:0 auto 40px}
.hero-sub strong{color:var(--text);font-weight:600}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.scroll-hint{
  position:absolute;bottom:34px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:12px;
  font-family:"Space Mono",monospace;font-size:.68rem;letter-spacing:.3em;color:var(--dim);
}
.mouse{width:24px;height:38px;border:2px solid var(--dim);border-radius:14px;display:flex;justify-content:center;padding-top:7px}
.wheel{width:3px;height:7px;border-radius:3px;background:var(--cyan);animation:wheel 1.6s infinite}
@keyframes wheel{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}100%{opacity:0;transform:translateY(8px)}}

/* ---------- Stats ---------- */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:20px}
.stat{
  padding:32px 28px;border-radius:var(--r-md);
  background:var(--panel);backdrop-filter:blur(14px);border:1px solid var(--line);
  position:relative;overflow:hidden;transition:transform .4s var(--ease),border-color .4s;
}
.stat:hover{transform:translateY(-6px);border-color:rgba(56,224,255,.4)}
.stat::before{content:"";position:absolute;inset:0;background:var(--grad-soft);opacity:0;transition:opacity .4s}
.stat:hover::before{opacity:1}
.stat-num{font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:2.6rem;line-height:1;position:relative}
.stat-num .suffix{font-size:1.1rem;color:var(--cyan)}
.stat-label{margin-top:14px;font-weight:600;position:relative}
.stat-sub{color:var(--dim);font-size:.86rem;margin-top:4px;position:relative}

/* ---------- Drake ---------- */
.drake{display:grid;grid-template-columns:1.15fr .85fr;gap:34px;align-items:start}
.drake-controls{display:flex;flex-direction:column;gap:22px}
.drake-factor{}
.df-top{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:8px}
.df-symbol{font-family:"Space Grotesk";font-weight:700;color:var(--cyan);font-size:1.05rem;min-width:2.4em}
.df-name{font-weight:600;font-size:.95rem;flex:1}
.df-val{font-family:"Space Mono",monospace;color:var(--text);font-size:.9rem;background:rgba(56,224,255,.08);padding:3px 10px;border-radius:8px}
.df-desc{color:var(--dim);font-size:.82rem;margin-top:4px}
input[type=range]{
  -webkit-appearance:none;appearance:none;width:100%;height:5px;border-radius:6px;
  background:linear-gradient(90deg,var(--cyan),var(--violet));outline:none;margin-top:6px;cursor:pointer;
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:20px;height:20px;border-radius:50%;
  background:#fff;border:3px solid var(--violet);box-shadow:0 0 14px rgba(56,224,255,.7);cursor:pointer;transition:transform .15s;
}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}
input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid var(--violet);box-shadow:0 0 14px rgba(56,224,255,.7);cursor:pointer}
.drake-result{position:sticky;top:90px}
.drake-readout{padding:38px 30px;text-align:center}
.readout-label{font-size:.82rem;color:var(--muted);letter-spacing:.04em}
.readout-number{
  font-family:"Space Grotesk";font-weight:700;font-size:clamp(3rem,8vw,5rem);line-height:1;margin:14px 0;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 30px rgba(154,107,255,.45));
}
.readout-eq{font-family:"Space Mono",monospace;font-size:.8rem;color:var(--dim);letter-spacing:.05em}
.readout-verdict{margin-top:18px;font-size:.95rem;color:var(--muted);min-height:3em}

/* ---------- Timeline ---------- */
.timeline{position:relative;padding-left:0}
.timeline::before{
  content:"";position:absolute;left:124px;top:0;bottom:0;width:2px;
  background:linear-gradient(var(--cyan),var(--violet),transparent);opacity:.4;
}
.tl-item{position:relative;display:grid;grid-template-columns:96px 1fr;gap:56px;padding:18px 0 40px;}
.tl-year{
  font-family:"Space Grotesk";font-weight:700;font-size:1.4rem;text-align:right;
  color:var(--text);position:relative;padding-right:4px;letter-spacing:.01em;
}
.tl-dot{
  position:absolute;left:117px;top:22px;width:15px;height:15px;border-radius:50%;
  background:var(--bg);border:3px solid var(--cyan);box-shadow:0 0 0 5px rgba(56,224,255,.12);z-index:2;
  transition:transform .3s,box-shadow .3s;
}
.tl-item:hover .tl-dot{transform:scale(1.3);box-shadow:0 0 0 8px rgba(56,224,255,.2)}
.tl-card{
  padding:22px 26px;border-radius:var(--r-md);
  background:var(--panel);backdrop-filter:blur(12px);border:1px solid var(--line);
  transition:transform .35s var(--ease),border-color .35s;
}
.tl-card:hover{transform:translateX(8px);border-color:rgba(154,107,255,.4)}
.tl-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:8px}
.tl-title{font-family:"Space Grotesk";font-weight:600;font-size:1.18rem}
.tl-tag{font-family:"Space Mono",monospace;font-size:.66rem;letter-spacing:.12em;padding:3px 9px;border-radius:6px;background:rgba(154,107,255,.16);color:#cbb6ff;text-transform:uppercase}
.tl-flag{font-family:"Space Mono",monospace;font-size:.64rem;letter-spacing:.1em;color:var(--green);border:1px solid rgba(61,255,168,.4);padding:2px 8px;border-radius:6px}
.tl-text{color:var(--muted);font-size:.95rem}
.flag-inline{font-family:"Space Mono",monospace;font-size:.72rem;color:var(--green);border:1px solid rgba(61,255,168,.4);padding:1px 8px;border-radius:6px}

/* ---------- Evidence ---------- */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:34px}
.chip{
  font-family:"Inter";font-size:.85rem;font-weight:500;color:var(--muted);cursor:pointer;
  padding:9px 20px;border-radius:100px;border:1px solid var(--line);background:rgba(255,255,255,.02);
  transition:.25s var(--ease);
}
.chip:hover{color:var(--text);border-color:rgba(56,224,255,.4)}
.chip.is-active{background:var(--grad);color:#06070d;border-color:transparent;box-shadow:var(--glow-cyan)}
.evidence-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:20px}
.ev-card{
  position:relative;border-radius:var(--r-md);overflow:hidden;cursor:pointer;
  background:var(--panel);backdrop-filter:blur(12px);border:1px solid var(--line);
  padding:26px 24px;transition:transform .4s var(--ease),border-color .4s,box-shadow .4s;
  display:flex;flex-direction:column;min-height:230px;
}
.ev-card:hover{transform:translateY(-7px);border-color:rgba(56,224,255,.45);box-shadow:0 30px 60px -25px rgba(56,224,255,.3)}
.ev-card.open{min-height:auto}
.ev-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.ev-icon{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--grad-soft);border:1px solid var(--line)}
.ev-icon svg{width:24px;height:24px;stroke:var(--cyan);fill:none;stroke-width:1.6}
.ev-cat{font-family:"Space Mono",monospace;font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dim)}
.ev-title{font-family:"Space Grotesk";font-weight:600;font-size:1.22rem;margin-bottom:10px}
.ev-summary{color:var(--muted);font-size:.92rem;flex:1}
.ev-detail{
  max-height:0;overflow:hidden;opacity:0;color:var(--muted);font-size:.9rem;
  transition:max-height .5s var(--ease),opacity .4s,margin .4s;border-top:1px solid transparent;
}
.ev-card.open .ev-detail{max-height:460px;opacity:1;margin-top:16px;padding-top:16px;border-top-color:var(--line)}
.ev-more{margin-top:16px;font-family:"Space Mono",monospace;font-size:.72rem;letter-spacing:.1em;color:var(--cyan);display:flex;align-items:center;gap:6px}
.ev-more .plus{transition:transform .3s}
.ev-card.open .ev-more .plus{transform:rotate(45deg)}
.cred{font-family:"Space Mono",monospace;font-size:.62rem;letter-spacing:.1em;padding:3px 9px;border-radius:6px;text-transform:uppercase}
.cred.onrecord{background:rgba(61,255,168,.14);color:var(--green);border:1px solid rgba(61,255,168,.35)}
.cred.unverified{background:rgba(255,180,84,.14);color:var(--amber);border:1px solid rgba(255,180,84,.35)}

/* ---------- Players ---------- */
.players{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.player{
  padding:24px;border-radius:var(--r-md);background:var(--panel);backdrop-filter:blur(12px);
  border:1px solid var(--line);transition:transform .35s var(--ease),border-color .35s;
}
.player:hover{transform:translateY(-5px);border-color:rgba(154,107,255,.45)}
.player-abbr{font-family:"Space Grotesk";font-weight:700;font-size:1.5rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.player-years{font-family:"Space Mono",monospace;font-size:.72rem;color:var(--dim);margin:4px 0 12px}
.player-name{font-weight:600;font-size:.92rem;margin-bottom:8px}
.player-note{color:var(--muted);font-size:.85rem}

/* ---------- Balance scale ---------- */
.scale-wrap{max-width:540px;margin:0 auto 54px;text-align:center}
.scale-labels{display:flex;justify-content:space-between;font-family:"Space Mono",monospace;font-size:.78rem;letter-spacing:.1em;color:var(--muted);margin-bottom:14px}
.scale-slider{height:6px}
.scale-beam{
  height:8px;margin-top:26px;border-radius:8px;position:relative;
  background:linear-gradient(90deg,var(--amber),var(--cyan));
  transform-origin:center;transition:transform .15s ease-out;
}
.scale-beam::before{content:"▲";position:absolute;left:50%;top:-22px;transform:translateX(-50%);color:var(--text)}
.balance-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.balance-col{padding:30px 28px;border-radius:var(--r-lg);background:var(--panel);backdrop-filter:blur(12px);border:1px solid var(--line)}
.col-for{border-top:3px solid var(--green)}
.col-against{border-top:3px solid var(--amber)}
.balance-col h3{font-family:"Space Grotesk";font-size:1.3rem;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.col-for .tick{color:var(--green)}
.col-against .tick{color:var(--amber)}
.balance-col li{padding:16px 0;border-top:1px solid var(--line)}
.balance-col li:first-of-type{border-top:0}
.bal-title{font-weight:600;margin-bottom:4px}
.bal-text{color:var(--muted);font-size:.9rem}

/* ---------- Classified block ---------- */
.classified{position:relative;padding:clamp(34px,6vw,64px);overflow:hidden}
.classified::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,.015) 0 1px,transparent 1px 3px);
}
.classified p{color:var(--muted);max-width:70ch;margin-top:16px}
.classified p strong{color:var(--text)}
.stamp{
  position:absolute;top:30px;right:-46px;transform:rotate(14deg);
  font-family:"Space Mono",monospace;font-weight:700;letter-spacing:.2em;font-size:1.1rem;
  color:rgba(255,92,92,.85);border:3px solid rgba(255,92,92,.7);padding:8px 60px;border-radius:6px;
  opacity:.55;
}
.redacted{
  background:var(--text);color:transparent;border-radius:3px;padding:0 4px;cursor:pointer;
  transition:.35s var(--ease);user-select:none;
}
.redacted:hover,.redacted:focus,.redacted.revealed{background:rgba(56,224,255,.14);color:var(--cyan);outline:none}
.fine-print{font-size:.85rem;color:var(--dim);border-left:3px solid var(--amber);padding-left:16px;margin-top:28px!important}

/* ---------- Verdict ---------- */
.verdict-card{max-width:620px;margin:0 auto;padding:clamp(34px,5vw,52px);text-align:center}
.belief-readout{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:26px}
.belief-emoji{font-size:3.4rem;line-height:1;transition:transform .3s var(--ease)}
.belief-text{font-family:"Space Grotesk";font-weight:600;font-size:1.5rem}
.belief-slider{height:7px}
.belief-scale{display:flex;justify-content:space-between;font-family:"Space Mono",monospace;font-size:.72rem;color:var(--dim);margin-top:14px;letter-spacing:.05em}
.btn-vote{margin-top:34px}
.tally{margin-top:34px;animation:fadein .5s var(--ease)}
@keyframes fadein{from{opacity:0;transform:translateY(10px)}to{opacity:1}}
.tally-head{color:var(--muted);font-size:.92rem;margin-bottom:14px}
.tally-head span{color:var(--cyan);font-weight:700}
.tally-bar{position:relative;height:34px;border-radius:100px;background:rgba(255,255,255,.06);overflow:hidden;border:1px solid var(--line)}
.tally-fill{height:100%;width:50%;background:var(--grad);transition:width 1s var(--ease)}
.tally-pct{position:absolute;top:50%;left:14px;transform:translateY(-50%);font-family:"Space Grotesk";font-weight:700;font-size:.95rem;color:#06070d}
.tally-sub{color:var(--dim);font-size:.82rem;margin-top:10px}

/* ---------- Footer ---------- */
.footer{border-top:1px solid var(--line);margin-top:60px;padding:64px clamp(18px,4vw,40px) 30px;background:rgba(6,7,12,.6);backdrop-filter:blur(10px)}
.footer-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr 1.2fr;gap:40px}
.footer-brand .brand-mark{font-size:1.6rem}
.footer-brand .brand-text{font-family:"Space Grotesk";font-weight:700;letter-spacing:.18em;margin-left:8px}
.footer-tag{color:var(--muted);margin-top:14px;font-size:.92rem}
.footer h4{font-family:"Space Grotesk";font-size:.95rem;margin-bottom:16px;color:var(--text)}
.footer-sources li{color:var(--muted);font-size:.85rem;padding:7px 0;border-bottom:1px solid var(--line)}
.footer-sources li a{color:var(--muted);transition:color .25s}
.footer-sources li a:hover{color:var(--cyan)}
.footer-sources li span{display:block;color:var(--dim);font-size:.74rem;margin-top:2px}
.footer-note p{color:var(--muted);font-size:.86rem}
.footer-note strong{color:var(--text)}
.footer-bar{max-width:var(--maxw);margin:40px auto 0;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-family:"Space Mono",monospace;font-size:.74rem;color:var(--dim)}

/* ---------- Sub-head ---------- */
.sub-head{font-family:"Space Grotesk";font-weight:600;font-size:1.5rem;margin:60px 0 24px;letter-spacing:-.01em}

/* ---------- Flags ---------- */
.flag-unv{font-family:"Space Mono",monospace;font-size:.72rem;color:var(--amber);border:1px solid rgba(255,180,84,.4);padding:1px 8px;border-radius:6px}

/* ---------- Video gallery ---------- */
.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.video-card{
  position:relative;border-radius:var(--r-md);overflow:hidden;cursor:pointer;text-align:left;
  border:1px solid var(--line);background:var(--panel);backdrop-filter:blur(12px);
  transition:transform .4s var(--ease),border-color .4s,box-shadow .4s;display:flex;flex-direction:column;
}
.video-card:hover{transform:translateY(-7px);border-color:rgba(56,224,255,.5);box-shadow:0 30px 60px -25px rgba(56,224,255,.3)}
.video-thumb{
  position:relative;aspect-ratio:16/9;overflow:hidden;
  background:
    radial-gradient(60% 80% at 30% 20%, rgba(56,224,255,.25), transparent 60%),
    radial-gradient(70% 90% at 80% 80%, rgba(154,107,255,.3), transparent 60%),
    linear-gradient(135deg,#0a0e1f,#11152b);
}
.video-thumb::after{
  content:"";position:absolute;inset:0;opacity:.5;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,.04) 0 1px,transparent 1px 3px);
}
.video-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.play-btn{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:64px;height:64px;border-radius:50%;display:grid;place-items:center;z-index:2;
  background:rgba(5,6,10,.55);border:1px solid rgba(255,255,255,.5);backdrop-filter:blur(4px);
  transition:transform .3s var(--ease),background .3s;
}
.play-btn::before{content:"";width:0;height:0;border-left:18px solid #fff;border-top:11px solid transparent;border-bottom:11px solid transparent;margin-left:5px}
.video-card:hover .play-btn{transform:translate(-50%,-50%) scale(1.12);background:rgba(56,224,255,.3)}
.video-badge{
  position:absolute;top:12px;left:12px;z-index:2;font-family:"Space Mono",monospace;font-size:.62rem;
  letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:6px;
  background:rgba(5,6,10,.7);border:1px solid var(--line);color:var(--cyan);
}
.video-badge.ext{color:var(--amber)}
.video-len{position:absolute;bottom:12px;right:12px;z-index:2;font-family:"Space Mono",monospace;font-size:.66rem;padding:3px 9px;border-radius:6px;background:rgba(5,6,10,.7);color:var(--text)}
.link-thumb{display:grid;place-items:center;
  background:
    radial-gradient(60% 80% at 72% 18%, rgba(255,180,84,.20), transparent 60%),
    radial-gradient(70% 90% at 18% 92%, rgba(154,107,255,.30), transparent 60%),
    linear-gradient(135deg,#0a0e1f,#11152b);}
.link-thumb .vt-glyph{font-size:3.3rem;z-index:1;opacity:.95;filter:drop-shadow(0 8px 20px rgba(0,0,0,.55))}
.link-thumb .vt-wm{position:absolute;left:14px;bottom:12px;z-index:2;max-width:62%;
  font-family:"Space Mono",monospace;font-size:.6rem;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;line-height:1.3}
.play-btn.ext::before{content:"↗";width:auto;height:auto;border:0;margin:0;font-size:1.7rem;line-height:1;color:#fff}
/* keep the official-source glyph fully visible; relocate the ↗ badge to a corner so it never covers it */
.link-thumb .vt-glyph{z-index:3;font-size:3.7rem;opacity:1}
.link-thumb .play-btn.ext{left:auto;right:12px;top:12px;bottom:auto;width:34px;height:34px;transform:none;background:rgba(5,6,10,.6)}
.link-thumb .play-btn.ext::before{font-size:1.05rem}
.video-card:hover .link-thumb .play-btn.ext{transform:scale(1.12);background:rgba(56,224,255,.3)}
.video-meta{padding:18px 20px}
.video-title{font-family:"Space Grotesk";font-weight:600;font-size:1.08rem;margin-bottom:6px;display:flex;gap:8px;align-items:baseline}
.video-org{font-family:"Space Mono",monospace;font-size:.68rem;color:var(--dim);letter-spacing:.04em}
.video-blurb{color:var(--muted);font-size:.88rem;margin-top:8px}

/* ---------- Video modal ---------- */
.modal{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:24px}
.modal[hidden]{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(2,3,6,.86);backdrop-filter:blur(8px);animation:fadein .3s}
.modal-box{position:relative;z-index:2;width:min(960px,100%);animation:popin .4s var(--ease)}
@keyframes popin{from{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:none}}
.modal-frame{position:relative;aspect-ratio:16/9;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#000}
.modal-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.modal-cap{color:var(--muted);font-size:.88rem;margin-top:14px;text-align:center}
.modal-close{
  position:absolute;top:-14px;right:-10px;z-index:5;width:42px;height:42px;border-radius:50%;
  background:var(--grad);color:#06070d;border:0;font-size:1.1rem;cursor:pointer;box-shadow:var(--glow-cyan);
  transition:transform .25s var(--ease);
}
.modal-close:hover{transform:rotate(90deg) scale(1.1)}

/* ---------- Case files ---------- */
.case-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.case-card{
  position:relative;border-radius:var(--r-md);overflow:hidden;cursor:pointer;
  border:1px solid var(--line);background:var(--panel);backdrop-filter:blur(12px);
  padding:24px;transition:transform .4s var(--ease),border-color .4s,box-shadow .4s;
  display:flex;flex-direction:column;
}
.case-card.featured{grid-column:span 2}
.case-card:hover{transform:translateY(-7px);border-color:rgba(154,107,255,.5);box-shadow:0 30px 60px -25px rgba(154,107,255,.3)}
.case-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px}
.case-code{font-family:"Space Mono",monospace;font-size:.64rem;letter-spacing:.12em;color:var(--cyan);background:rgba(56,224,255,.08);padding:4px 10px;border-radius:6px}
.case-flag{font-size:1.4rem;line-height:1}
.case-name{font-family:"Space Grotesk";font-weight:600;font-size:1.3rem;margin-bottom:8px}
.case-line{display:flex;flex-wrap:wrap;gap:8px 16px;font-family:"Space Mono",monospace;font-size:.7rem;color:var(--dim);margin-bottom:14px}
.case-line b{color:var(--muted);font-weight:400}
.case-blurb{color:var(--muted);font-size:.92rem;flex:1}
.case-detail{max-height:0;overflow:hidden;opacity:0;color:var(--muted);font-size:.9rem;transition:max-height .55s var(--ease),opacity .4s,margin .4s}
.case-card.open .case-detail{max-height:520px;opacity:1;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.case-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:16px;flex-wrap:wrap}
.case-status{font-family:"Space Mono",monospace;font-size:.66rem;letter-spacing:.08em;color:var(--green);border:1px solid rgba(61,255,168,.3);padding:3px 10px;border-radius:6px}
.case-status.disp{color:var(--amber);border-color:rgba(255,180,84,.3)}
.case-src{font-family:"Space Mono",monospace;font-size:.7rem;color:var(--cyan);display:inline-flex;align-items:center;gap:6px}
.case-src:hover{text-decoration:underline}
.case-more{margin-top:14px;font-family:"Space Mono",monospace;font-size:.7rem;letter-spacing:.1em;color:var(--violet)}
.case-card.open .case-more .plus{transform:rotate(45deg)}
.case-more .plus{display:inline-block;transition:transform .3s}

/* ---------- Accounts / quotes ---------- */
.accounts{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:20px}
.account{
  position:relative;padding:30px 28px 26px;border-radius:var(--r-md);
  border:1px solid var(--line);background:var(--panel);backdrop-filter:blur(12px);
  transition:transform .35s var(--ease),border-color .35s;display:flex;flex-direction:column;
}
.account:hover{transform:translateY(-5px);border-color:rgba(56,224,255,.4)}
.account.unv{border-left:3px solid var(--amber)}
.account.rec{border-left:3px solid var(--green)}
.account-quote{font-family:"Space Grotesk";font-weight:500;font-size:1.12rem;line-height:1.5;margin-bottom:18px;position:relative;padding-left:22px}
.account-quote::before{content:"\201C";position:absolute;left:-4px;top:-10px;font-size:2.6rem;color:var(--violet);opacity:.6;font-family:Georgia,serif}
.account-name{font-family:"Space Grotesk";font-weight:600;font-size:1rem}
.account-role{color:var(--dim);font-size:.8rem;margin:2px 0 12px}
.account-context{color:var(--muted);font-size:.85rem;flex:1}
.account-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:16px;flex-wrap:wrap}
.account-src{font-family:"Space Mono",monospace;font-size:.68rem;color:var(--cyan)}
.account-src:hover{text-decoration:underline}

/* ---------- Document archive ---------- */
.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.doc-card{
  position:relative;display:flex;flex-direction:column;padding:24px;border-radius:var(--r-md);
  border:1px solid var(--line);background:var(--panel);backdrop-filter:blur(12px);
  transition:transform .35s var(--ease),border-color .35s;overflow:hidden;cursor:pointer;
}
.doc-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad);opacity:.7}
.doc-card:hover{transform:translateY(-6px);border-color:rgba(56,224,255,.45)}
.doc-type{align-self:flex-start;font-family:"Space Mono",monospace;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;padding:4px 10px;border-radius:6px;background:rgba(154,107,255,.16);color:#cbb6ff;margin-bottom:14px}
.doc-title{font-family:"Space Grotesk";font-weight:600;font-size:1.12rem;margin-bottom:4px}
.doc-org{font-family:"Space Mono",monospace;font-size:.68rem;color:var(--dim);margin-bottom:12px}
.doc-org b{color:var(--cyan);font-weight:400}
.doc-blurb{color:var(--muted);font-size:.86rem;flex:1;margin-bottom:18px}
.doc-link{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.86rem;color:var(--cyan);align-self:flex-start}
.doc-link .ext-arr{transition:transform .25s}
.doc-card:hover .doc-link .ext-arr{transform:translate(3px,-3px)}

/* ---------- Imagery gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.gtile{
  position:relative;display:block;aspect-ratio:4/3;border-radius:var(--r-md);overflow:hidden;
  border:1px solid var(--line);background:linear-gradient(135deg,#0a0e1f,#141833);
  transition:transform .35s var(--ease),border-color .35s;
}
.gtile:hover{transform:translateY(-5px);border-color:rgba(56,224,255,.5)}
.gtile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:1}
.gtile-glyph{position:absolute;inset:0;display:grid;place-items:center;font-size:3rem;opacity:.85}
.gtile-cap{
  position:absolute;left:0;right:0;bottom:0;padding:14px 14px 12px;z-index:2;
  background:linear-gradient(transparent,rgba(4,5,10,.92));
}
.gtile-cap b{display:block;font-size:.82rem;font-weight:600}
.gtile-cap span{font-family:"Space Mono",monospace;font-size:.64rem;color:var(--dim)}

/* ---------- Documentary shelf ---------- */
.doc-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px}
.film-card{--fc:var(--cyan);position:relative;display:flex;flex-direction:column;border-radius:var(--r-md);overflow:hidden;
  border:1px solid var(--line);background:var(--panel);backdrop-filter:blur(12px);
  transition:transform .4s var(--ease),border-color .4s,box-shadow .4s}
.film-card:hover{transform:translateY(-7px);border-color:color-mix(in srgb,var(--fc) 55%,transparent);
  box-shadow:0 30px 60px -28px color-mix(in srgb,var(--fc) 45%,transparent)}
.film-cyan{--fc:var(--cyan)} .film-violet{--fc:var(--violet)} .film-magenta{--fc:var(--magenta)} .film-green{--fc:var(--green)} .film-amber{--fc:var(--amber)}
.film-poster{position:relative;aspect-ratio:16/10;display:grid;place-items:center;overflow:hidden;border-bottom:1px solid var(--line);
  background:radial-gradient(80% 90% at 50% 28%, color-mix(in srgb,var(--fc) 24%,transparent), transparent 62%),linear-gradient(150deg,#0a0e1f,#10142a)}
.film-poster::after{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,.04) 0 1px,transparent 1px 3px)}
.film-glyph{font-size:3.7rem;z-index:1;transition:transform .4s var(--ease);
  filter:drop-shadow(0 0 14px color-mix(in srgb,var(--fc) 70%,transparent)) drop-shadow(0 8px 18px rgba(0,0,0,.5))}
.film-card:hover .film-glyph{transform:scale(1.12)}
.film-lens{position:absolute;top:12px;left:12px;z-index:2;font-family:"Space Mono",monospace;font-size:.56rem;
  letter-spacing:.08em;text-transform:uppercase;padding:4px 9px;border-radius:6px;background:rgba(5,6,10,.72);
  border:1px solid color-mix(in srgb,var(--fc) 45%,transparent);color:var(--fc)}
.film-runtime{position:absolute;bottom:12px;right:12px;z-index:2;font-family:"Space Mono",monospace;font-size:.64rem;
  padding:3px 9px;border-radius:6px;background:rgba(5,6,10,.72);color:var(--text)}
.film-meta{padding:18px 20px;display:flex;flex-direction:column;flex:1}
.film-title{font-family:"Space Grotesk";font-weight:600;font-size:1.08rem;line-height:1.25}
.film-sub{font-family:"Space Mono",monospace;font-size:.68rem;color:var(--dim);margin:5px 0 12px}
.film-blurb{color:var(--muted);font-size:.87rem;line-height:1.55;flex:1}
.film-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:16px;flex-wrap:wrap}
.film-where{font-family:"Space Mono",monospace;font-size:.64rem;letter-spacing:.03em;color:var(--fc)}
.film-src{font-family:"Space Mono",monospace;font-size:.66rem;color:var(--muted);transition:color .3s}
.film-card:hover .film-src{color:var(--fc)}

/* ---------- World map / hotspots ---------- */
.map-wrap{display:grid;grid-template-columns:1.55fr .85fr;gap:22px;align-items:stretch}
.map-stage{
  position:relative;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;min-height:300px;
  background:radial-gradient(120% 120% at 50% 0%,rgba(56,224,255,.07),transparent 60%),linear-gradient(160deg,#070b18,#0b1024);
}
.world-map{display:block;width:100%;height:100%}
.world-map .map-bg{fill:transparent}
.world-map .graticule line{stroke:rgba(120,150,255,.10);stroke-width:.3}
.world-map .equator{stroke:rgba(56,224,255,.30);stroke-width:.4;stroke-dasharray:2 2}
.world-map .land{
  fill:rgba(80,120,200,.10);stroke:rgba(120,170,255,.45);stroke-width:.5;
  filter:drop-shadow(0 0 2px rgba(56,224,255,.25));transition:fill .4s;
}
.map-stage:hover .world-map .land{fill:rgba(90,140,230,.16)}
.map-pin{cursor:pointer}
.map-pin .pin-core{fill:var(--magenta);filter:drop-shadow(0 0 3px var(--magenta));transition:fill .25s}
.map-pin .pin-pulse{fill:rgba(255,92,219,.55);transform-origin:center;transform-box:fill-box;animation:pinpulse 2.6s ease-out infinite}
.map-pin:hover .pin-core,.map-pin.active .pin-core{fill:var(--cyan);filter:drop-shadow(0 0 6px var(--cyan));r:2}
.map-pin.active .pin-pulse{fill:rgba(56,224,255,.6)}
.map-pin:focus{outline:none}
.map-pin:focus .pin-core{stroke:#fff;stroke-width:.5}
@keyframes pinpulse{0%{r:1.6;opacity:.85}70%{r:6;opacity:0}100%{r:6;opacity:0}}
.map-sweep{
  position:absolute;left:50%;top:50%;width:150%;aspect-ratio:1;border-radius:50%;
  transform:translate(-50%,-50%);transform-origin:50% 50%;
  pointer-events:none;mix-blend-mode:screen;
  background:conic-gradient(from 0deg at 50% 50%,
    rgba(56,224,255,.42),
    rgba(56,224,255,.10) 14deg,
    rgba(56,224,255,0) 62deg,
    rgba(56,224,255,0) 360deg);
  animation:sweep 7s linear infinite;
}
@keyframes sweep{to{transform:translate(-50%,-50%) rotate(360deg)}}
.map-legend{
  position:absolute;left:14px;bottom:12px;display:flex;align-items:center;gap:8px;
  font-family:"Space Mono",monospace;font-size:.62rem;letter-spacing:.08em;color:var(--muted);
  background:rgba(4,6,12,.6);padding:6px 11px;border-radius:100px;border:1px solid var(--line);backdrop-filter:blur(6px);
}
.lg-dot{width:8px;height:8px;border-radius:50%;background:var(--magenta);box-shadow:0 0 8px var(--magenta)}
.map-info{
  border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;
  background:var(--panel);backdrop-filter:blur(14px);display:flex;flex-direction:column;min-height:300px;
}
.map-info:empty::before{content:"Select a beacon to open its file.";color:var(--dim);font-size:.9rem;margin:auto}
.mi-code{font-family:"Space Mono",monospace;font-size:.62rem;letter-spacing:.14em;color:var(--cyan)}
.mi-flag{font-size:1.8rem;margin:6px 0;animation:fadeUp .5s var(--ease)}
.mi-name{font-family:"Space Grotesk";font-size:1.3rem;margin-bottom:8px;animation:fadeUp .5s var(--ease)}
.mi-line{font-size:.82rem;color:var(--muted);margin-bottom:12px}
.mi-line b{color:var(--text)}
.mi-status{
  align-self:flex-start;font-family:"Space Mono",monospace;font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;
  padding:4px 10px;border-radius:6px;background:rgba(61,255,168,.14);color:var(--green);margin-bottom:14px;
}
.mi-status.disp{background:rgba(255,180,84,.14);color:var(--amber)}
.mi-blurb{color:var(--muted);font-size:.9rem;flex:1;margin-bottom:16px}
.mi-src{font-weight:600;font-size:.84rem;color:var(--cyan);align-self:flex-start}
.mi-src:hover{text-decoration:underline}
.world-map .range-ring{fill:none;stroke:rgba(56,224,255,.12);stroke-width:.3}
.world-map .radar-cross{stroke:rgba(56,224,255,.14);stroke-width:.3}
.world-map .island{fill:rgba(82,124,205,.12);stroke:rgba(120,170,255,.42);stroke-width:.4}
.world-map .arc-line{fill:none;stroke:rgba(154,107,255,.40);stroke-width:.45;stroke-dasharray:2.5 2.5;opacity:.7}
.world-map .arc-pulse{fill:var(--cyan);filter:drop-shadow(0 0 3px var(--cyan))}

/* ---------- The SCIF ---------- */
.scif{position:relative;padding:0;overflow:hidden}
.scif-gate{position:relative;min-height:430px;display:grid;place-items:center;overflow:hidden}
.gate-door{
  position:absolute;top:0;bottom:0;width:50.5%;z-index:1;transition:transform 1s var(--ease);
  background:linear-gradient(160deg,#10162c,#0a0e1d);
}
.gate-door::before{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(90deg,transparent,transparent 38px,rgba(56,224,255,.06) 39px,transparent 40px);
}
.gate-l{left:0;border-right:1px solid rgba(56,224,255,.22)}
.gate-r{right:0;border-left:1px solid rgba(56,224,255,.22)}
.scif-gate.open .gate-l{transform:translateX(-101%)}
.scif-gate.open .gate-r{transform:translateX(101%)}
.scif-gate.open .gate-panel{opacity:0;transition:opacity .5s}
.gate-panel{position:relative;z-index:2;text-align:center;padding:42px 24px;max-width:540px}
.gate-seal{font-size:3rem;color:var(--cyan);filter:drop-shadow(0 0 14px rgba(56,224,255,.6));display:inline-block;animation:spin 18s linear infinite}
.gate-title{font-family:"Space Grotesk";font-weight:700;font-size:clamp(1.3rem,3.6vw,1.7rem);letter-spacing:.2em;margin:14px 0 6px}
.gate-sub{font-family:"Space Mono",monospace;font-size:.7rem;letter-spacing:.16em;color:var(--amber);text-transform:uppercase;margin-bottom:26px}
.gate-btn{margin-bottom:18px}
.scif-term{font-family:"Space Mono",monospace;font-size:.74rem;color:var(--green);min-height:1.3em;text-align:left;line-height:1.75;text-shadow:0 0 8px rgba(61,255,168,.5)}

.scif-vault{padding:28px clamp(16px,3vw,32px) 34px}
.scif-vault.in{animation:fadeUp .6s var(--ease)}
.vault-brief{
  border:1px solid rgba(61,255,168,.22);border-radius:var(--r-md);overflow:hidden;margin-bottom:28px;
  background:linear-gradient(160deg,rgba(8,18,14,.7),rgba(6,10,18,.7));
}
.brief-head{
  display:flex;align-items:center;gap:8px;padding:10px 16px;background:rgba(61,255,168,.05);
  border-bottom:1px solid rgba(61,255,168,.18);
  font-family:"Space Mono",monospace;font-size:.66rem;letter-spacing:.14em;color:var(--green);
}
.brief-led{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:blink 1.4s steps(1) infinite}
@keyframes blink{50%{opacity:.25}}
.brief-body{
  font-family:"Space Mono",monospace;font-size:.76rem;line-height:1.75;color:#bdf5d8;
  padding:16px;white-space:pre-wrap;word-break:break-word;min-height:120px;margin:0;
}
.vault-hint{color:var(--muted);font-size:.88rem;margin-bottom:18px}
.redact-inline{font-family:"Space Mono",monospace;font-size:.74rem;background:#05070d;color:#05070d;border-radius:3px;padding:1px 6px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}

.redact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:18px}
.redact-doc{
  position:relative;display:flex;flex-direction:column;overflow:hidden;
  background:#0c0f1d;border:1px solid var(--line);border-radius:var(--r-md);padding:0 0 18px;
}
.rd-banner{
  background:repeating-linear-gradient(45deg,#7a0d12,#7a0d12 12px,#5e0a0e 12px,#5e0a0e 24px);
  color:#fff;text-align:center;padding:7px;text-transform:uppercase;
  font-family:"Space Mono",monospace;font-weight:700;font-size:.7rem;letter-spacing:.22em;
}
.rd-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;padding:14px 16px 6px}
.rd-code{font-family:"Space Mono",monospace;font-size:.58rem;letter-spacing:.1em;color:var(--cyan)}
.rd-agency{font-family:"Space Grotesk";font-size:.78rem;color:var(--muted);text-align:right}
.rd-meta{padding:6px 16px 10px;display:grid;gap:5px;border-bottom:1px dashed var(--line);margin-bottom:10px}
.rd-meta>div{display:grid;grid-template-columns:48px 1fr;gap:8px;font-size:.78rem}
.rd-meta dt{font-family:"Space Mono",monospace;font-size:.58rem;color:var(--dim);letter-spacing:.1em;padding-top:3px}
.rd-meta dd{color:var(--text)}
.rd-body{padding:0 16px;font-size:.82rem;color:#c7cdf0;line-height:1.65;flex:1}
.rd-body p{margin-bottom:10px}
.redact{
  position:relative;display:inline;background:#05070d;color:transparent;border-radius:3px;padding:0 5px;cursor:pointer;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);transition:color .35s,background .35s;-webkit-user-select:none;user-select:none;
}
.redact::after{
  content:"";position:absolute;inset:0;border-radius:3px;transition:opacity .35s;
  background:repeating-linear-gradient(90deg,#000,#000 3px,#15161f 3px,#15161f 4px);
}
.redact:hover{box-shadow:inset 0 0 0 1px rgba(56,224,255,.55)}
.redact.lifted{color:var(--amber);background:rgba(255,180,84,.12)}
.redact.lifted::after{opacity:0}
.rd-declass{
  margin:14px 16px 6px;align-self:flex-start;cursor:pointer;
  font-family:"Space Mono",monospace;font-size:.66rem;letter-spacing:.1em;color:var(--cyan);
  background:rgba(56,224,255,.08);border:1px solid rgba(56,224,255,.3);padding:8px 14px;border-radius:8px;transition:background .25s;
}
.rd-declass:hover{background:rgba(56,224,255,.16)}
.rd-declass:disabled{color:var(--green);border-color:rgba(61,255,168,.3);background:rgba(61,255,168,.08);cursor:default}
.rd-foot{padding:6px 16px 0;display:flex;flex-direction:column;gap:6px}
.rd-note{font-size:.66rem;color:var(--dim);font-style:italic;line-height:1.5}
.rd-src{font-size:.74rem;font-weight:600;color:var(--cyan)}
.rd-src:hover{text-decoration:underline}

/* ---------- Ambient audio toggle ---------- */
.audio-toggle{
  position:fixed;right:18px;bottom:18px;z-index:80;display:inline-flex;align-items:center;gap:9px;cursor:pointer;
  padding:10px 16px;border-radius:100px;color:var(--muted);
  background:rgba(7,9,16,.7);border:1px solid var(--line);backdrop-filter:blur(12px);
  font-family:"Space Mono",monospace;font-size:.64rem;letter-spacing:.14em;
  transition:color .25s,border-color .25s,box-shadow .25s;
}
.audio-toggle:hover{color:var(--text);border-color:rgba(56,224,255,.5)}
.audio-toggle.on{color:var(--cyan);border-color:rgba(56,224,255,.5);box-shadow:0 0 26px -6px rgba(56,224,255,.6)}
.audio-toggle .eq{display:flex;align-items:flex-end;gap:2px;height:14px}
.audio-toggle .eq i{width:3px;height:4px;background:currentColor;border-radius:2px}
.audio-toggle.on .eq i{animation:eq 1s ease-in-out infinite}
.audio-toggle.on .eq i:nth-child(2){animation-delay:.2s}
.audio-toggle.on .eq i:nth-child(3){animation-delay:.4s}
.audio-toggle.on .eq i:nth-child(4){animation-delay:.15s}
@keyframes eq{0%,100%{height:4px}50%{height:14px}}
.audio-toggle.music{bottom:70px}
.audio-toggle.music.on{color:var(--amber);border-color:rgba(255,180,84,.5);box-shadow:0 0 26px -6px rgba(255,180,84,.6)}
.audio-toggle .note{font-size:.98rem;line-height:1;display:inline-block;width:14px;text-align:center}
.audio-toggle.music.on .note{animation:notepulse 1.05s ease-in-out infinite}
@keyframes notepulse{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(-2px);opacity:.55}}

/* ---------- Geiger reading (hover in the SCIF) ---------- */
.redact.rd-geiger{cursor:help}
.geiger-active{animation:geigerflick .1s steps(2) infinite}
@keyframes geigerflick{0%{filter:none}50%{filter:brightness(1.7) drop-shadow(0 0 5px var(--green))}100%{filter:none}}

/* ---------- Into the Weird (fringe flip cards) ---------- */
.fringe-tagline{margin-top:14px;font-family:"Space Mono",monospace;font-size:.84rem;letter-spacing:.06em;color:var(--green);opacity:.85}
.fringe-tagline em{color:var(--cyan);font-style:italic}
.fringe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px;margin-top:30px}
.fringe-card{position:relative;perspective:1500px;cursor:pointer;border-radius:var(--r-md)}
.fringe-card:focus{outline:none}
.fc-inner{position:relative;transform-style:preserve-3d;transition:transform .8s var(--ease)}
.fringe-card.flip .fc-inner{transform:rotateY(180deg)}
.fc-face{display:flex;flex-direction:column;gap:12px;padding:22px;border-radius:var(--r-md);
  border:1px solid var(--line);background:var(--panel);backdrop-filter:blur(12px);
  -webkit-backface-visibility:hidden;backface-visibility:hidden}
.fc-back{position:relative;min-height:300px;transform:rotateY(180deg);
  background:linear-gradient(165deg,rgba(9,12,20,.97),rgba(7,9,16,.97))}
.fc-front{position:absolute;inset:0}
.fringe-card:focus-visible .fc-face{box-shadow:0 0 0 2px var(--cyan)}
.fringe-card:hover .fc-front{border-color:rgba(154,107,255,.45);box-shadow:0 20px 50px -28px rgba(154,107,255,.6)}
.fc-back::after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:var(--r-md);
  background:repeating-linear-gradient(0deg,transparent 0 2px,rgba(0,0,0,.18) 2px 3px);mix-blend-mode:overlay}
.fc-top{display:flex;align-items:center;justify-content:space-between}
.fc-glyph{font-size:2rem;line-height:1}
.weird{letter-spacing:3px;font-size:.82rem;color:var(--amber)}
.fringe-card[data-tier="documented"] .weird{color:var(--green)}
.fringe-card[data-tier="anomaly"] .weird{color:var(--cyan)}
.fringe-card[data-tier="fringe"] .weird{color:var(--violet)}
.fringe-card[data-tier="myth"] .weird{color:var(--magenta)}
.tier-badge{align-self:flex-start;font-family:"Space Mono",monospace;font-size:.6rem;letter-spacing:.14em;
  text-transform:uppercase;padding:4px 10px;border-radius:999px;border:1px solid currentColor}
.tier-documented{color:var(--green);background:rgba(61,255,168,.08)}
.tier-anomaly{color:var(--cyan);background:rgba(56,224,255,.08)}
.tier-fringe{color:var(--violet);background:rgba(154,107,255,.08)}
.tier-unverified{color:var(--amber);background:rgba(255,180,84,.08)}
.tier-myth{color:var(--magenta);background:rgba(255,92,219,.08)}
.fc-title{font-family:"Space Grotesk",sans-serif;font-weight:600;font-size:1.16rem;line-height:1.22}
.fc-hook{color:var(--muted);font-size:.93rem;line-height:1.55}
.fc-cue{margin-top:auto;font-family:"Space Mono",monospace;font-size:.64rem;letter-spacing:.12em;color:var(--dim);text-transform:uppercase}
.fc-back-label{font-family:"Space Mono",monospace;font-size:.64rem;letter-spacing:.2em;color:var(--green);text-transform:uppercase}
.fc-truth{color:var(--text);font-size:.9rem;line-height:1.55}
.fc-src{align-self:flex-start;font-size:.82rem;color:var(--cyan);border-bottom:1px solid rgba(56,224,255,.35);padding-bottom:1px}
.fc-src:hover{border-color:var(--cyan)}
.fc-nosrc{font-size:.79rem;color:var(--dim);font-style:italic}

/* ---------- Crop circles ---------- */
.cc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:22px}
.cc-card{
  --cc:var(--cyan);
  position:relative;display:flex;flex-direction:column;cursor:pointer;overflow:hidden;
  border-radius:var(--r-md);border:1px solid var(--line);background:var(--panel);backdrop-filter:blur(12px);
  transition:transform .4s var(--ease),border-color .4s,box-shadow .4s;
}
.cc-card:hover{transform:translateY(-7px);border-color:var(--cc);border-color:color-mix(in srgb,var(--cc) 55%,transparent);
  box-shadow:0 30px 60px -28px color-mix(in srgb,var(--cc) 45%,transparent)}
.cc-cyan{--cc:var(--cyan)} .cc-violet{--cc:var(--violet)} .cc-magenta{--cc:var(--magenta)} .cc-green{--cc:var(--green)} .cc-amber{--cc:var(--amber)}

.cc-field{
  position:relative;aspect-ratio:1/1;display:grid;place-items:center;overflow:hidden;border-bottom:1px solid var(--line);
  background:
    radial-gradient(circle at 50% 50%, color-mix(in srgb,var(--cc) 16%,transparent), transparent 62%),
    repeating-conic-gradient(from 0deg, rgba(120,140,90,.05) 0deg 6deg, transparent 6deg 12deg),
    linear-gradient(160deg,#0a0f14,#070a12);
}
.cc-field::after{content:"";position:absolute;inset:0;opacity:.35;pointer-events:none;
  background:repeating-linear-gradient(115deg, rgba(180,200,120,.06) 0 2px, transparent 2px 9px)}
.cc-art{position:relative;z-index:1;width:80%;height:80%;color:var(--cc);overflow:visible;
  filter:drop-shadow(0 0 7px color-mix(in srgb,var(--cc) 70%,transparent)) drop-shadow(0 0 2px color-mix(in srgb,var(--cc) 90%,transparent))}
.cc-ring{fill:none;stroke:var(--cc);stroke-width:.8;opacity:.4}
.cc-spin{transform-origin:100px 100px;animation:ccspin 90s linear infinite}
@keyframes ccspin{to{transform:rotate(360deg)}}
.cc-sweep{position:absolute;left:50%;top:50%;width:150%;height:150%;transform:translate(-50%,-50%);pointer-events:none;
  opacity:0;mix-blend-mode:screen;transition:opacity .5s;
  background:conic-gradient(from 0deg, transparent 0deg, color-mix(in srgb,var(--cc) 32%,transparent) 16deg, transparent 38deg);
  animation:ccsweep 6.5s linear infinite}
.cc-card:hover .cc-sweep{opacity:.75}
@keyframes ccsweep{to{transform:translate(-50%,-50%) rotate(360deg)}}

.cc-meta{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1}
.cc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.cc-name{font-family:"Space Grotesk";font-weight:600;font-size:1.18rem;line-height:1.2}
.cc-flag{font-size:1.3rem;line-height:1}
.cc-line{display:flex;flex-wrap:wrap;gap:6px 14px;font-family:"Space Mono",monospace;font-size:.66rem;color:var(--dim);margin:12px 0 14px}
.cc-line b{color:var(--cc);font-weight:400;letter-spacing:.05em}
.cc-blurb{color:var(--muted);font-size:.9rem;line-height:1.55;flex:1}
.cc-detail{max-height:0;overflow:hidden;opacity:0;transition:max-height .55s var(--ease),opacity .4s,margin .4s}
.cc-card.open .cc-detail{max-height:480px;opacity:1;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.cc-detail-label{display:block;font-family:"Space Mono",monospace;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cc);margin-bottom:8px}
.cc-truth{color:var(--muted);font-size:.88rem;line-height:1.55;margin-bottom:12px}
.cc-src{font-family:"Space Mono",monospace;font-size:.68rem;color:var(--cc)}
.cc-src:hover{text-decoration:underline}
.cc-more{margin-top:14px;font-family:"Space Mono",monospace;font-size:.7rem;letter-spacing:.1em;color:var(--cc)}
.cc-more .plus{display:inline-block;transition:transform .3s}
.cc-card.open .cc-more .plus{transform:rotate(45deg)}

/* ---------- Reader modal (on-site dossier) ---------- */
.reader-box{position:relative;width:min(720px,100%);max-height:86vh;display:flex;flex-direction:column;overflow:hidden;
  background:linear-gradient(165deg,#0c1020,#080a14);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow)}
.reader-box::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad);z-index:3}
.reader-box .modal-close{top:14px;right:14px}
.reader-body{padding:36px 38px 32px;overflow-y:auto}
.reader-type{display:inline-block;font-family:"Space Mono",monospace;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;padding:4px 10px;border-radius:6px;background:rgba(154,107,255,.16);color:#cbb6ff}
.reader-title{font-family:"Space Grotesk";font-weight:700;font-size:1.5rem;line-height:1.2;margin:14px 0 6px;max-width:90%}
.reader-org{font-family:"Space Mono",monospace;font-size:.72rem;color:var(--dim);margin-bottom:18px}
.reader-org b{color:var(--cyan);font-weight:400}
.reader-facts{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:8px 18px;margin:0 0 22px;padding:16px 18px;border:1px solid var(--line);border-radius:12px;background:rgba(56,224,255,.04)}
.reader-facts li{position:relative;padding-left:18px;font-family:"Space Mono",monospace;font-size:.73rem;color:var(--muted);line-height:1.4}
.reader-facts li::before{content:"▹";position:absolute;left:0;color:var(--cyan)}
.reader-prose p{color:var(--text);font-size:.95rem;line-height:1.7;margin-bottom:14px;opacity:.92}
.reader-cta{margin-top:22px;padding-top:20px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px}
.reader-link{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;font-weight:600;font-size:.92rem;color:#06070d;background:var(--grad);padding:11px 18px;border-radius:10px;box-shadow:var(--glow-cyan);transition:transform .25s var(--ease)}
.reader-link:hover{transform:translateY(-2px)}
.reader-link .ext-arr{transition:transform .25s}
.reader-link:hover .ext-arr{transform:translate(3px,-3px)}
.reader-note{font-family:"Space Mono",monospace;font-size:.66rem;color:var(--dim)}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease);transition-delay:var(--d,0s)}
.reveal.in{opacity:1;transform:none}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .nebula,.brand-mark,.dot-live,.wheel,
  .map-sweep,.map-pin .pin-pulse,.gate-seal,.brief-led,
  .audio-toggle.on .eq i,.audio-toggle.music.on .note,.geiger-active,.arc-pulse{animation:none}
  .scif-vault.in,.mi-name,.mi-flag{animation:none}
  .fc-inner{transition:none}
  .cc-spin,.cc-sweep{animation:none}
  .cc-card:hover .cc-sweep{opacity:0}
}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .drake{grid-template-columns:1fr}
  .drake-result{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .map-wrap{grid-template-columns:1fr}
  .map-info{min-height:auto}
}
@media (max-width:760px){
  .nav-links{
    position:fixed;inset:0 0 auto 0;top:0;flex-direction:column;gap:0;
    background:rgba(7,8,14,.97);backdrop-filter:blur(20px);padding:90px 30px 30px;
    transform:translateY(-100%);transition:transform .4s var(--ease);height:100vh;
  }
  .nav-links.open{transform:none}
  .nav-links a{padding:18px 0;border-bottom:1px solid var(--line);font-size:1.1rem}
  .nav-toggle{display:flex;z-index:95}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .balance-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .timeline::before{left:54px}
  .case-card.featured{grid-column:span 1}
  .scif-gate{min-height:360px}
  .redact-grid{grid-template-columns:1fr}
  .tl-item{grid-template-columns:54px 1fr;gap:18px}
  .tl-year{font-size:1rem;writing-mode:vertical-rl;transform:rotate(180deg);text-align:left}
  .tl-dot{left:47px}
}
