/* ============================================================
   MoonServ — Premium Dark Theme v3
   Nunito + JetBrains Mono • Gradient BG • SVG Icons • No Emoji
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root {
  --bg:#0b1120; --bg2:#0e1528; --card:#111827; --card2:#1a2235;
  --glass:rgba(17,24,39,.72); --glass2:rgba(11,17,32,.92);
  --bdr:rgba(99,128,255,.08); --bdr2:rgba(99,128,255,.15); --bdrg:rgba(99,128,255,.25);
  --tx:#e8ecf4; --tx2:#7a8599; --tx3:#4a556b;
  --ac:#6366f1; --ac2:#818cf8; --ac3:#a5b4fc;
  --acbg:rgba(99,102,241,.08); --acg:rgba(99,102,241,.35);
  --gr:#10b981; --grbg:rgba(16,185,129,.1); --grg:rgba(16,185,129,.4);
  --rd:#ef4444; --rdbg:rgba(239,68,68,.1);
  --or:#f59e0b; --orbg:rgba(245,158,11,.1);
  --cy:#06b6d4; --cybg:rgba(6,182,212,.1);
  --pu:#a855f7;
  --font:'Nunito',sans-serif; --mono:'JetBrains Mono',monospace;
  --r:12px; --rl:16px; --rx:24px;
  --shadow:0 4px 24px rgba(0,0,0,.4),0 0 0 1px var(--bdr);
  --shadow-glow:0 0 40px var(--acg),0 4px 24px rgba(0,0,0,.4);
}

[data-theme="light"] {
  --bg:#f0f2f5; --bg2:#e8ecf0; --card:#ffffff; --card2:#f6f8fa;
  --glass:rgba(255,255,255,.82); --glass2:rgba(255,255,255,.92);
  --bdr:rgba(0,0,0,.06); --bdr2:rgba(0,0,0,.1); --bdrg:rgba(99,102,241,.2);
  --tx:#1f2328; --tx2:#656d76; --tx3:#8b949e;
  --ac:#4f46e5; --ac2:#6366f1; --ac3:#818cf8;
  --acbg:rgba(79,70,229,.06); --acg:rgba(79,70,229,.2);
}

/* Variable aliases for compatibility */
:root {
  --bg-body:var(--bg); --bg-card:var(--card); --bg-card-2:var(--card2);
  --bg-nav:var(--glass2); --bg-input:var(--bg2);
  --border:var(--bdr); --border-hover:var(--bdr2);
  --text:var(--tx); --text-2:var(--tx2); --text-3:var(--tx3);
  --accent:var(--ac); --accent-2:var(--ac2); --accent-bg:var(--acbg);
  --green:var(--gr); --green-bg:var(--grbg);
  --red:var(--rd); --red-bg:var(--rdbg);
  --orange:var(--or); --orange-bg:var(--orbg);
  --purple:var(--pu);
  --radius:var(--r); --radius-lg:var(--rl);
}

* { margin:0; padding:0; box-sizing:border-box; }

/* ═══ GRADIENT BACKGROUND ═══ */
body {
  color:var(--tx); font-family:var(--font); -webkit-font-smoothing:antialiased; line-height:1.6;
  background:
    radial-gradient(ellipse at 15% 10%, rgba(99,102,241,.07), transparent 50%),
    radial-gradient(ellipse at 85% 90%, rgba(6,182,212,.05), transparent 50%),
    radial-gradient(ellipse at 50% 50%, rgba(16,185,129,.03), transparent 60%),
    linear-gradient(165deg, #080d1a 0%, #0b1120 25%, #0e1528 50%, #0d1329 75%, #0a0f1e 100%);
  background-attachment:fixed;
  min-height:100vh;
}

a { color:var(--ac2); text-decoration:none; transition:color .2s; }
a:hover { color:var(--ac3); }
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--tx3); border-radius:3px; }

/* ═══ SVG ICON BASE ═══ */
.ico { display:inline-block; vertical-align:middle; flex-shrink:0; }
.feature-icon .ico { color:var(--ac2); }

