@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Inter:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500&display=swap');

/* ═══════════════════════════════════════════════
   DESIGN TOKENS
═══════════════════════════════════════════════ */
:root {
  --bg-void:   #010208;
  --bg-deep:   #03050e;
  --bg-base:   #060a18;
  --bg-raise:  #09102a;
  --bg-panel:  rgba(9, 13, 28, 0.72);
  --bg-glass:  rgba(255, 255, 255, 0.028);
  --bg-glass2: rgba(255, 255, 255, 0.048);
  --wallpaper-url: none;
  --wallpaper-opacity: 0;

  --line-0:    rgba(255,255,255,0.042);
  --line-1:    rgba(255,255,255,0.08);
  --line-2:    rgba(255,255,255,0.14);
  --line-3:    rgba(255,255,255,0.22);

  --t1: #eef2ff;
  --t2: rgba(220,230,255,0.70);
  --t3: rgba(196,212,255,0.42);
  --t4: rgba(175,195,255,0.24);

  --aqua:       #00cfff;
  --aqua-mid:   rgba(0,207,255,0.18);
  --aqua-dim:   rgba(0,207,255,0.08);
  --violet:     #8b68ff;
  --violet-mid: rgba(139,104,255,0.18);
  --violet-dim: rgba(139,104,255,0.08);
  --rose:       #ff4d9e;
  --rose-mid:   rgba(255,77,158,0.14);
  --rose-dim:   rgba(255,77,158,0.06);
  --amber:      #fbbf24;
  --good:       #22c55e;
  --bad:        #f43f5e;
  --silver:     #94a3b8;

  --glow-a: rgba(0,207,255,0.5);
  --glow-v: rgba(139,104,255,0.5);
  --glow-r: rgba(255,77,158,0.4);

  --shadow-xs: 0 2px 8px rgba(0,0,0,0.4);
  --shadow-sm: 0 8px 32px rgba(0,0,0,0.48);
  --shadow-md: 0 20px 60px rgba(0,0,0,0.55), 0 0 0 0.5px var(--line-0);
  --shadow-lg: 0 32px 90px rgba(0,0,0,0.65), 0 0 0 0.5px var(--line-1);

  --r-xs: 6px;
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 22px;
  --r-xl: 30px;

  --wrap: min(1300px, calc(100% - 48px));
  --gap:  22px;

  --spring: cubic-bezier(.22,.68,0,1.2);
  --smooth: cubic-bezier(.16,1,.3,1);
}

/* ═══════════════════════════════════════════════
   RESET
═══════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: 72px; }
body {
  min-height: 100dvh;
  font-family: 'Inter', sans-serif;
  font-size: 15px; line-height: 1.65;
  color: var(--t1); background: var(--bg-void);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
img { display: block; max-width: 100%; }
ul, ol { list-style: none; }

/* ═══════════════════════════════════════════════
   BACKGROUND SCENE
═══════════════════════════════════════════════ */
.scene {
  position: fixed; inset: 0; z-index: 0;
  pointer-events: none; overflow: hidden;
}
.scene-wallpaper{
  position:absolute; inset:0;
  background-image: var(--wallpaper-url);
  background-size: cover;
  background-position: center;
  opacity: var(--wallpaper-opacity);
  transform: scale(1.03);
  filter: saturate(1.08) contrast(1.05);
}
.scene-blob {
  position: absolute; border-radius: 50%;
  filter: blur(100px); will-change: transform;
}
.scene-blob:nth-child(1) {
  width: 1000px; height: 700px; top: -220px; left: -280px;
  background: radial-gradient(ellipse, var(--aqua-dim), transparent 68%);
  transform: translate(calc(var(--mx,0) * 20px), calc(var(--my,0) * 12px));
  transition: transform 1.2s var(--smooth);
}
.scene-blob:nth-child(2) {
  width: 820px; height: 820px; top: -160px; right: -260px;
  background: radial-gradient(ellipse, var(--violet-mid), transparent 68%);
  transform: translate(calc(var(--mx,0) * -16px), calc(var(--my,0) * 18px));
  transition: transform 1.4s var(--smooth);
}
.scene-blob:nth-child(3) {
  width: 640px; height: 640px; bottom: -120px; left: 28%;
  background: radial-gradient(ellipse, var(--rose-dim), transparent 68%);
  transform: translate(calc(var(--mx,0) * 10px), calc(var(--my,0) * -10px));
  transition: transform 1.6s var(--smooth);
}
.scene-stars {
  position: absolute; inset: 0;
  background-image:
    radial-gradient(1px 1px at  7% 13%, rgba(255,255,255,.55), transparent 60%),
    radial-gradient(1px 1px at 21% 67%, rgba(255,255,255,.28), transparent 60%),
    radial-gradient(1px 1px at 37%  8%, rgba(255,255,255,.42), transparent 60%),
    radial-gradient(1px 1px at 54% 81%, rgba(255,255,255,.32), transparent 60%),
    radial-gradient(1px 1px at 69% 31%, rgba(255,255,255,.26), transparent 60%),
    radial-gradient(1px 1px at 83% 57%, rgba(255,255,255,.35), transparent 60%),
    radial-gradient(1px 1px at 90% 19%, rgba(255,255,255,.22), transparent 60%),
    radial-gradient(1px 1px at 44% 44%, rgba(255,255,255,.20), transparent 60%),
    radial-gradient(1.5px 1.5px at 14% 44%, var(--glow-a), transparent 60%),
    radial-gradient(1.5px 1.5px at 72% 70%, var(--glow-v), transparent 60%),
    radial-gradient(1.5px 1.5px at 47% 27%, var(--glow-r), transparent 60%),
    radial-gradient(1.5px 1.5px at 88% 85%, var(--aqua-mid), transparent 60%);
  opacity: .65;
}
.scene-grid {
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(0deg, transparent, transparent 79px, rgba(255,255,255,.014) 80px);
  mask-image: radial-gradient(ellipse 80% 55% at 50% 0%, black 20%, transparent 80%);
}

