/* ============================================================
   A-NEXO // NEXORIA — Sistema de diseño v2 (Cinematic HUD)
   Dark void + neon cyan · holographic starship interface
   Fuentes: Oxanium (display) · Rajdhani (UI) · Share Tech Mono
   ============================================================ */

:root{
  /* ---------- Color ---------- */
  --bg:        #03060d;
  --bg-2:      #060b18;
  --void:      #01030a;
  --panel:     #0a1322;
  --panel-2:   #0d1a2e;
  --line:      rgba(46, 226, 255, .16);
  --line-soft: rgba(120, 160, 200, .10);

  --cyan:      #2ef2ff;
  --cyan-deep: #0bb8d4;
  --cyan-dim:  #7fe1ee;
  --blue:      #4d9fff;
  --danger:    #ff3b5e;
  --amber:     #ffb23b;
  --gold:      #ffd34d;
  --myth:      #ff6bd0;

  --ink:       #e8f6ff;
  --muted:     #93aac0;
  --muted-2:   #5d7388;

  /* ---------- Type ---------- */
  --display: "Oxanium", system-ui, sans-serif;
  --ui:      "Rajdhani", system-ui, sans-serif;
  --body:    "Rajdhani", system-ui, sans-serif;
  --mono:    "Share Tech Mono", ui-monospace, monospace;

  /* ---------- Geometry ---------- */
  --cut: 16px;
  --maxw: 1280px;
  --glow: 0 0 24px rgba(46,226,255,.35);
  --glow-soft: 0 0 60px rgba(46,226,255,.18);
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  position:relative;
  min-height:100vh;
  letter-spacing:.01em;
}
::selection{background:rgba(46,226,255,.28);color:#fff}

/* ============================================================
   ATMOSPHERE LAYERS  (starfield · nebula · grid floor · scanlines · grain)
   ============================================================ */
#starfield{position:fixed;inset:0;z-index:-4;display:block}

body::before{ /* nebula */
  content:"";position:fixed;inset:0;z-index:-3;pointer-events:none;
  background:
    radial-gradient(1000px 700px at 80% -8%, rgba(46,226,255,.12), transparent 60%),
    radial-gradient(900px 800px at 6% 10%, rgba(77,159,255,.09), transparent 60%),
    radial-gradient(1300px 900px at 50% 118%, rgba(11,184,212,.10), transparent 55%),
    radial-gradient(700px 600px at 92% 88%, rgba(255,107,208,.05), transparent 60%),
    linear-gradient(180deg, var(--void), var(--bg) 40%, var(--bg-2));
}

/* perspective grid floor (injected via app.js) */
.grid-floor{
  position:fixed;left:50%;bottom:-12vh;z-index:-2;pointer-events:none;
  width:240vw;height:78vh;opacity:.42;
  transform:translateX(-50%) perspective(420px) rotateX(74deg);
  transform-origin:bottom center;
  background-image:
    linear-gradient(rgba(46,226,255,.55) 1px, transparent 1px),
    linear-gradient(90deg, rgba(46,226,255,.55) 1px, transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:linear-gradient(transparent, #000 70%);
  mask-image:linear-gradient(transparent, #000 70%);
  animation:grid-move 7s linear infinite;
}
@keyframes grid-move{to{background-position:0 64px}}

body::after{ /* scanlines + grain */
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.55;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.014) 0 1px, transparent 1px 3px),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
  background-size:auto, 160px 160px;
  -webkit-mask-image:radial-gradient(circle at 50% 28%, #000 55%, transparent 100%);
  mask-image:radial-gradient(circle at 50% 28%, #000 55%, transparent 100%);
}

/* ============================================================
   LAYOUT PRIMITIVES
   ============================================================ */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
section{position:relative;padding:104px 0}
.kicker{
  font-family:var(--mono);font-size:.76rem;letter-spacing:.34em;
  text-transform:uppercase;color:var(--cyan);
  display:inline-flex;align-items:center;gap:12px;margin-bottom:20px;
}
.kicker::before{content:"";width:30px;height:1px;background:var(--cyan);box-shadow:var(--glow)}
h1,h2,h3,h4,h5{font-family:var(--display);font-weight:700;line-height:1.02;letter-spacing:.005em}
h2.title{font-size:clamp(2.1rem,5.2vw,3.6rem);text-transform:uppercase;margin-bottom:18px;font-weight:800}
h2.title b{color:var(--cyan);font-weight:800}
.lead{color:var(--muted);max-width:64ch;font-size:1.12rem;font-weight:400}

/* ---------- Panels w/ cut corners + HUD brackets ---------- */
.panel{
  position:relative;background:linear-gradient(160deg,var(--panel),var(--panel-2));
  border:1px solid var(--line);
  clip-path:polygon(var(--cut) 0,100% 0,100% calc(100% - var(--cut)),calc(100% - var(--cut)) 100%,0 100%,0 var(--cut));
}
.bracket{position:relative}
.bracket::before,.bracket::after{
  content:"";position:absolute;width:16px;height:16px;pointer-events:none;
  border-color:var(--cyan);opacity:.7
}
.bracket::before{top:9px;left:9px;border-top:2px solid;border-left:2px solid}
.bracket::after{bottom:9px;right:9px;border-bottom:2px solid;border-right:2px solid}

/* ---------- Buttons ---------- */
.btn{
  --c:var(--cyan);
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;
  padding:14px 28px;color:var(--bg);background:var(--c);text-decoration:none;
  border:1px solid var(--c);cursor:pointer;font-weight:700;position:relative;overflow:hidden;
  clip-path:polygon(11px 0,100% 0,100% calc(100% - 11px),calc(100% - 11px) 100%,0 100%,0 11px);
  transition:.25s ease;box-shadow:0 0 0 rgba(46,226,255,0)
}
.btn::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.5),transparent 70%);
  transform:translateX(-120%);transition:.5s}
.btn:hover{box-shadow:var(--glow),0 0 55px rgba(46,226,255,.28);transform:translateY(-2px)}
.btn:hover::after{transform:translateX(120%)}
.btn.ghost{background:transparent;color:var(--cyan)}
.btn.ghost:hover{background:rgba(46,226,255,.08);color:#fff}

/* ============================================================
   NAV  (shrinks on scroll)
   ============================================================ */
header.nav{position:fixed;top:0;left:0;right:0;z-index:60;
  backdrop-filter:blur(16px);
  background:linear-gradient(180deg, rgba(3,6,13,.92), rgba(3,6,13,.45));
  border-bottom:1px solid var(--line);transition:.32s cubic-bezier(.2,.7,.2,1)}
header.nav.shrink{background:rgba(3,6,13,.96);box-shadow:0 8px 30px rgba(0,0,0,.5)}
.nav-inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;
  justify-content:space-between;padding:16px 26px;transition:padding .32s ease}
header.nav.shrink .nav-inner{padding:9px 26px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink)}
.brand .glyph{width:36px;height:36px;flex:none;transition:.32s ease;filter:drop-shadow(0 0 8px rgba(46,226,255,.45))}
header.nav.shrink .brand .glyph{width:30px;height:30px}
.brand .word{font-family:var(--display);font-weight:800;letter-spacing:.2em;font-size:1.18rem}
.brand .word b{color:var(--cyan)}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{font-family:var(--mono);font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);text-decoration:none;padding:10px 15px;position:relative;transition:.2s}
.nav-links a:hover,.nav-links a.active{color:var(--cyan)}
.nav-links a.active::after{content:"";position:absolute;left:15px;right:15px;bottom:3px;height:2px;
  background:var(--cyan);box-shadow:var(--glow)}
