/* ============================================================
   MONSTERS: BATTLE EVOLUTION — landing styles
   Vibe: early-2000s Saturday-morning card-battle anime,
   holographic Tron arenas, neon energy.
   ============================================================ */
:root{
  --bg:#05060f;
  --bg2:#0a0c1e;
  --ink:#eaf2ff;
  --muted:#9aa6c8;
  --cyan:#27e7ff;
  --cyan-d:#0bb4d4;
  --magenta:#ff3ea5;
  --violet:#8a5cff;
  --gold:#ffcf3a;
  --red:#ff4338;
  --grid:#1b8fff;
  --edge:rgba(39,231,255,.22);
  --glass:rgba(14,20,42,.62);
  --maxw:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:'Rajdhani',system-ui,sans-serif;
  width:100%;position:relative;
  background:
    radial-gradient(1200px 700px at 50% -10%, #142046 0%, transparent 60%),
    radial-gradient(900px 600px at 90% 20%, rgba(138,92,255,.16), transparent 55%),
    radial-gradient(900px 600px at 10% 30%, rgba(255,62,165,.12), transparent 55%),
    var(--bg);
}
h1,h2,h3,h4{font-family:'Orbitron',sans-serif;margin:0;letter-spacing:.02em}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
section{position:relative}

/* ---------- ambient overlays ---------- */
.bg-stars{position:fixed;inset:0;z-index:0;pointer-events:none}
.bg-stars i{position:absolute;width:2px;height:2px;border-radius:50%;background:#fff;opacity:.5;animation:tw 4s infinite ease-in-out}
@keyframes tw{0%,100%{opacity:.15}50%{opacity:.8}}
.scanlines{position:fixed;inset:0;z-index:60;pointer-events:none;
  background:repeating-linear-gradient(to bottom,rgba(0,0,0,0) 0,rgba(0,0,0,0) 2px,rgba(0,0,0,.18) 3px,rgba(0,0,0,0) 4px);
  mix-blend-mode:multiply;opacity:.5}
.vignette{position:fixed;inset:0;z-index:59;pointer-events:none;
  box-shadow:inset 0 0 240px 40px rgba(0,0,0,.75)}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;
  transition:.3s;backdrop-filter:blur(0px)}
.nav.solid{background:linear-gradient(to bottom,rgba(5,6,15,.92),rgba(5,6,15,.6));
  backdrop-filter:blur(10px);border-bottom:1px solid var(--edge)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:14px 22px;display:flex;align-items:center;gap:24px}
.brand{display:flex;align-items:center;gap:10px;font-family:'Russo One';font-size:22px}
.brand-mark{color:var(--cyan);text-shadow:0 0 14px var(--cyan)}
.brand-text{letter-spacing:3px}
.brand-x{color:var(--magenta);text-shadow:0 0 12px var(--magenta)}
.nav-links{display:flex;gap:26px;margin-left:auto;font-weight:600;font-size:15px;letter-spacing:.06em;text-transform:uppercase}
.nav-links a{color:var(--muted);position:relative;transition:.2s}
.nav-links a:hover{color:var(--cyan)}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;background:var(--cyan);box-shadow:0 0 8px var(--cyan);transition:right .25s}
.nav-links a:hover::after{right:0}
.cta-pill{position:relative;overflow:hidden;padding:10px 20px;border-radius:40px;
  font-family:'Orbitron';font-weight:700;font-size:13px;letter-spacing:.08em;
  background:linear-gradient(120deg,var(--magenta),var(--violet));
  box-shadow:0 0 18px rgba(255,62,165,.5);transition:.2s}
.cta-pill:hover{transform:translateY(-2px);box-shadow:0 0 28px rgba(255,62,165,.8)}
.cta-glow{position:absolute;top:0;left:-60%;width:40%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);
  animation:sweep 3.2s infinite}
@keyframes sweep{0%{left:-60%}60%,100%{left:130%}}
/* nav "ENTER ARENA" stays hidden over the jumbotron (the hero already has that CTA);
   it fades in only once you've scrolled past the hero button */
.cta-pill{opacity:0;pointer-events:none;
  transition:opacity .3s ease, transform .3s ease, box-shadow .2s}
@media(max-width:760px){.nav-links{display:none}}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;
  overflow:hidden;z-index:1}
/* full-bleed high-energy backdrop */
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center;
  animation:bgdrift 24s ease-in-out infinite}
