:root{
  --bg:#02040a;
  --bg2:#050812;
  --panel:rgba(7,12,24,.74);
  --panel2:rgba(10,16,30,.86);
  --line:rgba(255,255,255,.10);
  --line2:rgba(255,255,255,.18);
  --text:#f7f9ff;
  --muted:#aab4c8;
  --soft:#6f7a92;
  --blue:#287cff;
  --blue2:#73b2ff;
  --red:#ff244d;
  --red2:#ff5a36;
  --green:#45ff95;
  --gold:#e4bd66;
  --radius:30px;
  --shadow:0 34px 120px rgba(0,0,0,.58);
}

*{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
  background:var(--bg);
}

body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing:-.02em;
  overflow-x:hidden;
}

body.modal-open{
  overflow:hidden;
}

a{
  color:inherit;
  text-decoration:none;
}

button,
input{
  font:inherit;
}

button{
  -webkit-tap-highlight-color:transparent;
}

h1,h2,h3,p{
  margin-top:0;
}

/* GLOBAL BACKGROUND */

.page-glow{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-5;
  background:
    radial-gradient(circle at 22% 18%, rgba(40,124,255,.30), transparent 34%),
    radial-gradient(circle at 82% 20%, rgba(255,36,77,.26), transparent 35%),
    radial-gradient(circle at 48% 0%, rgba(255,255,255,.08), transparent 28%),
    linear-gradient(180deg,#030713 0%, #02040a 48%, #03050b 100%);
}

.page-glow:after{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.023) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.023) 1px, transparent 1px);
  background-size:68px 68px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.9), transparent 78%);
  opacity:.72;
}

/* HEADER */

.site-header{
  height:72px;
  display:grid;
  grid-template-columns:240px minmax(0,1fr) 300px;
  align-items:center;
  gap:24px;
  padding:0 clamp(18px,4vw,58px);
  border-bottom:1px solid var(--line);
  background:rgba(2,4,10,.78);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  position:sticky;
  top:0;
  z-index:50;
}

.brand{
  display:flex;
  align-items:center;
  min-width:0;
}

.brand-word{
  font-size:23px;
  font-weight:850;
  letter-spacing:-.055em;
  white-space:nowrap;
}

.brand-word span{
  color:var(--red);
}

.top-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:34px;
  color:#c8d0e1;
  font-weight:720;
  font-size:14px;
}

.top-nav a{
  opacity:.78;
}

.top-nav a:hover{
  opacity:1;
  color:#fff;
}

.social-nav{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:14px;
}

.social-nav a{
  border:1px solid var(--line);
  background:rgba(255,255,255,.045);
  color:#dce4f5;
  border-radius:999px;
  padding:9px 12px;
  font-size:12px;
  font-weight:800;
  opacity:.86;
}

.social-nav a:hover{
  opacity:1;
  border-color:rgba(255,255,255,.28);
  background:rgba(255,255,255,.075);
}

/* PAGE */

.page-shell{
  width:min(1680px, calc(100% - 42px));
  margin:0 auto;
  padding:28px 0 76px;
}

/* BUTTONS */

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:0 25px;
  border-radius:12px;
  font-weight:900;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
  text-transform:uppercase;
  letter-spacing:.035em;
  font-size:13px;
}

.btn:hover{
  transform:translateY(-2px);
}

.btn-primary{
  background:linear-gradient(135deg,var(--red),var(--red2));
  color:#fff;
  box-shadow:0 18px 60px rgba(255,36,77,.32);
}

.btn-ghost{
  border-color:var(--line2);
  background:rgba(255,255,255,.045);
  color:#fff;
  backdrop-filter:blur(14px);
}

.btn-ghost:hover{
  border-color:rgba(255,255,255,.30);
  background:rgba(255,255,255,.075);
}

/* HERO ARENA — cinematic live voting surface */

.arena-hero{
  min-height:730px;
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1fr) 390px;
  gap:28px;
  align-items:start;
  padding:34px 0 18px;
  overflow:visible;
}

.premium-arena:before{
  content:"";
  position:absolute;
  left:8%;
  right:18%;
  top:26px;
  height:560px;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 42% 42%, rgba(40,124,255,.28), transparent 36%),
    radial-gradient(circle at 62% 45%, rgba(255,36,77,.22), transparent 38%),
    radial-gradient(ellipse at center, rgba(255,255,255,.08), transparent 62%);
  filter:blur(20px);
}

.hero-copy{
  position:relative;
  z-index:7;
  max-width:520px;
  padding-top:52px;
}