.nav-cta{display:flex;gap:10px;align-items:center}
.nav-cta .btn{padding:11px 18px;font-size:.72rem}
.burger{display:none;background:none;border:1px solid var(--line);color:var(--cyan);
  width:44px;height:44px;cursor:pointer;font-size:1.2rem}

/* ============================================================
   HERO  (full-bleed · holographic Prometeo · orbital ring · glitch)
   ============================================================ */
.hero{min-height:100vh;display:flex;align-items:center;padding:120px 0 80px;
  position:relative;overflow:hidden}

/* full-bleed emblem backdrop (A-NEXO8 optimizado) — muy atenuado para no competir
   con el starfield, la nave Prometeo, los anillos ni el texto */
.hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    linear-gradient(90deg, var(--void) 6%, rgba(1,3,10,.62) 58%, rgba(1,3,10,.9) 100%),
    radial-gradient(circle at 72% 44%, rgba(3,6,13,.18), var(--void) 82%),
    url("assets/optimized/hero-bg.webp") 72% center / cover no-repeat;
  opacity:.5}

/* holographic stage behind content */
.hero-stage{position:absolute;inset:0;z-index:0;pointer-events:none;
  display:flex;align-items:center;justify-content:flex-end}
.hero-stage .stage-inner{position:relative;width:min(70vw,900px);aspect-ratio:1;
  margin-right:-6vw;display:flex;align-items:center;justify-content:center}
