/* ══════════════════════════════════════════════════════════
   VYNDRA — RANKING.CSS
   ══════════════════════════════════════════════════════════ */

/* ══ THEMES ═══════════════════════════════════════════════ */
:root{--acc-rgb:168,85,247;--acc:#a855f7;--acc-dim:rgba(168,85,247,.12);--acc-glow:0 0 14px rgba(168,85,247,.4)}
[data-theme=purple]{--acc-rgb:168,85,247;--acc:#a855f7;--acc-dim:rgba(168,85,247,.12);--acc-glow:0 0 14px rgba(168,85,247,.4)}
[data-theme=green] {--acc-rgb:34,197,94;--acc:#22c55e;--acc-dim:rgba(34,197,94,.12);--acc-glow:0 0 14px rgba(34,197,94,.4)}
[data-theme=orange]{--acc-rgb:245,158,11;--acc:#f59e0b;--acc-dim:rgba(245,158,11,.12);--acc-glow:0 0 14px rgba(245,158,11,.4)}
[data-theme=red]   {--acc-rgb:239,68,68;--acc:#ef4444;--acc-dim:rgba(239,68,68,.12);--acc-glow:0 0 14px rgba(239,68,68,.4)}
[data-theme=cyan]  {--acc-rgb:6,182,212;--acc:#06b6d4;--acc-dim:rgba(6,182,212,.12);--acc-glow:0 0 14px rgba(6,182,212,.4)}

/* ══ BASE ══════════════════════════════════════════════════ */
:root{
  --bg:#020509;--bg2:#07090f;--bg3:#0c1018;
  --card:#090c14;--card2:#0d1120;
  --border:rgba(255,255,255,.06);--border2:rgba(255,255,255,.1);
  --txt:#e8f0ff;--txt2:rgba(232,240,255,.5);--txt3:rgba(232,240,255,.25);
  --ff-d:'Bebas Neue',sans-serif;--ff-m:'Share Tech Mono',monospace;--ff-r:'Rajdhani',sans-serif;
  --nav-h:58px;--rad:12px;--rad-s:8px;--gap:14px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--txt);font-family:var(--ff-r);min-height:100vh;overflow-x:hidden;cursor:none}
a{text-decoration:none;color:inherit}
input,button,select,textarea{font-family:inherit;outline:none}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:rgba(var(--acc-rgb),.35);border-radius:2px}

/* ══ CURSOR ════════════════════════════════════════════════ */
#vCursor{position:fixed;width:26px;height:26px;border-radius:50%;border:1px solid rgba(var(--acc-rgb),.5);pointer-events:none;transform:translate(-50%,-50%);z-index:9999;transition:transform .12s,border-color .2s}
#vCursorDot{position:fixed;width:4px;height:4px;border-radius:50%;background:var(--acc);pointer-events:none;transform:translate(-50%,-50%);z-index:10000}
#vCursor.hovering{transform:translate(-50%,-50%) scale(1.6);border-color:var(--acc)}

/* ─────────────────────────────────────────────────────────────────────
   NAVIGATION
───────────────────────────────────────────────────────────────────── */
.navbar{position:fixed;top:0;left:0;right:0;height:var(--nav-h);background:rgba(2,5,9,.92);backdrop-filter:blur(24px) saturate(1.4);border-bottom:1px solid rgba(255,255,255,.055);display:flex;align-items:center;padding:0 24px;gap:0;z-index:900;overflow:visible;animation:navDropIn .6s cubic-bezier(.16,1,.3,1) both}
@keyframes navDropIn{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
.nav-scan{position:absolute;top:0;left:-40%;width:40%;height:100%;pointer-events:none;z-index:1;background:linear-gradient(90deg,transparent,rgba(var(--acc-rgb),.05),rgba(var(--acc-rgb),.1),rgba(var(--acc-rgb),.05),transparent);animation:navScan 7s cubic-bezier(.4,0,.6,1) infinite 1.5s}
@keyframes navScan{0%{left:-40%}100%{left:140%}}
.nav-border-glow{position:absolute;bottom:-1px;left:0;right:0;height:1px;pointer-events:none;background:linear-gradient(90deg,transparent 0%,rgba(var(--acc-rgb),0) 10%,rgba(var(--acc-rgb),.6) 35%,rgba(var(--acc-rgb),.9) 50%,rgba(var(--acc-rgb),.6) 65%,rgba(var(--acc-rgb),0) 90%,transparent 100%);animation:navGlow 4s ease-in-out infinite;box-shadow:0 0 14px rgba(var(--acc-rgb),.4),0 0 30px rgba(var(--acc-rgb),.15)}
@keyframes navGlow{0%,100%{opacity:.3;transform:scaleX(.65)}50%{opacity:1;transform:scaleX(1)}}
.nav-hud-tl,.nav-hud-tr{position:absolute;top:7px;width:14px;height:14px;pointer-events:none;animation:hudBlink 3.5s ease-in-out infinite}
.nav-hud-tl{left:8px;border-top:1.5px solid var(--acc);border-left:1.5px solid var(--acc)}
.nav-hud-tr{right:8px;border-top:1.5px solid var(--acc);border-right:1.5px solid var(--acc)}
@keyframes hudBlink{0%,100%{opacity:.6}50%{opacity:.15}}
@keyframes navItemIn{from{opacity:0;transform:translateY(-7px)}to{opacity:1;transform:translateY(0)}}
@keyframes logoPulse{0%,100%{transform:translateY(-50%) scale(1);opacity:.4}50%{transform:translateY(-50%) scale(1.6);opacity:0}}
.nav-logo{font-family:var(--ff-head);font-size:22px;letter-spacing:.18em;color:var(--t1);flex-shrink:0;cursor:default;animation:navItemIn .5s .1s both;transition:text-shadow .25s;display:flex;align-items:center;gap:10px;position:relative;margin-right:4px}
.nav-logo:hover{text-shadow:0 0 20px rgba(var(--acc-rgb),.4)}
.nav-logo span{color:var(--acc)}
.nav-logo-icon{color:var(--acc);flex-shrink:0;transition:transform .4s cubic-bezier(.34,1.56,.64,1),filter .3s;filter:drop-shadow(0 0 5px rgba(var(--acc-rgb),.55))}
.nav-logo:hover .nav-logo-icon{transform:rotate(30deg) scale(1.14);filter:drop-shadow(0 0 12px rgba(var(--acc-rgb),.9))}
.nav-logo-pulse{position:absolute;left:0;top:50%;width:28px;height:28px;border-radius:50%;border:1px solid rgba(var(--acc-rgb),.22);transform:translateY(-50%);animation:logoPulse 3s ease-in-out infinite;pointer-events:none}
.nav-divider{width:1px;height:22px;background:rgba(255,255,255,.07);margin:0 14px;flex-shrink:0;animation:navItemIn .5s .15s both}
.nav-home-btn{display:flex;align-items:center;gap:5px;padding:6px 13px;font-family:var(--ff-mono);font-size:9px;letter-spacing:.14em;color:var(--acc);background:rgba(var(--acc-rgb),.12);border:1px solid rgba(var(--acc-rgb),.3);border-radius:var(--r1);transition:all .2s;white-space:nowrap;flex-shrink:0;margin-right:12px;text-decoration:none;cursor:pointer;animation:navItemIn .5s .18s both}
.nav-home-btn:hover{background:rgba(var(--acc-rgb),.22);border-color:var(--acc);transform:translateY(-1px)}
.nav-links{display:flex;gap:1px;flex:1;min-width:0;position:relative;animation:navItemIn .5s .2s both}
.nav-glider{position:absolute;top:50%;transform:translateY(-50%);height:30px;border-radius:6px;background:rgba(var(--acc-rgb),.09);border:1px solid rgba(var(--acc-rgb),.28);box-shadow:0 0 12px rgba(var(--acc-rgb),.1),inset 0 0 8px rgba(var(--acc-rgb),.04);transition:left .3s cubic-bezier(.34,1.2,.64,1),width .3s cubic-bezier(.34,1.2,.64,1);pointer-events:none;z-index:0;opacity:0}
.nav-link{padding:6px 13px;font-family:var(--ff-mono);font-size:9px;letter-spacing:.12em;color:rgba(255,255,255,.32);border-radius:6px;border:1px solid transparent;transition:color .18s,border-color .2s,background .2s;white-space:nowrap;position:relative;z-index:1;overflow:hidden;text-decoration:none}
.nav-link:nth-child(2){animation:navItemIn .45s .22s both}
.nav-link:nth-child(3){animation:navItemIn .45s .26s both}
.nav-link:nth-child(4){animation:navItemIn .45s .30s both}
.nav-link:nth-child(5){animation:navItemIn .45s .34s both}
.nav-link:nth-child(6){animation:navItemIn .45s .38s both}
.nav-link:nth-child(7){animation:navItemIn .45s .42s both}

/* Efecto fluido al hacer hover — entra desde la izquierda */
.nav-link::before{content:'';position:absolute;inset:0;border-radius:6px;background:rgba(var(--acc-rgb),.08);transform:translateX(-110%) skewX(-10deg);transition:transform .38s cubic-bezier(.16,1,.3,1);pointer-events:none;z-index:0}
.nav-link:hover::before{transform:translateX(0) skewX(0deg)}
.nav-link:hover{color:var(--t2);border-color:rgba(var(--acc-rgb),.18)}
.nav-link.active{color:var(--acc)!important;font-weight:600;background:rgba(var(--acc-rgb),.1);border-color:rgba(var(--acc-rgb),.28);text-shadow:0 0 14px rgba(var(--acc-rgb),.45)}
.nav-link.active::after{content:'';position:absolute;bottom:0;left:22%;right:22%;height:1.5px;background:var(--acc);box-shadow:0 0 10px var(--acc);border-radius:2px}
.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0;animation:navItemIn .5s .45s both}
.theme-selector{position:relative}
.theme-toggle-btn{display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);color:var(--t2);font-family:var(--ff-mono);font-size:9px;letter-spacing:.12em;padding:5px 12px;border-radius:var(--r1);cursor:pointer;white-space:nowrap;transition:all .2s}
.theme-orb{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--acc);box-shadow:0 0 6px rgba(var(--acc-rgb),.7);animation:orbPulse 2.2s ease-in-out infinite}
@keyframes orbPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.55}}
.theme-toggle-btn:hover{border-color:rgba(var(--acc-rgb),.4);color:var(--acc);background:rgba(var(--acc-rgb),.07);transform:translateY(-1px);box-shadow:0 0 12px rgba(var(--acc-rgb),.14)}
.theme-panel{position:absolute;top:calc(100% + 10px);right:0;background:rgba(7,9,15,.97);border:1px solid rgba(var(--acc-rgb),.2);border-radius:10px;padding:14px;opacity:0;pointer-events:none;transform:translateY(-8px) scale(.96);transition:all .22s cubic-bezier(.16,1,.3,1);z-index:10;min-width:200px;box-shadow:0 18px 45px rgba(0,0,0,.65),0 0 22px rgba(var(--acc-rgb),.09);backdrop-filter:blur(22px)}
.theme-panel.open{opacity:1;pointer-events:all;transform:translateY(0) scale(1)}
.tp-label{font-family:var(--ff-mono);font-size:7px;letter-spacing:.22em;color:var(--t3);margin-bottom:10px}
.tp-swatches{display:flex;gap:9px}
.swatch{width:22px;height:22px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .25s cubic-bezier(.34,1.56,.64,1),border-color .2s,box-shadow .2s}
.swatch:hover{transform:scale(1.35);border-color:rgba(255,255,255,.65);box-shadow:0 0 12px var(--sw,#a855f7)}
.swatch.active{transform:scale(1.2);border-color:rgba(255,255,255,.8);box-shadow:0 0 16px var(--sw,#a855f7)}
.nav-premium-btn{display:flex;align-items:center;gap:6px;padding:6px 15px;font-family:var(--ff-mono);font-size:9px;letter-spacing:.14em;font-weight:700;color:#000;background:linear-gradient(135deg,#f59e0b,#fbbf24,#f59e0b);background-size:200% 100%;border:1px solid #f59e0b;border-radius:var(--r1);white-space:nowrap;text-decoration:none;box-shadow:0 0 14px rgba(245,158,11,.38),inset 0 1px 0 rgba(255,255,255,.22);position:relative;overflow:hidden;transition:box-shadow .2s,transform .15s,filter .2s;animation:premGradShift 3s linear infinite}
@keyframes premGradShift{0%{background-position:0%}100%{background-position:200%}}
.prem-shimmer{position:absolute;top:0;left:-100%;width:55%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);transform:skewX(-14deg);animation:premShimmer 2.8s ease-in-out infinite 1.2s;pointer-events:none}
@keyframes premShimmer{0%{left:-55%}100%{left:160%}}
.nav-premium-btn:hover{transform:translateY(-2px);box-shadow:0 0 26px rgba(245,158,11,.65),0 6px 22px rgba(245,158,11,.28);filter:brightness(1.1)}
.nav-config-btn{display:flex;align-items:center;gap:6px;padding:5px 12px;font-family:var(--ff-mono);font-size:9px;letter-spacing:.12em;color:var(--t2);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:var(--r1);white-space:nowrap;cursor:pointer;transition:all .2s}
.cfg-spin{display:inline-block;transition:transform .4s cubic-bezier(.34,1.56,.64,1)}
.nav-config-btn:hover{border-color:rgba(var(--acc-rgb),.4);color:var(--acc);background:rgba(var(--acc-rgb),.07);transform:translateY(-1px);box-shadow:0 0 12px rgba(var(--acc-rgb),.12)}
.nav-config-btn:hover .cfg-spin{transform:rotate(90deg)}
.nav-user{display:flex;align-items:center;gap:8px;padding:5px 12px 5px 7px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:30px;cursor:default;transition:all .2s}
.nav-user:hover{border-color:rgba(var(--acc-rgb),.3);background:rgba(var(--acc-rgb),.05);box-shadow:0 0 12px rgba(var(--acc-rgb),.09)}
.nav-av{width:28px;height:28px;border-radius:50%;background:rgba(var(--acc-rgb),.15);border:1.5px solid rgba(var(--acc-rgb),.35);display:flex;align-items:center;justify-content:center;font-family:var(--ff-head);font-size:16px;color:var(--acc);flex-shrink:0;position:relative}
.avatar-online-ring{position:absolute;inset:-4px;border-radius:50%;border:1.5px solid rgba(34,197,94,.0);animation:onlineRing 2.8s ease-in-out infinite;pointer-events:none}
@keyframes onlineRing{0%{border-color:rgba(34,197,94,.0);transform:scale(1)}30%{border-color:rgba(34,197,94,.55)}70%{border-color:rgba(34,197,94,.0);transform:scale(1.35)}100%{border-color:rgba(34,197,94,.0);transform:scale(1)}}
.nav-user-info{display:flex;flex-direction:column;gap:1px}
.nav-uname{font-family:var(--ff-mono);font-size:8.5px;letter-spacing:.1em;color:var(--t1);text-transform:uppercase;line-height:1}
.nav-user-status{font-family:var(--ff-mono);font-size:6.5px;letter-spacing:.1em;color:#22c55e;text-transform:uppercase;line-height:1;display:flex;align-items:center;gap:3px}
.nav-user-status::before{content:'';width:4px;height:4px;border-radius:50%;background:#22c55e;box-shadow:0 0 5px #22c55e;flex-shrink:0;animation:statusBlink 2s ease-in-out infinite}
@keyframes statusBlink{0%,100%{opacity:1}50%{opacity:.25}}
.nav-logout-btn{background:transparent;border:none;color:var(--t3);cursor:pointer;font-size:14px;transition:color .2s;padding:2px 4px;flex-shrink:0}
.nav-logout-btn:hover{color:#ef4444}
.navbar.scrolled{border-bottom-color:rgba(var(--acc-rgb),.18);box-shadow:0 4px 30px rgba(0,0,0,.55),0 1px 0 rgba(var(--acc-rgb),.08)}
.nav-hamburger{display:none;align-items:center;justify-content:center;width:34px;height:34px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:var(--r1);color:var(--t2);cursor:pointer;font-size:16px;transition:all .2s}
.nav-hamburger:hover{border-color:rgba(var(--acc-rgb),.4);color:var(--acc)}
@media(max-width:960px){.nav-links{display:none}.nav-hamburger{display:flex}.nav-home-btn{display:none}}

/* ══ SCROLL PROGRESS ═══════════════════════════════════════ */
.scroll-prog-bar{position:fixed;top:0;left:0;right:0;height:2px;z-index:1001}
#scrollProg{height:100%;width:0;background:var(--acc);box-shadow:var(--acc-glow);transition:width .1s}

/* ══ PAGE WRAP ═════════════════════════════════════════════ */
.page-wrap{
  position:relative;z-index:1;
  padding-top:calc(var(--nav-h) + 24px);
  padding-left:24px;padding-right:24px;padding-bottom:60px;
  max-width:1400px;margin:0 auto;
}

/* ══ PAGE HEADER ═══════════════════════════════════════════ */
.page-header{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:24px;gap:16px;flex-wrap:wrap;
}
.ph-left{}
.ph-eyebrow{
  font-family:var(--ff-m);font-size:8px;letter-spacing:.28em;
  color:var(--acc);text-transform:uppercase;margin-bottom:4px;
  display:flex;align-items:center;gap:8px;
}
.ph-eyebrow::before{content:'';width:18px;height:1px;background:var(--acc);opacity:.6}
.ph-title{
  font-family:var(--ff-d);font-size:42px;letter-spacing:.08em;
  color:var(--txt);line-height:1;
}
.ph-title span{color:var(--acc)}
.ph-sub{
  font-family:var(--ff-m);font-size:9px;color:var(--txt3);
  letter-spacing:.14em;margin-top:5px;
}
.ph-right{display:flex;align-items:center;gap:10px;flex-shrink:0}

/* ══ CATEGORY TABS ═════════════════════════════════════════ */
.cat-tabs{
  display:flex;gap:6px;margin-bottom:20px;
  flex-wrap:wrap;
}
.cat-tab{
  padding:7px 16px;font-family:var(--ff-m);font-size:8px;letter-spacing:.14em;
  color:var(--txt3);background:rgba(255,255,255,.03);border:1px solid var(--border);
  border-radius:var(--rad-s);cursor:pointer;transition:all .2s;text-transform:uppercase;
}
.cat-tab:hover{color:var(--txt2);border-color:var(--border2)}
.cat-tab.active{color:var(--acc);background:var(--acc-dim);border-color:rgba(var(--acc-rgb),.35)}

/* ══ SEARCH + FILTER BAR ═══════════════════════════════════ */
.filter-bar{
  display:flex;align-items:center;gap:10px;margin-bottom:20px;flex-wrap:wrap;
}
.search-wrap{
  flex:1;min-width:200px;position:relative;
}
.search-icon{
  position:absolute;left:12px;top:50%;transform:translateY(-50%);
  font-size:12px;color:var(--txt3);pointer-events:none;
}
.search-input{
  width:100%;padding:8px 12px 8px 34px;
  background:rgba(255,255,255,.04);border:1px solid var(--border2);
  border-radius:var(--rad-s);font-family:var(--ff-m);font-size:9px;
  letter-spacing:.1em;color:var(--txt);transition:all .2s;
}
.search-input::placeholder{color:var(--txt3)}
.search-input:focus{border-color:rgba(var(--acc-rgb),.5);background:rgba(var(--acc-rgb),.04);outline:none}
.filter-btn{
  display:flex;align-items:center;gap:6px;
  padding:7px 14px;font-family:var(--ff-m);font-size:8px;letter-spacing:.12em;
  color:var(--txt2);background:rgba(255,255,255,.04);border:1px solid var(--border2);
  border-radius:var(--rad-s);cursor:pointer;transition:all .2s;white-space:nowrap;
}
.filter-btn:hover{border-color:rgba(var(--acc-rgb),.4);color:var(--acc)}
.filter-btn.active{background:var(--acc-dim);border-color:rgba(var(--acc-rgb),.4);color:var(--acc)}

/* ══ TOP 3 PODIUM ══════════════════════════════════════════ */
.podium-row{
  display:grid;grid-template-columns:1fr 1.1fr 1fr;gap:12px;
  margin-bottom:24px;align-items:end;
}
.podium-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--rad);padding:20px 16px;
  display:flex;flex-direction:column;align-items:center;
  gap:8px;position:relative;overflow:hidden;transition:all .25s;
}
.podium-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(var(--acc-rgb),.04) 0%,transparent 60%);
  pointer-events:none;
}
.podium-card.first{
  border-color:rgba(245,158,11,.3);
  background:linear-gradient(160deg,rgba(245,158,11,.06) 0%,var(--card) 60%);
}
.podium-card.second{border-color:rgba(var(--acc-rgb),.2)}
.podium-card.third{border-color:rgba(var(--acc-rgb),.15)}
.podium-rank{
  font-family:var(--ff-d);font-size:11px;letter-spacing:.2em;
  color:var(--txt3);text-transform:uppercase;
}
.podium-card.first .podium-rank{color:#f59e0b}
.podium-medal{font-size:28px;line-height:1}
.podium-av{
  width:52px;height:52px;border-radius:50%;
  background:var(--acc-dim);border:2px solid rgba(var(--acc-rgb),.35);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-d);font-size:26px;color:var(--acc);
  flex-shrink:0;box-shadow:var(--acc-glow);
}
.podium-card.first .podium-av{border-color:rgba(245,158,11,.6);color:#f59e0b;background:rgba(245,158,11,.1);box-shadow:0 0 14px rgba(245,158,11,.4)}
.podium-name{font-family:var(--ff-d);font-size:16px;letter-spacing:.08em;color:var(--txt);text-align:center}
.podium-score{font-family:var(--ff-d);font-size:26px;letter-spacing:.06em;color:var(--acc)}
.podium-card.first .podium-score{color:#f59e0b;text-shadow:0 0 14px rgba(245,158,11,.5)}
.podium-tag{
  font-family:var(--ff-m);font-size:7px;letter-spacing:.14em;
  color:var(--txt3);text-transform:uppercase;
}

/* ══ RANKING TABLE ═════════════════════════════════════════ */
.rank-table-wrap{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--rad);overflow:hidden;margin-bottom:20px;
}
.rank-table-header{
  display:grid;grid-template-columns:60px 1fr 110px 110px 110px 110px 80px;
  padding:10px 16px;border-bottom:1px solid var(--border);
  background:rgba(255,255,255,.025);
}
.rth-cell{
  font-family:var(--ff-m);font-size:7px;letter-spacing:.18em;
  color:var(--txt3);text-transform:uppercase;
}
.rth-cell.center{text-align:center}
.rank-row{
  display:grid;grid-template-columns:60px 1fr 110px 110px 110px 110px 80px;
  padding:11px 16px;border-bottom:1px solid rgba(255,255,255,.035);
  align-items:center;transition:background .18s;cursor:default;
}
.rank-row:last-child{border-bottom:none}
.rank-row:hover{background:rgba(var(--acc-rgb),.04)}
.rank-row.highlight{
  background:rgba(var(--acc-rgb),.07);
  border-color:rgba(var(--acc-rgb),.12);
}
.rr-pos{
  font-family:var(--ff-d);font-size:18px;letter-spacing:.04em;
  color:var(--txt3);
}
.rr-pos.top1{color:#f59e0b}
.rr-pos.top2{color:rgba(200,200,220,.7)}
.rr-pos.top3{color:rgba(205,127,50,.8)}
.rr-player{display:flex;align-items:center;gap:10px;min-width:0}
.rr-av{
  width:30px;height:30px;border-radius:50%;flex-shrink:0;
  background:var(--acc-dim);border:1px solid rgba(var(--acc-rgb),.25);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-d);font-size:15px;color:var(--acc);
}
.rr-name{
  font-family:var(--ff-r);font-size:14px;font-weight:600;
  color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.rr-handle{
  font-family:var(--ff-m);font-size:7.5px;color:var(--txt3);
  letter-spacing:.08em;margin-top:1px;
}
.rr-val{
  font-family:var(--ff-d);font-size:16px;letter-spacing:.04em;
  color:var(--txt);text-align:center;
}
.rr-val.accent{color:var(--acc)}
.rr-val.green{color:#22c55e}
.rr-val.dim{color:var(--txt3);font-size:13px}
.rr-badge{
  display:flex;justify-content:center;
}
.rank-badge{
  font-family:var(--ff-m);font-size:7px;letter-spacing:.1em;
  padding:3px 8px;border-radius:4px;text-transform:uppercase;
  border:1px solid;
}
.rank-badge.s{color:#f59e0b;background:rgba(245,158,11,.1);border-color:rgba(245,158,11,.3)}
.rank-badge.a{color:var(--acc);background:var(--acc-dim);border-color:rgba(var(--acc-rgb),.3)}
.rank-badge.b{color:#22c55e;background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.3)}
.rank-badge.c{color:var(--txt2);background:rgba(255,255,255,.05);border-color:var(--border2)}

/* ══ PAGINATION ════════════════════════════════════════════ */
.pagination{
  display:flex;align-items:center;justify-content:center;
  gap:6px;margin-bottom:32px;
}
.page-btn{
  width:32px;height:32px;border-radius:var(--rad-s);
  background:rgba(255,255,255,.04);border:1px solid var(--border2);
  color:var(--txt3);font-family:var(--ff-m);font-size:9px;
  cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;
}
.page-btn:hover{border-color:rgba(var(--acc-rgb),.4);color:var(--acc)}
.page-btn.active{background:var(--acc-dim);border-color:rgba(var(--acc-rgb),.5);color:var(--acc)}
.page-btn:disabled{opacity:.3;cursor:default}

/* ══ STATS SIDEBAR ═════════════════════════════════════════ */
.rank-layout{display:grid;grid-template-columns:1fr 300px;gap:20px;align-items:start}
.rank-sidebar{display:flex;flex-direction:column;gap:14px}

/* ══ CARD ══════════════════════════════════════════════════ */
.card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--rad);padding:16px;position:relative;
  transition:border-color .25s;
}
.card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(var(--acc-rgb),.025) 0%,transparent 60%);pointer-events:none;border-radius:var(--rad)}
.card:hover{border-color:rgba(var(--acc-rgb),.18)}a
.card-lbl{font-family:var(--ff-m);font-size:8px;letter-spacing:.2em;color:var(--txt3);text-transform:uppercase;margin-bottom:12px}

/* ══ MINI STATS ════════════════════════════════════════════ */
.mini-stat{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}
.mini-stat:last-child{border-bottom:none}
.ms-label{font-family:var(--ff-m);font-size:8px;letter-spacing:.1em;color:var(--txt3)}
.ms-val{font-family:var(--ff-d);font-size:18px;color:var(--acc)}

/* ══ TIMER CARD ════════════════════════════════════════════ */
.timer-display{font-family:var(--ff-d);font-size:30px;letter-spacing:.1em;color:var(--acc);text-shadow:var(--acc-glow);text-align:center;margin:8px 0}
.timer-controls{display:flex;gap:8px}
.timer-btn{flex:1;padding:7px;border-radius:var(--rad-s);font-family:var(--ff-m);font-size:8px;letter-spacing:.12em;cursor:pointer;transition:all .2s;border:1px solid}
.timer-btn.start{background:var(--acc-dim);border-color:rgba(var(--acc-rgb),.3);color:var(--acc)}
.timer-btn.start:hover{background:rgba(var(--acc-rgb),.2)}
.timer-btn.start.running{color:#ef4444;border-color:rgba(239,68,68,.3);background:rgba(239,68,68,.1)}
.timer-btn.reset{background:transparent;border-color:var(--border2);color:var(--txt3)}
.timer-btn.reset:hover{color:var(--txt)}

/* ══ ANIMATIONS ════════════════════════════════════════════ */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.anim{animation:fadeUp .45s ease both}

/* ══ RESPONSIVE ════════════════════════════════════════════ */
@media(max-width:1100px){.rank-layout{grid-template-columns:1fr}}
@media(max-width:800px){
  .podium-row{grid-template-columns:1fr}
  .rank-table-header,.rank-row{grid-template-columns:50px 1fr 90px 90px}
  .rth-cell:nth-child(n+5),.rr-val:nth-child(n+5){display:none}
}
@media(max-width:520px){.page-wrap{padding-left:14px;padding-right:14px}}