@keyframes bgdrift{0%,100%{transform:scale(1.05)}50%{transform:scale(1.14)}}
.hero-bg-glow{position:absolute;inset:0;z-index:1;pointer-events:none;mix-blend-mode:screen;
  background:radial-gradient(42% 38% at 50% 46%,rgba(39,231,255,.32),transparent 70%);
  animation:burst 4.5s ease-in-out infinite}
.hero-bg-overlay{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    radial-gradient(72% 62% at 50% 44%,transparent,rgba(5,6,15,.5) 78%,rgba(5,6,15,.92) 100%),
    linear-gradient(to bottom,rgba(5,6,15,.5) 0%,transparent 24%,transparent 56%,rgba(5,6,15,.86) 90%,var(--bg) 100%)}

/* champions sweeping in from the sides */
.hero-mon-wrap{position:absolute;bottom:4%;z-index:3;pointer-events:none;height:min(86vh,780px)}
.hmw-l{left:0;animation:sweepL 1s cubic-bezier(.18,.7,.2,1) both}
.hmw-r{right:0;animation:sweepR 1s cubic-bezier(.18,.7,.2,1) both}
@keyframes sweepL{from{opacity:0;transform:translateX(-55%)}to{opacity:1;transform:translateX(0)}}
@keyframes sweepR{from{opacity:0;transform:translateX(55%)}to{opacity:1;transform:translateX(0)}}
.hero-mon{height:100%;width:auto;
  filter:drop-shadow(0 14px 30px rgba(0,0,0,.6)) drop-shadow(0 0 42px rgba(39,231,255,.3));
  animation:monbob 6.5s ease-in-out infinite}
@keyframes monbob{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}

.hero-stage{position:relative;z-index:5;text-align:center;max-width:920px;padding:0 20px;margin-bottom:3vh;
  will-change:transform}
@media(max-width:820px){
  /* vertical only — horizontal placement is set by JS (heroFaces) so each champion's
     FACE lands at the screen edge regardless of width. Height is capped (max size).
     No slide-in animation here — its translateX would fight the JS px positioning. */
  .hero-mon-wrap{height:min(86vh,680px);bottom:16%;opacity:.92}
  .hmw-l,.hmw-r{animation:fadein 1.1s ease both}
  .hero-mon{max-width:none;animation:none}  /* no bob on mobile — it would offset the JS-set position */
}
@keyframes fadein{from{opacity:0}to{opacity:.92}}

.hero-title{position:relative;z-index:6;transform:translate3d(var(--mx,0),var(--my,0),0)}
/* energy burst radiating behind the wordmark */
.hero-title::before{content:"";position:absolute;left:50%;top:34%;transform:translate(-50%,-50%);
  width:min(900px,120%);height:min(560px,80vh);z-index:-1;pointer-events:none;
  background:radial-gradient(closest-side,rgba(39,231,255,.30),rgba(138,92,255,.14) 45%,transparent 72%);
  filter:blur(6px);animation:burst 5s ease-in-out infinite}