.orbit{position:absolute;inset:0;animation:spin 38s linear infinite}
.orbit.r2{animation-duration:26s;animation-direction:reverse;inset:9%}
.orbit.r3{animation-duration:60s;inset:18%}
.orbit svg{width:100%;height:100%;display:block}
@keyframes spin{to{transform:rotate(360deg)}}
.holo-ship{position:absolute;width:78%;
  filter:drop-shadow(0 0 40px rgba(46,226,255,.4));
  animation:float 9s ease-in-out infinite}
@keyframes float{50%{transform:translateY(-22px)}}
.holo-ship .scan{animation:holo-scan 4s linear infinite}
@keyframes holo-scan{0%{transform:translateY(-50px);opacity:0}10%{opacity:.6}90%{opacity:.6}100%{transform:translateY(50px);opacity:0}}

.hero-content{position:relative;z-index:2;max-width:760px}
.hero-tag{font-family:var(--mono);font-size:.76rem;letter-spacing:.32em;color:var(--cyan);
  text-transform:uppercase;margin-bottom:14px;display:inline-flex;gap:10px;align-items:center}
.hero-tag::before{content:"";width:8px;height:8px;background:var(--cyan);box-shadow:var(--glow);
  border-radius:50%;animation:pulse 1.8s ease-in-out infinite}
@keyframes pulse{50%{opacity:.3;transform:scale(.7)}}
.hero h1{font-size:clamp(3.4rem,11vw,8rem);text-transform:uppercase;letter-spacing:.01em;
  margin:0 0 4px;font-weight:800;line-height:.92}

/* glitch title */
.glitch{position:relative;color:var(--ink);text-shadow:0 0 30px rgba(46,226,255,.35)}
.glitch::before,.glitch::after{content:attr(data-text);position:absolute;left:0;top:0;
  width:100%;overflow:hidden;pointer-events:none}
.glitch::before{color:var(--cyan);clip-path:inset(0 0 58% 0);
  animation:glitch-top 3.2s infinite steps(2,end) alternate}
.glitch::after{color:var(--myth);clip-path:inset(54% 0 0 0);
  animation:glitch-bot 2.7s infinite steps(2,end) alternate}
@keyframes glitch-top{
  0%,82%,100%{transform:translate(0,0)}84%{transform:translate(-3px,-2px)}
  88%{transform:translate(3px,1px)}92%{transform:translate(-2px,1px)}96%{transform:translate(2px,-1px)}}
@keyframes glitch-bot{
  0%,80%,100%{transform:translate(0,0)}83%{transform:translate(3px,2px)}
  87%{transform:translate(-3px,-1px)}91%{transform:translate(2px,-1px)}95%{transform:translate(-2px,1px)}}

.hero .motto{font-family:var(--display);font-weight:600;font-size:clamp(1rem,2.6vw,1.7rem);
  letter-spacing:.46em;text-transform:uppercase;color:var(--cyan-dim);margin:10px 0 28px;
  text-shadow:0 0 18px rgba(46,226,255,.4)}
