:root{
  --bg:#04110b;
  --ink:#e8ffef;
  --acid:#00ff9a;
  --dim:#00ff9a33;
  --cyan:#00ffd1;
  --lime:#9bff00;
  --card:#0b1410;
}

/* Reset */
*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:
    radial-gradient(1200px 800px at 70% -10%,#00ffbf22,transparent),
    radial-gradient(900px 600px at 10% 110%,#00ff8a11,transparent),
    var(--bg);
  color:var(--ink);
  font-family:"Space Grotesk",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  line-height:1.5;
  overflow-x:hidden; /* lock horizontal scroll on mobile */
}

#noise{position:fixed;inset:0;pointer-events:none;opacity:.07;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 2 2'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.6'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");mix-blend-mode:overlay;z-index:0}
#matrixRain{position:fixed;inset:0;pointer-events:none;opacity:.28;z-index:1;mix-blend-mode:screen}
#scanlines{position:fixed;inset:0;pointer-events:none;opacity:.08;z-index:2}

.page{position:relative;z-index:3}

.hero{min-height:100svh;display:grid;grid-template-columns:1.2fr 1fr;gap:4rem;align-items:center;padding:clamp(16px,4vw,48px);position:relative}
.hero--banner::before{content:"";position:absolute;inset:-2%;background:url('assets/banner.jpg') center/cover no-repeat;opacity:.08;pointer-events:none;filter:saturate(1.2) contrast(1.05);mix-blend-mode:screen}
.hero__media{position:relative}
.hero__image{width:100%;height:auto;border-radius:16px;box-shadow:0 20px 80px #00ffd033;object-fit:cover;filter:contrast(1.05) saturate(1.05)}
.hero__image.is-jittering{animation:jitter .22s steps(3,end) 1}
.hero__image.is-jittering + .hero__fx{opacity:.5}
.hero__fx{position:absolute;inset:0;border-radius:16px;pointer-events:none;mix-blend-mode:screen;background:radial-gradient(100px 60px at 20% 20%,#0ff8,transparent),radial-gradient(100px 60px at 80% 30%,#f0f8,transparent),radial-gradient(120px 80px at 40% 80%,#0f88,transparent);opacity:.0;transition:opacity .25s ease}
.hero__media:hover .hero__fx{opacity:.35}
.hero__badge{position:absolute;top:12px;left:12px;background:linear-gradient(90deg,var(--acid),var(--cyan));color:#00140f;padding:6px 10px;border-radius:999px;font-weight:700;letter-spacing:.04em;font-size:.8rem;box-shadow:0 6px 24px #00ff9a55}
.hero__copy h1{font-size:clamp(42px,8vw,120px);margin:0;line-height:.85;font-weight:900;letter-spacing:-.02em;position:relative;display:inline-block;background:linear-gradient(90deg,var(--lime) 0%,var(--cyan) 45%,var(--acid) 70%,var(--lime) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 24px #00ffa244,0 0 64px #00ffa222}
.hero__copy h1 span:nth-child(1){color:var(--acid)}
.hero__copy .lede{font-size:clamp(16px,2.5vw,24px);opacity:.9;margin:18px 0 24px}
.callout{background:#0b1410;border:1px solid #124b3a;border-radius:12px;padding:12px 14px;margin:8px 0 18px;color:#dffdef}
.callout strong{color:var(--acid)}
.micro{opacity:.7;font-family:"JetBrains Mono",monospace;font-size:.9rem}

.cta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.btn{appearance:none;border:0;border-radius:12px;padding:12px 16px;font-weight:700;color:#00140f;background:var(--acid);cursor:pointer;transition:transform .12s ease,box-shadow .2s ease}
.btn:active{transform:translateY(1px)}
.btn--primary{box-shadow:0 10px 30px #00ffd055}
.btn--icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:1px solid #00ff9a44;background:#0b0e14;color:var(--acid)}
.btn--icon:hover{box-shadow:0 0 0 6px var(--dim)}
.btn--ghost{background:transparent;border:1px solid #1b2522;color:var(--ink)}

.narrative{padding:clamp(16px,4vw,48px);padding-top:0}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.panel{grid-column:span 6;background:linear-gradient(180deg,#0e141a,#080b10);border:1px solid #0f1b18;border-radius:16px;padding:24px;box-shadow:inset 0 0 0 1px #00ffd011,0 30px 80px #0008}
.panel h2{margin:0 0 10px;font-size:clamp(22px,3vw,32px);color:var(--acid)}
.panel p{margin:0;color:#e9fff7cc}

/* Glitch headline effect */
.glitch{--sh:0px;--sv:0px;--co:var(--acid)}
.glitch::before,.glitch::after{content:attr(data-text);position:absolute;left:0;top:0;clip-path:inset(0 0 0 0);opacity:.8}
.glitch::before{transform:translate(var(--sh),var(--sv));color:#ff00ea99;mix-blend-mode:screen}
.glitch::after{transform:translate(calc(var(--sh) * -1),calc(var(--sv) * -1));color:#00fff299;mix-blend-mode:screen}
.glitch.is-glitching{animation:glitchPulse .9s steps(2,end) 1}
@keyframes glitchPulse{0%{--sh:3px;--sv:-2px}20%{--sh:-4px;--sv:3px}40%{--sh:2px;--sv:-4px}60%{--sh:-1px;--sv:2px}80%{--sh:1px;--sv:-1px}100%{--sh:0;--sv:0}}

@keyframes jitter{0%{transform:translate(0,0)}25%{transform:translate(-2px,1px)}50%{transform:translate(3px,-1px)}75%{transform:translate(-1px,-2px)}100%{transform:translate(0,0)}}

/* Panel reveal */
.panel{transform:translateY(24px);opacity:0;will-change:transform,opacity}
.panel.is-visible{transform:none;opacity:1;transition:transform .7s cubic-bezier(.2,.8,.2,1),opacity .7s ease}

/* Manifesto */
.manifesto{padding:0 clamp(16px,4vw,48px) clamp(32px,6vw,96px)}
.quote{font-size:clamp(22px,4vw,40px);font-weight:800;letter-spacing:.02em;color:var(--ink);margin:16px 0 24px;border-left:4px solid var(--acid);padding-left:16px}
.columns{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:12px 0 16px}
.card{background:#0b0e14;border:1px solid #0f1b18;border-radius:14px;padding:20px}
.card h3{margin:0 0 10px;color:var(--acid)}
.card ul{margin:0;padding-left:18px;color:#e9fff7cc}
.aside{opacity:.8}

/* Story section */
.story{max-width:980px;margin:0 auto;padding:0 clamp(16px,4vw,48px) clamp(24px,6vw,64px)}
.story h2{color:var(--acid);margin:0 0 10px;font-size:clamp(26px,4vw,40px)}
.story p{color:#e9fff7cc;margin:0 0 12px}
.story .note{opacity:.8;font-style:italic}

/* Protocol */
.protocol{padding:clamp(24px,6vw,80px) clamp(16px,4vw,48px)}
.protocol__title{margin:0 0 12px;color:var(--acid);font-size:clamp(26px,4vw,40px)}
.proto-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.proto-card{grid-column:span 3;background:#0b1410;border:1px solid #123a2d;border-radius:14px;padding:18px}
.proto-card .step{font-family:"JetBrains Mono",monospace;color:#74ffc9;opacity:.7;margin-bottom:6px}
.proto-card h3{margin:0 0 6px}
.proto-card ul{margin:0;padding-left:18px;color:#e9fff7cc}

@media (max-width:980px){
  .proto-card{grid-column:span 6}
}
@media (max-width:720px){
  .proto-card{grid-column:span 12}
}

@media (max-width:980px){
  .hero{grid-template-columns:1fr;gap:24px}
  .hero__media{order:-1}
}

@media (max-width:720px){
  .grid{grid-template-columns:1fr}
  .panel{grid-column:span 1}
  .columns{grid-template-columns:1fr}
}

.ticker{padding:24px 0;mask-image:linear-gradient(90deg,transparent,black 10%,black 90%,transparent)}
.marquee{white-space:nowrap;overflow:hidden;font-weight:800;letter-spacing:.08em;color:var(--acid);opacity:.7}
.marquee::before{content:attr(data-dup) attr(data-dup) attr(data-dup) attr(data-dup) attr(data-dup);display:inline-block;animation:scroll 18s linear infinite}
@keyframes scroll{to{transform:translateX(-50%)}}

.footer{padding:32px 16px}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#070a0f;border:1px solid #0f1b18;border-radius:14px;padding:16px}
.brand{font-weight:900;letter-spacing:.1em;color:var(--acid)}
.contract code{font-family:"JetBrains Mono",monospace}
.actions{display:flex;gap:8px;align-items:center}

#toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(20px);background:#071a16;border:1px solid #1b3e35;color:var(--ink);padding:12px 16px;border-radius:12px;opacity:0;pointer-events:none;transition:opacity .2s ease, transform .2s ease;box-shadow:0 10px 40px #001a14}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Accessibility focus */
:focus-visible{outline:2px solid var(--acid);outline-offset:2px}

@media (prefers-reduced-motion:reduce){
  .glitch::before,.glitch::after{display:none}
  .panel{transition:none}
  .hero__fx{display:none}
}

*{box-sizing:border-box}
html,body{height:100%}
html{overflow-x:hidden}
body{margin:0;background:#05060b;color:#e7f0ff;font-family:'Inter',system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.65;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}

:root{--line:rgba(255,255,255,.16);--glass:rgba(255,255,255,.06);--c1:#67f9ff;--c2:#a277ff;--muted:#9fb2cc}
.mono{font-family:'Space Grotesk',ui-monospace,Menlo,Monaco,Consolas,monospace;letter-spacing:.02em}
.sr-only{position:absolute!important;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}

.wrap{min-height:100svh;display:grid;grid-template-rows:auto auto 1fr auto;gap:24px;padding:22px 22px 90px;position:relative}
.mast{display:flex;justify-content:space-between;align-items:center}
.logo{letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.modes{display:flex;gap:8px}
.mode{padding:8px 12px;border:1px solid var(--line);background:var(--glass);border-radius:12px;color:#e7f0ff}
.mode[aria-selected="true"]{outline:2px solid var(--c1)}

.artifact{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--glass)}
.artifact img{width:100%}

.narrative{display:grid;gap:10px;max-width:900px;margin-inline:auto}
.narrative h1{margin:0;font-size:clamp(18px,2.6vw,34px);background:linear-gradient(90deg,var(--c1),var(--c2));-webkit-background-clip:text;background-clip:text;color:transparent}
.narrative p{margin:0;color:#dce7ff}

.actions{position:fixed;left:0;right:0;bottom:0;display:flex;justify-content:center;gap:12px;padding:12px}
.chip{display:flex;gap:8px;align-items:center;border:1px solid var(--line);background:var(--glass);color:#e7f0ff;border-radius:14px;padding:10px 14px}
.icon.twitter{display:grid;place-items:center;width:44px;height:44px;border-radius:14px;border:1px solid var(--line);background:var(--glass)}
.icon.twitter svg{width:22px;color:#e7f0ff}

#grain{position:fixed;inset:0;z-index:-1}

@media (min-width: 900px){
  .wrap{grid-template-columns:1fr 1fr;grid-template-rows:auto 1fr auto;gap:26px 26px}
  .artifact{grid-column:2;grid-row:2}
  .narrative{grid-column:1;grid-row:2}
}