/* ═══ ANIMATIONS ═══ */
@keyframes fadeUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes scaleIn { from{opacity:0;transform:scale(.94)} to{opacity:1;transform:scale(1)} }
@keyframes slideDown { from{opacity:0;transform:translateY(-12px)} to{opacity:1;transform:translateY(0)} }
@keyframes pulseGlow { 0%,100%{box-shadow:0 0 6px var(--grg)} 50%{box-shadow:0 0 18px var(--grg)} }
@keyframes gradShift { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }
@keyframes spin { to{transform:rotate(360deg)} }
@keyframes toastIn { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes orbFloat1 { 0%{transform:translate(0,0) scale(1)} 33%{transform:translate(30px,-40px) scale(1.1)} 66%{transform:translate(-20px,20px) scale(.9)} 100%{transform:translate(0,0) scale(1)} }
@keyframes orbFloat2 { 0%{transform:translate(0,0)} 33%{transform:translate(-40px,20px)} 66%{transform:translate(20px,-30px)} 100%{transform:translate(0,0)} }

.anim-up { animation:fadeUp .5s ease both; }
.anim-up.d1{animation-delay:.06s} .anim-up.d2{animation-delay:.12s}
.anim-up.d3{animation-delay:.18s} .anim-up.d4{animation-delay:.24s}

/* ═══ BUTTONS ═══ */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 24px; border-radius:var(--r);
  font-family:var(--font); font-size:14px; font-weight:700;
  cursor:pointer; border:none; transition:all .25s;
  text-decoration:none; white-space:nowrap;
  position:relative; overflow:hidden;
}
.btn::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,.12),transparent); opacity:0; transition:.25s; }
.btn:hover::before { opacity:1; }
.btn-primary { background:linear-gradient(135deg,var(--ac),#4f46e5); color:#fff; box-shadow:0 4px 20px var(--acg); border-radius:var(--r); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 30px var(--acg); }
.btn-outline { background:transparent; color:var(--tx); border:1px solid var(--bdr2); border-radius:var(--r); }
.btn-outline:hover { border-color:var(--ac); color:var(--ac2); background:var(--acbg); }
.btn-ghost { background:rgba(255,255,255,.04); color:var(--tx2); border:1px solid var(--bdr); }
.btn-ghost:hover { background:rgba(255,255,255,.08); color:var(--tx); }
.btn-danger { background:var(--rd); color:#fff; }
.btn-success { background:var(--gr); color:#fff; }
.btn-sm { padding:7px 16px; font-size:12px; border-radius:8px; }
.btn-lg { padding:14px 32px; font-size:16px; border-radius:var(--rl); }
.btn-block { width:100%; justify-content:center; }
.btn:disabled { opacity:.5; cursor:not-allowed; }

/* ═══ INPUTS ═══ */
.input, select.input, textarea.input {
  width:100%; padding:12px 16px; border-radius:var(--r);
  border:1px solid var(--bdr); background:rgba(10,15,30,.6);
  color:var(--tx); font-family:var(--font); font-size:14px;
  outline:none; transition:all .25s;
}
.input:focus { border-color:var(--ac); box-shadow:0 0 0 3px var(--acbg); }
.input::placeholder { color:var(--tx3); }
textarea.input { resize:vertical; min-height:80px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group label { font-size:12px; font-weight:600; color:var(--tx2); text-transform:uppercase; letter-spacing:.5px; }

/* ═══ ALERTS ═══ */
.alert { padding:12px 16px; border-radius:var(--r); font-size:14px; margin-bottom:16px; animation:slideDown .3s ease; }
.alert-error { background:var(--rdbg); color:var(--rd); border:1px solid rgba(239,68,68,.15); }
.alert-success { background:var(--grbg); color:var(--gr); border:1px solid rgba(16,185,129,.15); }

/* ═══ CARDS ═══ */
.card {
  background:linear-gradient(145deg, #111827, #151d2e);
  border:1px solid var(--bdr); border-radius:var(--rl); overflow:hidden;
  transition:border-color .3s;
}
.card:hover { border-color:var(--bdr2); }
.card-header {
  padding:18px 22px; border-bottom:1px solid var(--bdr);
  font-weight:700; font-size:15px;
  display:flex; align-items:center; justify-content:space-between; gap:8px;
}
.card-body { padding:22px; }

/* ═══ BADGES ═══ */
.badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:5px 12px; border-radius:20px;
  font-size:11px; font-weight:700; letter-spacing:.3px;
}
.badge-online { background:var(--grbg); color:var(--gr); }
.badge-online::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--gr); animation:pulseGlow 2s ease infinite; }
.badge-stopped { background:var(--rdbg); color:var(--rd); }
.badge-stopped::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--rd); }
.badge-installing { background:var(--orbg); color:var(--or); }
.badge-expired { background:rgba(255,255,255,.04); color:var(--tx3); }
.badge-open { background:var(--orbg); color:var(--or); }
.badge-answered { background:var(--grbg); color:var(--gr); }
.badge-waiting { background:var(--orbg); color:var(--or); }
.badge-closed { background:rgba(255,255,255,.04); color:var(--tx3); }
.badge-admin { background:var(--acbg); color:var(--ac2); }
.badge-moderator { background:rgba(168,85,247,.1); color:var(--pu); }
.badge-user { background:rgba(255,255,255,.04); color:var(--tx2); }

/* ═══ LANDING NAV ═══ */
.landing-nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:var(--glass2); backdrop-filter:blur(24px) saturate(1.4);
  border-bottom:1px solid var(--bdr); height:60px;
}
.nav-inner {
  max-width:1200px; margin:0 auto; padding:0 20px;
  display:flex; align-items:center; height:100%;
}
.nav-brand {
  display:flex; align-items:center; gap:10px;
  text-decoration:none; color:var(--tx); font-weight:800; font-size:18px;
}
.nav-logo {
  width:36px; height:36px; border-radius:11px;
  background:linear-gradient(135deg,var(--ac),#4338ca);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 24px var(--acg); color:#fff;
}
.nav-title { letter-spacing:-.5px; }
.nav-links { margin-left:auto; display:flex; align-items:center; gap:20px; }
.nav-links a { color:var(--tx2); font-size:14px; font-weight:600; transition:.2s; }
.nav-links a:hover { color:var(--tx); }
.mobile-menu-btn { display:none; background:none; border:none; color:var(--tx); cursor:pointer; margin-left:auto; line-height:0; }
@media(max-width:768px) {
  .mobile-menu-btn { display:block; }
  .nav-links { display:none; flex-direction:column; position:absolute; top:60px; left:0; right:0; background:var(--card); border-bottom:1px solid var(--bdr); padding:16px; gap:12px; }
  .nav-links.open { display:flex; }
}

/* ═══ HERO ═══ */
.hero {
  position:relative; min-height:600px; display:flex; align-items:center; justify-content:center;
  padding:120px 20px 80px; text-align:center; overflow:hidden;
}
.hero-bg { position:absolute; inset:0; overflow:hidden; }
.hero::before {
  content:''; position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse at 20% 40%, rgba(99,102,241,.15), transparent 60%),
    radial-gradient(ellipse at 80% 30%, rgba(6,182,212,.1), transparent 50%),
    radial-gradient(ellipse at 50% 90%, rgba(16,185,129,.06), transparent 50%);
}
.hero-content { position:relative; max-width:700px; z-index:1; }
.hero-title {
  font-size:clamp(34px,6vw,56px); font-weight:900;
  line-height:1.08; letter-spacing:-1.5px; margin-bottom:20px;
}
.hero-title .accent {
  background:linear-gradient(135deg,var(--ac2),var(--cy));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-size:200% 200%; animation:gradShift 4s ease infinite;
}
.hero-sub { font-size:clamp(14px,2vw,18px); color:var(--tx2); margin-bottom:36px; max-width:540px; margin-left:auto; margin-right:auto; line-height:1.7; }
.hero-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-bottom:56px; }
.hero-stats { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.hero-stat {
  text-align:center; padding:16px 24px;
  background:var(--glass); backdrop-filter:blur(12px);
  border:1px solid var(--bdr); border-radius:var(--rl);
  min-width:110px; transition:.3s;
}
.hero-stat:hover { border-color:var(--bdr2); transform:translateY(-4px); }
.hero-stat-num { display:block; font-size:26px; font-weight:900; font-family:var(--mono); color:var(--ac2); letter-spacing:-1px; }
.hero-stat-label { font-size:12px; color:var(--tx3); margin-top:2px; }
@media(max-width:600px) { .hero-title { font-size:32px; } .hero-sub { font-size:14px; } .hero { padding:100px 16px 60px; min-height:auto; } }

/* ═══ SECTIONS ═══ */
.section { padding:80px 20px; }
.section-alt { background:rgba(17,24,39,.5); }
.container { max-width:1200px; margin:0 auto; }
.section-title { font-size:clamp(26px,4vw,36px); font-weight:900; text-align:center; margin-bottom:12px; letter-spacing:-.5px; }
.section-sub { text-align:center; color:var(--tx2); font-size:16px; margin-bottom:48px; }

/* Games showcase */
.games-showcase { display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:12px; }
@media(max-width:480px) { .games-showcase { grid-template-columns:repeat(3,1fr); } }
.game-showcase-card {
  background:linear-gradient(145deg, #141c30, #1a2440);
  border:1px solid rgba(99,128,255,.1); border-radius:var(--rl);
  padding:20px 12px; text-align:center; cursor:pointer; transition:all .35s;
  position:relative; overflow:hidden;
}
.game-showcase-card::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(99,102,241,.06),transparent); opacity:0; transition:.35s; }
.game-showcase-card:hover { border-color:rgba(99,102,241,.3); transform:translateY(-5px); box-shadow:0 12px 40px rgba(0,0,0,.3); }
.game-showcase-card:hover::after { opacity:1; }
.game-showcase-icon { font-size:40px; margin-bottom:10px; display:block; transition:.3s; }
.game-showcase-card:hover .game-showcase-icon { transform:scale(1.15); }
.game-showcase-name { font-size:12px; font-weight:700; }
.game-showcase-price { font-size:11px; color:var(--gr); font-family:var(--mono); margin-top:2px; }

