/* ============================================================
   RECOVERY — cryptic neon site
   Black void · lime/yellow glow · the ascent
   ============================================================ */

:root{
  --void:        #000000;
  --void-2:      #050805;
  --ink:         #0a0f0a;
  --lime:        #c6f000;   /* matched to the logo chartreuse (#9EBD04 body) */
  --lime-soft:   #9ebd04;   /* logo body color */
  --acid:        #cdf51a;   /* accent — same chartreuse hue as the logo */
  --acid-hot:    #dafb45;
  --text:        #d6e8c8;
  --text-dim:    #6f7d63;
  --line:        rgba(198,240,0,.16);
  --glow:        0 0 18px rgba(198,240,0,.55), 0 0 48px rgba(198,240,0,.25);
  --glow-acid:   0 0 22px rgba(205,245,26,.6), 0 0 60px rgba(205,245,26,.28);
  --ease:        cubic-bezier(.2,.7,.2,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  background:var(--void);
  color:var(--text);
  font-family:'Rajdhani', system-ui, sans-serif;
  font-size:18px;
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  position:relative;
}

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* ---------- ambient overlays ---------- */
.grain,.vignette,.scanlines{
  position:fixed; inset:0; pointer-events:none; z-index:60;
}
.grain{
  opacity:.05; mix-blend-mode:screen;
  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");
}
.vignette{
  z-index:55;
  background:radial-gradient(120% 90% at 50% 30%, transparent 40%, rgba(0,0,0,.55) 78%, #000 100%);
}
.scanlines{
  opacity:.35;
  background:repeating-linear-gradient(to bottom, transparent 0 3px, rgba(0,0,0,.18) 3px 4px);
}
#embers{
  position:fixed; inset:0; z-index:1; pointer-events:none;
}

/* ---------- NAV ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:18px clamp(18px,5vw,64px);
  transition:background .4s var(--ease), border-color .4s var(--ease), padding .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  padding-top:12px; padding-bottom:12px;
}
.nav__brand img{ height:22px; filter:drop-shadow(0 0 10px rgba(182,255,0,.5)); }
.nav__links{ display:flex; align-items:center; gap:clamp(14px,2.6vw,34px); }
.nav__links a{
  font-size:14px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--text-dim); transition:color .25s var(--ease), text-shadow .25s var(--ease);
}
.nav__links a:hover{ color:var(--lime); text-shadow:0 0 12px rgba(182,255,0,.6); }
.nav__cta{
  color:var(--void)!important; background:var(--acid);
  padding:8px 18px; border-radius:40px; font-weight:700;
  box-shadow:var(--glow-acid);
}
.nav__cta:hover{ text-shadow:none!important; transform:translateY(-1px); }
@media(max-width:620px){ .nav__links a:not(.nav__cta){ display:none; } }

/* ---------- HERO ---------- */
.hero{
  position:relative; min-height:100svh;
  display:flex; align-items:center; justify-content:center;
  text-align:center; overflow:hidden;
}
.hero__video{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; z-index:0; opacity:.62;
  filter:contrast(1.12) saturate(1.15);
}
.hero__veil{
  position:absolute; inset:0; z-index:1;
  background:
    radial-gradient(60% 50% at 50% 42%, rgba(182,255,0,.10), transparent 70%),
    linear-gradient(to bottom, rgba(0,0,0,.55), rgba(0,0,0,.2) 45%, #000 96%);
}
.hero__inner{ position:relative; z-index:2; padding:0 22px; max-width:900px; }
.hero__eyebrow{
  font-family:'Share Tech Mono', monospace;
  color:var(--lime-soft); letter-spacing:.32em; font-size:13px;
  text-transform:uppercase; margin-bottom:24px; opacity:.85;
}
/* hero wordmark: shown only on mobile (desktop video already shows RECOVERY) */
.hero__title{ display:none; }
@media(max-width:768px){ .hero__title{ display:block; } }
.hero__logo{
  width:min(640px,82vw); margin:0 auto;
  filter:drop-shadow(0 0 26px rgba(182,255,0,.55)) drop-shadow(0 0 70px rgba(182,255,0,.3));
  animation:breathe 5s ease-in-out infinite;
}
@keyframes breathe{
  0%,100%{ filter:drop-shadow(0 0 22px rgba(182,255,0,.45)) drop-shadow(0 0 60px rgba(182,255,0,.22)); }
  50%{ filter:drop-shadow(0 0 34px rgba(182,255,0,.7)) drop-shadow(0 0 92px rgba(182,255,0,.4)); }
}
.hero__tag{
  margin-top:18px; font-size:clamp(18px,2.4vw,24px);
  letter-spacing:.06em; color:var(--text); font-weight:300;
}
.hero__actions{
  margin-top:42px; display:flex; gap:16px; justify-content:center; flex-wrap:wrap;
}
.hero__scroll{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:2;
  width:26px; height:42px; border:1.5px solid var(--line); border-radius:20px;
  display:grid; place-items:start center; padding-top:8px;
}
.hero__scroll span{
  width:4px; height:8px; border-radius:4px; background:var(--lime);
  box-shadow:var(--glow); animation:scrolldot 1.8s var(--ease) infinite;
}
@keyframes scrolldot{ 0%{ transform:translateY(0); opacity:1; } 70%{ transform:translateY(16px); opacity:0; } 100%{ opacity:0; } }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-weight:600; letter-spacing:.04em; font-size:16px;
  padding:14px 28px; border-radius:50px; cursor:pointer;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
}
.btn--solid{ background:var(--acid); color:#0a0a00; box-shadow:var(--glow-acid); }
.btn--solid:hover{ transform:translateY(-2px); box-shadow:0 0 30px rgba(230,255,26,.85),0 0 80px rgba(230,255,26,.4); }
.btn--ghost{ border:1.5px solid var(--line); color:var(--text); }
.btn--ghost:hover{ border-color:var(--lime); color:var(--lime); box-shadow:var(--glow); transform:translateY(-2px); }
.btn__dot{ width:9px; height:9px; border-radius:50%; background:#0a0a00; box-shadow:0 0 0 3px rgba(0,0,0,.25) inset; animation:pulse 1.4s infinite; }
@keyframes pulse{ 0%,100%{ opacity:.5; } 50%{ opacity:1; } }

/* ---------- section scaffolding ---------- */
section{ position:relative; z-index:2; padding:clamp(70px,11vw,150px) clamp(20px,6vw,90px); }
.section__label{
  display:inline-flex; align-items:center; gap:12px;
  font-family:'Share Tech Mono', monospace; font-size:13px; letter-spacing:.3em;
  color:var(--lime-soft); text-transform:uppercase; margin-bottom:26px;
}
.section__label span{ width:34px; height:1px; background:var(--lime); box-shadow:var(--glow); display:inline-block; }
.section__label--center{ justify-content:center; }

/* ---------- MANIFESTO ---------- */
.manifesto{ max-width:1000px; margin:0 auto; text-align:center; }
.manifesto__lead{
  font-family:'Cinzel', serif; font-weight:600;
  font-size:clamp(24px,4vw,44px); line-height:1.35; color:#eafbd6;
  text-shadow:0 0 30px rgba(182,255,0,.18); margin:0 auto 22px; max-width:900px;
}
.manifesto__lead em{ color:var(--lime); font-style:italic; text-shadow:var(--glow); }
.manifesto__body{
  font-size:clamp(17px,2vw,21px); color:var(--text-dim);
  max-width:62ch; margin:0 auto;
}
.pillars{
  margin-top:64px; display:grid; gap:22px;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
}
.pillar{
  text-align:left; padding:30px 26px; border:1px solid var(--line); border-radius:16px;
  background:linear-gradient(160deg, rgba(182,255,0,.04), rgba(0,0,0,0));
  transition:transform .35s var(--ease), border-color .35s var(--ease), box-shadow .35s var(--ease);
}
.pillar:hover{ transform:translateY(-6px); border-color:rgba(182,255,0,.4); box-shadow:var(--glow); }
.pillar__rune{
  font-family:'Cinzel', serif; font-size:26px; font-weight:900; color:var(--lime);
  text-shadow:var(--glow); margin-bottom:14px; letter-spacing:.1em;
}
.pillar h3{ font-size:22px; letter-spacing:.04em; margin-bottom:10px; color:#eafbd6; }
.pillar p{ font-size:16px; color:var(--text-dim); }

/* ---------- CONTRACT (copy bar — matches reference graphic) ---------- */
.contract{ max-width:920px; margin:0 auto; text-align:center; }
.contract__title{
  font-family:'Cinzel', serif; font-size:clamp(30px,5vw,52px); color:#eafbd6;
  text-shadow:0 0 30px rgba(182,255,0,.25); margin-bottom:10px;
}
.contract__sub{ color:var(--text-dim); margin-bottom:40px; }

.ca{
  display:flex; align-items:stretch; gap:0;
  max-width:760px; margin:0 auto;
  background:#000; border:2px solid var(--acid);
  border-radius:18px; padding:10px;
  box-shadow:0 0 0 1px rgba(0,0,0,.8), var(--glow-acid);
  position:relative;
}
.ca__field{
  flex:1; display:flex; align-items:center;
  background:#fff; border-radius:11px; padding:0 22px; min-height:64px;
  overflow:hidden;
}
.ca__text{
  font-family:'Share Tech Mono', monospace; font-size:clamp(13px,2.2vw,18px);
  color:#111; letter-spacing:.01em; white-space:nowrap; overflow:hidden;
  text-overflow:ellipsis; width:100%; text-align:left;
}
.ca__copy{
  margin-left:10px; min-width:120px; border:none; cursor:pointer;
  background:var(--acid); border-radius:11px;
  font-family:'Rajdhani', sans-serif; font-weight:700; font-size:22px;
  color:#0a0a00; letter-spacing:.02em;
  transition:transform .15s var(--ease), background .2s var(--ease), box-shadow .2s var(--ease);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.25);
}
.ca__copy:hover{ background:var(--acid-hot); box-shadow:0 0 24px rgba(230,255,26,.7), inset 0 0 0 1px rgba(0,0,0,.25); }
.ca__copy:active{ transform:scale(.96); }
.ca__copy.is-copied{ background:var(--lime); }
.ca__hint{ margin-top:18px; font-size:14px; color:var(--text-dim); font-family:'Share Tech Mono',monospace; letter-spacing:.06em; }
@media(max-width:520px){
  .ca{ flex-direction:column; gap:10px; }
  .ca__copy{ margin-left:0; min-height:54px; }
}

/* ---------- JOURNEY ---------- */
.journey{
  max-width:1150px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,6vw,80px); align-items:center;
}
.journey__art{ position:relative; }
.journey__art img{
  width:100%; border-radius:50%;
  filter:drop-shadow(0 0 40px rgba(182,255,0,.35));
  animation:floaty 7s ease-in-out infinite;
}
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-14px); } }
.journey__copy h2{
  font-family:'Cinzel', serif; font-size:clamp(24px,3.2vw,38px);
  line-height:1.3; color:#eafbd6; margin-bottom:20px;
  text-shadow:0 0 24px rgba(182,255,0,.15);
}
.journey__copy p{ color:var(--text-dim); margin-bottom:16px; font-size:17px; }
@media(max-width:820px){ .journey{ grid-template-columns:1fr; } .journey__art{ max-width:380px; margin:0 auto; } }