.hero .sub{color:var(--muted);font-size:1.18rem;max-width:56ch;margin-bottom:36px;font-weight:400}
.hero .sub b{color:var(--cyan-dim);font-weight:600}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;
  font-family:var(--mono);font-size:.66rem;letter-spacing:.3em;color:var(--muted-2);
  text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-hint::after{content:"";width:1px;height:34px;
  background:linear-gradient(var(--cyan),transparent);animation:scrolldot 2s ease-in-out infinite}
@keyframes scrolldot{0%{opacity:0;transform:scaleY(.2)}50%{opacity:1}100%{opacity:0;transform:scaleY(1)}}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:linear-gradient(90deg,rgba(46,226,255,.04),rgba(46,226,255,.07),rgba(46,226,255,.04));
  overflow:hidden;padding:16px 0;position:relative;z-index:3}
.marquee .track{display:flex;gap:38px;white-space:nowrap;width:max-content;
  animation:scroll 28s linear infinite;font-family:var(--display);font-weight:700;
  text-transform:uppercase;letter-spacing:.2em;font-size:1.15rem}
.marquee .track span{color:var(--ink)}
.marquee .track .dot{color:var(--cyan);text-shadow:var(--glow)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============================================================
   STATS  (animated counters)
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{padding:30px 24px;transition:.3s ease}
.stat:hover{transform:translateY(-4px);border-color:rgba(46,226,255,.4);box-shadow:var(--glow-soft)}
.stat .n{font-family:var(--display);font-weight:800;font-size:clamp(2rem,4.2vw,3rem);color:var(--cyan);
  text-shadow:0 0 22px rgba(46,226,255,.3)}
.stat .l{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}

/* ============================================================
   CARDS GRID  (hover-reactive)
   ============================================================ */
.grid{display:grid;gap:18px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.card{padding:32px 28px;transition:.32s cubic-bezier(.2,.7,.2,1);overflow:hidden}
.card::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:0;transition:.32s;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%), rgba(46,226,255,.12), transparent 60%)}
.card:hover{transform:translateY(-6px);border-color:rgba(46,226,255,.45);
  box-shadow:0 22px 50px rgba(0,0,0,.55),0 0 34px rgba(46,226,255,.14)}
.card:hover::after{opacity:1}
.card .idx{font-family:var(--mono);font-size:.74rem;letter-spacing:.2em;color:var(--cyan);opacity:.85}
.card h3{font-size:1.5rem;text-transform:uppercase;margin:12px 0 12px;font-weight:700}
.card p{color:var(--muted);font-size:1rem;font-weight:400}
.card.feature{grid-column:span 2}

/* ============================================================
   PILARES  (Honor · Valentía · Lealtad · Supremacía)
   ============================================================ */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:40px}
.pillar{padding:34px 26px;text-align:center;transition:.32s cubic-bezier(.2,.7,.2,1);position:relative}
.pillar:hover{transform:translateY(-8px);border-color:rgba(46,226,255,.5);box-shadow:0 24px 50px rgba(0,0,0,.5),0 0 36px rgba(46,226,255,.16)}
.pillar .pico{width:64px;height:64px;margin:0 auto 18px;display:block;
  filter:drop-shadow(0 0 14px rgba(46,226,255,.45))}
.pillar:hover .pico{animation:tick 1.2s ease}
@keyframes tick{30%{transform:rotate(-6deg) scale(1.06)}60%{transform:rotate(4deg)}}
.pillar h3{font-size:1.4rem;text-transform:uppercase;margin-bottom:8px;font-weight:700;letter-spacing:.04em}
.pillar .num{font-family:var(--mono);font-size:.7rem;letter-spacing:.28em;color:var(--cyan);opacity:.7;display:block;margin-bottom:14px}
.pillar p{color:var(--muted);font-size:.96rem;font-weight:400}

/* ============================================================
   SPLIT  "Liderados por Titanes"
   ============================================================ */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:40px;align-items:center}
.split .quote{font-family:var(--display);font-size:clamp(1.2rem,2.4vw,1.7rem);font-weight:600;
  line-height:1.35;color:var(--ink);margin:8px 0 20px}