.eyebrow{
  margin:0 0 16px;
  color:var(--blue2);
  text-transform:uppercase;
  letter-spacing:.25em;
  font-weight:900;
  font-size:12px;
}

.live-eyebrow{
  display:flex;
  align-items:center;
  gap:10px;
}

.live-eyebrow:before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--red);
  box-shadow:0 0 24px rgba(255,36,77,.85);
}

h1{
  font-size:clamp(56px,6vw,98px);
  line-height:.86;
  letter-spacing:-.09em;
  margin:0 0 24px;
  color:#fff;
}

h1 span{
  background:linear-gradient(90deg,#fff 0%, var(--blue2) 34%, var(--red) 74%, var(--red2) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.hero-subtitle{
  max-width:470px;
  font-size:18px;
  line-height:1.45;
  color:#c4ccdc;
  margin:0 0 22px;
}

.hero-proof{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  color:#cbd4e6;
  margin-bottom:26px;
}

.hero-proof strong{
  color:#fff;
}

.proof-dot{
  width:34px;
  height:34px;
  border-radius:999px;
  display:inline-grid;
  place-items:center;
  background:rgba(255,36,77,.10);
  border:1px solid rgba(255,36,77,.34);
  box-shadow:0 0 44px rgba(255,36,77,.18);
}

.proof-dot:before{
  content:"";
  width:10px;
  height:10px;
  background:var(--red);
  border-radius:50%;
  box-shadow:0 0 22px rgba(255,36,77,.88);
}

.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

/* Globe */

.arena-canvas-wrap{
  position:absolute;
  left:15%;
  top:-28px;
  width:74%;
  height:570px;
  z-index:1;
  pointer-events:none;
  opacity:.98;
  filter:
    drop-shadow(0 0 90px rgba(40,124,255,.23))
    drop-shadow(0 0 100px rgba(255,36,77,.14));
}

#arenaGlobe{
  width:100%;
  height:100%;
  display:block;
}

.hero-orbit-glow{
  position:absolute;
  left:22%;
  top:170px;
  width:720px;
  height:250px;
  z-index:2;
  pointer-events:none;
  border-radius:50%;
  background:
    radial-gradient(ellipse at center, rgba(40,124,255,.18), transparent 68%),
    radial-gradient(ellipse at center, rgba(255,36,77,.12), transparent 78%);
  filter:blur(16px);
}

.hero-orbit-ring{
  position:absolute;
  left:19%;
  top:128px;
  width:850px;
  height:280px;
  z-index:3;
  pointer-events:none;
  border-radius:50%;
  border:1px solid rgba(115,178,255,.22);
  transform:rotate(-4deg) perspective(900px) rotateX(62deg);
  box-shadow:
    0 0 46px rgba(40,124,255,.24),
    inset 0 0 44px rgba(255,36,77,.10);
}

/* Orbit cards */

.hero-battle-orbit{
  position:absolute;
  left:19%;
  top:38px;
  width:940px;
  height:330px;
  z-index:6;
  perspective:1500px;
  pointer-events:none;
}

.orbit-card{
  position:absolute;
  width:180px;
  height:238px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:22px;
  overflow:hidden;
  color:#fff;
  background:#0b1020;
  text-align:left;
  padding:16px;
  cursor:pointer;
  pointer-events:auto;
  box-shadow:0 30px 90px rgba(0,0,0,.48);
  transform-style:preserve-3d;
  transition:
    transform .35s ease,
    border-color .25s ease,
    box-shadow .25s ease,
    filter .25s ease;
  will-change:transform;
}

.orbit-card:before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  background:linear-gradient(135deg, rgba(40,124,255,.58), transparent 36%, rgba(255,36,77,.54));
  opacity:.34;
  pointer-events:none;
  z-index:1;
}

.orbit-card:hover{
  transform:translateY(-22px) scale(1.10) rotate(0deg) !important;
  z-index:30 !important;
  border-color:rgba(255,255,255,.40);
  box-shadow:
    0 42px 130px rgba(0,0,0,.70),
    0 0 68px rgba(40,124,255,.24),
    0 0 54px rgba(255,36,77,.18);
}

.orbit-card-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(3,6,16,.05), rgba(3,6,16,.86)),
    var(--battle-image);
  background-size:cover;
  background-position:center;
  transition:transform .55s ease;
}

.orbit-card:hover .orbit-card-bg{
  transform:scale(1.08);
}