@keyframes burst{0%,100%{opacity:.7;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}}
.title-monsters{
  position:relative;font-family:'Russo One';
  font-size:clamp(54px,11.6vw,152px);line-height:.84;letter-spacing:.01em;
  color:#eafaff;
  background:linear-gradient(180deg,#ffffff 0%,#dff4ff 30%,#7fe6ff 52%,var(--cyan) 66%,#0a86c9 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  -webkit-text-stroke:2px rgba(4,28,52,.35);
  /* hard bevel extrude + neon bloom */
  filter:
    drop-shadow(0 2px 0 #0b4f72) drop-shadow(0 4px 0 #073e5e) drop-shadow(0 7px 1px #04243a)
    drop-shadow(0 10px 18px rgba(0,0,0,.55))
    drop-shadow(0 0 30px rgba(39,231,255,.65));
  animation:titlePulse 3.6s ease-in-out infinite}
@keyframes titlePulse{0%,100%{filter:drop-shadow(0 2px 0 #0b4f72) drop-shadow(0 4px 0 #073e5e) drop-shadow(0 7px 1px #04243a) drop-shadow(0 10px 18px rgba(0,0,0,.55)) drop-shadow(0 0 26px rgba(39,231,255,.55))}50%{filter:drop-shadow(0 2px 0 #0b4f72) drop-shadow(0 4px 0 #073e5e) drop-shadow(0 7px 1px #04243a) drop-shadow(0 10px 18px rgba(0,0,0,.55)) drop-shadow(0 0 46px rgba(39,231,255,.95))}}
/* sheen sweep across the wordmark */
.title-monsters::after{content:"MONSTER";position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 38%,rgba(255,255,255,.85) 50%,transparent 62%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  background-size:250% 100%;animation:sheen 5.5s linear infinite}
@keyframes sheen{0%{background-position:160% 0}55%,100%{background-position:-60% 0}}
.title-sub{display:flex;gap:clamp(12px,2.6vw,34px);justify-content:center;align-items:baseline;margin-top:8px}
.title-sub span{font-family:'Russo One';font-size:clamp(26px,6.4vw,86px);line-height:1;letter-spacing:.05em}
.ts-battle{color:#fff;-webkit-text-stroke:1.5px rgba(255,62,165,.55);
  text-shadow:0 0 26px var(--magenta),0 4px 0 #7a1450,0 6px 0 #4d0c33}
.ts-evolution{
  background:linear-gradient(180deg,#fff,var(--gold) 52%,#b87900);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 4px 0 #6b4a00) drop-shadow(0 0 22px rgba(255,207,58,.7))}
.hero-tag{margin:22px auto 26px;max-width:640px;font-size:clamp(15px,2vw,20px);color:var(--ink);font-weight:600;letter-spacing:.02em}
.hero-tag b{color:var(--gold)}
.hero-actions{display:flex;flex-direction:column;gap:18px;align-items:center;justify-content:center}

/* champions flanking the arena, rising from the grid (transparent cutouts) */
.float-mon{position:absolute;z-index:4;bottom:0;width:clamp(160px,21vw,300px);
  filter:drop-shadow(0 14px 22px rgba(0,0,0,.6)) drop-shadow(0 0 30px rgba(39,231,255,.3));
  will-change:transform;animation:bob 6.5s ease-in-out infinite;
  -webkit-mask-image:linear-gradient(to bottom,#000 86%,transparent 100%);
  mask-image:linear-gradient(to bottom,#000 86%,transparent 100%)} /* feet dissolve into the grid */
.fm1{left:-44%;animation-delay:0s}              /* lava beast, faces right toward arena */
.fm2{right:-46%;animation-delay:-2.4s}          /* ice beast, faces left toward arena */
@keyframes bob{0%,100%{transform:translateY(0) rotate(-.6deg)}50%{transform:translateY(-14px) rotate(.6deg)}}
@media(max-width:780px){
  .float-mon{width:clamp(120px,30vw,160px)}
  .fm1{left:-26%}.fm2{right:-28%}
}

.hero-stats{display:flex;gap:30px;justify-content:center;margin-top:40px;flex-wrap:wrap}
.hstat{display:flex;flex-direction:column;align-items:center}
.hstat b{font-family:'Orbitron';font-size:30px;color:var(--cyan);text-shadow:0 0 16px rgba(39,231,255,.6)}
.hstat span{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

.scroll-cue{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:6;
  font-size:11px;letter-spacing:.3em;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue span{width:18px;height:28px;border:2px solid var(--muted);border-radius:12px;position:relative}
.scroll-cue span::after{content:"";position:absolute;left:50%;top:6px;width:3px;height:7px;background:var(--cyan);border-radius:2px;transform:translateX(-50%);animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:0;top:6px}40%{opacity:1}100%{opacity:0;top:15px}}

/* contract address bar — bottom of the jumbotron */
.hero-contract{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:7;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center;max-width:94vw;
  padding:8px 14px;border-radius:30px;background:rgba(8,12,26,.72);backdrop-filter:blur(8px);
  border:1px solid var(--edge);box-shadow:0 0 22px rgba(39,231,255,.18)}
.hc-label{font-family:'Orbitron';font-weight:700;font-size:11px;letter-spacing:.14em;color:var(--gold)}
.hc-addr{font-family:'Courier Prime',monospace;font-size:12px;color:var(--ink);
  max-width:42vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hc-copy{font-family:'Orbitron';font-weight:700;font-size:10px;letter-spacing:.1em;cursor:pointer;
  color:#021018;background:linear-gradient(120deg,var(--cyan),#8ff6ff);border:0;
  padding:5px 11px;border-radius:20px;transition:.2s}
.hc-copy:hover{box-shadow:0 0 14px rgba(39,231,255,.7)}
.hc-copy.copied{background:linear-gradient(120deg,#39d98a,#9af6c4)}
.hc-soon{font-family:'Orbitron';font-weight:700;font-size:10px;letter-spacing:.1em;color:var(--gold);
  background:rgba(255,184,77,.10);border:1px solid rgba(255,184,77,.40);padding:5px 11px;border-radius:20px;white-space:nowrap}
@media(max-width:560px){.hc-addr{max-width:50vw}}

/* nav X / social icon */
.nav-social{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;
  color:var(--muted);border:1px solid var(--edge);transition:.2s}
.nav-social:hover{color:var(--cyan);border-color:var(--cyan);box-shadow:0 0 14px rgba(39,231,255,.4);transform:translateY(-2px)}

/* ---------- buttons ---------- */
.btn{position:relative;overflow:hidden;display:inline-block;
  font-family:'Orbitron';font-weight:700;letter-spacing:.08em;font-size:15px;
  padding:15px 30px;border-radius:8px;cursor:pointer;transition:transform .15s, box-shadow .2s;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px)}
.btn-primary{color:#021018;background:linear-gradient(120deg,var(--cyan),#8ff6ff);
  box-shadow:0 0 24px rgba(39,231,255,.5),inset 0 0 0 1px rgba(255,255,255,.4)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 0 38px rgba(39,231,255,.9)}
.btn-ghost{color:var(--ink);background:rgba(20,28,56,.55);border:1px solid var(--edge)}
.btn-ghost:hover{transform:translateY(-3px);color:var(--cyan);border-color:var(--cyan);box-shadow:0 0 20px rgba(39,231,255,.4)}
.btn.sm{padding:12px 22px;font-size:13px}
.btn.big{padding:20px 46px;font-size:20px}
.btn-shine{position:absolute;top:0;left:-70%;width:45%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.7),transparent);transform:skewX(-20deg);animation:sweep 3.5s infinite}
/* locked (pre-launch) CTA */
.btn-locked{cursor:not-allowed;background:linear-gradient(120deg,#16203a,#1d2a4a)!important;
  color:var(--gold)!important;border:1px solid rgba(255,207,58,.45);box-shadow:0 0 18px rgba(255,207,58,.12)!important;
  -webkit-text-fill-color:var(--gold)}
.btn-locked .btn-shine{display:none}

/* ---------- launch countdown ---------- */
.countdown{display:inline-flex;flex-direction:column;align-items:center;gap:9px;
  padding:14px 24px;border-radius:12px;background:rgba(8,12,26,.62);border:1px solid var(--edge);
  box-shadow:0 0 28px rgba(39,231,255,.2)}
.cd-label{font-family:'Orbitron';font-weight:700;font-size:12px;letter-spacing:.2em;color:var(--gold);
  text-shadow:0 0 10px rgba(255,207,58,.4)}
.cd-grid{display:flex;align-items:flex-start;gap:12px}
.cd-u{display:flex;flex-direction:column;align-items:center;min-width:46px}
.cd-u b{font-family:'Orbitron';font-weight:900;font-size:clamp(28px,6vw,40px);line-height:1;color:#fff;
  text-shadow:0 0 16px rgba(39,231,255,.65)}
.cd-u span{font-family:'Orbitron';font-size:9px;letter-spacing:.16em;color:var(--muted);margin-top:5px}
.cd-colon{font-family:'Orbitron';font-weight:900;font-size:clamp(24px,5vw,34px);color:var(--cyan);opacity:.65;line-height:1}
/* nav compact countdown */
.cd-nav{display:flex;align-items:center;gap:8px;padding:9px 15px;border-radius:30px;
  font-family:'Orbitron';font-weight:700;font-size:13px;letter-spacing:.03em;color:var(--cyan);white-space:nowrap;
  background:rgba(8,12,26,.72);border:1px solid var(--edge);box-shadow:0 0 14px rgba(39,231,255,.18)}
.cd-nav-dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 8px var(--red);animation:tw 1.4s infinite}
@media(max-width:760px){.cd-nav{font-size:11px;padding:7px 11px}}

/* ---------- ticker ---------- */
.ticker{position:relative;z-index:6;overflow:hidden;white-space:nowrap;
  background:linear-gradient(90deg,#16071f,#1a0a2e,#07101f);
  border-top:1px solid var(--edge);border-bottom:1px solid var(--edge);padding:10px 0}
.ticker-track{display:inline-block;animation:scrollx 26s linear infinite}
.ticker-track span{font-family:'Orbitron';font-weight:700;font-size:14px;letter-spacing:.1em;
  color:var(--cyan);margin:0 28px;text-shadow:0 0 10px rgba(39,231,255,.5)}
.ticker-track span:nth-child(even){color:var(--magenta);text-shadow:0 0 10px rgba(255,62,165,.5)}
@keyframes scrollx{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ---------- generic section ---------- */
.section{padding:110px 22px;max-width:100%;z-index:2;overflow-x:clip}
.sec-head{max-width:var(--maxw);margin:0 auto 56px}
.kicker{display:inline-block;font-family:'Orbitron';font-weight:700;font-size:12px;letter-spacing:.3em;
  color:var(--magenta);border:1px solid rgba(255,62,165,.4);padding:6px 14px;border-radius:4px;margin-bottom:20px;
  text-shadow:0 0 10px rgba(255,62,165,.4)}
.sec-head h2{font-size:clamp(32px,5.5vw,62px);line-height:1.02;letter-spacing:.01em}
.hl{background:linear-gradient(120deg,var(--cyan),#8ff6ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 16px rgba(39,231,255,.4))}
.hl-red{background:linear-gradient(120deg,var(--red),#ff9a6a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hl-gold{background:linear-gradient(120deg,var(--gold),#fff1b8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 16px rgba(255,207,58,.4))}
.lead{margin-top:22px;max-width:680px;font-size:clamp(16px,2vw,20px);line-height:1.55;color:var(--muted)}
.lead b{color:var(--ink)}

/* DISCRETE tron divider — a thin band of receding grid that marks a section seam.
   Lives inside an overflow-clipped section so it can never create horizontal scroll. */
/* 3D Tron perspective-grid divider — a single floor plane spanning the full width at each seam */
.grid-divider3d{position:absolute;top:-44px;left:0;width:100%;height:150px;display:block;
  pointer-events:none;z-index:0;opacity:.9;
  -webkit-mask-image:linear-gradient(to bottom,transparent,#000 22%,#000 80%,transparent);
  mask-image:linear-gradient(to bottom,transparent,#000 22%,#000 80%,transparent)}

/* ---------- FORGE ---------- */
.forge-stage{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.mv-poster{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:14px}
.mv-poster img{max-height:340px;width:auto;filter:drop-shadow(0 0 30px rgba(39,231,255,.4))}
.mv-loading{font-family:'Orbitron';font-size:12px;letter-spacing:.2em;color:var(--cyan);animation:tw 1.4s infinite}

/* forge result "card" */
.forge-card{display:flex;flex-direction:column;align-items:center;gap:16px}
.fc-frame{position:relative;width:min(360px,80%);aspect-ratio:3/4;border-radius:16px;overflow:hidden;
  border:2px solid rgba(39,231,255,.5);
  box-shadow:0 0 40px rgba(39,231,255,.3),inset 0 0 30px rgba(0,0,0,.5),0 30px 60px rgba(0,0,0,.6);
  background:linear-gradient(160deg,#101a3a,#0a0c1e)}
.fc-frame img{width:100%;height:100%;object-fit:cover}
.fc-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(5,6,15,.92),transparent 45%)}
.fc-holo{position:absolute;inset:0;z-index:2;pointer-events:none;mix-blend-mode:screen;opacity:.55;
  background:linear-gradient(115deg,transparent 35%,rgba(39,231,255,.35) 48%,rgba(255,62,165,.25) 56%,transparent 68%);
  background-size:300% 300%;animation:holo 4.5s linear infinite}
.fc-lv{position:absolute;top:12px;right:12px;z-index:3;font-family:'Orbitron';font-weight:700;font-size:13px;
  color:#021018;background:linear-gradient(120deg,var(--gold),#fff1b8);padding:5px 11px;border-radius:20px;box-shadow:0 0 14px rgba(255,207,58,.6)}
.fc-name{position:absolute;left:0;right:0;bottom:14px;z-index:3;text-align:center;
  font-family:'Orbitron';font-weight:700;font-size:16px;color:#fff;text-shadow:0 2px 8px #000;letter-spacing:.03em}
.fc-caption{font-family:'Orbitron';font-size:12px;letter-spacing:.12em;color:var(--muted)}
.fc-caption b{color:var(--cyan)}

/* $RARE heart centerpiece */
.econ-hero{max-width:var(--maxw);margin:0 auto 54px;display:grid;grid-template-columns:.9fr 1.1fr;gap:40px;align-items:center}
.heart-3d{position:relative}
/* pulsing energy halo radiating from the heart */
.heart-3d::before{content:"";position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);
  width:70%;height:70%;z-index:0;pointer-events:none;border-radius:50%;
  background:radial-gradient(closest-side,rgba(39,231,255,.5),rgba(255,207,58,.22) 45%,transparent 72%);
  filter:blur(10px);animation:heartpulse 2.4s ease-in-out infinite}
@keyframes heartpulse{0%,100%{opacity:.6;transform:translate(-50%,-50%) scale(.92)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.12)}}
#heartCanvas{position:relative;z-index:1;display:block;width:100%;height:460px;
  filter:drop-shadow(0 0 30px rgba(255,207,58,.35))}
@media(max-width:880px){#heartCanvas{height:340px}}
.heart-base{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);width:62%;height:34px;
  background:radial-gradient(ellipse at center,rgba(255,207,58,.5),transparent 70%);filter:blur(6px)}
.heart-tag{text-align:center;margin-top:6px;font-family:'Orbitron';font-weight:700;font-size:15px;letter-spacing:.1em;color:var(--gold)}
.heart-tag span{color:var(--muted);font-weight:500}
.econ-intro .kicker{margin-bottom:18px}
.econ-intro h2{font-size:clamp(30px,4.6vw,54px);line-height:1.02}
.econ-intro .lead{margin-top:18px}
@media(max-width:880px){.econ-hero{grid-template-columns:1fr;gap:18px;text-align:center}.heart-3d model-viewer,.heart-3d #heartModel{height:360px}.econ-intro .lead{margin-left:auto;margin-right:auto}}

/* horizontal champion carousel — a draggable wheel, seamless loop */
.forge-carousel{display:flex;gap:16px;overflow-x:auto;overflow-y:hidden;align-items:center;
  /* generous vertical padding so the hover lift+scale isn't clipped by the scroll box */
  padding:30px 22px 30px;margin:0 calc(50% - 50vw);scrollbar-width:none;-webkit-overflow-scrolling:touch;
  cursor:grab;user-select:none;-webkit-user-select:none;
  -webkit-mask-image:linear-gradient(to right,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(to right,transparent,#000 6%,#000 94%,transparent)}
.forge-carousel.drag{cursor:grabbing}
.forge-carousel.drag .mon-card{pointer-events:none}
.forge-carousel::-webkit-scrollbar{display:none}
.forge-carousel .mon-card{flex:0 0 auto;width:clamp(190px,23vw,244px);aspect-ratio:3/4}
/* carousel cards show only image + level + name (no encyclopedia/dex description) */
.forge-carousel .mon-card .mon-desc{display:none}

.forge-howto{max-width:760px;margin:14px auto 0;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}
.recipe-row{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}
.chip{position:relative;background:var(--glass);border:1px solid var(--edge);border-radius:8px;
  padding:10px 16px;font-weight:700;font-size:16px;min-width:120px;text-align:center}
.chip-k{display:block;font-family:'Orbitron';font-size:9px;letter-spacing:.18em;color:var(--muted);margin-bottom:3px}
.chip-essence{border-color:rgba(255,62,165,.5);box-shadow:0 0 18px rgba(255,62,165,.25)}
.chip-essence .chip-k{color:var(--magenta)}
.plus{font-family:'Orbitron';color:var(--muted);font-size:18px}
.recipe-arrow{font-family:'Orbitron';color:var(--gold);letter-spacing:.12em;font-size:14px}
.forge-points{list-style:none;padding:0;margin:22px 0;display:grid;grid-template-columns:repeat(2,1fr);gap:14px 26px;text-align:left}
.forge-points li{position:relative;padding-left:26px;color:var(--muted);line-height:1.4;font-size:15px}
.forge-points li b{color:var(--ink)}
.forge-points li::before{content:"◆";position:absolute;left:0;top:0;color:var(--cyan);text-shadow:0 0 8px var(--cyan)}
@media(max-width:620px){.forge-points{grid-template-columns:1fr}}

/* ---------- BATTLE / VIDEO ---------- */
.video-feature{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.6fr .8fr;gap:24px;align-items:stretch}
.feat-video{width:100%;border-radius:12px;border:1px solid var(--edge);background:#000;
  box-shadow:0 0 50px rgba(39,231,255,.18),0 30px 60px rgba(0,0,0,.6);aspect-ratio:16/10;object-fit:cover}
.feat-meta{display:flex;flex-direction:column;justify-content:center;
  background:var(--glass);border:1px solid var(--edge);border-radius:12px;padding:26px}
.feat-meta{font-family:'Orbitron';font-size:12px;letter-spacing:.18em;color:var(--magenta)}
.feat-meta h3{font-size:24px;margin:14px 0 8px;color:#fff;letter-spacing:0;line-height:1.15}
.feat-meta h3 em{color:var(--red);font-style:normal}
.feat-meta p{font-family:'Rajdhani';font-size:15px;letter-spacing:.04em;color:var(--muted)}
.live-dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--red);margin-right:6px;
  box-shadow:0 0 10px var(--red);animation:tw 1.2s infinite}
.video-strip{max-width:var(--maxw);margin:22px auto 0;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.vthumb{position:relative;border:1px solid var(--edge);border-radius:10px;overflow:hidden;cursor:pointer;
  background:#000;padding:0;aspect-ratio:16/10;transition:.2s}
.vthumb img{width:100%;height:100%;object-fit:cover;opacity:.7;transition:.25s}
.vthumb .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:26px;color:#fff;text-shadow:0 0 12px var(--cyan)}
.vthumb:hover{transform:translateY(-4px);border-color:var(--cyan);box-shadow:0 0 22px rgba(39,231,255,.45)}
.vthumb:hover img{opacity:1}
.vthumb.active{border-color:var(--magenta);box-shadow:0 0 22px rgba(255,62,165,.5)}
.vthumb.active img{opacity:1}
@media(max-width:880px){.video-feature{grid-template-columns:1fr}.video-strip{grid-template-columns:repeat(2,1fr)}}

/* ---------- ECONOMY ---------- */
.econ-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.econ-card{position:relative;background:var(--glass);border:1px solid var(--edge);border-radius:14px;padding:26px 22px;
  transition:transform .25s, box-shadow .25s;overflow:hidden;transform-style:preserve-3d}
.econ-card::before{content:"";position:absolute;inset:0;background:linear-gradient(140deg,rgba(39,231,255,.12),transparent 45%);opacity:0;transition:.25s}
.econ-card:hover{transform:translateY(-8px);box-shadow:0 18px 40px rgba(0,0,0,.5),0 0 28px rgba(39,231,255,.3);border-color:var(--cyan)}
.econ-card:hover::before{opacity:1}
.econ-ico{font-size:34px;margin-bottom:14px;filter:drop-shadow(0 0 12px rgba(39,231,255,.5))}
.econ-card h4{font-size:18px;color:#fff;margin-bottom:10px;letter-spacing:.02em}
.econ-card p{color:var(--muted);font-size:15px;line-height:1.5}
@media(max-width:980px){.econ-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.econ-grid{grid-template-columns:1fr}}

.econ-pricetag{position:relative;max-width:880px;margin:50px auto 0;text-align:center;
  background:linear-gradient(160deg,rgba(255,207,58,.08),rgba(20,28,56,.5));
  border:1px solid rgba(255,207,58,.4);border-radius:16px;padding:34px 26px;overflow:hidden}
.pt-glow{position:absolute;top:-40%;left:50%;transform:translateX(-50%);width:60%;height:120%;
  background:radial-gradient(ellipse,rgba(255,207,58,.18),transparent 65%)}
.pt-k{font-family:'Orbitron';font-size:12px;letter-spacing:.24em;color:var(--gold)}
.pt-row{display:flex;align-items:center;justify-content:center;gap:18px;margin:22px 0 14px;flex-wrap:wrap}
.pt-cell{display:flex;flex-direction:column}
.pt-cell b{font-family:'Orbitron';font-size:30px;color:#fff;text-shadow:0 0 14px rgba(255,207,58,.5)}
.pt-cell span{font-size:13px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase}
.pt-arrow{font-family:'Orbitron';color:var(--gold);font-size:20px}
.pt-note{color:var(--muted);font-size:14px;max-width:520px;margin:8px auto 0}

/* ---------- ROSTER ---------- */
.roster-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.mon-card{position:relative;border-radius:14px;overflow:hidden;cursor:pointer;
  background:linear-gradient(160deg,#101938,#0a0c1e);border:1px solid var(--edge);
  aspect-ratio:3/4;transition:transform .25s, box-shadow .25s}
.mon-card .mon-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform .4s ease;filter:saturate(1.05)}
.mon-card::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(5,6,15,.96) 6%,rgba(5,6,15,.2) 45%,transparent 70%)}
.mon-holo{position:absolute;inset:0;z-index:3;opacity:0;transition:.3s;pointer-events:none;
  background:linear-gradient(115deg,transparent 30%,rgba(39,231,255,.25) 45%,rgba(255,62,165,.2) 55%,transparent 70%);
  mix-blend-mode:screen;background-size:300% 300%}
.mon-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 22px 50px rgba(0,0,0,.6),0 0 30px rgba(39,231,255,.4);border-color:var(--cyan);z-index:4}
.mon-card:hover .mon-img{transform:scale(1.12)}
.mon-card:hover .mon-holo{opacity:1;animation:holo 2.4s linear infinite}
@keyframes holo{0%{background-position:0% 50%}100%{background-position:300% 50%}}
.mon-lv{position:absolute;top:10px;right:10px;z-index:5;font-family:'Orbitron';font-weight:700;font-size:12px;
  color:#021018;background:linear-gradient(120deg,var(--gold),#fff1b8);padding:4px 9px;border-radius:20px;
  box-shadow:0 0 14px rgba(255,207,58,.6)}
.mon-info{position:absolute;left:0;right:0;bottom:0;z-index:5;padding:14px}
.mon-name{font-family:'Orbitron';font-weight:700;font-size:15px;color:#fff;line-height:1.1;text-shadow:0 2px 6px #000}
.mon-desc{margin-top:6px;font-size:12.5px;color:var(--muted);line-height:1.35;max-height:0;opacity:0;overflow:hidden;transition:.3s}
.mon-card:hover .mon-desc{max-height:120px;opacity:1}
@media(max-width:1080px){.roster-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:820px){.roster-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.roster-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- FEATURES ---------- */
.feat-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.feat-cell{position:relative;background:var(--glass);border:1px solid var(--edge);border-radius:12px;padding:26px 22px;
  transition:.25s;overflow:hidden}
.feat-cell:hover{border-color:var(--magenta);transform:translateY(-5px);box-shadow:0 0 26px rgba(255,62,165,.3)}
.fno{font-family:'Orbitron';font-weight:900;font-size:34px;color:transparent;-webkit-text-stroke:1px var(--edge);display:block;margin-bottom:8px}
.feat-cell:hover .fno{-webkit-text-stroke-color:var(--magenta);color:rgba(255,62,165,.08)}
.feat-cell h4{font-size:17px;color:#fff;margin-bottom:8px}
.feat-cell p{color:var(--muted);font-size:14.5px;line-height:1.5}
@media(max-width:880px){.feat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.feat-grid{grid-template-columns:1fr}}

/* ---------- FINALE ---------- */
.finale{min-height:78vh;display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center;padding:120px 22px}
.finale-inner{position:relative;z-index:5}
.finale-title{font-family:'Russo One';font-size:clamp(34px,6.5vw,80px);line-height:.98;
  background:linear-gradient(180deg,#fff,var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 0 28px rgba(39,231,255,.5))}
.finale-inner>p{font-size:20px;color:var(--muted);margin:18px 0 30px;font-weight:600}
.finale-chain{margin-top:24px;font-family:'Orbitron';font-size:12px;letter-spacing:.18em;color:var(--muted)}

/* ---------- footer ---------- */
.foot{border-top:1px solid var(--edge);padding:40px 22px;max-width:var(--maxw);margin:0 auto;
  display:flex;flex-wrap:wrap;gap:18px;align-items:center;justify-content:space-between}
.foot-brand{font-family:'Russo One';font-size:20px;letter-spacing:2px}
.foot-brand span{color:var(--muted);font-size:14px}
.foot-links{display:flex;gap:22px}
.foot-links a{color:var(--muted);font-weight:600;transition:.2s}
.foot-links a:hover{color:var(--cyan)}
.foot-fine{width:100%;color:#566;font-size:12px;letter-spacing:.06em}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .7s, transform .7s}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}
