/* ============================================================
   ZORBLINS — Toxic Goblin Theme
   ============================================================ */

:root{
  --tox:        #b6ff00;   /* radioactive lime */
  --tox-soft:   #a3e635;
  --tox-deep:   #6b8e00;
  --slime:      #c4ff3d;
  --brain:      #ff7eb6;   /* pink brain */
  --blood:      #ef3b3b;   /* tongue / blood red */
  --purple:     #7c3aed;   /* purple goblin */
  --ink:        #060a02;   /* near-black green */
  --ink-2:      #0c1305;
  --panel:      #0f1707;
  --panel-2:    #14200a;
  --line:       rgba(182,255,0,.14);
  --line-soft:  rgba(182,255,0,.07);
  --text:       #e9f4da;
  --text-dim:   #93a884;
  --glow:       0 0 20px rgba(182,255,0,.2);
  --font-disp:  'Bangers', cursive;
  --font-hand:  'Permanent Marker', cursive;
  --font-body:  'Space Grotesk', sans-serif;
  --ease:       cubic-bezier(.16,1,.3,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--ink);
  color:var(--text);
  overflow-x:hidden;
  line-height:1.6;
  cursor:none;
}
@media (max-width:900px){ body{cursor:auto} }

img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--tox);color:var(--ink)}

/* ---- toxic textured background ---- */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(900px 600px at 20% -5%, rgba(124,58,237,.10), transparent 60%),
    radial-gradient(1000px 700px at 85% 10%, rgba(182,255,0,.10), transparent 55%),
    radial-gradient(1200px 900px at 50% 120%, rgba(182,255,0,.07), transparent 60%),
    linear-gradient(180deg, #060a02, #04060100 40%, #060a02);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.cursor,.cursor-dot{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9999;mix-blend-mode:screen}
.cursor{width:38px;height:38px;border:2px solid var(--tox);box-shadow:0 0 18px rgba(182,255,0,.6);transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s,border-color .25s}
.cursor-dot{width:7px;height:7px;background:var(--tox);transform:translate(-50%,-50%);box-shadow:0 0 12px var(--tox)}
.cursor.is-hover{width:64px;height:64px;background:rgba(182,255,0,.12);border-color:var(--slime)}
@media (max-width:900px){.cursor,.cursor-dot{display:none}}

/* ============================================================
   LOADER — slime panels split open over a liquid counter
   ============================================================ */
.loader{position:fixed;inset:0;z-index:10000;overflow:hidden;transition:visibility .1s .9s}
.loader.done{visibility:hidden}
.loader__panel{position:absolute;top:0;height:100%;width:51%;background:linear-gradient(180deg,#0a1104,#05080100);background-color:#070d02;transition:transform .85s cubic-bezier(.85,0,.15,1)}
.loader__panel--l{left:0;box-shadow:inset -1px 0 0 rgba(182,255,0,.12)}
.loader__panel--r{right:0;box-shadow:inset 1px 0 0 rgba(182,255,0,.12)}
.loader.done .loader__panel--l{transform:translateX(-101%)}
.loader.done .loader__panel--r{transform:translateX(101%)}
.loader__seam{position:absolute;left:50%;top:0;width:2px;height:100%;transform:translateX(-50%);background:linear-gradient(180deg,transparent,var(--tox),transparent);box-shadow:0 0 22px var(--tox);opacity:.55;transition:opacity .4s}
.loader.done .loader__seam{opacity:0}
.loader__body{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;transition:opacity .45s,transform .45s}
.loader.done .loader__body{opacity:0;transform:scale(.94)}
.loader__logo img{width:88px;height:88px;border-radius:20px;box-shadow:var(--glow);animation:bob 2.2s ease-in-out infinite}
.loader__count{display:flex;align-items:flex-start;font-family:var(--font-disp);line-height:.82;letter-spacing:2px;margin-top:6px}
.loader__count span{
  font-size:clamp(5.5rem,21vw,15rem);color:transparent;
  -webkit-text-stroke:2px rgba(182,255,0,.35);
  background:linear-gradient(0deg,var(--tox-deep),var(--tox) 60%,var(--slime));
  -webkit-background-clip:text;background-clip:text;
  background-repeat:no-repeat;background-position:left bottom;background-size:100% 0%;
  filter:drop-shadow(0 0 34px rgba(182,255,0,.35));transition:background-size .25s ease-out;
}
.loader__count i{font-style:normal;font-size:clamp(1.6rem,5vw,3.4rem);color:var(--tox);margin-top:.4em;margin-left:.05em;text-shadow:0 0 18px rgba(182,255,0,.6)}
.loader__status{font-family:var(--font-body);font-weight:500;letter-spacing:3px;text-transform:uppercase;font-size:.8rem;color:var(--tox);display:flex;align-items:center;gap:4px}
.loader__caret{opacity:.7}
.loader__blink{animation:blink 1s steps(2) infinite}
@keyframes blink{50%{opacity:0}}
@keyframes bob{50%{transform:translateY(-10px) rotate(-3deg)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ============================================================
   PARTICLES + DRIP
   ============================================================ */
.spores{position:fixed;inset:0;z-index:-1;pointer-events:none}
.topdrip{position:fixed;top:0;left:0;width:100%;height:70px;z-index:90;pointer-events:none}
.topdrip svg{width:100%;height:100%}
.topdrip path{fill:var(--tox);filter:drop-shadow(0 6px 14px rgba(182,255,0,.35));opacity:.9}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-disp);letter-spacing:1.5px;font-size:1rem;
  padding:14px 26px;border-radius:14px;border:2px solid transparent;
  cursor:none;transition:transform .3s var(--ease),box-shadow .3s,background .3s,color .3s;overflow:hidden;
}
.btn--lg{padding:18px 34px;font-size:1.2rem}
.btn--mint{background:var(--tox);color:var(--ink);box-shadow:inset 0 -4px 0 rgba(0,0,0,.18)}
.btn--mint:hover{box-shadow:0 12px 28px rgba(120,160,0,.25), inset 0 -4px 0 rgba(0,0,0,.18);transform:translateY(-3px)}
.btn--mint::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.55),transparent);transform:skewX(-20deg);transition:left .6s}
.btn--mint:hover::after{left:140%}
.btn--ghost{background:rgba(182,255,0,.04);color:var(--tox);border-color:var(--line)}
.btn--ghost:hover{background:rgba(182,255,0,.12);border-color:var(--tox);transform:translateY(-3px);box-shadow:var(--glow)}