.orbit-card:after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 10%, rgba(40,124,255,.32), transparent 35%),
    radial-gradient(circle at 80% 20%, rgba(255,36,77,.28), transparent 35%);
  mix-blend-mode:screen;
  opacity:.72;
}

.orbit-card > *:not(.orbit-card-bg){
  position:relative;
  z-index:2;
}

.orbit-live{
  position:absolute;
  right:12px;
  top:12px;
  border-radius:7px;
  padding:5px 7px;
  background:rgba(255,36,77,.90);
  color:#fff;
  text-transform:uppercase;
  font-size:9px;
  font-weight:950;
  letter-spacing:.08em;
}

.orbit-card strong{
  position:absolute;
  left:16px;
  right:16px;
  bottom:42px;
  font-size:18px;
  line-height:1.08;
  font-weight:950;
  letter-spacing:-.045em;
  text-shadow:0 14px 40px rgba(0,0,0,.86);
  text-transform:uppercase;
}

.orbit-card em{
  display:block;
  color:#fff;
  font-style:normal;
  text-transform:uppercase;
  font-size:13px;
  letter-spacing:.04em;
  opacity:.92;
}

.orbit-card small{
  position:absolute;
  left:16px;
  bottom:16px;
  color:#b9d8ff;
  font-weight:850;
}

.orbit-card-1{
  left:0;
  top:120px;
  transform:rotate(-13deg) translateZ(-80px) scale(.82);
  opacity:.74;
  z-index:2;
  animation:floatCard 5.8s ease-in-out infinite;
}

.orbit-card-2{
  left:170px;
  top:36px;
  transform:rotate(-7deg) translateZ(10px) scale(.98);
  opacity:.92;
  z-index:4;
  border-color:rgba(40,124,255,.44);
  animation:floatCard 6.4s ease-in-out infinite .18s;
}

.orbit-card-3{
  left:388px;
  top:0;
  transform:rotate(4deg) translateZ(90px) scale(1.12);
  opacity:1;
  z-index:8;
  border-color:rgba(255,255,255,.34);
  box-shadow:
    0 36px 120px rgba(0,0,0,.62),
    0 0 70px rgba(255,36,77,.20);
  animation:floatCard 5.6s ease-in-out infinite .34s;
}

.orbit-card-4{
  left:606px;
  top:44px;
  transform:rotate(8deg) translateZ(20px) scale(.98);
  opacity:.92;
  z-index:4;
  border-color:rgba(255,36,77,.40);
  animation:floatCard 6.6s ease-in-out infinite .52s;
}

.orbit-card-5{
  left:776px;
  top:132px;
  transform:rotate(13deg) translateZ(-90px) scale(.80);
  opacity:.72;
  z-index:2;
  animation:floatCard 7.2s ease-in-out infinite .7s;
}

/* Center live voting window */

.hero-vote-window{
  position:absolute;
  left:50%;
  top:260px;
  transform:translateX(-50%);
  width:min(720px, 58vw);
  z-index:12;
  border:1px solid rgba(255,255,255,.20);
  border-radius:26px;
  background:
    radial-gradient(circle at 28% 40%, rgba(40,124,255,.22), transparent 42%),
    radial-gradient(circle at 74% 42%, rgba(255,36,77,.18), transparent 42%),
    rgba(7,12,24,.88);
  backdrop-filter:blur(28px);
  -webkit-backdrop-filter:blur(28px);
  box-shadow:
    0 44px 150px rgba(0,0,0,.72),
    inset 0 1px 0 rgba(255,255,255,.08);
  overflow:hidden;
}

.hero-window-close{
  position:absolute;
  right:14px;
  top:12px;
  width:34px;
  height:34px;
  z-index:8;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
  color:#fff;
  cursor:pointer;
  font-size:24px;
  line-height:1;
}

.hero-live-chip{
  top:16px !important;
}

.hero-vote-body{
  display:grid;
  grid-template-columns:minmax(0,1fr) 130px minmax(0,1fr);
  min-height:240px;
}

.hero-vote-side{
  position:relative;
  overflow:hidden;
  border:0;
  color:#fff;
  background:#071020;
  cursor:pointer;
  padding:24px;
  text-align:left;
}

.hero-vote-image{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(3,6,16,.10), rgba(3,6,16,.76)),
    var(--side-image);
  background-size:cover;
  background-position:center;
  transition:transform .45s ease;
}

.hero-vote-b .hero-vote-image{
  background:
    linear-gradient(270deg, rgba(3,6,16,.10), rgba(3,6,16,.76)),
    var(--side-image);
  background-size:cover;
  background-position:center;
}

