/* ═══════════════════════════════════════════════
   GeradorDeNick.net — Main Stylesheet
   Dark mode default · Light mode (Vibrant) toggle
   ═══════════════════════════════════════════════ */

/* ── DARK THEME (default) ── */
:root {
  --bg:        #070a0f;
  --bg2:       #0c1018;
  --surface:   #111827;
  --surface2:  #1a2235;
  --border:    #1e2d45;
  --border2:   #243352;
  --accent:    #00e5ff;
  --accent2:   #a855f7;
  --accent3:   #ec4899;
  --orange:    #f97316;
  --green:     #10b981;
  --red:       #ef4444;
  --text:      #e2e8f0;
  --muted:     #64748b;
  --light:     #94a3b8;
  --nav-bg:    rgba(7,10,15,.85);
  --grid-clr:  rgba(0,229,255,.025);
  --shadow-card: 0 32px 64px rgba(0,0,0,.55), 0 0 80px rgba(0,229,255,.04);
  --shadow-btn:  0 4px 20px rgba(0,229,255,.25);
  --glow:      0 0 20px rgba(0,229,255,.2);
  --marquee-bg:linear-gradient(90deg,rgba(0,229,255,.08),rgba(168,85,247,.08),rgba(236,72,153,.08),rgba(249,115,22,.08));
  --cta-glow:  radial-gradient(ellipse 80% 60% at 50% 100%,rgba(0,229,255,.08),transparent),
               radial-gradient(ellipse 60% 50% at 20% 50%,rgba(168,85,247,.07),transparent),
               radial-gradient(ellipse 60% 50% at 80% 50%,rgba(236,72,153,.06),transparent);
}

/* ── LIGHT THEME (Vibrant) ── */
[data-theme="light"] {
  --bg:        #fafafa;
  --bg2:       #f1f5f9;
  --surface:   #ffffff;
  --surface2:  #f8fafc;
  --border:    #dde1e7;
  --border2:   #9ca3af;
  --accent:    #7c3aed;
  --accent2:   #a855f7;
  --accent3:   #ec4899;
  --orange:    #f97316;
  --green:     #10b981;
  --red:       #ef4444;
  --text:      #111111;
  --muted:     #4a5568;
  --light:     #6b7280;
  --nav-bg:    rgba(250,250,250,.9);
  --grid-clr:  rgba(124,58,237,.035);
  --shadow-card: 0 4px 6px rgba(0,0,0,.04), 0 20px 48px rgba(124,58,237,.1);
  --shadow-btn:  0 4px 16px rgba(124,58,237,.3);
  --glow:      0 0 20px rgba(124,58,237,.15);
  --marquee-bg:linear-gradient(90deg,rgba(124,58,237,.12),rgba(168,85,247,.1),rgba(236,72,153,.1),rgba(249,115,22,.1));
  --cta-glow:  radial-gradient(ellipse 80% 60% at 50% 100%,rgba(124,58,237,.1),transparent),
               radial-gradient(ellipse 60% 50% at 20% 50%,rgba(168,85,247,.08),transparent),
               radial-gradient(ellipse 60% 50% at 80% 50%,rgba(236,72,153,.07),transparent);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; overflow-x:hidden; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
  line-height: 1.6;
  min-height: 100vh;
  overflow-x: hidden;
  transition: background .3s, color .3s;
}
img { max-width:100%; height:auto; display:block; }
a { color: inherit; text-decoration:none; }
button { font-family: inherit; cursor:pointer; }

/* ── GRID OVERLAY ── */
body::before {
  content:'';
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(var(--grid-clr) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-clr) 1px, transparent 1px);
  background-size: 44px 44px;
  transition: background-image .3s;
}
.z { position:relative; z-index:1; }

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4 { font-weight:900; letter-spacing:-.02em; line-height:1.1; }
h1 { font-size: clamp(2rem,5vw,3.5rem); }
h2 { font-size: clamp(1.5rem,3vw,2.2rem); }
h3 { font-size: 1.1rem; }
p  { line-height:1.65; }

