/* FoxxFire — Modern Dark Theme v4.0 */
:root {
    --orange:      #ff7e00;
    --orange-dark: #cc6200;
    --orange-light:#ff9d00;
    --bg:          #060608;
    --bg2:         #0d0d0f;
    --bg3:         #111114;
    --bg-card:     #151518;
    --bg-panel:    #1a1a1e;
    --border:      #222226;
    --border-soft: #1a1a1e;
    --text:        #e8e8ec;
    --text-muted:  #666672;
    --text-dim:    #aaaabc;
    --gold:        #ffd700;
    --silver:      #c0c0c0;
    --bronze:      #cd7f32;
    --success:     #4dff4d;
    --danger:      #ff4d4d;
    --info:        #4d9fff;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { background:#060608; scroll-behavior:smooth; }

body {
    font-family: 'Roboto', sans-serif;
    line-height: 1.6;
    color: var(--text);
    background: var(--bg);
    min-height: 100vh;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:#0a0a0c; }
::-webkit-scrollbar-thumb { background:#2a2a30; border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--orange); }
::selection { background:rgba(255,126,0,0.25); color:#fff; }

/* ── HEADER / NAV ── */
header {
    background: rgba(6,6,8,0.98);
    border-bottom: 1px solid var(--border);
    position: sticky; top:0; z-index:1000;
    backdrop-filter: blur(12px);
}
header::after {
    content:''; display:block; height:2px;
    background: linear-gradient(90deg, var(--orange) 0%, rgba(255,126,0,0.15) 60%, transparent 100%);
}
nav {
    max-width:1280px; margin:0 auto;
    display:flex; justify-content:space-between; align-items:center;
    padding:0 2rem; height:58px;
}
.logo {
    font-family:'Oswald',sans-serif; font-size:1.35rem; font-weight:700;
    text-transform:uppercase; letter-spacing:2px;
    color:#fff; text-decoration:none;
    display:flex; align-items:center; gap:.6rem;
}
.logo img { height:26px; }
.logo span { color:var(--orange); }

.nav-links { display:flex; list-style:none; gap:.1rem; align-items:center; }
.nav-links a {
    color:var(--text-muted); text-decoration:none;
    font-weight:700; text-transform:uppercase;
    font-size:.75rem; letter-spacing:.8px;
    padding:.55rem 1rem;
    transition:color .2s, background .2s;
    position:relative;
}
.nav-links a::after {
    content:''; position:absolute; bottom:0; left:1rem; right:1rem;
    height:2px; background:var(--orange);
    transform:scaleX(0); transition:transform .2s;
}
.nav-links a:hover { color:#fff; }
.nav-links a:hover::after { transform:scaleX(1); }

.nav-links .logout-link {
    color:var(--danger); border:1px solid rgba(255,77,77,0.25);
    padding:.4rem .9rem; margin-left:.5rem;
}
.nav-links .logout-link:hover { background:rgba(255,77,77,0.08); }
.nav-links .logout-link::after { display:none; }

.nav-links .btn-nav-cta {
    background:var(--orange); color:#fff !important;
    padding:.42rem 1.1rem; margin-left:.4rem;
    font-weight:700; letter-spacing:.5px;
}
.nav-links .btn-nav-cta:hover { background:var(--orange-light); }
.nav-links .btn-nav-cta::after { display:none; }

/* ── LAYOUT ── */
.main-container {
    max-width:1280px; margin:2.5rem auto;
    padding:0 2rem;
    min-height:calc(100vh - 220px);
    animation:fadeUp .3s ease;
}
@keyframes fadeUp {
    from { opacity:0; transform:translateY(8px); }
    to   { opacity:1; transform:translateY(0); }
}

/* ── FOOTER ── */
footer {
    background:#000;
    border-top:1px solid var(--border);
    color:var(--text-muted); text-align:center;
    padding:2.5rem 0; margin-top:5rem;
    font-size:.82rem; position:relative;
}
footer::before {
    content:''; position:absolute; top:0; left:0; right:0; height:1px;
    background:linear-gradient(90deg, transparent, var(--orange), transparent);
}
footer a { color:var(--orange); text-decoration:none; }
footer a:hover { text-decoration:underline; }

/* ── BUTTONS ── */
.btn-primary {
    display:inline-flex; align-items:center; gap:.5rem;
    padding:.75rem 2rem;
    background:var(--orange);
    color:#fff; text-decoration:none;
    font-weight:700; text-transform:uppercase;
    font-family:'Oswald',sans-serif; font-size:.9rem; letter-spacing:1px;
    border:none; cursor:pointer;
    transition:background .2s, transform .2s, box-shadow .2s;
    clip-path:polygon(8px 0,100% 0,calc(100% - 8px) 100%,0 100%);
}
.btn-primary:hover {
    background:var(--orange-light);
    transform:translateY(-2px);
    box-shadow:0 6px 24px rgba(255,126,0,.4);
}
.btn-outline {
    display:inline-flex; align-items:center; gap:.5rem;
    padding:.75rem 2rem;
    background:transparent; color:var(--text-dim);
    text-decoration:none; font-weight:700;
    text-transform:uppercase; font-family:'Oswald',sans-serif;
    font-size:.9rem; letter-spacing:1px;
    border:1px solid #333; cursor:pointer;
    transition:border-color .2s, color .2s;
}
.btn-outline:hover { border-color:var(--orange); color:var(--orange); }
.btn-full { width:100%; justify-content:center; clip-path:none; }

/* ── ALERTS ── */
.alert { padding:.85rem 1rem; margin-bottom:1.25rem; font-weight:700; font-size:.78rem; text-transform:uppercase; letter-spacing:.5px; }
.alert-error   { background:rgba(255,77,77,.08);  color:var(--danger);  border:1px solid rgba(255,77,77,.25); border-left:3px solid var(--danger); }
.alert-success { background:rgba(77,255,77,.08);  color:var(--success); border:1px solid rgba(77,255,77,.25); border-left:3px solid var(--success); }
.alert-success a { color:var(--success); font-weight:900; }

/* ── SECTION TITLE ── */
.section-title {
    font-family:'Oswald',sans-serif; font-size:1.4rem;
    color:#fff; text-transform:uppercase; letter-spacing:1px;
    display:flex; align-items:center; gap:.75rem;
    margin-bottom:1.75rem;
}
.section-title::before { content:''; width:3px; height:1.3em; background:var(--orange); flex-shrink:0; }
.section-title::after  { content:''; flex:1; height:1px; background:linear-gradient(90deg,var(--border),transparent); }

/* ── PAGE HEADER ── */
.page-header {
    text-align:center; padding:2.5rem 0 2rem;
    border-bottom:1px solid var(--border); margin-bottom:2.5rem;
}
.page-header h1 { font-family:'Oswald',sans-serif; font-size:2rem; text-transform:uppercase; color:#fff; margin-bottom:.4rem; }
.page-header h1 span { color:var(--orange); }
.page-header p { color:var(--text-muted); font-size:.9rem; }

/* ── NO DATA ── */
.no-data { text-align:center; padding:4rem 2rem; color:var(--text-muted); border:1px dashed var(--border); }

/* ── HERO ── */
.hero {
    position:relative; overflow:hidden;
    min-height:520px; display:flex; align-items:center;
    background:
        linear-gradient(90deg, rgba(6,6,8,.97) 35%, rgba(6,6,8,.65) 65%, rgba(6,6,8,.2) 100%),
        url('img/bg_hero.jpg') center 35% / cover no-repeat;
    border-left:4px solid var(--orange);
    margin-bottom:0;
}
.hero::before {
    content:''; position:absolute; top:0; left:0; right:0; height:2px;
    background:linear-gradient(90deg,var(--orange),transparent);
}
.hero-container { max-width:1280px; width:100%; padding:5rem 2rem; margin:0 auto; }
.hero-eyebrow {
    font-family:'Oswald',sans-serif; font-size:.72rem;
    letter-spacing:4px; color:var(--orange); text-transform:uppercase;
    margin-bottom:1rem; display:flex; align-items:center; gap:.6rem;
}
.hero-eyebrow::before { content:''; width:24px; height:2px; background:var(--orange); }
.hero h1 {
    font-family:'Oswald',sans-serif; font-size:clamp(2.8rem,6vw,5rem);
    color:#fff; text-transform:uppercase; line-height:.95;
    margin-bottom:1.5rem; letter-spacing:-1px;
}
.hero h1 span { color:var(--orange); }
.hero p { font-size:1rem; color:#aaa; max-width:500px; margin-bottom:2.5rem; line-height:1.7; }
.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; align-items:center; }

/* ── STATS BAR ── */
.home-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 2rem 4rem;
}
.stats-bar {
    display:grid; grid-template-columns:repeat(4,1fr);
    background:var(--bg-card); border:1px solid var(--border);
    border-top:none; margin-bottom:4rem;
}
.stats-bar-item {
    padding:1.75rem 1.5rem; text-align:center;
    border-right:1px solid var(--border);
    position:relative;
}
.stats-bar-item:last-child { border-right:none; }
.stats-bar-item::before {
    content:''; position:absolute; top:0; left:0; right:0; height:2px;
    background:var(--orange); opacity:0; transition:opacity .2s;
}
.stats-bar-item:hover::before { opacity:1; }
.stats-bar-item .num {
    font-family:'Oswald',sans-serif; font-size:2.4rem;
    color:var(--orange); display:block; line-height:1;
}
.stats-bar-item .lbl {
    font-size:.7rem; text-transform:uppercase; letter-spacing:2px;
    color:var(--text-muted); margin-top:.4rem; display:block;
}

/* ── INFO SECTION ── */
.info-section { margin-bottom:4rem; }

/* ── CARDS GRID ── */
.info-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1px; background:var(--border); border:1px solid var(--border); }
.info-card {
    background:var(--bg-card); padding:1.75rem;
    transition:background .2s; position:relative; overflow:hidden;
}
.info-card::before {
    content:''; position:absolute; top:0; left:0; width:3px; height:100%;
    background:var(--orange); opacity:0; transition:opacity .2s;
}
.info-card:hover { background:var(--bg3); }
.info-card:hover::before { opacity:1; }
.info-card h3 { color:#fff; font-family:'Oswald',sans-serif; font-size:1rem; text-transform:uppercase; margin-bottom:.5rem; }
.info-card p { color:var(--text-muted); font-size:.85rem; line-height:1.5; }

/* ── GAME MODES ── */
.game-modes-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1px; background:var(--border); border:1px solid var(--border); }
.game-mode-card { background:var(--bg-card); overflow:hidden; transition:background .2s; }
.game-mode-card:hover { background:var(--bg3); }
.game-mode-img { height:180px; background-size:cover; background-position:center; position:relative; }
.game-mode-img::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom,transparent 30%,rgba(6,6,8,.9)); }
.game-mode-img.tdm   { background-image:url('img/bg_codes.jpg'); }
.game-mode-img.snd   { background-image:url('img/bg_items.jpg'); }
.game-mode-img.ghost { background-image:url('img/bg_ranking.jpg'); }
.game-mode-info { padding:1.25rem; border-top:2px solid var(--orange); }
.game-mode-info h3 { font-family:'Oswald',sans-serif; font-size:1rem; color:#fff; text-transform:uppercase; margin-bottom:.35rem; }
.game-mode-info p { color:var(--text-muted); font-size:.83rem; line-height:1.5; }

/* ── NEWS GRID ── */
.news-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1px; background:var(--border); border:1px solid var(--border); }
.news-card { background:var(--bg-card); overflow:hidden; transition:background .2s; display:flex; flex-direction:column; }
.news-card:hover { background:var(--bg3); }
.news-img { height:180px; background-size:cover; background-position:center; position:relative; flex-shrink:0; }
.news-img::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom,transparent 30%,rgba(6,6,8,.85)); }
.news-body { padding:1.25rem; flex:1; display:flex; flex-direction:column; border-top:2px solid var(--border); }
.news-tag {
    display:inline-block; background:rgba(255,126,0,.12); color:var(--orange);
    border:1px solid rgba(255,126,0,.25); padding:2px 8px;
    font-size:.65rem; font-weight:700; text-transform:uppercase; letter-spacing:1px;
    margin-bottom:.6rem; font-family:'Oswald',sans-serif;
}
.news-body h3 { font-family:'Oswald',sans-serif; font-size:.95rem; color:#fff; text-transform:uppercase; margin-bottom:.4rem; line-height:1.3; }
.news-body p { color:var(--text-muted); font-size:.82rem; line-height:1.5; margin-bottom:.75rem; flex:1; }
.news-date { font-size:.72rem; color:#444; font-family:'Oswald',sans-serif; letter-spacing:1px; margin-top:auto; }

/* ── TABLES ── */
.data-table { width:100%; border-collapse:collapse; background:var(--bg-card); border:1px solid var(--border); }
.data-table thead { background:var(--bg3); border-bottom:2px solid var(--orange); }
.data-table th { padding:.85rem 1rem; text-align:left; font-family:'Oswald',sans-serif; font-size:.72rem; font-weight:600; text-transform:uppercase; letter-spacing:2px; color:var(--text-muted); white-space:nowrap; }
.data-table td { padding:.85rem 1rem; font-size:.85rem; border-bottom:1px solid var(--border-soft); }
.data-table tbody tr:hover { background:rgba(255,126,0,.04); }
.data-table tbody tr:last-child td { border-bottom:none; }

.ranking-table .top-1 { background:rgba(255,215,0,.06) !important; border-left:3px solid var(--gold); }
.ranking-table .top-2 { background:rgba(192,192,192,.04) !important; border-left:3px solid var(--silver); }
.ranking-table .top-3 { background:rgba(205,127,50,.04) !important; border-left:3px solid var(--bronze); }
.medal { font-size:1.3rem; }
.rank-badge { background:rgba(255,126,0,.12); color:var(--orange); padding:2px 8px; font-size:.72rem; font-weight:700; text-transform:uppercase; border:1px solid rgba(255,126,0,.25); }

/* ── AUTH ── */
.auth-page { display:flex; justify-content:center; align-items:center; min-height:calc(100vh - 58px); padding:2rem; }
.page-login  .auth-page,
.page-register .auth-page {
    background:linear-gradient(135deg,rgba(6,6,8,.96) 0%,rgba(6,6,8,.8) 100%), url('img/bg_login.jpg') center/cover no-repeat;
    margin:-2.5rem -2rem 0; padding:4rem 2rem;
}
.auth-container { width:100%; max-width:420px; }
.auth-box {
    background:var(--bg-card); padding:2.5rem;
    border:1px solid var(--border); border-top:3px solid var(--orange);
    box-shadow:0 24px 64px rgba(0,0,0,.7);
}
.auth-box h1 { font-family:'Oswald',sans-serif; text-align:center; text-transform:uppercase; color:#fff; margin-bottom:.3rem; font-size:1.7rem; }
.auth-box h1 span { color:var(--orange); }
.auth-subtitle { text-align:center; color:var(--text-muted); text-transform:uppercase; font-size:.7rem; letter-spacing:2px; margin-bottom:2rem; }
.form-group { margin-bottom:1.1rem; }
.form-group label { display:block; font-size:.7rem; text-transform:uppercase; letter-spacing:1px; color:var(--text-muted); margin-bottom:.35rem; font-weight:700; }
.form-group input {
    width:100%; padding:.7rem 1rem; background:#0a0a0c;
    border:1px solid var(--border); color:var(--text);
    font-size:.9rem; font-family:'Roboto',sans-serif;
    transition:border-color .2s; outline:none;
}
.form-group input:focus { border-color:var(--orange); box-shadow:0 0 0 2px rgba(255,126,0,.1); }
.auth-link { text-align:center; margin-top:1.25rem; color:var(--text-muted); font-size:.85rem; }
.auth-link a { color:var(--orange); text-decoration:none; font-weight:700; }
.auth-link a:hover { text-decoration:underline; }

/* ── DOWNLOAD ── */
.download-section { max-width:960px; margin:0 auto; }
.download-hero {
    background:linear-gradient(90deg,rgba(6,6,8,.98) 50%,rgba(6,6,8,.6) 100%), url('img/bg_hero.jpg') center/cover no-repeat;
    border:1px solid var(--border); border-left:4px solid var(--orange);
    padding:3rem; display:flex; justify-content:space-between; align-items:center;
    margin-bottom:3rem; gap:2rem;
}
.download-info h2 { font-family:'Oswald',sans-serif; font-size:2.5rem; text-transform:uppercase; line-height:1; margin-bottom:.5rem; }
.download-info h2 span { color:var(--orange); }
.download-info .version { font-size:.9rem; color:var(--text-dim); margin-bottom:.25rem; }
.download-info .release-date { color:var(--text-muted); margin-bottom:1.5rem; font-size:.85rem; }
.download-buttons { display:flex; gap:1rem; flex-wrap:wrap; }
.btn-download {
    display:inline-flex; align-items:center; gap:.5rem;
    padding:.8rem 1.75rem; background:var(--orange); color:#fff;
    text-decoration:none; font-weight:700; font-family:'Oswald',sans-serif;
    text-transform:uppercase; font-size:.9rem;
    transition:background .2s, transform .2s;
    clip-path:polygon(8px 0,100% 0,calc(100% - 8px) 100%,0 100%);
}
.btn-download:hover { background:var(--orange-light); transform:translateY(-2px); }
.btn-download.btn-secondary { background:var(--bg3); border:1px solid var(--border); color:var(--text-dim); clip-path:none; }
.btn-download.btn-secondary:hover { border-color:var(--orange); color:var(--orange); background:var(--bg-card); transform:none; }
.game-logo { font-size:4.5rem; flex-shrink:0; }
.download-versions h3, .system-requirements h3, .install-guide h3 {
    font-family:'Oswald',sans-serif; text-transform:uppercase;
    border-left:3px solid var(--orange); padding-left:12px;
    margin-bottom:1.25rem; color:#fff; font-size:1.2rem;
}
.download-versions { margin-bottom:3rem; }
.system-requirements { margin-bottom:3rem; }
.requirements-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1px; background:var(--border); border:1px solid var(--border); }
.req-card { background:var(--bg-card); padding:1.5rem; }
.req-card h4 { color:var(--orange); font-family:'Oswald',sans-serif; text-transform:uppercase; margin-bottom:1rem; font-size:.9rem; }
.req-card ul { list-style:none; }
.req-card li { padding:.4rem 0; color:var(--text-muted); font-size:.85rem; border-bottom:1px solid var(--border-soft); }
.req-card li:last-child { border-bottom:none; }
.req-card li strong { color:var(--text-dim); }
.install-guide { margin-bottom:2rem; }
.steps { background:var(--bg-card); padding:1.5rem 2rem; border:1px solid var(--border); list-style:none; counter-reset:steps; }
.steps li { padding:.75rem 0 .75rem 1rem; border-left:2px solid var(--border); margin-left:1rem; color:var(--text-muted); counter-increment:steps; position:relative; font-size:.88rem; }
.steps li::before { content:counter(steps); position:absolute; left:-1.4rem; top:50%; transform:translateY(-50%); background:var(--orange); color:#fff; width:1.3rem; height:1.3rem; display:flex; align-items:center; justify-content:center; font-size:.7rem; font-weight:900; border-radius:50%; }
.steps li + li { margin-top:.4rem; }
.btn-small { display:inline-block; padding:.3rem .8rem; background:var(--orange); color:#fff; text-decoration:none; font-weight:700; text-transform:uppercase; font-size:.72rem; transition:filter .2s; }
.btn-small:hover { filter:brightness(1.15); }

/* ── RANKING ── */
.ranking-page { padding-bottom:3rem; }
.ranking-hero {
    text-align:center; padding:3rem 1rem 2rem; margin-bottom:2.5rem;
    background:linear-gradient(180deg,rgba(6,6,8,.7) 0%,rgba(6,6,8,1) 100%), url('img/bg_ranking.jpg') center/cover no-repeat;
    border-bottom:1px solid var(--border);
}
.ranking-hero .page-eyebrow { font-family:'Oswald',sans-serif; font-size:.7rem; letter-spacing:4px; color:var(--orange); text-transform:uppercase; margin-bottom:.5rem; }
.ranking-hero h1 { font-family:'Oswald',sans-serif; font-size:clamp(1.8rem,4vw,2.6rem); font-weight:700; text-transform:uppercase; color:#fff; }
.ranking-hero .page-sub { font-size:.85rem; color:var(--text-muted); margin-top:.4rem; }

.podium { display:flex; justify-content:center; align-items:flex-end; gap:1px; max-width:820px; margin:0 auto 2.5rem; background:var(--border); border:1px solid var(--border); }
.podium-card { background:var(--bg-card); text-align:center; padding:2rem 1.25rem 1.5rem; flex:1; position:relative; transition:background .2s; }
.podium-card:hover { background:var(--bg3); }
.podium-card.first  { background:linear-gradient(180deg,rgba(255,215,0,.06) 0%,var(--bg-card) 100%); border-top:3px solid var(--gold); order:2; }
.podium-card.second { border-top:3px solid var(--silver); order:1; }
.podium-card.third  { border-top:3px solid var(--bronze); order:3; }
.podium-pos { position:absolute; top:-1px; left:50%; transform:translateX(-50%); background:var(--bg-card); border:1px solid var(--border); border-radius:50%; width:26px; height:26px; display:flex; align-items:center; justify-content:center; font-family:'Oswald',sans-serif; font-weight:700; font-size:.75rem; }
.podium-card.first  .podium-pos { color:var(--gold); }
.podium-card.second .podium-pos { color:var(--silver); }
.podium-card.third  .podium-pos { color:var(--bronze); }
.podium-medal { font-size:2rem; display:block; margin-bottom:6px; }
.podium-card.first .podium-medal { font-size:2.5rem; }
.podium-rank-img { width:48px; height:48px; object-fit:contain; margin:4px auto 8px; display:block; }
.podium-nick { font-family:'Oswald',sans-serif; font-size:1rem; font-weight:700; color:#fff; margin-bottom:4px; word-break:break-all; }
.podium-card.first .podium-nick { font-size:1.15rem; }
.podium-rank-name { font-size:.72rem; margin-bottom:8px; }
.podium-exp-label { font-size:.62rem; color:#444; text-transform:uppercase; letter-spacing:1px; }
.podium-exp { font-family:'Oswald',sans-serif; font-size:1rem; font-weight:700; color:#fff; }
.podium-card.first .podium-exp { color:var(--gold); font-size:1.15rem; }
.podium-stats { display:flex; justify-content:center; gap:10px; margin-top:10px; font-size:.72rem; color:var(--text-muted); }
.podium-stats span { display:flex; flex-direction:column; align-items:center; gap:2px; }
.podium-stats b { color:var(--text-dim); font-size:.8rem; }

.ranking-table-wrap { overflow-x:auto; }
.ranking-table-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:1rem; }
.ranking-table-header h2 { font-family:'Oswald',sans-serif; font-size:.9rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:#fff; border-left:3px solid var(--orange); padding-left:10px; }
.ranking-table-header span { font-size:.78rem; color:var(--text-muted); }
.ranking-tbl { width:100%; border-collapse:collapse; background:var(--bg-card); border:1px solid var(--border); }
.ranking-tbl thead th { background:var(--bg3); color:var(--text-muted); padding:10px 14px; text-align:left; font-size:.68rem; font-family:'Oswald',sans-serif; font-weight:600; text-transform:uppercase; letter-spacing:2px; border-bottom:2px solid var(--orange); white-space:nowrap; }
.ranking-tbl tbody tr { border-bottom:1px solid var(--border-soft); transition:background .15s; }
.ranking-tbl tbody tr:hover { background:rgba(255,126,0,.04); }
.ranking-tbl tbody td { padding:10px 14px; font-size:.85rem; white-space:nowrap; }
.ranking-tbl tbody tr:nth-child(1) { background:rgba(255,215,0,.04); }
.ranking-tbl tbody tr:nth-child(2) { background:rgba(192,192,192,.02); }
.ranking-tbl tbody tr:nth-child(3) { background:rgba(205,127,50,.02); }
.pos-cell { font-family:'Oswald',sans-serif; font-weight:700; font-size:.82rem; color:var(--text-muted); width:48px; }
.pos-cell.gold   { color:var(--gold); }
.pos-cell.silver { color:var(--silver); }
.pos-cell.bronze { color:var(--bronze); }
.nick-cell { font-family:'Oswald',sans-serif; font-weight:700; font-size:.92rem; color:#fff; }
.rank-pill { display:inline-block; border:1px solid; padding:2px 7px; font-size:.68rem; font-weight:600; font-family:'Oswald',sans-serif; letter-spacing:1px; white-space:nowrap; }
.exp-cell { font-family:'Oswald',sans-serif; font-weight:600; color:var(--text); }
.lev-cell { font-family:'Oswald',sans-serif; font-weight:700; color:var(--orange); }
.kd-pos { color:#4caf50; } .kd-neg { color:#f44336; } .kd-neu { color:var(--text-muted); }
.ranking-pagination { display:flex; justify-content:center; flex-wrap:wrap; gap:4px; padding:1.5rem 0 0; }
.ranking-pagination a { font-family:'Oswald',sans-serif; font-weight:600; font-size:.75rem; letter-spacing:1px; text-transform:uppercase; color:var(--text-muted); padding:6px 12px; text-decoration:none; background:var(--bg-card); border:1px solid var(--border); transition:all .2s; }
.ranking-pagination a:hover, .ranking-pagination a.active { background:var(--orange); color:#fff; border-color:var(--orange); }
.ranking-error { background:rgba(255,77,77,.06); border-left:3px solid var(--danger); color:#ff6b6b; padding:1.25rem 1.5rem; max-width:600px; margin:2rem auto; font-size:.88rem; }

/* ── PROFILE / PANEL ── */
.page-profile-wrapper { width:100%; margin:0; padding:0; animation:fadeUp .3s ease; }
.panel-wrapper {
    display:flex; width:100%; min-height:calc(100vh - 58px);
    background:linear-gradient(180deg,rgba(6,6,8,.98) 0%,rgba(6,6,8,1) 100%), url('img/bg_panel.jpg') center/cover fixed;
    border-top:2px solid var(--orange);
}
.sidebar-panel {
    width:220px; min-width:220px; min-height:calc(100vh - 58px);
    background:#0a0a0c; padding:2rem 0;
    border-right:1px solid var(--border);
    display:flex; flex-direction:column; align-items:stretch; flex-shrink:0;
}
.user-info-side { text-align:center; margin-bottom:1.5rem; padding:0 1rem; }
.avatar-circle { width:72px; height:72px; background:var(--orange); border-radius:50%; display:flex; justify-content:center; align-items:center; margin:0 auto .75rem; overflow:hidden; border:2px solid rgba(255,126,0,.3); box-shadow:0 0 20px rgba(255,126,0,.2); }
.avatar-circle img { width:100%; height:100%; object-fit:cover; }
.user-info-side h3 { color:#fff; font-family:'Oswald',sans-serif; font-size:1rem; margin-bottom:.2rem; text-transform:uppercase; word-break:break-all; }
.rank-title { color:var(--orange); font-size:.7rem; text-transform:uppercase; letter-spacing:1px; font-weight:700; }
.side-nav { width:100%; display:flex; flex-direction:column; flex:1; }
.side-nav a { display:flex; align-items:center; gap:.6rem; padding:.75rem 1.25rem; color:var(--text-muted); text-decoration:none; font-weight:700; font-size:.72rem; text-transform:uppercase; letter-spacing:.3px; transition:background .15s, color .15s; border-left:2px solid transparent; }
.side-nav a span { font-size:.9rem; flex-shrink:0; }
.side-nav a:hover, .side-nav a.active { background:rgba(255,126,0,.06); color:var(--orange); border-left-color:var(--orange); }
.side-nav .logout-item { border-top:1px solid var(--border); color:var(--danger); margin-top:auto; }
.side-nav .logout-item:hover { background:rgba(255,77,77,.06); color:var(--danger); border-left-color:var(--danger); }
.panel-content { flex:1; min-width:0; padding:2.5rem 3rem; }
.panel-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:2.5rem; border-bottom:1px solid var(--border); padding-bottom:1.25rem; flex-wrap:wrap; gap:1rem; }
.panel-header h2 { font-family:'Oswald',sans-serif; font-size:1.6rem; color:#fff; text-transform:uppercase; }
.panel-header h2 span { color:var(--orange); }
.currency-bar { display:flex; gap:.75rem; }
.currency-item { background:var(--bg3); padding:.55rem 1rem; font-family:'Oswald',sans-serif; font-size:.95rem; color:#fff; border:1px solid var(--border); }
.currency-item strong { color:var(--orange); margin-right:4px; }
.currency-ec { border-color:rgba(77,159,255,.2); }
.currency-ec strong { color:var(--info); }
.ec-value { color:var(--info); }
.stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(130px,1fr)); gap:1px; background:var(--border); border:1px solid var(--border); margin-bottom:2rem; }
.stat-card { background:var(--bg-card); padding:1.25rem; text-align:center; transition:background .2s; position:relative; }
.stat-card::before { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:var(--orange); opacity:0; transition:opacity .2s; }
.stat-card:hover { background:var(--bg3); }
.stat-card:hover::before { opacity:1; }
.stat-label { display:block; color:var(--text-muted); font-size:.65rem; text-transform:uppercase; letter-spacing:1px; margin-bottom:.4rem; font-weight:700; }
.stat-value { font-family:'Oswald',sans-serif; font-size:1.8rem; color:#fff; line-height:1; }
.stat-value.orange { color:var(--orange); }
.account-details-card { background:var(--bg-card); padding:2rem; border:1px solid var(--border); border-left:3px solid var(--orange); }
.account-details-card h3 { font-family:'Oswald',sans-serif; font-size:1.1rem; color:#fff; text-transform:uppercase; margin-bottom:1.5rem; padding-bottom:.75rem; border-bottom:1px solid var(--border); }
.account-details-card h3 span { color:var(--orange); }
.info-row { display:flex; justify-content:space-between; padding:.7rem 0; border-bottom:1px solid var(--border-soft); align-items:center; gap:1rem; }
.info-row:last-child { border-bottom:none; }
.info-row span { color:var(--text-muted); font-size:.78rem; text-transform:uppercase; letter-spacing:.5px; flex-shrink:0; }
.info-row strong { color:var(--text-dim); font-weight:400; text-align:right; }
.info-row strong.text-success { color:var(--success); font-weight:700; }

/* ── SETTINGS ── */
.settings-card { background:var(--bg-card); border:1px solid var(--border); border-left:3px solid var(--orange); padding:2rem; }
.settings-card-header { display:flex; align-items:flex-start; gap:1rem; margin-bottom:1.75rem; padding-bottom:1.25rem; border-bottom:1px solid var(--border); }
.settings-icon { font-size:1.5rem; flex-shrink:0; margin-top:2px; }
.settings-card-header h3 { font-family:'Oswald',sans-serif; font-size:1.1rem; color:#fff; text-transform:uppercase; margin-bottom:.2rem; }
.settings-card-header p { color:var(--text-muted); font-size:.83rem; }
.input-password-wrap { position:relative; display:flex; }
.input-password-wrap input { flex:1; padding-right:2.8rem; }
.toggle-pw { position:absolute; right:0; top:0; bottom:0; width:2.8rem; background:none; border:none; color:var(--text-muted); cursor:pointer; font-size:1rem; transition:color .2s; display:flex; align-items:center; justify-content:center; }
.toggle-pw:hover { color:var(--orange); }
.pw-strength-bar { height:3px; background:#1a1a1e; margin-top:5px; overflow:hidden; }
.pw-strength-fill { height:100%; width:0%; transition:width .3s, background .3s; }
.pw-strength-label { font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; margin-top:3px; display:block; }
.pw-match-label { font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; margin-top:4px; display:block; }

/* ── AVATAR MODAL ── */
.avatar-clickable { cursor:pointer; position:relative; }
.avatar-overlay { position:absolute; inset:0; background:rgba(0,0,0,.55); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.2rem; opacity:0; transition:opacity .2s; }
.avatar-clickable:hover .avatar-overlay { opacity:1; }
.avatar-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.8); z-index:9999; display:flex; align-items:center; justify-content:center; padding:1rem; }
.avatar-modal-box { background:var(--bg-card); border:1px solid var(--border); border-top:3px solid var(--orange); padding:2rem; width:100%; max-width:400px; position:relative; box-shadow:0 24px 64px rgba(0,0,0,.8); }
.avatar-modal-close { position:absolute; top:.75rem; right:1rem; background:none; border:none; color:#555; font-size:1.5rem; cursor:pointer; line-height:1; transition:color .2s; }
.avatar-modal-close:hover { color:#fff; }
.avatar-modal-box h3 { font-family:'Oswald',sans-serif; font-size:1.3rem; text-transform:uppercase; color:#fff; margin-bottom:.2rem; }
.avatar-modal-sub { font-size:.72rem; color:#444; text-transform:uppercase; letter-spacing:1px; margin-bottom:1.5rem; }
.avatar-preview-wrap { width:100px; height:100px; border-radius:50%; overflow:hidden; margin:0 auto 1.5rem; border:2px solid rgba(255,126,0,.3); background:var(--bg3); }
.avatar-preview-wrap img { width:100%; height:100%; object-fit:cover; }
.avatar-file-label { display:flex; align-items:center; justify-content:center; gap:.5rem; width:100%; padding:.7rem; background:var(--bg3); border:1px dashed #333; color:#888; font-size:.82rem; font-weight:700; text-transform:uppercase; cursor:pointer; transition:border-color .2s, color .2s; margin-bottom:.5rem; }
.avatar-file-label:hover { border-color:var(--orange); color:var(--orange); }
.avatar-file-name { font-size:.72rem; color:#444; text-align:center; margin-bottom:1rem; word-break:break-all; }
.avatar-msg { font-size:.75rem; font-weight:700; text-transform:uppercase; text-align:center; padding:.55rem; margin-bottom:1rem; }
.avatar-msg.error   { background:rgba(255,77,77,.08);  color:var(--danger);  border:1px solid rgba(255,77,77,.2); }
.avatar-msg.success { background:rgba(77,255,77,.08);  color:var(--success); border:1px solid rgba(77,255,77,.2); }
#avatar-save-btn:disabled { opacity:.35; cursor:not-allowed; pointer-events:none; }

/* ── SHOP ── */
.shop-hero { display:flex; justify-content:space-between; align-items:center; background:linear-gradient(90deg,rgba(6,6,8,.98) 50%,rgba(6,6,8,.7) 100%), url('img/bg_items.jpg') center/cover no-repeat; border-left:4px solid var(--orange); padding:2.5rem; margin-bottom:2rem; gap:2rem; flex-wrap:wrap; }
.shop-hero-text .hero-eyebrow { font-family:'Oswald',sans-serif; font-size:.7rem; letter-spacing:4px; color:var(--orange); text-transform:uppercase; margin-bottom:.5rem; }
.shop-hero-text h1 { font-family:'Oswald',sans-serif; font-size:2.5rem; color:#fff; text-transform:uppercase; line-height:1; margin-bottom:.6rem; }
.shop-hero-text h1 span { color:var(--orange); }
.shop-hero-text p { color:#888; font-size:.88rem; max-width:440px; }
.shop-ec-badge { background:rgba(77,159,255,.06); border:1px solid rgba(77,159,255,.2); border-top:3px solid var(--info); padding:1.25rem 2rem; text-align:center; min-width:150px; }
.shop-ec-label { font-size:.62rem; text-transform:uppercase; letter-spacing:2px; color:var(--info); margin-bottom:.2rem; }
.shop-ec-value { font-family:'Oswald',sans-serif; font-size:2.2rem; color:var(--info); line-height:1; }
.shop-ec-unit  { font-size:.65rem; color:#444; text-transform:uppercase; letter-spacing:1px; margin-top:.2rem; }
.shop-filters { margin-bottom:2rem; display:flex; flex-direction:column; gap:.75rem; }
.shop-search-form { display:flex; gap:.5rem; align-items:center; flex-wrap:wrap; }
.shop-search-input { flex:1; min-width:200px; padding:.6rem 1rem; background:var(--bg3); border:1px solid var(--border); color:var(--text); font-size:.85rem; outline:none; transition:border-color .2s; }
.shop-search-input:focus { border-color:var(--orange); }
.shop-cats { display:flex; gap:.35rem; flex-wrap:wrap; }
.shop-cat-btn { padding:.3rem .85rem; background:var(--bg3); border:1px solid var(--border); color:var(--text-muted); font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.5px; text-decoration:none; transition:all .2s; cursor:pointer; }
.shop-cat-btn:hover, .shop-cat-btn.active { background:rgba(255,126,0,.1); border-color:var(--orange); color:var(--orange); }
.shop-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(210px,1fr)); gap:1px; background:var(--border); border:1px solid var(--border); }
.shop-card { background:var(--bg-card); display:flex; flex-direction:column; transition:background .2s; position:relative; overflow:hidden; }
.shop-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--orange); opacity:0; transition:opacity .2s; }
.shop-card:hover { background:var(--bg3); }
.shop-card:hover::before { opacity:1; }
.shop-card-img { height:150px; background:var(--bg3); display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; border-bottom:1px solid var(--border-soft); }
.shop-card-img img { width:100%; height:100%; object-fit:cover; }
.shop-card-img-fallback { font-size:3rem; opacity:.2; display:flex; align-items:center; justify-content:center; width:100%; height:100%; }
.shop-card-cat { position:absolute; top:.5rem; left:.5rem; background:rgba(255,126,0,.85); color:#fff; font-size:.62rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; padding:2px 6px; }
.shop-card-body { padding:1rem; flex:1; }
.shop-card-name { font-family:'Oswald',sans-serif; font-size:.95rem; color:#fff; text-transform:uppercase; margin-bottom:.35rem; line-height:1.2; }
.shop-card-desc { font-size:.75rem; color:#555; line-height:1.4; margin-bottom:.4rem; }
.shop-card-qty  { font-size:.72rem; color:#444; }
.shop-card-qty strong { color:var(--orange); }
.shop-card-footer { padding:.7rem 1rem; border-top:1px solid var(--border-soft); display:flex; align-items:center; justify-content:space-between; gap:.5rem; background:rgba(0,0,0,.2); }
.shop-card-price { display:flex; align-items:baseline; gap:.25rem; }
.shop-price-num { font-family:'Oswald',sans-serif; font-size:1.2rem; color:var(--info); }
.shop-price-unit { font-size:.65rem; color:var(--info); opacity:.7; text-transform:uppercase; }
.btn-buy { padding:.4rem .9rem; background:var(--orange); color:#fff; border:none; font-family:'Oswald',sans-serif; font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.5px; cursor:pointer; transition:background .2s; white-space:nowrap; }
.btn-buy:hover:not(:disabled) { background:var(--orange-light); }
.btn-buy:disabled { background:var(--bg3); color:#333; cursor:not-allowed; border:1px solid var(--border); }
.shop-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.85); z-index:9999; display:flex; align-items:center; justify-content:center; padding:1rem; }
.shop-modal-box { background:var(--bg-card); border:1px solid var(--border); border-top:3px solid var(--orange); padding:2.5rem 2rem; width:100%; max-width:380px; position:relative; text-align:center; box-shadow:0 24px 64px rgba(0,0,0,.9); }
.shop-modal-close { position:absolute; top:.75rem; right:1rem; background:none; border:none; color:#555; font-size:1.5rem; cursor:pointer; line-height:1; transition:color .2s; }
.shop-modal-close:hover { color:#fff; }
.shop-modal-icon { font-size:2.2rem; margin-bottom:.75rem; }
.shop-modal-title { font-family:'Oswald',sans-serif; font-size:1.3rem; text-transform:uppercase; color:#fff; margin-bottom:.5rem; }
.shop-modal-item { color:var(--orange); font-weight:700; font-size:.95rem; margin-bottom:1.5rem; }
.shop-modal-price-row { display:flex; justify-content:space-between; padding:.45rem 0; border-bottom:1px solid var(--border-soft); font-size:.85rem; color:var(--text-muted); }
.shop-modal-price-row:last-of-type { border-bottom:none; margin-bottom:1.5rem; }
.shop-modal-price-val { color:var(--info); font-family:'Oswald',sans-serif; font-size:1rem; }
.shop-modal-actions { display:flex; gap:.75rem; justify-content:center; flex-wrap:wrap; }
.shop-modal-actions .btn-primary { clip-path:none; padding:.65rem 1.75rem; }
.shop-modal-actions .btn-outline  { padding:.65rem 1.75rem; }

/* ── RESPONSIVE PANEL ── */
@media (max-width:992px) {
    .panel-wrapper { flex-direction:column; }
    .sidebar-panel { width:100%; min-width:unset; flex-direction:row; align-items:center; justify-content:space-between; padding:.75rem 1.5rem; border-right:none; border-bottom:1px solid var(--border); gap:1rem; flex-wrap:wrap; min-height:unset; }
    .user-info-side { display:flex; align-items:center; gap:.75rem; margin-bottom:0; padding:0; text-align:left; }
    .avatar-circle { width:40px; height:40px; margin:0; flex-shrink:0; }
    .user-info-side h3 { font-size:.9rem; margin-bottom:0; }
    .rank-title { font-size:.65rem; }
    .side-nav { flex-direction:row; flex-wrap:wrap; gap:.1rem; width:auto; flex:1; justify-content:flex-end; align-items:center; }
    .side-nav a { padding:.4rem .75rem; border-left:none; border-bottom:2px solid transparent; font-size:.68rem; white-space:nowrap; }
    .side-nav a:hover, .side-nav a.active { border-left-color:transparent; border-bottom-color:var(--orange); background:rgba(255,126,0,.06); }
    .side-nav .logout-item { border-top:none; border-left:1px solid var(--border); margin-top:0; margin-left:.25rem; padding-left:.75rem; }
    .side-nav .logout-item:hover { border-left-color:var(--danger); border-bottom-color:transparent; }
    .panel-content { padding:1.5rem; }
    .panel-header { flex-direction:column; align-items:flex-start; }
    .currency-bar { width:100%; }
}
@media (max-width:600px) {
    .sidebar-panel { flex-direction:column; align-items:flex-start; padding:1rem; }
    .user-info-side { width:100%; }
    .side-nav { width:100%; justify-content:flex-start; }
    .side-nav .logout-item { border-left:none; border-top:1px solid var(--border); margin-left:0; padding-left:.75rem; width:100%; }
}

/* ── RESPONSIVE GERAL ── */
@media (max-width:768px) {
    nav { flex-direction:column; height:auto; padding:1rem 1.5rem; gap:.6rem; }
    .nav-links { gap:.1rem; flex-wrap:wrap; justify-content:center; }
    .hero h1 { font-size:2.2rem; }
    .hero { min-height:380px; }
    .hero-container { padding:3.5rem 1.5rem; }
    .home-inner { padding:0 1rem 3rem; }
    .stats-bar { grid-template-columns:repeat(2,1fr); }
    .stats-bar-item:nth-child(2) { border-right:none; }
    .main-container { padding:0 1rem; margin:1.5rem auto; }
    .podium { flex-direction:column; align-items:stretch; }
    .podium-card { max-width:100%; order:unset !important; }
    .download-hero { flex-direction:column; text-align:center; }
    .download-buttons { justify-content:center; }
    .shop-hero { flex-direction:column; }
}
@media (max-width:480px) {
    .auth-box { padding:2rem 1.25rem; }
    .hero h1 { font-size:1.8rem; }
    .stats-bar { grid-template-columns:repeat(2,1fr); }
    .panel-content { padding:1rem; }
}