.hero-vote-side:hover .hero-vote-image{
  transform:scale(1.06);
}

.hero-vote-side strong,
.hero-vote-side em{
  position:relative;
  z-index:2;
  display:block;
  text-shadow:0 18px 58px rgba(0,0,0,.9);
}

.hero-vote-side strong{
  position:absolute;
  left:24px;
  right:24px;
  bottom:78px;
  font-size:38px;
  line-height:.92;
  letter-spacing:-.07em;
  text-transform:uppercase;
  font-weight:950;
}

.hero-vote-side em{
  position:absolute;
  left:24px;
  bottom:42px;
  color:#d7e2f6;
  font-style:normal;
  font-weight:900;
}

.hero-vs-core{
  display:grid;
  place-items:center;
  text-align:center;
  background:
    radial-gradient(circle at center, rgba(255,255,255,.12), transparent 54%),
    rgba(3,6,16,.88);
  border-left:1px solid var(--line);
  border-right:1px solid var(--line);
}

.hero-vs-core span{
  font-size:58px;
  line-height:.9;
  font-weight:950;
  letter-spacing:-.10em;
  background:linear-gradient(90deg,var(--blue2),#fff,var(--red));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.hero-vs-core strong{
  display:block;
  margin-top:10px;
  font-size:18px;
  color:#fff;
  font-variant-numeric:tabular-nums;
}

.hero-vs-core small{
  color:var(--muted);
  font-weight:850;
}

.hero-vote-score{
  display:grid;
  grid-template-columns:70px minmax(0,1fr) 70px;
  gap:14px;
  align-items:center;
  padding:16px 22px 0;
}

.hero-vote-score span{
  font-size:24px;
  font-weight:950;
}

.blue-score{
  color:var(--blue2);
}

.red-score{
  color:#ff8ca0;
  text-align:right;
}

.hero-vote-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  padding:18px 22px 8px;
}

.vote-action{
  min-height:52px;
  border-radius:12px;
  color:#fff;
  cursor:pointer;
  text-transform:uppercase;
  letter-spacing:.04em;
  font-weight:950;
}

.vote-action-a{
  border:1px solid rgba(40,124,255,.48);
  background:linear-gradient(135deg, rgba(40,124,255,.42), rgba(40,124,255,.18));
}

.vote-action-b{
  border:1px solid rgba(255,36,77,.48);
  background:linear-gradient(135deg, rgba(255,36,77,.42), rgba(255,36,77,.18));
}

.vote-action:hover{
  transform:translateY(-2px);
}

.hero-vote-help{
  margin:0;
  padding:0 22px 20px;
  text-align:center;
  color:#9faabe;
  font-weight:750;
}

/* Hero ranking */

.hero-ranking{
  position:relative !important;
  top:auto !important;
  max-height:none !important;
  grid-column:2;
  grid-row:1;
  z-index:14;
  margin-top:0;
}

/* TICKER */

.live-ticker{
  position:relative;
  z-index:8;
  min-height:48px;
  margin:12px 0 20px;
  border:1px solid var(--line2);
  border-radius:15px;
  background:rgba(7,12,24,.72);
  backdrop-filter:blur(20px);
  display:flex;
  align-items:center;
  gap:22px;
  overflow:hidden;
  padding:0 16px;
  box-shadow:0 18px 60px rgba(0,0,0,.25);
}

.live-ticker strong{
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:950;
  color:var(--red);
  white-space:nowrap;
}

.live-ticker span{
  color:#d1d9e9;
  white-space:nowrap;
}

.live-ticker button{
  border:0;
  background:transparent;
  color:#d7e0f2;
  white-space:nowrap;
  cursor:pointer;
  opacity:.76;
  border-left:1px solid var(--line);
  padding-left:22px;
}

.live-ticker button:hover{
  opacity:1;
  color:white;
}

/* RANKING */

.ranking-rail{
  border:1px solid var(--line2);
  border-radius:24px;
  background:rgba(8,12,22,.82);
  box-shadow:var(--shadow);
  backdrop-filter:blur(28px);
  -webkit-backdrop-filter:blur(28px);
  overflow:hidden;
}

.ranking-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  padding:22px 22px 12px;
}

.ranking-header h2{
  margin:0;
  font-size:28px;
  line-height:1;
  letter-spacing:-.06em;
}

.live-chip{
  background:rgba(255,36,77,.12);
  color:#ff8ca0;
  border:1px solid rgba(255,36,77,.32);
  border-radius:999px;
  padding:7px 10px;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:950;
}