/* Features */
.features-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:16px; }
.feature-card {
  background:linear-gradient(145deg, #141c30, #1a2440);
  border:1px solid rgba(99,128,255,.08); border-radius:var(--rl);
  padding:28px; transition:all .35s; position:relative; overflow:hidden;
}
.feature-card::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(99,102,241,.06),transparent 60%);
  opacity:0; transition:.3s;
}
.feature-card:hover { border-color:var(--bdr2); transform:translateY(-3px); }
.feature-card:hover::before { opacity:1; }
.feature-icon { margin-bottom:14px; color:var(--ac2); }
.feature-card h3 { font-size:16px; font-weight:700; margin-bottom:8px; }
.feature-card p { font-size:14px; color:var(--tx2); line-height:1.6; }

/* Tariffs */
.tariffs-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:20px; }
.tariff-card {
  background:linear-gradient(145deg, #141c30, #1a2440);
  border:1px solid rgba(99,128,255,.1); border-radius:20px;
  padding:28px; position:relative; transition:all .3s;
}
.tariff-card.popular { border-color:rgba(99,102,241,.4); box-shadow:0 0 30px rgba(99,102,241,.08); }
.tariff-card:hover { transform:translateY(-3px); box-shadow:var(--shadow); }
.tariff-badge { position:absolute; top:16px; right:16px; background:linear-gradient(135deg,var(--ac),#4f46e5); color:#fff; font-size:11px; font-weight:700; padding:4px 12px; border-radius:20px; }
.tariff-game { display:flex; align-items:center; gap:8px; margin-bottom:12px; font-size:14px; color:var(--tx2); }
.tariff-name { font-size:20px; font-weight:800; margin-bottom:6px; }
.tariff-price { font-size:28px; font-weight:900; font-family:var(--mono); color:var(--gr); margin-bottom:16px; }
.tariff-price small { font-size:14px; color:var(--tx3); font-weight:400; }
.tariff-features { list-style:none; margin-bottom:20px; }
.tariff-features li { padding:6px 0; font-size:14px; color:var(--tx2); border-bottom:1px solid var(--bdr); }
.tariff-features li:last-child { border:none; }
.tariff-features li::before { content:'✓ '; color:var(--gr); font-weight:700; }

/* Install steps */
.install-steps { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:24px; }
.install-step { text-align:center; padding:24px; }
.step-num {
  display:inline-flex; align-items:center; justify-content:center;
  width:48px; height:48px; border-radius:50%; background:var(--acbg);
  color:var(--ac2); font-size:20px; font-weight:900; font-family:var(--mono); margin-bottom:16px;
}

/* News */
.news-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(350px,1fr)); gap:20px; }
.news-card { background:linear-gradient(145deg,#141c30,#1a2440); border:1px solid var(--bdr); border-radius:var(--rl); padding:24px; transition:.3s; }
.news-card:hover { border-color:var(--bdr2); }
.news-date { font-size:12px; color:var(--tx3); margin-bottom:8px; }
.news-title { font-size:18px; font-weight:700; margin-bottom:10px; }
.news-excerpt { font-size:14px; color:var(--tx2); line-height:1.6; }

/* Footer */
.footer { background:rgba(10,15,30,.8); border-top:1px solid rgba(99,128,255,.08); padding:48px 24px 24px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:32px; max-width:1200px; margin:0 auto 32px; }
@media(max-width:768px) { .footer-grid { grid-template-columns:1fr; } }
.footer-brand { font-size:18px; font-weight:800; display:flex; align-items:center; gap:8px; margin-bottom:12px; }
.footer-col h4 { font-size:14px; font-weight:700; margin-bottom:12px; }
.footer-col a { display:block; color:var(--tx2); font-size:14px; padding:4px 0; }
.footer-col p { color:var(--tx2); font-size:14px; }
.footer-bottom { text-align:center; color:var(--tx3); font-size:13px; padding-top:24px; border-top:1px solid var(--bdr); max-width:1200px; margin:0 auto; }

/* ═══ AUTH PAGE ═══ */
.auth-page {
  min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px;
  position:relative; overflow:hidden;
  background:
    radial-gradient(ellipse at 30% 30%,rgba(99,102,241,.1),transparent 50%),
    radial-gradient(ellipse at 70% 70%,rgba(6,182,212,.06),transparent 50%),
    linear-gradient(165deg, #080d1a, #0b1120, #0a0f1e);
}
.auth-card {
  background:linear-gradient(145deg, #111827, #161e30);
  border:1px solid rgba(99,128,255,.15); border-radius:var(--rx);
  padding:44px 36px; width:100%; max-width:420px;
  box-shadow:0 20px 60px rgba(0,0,0,.4); animation:scaleIn .4s ease both;
}
.auth-logo { display:flex; align-items:center; gap:14px; justify-content:center; margin-bottom:12px; }
.auth-logo-icon {
  width:56px; height:56px; border-radius:18px;
  background:linear-gradient(135deg,var(--ac),#4338ca);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 40px var(--acg); color:#fff;
}
.auth-logo-text { font-size:28px; font-weight:900; letter-spacing:-1px; }
.auth-sub { text-align:center; color:var(--tx2); font-size:14px; margin-bottom:28px; }
.auth-form { display:flex; flex-direction:column; gap:18px; }
.auth-toggle { text-align:center; margin-top:20px; font-size:13px; color:var(--tx3); }

/* ═══ DROPDOWN — FIXED (click-based) ═══ */
.topnav-dropdown { position:relative; }
.topnav-dropdown .dropdown-menu {
  display:none; position:absolute; top:calc(100% + 6px); left:0;
  min-width:200px;
  background:linear-gradient(145deg, #141c30, #1a2440);
  border:1px solid var(--bdr2); border-radius:var(--r);
  box-shadow:0 12px 40px rgba(0,0,0,.5);
  padding:8px; z-index:500;
}
.topnav-dropdown.open .dropdown-menu { display:block; animation:slideDown .2s ease; }
.dropdown-right { left:auto; right:0; }
.dropdown-menu a,
.dropdown-menu .dropdown-btn {
  display:flex; align-items:center; gap:10px;
  width:100%; text-align:left; padding:10px 14px;
  color:var(--tx2); font-size:13px; font-weight:500;
  border-radius:8px; transition:.2s; text-decoration:none;
  background:none; border:none; cursor:pointer; font-family:var(--font);
}
.dropdown-menu a:hover,
.dropdown-menu .dropdown-btn:hover { background:rgba(255,255,255,.06); color:var(--tx); }
.dropdown-header {
  padding:10px 14px; font-weight:700; font-size:14px;
  color:var(--tx); border-bottom:1px solid var(--bdr);
  margin-bottom:4px;
}
.dropdown-divider { height:1px; background:var(--bdr); margin:4px 0; }
.dropdown-btn-logout { color:var(--rd) !important; }
.dropdown-btn-logout:hover { background:var(--rdbg) !important; color:var(--rd) !important; }

/* Logout form fix */
.logout-form { margin:0; padding:0; }

/* ═══ TOPNAV AVATAR ═══ */
.topnav-avatar {
  width:38px; height:38px; border-radius:50% !important;
  background:linear-gradient(135deg, var(--ac), #7c3aed);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:15px; color:#fff;
  text-decoration:none; cursor:pointer; transition:.2s;
  flex-shrink:0; aspect-ratio:1/1;
}
.topnav-avatar:hover { transform:scale(1.08); }

/* ═══ STAT CARDS ═══ */
.stat-card {
  background:linear-gradient(145deg, #111827, #161e30);
  border:1px solid var(--bdr); border-radius:var(--rl);
  padding:20px; transition:.3s;
}
.stat-card:hover { border-color:var(--bdr2); transform:translateY(-2px); }
.stat-card-value { font-family:var(--mono); font-weight:800; font-size:26px; }

/* ═══ TABLE FIXES ═══ */
.table-card {
  background:linear-gradient(145deg, #111827, #151d2e);
  border:1px solid var(--bdr); border-radius:var(--rl); overflow:hidden;
}
table.dt { border-collapse:collapse; width:100%; }
table.dt th {
  background:rgba(255,255,255,.02); font-size:10px; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--tx3); padding:12px 16px;
  border-bottom:1px solid var(--bdr); text-align:left;
}
table.dt td { padding:14px 16px; border-bottom:1px solid var(--bdr); font-size:14px; vertical-align:middle; }
table.dt tbody tr { transition:background .15s; cursor:pointer; }
table.dt tbody tr:hover { background:rgba(99,102,241,.03); }
table.dt tbody tr:last-child td { border-bottom:none; }

/* ═══ EMPTY STATE ═══ */
.empty-state { text-align:center; padding:60px 20px; }
.empty-state-icon { margin-bottom:12px; color:var(--tx3); }
.empty-state-text { color:var(--tx2); font-size:16px; margin-bottom:16px; }

/* ═══ FORM SPACING ═══ */
.mb-16 { margin-bottom:16px; }
.mb-24 { margin-bottom:24px; }
.mt-16 { margin-top:16px; }
.mt-24 { margin-top:24px; }

/* ═══ LOADING SPINNER ═══ */
.loading { text-align:center; padding:60px; color:var(--tx3); }
.spinner {
  width:32px; height:32px; border:3px solid var(--bdr);
  border-top-color:var(--ac); border-radius:50%;
  animation:spin .8s linear infinite; margin:0 auto 12px;
}

/* ═══ CONSOLE ═══ */
.console {
  background:#020408; border:1px solid var(--bdr); border-radius:12px;
  padding:16px; font-family:var(--mono); font-size:12px;
  color:var(--gr); max-height:300px; overflow-y:auto; line-height:1.8;
}
.console-line::before { content:'› '; color:var(--tx3); }

/* ═══ MOBILE BOTTOM NAV ═══ */
.mobile-bottom-nav {
  display:none; position:fixed;
  bottom:0; left:0; right:0; z-index:200;
  background:rgba(6,8,15,.95); backdrop-filter:blur(24px);
  border-top:1px solid var(--bdr);
  padding:4px 6px; padding-bottom:env(safe-area-inset-bottom, 4px);
}
.mobile-bottom-nav a {
  flex:1; display:flex; flex-direction:column; align-items:center;
  gap:2px; padding:8px 4px; border-radius:8px;
  font-size:10px; font-weight:600; color:var(--tx3);
  text-decoration:none; transition:.2s;
}
.mobile-bottom-nav a.active { color:var(--ac2); background:var(--acbg); }
.mobile-bottom-nav .nav-icon { display:flex; align-items:center; justify-content:center; height:22px; }

@media(max-width:768px) {
  .mobile-bottom-nav { display:flex; }
  .topnav-links { display:none !important; }
  .panel-main { padding-bottom:80px; }
  .config-grid { grid-template-columns:1fr; }
  .order-summary { position:static; }
  .profile-grid { grid-template-columns:1fr; }
  .stats-row { grid-template-columns:1fr 1fr; }
  .page-title { font-size:20px; }
}

/* ═══ ORDER CONFIGURATOR ═══ */
.opt-btn {
  padding:12px 20px; border-radius:var(--r);
  border:1px solid var(--bdr); background:linear-gradient(145deg,#111827,#151d2e);
  color:var(--tx2); cursor:pointer; font-family:var(--font);
  font-size:14px; font-weight:600; transition:.25s; position:relative;
}
.opt-btn:hover { border-color:var(--bdr2); color:var(--tx); }
.opt-btn.active { border-color:var(--ac); background:var(--acbg); color:var(--ac2); box-shadow:0 0 16px rgba(99,102,241,.1); }
.opt-btn .sub { display:block; font-size:11px; color:var(--tx3); font-family:var(--mono); margin-top:2px; }
.opt-badge-green { position:absolute; top:-8px; right:-4px; background:var(--gr); color:#000; font-size:10px; font-weight:700; padding:2px 6px; border-radius:4px; }

/* ═══ PANEL NAV ═══ */
.panel-topnav {
  background:rgba(10,15,30,.9); backdrop-filter:blur(24px) saturate(1.3);
}

/* ═══ TOAST ═══ */
.toast-notification {
  position:fixed; bottom:24px; right:24px; z-index:9999; max-width:400px;
  padding:14px 20px; border-radius:var(--rl);
  font-family:var(--font); font-size:14px; font-weight:600;
  box-shadow:0 8px 32px rgba(0,0,0,.4); animation:toastIn .3s ease;
}
.toast-success { background:var(--grbg); color:var(--gr); border:1px solid rgba(16,185,129,.2); }
.toast-error { background:var(--rdbg); color:var(--rd); border:1px solid rgba(239,68,68,.2); }

/* ═══ MODAL ═══ */
.modal-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.6); backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center; z-index:999;
  animation:fadeIn .2s ease;
}
.modal-box {
  background:linear-gradient(145deg,#111827,#161e30); border:1px solid var(--bdr2);
  border-radius:var(--rx); padding:32px; max-width:480px; width:90%;
  box-shadow:0 20px 60px rgba(0,0,0,.5); animation:scaleIn .3s ease both;
}