/* ═══════════════════════════════════════════════
   SHELL & WRAP
═══════════════════════════════════════════════ */
.site-shell { position: relative; z-index: 1; min-height: 100dvh; display: flex; flex-direction: column; }
main { flex: 1; }
.wrap { width: var(--wrap); margin: 0 auto; }

/* ═══════════════════════════════════════════════
   TOPBAR
═══════════════════════════════════════════════ */
.topbar {
  position: sticky; top: 0; z-index: 200;
  height: 68px; display: flex; align-items: center;
  backdrop-filter: blur(28px) saturate(180%);
  -webkit-backdrop-filter: blur(28px) saturate(180%);
  background: rgba(1, 2, 8, 0.78);
  border-bottom: 0.5px solid var(--line-0);
}
.topbar::after {
  content: ''; position: absolute; bottom: -1px; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--aqua-mid), var(--violet-mid), transparent);
}
.topbar-inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; }

.brand { display: flex; align-items: center; gap: 13px; }
.brand--logo-only{gap:0}
.brand-logo{height:44px;width:auto;max-width:220px;object-fit:contain;display:block;filter:drop-shadow(0 10px 18px rgba(0,0,0,.35))}
.sigil {
  position: relative; width: 42px; height: 42px;
  border-radius: 12px; overflow: hidden;
  border: 0.5px solid rgba(255,255,255,.15); flex-shrink: 0;
}
.sigil-bg {
  position: absolute; inset: 0;
  background: conic-gradient(from 0deg, var(--aqua), var(--violet), var(--rose), var(--aqua));
  animation: spin 9s linear infinite;
}
.sigil-inner {
  position: absolute; inset: 2px; border-radius: 10px;
  background: var(--bg-base);
  display: flex; align-items: center; justify-content: center;
}
.sigil-glyph {
  font-family: 'Rajdhani', sans-serif; font-weight: 700; font-size: 15px; letter-spacing: .06em;
  background: linear-gradient(135deg, var(--aqua), var(--violet));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
@keyframes spin { to { transform: rotate(360deg); } }

.brand-text strong {
  display: block; font-family: 'Rajdhani', sans-serif;
  font-size: 17px; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; line-height: 1.1;
}
.brand-text small { display: block; font-size: 10px; color: var(--t3); letter-spacing: .09em; text-transform: uppercase; margin-top: 2px; }

.nav { display: flex; align-items: center; gap: 2px; }
.nav a {
  padding: 7px 13px; font-size: 13px; font-weight: 500;
  color: var(--t3); border-radius: var(--r-sm); letter-spacing: .04em;
  transition: color .18s, background .18s; position: relative;
}
.nav a:hover { color: var(--t1); background: var(--bg-glass2); }
.nav a.active { color: var(--aqua); }
.nav a.active::after {
  content: ''; position: absolute; bottom: 2px; left: 50%; transform: translateX(-50%);
  width: 16px; height: 1.5px; background: var(--aqua); border-radius: 2px;
}

.nav-cta {
  display: inline-flex; align-items: center; gap: 8px; padding: 9px 18px;
  font-size: 13px; font-weight: 600; letter-spacing: .06em; color: var(--t1);
  background: linear-gradient(135deg, var(--aqua-mid), var(--violet-mid));
  border: 0.5px solid rgba(0,207,255,.38); border-radius: var(--r-md); cursor: pointer;
  transition: transform .2s var(--spring), box-shadow .2s, border-color .2s;
}
.nav-cta:hover { transform: translateY(-1px); border-color: rgba(0,207,255,.65); box-shadow: 0 0 22px -4px var(--glow-a); }
.nav-cta::after { content: '→'; font-size: 14px; }

/* ═══════════════════════════════════════════════
   CARD
═══════════════════════════════════════════════ */
.card {
  background: var(--bg-panel); border: 0.5px solid var(--line-1);
  backdrop-filter: blur(28px) saturate(130%);
  -webkit-backdrop-filter: blur(28px) saturate(130%);
  box-shadow: var(--shadow-md); border-radius: var(--r-lg);
}
.card-pad { padding: 24px; }
.card-pad-lg { padding: 32px; }

/* ═══════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 13px 22px; font-size: 14px; font-weight: 600; letter-spacing: .04em;
  border-radius: var(--r-md); border: 0.5px solid var(--line-1); cursor: pointer;
  color: var(--t1);
  transition: transform .22s var(--spring), box-shadow .22s, border-color .22s, background .22s;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary {
  background: linear-gradient(135deg, rgba(0,207,255,.22), rgba(139,104,255,.18), rgba(255,77,158,.14));
  border-color: rgba(0,207,255,.42);
}
.btn-primary:hover { box-shadow: 0 10px 36px -8px var(--glow-a); border-color: rgba(0,207,255,.75); }
.btn-ghost { background: var(--bg-glass); }
.btn-ghost:hover { background: var(--bg-glass2); border-color: var(--line-2); }
.btn-violet { background: linear-gradient(135deg, rgba(139,104,255,.22), rgba(255,77,158,.16)); border-color: rgba(139,104,255,.42); }
.btn-violet:hover { box-shadow: 0 10px 36px -8px var(--glow-v); border-color: rgba(139,104,255,.75); }
.btn-sm { padding: 9px 16px; font-size: 13px; }
.btn-lg { padding: 16px 28px; font-size: 15px; }
.btn-full { width: 100%; }
.btn.disabled, .btn[disabled] { opacity: .45; pointer-events: none; filter: saturate(.5); }

/* ═══════════════════════════════════════════════
   HERO (home)
═══════════════════════════════════════════════ */
.hero-section { padding: 72px 0 56px; }
.hero-grid { display: grid; grid-template-columns: 1fr 400px; gap: 32px; align-items: center; }
.hero-left { display: flex; flex-direction: column; gap: 30px; }

.hero-badge {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 9px 18px; background: var(--bg-glass); border: 0.5px solid var(--line-1);
  border-radius: 999px; font-size: 12px; color: var(--t2); letter-spacing: .06em; width: fit-content;
}
.orb {
  width: 7px; height: 7px; border-radius: 50%; background: var(--good);
  box-shadow: 0 0 0 2px rgba(34,197,94,.2);
  animation: orb-pulse 2.6s ease-in-out infinite; flex-shrink: 0;
}
.orb.bad { background: var(--bad); box-shadow: 0 0 0 2px rgba(244,63,94,.2); }
@keyframes orb-pulse {
  0%,100% { box-shadow: 0 0 0 2px rgba(34,197,94,.2), 0 0 8px rgba(34,197,94,.4); }
  50%      { box-shadow: 0 0 0 5px rgba(34,197,94,0),  0 0 14px rgba(34,197,94,.55); }
}

.hero-headline {
  font-family: 'Rajdhani', sans-serif; font-weight: 700;
  font-size: clamp(52px, 8vw, 96px); line-height: .88; letter-spacing: -.04em;
}
.hero-headline .grad {
  background: linear-gradient(120deg, var(--aqua) 0%, var(--violet) 48%, var(--rose) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.hero-sub { font-size: 16px; line-height: 1.75; color: var(--t2); max-width: 52ch; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }

.stats-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.stat-box {
  padding: 16px 12px; background: var(--bg-glass); border: 0.5px solid var(--line-0);
  border-radius: var(--r-md); text-align: center;
  transition: border-color .22s, background .22s, transform .22s var(--spring);
}
.stat-box:hover { background: var(--bg-glass2); border-color: var(--line-1); transform: translateY(-2px); }
.stat-box .lbl { display: block; font-size: 10px; color: var(--t3); text-transform: uppercase; letter-spacing: .12em; margin-bottom: 7px; }
.stat-box .val { display: block; font-family: 'Rajdhani', sans-serif; font-size: 19px; font-weight: 700; color: var(--t1); line-height: 1; }

/* Portal */
.portal-wrap { display: flex; flex-direction: column; gap: 16px; padding: 22px; }
.portal-visual { display: grid; place-items: center; min-height: 300px; }
.portal-ring { position: relative; width: 240px; height: 240px; border-radius: 50%; }
.portal-ring::before {
  content: ''; position: absolute; inset: -11px; border-radius: 50%;
  background: conic-gradient(from 0deg, rgba(0,207,255,.8), rgba(139,104,255,.65), rgba(255,77,158,.65), rgba(0,207,255,.8));
  animation: spin 11s linear infinite;
  mask: radial-gradient(farthest-side, transparent calc(100% - 2px), black calc(100% - 2px));
  -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 2px), black calc(100% - 2px));
}
.portal-ring::after {
  content: ''; position: absolute; inset: -26px; border-radius: 50%;
  background: conic-gradient(from 200deg, rgba(0,207,255,.12), rgba(139,104,255,.16), rgba(255,77,158,.10), rgba(0,207,255,.12));
  filter: blur(22px); animation: spin 16s linear infinite reverse;
}
.portal-inner {
  position: relative; width: 100%; height: 100%; border-radius: 50%;
  background:
    radial-gradient(circle at 32% 28%, rgba(0,207,255,.13), transparent 60%),
    radial-gradient(circle at 70% 72%, rgba(139,104,255,.11), transparent 55%),
    var(--bg-deep);
  border: 0.5px solid var(--line-1);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; gap: 4px; z-index: 1;
}
.portal-label { font-size: 9px; letter-spacing: .24em; text-transform: uppercase; color: var(--t3); }
.portal-season {
  font-family: 'Rajdhani', sans-serif; font-size: 40px; font-weight: 700;
  letter-spacing: -.025em; line-height: 1;
  background: linear-gradient(135deg, var(--aqua), var(--violet));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.portal-rates { font-size: 13px; color: var(--t2); }

.portal-ip-row {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 13px 15px; background: var(--bg-glass); border: 0.5px solid var(--line-0); border-radius: var(--r-md);
}
.ip-stack small { display: block; font-size: 9px; text-transform: uppercase; letter-spacing: .12em; color: var(--t3); margin-bottom: 4px; }
.ip-val { font-family: 'JetBrains Mono', monospace; font-size: 13px; font-weight: 500; color: var(--t1); }
.copy-btn {
  padding: 7px 13px; font-size: 11px; font-weight: 600; letter-spacing: .05em;
  color: var(--t2); background: var(--bg-glass); border: 0.5px solid var(--line-1);
  border-radius: var(--r-xs); cursor: pointer;
  transition: color .18s, border-color .18s, transform .18s;
}
.copy-btn:hover { color: var(--t1); border-color: var(--line-2); transform: translateY(-1px); }
.copy-btn.copied { color: var(--good); border-color: rgba(34,197,94,.4); }
.server-time-row { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--t3); text-align: center; padding: 4px 0; }
.portal-block { display: grid; gap: 12px; }
.portal-block-title { font-family: 'Rajdhani', sans-serif; font-size: 18px; font-weight: 700; color: var(--t1); text-align: center; }
.portal-login-form { display: grid; gap: 10px; }
.portal-input { width: 100%; padding: 10px 12px; background: rgba(255,255,255,.03); border: 0.5px solid var(--line-1); color: var(--t1); border-radius: var(--r-sm); outline: none; transition: border-color .2s, box-shadow .2s, background .2s; font-size: 13px; }
.portal-input::placeholder { color: var(--t4); }
.portal-input:hover { border-color: var(--line-2); background: rgba(255,255,255,.04); }
.portal-input:focus { border-color: rgba(0,207,255,.5); box-shadow: 0 0 0 3px rgba(0,207,255,.07), 0 0 24px -10px var(--glow-a); background: rgba(0,207,255,.03); }
.site-shell input[type=checkbox]{appearance:none;-webkit-appearance:none;width:18px;height:18px;border-radius:6px;border:1px solid rgba(255,255,255,.22);background:rgba(0,0,0,.25);box-shadow:inset 0 1px 0 rgba(255,255,255,.06);cursor:pointer;display:inline-block;vertical-align:middle}
.site-shell input[type=checkbox]:hover{border-color:rgba(0,230,118,.45)}
.site-shell input[type=checkbox]:focus{outline:none;box-shadow:0 0 0 3px rgba(0,230,118,.14),inset 0 1px 0 rgba(255,255,255,.06)}
.site-shell input[type=checkbox]:checked{border-color:rgba(0,230,118,.70);background:rgba(0,230,118,.12);background-image:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20viewBox%3D%220%200%2024%2024%22%3E%3Cpath%20fill%3D%22%2300e676%22%20d%3D%22M9%2016.2%204.8%2012%203.4%2013.4%209%2019%2021%207%2019.6%205.6z%22/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:14px 14px}
.portal-sep { height: 1px; background: var(--line-1); margin: 8px 0; }
.portal-avatar { width: 60px; height: 60px; border-radius: 50%; background: rgba(255,255,255,.05); border: .5px solid var(--line-1); margin: 0 auto 10px; display: flex; align-items: center; justify-content: center; font-size: 24px; }
.portal-user { color: var(--t1); font-size: 18px; font-weight: 700; }
.portal-user-sub { color: var(--t2); font-size: 13px; }
.portal-actions { display: grid; gap: 10px; }
.portal-empty { color: var(--t3); font-size: 13px; text-align: center; padding: 8px 0; }
.portal-market-list { display: grid; gap: 8px; }
.portal-market-item { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: rgba(255,255,255,.02); border: .5px solid rgba(255,255,255,.06); border-radius: var(--r-sm); }
.pmi-icon { width: 28px; height: 28px; border-radius: 6px; background: rgba(0,0,0,.35); border: 1px solid rgba(255,255,255,.08); image-rendering: pixelated; }
.pmi-name { color: var(--t1); font-weight: 600; font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 180px; }
.pmi-price { margin-left: auto; color: var(--t2); font-family: 'JetBrains Mono', monospace; font-size: 12px; }
.pmi-cur { color: var(--aqua); margin-left: 6px; }

.market-char-card .rank-tooltip{width:100%;background:linear-gradient(180deg,rgba(6,8,16,.96),rgba(6,8,16,.88));border:1px solid rgba(255,185,110,.14);border-radius:18px;box-shadow:0 22px 60px rgba(0,0,0,.6);overflow:visible}
.market-char-card .rank-tooltip{position:relative;top:auto;left:auto;opacity:1;visibility:visible;transform:none;pointer-events:auto}
.market-char-card .rank-tt-content{display:flex;gap:14px;align-items:stretch;padding:12px}
.market-char-card .rank-tt-left{flex:1;min-width:260px}
.market-char-card .rank-tt-right{flex:0 0 330px;display:flex;align-items:center;justify-content:center}
.market-char-card .rank-tt-left-card{padding:12px;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.market-char-card .rank-tt-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.market-char-card .rank-tt-top-left{display:flex;align-items:flex-start;gap:12px;min-width:0}
.market-char-card .rank-tt-id{min-width:0}
.market-char-card .rank-tt-name{font-size:18px;font-weight:900;color:#fff4e8;line-height:1.15}
.market-char-card .rank-tt-class{margin-top:4px;font-size:12px;letter-spacing:.06em;color:var(--t3);text-transform:none}
.market-char-card .rank-tt-status{font-weight:900;font-size:12px;letter-spacing:.08em;text-transform:uppercase;padding:8px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);white-space:nowrap}
.market-char-card .rank-tt-status.is-online{color:#20d65a;border-color:rgba(32,214,90,.25);background:rgba(32,214,90,.08)}
.market-char-card .rank-tt-status.is-offline{color:#e03e3e;border-color:rgba(224,62,62,.25);background:rgba(224,62,62,.08)}
.market-char-card .rank-class-ico--tt{width:100px;height:100px;border-radius:16px;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.12);image-rendering:pixelated;flex:0 0 auto}
.market-char-card .tt-stat{padding:6px 10px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);font-size:12px}
.market-char-card .tt-lbl{color:var(--t3)}
.market-char-card .tt-val{font-weight:900}
.market-char-card .tt-body{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.market-char-card .rank-equip{width:330px;max-width:330px;display:flex;align-items:center;justify-content:center}
.market-char-card .rank-equip-loading{color:var(--t3);font-size:12px}
.market-char-card .rank-equip-frame{width:330px;max-width:330px;padding:9px;border-radius:16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.market-char-card .rank-equip-head{font-size:12px;font-weight:900;letter-spacing:.18em;text-transform:uppercase;color:#f6cb97;margin-bottom:10px}
.market-char-card .rank-equip-stage{position:relative;width:316px;height:316px;border-radius:14px;background-size:contain;background-position:center;background-repeat:no-repeat;overflow:visible}
.market-char-card .rank-equip-slot{position:absolute;width:66px;height:66px;background-size:contain;background-position:center;background-repeat:no-repeat}
.market-char-card .rank-equip-slot.ring-slot,.market-char-card .rank-equip-slot.pendant-slot{width:29px;height:29px;background-size:70%}
.market-char-card .rank-equip-slot.pet-slot{left:23px;top:36px}
.market-char-card .rank-equip-slot.helm-slot{left:125px;top:36px}
.market-char-card .rank-equip-slot.wings-slot{right:23px;top:36px}
.market-char-card .rank-equip-slot.left-hand-slot{left:23px;top:109px}
.market-char-card .rank-equip-slot.chest-slot{left:125px;top:109px}
.market-char-card .rank-equip-slot.right-hand-slot{right:23px;top:109px}
.market-char-card .rank-equip-slot.gloves-slot{left:23px;bottom:36px}
.market-char-card .rank-equip-slot.pants-slot{left:125px;bottom:36px}
.market-char-card .rank-equip-slot.boots-slot{right:23px;bottom:36px}
.market-char-card .rank-equip-slot.pendant-slot{left:90px;top:115px}
.market-char-card .rank-equip-slot.ring-left{left:90px;top:207px}
.market-char-card .rank-equip-slot.ring-right{right:102px;top:207px}
.market-char-card .rank-equip-slot.has-item{cursor:pointer}
.market-char-card .rank-equip-tip{display:none;position:absolute;left:50%;top:100%;transform:translate(-50%,10px);width:300px;max-width:300px;background:rgba(10,4,2,.96);border:1px solid rgba(255,185,110,.18);border-radius:14px;padding:10px;z-index:3000;box-shadow:0 16px 40px rgba(0,0,0,.55);text-align:left}
.market-char-card .rank-equip-slot:hover .rank-equip-tip{display:block}
.market-char-card .rank-equip-tip-title{color:#fff4e8;font-weight:900;font-size:13px;margin-bottom:8px}
.market-char-card .rank-equip-tip-line{color:var(--t2);font-size:12px;line-height:1.5;padding:4px 0;border-top:1px solid rgba(255,255,255,.06)}
.market-char-card .rank-equip-tip-line:first-of-type{border-top:none}
@media (max-width: 980px){
  .market-char-card .rank-tt-content{flex-direction:column}
  .market-char-card .rank-tt-right{flex:1 1 auto}
  .market-char-card .rank-equip-frame,.market-char-card .rank-equip{width:100%;max-width:100%}
  .market-char-card .rank-equip-stage{width:316px;height:316px}
}

/* ═══════════════════════════════════════════════
   FEATURES STRIP
═══════════════════════════════════════════════ */
.features-strip { border-top: 0.5px solid var(--line-0); border-bottom: 0.5px solid var(--line-0); }
.features-strip-inner {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 0.5px; background: var(--line-0); border-radius: var(--r-md); overflow: hidden;
}
.feat-item { padding: 20px; background: var(--bg-deep); display: flex; align-items: flex-start; gap: 14px; transition: background .18s; }
.feat-item:hover { background: rgba(255,255,255,.02); }
.feat-icon { width: 32px; height: 32px; border-radius: var(--r-xs); background: var(--bg-raise); border: 0.5px solid var(--line-1); display: grid; place-items: center; font-size: 15px; flex-shrink: 0; }
.feat-text strong { display: block; font-size: 13px; font-weight: 600; color: var(--t1); margin-bottom: 3px; }
.feat-text span { font-size: 11px; color: var(--t3); line-height: 1.5; }

/* ═══════════════════════════════════════════════
   SECTION SHARED
═══════════════════════════════════════════════ */
.section { padding: 68px 0; }
.section-label {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: 11px; font-weight: 600; letter-spacing: .2em; text-transform: uppercase;
  color: var(--aqua); margin-bottom: 12px;
}
.section-label::before { content: ''; width: 20px; height: 1.5px; background: linear-gradient(90deg, var(--aqua), transparent); border-radius: 2px; }
.section-title { font-family: 'Rajdhani', sans-serif; font-size: clamp(34px, 5.5vw, 62px); font-weight: 700; line-height: .92; letter-spacing: -.035em; margin-bottom: 16px; }
.section-sub { font-size: 15px; color: var(--t2); max-width: 52ch; line-height: 1.72; }
.section-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; margin-bottom: 34px; }

/* ═══════════════════════════════════════════════
   PAGE HEADER (inner pages)
═══════════════════════════════════════════════ */
.page-header {
  padding: 52px 0 40px; border-bottom: 0.5px solid var(--line-0);
  margin-bottom: 48px; position: relative;
}
.page-header::after {
  content: ''; position: absolute; bottom: -1px; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,207,255,.12) 30%, rgba(139,104,255,.12) 60%, transparent);
}
.page-header-inner { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; }
.page-title { font-family: 'Rajdhani', sans-serif; font-size: clamp(38px, 6vw, 68px); font-weight: 700; line-height: .9; letter-spacing: -.035em; }
.page-meta { font-size: 14px; color: var(--t3); max-width: 44ch; line-height: 1.6; margin-top: 10px; }

/* ═══════════════════════════════════════════════
   RANKING PAGE
═══════════════════════════════════════════════ */
.ranking-layout { display: grid; grid-template-columns: 1fr 310px; gap: var(--gap); align-items: start; padding-bottom: 64px; }

/* RANKING TOOLTIP */
.rank-row { position: relative; }
.rank-name-col { position: relative; cursor: pointer; }
.rank-name { font-weight: 600; color: var(--t1); border-bottom: 1px dashed rgba(255,255,255,.2); padding-bottom: 2px; }
.rank-name:hover { color: var(--primary); border-bottom-color: var(--primary); }

.rank-tooltip {
  position: fixed;
  top: 0;
  left: 0;
  margin-top: 0;
  background: rgba(10,12,18,.95);
  backdrop-filter: blur(10px);
  border: 1px solid var(--line-1);
  border-radius: var(--r-md);
  box-shadow: 0 10px 30px rgba(0,0,0,.8);
  width: 320px;
  z-index: 10000;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: all .2s ease;
  pointer-events: none;
}
.rank-name-col.open .rank-tooltip {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.ranking-layout.single { grid-template-columns: 1fr; }
.ranking-layout.single .table-responsive { overflow: visible; }
.tt-header {
  padding: 14px;
  border-bottom: 1px solid var(--line-1);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(255,255,255,.02);
}
.tt-name { color: var(--gold); font-weight: 700; font-size: 16px; }
.tt-class { color: var(--t2); font-size: 13px; font-family: "JetBrains Mono", monospace; }
.tt-body {
  padding: 14px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.tt-col { display: grid; gap: 8px; }
.tt-stat { display: flex; justify-content: space-between; font-size: 13px; border-bottom: 1px solid rgba(255,255,255,.05); padding-bottom: 4px; }
.tt-lbl { color: var(--t3); }
.tt-val { font-weight: 600; }

.rank-pos {
  width: 32px; height: 32px;
  background: rgba(255,255,255,.05);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-family: "JetBrains Mono", monospace;
  font-size: 13px; color: var(--t2); font-weight: 600;
}
.rank-row:nth-child(1) .rank-pos { background: rgba(255,215,0,.15); color: #ffd700; box-shadow: 0 0 15px rgba(255,215,0,.2); }
.rank-row:nth-child(2) .rank-pos { background: rgba(192,192,192,.15); color: #c0c0c0; }
.rank-row:nth-child(3) .rank-pos { background: rgba(205,127,50,.15); color: #cd7f32; }
.table-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.table-title { font-family: 'Rajdhani', sans-serif; font-size: 19px; font-weight: 700; }
.db-badge { padding: 4px 10px; border-radius: 999px; font-size: 10px; font-weight: 600; letter-spacing: .05em; }
.db-badge.ok { background: rgba(34,197,94,.1); border: 0.5px solid rgba(34,197,94,.28); color: #86efac; }
.db-badge.err { background: rgba(244,63,94,.1); border: 0.5px solid rgba(244,63,94,.28); color: #fda4af; }

.ranking-table { width: 100%; border-collapse: collapse; }
.ranking-table thead tr { border-bottom: 0.5px solid var(--line-1); }
.ranking-table th { padding: 10px 12px; text-align: left; font-size: 10px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--t3); }
.ranking-table th:first-child { padding-left: 4px; }
.ranking-table td { padding: 13px 12px; font-size: 14px; border-bottom: 0.5px solid var(--line-0); color: var(--t2); vertical-align: middle; }
.ranking-table td:first-child { padding-left: 4px; }
.ranking-table tbody tr { transition: background .15s; }
.ranking-table tbody tr:hover { background: rgba(255,255,255,.022); }
.ranking-table tbody tr:last-child td { border-bottom: none; }

.rank-num { font-family: 'JetBrains Mono', monospace; font-size: 13px; font-weight: 500; color: var(--t3); display: inline-block; min-width: 22px; }
.rank-1 .rank-num { color: var(--amber); text-shadow: 0 0 10px rgba(251,191,36,.45); }
.rank-2 .rank-num { color: var(--silver); }
.rank-3 .rank-num { color: #cd7f32; }
.char-name { font-weight: 600; color: var(--t1); font-size: 14px; }
.class-tag { display: inline-block; padding: 2px 7px; background: var(--bg-raise); border: 0.5px solid var(--line-1); border-radius: var(--r-xs); font-family: 'JetBrains Mono', monospace; font-size: 10px; font-weight: 500; color: var(--aqua); letter-spacing: .05em; }
.lvl-val { font-family: 'JetBrains Mono', monospace; font-size: 13px; font-weight: 500; color: var(--t1); }
.reset-badge { font-family: 'Rajdhani', sans-serif; font-size: 17px; font-weight: 700; color: var(--violet); }
.mr-badge { font-family: 'Rajdhani', sans-serif; font-size: 17px; font-weight: 700; color: var(--rose); }

.ranking-side { display: flex; flex-direction: column; gap: 16px; }
.side-card-title { font-size: 11px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--t3); margin-bottom: 16px; }
.db-list { display: flex; flex-direction: column; gap: 9px; }
.db-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; font-size: 13px; padding: 7px 0; border-bottom: 0.5px solid var(--line-0); }
.db-row:last-child { border-bottom: none; }
.db-row-label { color: var(--t3); }
.db-row-val { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--t2); }
.feature-list { display: flex; flex-direction: column; gap: 10px; }
.feature-item { padding: 12px 14px; background: var(--bg-glass); border: 0.5px solid var(--line-0); border-radius: var(--r-sm); transition: border-color .18s, background .18s; }
.feature-item:hover { background: var(--bg-glass2); border-color: var(--line-1); }
.feature-item strong { display: block; font-size: 12px; font-weight: 600; color: var(--t1); margin-bottom: 3px; }
.feature-item span { font-size: 11px; color: var(--t3); line-height: 1.5; }
.debug-box { margin-top: 14px; padding: 12px 14px; background: rgba(0,0,0,.3); border: 0.5px solid var(--line-0); border-radius: var(--r-sm); font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--t3); display: grid; gap: 6px; }

/* ═══════════════════════════════════════════════
   REGISTER PAGE
═══════════════════════════════════════════════ */
.register-layout { display: grid; grid-template-columns: 1fr; gap: 16px; align-items: start; padding-bottom: 64px; max-width: 760px; margin: 0 auto; }
.register-layout .register-card{padding:28px 28px 24px}
.register-layout .register-header{margin-bottom:18px}
.register-layout .register-title{font-size:18px}
#cuentas .section-head{flex-direction:column;align-items:center;justify-content:center;text-align:center}
#cuentas .section-head .section-label{justify-content:center}
#cuentas .section-head .section-title{margin-left:auto;margin-right:auto}
#cuentas .section-head .section-sub{margin-left:auto;margin-right:auto;max-width:560px}
.register-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
.register-title { font-family: 'Rajdhani', sans-serif; font-size: 20px; font-weight: 700; }
.alert { padding: 13px 16px; border-radius: var(--r-md); border: 0.5px solid; font-size: 14px; line-height: 1.5; margin-bottom: 20px; }
.alert-success { background: rgba(34,197,94,.09); border-color: rgba(34,197,94,.28); color: #86efac; }
.alert-error   { background: rgba(244,63,94,.09); border-color: rgba(244,63,94,.28); color: #fda4af; }
.register-form { display: flex; flex-direction: column; gap: 22px; }
.fields-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.field { display: flex; flex-direction: column; gap: 8px; }
.field label { font-size: 11px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--t3); }
.field input,
.field select,
.field textarea { width: 100%; padding: 11px 12px; background: rgba(255,255,255,.03); border: 0.5px solid var(--line-1); border-radius: var(--r-md); color: var(--t1); font-size: 13px; outline: none; transition: border-color .2s, box-shadow .2s, background .2s; }
.field input::placeholder { color: var(--t4); }
.field input:hover,
.field select:hover,
.field textarea:hover { border-color: var(--line-2); background: rgba(255,255,255,.04); }
.field input:focus,
.field select:focus,
.field textarea:focus { border-color: rgba(0,207,255,.5); box-shadow: 0 0 0 3px rgba(0,207,255,.07), 0 0 24px -10px var(--glow-a); background: rgba(0,207,255,.03); }
.form-note { font-size: 13px; color: var(--t3); line-height: 1.55; }
.form-note .mono { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--aqua); }
.btn-submit { width: 100%; justify-content: center; padding: 14px; font-size: 14px; }
.req-list { display: flex; flex-direction: column; gap: 12px; }
.req-item { padding: 13px 15px; background: var(--bg-glass); border: 0.5px solid var(--line-0); border-radius: var(--r-md); transition: border-color .18s; }
.req-item:hover { border-color: var(--line-1); }
.req-item strong { display: block; font-size: 13px; font-weight: 600; color: var(--t1); margin-bottom: 4px; }
.req-item span { font-size: 12px; color: var(--t3); line-height: 1.5; }
.mono-tag { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--aqua); }

/* ═══════════════════════════════════════════════
   DOWNLOADS PAGE
═══════════════════════════════════════════════ */
.downloads-layout { padding-bottom: 64px; }
.downloads-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap); margin-bottom: 28px; }
.dl-card { display: flex; flex-direction: column; gap: 20px; padding: 28px; transition: transform .25s var(--spring), box-shadow .25s; }
.dl-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.dl-icon-wrap { width: 52px; height: 52px; border-radius: var(--r-md); display: grid; place-items: center; font-size: 24px; background: var(--bg-raise); border: 0.5px solid var(--line-1); }
.dl-icon-wrap.aqua   { background: var(--aqua-dim);   border-color: rgba(0,207,255,.22); }
.dl-icon-wrap.violet { background: var(--violet-dim);  border-color: rgba(139,104,255,.22); }
.dl-icon-wrap.rose   { background: var(--rose-dim);    border-color: rgba(255,77,158,.22); }
.dl-name { font-family: 'Rajdhani', sans-serif; font-size: 20px; font-weight: 700; margin-bottom: 4px; }
.dl-desc { font-size: 13px; color: var(--t2); line-height: 1.6; }
.dl-meta { display: flex; flex-direction: column; gap: 7px; }
.dl-meta-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; font-size: 12px; }
.dl-meta-row span { color: var(--t3); }
.dl-meta-row strong { color: var(--t1); font-weight: 500; font-family: 'JetBrains Mono', monospace; font-size: 11px; }
.download-note { padding: 16px 20px; background: var(--bg-glass); border: 0.5px solid var(--line-0); border-radius: var(--r-md); font-size: 13px; color: var(--t2); line-height: 1.6; }
.download-note strong { color: var(--t1); }

/* ═══════════════════════════════════════════════
   EVENTS
═══════════════════════════════════════════════ */
.events-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--gap); }
.event-card { padding: 24px; display: flex; flex-direction: column; gap: 12px; transition: transform .25s var(--spring), box-shadow .25s; }
.event-card:hover { transform: translateY(-4px); box-shadow: 0 32px 80px rgba(0,0,0,.6), 0 0 0 0.5px var(--line-2); }
.event-when { display: inline-block; padding: 5px 12px; background: var(--bg-glass); border: 0.5px solid var(--line-1); border-radius: 999px; font-size: 10px; font-weight: 500; letter-spacing: .06em; color: var(--t3); width: fit-content; }
.event-title { font-family: 'Rajdhani', sans-serif; font-size: 22px; font-weight: 700; letter-spacing: -.01em; color: var(--t1); }
.event-desc { font-size: 13px; color: var(--t2); line-height: 1.6; flex: 1; }
.event-line { height: 1.5px; border-radius: 2px; background: linear-gradient(90deg, var(--aqua), var(--violet), transparent); }