.global-list{
  list-style:none;
  padding:0 16px 14px;
  margin:0;
  display:grid;
  gap:8px;
}

.compact-global-list{
  max-height:520px;
  overflow:auto;
  scrollbar-width:thin;
}

.global-row{
  min-height:54px;
  display:grid;
  grid-template-columns:30px 38px minmax(0,1fr) auto;
  gap:10px;
  align-items:center;
  border:1px solid rgba(255,255,255,.07);
  border-radius:13px;
  background:rgba(255,255,255,.035);
  padding:8px 10px;
  transition:transform .25s ease, background .25s ease, border-color .25s ease;
}

.global-row:hover{
  transform:translateX(-3px);
  background:rgba(255,255,255,.065);
  border-color:rgba(255,255,255,.16);
}

.global-row.top-five{
  background:linear-gradient(90deg, rgba(255,36,77,.18), rgba(40,124,255,.10));
  border-color:rgba(255,255,255,.16);
}

.rank-num{
  color:var(--gold);
  font-size:15px;
  font-weight:950;
}

.fighter-avatar{
  width:38px;
  height:38px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#121827;
  color:#fff;
  border:1px solid var(--line2);
  font-weight:900;
}

.fighter-meta{
  min-width:0;
}

.fighter-meta strong{
  display:block;
  font-size:14px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.fighter-meta small{
  display:block;
  margin-top:2px;
  color:var(--soft);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:9px;
  font-weight:900;
}

.fighter-votes{
  color:#eaf2ff;
  font-weight:950;
  font-size:13px;
  font-variant-numeric:tabular-nums;
}

.ranking-link{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  margin:0 16px 16px;
  border:1px solid var(--line);
  border-radius:13px;
  color:#d5ddef;
  font-weight:850;
}

.ranking-link:hover{
  background:rgba(255,255,255,.06);
}

/* FEATURED LIVE BATTLE */

.featured-live-battle{
  position:relative;
  z-index:8;
  margin-top:10px;
}

.featured-label{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:10px;
  color:#fff;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:13px;
  font-weight:950;
}

.featured-label span{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--red);
  box-shadow:0 0 24px rgba(255,36,77,.9);
}

.featured-battle-card{
  position:relative;
  min-height:260px;
  display:grid;
  grid-template-columns:minmax(0,1fr) 140px minmax(0,1fr);
  align-items:stretch;
  border:1px solid var(--line2);
  border-radius:20px;
  overflow:hidden;
  background:rgba(7,12,24,.78);
  box-shadow:var(--shadow);
}

.featured-side{
  position:relative;
  border:0;
  color:#fff;
  text-align:left;
  cursor:pointer;
  overflow:hidden;
  background:#071020;
  padding:28px;
}

.featured-side-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(3,6,16,.20), rgba(3,6,16,.75)),
    var(--side-image);
  background-size:cover;
  background-position:center;
  opacity:.92;
  transition:transform .45s ease;
}

.featured-side-b .featured-side-bg{
  background:
    linear-gradient(270deg, rgba(3,6,16,.20), rgba(3,6,16,.75)),
    var(--side-image);
  background-size:cover;
  background-position:center;
}

.featured-side:hover .featured-side-bg{
  transform:scale(1.05);
}

.featured-side strong,
.featured-side em{
  position:relative;
  z-index:2;
  display:block;
  text-shadow:0 18px 60px rgba(0,0,0,.8);
}

.featured-side strong{
  position:absolute;
  bottom:70px;
  left:28px;
  right:28px;
  font-size:46px;
  line-height:.9;
  letter-spacing:-.07em;
  text-transform:uppercase;
  font-weight:950;
}

.featured-side em{
  position:absolute;
  bottom:32px;
  left:28px;
  color:#c9d3e6;
  font-style:normal;
  font-weight:850;
}

.featured-vs{
  display:grid;
  place-items:center;
  text-align:center;
  background:
    radial-gradient(circle at center, rgba(255,255,255,.08), transparent 46%),
    rgba(3,6,16,.84);
  border-left:1px solid var(--line);
  border-right:1px solid var(--line);
  z-index:2;
}

.featured-vs span{
  font-size:54px;
  font-weight:950;
  letter-spacing:-.08em;
  background:linear-gradient(90deg,var(--blue2),#fff,var(--red));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.featured-vs small{
  color:var(--muted);
  font-weight:850;
}

.featured-result{
  position:absolute;
  left:28px;
  right:28px;
  bottom:18px;
  display:grid;
  grid-template-columns:60px minmax(0,1fr) 60px;
  gap:14px;
  align-items:center;
  z-index:4;
}

.featured-result > span{
  font-size:24px;
  font-weight:950;
}

.featured-result > span:last-child{
  text-align:right;
  color:#ff8ca0;
}

/* RESULT BARS */

.result-bars{
  height:10px;
  border-radius:999px;
  overflow:hidden;
  display:flex;
  background:rgba(255,255,255,.08);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.05);
}