/* ---------- JOIN / SOCIALS ---------- */
.join{ text-align:center; }
.join__title{
  font-family:'Cinzel', serif; font-size:clamp(30px,5vw,54px); color:#eafbd6;
  text-shadow:0 0 30px rgba(182,255,0,.25);
}
.join__sub{ color:var(--text-dim); margin:10px auto 50px; }
.links{
  display:grid; gap:22px; max-width:1000px; margin:0 auto;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
}
.link-card{
  position:relative; overflow:hidden;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  padding:34px 22px; border:1px solid var(--line); border-radius:20px;
  background:rgba(255,255,255,.012);
  transition:transform .35s var(--ease), border-color .35s var(--ease), box-shadow .35s var(--ease);
}
.link-card__glow{
  position:absolute; inset:auto; top:-40%; left:50%; transform:translateX(-50%);
  width:160px; height:160px; border-radius:50%;
  background:radial-gradient(circle, rgba(198,240,0,.25), transparent 70%);
  opacity:0; transition:opacity .4s var(--ease);
}
.link-card__icon{
  width:96px; height:96px; border-radius:50%;
  /* nudge the yellow neon icons to the logo chartreuse hue + keep them bright
     so the cinematic vignette/scanline overlays don't mute them */
  filter:hue-rotate(15deg) saturate(1.1) brightness(1.3) drop-shadow(0 0 14px rgba(198,240,0,.45));
  transition:transform .35s var(--ease), filter .35s var(--ease);
}
.link-card__name{ font-size:18px; font-weight:600; letter-spacing:.05em; color:#eafbd6; }
.link-card__meta{
  font-family:'Share Tech Mono', monospace; font-size:12px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--text-dim);
}
.link-card:hover{ transform:translateY(-8px); border-color:rgba(230,255,26,.45); box-shadow:var(--glow-acid); }
.link-card:hover .link-card__glow{ opacity:1; }
.link-card:hover .link-card__icon{ transform:scale(1.08); filter:hue-rotate(15deg) saturate(1.2) brightness(1.65) drop-shadow(0 0 32px rgba(198,240,0,.95)); }