/* ═══════════════════════════════════════════════
   SOCIALS
═══════════════════════════════════════════════ */
.socials-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }
.social-card { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; min-height: 116px; padding: 20px 12px; background: var(--bg-panel); border: 0.5px solid var(--line-1); border-radius: var(--r-lg); backdrop-filter: blur(20px); text-align: center; transition: transform .25s var(--spring), box-shadow .25s, border-color .25s; box-shadow: var(--shadow-md); }
.social-card:hover { transform: translateY(-4px); border-color: var(--line-2); box-shadow: 0 24px 64px rgba(0,0,0,.55), 0 0 0 0.5px var(--line-2); }
.social-icon { font-size: 22px; line-height: 1; }
.social-name { font-size: 12px; font-weight: 600; color: var(--t2); letter-spacing: .05em; }

/* ═══════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════ */
.footer { padding: 28px 0 36px; border-top: 0.5px solid var(--line-0); margin-top: auto; }
.footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.footer-brand strong { display: block; font-family: 'Rajdhani', sans-serif; font-size: 15px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--t1); }
.footer-brand small { display: block; font-size: 11px; color: var(--t3); margin-top: 2px; }
.footer-links { display: flex; gap: 16px; }
.footer-links a { font-size: 12px; color: var(--t3); transition: color .18s; }
.footer-links a:hover { color: var(--t1); }