.result-bar{
  height:100%;
}

.result-a{
  background:linear-gradient(90deg,var(--blue),var(--blue2));
  box-shadow:0 0 26px rgba(40,124,255,.42);
}

.result-b{
  background:linear-gradient(90deg,var(--red),#ff6a82);
  box-shadow:0 0 26px rgba(255,36,77,.38);
}

/* DASHBOARD GRID */

.dashboard-grid{
  position:relative;
  z-index:8;
  margin-top:22px;
  display:grid;
  grid-template-columns:1.35fr .8fr .8fr;
  gap:18px;
}

.panel-card{
  border:1px solid var(--line2);
  border-radius:22px;
  background:rgba(8,12,22,.78);
  box-shadow:0 24px 80px rgba(0,0,0,.34);
  backdrop-filter:blur(24px);
  padding:22px;
  overflow:hidden;
}

.wide-panel{
  grid-column:span 1;
}

.section-title-row{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
}

.section-title-row h2,
.panel-card h2{
  margin:0;
  font-size:27px;
  letter-spacing:-.055em;
  line-height:1;
}

.section-title-row a{
  color:#cbd5e8;
  font-size:13px;
  font-weight:850;
  opacity:.8;
}

.section-title-row a:hover{
  opacity:1;
}

.compact{
  margin-bottom:16px;
}

/* TRENDING CARDS */

.trending-cards{
  display:grid;
  grid-template-columns:repeat(5, minmax(130px,1fr));
  gap:12px;
}

.trending-card{
  position:relative;
  min-height:170px;
  overflow:hidden;
  border:1px solid var(--line2);
  border-radius:16px;
  background:#071020;
  color:#fff;
  text-align:left;
  padding:14px;
  cursor:pointer;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.trending-card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,255,255,.32);
  box-shadow:0 24px 70px rgba(0,0,0,.44);
}

.trending-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(3,6,16,.08), rgba(3,6,16,.86)),
    var(--battle-image);
  background-size:cover;
  background-position:center;
  transition:transform .45s ease;
}

.trending-card:hover .trending-bg{
  transform:scale(1.06);
}

.trending-card strong,
.trending-card small{
  position:absolute;
  left:14px;
  right:14px;
  z-index:2;
  text-shadow:0 16px 50px rgba(0,0,0,.9);
}

.trending-card strong{
  bottom:38px;
  font-size:20px;
  line-height:1.05;
  letter-spacing:-.045em;
}

.trending-card small{
  bottom:15px;
  color:#b8c7e4;
  font-weight:850;
}

/* MINI LIST */

.mini-battle-list{
  display:grid;
  gap:9px;
}

.mini-battle{
  min-height:48px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  border:1px solid rgba(255,255,255,.07);
  border-radius:13px;
  padding:10px 12px;
  color:#e9eefb;
  background:rgba(255,255,255,.035);
}

.mini-battle:hover{
  border-color:rgba(255,255,255,.20);
  background:rgba(255,255,255,.065);
}

.mini-battle strong{
  font-variant-numeric:tabular-nums;
  color:#b8d5ff;
}

/* SUGGEST */

.suggestion-card p{
  color:var(--muted);
  line-height:1.45;
}

.suggest-form{
  display:grid;
  gap:12px;
}

.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

input{
  width:100%;
  min-height:50px;
  border:1px solid var(--line2);
  border-radius:14px;
  background:#050812;
  color:#fff;
  padding:0 14px;
  outline:none;
}

input:focus{
  border-color:rgba(40,124,255,.75);
  box-shadow:0 0 0 4px rgba(40,124,255,.10);
}

.success-box{
  border:1px solid rgba(69,255,149,.25);
  background:rgba(69,255,149,.08);
  color:#baffd3;
  border-radius:15px;
  padding:12px 14px;
  margin:14px 0;
}

/* FULL RANKING PANEL */

.full-ranking-panel{
  position:relative;
  z-index:8;
  margin-top:22px;
  border:1px solid var(--line2);
  border-radius:24px;
  padding:24px;
  background:rgba(8,12,22,.70);
}