/* ---------- FOOTER ---------- */
.footer{
  text-align:center; padding:80px 22px 60px;
  border-top:1px solid var(--line); position:relative; z-index:2;
}
.footer__logo{ height:26px; margin:0 auto 22px; filter:drop-shadow(0 0 14px rgba(182,255,0,.5)); opacity:.9; }
.footer__line{ font-family:'Cinzel',serif; color:var(--lime); letter-spacing:.04em; margin-bottom:18px; text-shadow:0 0 20px rgba(182,255,0,.3); }
.footer__fine{ max-width:60ch; margin:0 auto 22px; font-size:13px; color:var(--text-dim); line-height:1.7; }
.footer__copy{ font-family:'Share Tech Mono',monospace; font-size:12px; color:var(--text-dim); letter-spacing:.2em; }
.footer__mayhem{
  display:inline-block; margin-top:14px;
  font-family:'Share Tech Mono',monospace; font-size:13px; letter-spacing:.18em;
  color:var(--lime); text-transform:uppercase;
  text-shadow:0 0 10px rgba(198,240,0,.5), 0 0 22px rgba(198,240,0,.28);
  transition:text-shadow .25s var(--ease), transform .25s var(--ease), color .25s var(--ease);
}
.footer__mayhem:hover{
  color:var(--acid-hot);
  text-shadow:0 0 14px rgba(205,245,26,.95), 0 0 34px rgba(205,245,26,.6), 0 0 60px rgba(205,245,26,.35);
  transform:translateY(-1px);
}

/* ---------- toast ---------- */
.toast{
  position:fixed; left:50%; bottom:34px; transform:translate(-50%, calc(100% + 90px));
  background:var(--lime); color:#0a0a00; font-weight:700; letter-spacing:.04em;
  padding:13px 26px; border-radius:40px; z-index:80; pointer-events:none;
  box-shadow:var(--glow); transition:transform .45s var(--ease);
}
.toast.is-show{ transform:translate(-50%,0); }

/* ---------- reveal animation ---------- */
[data-reveal]{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
[data-reveal].is-in{ opacity:1; transform:none; }

@media(prefers-reduced-motion:reduce){
  *{ animation:none!important; scroll-behavior:auto; }
  [data-reveal]{ opacity:1; transform:none; }
}