/* ============================================================
   NAVBAR
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 5vw;transition:background .4s,backdrop-filter .4s,padding .4s,box-shadow .4s;
}
.nav.scrolled{background:rgba(6,10,2,.82);backdrop-filter:blur(14px);padding:12px 5vw;box-shadow:0 1px 0 var(--line)}
.nav__brand{display:flex;align-items:center;gap:12px;font-family:var(--font-disp);font-size:1.5rem;letter-spacing:2px;color:var(--tox)}
.nav__brand img{width:42px;height:42px;border-radius:11px;box-shadow:0 0 16px rgba(182,255,0,.5)}
.nav__links{display:flex;gap:30px}
.nav__link{position:relative;font-weight:600;font-size:.95rem;color:var(--text-dim);transition:color .25s}
.nav__link::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--tox);transition:width .3s var(--ease);box-shadow:0 0 8px var(--tox)}
.nav__link:hover{color:var(--tox)}
.nav__link:hover::after{width:100%}
.nav__actions{display:flex;align-items:center;gap:16px}
.nav__social{display:grid;place-items:center;width:40px;height:40px;border-radius:11px;border:1px solid var(--line);color:var(--text-dim);transition:.3s}
.nav__social:hover{color:var(--tox);border-color:var(--tox);box-shadow:var(--glow);transform:translateY(-2px)}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav__burger span{width:26px;height:3px;background:var(--tox);border-radius:3px;transition:.3s}
.nav__burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0}
.nav__burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:120px 5vw 80px;overflow:hidden}
/* ---- living slime metaball background ---- */
.goo-defs{position:absolute;width:0;height:0;pointer-events:none}
.slime{position:absolute;inset:-12% -8%;z-index:0;filter:url(#goo);opacity:.22;pointer-events:none;overflow:hidden;transition:translate .5s var(--ease)}
.blob{position:absolute;border-radius:50%;mix-blend-mode:screen;will-change:transform}
.blob--1{width:230px;height:230px;left:2%;top:6%;background:radial-gradient(circle at 38% 38%,var(--tox),var(--tox-deep) 70%);animation:blobA 23s ease-in-out infinite}
.blob--2{width:200px;height:200px;right:1%;top:4%;background:radial-gradient(circle at 38% 38%,#7c3aed,#2c1066 70%);animation:blobB 27s ease-in-out infinite}
.blob--3{width:140px;height:140px;left:30%;top:20%;background:radial-gradient(circle at 38% 38%,var(--tox-soft),var(--tox-deep) 70%);animation:blobC 19s ease-in-out infinite}
.blob--4{width:240px;height:240px;left:8%;bottom:-14%;background:radial-gradient(circle at 38% 38%,var(--tox),var(--tox-deep) 70%);animation:blobD 25s ease-in-out infinite}
.blob--5{width:130px;height:130px;right:14%;bottom:0;background:radial-gradient(circle at 38% 38%,var(--brain),#7a2450 70%);animation:blobE 21s ease-in-out infinite}
.blob--6{width:180px;height:180px;right:26%;top:34%;background:radial-gradient(circle at 38% 38%,#6d34d6,#26105e 70%);animation:blobF 29s ease-in-out infinite}
@keyframes blobA{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(70px,50px) scale(1.18)}}
@keyframes blobB{0%,100%{transform:translate(0,0) scale(1.1)}50%{transform:translate(-60px,60px) scale(.9)}}
@keyframes blobC{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(90px,-50px) scale(1.25)}}
@keyframes blobD{0%,100%{transform:translate(0,0) scale(1.05)}50%{transform:translate(50px,-60px) scale(.85)}}
@keyframes blobE{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-80px,-40px) scale(1.2)}}
@keyframes blobF{0%,100%{transform:translate(0,0) scale(.95)}50%{transform:translate(40px,70px) scale(1.15)}}

.hero__glow{position:absolute;width:1100px;height:1100px;left:50%;top:40%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(182,255,0,.18),transparent 60%);filter:blur(20px);animation:pulseGlow 6s ease-in-out infinite;z-index:0}
.hero__banner,.hero__float{transition:translate .45s var(--ease)}
@keyframes pulseGlow{50%{transform:translate(-50%,-50%) scale(1.12);opacity:.8}}
.hero__crack{position:absolute;inset:0;opacity:.25;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1200' height='800'%3E%3Cg stroke='%23b6ff00' stroke-width='1' fill='none' opacity='.5'%3E%3Cpath d='M100 0 L160 200 L120 380 L210 600 L160 800'/%3E%3Cpath d='M1100 0 L1040 180 L1110 360 L1020 560 L1080 800'/%3E%3Cpath d='M600 0 L640 160 L580 340'/%3E%3C/g%3E%3C/svg%3E");background-size:cover}

.hero__float{position:absolute;width:190px}
.hero__float--1{left:4%;top:24%}
.hero__float--2{right:4%;bottom:14%}
@media (max-width:1100px){.hero__float{display:none}}

/* ---- cursor-reactive goblins ---- */
/* .goblin is always also .hero__float (position:absolute), which provides
   the positioning context for the eyes — don't override it here. */
.goblin{line-height:0}
.goblin img{width:100%;border-radius:20px;box-shadow:0 18px 50px rgba(0,0,0,.6),0 0 0 3px rgba(182,255,0,.25);opacity:.95;display:block;transition:filter .25s}
.goblin:hover img{filter:brightness(1.08);animation:flinch .55s ease}
@keyframes flinch{0%{transform:scale(1) rotate(0)}12%{transform:scale(1.09) rotate(-3deg)}26%{transform:scale(1.05) rotate(3deg)}40%{transform:scale(1.08) rotate(-2deg)}55%{transform:scale(1.03) rotate(1deg)}100%{transform:scale(1) rotate(0)}}
.eye{position:absolute;left:var(--x);top:var(--y);width:var(--s,15%);aspect-ratio:1;background:radial-gradient(circle at 38% 32%,#fff,#dfe7d0 80%);border:2px solid #0c0c0c;border-radius:50%;transform:translate(-50%,-50%);display:grid;place-items:center;box-shadow:inset 0 -3px 7px rgba(0,0,0,.28),0 1px 3px rgba(0,0,0,.5);z-index:2}
.pupil{width:46%;height:46%;background:radial-gradient(circle at 40% 35%,#333,#000 75%);border-radius:50%;transition:translate .12s ease-out}
@media (max-width:1100px){.goblin .eye{display:none}}

/* ---- slime cursor trail ---- */
.drip{position:fixed;border-radius:50% 50% 52% 48%;background:radial-gradient(circle at 35% 30%,var(--slime),var(--tox-deep) 80%);box-shadow:0 0 10px rgba(182,255,0,.6);pointer-events:none;z-index:9998;transform:translate(-50%,-50%);mix-blend-mode:screen;animation:dripFall .9s ease-in forwards}
@keyframes dripFall{0%{opacity:.85}65%{opacity:.45}100%{opacity:0;transform:translate(-50%,22px) scale(.25)}}
@media (max-width:900px){.drip{display:none}}

.hero__inner{position:relative;z-index:2;max-width:920px}
.hero__tags{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:26px}
.tag{font-family:var(--font-hand);font-size:.95rem;letter-spacing:.5px;padding:7px 16px;border-radius:8px;color:var(--ink);box-shadow:0 6px 0 rgba(0,0,0,.35),inset 0 0 0 2px rgba(0,0,0,.25);transition:transform .25s var(--ease)}
.tag--lime{background:var(--tox);transform:rotate(-3deg)}
.tag--pink{background:var(--brain);transform:rotate(2.5deg)}
.tag--purple{background:var(--purple);color:#fff;transform:rotate(-1.5deg);box-shadow:0 6px 0 rgba(0,0,0,.35),inset 0 0 0 2px rgba(255,255,255,.18)}
.tag:hover{transform:rotate(0) translateY(-3px) scale(1.06)}

.hero__banner{margin:0 auto 14px;max-width:680px}
.hero__banner img{width:100%;border-radius:18px;filter:drop-shadow(0 0 30px rgba(182,255,0,.35))}

.hero__title{font-family:var(--font-disp);font-weight:400;font-size:clamp(2rem,5.2vw,4.1rem);line-height:1.02;letter-spacing:1px;color:#fff;text-shadow:0 4px 0 rgba(0,0,0,.4);margin-bottom:18px}
.tox{color:var(--tox);text-shadow:0 0 16px rgba(182,255,0,.28)}
.hero__sub{max-width:640px;margin:0 auto 34px;color:var(--text-dim);font-size:1.12rem}
.hero__cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:46px}

.hero__stats{display:inline-flex;align-items:center;gap:28px;padding:20px 34px;border:1px solid var(--line);border-radius:18px;background:rgba(10,16,4,.5);backdrop-filter:blur(8px)}
.stat{display:flex;flex-direction:column;align-items:center}
.stat__num{font-family:var(--font-disp);font-size:2rem;color:var(--tox);letter-spacing:1px;text-shadow:0 0 12px rgba(182,255,0,.22)}
.stat__label{font-size:.8rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:2px}
.stat__div{width:1px;height:42px;background:var(--line)}
@media (max-width:560px){.hero__stats{gap:16px;padding:16px 18px}.stat__num{font-size:1.5rem}}

.hero__scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);width:26px;height:44px;border:2px solid var(--line);border-radius:14px;display:grid;place-items:start center;padding-top:7px;z-index:3}
.hero__scroll span{width:5px;height:9px;background:var(--tox);border-radius:3px;animation:scrolly 1.6s infinite}
@keyframes scrolly{0%{opacity:0;transform:translateY(0)}40%{opacity:1}100%{opacity:0;transform:translateY(14px)}}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{overflow:hidden;border-top:2px solid var(--line);border-bottom:2px solid var(--line);background:linear-gradient(90deg,rgba(182,255,0,.06),rgba(124,58,237,.05),rgba(182,255,0,.06));padding:16px 0}
.marquee__track{display:flex;align-items:center;gap:30px;white-space:nowrap;width:max-content;animation:marquee 22s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track span{font-family:var(--font-disp);font-size:1.9rem;letter-spacing:2px;color:#fff;-webkit-text-stroke:1px var(--tox-deep)}
.marquee__track i{color:var(--tox);font-size:1.3rem;animation:spin 5s linear infinite}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============================================================
   SECTION SHARED
   ============================================================ */
section{position:relative}
.eyebrow{display:inline-block;font-family:var(--font-hand);color:var(--tox);letter-spacing:1px;font-size:1.05rem;margin-bottom:12px;transform:rotate(-2deg)}
.section-title{font-family:var(--font-disp);font-weight:400;font-size:clamp(1.9rem,4.5vw,3.4rem);line-height:1.04;letter-spacing:1px;color:#fff}

.section-title{margin-bottom:22px}

/* ============================================================
   LORE
   ============================================================ */
.lore{position:relative;max-width:1200px;margin:0 auto;padding:120px 5vw;overflow:visible}
.lore__bg{position:absolute;inset:0;background:radial-gradient(600px 500px at 18% 40%,rgba(124,58,237,.10),transparent 65%),radial-gradient(600px 500px at 90% 70%,rgba(182,255,0,.08),transparent 60%);pointer-events:none}
.lore__tag{display:inline-block;font-family:var(--font-hand);color:var(--tox);font-size:1.05rem;letter-spacing:1px;transform:rotate(-2deg);margin-bottom:30px;position:relative}
.lore__inner{display:grid;grid-template-columns:1.35fr .9fr;gap:60px;align-items:center;position:relative}
@media (max-width:880px){.lore__inner{grid-template-columns:1fr;gap:70px}}
.lore__line{font-family:var(--font-disp);font-weight:400;letter-spacing:.5px;color:#fff;line-height:1.12;font-size:clamp(1.5rem,3vw,2.3rem);margin-bottom:18px;text-shadow:0 3px 0 rgba(0,0,0,.35)}
.lore__line--xl{font-size:clamp(2rem,4.4vw,3.4rem);line-height:1.02}
.lore__line em{color:var(--brain);font-style:italic}
.lore__chips{display:flex;flex-wrap:wrap;gap:12px;margin:24px 0 28px}
.lore__chips span{font-family:var(--font-hand);font-size:1.05rem;color:var(--ink);background:var(--tox);padding:6px 16px;border-radius:8px;transform:rotate(-1.5deg);box-shadow:0 5px 0 rgba(0,0,0,.3)}
.lore__chips span:nth-child(2){background:var(--brain);transform:rotate(2deg)}
.lore__chips span:nth-child(3){background:#fff;transform:rotate(-1deg)}

.lore__media{position:relative}
.lore__frame{position:relative;border-radius:22px;overflow:hidden;border:3px solid var(--tox);box-shadow:0 30px 70px rgba(0,0,0,.6)}
.lore__frame img{width:100%}
.lore__frame-glow{position:absolute;inset:0;box-shadow:inset 0 0 60px rgba(182,255,0,.3);pointer-events:none}
.lore__media-2{position:absolute;width:46%;right:-8%;bottom:-12%;border-radius:16px;border:3px solid var(--ink);box-shadow:0 20px 50px rgba(0,0,0,.7),0 0 0 3px rgba(182,255,0,.4)}
.lore__stamp{position:absolute;top:-18px;left:-18px;width:78px;height:78px;display:grid;place-items:center;text-align:center;font-family:var(--font-disp);font-size:1rem;line-height:.9;color:var(--tox);border:2px dashed var(--tox);border-radius:50%;background:rgba(6,10,2,.85);transform:rotate(-14deg);box-shadow:var(--glow)}
@media (max-width:880px){.lore__media-2{width:40%;right:0}}

/* ============================================================
   HORDE BAND (image marquee)
   ============================================================ */
.hordeband{overflow:hidden;border-top:2px solid var(--line);border-bottom:2px solid var(--line);padding:22px 0;background:linear-gradient(180deg,rgba(124,58,237,.06),rgba(182,255,0,.05))}
.hordeband__track{display:flex;gap:20px;width:max-content;animation:marquee 36s linear infinite}
.hordeband:hover .hordeband__track{animation-play-state:paused}
.hordeband__track img{width:150px;height:150px;object-fit:cover;border-radius:16px;border:2px solid var(--line);box-shadow:0 10px 30px rgba(0,0,0,.5);transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.hordeband__track img:hover{transform:translateY(-8px) rotate(-2deg) scale(1.05);border-color:var(--tox);box-shadow:var(--glow)}
@media (max-width:560px){.hordeband__track img{width:108px;height:108px}}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{max-width:1200px;margin:0 auto;padding:80px 5vw 120px;text-align:center}
.gallery__head{margin-bottom:54px}
.gallery__head p{color:var(--text-dim);margin-top:10px}
.gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media (max-width:860px){.gallery__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.gallery__grid{grid-template-columns:1fr}}
.card{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--line);background:var(--panel);transform-style:preserve-3d;transition:box-shadow .4s,border-color .4s;cursor:none}
.card img{width:100%;aspect-ratio:1;object-fit:cover;transition:transform .5s var(--ease)}
.card:hover{border-color:var(--tox);box-shadow:0 24px 60px rgba(0,0,0,.6),var(--glow)}
.card:hover img{transform:scale(1.07);animation:flinchCard .55s ease}
@keyframes flinchCard{0%{transform:scale(1)}14%{transform:scale(1.12) rotate(-2deg)}30%{transform:scale(1.06) rotate(2deg)}46%{transform:scale(1.1) rotate(-1deg)}100%{transform:scale(1.07) rotate(0)}}
.card figcaption{position:absolute;left:0;bottom:0;width:100%;padding:18px;text-align:left;background:linear-gradient(transparent,rgba(6,10,2,.95));transform:translateY(20px);opacity:0;transition:.4s var(--ease)}
.card:hover figcaption{transform:translateY(0);opacity:1}
.card figcaption span{display:block;font-family:var(--font-hand);color:var(--tox);font-size:.8rem;letter-spacing:1px}
.card figcaption b{font-family:var(--font-disp);font-size:1.3rem;letter-spacing:1px;color:#fff}

/* ============================================================
   COLLECTION
   ============================================================ */
.collection{padding:110px 5vw;position:relative;overflow:hidden}
.collection__bg{position:absolute;inset:0;background:radial-gradient(700px 500px at 50% 0%,rgba(182,255,0,.08),transparent 70%);pointer-events:none}
.collection__head{text-align:center;margin-bottom:60px;position:relative}
.collection__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;max-width:1200px;margin:0 auto;position:relative}
@media (max-width:980px){.collection__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.collection__grid{grid-template-columns:1fr}}
.detail{padding:40px 30px;border:1px solid var(--line);border-radius:22px;background:linear-gradient(180deg,var(--panel-2),var(--panel));text-align:center;transition:transform .4s var(--ease),border-color .4s,box-shadow .4s}
.detail:hover{transform:translateY(-8px);border-color:var(--tox);box-shadow:0 22px 50px rgba(0,0,0,.5),var(--glow)}
.detail__icon{font-size:2.4rem;margin-bottom:14px;filter:drop-shadow(0 0 12px rgba(182,255,0,.5))}
.detail__big{display:block;font-family:var(--font-disp);font-size:3.4rem;color:var(--tox);letter-spacing:1px;text-shadow:0 0 14px rgba(182,255,0,.22);line-height:1}
.detail__label{display:block;text-transform:uppercase;letter-spacing:3px;font-size:.85rem;color:#fff;margin:10px 0 14px}
.detail p{color:var(--text-dim);font-size:.98rem}

/* ============================================================
   ROADMAP
   ============================================================ */
.roadmap{max-width:980px;margin:0 auto;padding:110px 5vw}
.roadmap__head{text-align:center;margin-bottom:64px}
.timeline{position:relative;padding-left:20px}
.tl__line{position:absolute;left:39px;top:8px;bottom:8px;width:4px;background:var(--line);border-radius:4px;overflow:hidden}
.tl__progress{position:absolute;top:0;left:0;width:100%;height:0;background:linear-gradient(var(--tox),var(--tox-deep));box-shadow:0 0 14px var(--tox)}
.tl__item{position:relative;display:flex;gap:30px;align-items:flex-start;margin-bottom:40px;padding-left:0}
.tl__node{flex:none;width:58px;height:58px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-disp);font-size:1.4rem;color:var(--ink);background:var(--tox);box-shadow:0 0 0 6px var(--ink),var(--glow);z-index:2;position:relative}
.tl__card{flex:1;background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:18px;padding:24px 28px;transition:transform .4s var(--ease),border-color .4s,box-shadow .4s}
.tl__item:hover .tl__card{transform:translateX(8px);border-color:var(--tox);box-shadow:0 16px 40px rgba(0,0,0,.5)}
.tl__card h3{font-family:var(--font-disp);font-size:1.5rem;letter-spacing:1px;color:var(--tox);margin-bottom:8px}
.tl__card p{color:var(--text-dim)}
@media (max-width:560px){.tl__line{left:29px}.tl__node{width:44px;height:44px;font-size:1.1rem}.tl__item{gap:18px}}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:840px;margin:0 auto;padding:90px 5vw 110px}
.faq__head{text-align:center;margin-bottom:48px}
.faq__list{display:grid;gap:14px}
.faq__item{border:1px solid var(--line);border-radius:16px;background:var(--panel);overflow:hidden;transition:border-color .3s,box-shadow .3s}
.faq__item[open]{border-color:var(--tox);box-shadow:0 12px 30px rgba(0,0,0,.4)}
.faq__item summary{list-style:none;cursor:none;padding:22px 26px;font-family:var(--font-disp);font-size:1.25rem;letter-spacing:.5px;color:#fff;display:flex;justify-content:space-between;align-items:center;gap:16px;transition:color .3s}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary:hover{color:var(--tox)}
.faq__item summary i{flex:none;width:26px;height:26px;position:relative}
.faq__item summary i::before,.faq__item summary i::after{content:"";position:absolute;background:var(--tox);border-radius:2px;transition:transform .3s}
.faq__item summary i::before{top:12px;left:3px;width:20px;height:3px}
.faq__item summary i::after{top:3px;left:12px;width:3px;height:20px}
.faq__item[open] summary i::after{transform:rotate(90deg);opacity:0}
.faq__body{padding:0 26px 22px;color:var(--text-dim);animation:fadeUp .4s var(--ease)}
.faq__body a{color:var(--tox);text-decoration:underline}
@keyframes fadeUp{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   JOIN CTA
   ============================================================ */
.join{position:relative;text-align:center;padding:130px 5vw;overflow:hidden;border-top:1px solid var(--line)}
.join__glow{position:absolute;width:900px;height:900px;left:50%;top:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(182,255,0,.16),transparent 60%);filter:blur(30px);animation:pulseGlow 7s ease-in-out infinite}
.join__goblin{position:absolute;right:6%;bottom:0;width:200px;border-radius:18px;opacity:.85;transform:rotate(6deg);box-shadow:0 0 0 3px rgba(182,255,0,.3)}
@media (max-width:900px){.join__goblin{display:none}}
.join__inner{position:relative;z-index:2;max-width:720px;margin:0 auto}
.join h2{font-family:var(--font-disp);font-weight:400;font-size:clamp(2.2rem,6vw,4.4rem);line-height:1;color:#fff;letter-spacing:1px;margin-bottom:18px}
.join p{color:var(--text-dim);font-size:1.15rem;margin-bottom:34px}
.join__cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{border-top:1px solid var(--line);padding:50px 5vw 30px;background:var(--ink-2)}
.footer__top{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;max-width:1200px;margin:0 auto;padding-bottom:30px;border-bottom:1px solid var(--line-soft)}
.footer__brand{display:flex;align-items:center;gap:12px;font-family:var(--font-disp);font-size:1.5rem;letter-spacing:2px;color:var(--tox)}
.footer__brand img{width:40px;height:40px;border-radius:10px;box-shadow:0 0 14px rgba(182,255,0,.5)}
.footer__links{display:flex;gap:24px;flex-wrap:wrap}
.footer__links a{color:var(--text-dim);font-weight:500;transition:color .25s}
.footer__links a:hover{color:var(--tox)}
.footer__x{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;border:1px solid var(--line);color:var(--text-dim);transition:.3s}
.footer__x:hover{color:var(--tox);border-color:var(--tox);box-shadow:var(--glow);transform:translateY(-2px)}
.footer__bottom{max-width:1200px;margin:24px auto 0;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;color:var(--text-dim);font-size:.85rem}
.footer__dis{opacity:.6}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{position:fixed;inset:0;z-index:9000;background:rgba(3,6,1,.9);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:.35s;padding:5vw}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:90vw;max-height:85vh;border-radius:20px;border:3px solid var(--tox);box-shadow:0 0 60px rgba(182,255,0,.5);transform:scale(.9);transition:transform .35s var(--ease)}
.lightbox.open img{transform:scale(1)}
.lightbox__close{position:absolute;top:24px;right:30px;width:48px;height:48px;border-radius:50%;border:1px solid var(--line);background:rgba(182,255,0,.08);color:var(--tox);font-size:1.4rem;cursor:none;transition:.3s}
.lightbox__close:hover{background:var(--tox);color:var(--ink);transform:rotate(90deg)}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal,.reveal-left,.reveal-right{opacity:0;transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal{transform:translateY(40px)}
.reveal-left{transform:translateX(-50px)}
.reveal-right{transform:translateX(50px)}
.reveal.in,.reveal-left.in,.reveal-right.in{opacity:1;transform:none}

.floaty{animation:floaty 6s ease-in-out infinite}
@keyframes floaty{50%{transform:translateY(-18px) rotate(var(--rot,0deg))}}
.hero__float--1.floaty{animation-name:floaty1}
.hero__float--2.floaty{animation-name:floaty2}
@keyframes floaty1{0%,100%{transform:rotate(-8deg) translateY(0)}50%{transform:rotate(-8deg) translateY(-22px)}}
@keyframes floaty2{0%,100%{transform:rotate(7deg) translateY(0)}50%{transform:rotate(7deg) translateY(-26px)}}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal,.reveal-left,.reveal-right{opacity:1;transform:none}
}

/* ============================================================
   MOBILE NAV
   ============================================================ */
@media (max-width:900px){
  .nav__links{position:fixed;inset:0 0 0 auto;width:75%;max-width:320px;flex-direction:column;justify-content:center;gap:34px;background:rgba(6,10,2,.97);backdrop-filter:blur(16px);transform:translateX(100%);transition:transform .4s var(--ease);padding:40px;border-left:1px solid var(--line)}
  .nav__links.open{transform:translateX(0)}
  .nav__link{font-family:var(--font-disp);font-size:1.6rem;color:#fff}
  .nav__burger{display:flex;z-index:201}
  .nav__actions .btn--mint{display:none}
}