.section-note{
  color:var(--muted);
  max-width:470px;
  line-height:1.45;
  margin:0;
}

.ranking-tabs{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.ranking-tabs button{
  border:1px solid var(--line);
  background:rgba(255,255,255,.045);
  color:#cfd6e7;
  border-radius:999px;
  padding:10px 16px;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
}

.ranking-tabs button.active{
  background:#fff;
  color:#02040a;
}

/* MODAL */

.battle-modal{
  position:fixed;
  inset:0;
  z-index:200;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
}

.battle-modal.is-open{
  display:flex;
}

.battle-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(2,4,10,.72);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
}

.battle-modal-card{
  position:relative;
  z-index:2;
  width:min(960px, 100%);
  min-height:440px;
  border:1px solid rgba(255,255,255,.20);
  border-radius:28px;
  overflow:hidden;
  background:rgba(8,12,22,.92);
  box-shadow:0 40px 150px rgba(0,0,0,.72);
  animation:modalIn .22s ease both;
}

.modal-close{
  position:absolute;
  right:18px;
  top:16px;
  z-index:6;
  width:38px;
  height:38px;
  border-radius:50%;
  border:1px solid var(--line2);
  background:rgba(255,255,255,.06);
  color:#fff;
  cursor:pointer;
  font-size:26px;
  line-height:1;
}

.modal-live-chip{
  position:absolute;
  left:50%;
  top:18px;
  transform:translateX(-50%);
  z-index:6;
  border:1px solid rgba(255,36,77,.35);
  background:rgba(255,36,77,.13);
  color:#ff8fa2;
  border-radius:999px;
  padding:8px 12px;
  font-size:11px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.12em;
}

.modal-sides{
  display:grid;
  grid-template-columns:minmax(0,1fr) 150px minmax(0,1fr);
  min-height:340px;
}

.modal-side{
  position:relative;
  border:0;
  color:#fff;
  overflow:hidden;
  background:#071020;
  cursor:pointer;
  text-align:left;
  padding:30px;
}

.modal-side-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(3,6,16,.12), rgba(3,6,16,.78)),
    var(--side-image);
  background-size:cover;
  background-position:center;
  transition:transform .5s ease;
}

.modal-side-b .modal-side-bg{
  background:
    linear-gradient(270deg, rgba(3,6,16,.12), rgba(3,6,16,.78)),
    var(--side-image);
  background-size:cover;
  background-position:center;
}

.modal-side:hover .modal-side-bg{
  transform:scale(1.06);
}

.modal-side strong,
.modal-side span{
  position:relative;
  z-index:2;
  display:block;
  text-shadow:0 18px 60px rgba(0,0,0,.85);
}

.modal-side strong{
  position:absolute;
  left:30px;
  right:30px;
  bottom:88px;
  font-size:58px;
  line-height:.88;
  text-transform:uppercase;
  letter-spacing:-.08em;
  font-weight:950;
}

.modal-side span:not(.modal-side-bg){
  position:absolute;
  left:30px;
  bottom:42px;
  color:#d9e4f7;
  font-size:20px;
  font-weight:950;
}

.modal-vs{
  display:grid;
  place-items:center;
  text-align:center;
  background:
    radial-gradient(circle at center, rgba(255,255,255,.10), transparent 50%),
    rgba(3,6,16,.86);
  border-left:1px solid var(--line);
  border-right:1px solid var(--line);
}