.split .quote b{color:var(--cyan)}
.split .by{font-family:var(--mono);font-size:.82rem;letter-spacing:.18em;color:var(--cyan-dim);text-transform:uppercase}
.titan-visual{position:relative;min-height:380px;display:flex;align-items:center;justify-content:center;
  padding:34px;overflow:hidden}
.titan-visual .ring{position:absolute;inset:34px;border:1px solid var(--line);border-radius:50%;
  animation:spin 30s linear infinite}
.titan-visual .ring.b{inset:74px;border-style:dashed;animation-duration:20s;animation-direction:reverse}
.titan-roster{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.titan{display:flex;align-items:center;gap:16px;padding:14px 18px;border:1px solid var(--line);
  background:rgba(255,255,255,.015);transition:.25s;
  clip-path:polygon(9px 0,100% 0,100% calc(100% - 9px),calc(100% - 9px) 100%,0 100%,0 9px)}
.titan:hover{border-color:rgba(46,226,255,.5);background:rgba(46,226,255,.05);transform:translateX(6px)}
.titan .av{width:46px;height:46px;flex:none;display:grid;place-items:center;
  border:1px solid var(--cyan);color:var(--cyan);font-family:var(--display);font-weight:800;font-size:1.1rem;
  background:rgba(46,226,255,.06)}
.titan .info b{font-family:var(--display);font-size:1.05rem;display:block;text-transform:uppercase;letter-spacing:.04em}
.titan .info span{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;color:var(--muted);text-transform:uppercase}

/* ============================================================
   MAP CARDS  (Arisaka-style)
   ============================================================ */
.maps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}
.map-card{padding:0;overflow:hidden;cursor:pointer;transition:.32s cubic-bezier(.2,.7,.2,1)}
.map-card:hover{transform:translateY(-6px);border-color:rgba(46,226,255,.5);box-shadow:0 24px 50px rgba(0,0,0,.5),0 0 34px rgba(46,226,255,.14)}
.map-card .vis{height:200px;position:relative;overflow:hidden;
  background:radial-gradient(circle at 50% 120%, rgba(46,226,255,.16), transparent 60%),linear-gradient(160deg,#091627,#0c2238)}
.map-card .vis svg{position:absolute;inset:0;width:100%;height:100%}
.map-card .vis::after{content:"";position:absolute;inset:0;
  background:linear-gradient(transparent 40%, rgba(3,6,13,.85))}
.map-card .meta{padding:20px 22px;position:relative;z-index:1;display:flex;justify-content:space-between;align-items:flex-end;gap:14px}
.map-card .meta h3{font-size:1.25rem;text-transform:uppercase;font-weight:700}
.map-card .meta .sub{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;color:var(--muted);text-transform:uppercase}
.map-card .meta .mode{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;color:var(--cyan);
  border:1px solid var(--line);padding:5px 10px;white-space:nowrap}

/* ============================================================
   DIVISIONES  (emblemas reales · cuerpos de élite)
   ============================================================ */
.divisions{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
.division{padding:30px 24px 28px;text-align:center;transition:.32s cubic-bezier(.2,.7,.2,1)}
.division:hover{transform:translateY(-6px);border-color:rgba(46,226,255,.5);
  box-shadow:0 24px 50px rgba(0,0,0,.5),0 0 34px rgba(46,226,255,.14)}
.division .emblem{width:100%;max-width:230px;aspect-ratio:1;object-fit:contain;
  display:block;margin:0 auto 20px;filter:drop-shadow(0 0 20px rgba(46,226,255,.16))}
.division h3{font-family:var(--display);font-size:1.32rem;text-transform:uppercase;
  letter-spacing:.04em;font-weight:700;line-height:1.1}
.division .role{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;color:var(--cyan);
  text-transform:uppercase;margin-top:8px;display:block}
.division p{color:var(--muted);margin-top:14px;font-size:.96rem;line-height:1.55}

/* ============================================================
   POSTERS  (archivo)
   ============================================================ */
.posters{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:32px}
.poster{position:relative;aspect-ratio:3/4;overflow:hidden;padding:24px;display:flex;
  flex-direction:column;justify-content:space-between;transition:.32s cubic-bezier(.2,.7,.2,1);
  background:linear-gradient(160deg,#0a1322,#0d1a2e)}
.poster::before{content:"";position:absolute;inset:0;z-index:0;opacity:.5;
  background:radial-gradient(circle at 50% 30%, rgba(46,226,255,.18), transparent 60%)}
.poster>*{position:relative;z-index:1}
.poster:hover{transform:translateY(-6px) scale(1.01);box-shadow:0 26px 60px rgba(0,0,0,.6),0 0 40px rgba(46,226,255,.16)}
.poster .pnum{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;color:var(--cyan)}
.poster .pmid{flex:1;display:flex;align-items:center;justify-content:center}
.poster .pmid svg{width:72%;filter:drop-shadow(0 0 18px rgba(46,226,255,.4))}
.poster h3{font-size:1.5rem;text-transform:uppercase;font-weight:800;line-height:1}
.poster p{color:var(--muted);font-size:.9rem;margin-top:8px;font-weight:400}
.poster .ptag{font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;color:var(--muted-2);text-transform:uppercase}

/* ============================================================
   WAR RECORD
   ============================================================ */
.record{display:grid;grid-template-columns:2fr 1fr;gap:18px}
.tag-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.tag{font-family:var(--mono);font-size:.82rem;padding:8px 14px;border:1px solid var(--line);
  background:rgba(255,255,255,.02);color:var(--ink);transition:.2s;
  clip-path:polygon(7px 0,100% 0,100% calc(100% - 7px),calc(100% - 7px) 100%,0 100%,0 7px)}
.tag:hover{transform:translateY(-2px)}
.tag.kill{border-color:rgba(255,59,94,.4);color:#ffd6dd}
.tag.kill::before{content:"✕ ";color:var(--danger)}
.tag.kill:hover{border-color:var(--danger);box-shadow:0 0 18px rgba(255,59,94,.25)}
.tag.scare{border-color:rgba(255,178,59,.4);color:#ffe8c2}

/* ============================================================
   TIMELINE
   ============================================================ */
.timeline{position:relative;margin-top:32px;padding-left:30px}
.timeline::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:2px;
  background:linear-gradient(var(--cyan),rgba(46,226,255,.1))}
.tl{position:relative;padding:0 0 30px 8px}
.tl::before{content:"";position:absolute;left:-29px;top:6px;width:12px;height:12px;
  background:var(--bg);border:2px solid var(--cyan);box-shadow:var(--glow);transform:rotate(45deg)}
.tl .yr{font-family:var(--mono);color:var(--cyan);letter-spacing:.2em;font-size:.85rem}
.tl h4{font-size:1.25rem;text-transform:uppercase;margin:6px 0 8px;font-weight:700}
.tl p{color:var(--muted);font-weight:400}

/* ============================================================
   STEPS
   ============================================================ */
.steps{counter-reset:s}
.step{display:flex;gap:22px;padding:28px;align-items:flex-start;margin-bottom:16px;transition:.3s}
.step:hover{transform:translateX(6px);border-color:rgba(46,226,255,.4)}
.step .num{counter-increment:s;font-family:var(--display);font-weight:800;font-size:2.1rem;
  color:var(--cyan);line-height:1;min-width:56px;text-shadow:0 0 18px rgba(46,226,255,.35)}
.step .num::before{content:"0" counter(s)}
.step h4{font-size:1.3rem;text-transform:uppercase;margin-bottom:6px;font-weight:700}
.step p{color:var(--muted);font-weight:400}

/* ============================================================
   REQUIREMENTS
   ============================================================ */
.req{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:8px}
.req li{list-style:none;display:flex;gap:12px;padding:17px 20px;border:1px solid var(--line);
  background:rgba(255,255,255,.015);align-items:center;transition:.25s}
.req li:hover{border-color:rgba(46,226,255,.4);background:rgba(46,226,255,.04)}
.req li .c{color:var(--cyan);font-family:var(--mono)}
.req li span{color:var(--ink)}

/* ============================================================
   ARSENAL / MARKETPLACE
   ============================================================ */
.skins{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.skin{padding:0;overflow:hidden;transition:.32s cubic-bezier(.2,.7,.2,1)}
.skin:hover{transform:translateY(-6px);border-color:rgba(46,226,255,.45);box-shadow:0 22px 50px rgba(0,0,0,.5),0 0 30px rgba(46,226,255,.14)}
.skin .vis{height:180px;display:flex;align-items:center;justify-content:center;position:relative;
  background:radial-gradient(circle at 50% 40%, rgba(46,226,255,.16), transparent 70%)}
.skin .vis svg{width:78%;filter:drop-shadow(0 0 14px rgba(46,226,255,.4))}
.skin:hover .vis svg{animation:float 4s ease-in-out infinite}
.skin .meta{padding:18px 20px;border-top:1px solid var(--line)}
.skin .meta .r{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase}
.skin .meta h3{font-size:1.18rem;text-transform:uppercase;margin:6px 0;font-weight:700}
.skin .meta .p{color:var(--cyan);font-family:var(--mono)}
.rar-legend{color:var(--gold)}.rar-myth{color:var(--myth)}.rar-elite{color:var(--cyan)}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{text-align:center;padding:88px 24px;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;z-index:0;opacity:.6;pointer-events:none;
  background:radial-gradient(600px circle at 50% 0%, rgba(46,226,255,.12), transparent 60%)}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{font-size:clamp(2rem,6vw,4rem);text-transform:uppercase;margin-bottom:16px;font-weight:800}
.cta-band h2 b{color:var(--cyan)}
.cta-band p{color:var(--muted);max-width:50ch;margin:0 auto 30px;font-weight:400}

/* ============================================================
   FOOTER
   ============================================================ */
footer{border-top:1px solid var(--line);padding:52px 0 32px;margin-top:30px;position:relative}
.foot{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:flex-start}
.foot .brand .word{font-size:1rem}
.foot-links{display:flex;gap:44px;flex-wrap:wrap}
.foot-col h5{font-family:var(--mono);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--cyan);margin-bottom:14px;font-weight:400}
.foot-col a{display:block;color:var(--muted);text-decoration:none;font-size:.94rem;padding:4px 0;transition:.2s}
.foot-col a:hover{color:var(--cyan);transform:translateX(3px)}
.copy{margin-top:38px;padding-top:22px;border-top:1px solid var(--line-soft);
  font-family:var(--mono);font-size:.74rem;letter-spacing:.12em;color:var(--muted-2);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ============================================================
   REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:.75s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- Interior page header ---------- */
.page-head{padding:184px 0 40px;position:relative}
.page-head h1{font-size:clamp(2.8rem,7vw,5.2rem);text-transform:uppercase;font-weight:800}
.page-head h1 b{color:var(--cyan);text-shadow:0 0 28px rgba(46,226,255,.4)}
.page-head .lead{margin-top:16px}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1040px){
  .pillars{grid-template-columns:repeat(2,1fr)}
  .maps,.posters,.divisions{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:980px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .grid.cols-3,.skins{grid-template-columns:repeat(2,1fr)}
  .record,.split{grid-template-columns:1fr}
  .card.feature{grid-column:span 1}
  .req{grid-template-columns:1fr}
  .hero-stage{opacity:.4}
  .titan-visual{min-height:280px}
}
@media(max-width:720px){
  .nav-links,.nav-cta .btn span{display:none}
  .nav-cta{order:3}
  .burger{display:flex;align-items:center;justify-content:center}
  .nav-links.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;
    background:var(--bg-2);border-bottom:1px solid var(--line);padding:14px}
  .nav-links.open a{padding:14px}
  .grid.cols-3,.grid.cols-2,.stats,.skins,.pillars,.maps,.posters,.divisions{grid-template-columns:1fr}
  section{padding:68px 0}
  .foot{flex-direction:column}
  .scroll-hint{display:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important}
  .glitch::before,.glitch::after{display:none}
}