.gradient-text {
  background: linear-gradient(135deg, var(--accent), var(--accent2), var(--accent3));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── LAYOUT ── */
.container { max-width:1140px; margin:0 auto; padding:0 24px; }
.section    { padding:64px 0; }

/* ── NAV ── */
.site-nav {
  position:sticky; top:0; z-index:200;
  height:58px;
  background: var(--nav-bg);
  backdrop-filter: blur(18px) saturate(180%);
  border-bottom: 1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
  padding: 0 24px;
  transition: background .3s, border-color .3s;
}
.nav-logo { display:flex; align-items:center; gap:9px; }
.nav-logo-mark {
  width:32px; height:32px; border-radius:8px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  display:flex; align-items:center; justify-content:center;
  font-size:.9rem; font-weight:900;
  color:#fff;
  flex-shrink:0;
}
[data-theme="dark"] .nav-logo-mark { color:#070a0f; }
.nav-logo-text {
  font-size:.9rem; font-weight:800;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  white-space:nowrap;
}
.nav-links { display:flex; gap:4px; }
.nav-link {
  padding:5px 12px; border-radius:7px;
  font-size:.8rem; font-weight:600;
  color:var(--light); border:1px solid transparent;
  transition: all .2s; white-space:nowrap;
}
.nav-link:hover { color:var(--accent); background:rgba(0,229,255,.06); border-color:rgba(0,229,255,.15); }
[data-theme="light"] .nav-link:hover { background:rgba(124,58,237,.07); border-color:rgba(124,58,237,.18); }
.nav-link.is-hot { color:var(--orange); }
.nav-actions { display:flex; gap:8px; align-items:center; }

/* theme toggle — icon button */
.theme-toggle-btn {
  width:38px; height:38px; border-radius:9px;
  background:var(--surface); border:1px solid var(--border2);
  display:flex; align-items:center; justify-content:center;
  font-size:1rem; cursor:pointer; flex-shrink:0;
  transition: background .2s, border-color .2s, transform .15s;
}
.theme-toggle-btn:hover { border-color:var(--accent); background:var(--surface2); transform:scale(1.08); }

.btn-ghost {
  padding:6px 14px; border-radius:7px;
  border:1px solid var(--border2); background:transparent;
  color:var(--light); font-size:.78rem; font-weight:600;
  transition: all .2s;
}
.btn-ghost:hover { border-color:var(--accent); color:var(--accent); }
[data-theme="light"] .btn-ghost { color:var(--muted); border-color:var(--border2); }
[data-theme="light"] .btn-ghost:hover { border-color:var(--accent); color:var(--accent); }
[data-theme="light"] .btn-outline { color:var(--muted); border-color:var(--border2); }
[data-theme="light"] .btn-outline:hover { border-color:var(--accent2); color:var(--accent2); }
.btn-fill {
  padding:7px 16px; border-radius:7px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  border:none; color:#fff; font-size:.78rem; font-weight:800;
  box-shadow: var(--shadow-btn);
  transition: opacity .2s, transform .1s;
}
[data-theme="dark"] .btn-fill { color:#070a0f; }
.btn-fill:hover { opacity:.9; transform:translateY(-1px); }

/* mobile nav toggle */
.nav-hamburger { display:none; flex-direction:column; gap:5px; padding:6px; border:none; background:transparent; }
.nav-hamburger span { display:block; width:22px; height:2px; background:var(--muted); border-radius:1px; transition: all .2s; }

/* ── HERO ── */
.hero {
  display:grid; grid-template-columns:1fr 1fr;
  gap:56px; align-items:center;
  padding:64px 0 56px;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:7px;
  background: rgba(0,229,255,.07);
  border:1px solid rgba(0,229,255,.2);
  border-radius:999px; padding:4px 14px;
  font-size:.7rem; font-weight:800; letter-spacing:.08em;
  text-transform:uppercase; color:var(--accent);
  margin-bottom:20px;
}
[data-theme="light"] .hero-badge { background:rgba(124,58,237,.08); border-color:rgba(124,58,237,.22); }
.badge-dot {
  width:6px; height:6px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 8px var(--accent);
  animation: blink 2s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }
.hero h1 { margin-bottom:18px; }
.hero-sub { font-size:1rem; color:var(--muted); max-width:430px; margin-bottom:32px; }
.hero-ctas { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:32px; }
.btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 26px; border-radius:10px; border:none;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color:#fff; font-size:.95rem; font-weight:800;
  box-shadow: var(--shadow-btn);
  transition: opacity .2s, transform .15s;
}
[data-theme="dark"] .btn-primary { color:#070a0f; }
.btn-primary:hover { opacity:.9; transform:translateY(-2px); }
.btn-outline {
  display:inline-flex; align-items:center; gap:6px;
  padding:14px 22px; border-radius:10px;
  border:1px solid var(--border2); background:transparent;
  color:var(--light); font-size:.9rem; font-weight:600;
  transition: all .2s;
}
.btn-outline:hover { border-color:var(--accent2); color:var(--accent2); }
.hero-micros { display:flex; gap:18px; flex-wrap:wrap; }
.micro { display:flex; align-items:center; gap:5px; font-size:.77rem; color:var(--muted); }
.micro-check { color:var(--green); font-weight:900; }

/* ── GENERATOR CARD ── */
.gen-card {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:18px; overflow:hidden;
  box-shadow: var(--shadow-card);
  position:relative;
  transition: background .3s, border-color .3s, box-shadow .3s;
}
.gen-card::before {
  content:''; position:absolute; inset:0; border-radius:18px;
  background: linear-gradient(135deg,rgba(0,229,255,.04),transparent 50%,rgba(168,85,247,.04));
  pointer-events:none;
}
[data-theme="light"] .gen-card::before {
  background: linear-gradient(135deg,rgba(124,58,237,.04),transparent 50%,rgba(168,85,247,.04));
}
.gen-topbar {
  background: linear-gradient(90deg, rgba(0,229,255,.1), rgba(168,85,247,.1));
  border-bottom:1px solid var(--border);
  padding:13px 18px;
  display:flex; align-items:center; gap:10px;
}
[data-theme="light"] .gen-topbar { background: linear-gradient(90deg,rgba(124,58,237,.1),rgba(168,85,247,.1)); }
.tb-dots { display:flex; gap:6px; }
.tb-dot { width:10px; height:10px; border-radius:50%; }
.tb-dot:nth-child(1){background:#ef4444} .tb-dot:nth-child(2){background:var(--orange)} .tb-dot:nth-child(3){background:var(--green)}
.tb-title { font-size:.72rem; color:var(--muted); font-weight:600; margin-left:4px; }
.tb-live { margin-left:auto; display:flex; align-items:center; gap:5px; font-size:.65rem; font-weight:700; color:var(--green); letter-spacing:.06em; }
.tb-live-dot { width:6px; height:6px; border-radius:50%; background:var(--green); box-shadow:0 0 6px var(--green); animation:blink 1.5s ease-in-out infinite; }
.gen-body { padding:18px; }

/* Platform tabs */
.ptabs { display:flex; gap:5px; margin-bottom:14px; overflow-x:auto; scrollbar-width:none; }
.ptabs::-webkit-scrollbar { display:none; }
.ptab {
  padding:5px 12px; border-radius:7px;
  font-size:.72rem; font-weight:700; white-space:nowrap;
  border:1px solid var(--border); background:transparent;
  color:var(--muted); transition: all .2s;
}
.ptab.is-active { background:rgba(0,229,255,.1); border-color:rgba(0,229,255,.35); color:var(--accent); }
[data-theme="light"] .ptab.is-active { background:rgba(124,58,237,.1); border-color:rgba(124,58,237,.35); }

/* Input row */
.gen-input-row { display:flex; gap:8px; margin-bottom:12px; }
.gen-input {
  flex:1; padding:11px 14px;
  background:var(--surface2); border:1px solid var(--border);
  border-radius:8px; color:var(--text); font-size:.9rem;
  outline:none; transition: border-color .2s, background .3s;
}
.gen-input:focus { border-color:var(--accent); box-shadow:var(--glow); }
.gen-input::placeholder { color:var(--muted); }
.gen-go {
  padding:11px 18px; border-radius:8px; border:none;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color:#fff; font-weight:800; font-size:.82rem;
  transition: opacity .2s;
}
[data-theme="dark"] .gen-go { color:#070a0f; }
.gen-go:hover { opacity:.88; }

/* Category chips */
.gen-chips { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:14px; }
.gen-chip {
  padding:4px 10px; border-radius:999px;
  font-size:.68rem; font-weight:700;
  border:1px solid var(--border); color:var(--muted);
  transition: all .2s; background:transparent;
}
.gen-chip.is-active { border-color:var(--accent2); color:var(--accent2); background:rgba(168,85,247,.08); }

/* Results */
.gen-results-hd { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.gen-results-label { font-size:.65rem; font-weight:800; text-transform:uppercase; letter-spacing:.07em; color:var(--muted); }
.gen-results-actions { display:flex; gap:6px; }
.btn-tiny {
  padding:4px 9px; border-radius:5px;
  border:1px solid var(--border); background:transparent;
  font-size:.65rem; font-weight:700; color:var(--muted);
  transition: all .2s;
}
.btn-tiny:hover { border-color:var(--accent); color:var(--accent); }

.gen-results { display:flex; flex-direction:column; gap:6px; }
.gen-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 12px; border-radius:8px;
  border:1px solid var(--border); background:var(--surface2);
  cursor:pointer; transition: all .2s;
}
.gen-row:hover { border-color:var(--accent); }
[data-theme="dark"] .gen-row:hover { background:rgba(0,229,255,.04); }
[data-theme="light"] .gen-row:hover { background:rgba(124,58,237,.04); }
.gen-row.is-top { border-color:rgba(0,229,255,.3); }
[data-theme="dark"] .gen-row.is-top { background:rgba(0,229,255,.06); }
[data-theme="light"] .gen-row.is-top { border-color:rgba(124,58,237,.3); background:rgba(124,58,237,.05); }
.gen-row-left { display:flex; align-items:center; gap:10px; flex:1; min-width:0; }
.gen-num { font-size:.62rem; color:var(--muted); font-weight:700; width:16px; flex-shrink:0; }
.gen-nick { font-size:.9rem; font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.gen-badge {
  font-size:.6rem; padding:2px 7px; border-radius:999px;
  background:var(--bg2,var(--surface)); color:var(--muted); font-weight:700;
  border:1px solid var(--border); flex-shrink:0;
}
.gen-row-right { display:flex; gap:5px; flex-shrink:0; }
.row-btn {
  width:28px; height:28px; border-radius:6px;
  border:1px solid var(--border); background:transparent;
  color:var(--muted); font-size:.75rem;
  display:flex; align-items:center; justify-content:center;
  transition: all .2s;
}
.row-btn:hover, .row-btn.is-copied { background:var(--accent); border-color:var(--accent); }
[data-theme="dark"] .row-btn:hover, [data-theme="dark"] .row-btn.is-copied { color:#070a0f; }
[data-theme="light"] .row-btn:hover, [data-theme="light"] .row-btn.is-copied { color:#fff; }
.row-btn.is-fav { color:var(--accent3); border-color:var(--accent3); }

/* Empty state */
.gen-empty { text-align:center; padding:32px 16px; color:var(--muted); font-size:.9rem; }
.gen-empty-icon { font-size:2rem; margin-bottom:10px; }

/* ── MARQUEE ── */
.marquee {
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background: var(--marquee-bg);
  padding:13px 0; overflow:hidden; white-space:nowrap;
  transition: border-color .3s;
}
.marquee-track { display:inline-block; animation:scroll 22s linear infinite; }
@keyframes scroll { to { transform:translateX(-50%); } }
.marquee-item { display:inline-flex; align-items:center; gap:7px; margin:0 28px; font-size:.78rem; font-weight:700; color:var(--light); }
.marquee-sep { color:var(--border2); }

/* ── STATS STRIP ── */
.stats-strip {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:1px; background:var(--border);
  border:1px solid var(--border); border-radius:14px; overflow:hidden;
  margin:48px 0;
  transition: border-color .3s;
}
.stat-cell { background:var(--surface); padding:28px 20px; text-align:center; transition:background .3s; }
.stat-n {
  font-size:2rem; font-weight:900; letter-spacing:-.03em; margin-bottom:4px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.stat-l { font-size:.78rem; color:var(--muted); font-weight:600; }

/* ── SECTION LABELS ── */
.sec-eye { font-size:.7rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); margin-bottom:6px; }
.sec-h2  { margin-bottom:8px; }
.sec-p   { color:var(--muted); font-size:.95rem; max-width:500px; margin-bottom:40px; }

/* ── GAME TILES ── */
.game-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:12px; }
.game-tile {
  background:var(--surface); border:1px solid var(--border);
  border-radius:14px; padding:22px 14px; text-align:center;
  transition: all .2s; position:relative; overflow:hidden; display:block;
}
.game-tile::before { content:''; position:absolute; inset:0; opacity:0; transition:opacity .2s; }
.game-tile:hover { transform:translateY(-3px); }
.game-tile:hover::before { opacity:1; }
.game-tile.ff::before   { background:linear-gradient(135deg,rgba(249,115,22,.12),rgba(239,68,68,.08)); }
.game-tile.ff:hover     { border-color:var(--orange); box-shadow:0 8px 24px rgba(249,115,22,.15); }
.game-tile.pubg::before  { background:linear-gradient(135deg,rgba(16,185,129,.1),rgba(6,182,212,.08)); }
.game-tile.pubg:hover    { border-color:var(--green); box-shadow:0 8px 24px rgba(16,185,129,.15); }
.game-tile.ig::before    { background:linear-gradient(135deg,rgba(168,85,247,.1),rgba(236,72,153,.08)); }
.game-tile.ig:hover      { border-color:var(--accent2); box-shadow:0 8px 24px rgba(168,85,247,.15); }
.game-tile.dc::before    { background:linear-gradient(135deg,rgba(99,102,241,.1),rgba(59,130,246,.08)); }
.game-tile.dc:hover      { border-color:#6366f1; box-shadow:0 8px 24px rgba(99,102,241,.15); }
.game-tile.tw::before    { background:linear-gradient(135deg,rgba(168,85,247,.12),rgba(139,92,246,.08)); }
.game-tile.tw:hover      { border-color:var(--accent2); box-shadow:0 8px 24px rgba(168,85,247,.15); }
.game-tile.vl::before    { background:linear-gradient(135deg,rgba(239,68,68,.1),rgba(249,115,22,.08)); }
.game-tile.vl:hover      { border-color:var(--red); box-shadow:0 8px 24px rgba(239,68,68,.15); }
.game-tile.tt::before    { background:linear-gradient(135deg,rgba(99,102,241,.1),rgba(59,130,246,.08)); }
.game-tile.tt:hover      { border-color:var(--accent); box-shadow:0 8px 24px rgba(0,229,255,.15); }
.game-tile.yt::before    { background:linear-gradient(135deg,rgba(239,68,68,.12),rgba(249,115,22,.08)); }
.game-tile.yt:hover      { border-color:var(--red); }
.tile-icon  { font-size:2rem; margin-bottom:8px; position:relative; }
.tile-name  { font-size:.78rem; font-weight:800; position:relative; }
.tile-count { font-size:.67rem; color:var(--muted); margin-top:3px; position:relative; }

/* ── STYLE GRID ── */
.style-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(170px,1fr)); gap:10px; }
.style-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:12px; padding:16px; cursor:pointer;
  transition: all .2s;
}
.style-card:hover { border-color:var(--accent); transform:translateY(-1px); box-shadow:var(--glow); }
.style-card.ac { border-color:rgba(0,229,255,.2); }
[data-theme="light"] .style-card.ac { border-color:rgba(124,58,237,.2); background:rgba(124,58,237,.04); }
[data-theme="dark"]  .style-card.ac { background:rgba(0,229,255,.04); }
.style-card.ap { border-color:rgba(168,85,247,.2); }
.style-card.ap { background:rgba(168,85,247,.04); }
.style-card.apk { border-color:rgba(236,72,153,.2); background:rgba(236,72,153,.04); }
.style-card-tag { font-size:.62rem; font-weight:800; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); margin-bottom:8px; }
.style-card-preview { font-size:.95rem; color:var(--text); }

/* ── FEATURE CARDS ── */
.features-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:12px; }
.feature-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:14px; padding:26px 22px;
  position:relative; overflow:hidden;
  transition: all .2s;
}
.feature-card::after { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; opacity:0; transition:opacity .2s; }
.feature-card:hover { transform:translateY(-2px); border-color:var(--border2); }
.feature-card:hover::after { opacity:1; }
.feature-card.c::after { background:linear-gradient(90deg, var(--accent), var(--accent2)); }
.feature-card.p::after { background:linear-gradient(90deg, var(--accent2), var(--accent3)); }
.feature-card.o::after { background:linear-gradient(90deg, var(--orange), var(--accent3)); }
.feature-card.g::after { background:linear-gradient(90deg, var(--green), var(--accent)); }
.feat-icon  { font-size:1.6rem; margin-bottom:14px; }
.feat-title { font-size:.92rem; font-weight:800; margin-bottom:6px; }
.feat-desc  { font-size:.8rem; color:var(--muted); line-height:1.55; }

/* ── COMPARE TABLE ── */
.compare-wrap { background:var(--surface); border:1px solid var(--border); border-radius:14px; overflow:hidden; transition:background .3s,border-color .3s; }
table { width:100%; border-collapse:collapse; }
thead th { padding:14px 18px; font-size:.75rem; font-weight:800; text-transform:uppercase; letter-spacing:.06em; background:var(--surface2); border-bottom:1px solid var(--border); text-align:left; color:var(--muted); }
thead th.us { color:var(--accent); }
tbody td { padding:13px 18px; font-size:.84rem; border-bottom:1px solid var(--border); }
tbody tr:last-child td { border-bottom:none; }
tbody tr:hover td { background:rgba(0,229,255,.02); }
[data-theme="light"] tbody tr:hover td { background:rgba(124,58,237,.03); }
.td-feat { font-weight:600; }
.yes { color:var(--green); font-weight:700; }
.no  { color:var(--muted); }

/* ── CTA BAND ── */
.cta-band {
  position:relative; overflow:hidden;
  background:var(--surface);
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  padding:72px 24px; text-align:center;
  transition: background .3s, border-color .3s;
}
.cta-band::before { content:''; position:absolute; inset:0; background:var(--cta-glow); pointer-events:none; }
.cta-band h2 { margin-bottom:14px; position:relative; }
.cta-band p  { color:var(--muted); font-size:.95rem; max-width:420px; margin:0 auto 36px; position:relative; }
.cta-btns   { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; position:relative; }

/* ── FAQ ── */
.faq-list { display:flex; flex-direction:column; gap:10px; }
.faq-item {
  background:var(--surface); border:1px solid var(--border);
  border-radius:14px; overflow:hidden;
  transition: border-color .25s, box-shadow .25s;
}
.faq-item:hover { border-color:var(--border2); }
.faq-item.is-open { border-color:var(--accent); box-shadow:0 0 0 1px var(--accent); }
.faq-q {
  padding:20px 24px; font-size:.93rem; font-weight:700;
  color:var(--text); cursor:pointer;
  display:flex; justify-content:space-between; align-items:center; gap:16px;
  background:transparent; border:none; width:100%; text-align:left;
}
.faq-icon {
  width:26px; height:26px; border-radius:7px; flex-shrink:0;
  background:var(--surface2); border:1px solid var(--border2);
  color:var(--accent); display:flex; align-items:center; justify-content:center;
  font-size:.9rem; font-weight:900;
  transition: background .2s, border-color .2s, color .2s;
}
.faq-item.is-open .faq-icon { background:var(--accent); border-color:var(--accent); color:#fff; }
[data-theme="dark"] .faq-item.is-open .faq-icon { color:#070a0f; }
.faq-body { max-height:0; overflow:hidden; transition:max-height .35s cubic-bezier(.4,0,.2,1); }
.faq-item.is-open .faq-body { max-height:500px; }
.faq-a { padding:0 24px 20px; font-size:.875rem; color:var(--muted); line-height:1.7; }

/* ── CONTENT ARTICLE (for platform pages) ── */
.content-article { max-width:800px; }
.content-article h2 { font-size:1.5rem; margin:36px 0 14px; }
.content-article h3 { font-size:1.1rem; margin:24px 0 10px; color:var(--accent); }
.content-article p  { margin-bottom:14px; color:var(--muted); }
.content-article ul, .content-article ol { padding-left:20px; margin-bottom:14px; color:var(--muted); }
.content-article li { margin-bottom:6px; line-height:1.6; }
.content-article strong { color:var(--text); font-weight:700; }
.content-article a { color:var(--accent); }
.content-article a:hover { text-decoration:underline; }

/* ── FAVORITES DRAWER ── */
.fav-drawer {
  position:fixed; top:58px; right:0; bottom:0; width:320px; overflow:hidden;
  background:var(--surface); border-left:1px solid var(--border);
  z-index:150; transform:translateX(100%);
  transition: transform .3s cubic-bezier(.4,0,.2,1);
  display:flex; flex-direction:column;
  box-shadow:-8px 0 32px rgba(0,0,0,.3);
}
.fav-drawer.is-open { transform:translateX(0); }
.fav-header { padding:16px 20px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
.fav-title { font-size:.9rem; font-weight:700; }
.fav-close { background:transparent; border:none; color:var(--muted); font-size:1.1rem; cursor:pointer; }
.fav-panel { flex:1; overflow-y:auto; padding:12px; }
.fav-item { display:flex; align-items:center; justify-content:space-between; padding:10px 12px; border:1px solid var(--border); border-radius:8px; margin-bottom:6px; background:var(--surface2); }
.fav-nick { font-size:.88rem; font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; flex:1; min-width:0; }
.fav-actions { display:flex; gap:5px; flex-shrink:0; margin-left:8px; }
.fav-empty { text-align:center; padding:32px 16px; color:var(--muted); font-size:.85rem; }

/* ── FOOTER ── */
.site-footer { background:var(--bg2); border-top:1px solid var(--border); padding:52px 24px 28px; transition:background .3s,border-color .3s; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:36px; margin-bottom:44px; }
.f-brand-logo { font-size:1rem; font-weight:800; margin-bottom:10px; background:linear-gradient(90deg,var(--accent),var(--accent2)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; display:inline-block; }
.f-brand-desc { font-size:.8rem; color:var(--muted); line-height:1.6; max-width:260px; }
.f-col h4 { font-size:.7rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--light); margin-bottom:14px; }
.f-col a  { display:block; font-size:.8rem; color:var(--muted); margin-bottom:9px; transition:color .2s; }
.f-col a:hover { color:var(--accent); }
.footer-bottom { border-top:1px solid var(--border); padding-top:22px; display:flex; justify-content:space-between; align-items:center; font-size:.76rem; color:var(--muted); flex-wrap:wrap; gap:8px; }

/* ── BREADCRUMB ── */
.breadcrumb { display:flex; align-items:center; gap:6px; font-size:.78rem; color:var(--muted); margin-bottom:24px; flex-wrap:wrap; }
.breadcrumb a { color:var(--muted); }
.breadcrumb a:hover { color:var(--accent); }
.breadcrumb-sep { color:var(--border2); }
.breadcrumb-current { color:var(--accent); font-weight:600; }

/* ── NOTICE BOX ── */
.notice {
  background:rgba(0,229,255,.06); border:1px solid rgba(0,229,255,.2);
  border-radius:10px; padding:16px 18px; margin-bottom:24px;
  font-size:.85rem; color:var(--text); line-height:1.55;
}
[data-theme="light"] .notice { background:rgba(124,58,237,.06); border-color:rgba(124,58,237,.2); }
.notice strong { color:var(--accent); }

/* ── 404 ── */
.page-404 { text-align:center; padding:80px 24px; }
.page-404 .num { font-size:6rem; font-weight:900; line-height:1; background:linear-gradient(135deg,var(--accent),var(--accent2)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  .footer-grid { grid-template-columns:1fr 1fr; }
  .hero { gap:36px; }
}
@media (max-width: 768px) {
  .hero { grid-template-columns:1fr; gap:40px; }
  .hero-left { order:1; }
  .hero-right { order:2; }
  .hero-sub { max-width:100%; }
  .stats-strip { grid-template-columns:repeat(2,1fr); }
  .nav-links { display:none; }
  .nav-hamburger { display:flex; }
  .nav-links.is-open {
    display:flex; flex-direction:column;
    position:absolute; top:58px; left:0; right:0;
    background:var(--nav-bg); backdrop-filter:blur(18px);
    border-bottom:1px solid var(--border);
    padding:12px 24px; gap:4px; z-index:199;
  }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .fav-drawer { width:100%; }
  .fav-drawer:not(.is-open) { display:none; }
  .game-grid { grid-template-columns:repeat(auto-fill,minmax(110px,1fr)); }
  .style-grid { grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); }
  .hero { padding:0; }
  .hero > * { min-width:0; width:100%; }
  .section.hero-wrap { padding-top:12px; }
  .section { padding:48px 0; }
  .nav-actions .btn-ghost { display:none; }
  .nav-actions .btn-fill  { display:none; }
  .nav-logo-img { width:140px; height:auto; }
}
@media (max-width: 480px) {
  .stats-strip { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .hero-ctas { flex-direction:column; }
  .btn-primary, .btn-outline { justify-content:center; }
  .features-grid { grid-template-columns:1fr; }
  h1 { font-size:1.9rem; }
  .hero { padding:0; }
  .section.hero-wrap { padding-top:8px; }
  .section { padding:40px 0; }
  .container { padding:0 16px; }
}

/* ── UTILITIES ── */
.text-muted { color:var(--muted); }
.text-accent { color:var(--accent); }
.mt-8 { margin-top:8px; }
.mt-16 { margin-top:16px; }
.mt-24 { margin-top:24px; }
.mb-8  { margin-bottom:8px; }
.mb-16 { margin-bottom:16px; }
.mb-24 { margin-bottom:24px; }
.mb-40 { margin-bottom:40px; }
.hidden { display:none !important; }