.modal-vs strong{
  font-size:72px;
  line-height:1;
  font-weight:950;
  letter-spacing:-.1em;
  background:linear-gradient(90deg,var(--blue2),#fff,var(--red));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.modal-vs span{
  color:#b8c4da;
  font-weight:850;
}

.modal-result{
  min-height:84px;
  display:grid;
  grid-template-columns:80px minmax(0,1fr) 80px;
  align-items:center;
  gap:14px;
  padding:0 28px;
  border-top:1px solid var(--line);
  background:rgba(2,4,10,.62);
}

.modal-result > span{
  font-size:26px;
  font-weight:950;
}

.modal-result > span:last-child{
  color:#ff8ca0;
  text-align:right;
}

.modal-help{
  margin:0;
  padding:0 28px 24px;
  color:#9faabe;
  text-align:center;
  font-weight:700;
}

/* FOOTER */

.site-footer{
  display:flex;
  justify-content:space-between;
  gap:18px;
  color:var(--muted);
  border-top:1px solid var(--line);
  padding:28px clamp(18px,4vw,68px);
  font-weight:800;
  background:rgba(2,4,10,.72);
}

.site-footer strong{
  color:#fff;
}

/* ANIMATIONS */

@keyframes floatCard{
  0%,100%{
    translate:0 0;
  }
  50%{
    translate:0 -13px;
  }
}

@keyframes modalIn{
  from{
    opacity:0;
    transform:translateY(18px) scale(.96);
  }
  to{
    opacity:1;
    transform:translateY(0) scale(1);
  }
}

/* RESPONSIVE */

@media (max-width:1280px){
  .site-header{
    grid-template-columns:220px minmax(0,1fr);
  }

  .social-nav{
    display:none;
  }

  .arena-hero{
    grid-template-columns:1fr;
    min-height:auto;
    padding-bottom:20px;
  }

  .hero-copy{
    order:1;
  }

  .hero-battle-orbit{
    order:2;
    position:relative;
    left:auto;
    top:auto;
    width:100%;
    height:300px;
    margin-top:22px;
  }

  .hero-vote-window{
    order:3;
    position:relative;
    left:auto;
    top:auto;
    transform:none;
    width:100%;
    margin-top:18px;
  }

  .hero-ranking{
    order:4;
    grid-column:auto;
    grid-row:auto;
  }

  .arena-canvas-wrap{
    left:20%;
    width:92%;
    height:500px;
    opacity:.72;
  }

  .hero-orbit-ring,
  .hero-orbit-glow{
    display:none;
  }

  .dashboard-grid{
    grid-template-columns:1fr 1fr;
  }

  .wide-panel{
    grid-column:1 / -1;
  }
}

@media (max-width:900px){
  .site-header{
    height:auto;
    min-height:70px;
    display:flex;
    justify-content:space-between;
    padding:16px;
  }

  .top-nav{
    display:none;
  }

  .page-shell{
    width:min(100% - 28px, 1680px);
    padding-top:18px;
  }

  .hero-copy{
    padding-top:20px;
  }

  h1{
    font-size:58px;
  }

  .arena-canvas-wrap{
    position:absolute;
    left:-10%;
    top:40px;
    width:120%;
    height:420px;
    opacity:.34;
  }

  .hero-battle-orbit{
    height:auto;
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
  }

  .orbit-card,
  .orbit-card-1,
  .orbit-card-2,
  .orbit-card-3,
  .orbit-card-4,
  .orbit-card-5{
    position:relative;
    left:auto;
    top:auto;
    width:100%;
    height:170px;
    opacity:1;
    transform:none !important;
    animation:none;
  }

  .orbit-card:hover{
    transform:translateY(-4px) scale(1.01) !important;
  }

  .hero-vote-body{
    grid-template-columns:1fr;
  }

  .hero-vs-core{
    min-height:110px;
    border-left:0;
    border-right:0;
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
  }

  .hero-vote-side{
    min-height:230px;
  }

  .hero-vote-actions{
    grid-template-columns:1fr;
  }

  .featured-battle-card{
    grid-template-columns:1fr;
  }

  .featured-vs{
    min-height:90px;
    border-left:0;
    border-right:0;
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
  }

  .featured-side{
    min-height:230px;
  }

  .featured-result{
    position:relative;
    left:auto;
    right:auto;
    bottom:auto;
    padding:18px;
    grid-column:1;
  }

  .dashboard-grid{
    grid-template-columns:1fr;
  }

  .trending-cards{
    grid-template-columns:1fr 1fr;
  }

  .modal-sides{
    grid-template-columns:1fr;
  }

  .modal-vs{
    min-height:110px;
    border-left:0;
    border-right:0;
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
  }

  .modal-side{
    min-height:230px;
  }
}

@media (max-width:560px){
  .brand-word{
    font-size:21px;
  }

  .hero-subtitle{
    font-size:17px;
  }

  h1{
    font-size:48px;
  }

  .hero-actions{
    display:grid;
  }

  .btn{
    width:100%;
  }

  .ranking-header{
    padding:18px 16px 10px;
  }

  .global-list{
    padding:0 12px 12px;
  }

  .trending-cards{
    grid-template-columns:1fr;
  }

  .form-row{
    grid-template-columns:1fr;
  }

  .hero-vote-side strong{
    font-size:42px;
  }

  .hero-vote-score{
    grid-template-columns:58px minmax(0,1fr) 58px;
    padding:14px 16px 0;
  }

  .modal-side strong{
    font-size:42px;
  }

  .modal-result{
    grid-template-columns:60px minmax(0,1fr) 60px;
    padding:0 18px;
  }

  .site-footer{
    flex-direction:column;
  }
}