/* ═══════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .hero-grid { grid-template-columns: 1fr; }
  .portal-wrap { max-width: 460px; margin: 0 auto; }
  .stats-strip { grid-template-columns: repeat(4, 1fr); }
  .ranking-layout, .register-layout { grid-template-columns: 1fr; }
  .features-strip-inner { grid-template-columns: repeat(2, 1fr); }
  .events-grid { grid-template-columns: repeat(2, 1fr); }
  .socials-grid { grid-template-columns: repeat(3, 1fr); }
  .downloads-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  :root { --wrap: calc(100% - 32px); }
  .topbar-inner { gap: 12px; }
  .nav { display: none; }
  .hero-section { padding: 44px 0 32px; }
  .stats-strip { grid-template-columns: repeat(2, 1fr); }
  .features-strip-inner { grid-template-columns: 1fr; }
  .fields-grid { grid-template-columns: 1fr; }
  .events-grid { grid-template-columns: 1fr; }
  .socials-grid { grid-template-columns: repeat(2, 1fr); }
  .downloads-grid { grid-template-columns: 1fr; }
  .section { padding: 48px 0; }
  .page-header { padding: 36px 0 28px; margin-bottom: 32px; }
  .page-header-inner { flex-direction: column; align-items: flex-start; }
  .footer-inner { flex-direction: column; align-items: flex-start; gap: 14px; }
  .footer-links { flex-wrap: wrap; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
