:root {
  --bg: #070b14;
  --bg-soft: #0c1220;
  --card: rgba(14, 21, 37, 0.82);
  --card-strong: rgba(19, 28, 48, 0.96);
  --border: rgba(148, 163, 184, 0.14);
  --text: #edf2ff;
  --muted: #91a0bc;
  --primary: #ef4444;
  --primary-2: #8b5cf6;
  --success: #22c55e;
  --warning: #f59e0b;
  --shadow: 0 24px 80px rgba(0,0,0,.45);
}
html { scroll-behavior: smooth; }
body.site-body {
  min-height: 100vh;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(239,68,68,.14), transparent 30%),
    radial-gradient(circle at top right, rgba(139,92,246,.16), transparent 32%),
    linear-gradient(180deg, #05070d 0%, #08101d 32%, #070b14 100%);
}
.grid-overlay::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
  background-size: 36px 36px;
  mask-image: linear-gradient(180deg, rgba(255,255,255,.6), transparent 95%);
}
.glass-card {
  background: var(--card);
  backdrop-filter: blur(18px);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.glass-card-strong {
  background: var(--card-strong);
  backdrop-filter: blur(18px);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.section-title {
  font-size: clamp(1.5rem, 2vw, 2.2rem);
  line-height: 1.1;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -.03em;
}
.kicker {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .45rem .8rem;
  border-radius: 9999px;
  border: 1px solid rgba(239,68,68,.25);
  background: rgba(239,68,68,.08);
  color: #fca5a5;
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.hero-title {
  font-size: clamp(2.4rem, 6vw, 5rem);
  line-height: .95;
  font-weight: 950;
  letter-spacing: -.06em;
  text-transform: uppercase;
}
.brand-gradient {
  background: linear-gradient(135deg, #fff 0%, #fca5a5 35%, #ef4444 60%, #8b5cf6 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.nav-link { color: #cbd5e1; transition: .2s; }
.nav-link:hover, .nav-link.active { color: white; }
.btn-primary {
  display: inline-flex; align-items: center; justify-content: center; gap: .65rem;
  border-radius: 1rem; padding: .95rem 1.2rem; font-weight: 900; text-transform: uppercase;
  letter-spacing: .08em; font-size: .78rem;
  background: linear-gradient(135deg, var(--primary), #fb7185);
  color: white; box-shadow: 0 12px 30px rgba(239,68,68,.3);
}
.btn-secondary {
  display: inline-flex; align-items: center; justify-content: center; gap: .65rem;
  border-radius: 1rem; padding: .95rem 1.2rem; font-weight: 900; text-transform: uppercase;
  letter-spacing: .08em; font-size: .78rem;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); color: white;
}
.stat-tile { border-radius: 1.5rem; padding: 1.4rem; position: relative; overflow: hidden; }
.stat-tile::after {
  content: ""; position: absolute; inset: auto -12% -38% auto; width: 110px; height: 110px;
  background: radial-gradient(circle, rgba(255,255,255,.18), transparent 65%); opacity: .5;
}
.server-row, .list-card { transition: .18s ease; }
.server-row:hover, .list-card:hover { transform: translateY(-2px); border-color: rgba(239,68,68,.35); }
.status-dot { width: .65rem; height: .65rem; border-radius: 9999px; display: inline-block; }
.status-online { background: var(--success); box-shadow: 0 0 0 6px rgba(34,197,94,.15); }
.status-offline { background: #ef4444; box-shadow: 0 0 0 6px rgba(239,68,68,.15); }
.badge {
  display: inline-flex; align-items: center; gap: .45rem; border-radius: 9999px; padding: .35rem .7rem;
  font-size: .68rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em;
}
.badge-red { background: rgba(239,68,68,.12); color: #fca5a5; border: 1px solid rgba(239,68,68,.2); }
.badge-green { background: rgba(34,197,94,.12); color: #86efac; border: 1px solid rgba(34,197,94,.2); }
.badge-violet { background: rgba(139,92,246,.12); color: #c4b5fd; border: 1px solid rgba(139,92,246,.2); }
.page-shell { max-width: 1280px; margin: 0 auto; padding: 1.25rem; }
.page-panel { border-radius: 2rem; padding: 1.5rem; }
.table-clean th { color: #94a3b8; font-size: .7rem; text-transform: uppercase; letter-spacing: .18em; }
.table-clean td { color: #e5e7eb; }
.input-shell, .select-shell {
  width: 100%; border-radius: 1rem; border: 1px solid rgba(148,163,184,.14); background: rgba(5,10,20,.62);
  color: white; padding: 1rem 1rem; outline: none; transition: .2s;
}
.input-shell:focus, .select-shell:focus { border-color: rgba(239,68,68,.55); box-shadow: 0 0 0 4px rgba(239,68,68,.12); }
.panel-title { font-size: 1.7rem; font-weight: 900; text-transform: uppercase; letter-spacing: -.04em; }
.topbar {
  position: sticky; top: 0; z-index: 40; backdrop-filter: blur(14px);
  background: rgba(5,8,16,.76); border-bottom: 1px solid rgba(148,163,184,.08);
}
.muted { color: var(--muted); }
.footer-note { color: #6b7280; font-size: .78rem; }
@media (max-width: 768px) {
  .page-shell { padding: .9rem; }
  .page-panel { border-radius: 1.5rem; padding: 1rem; }
}


.hero-surface {
  position: relative;
  overflow: hidden;
  border-radius: 2rem;
  padding: 1.6rem;
}
.hero-surface::before {
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(110deg, rgba(5,8,16,.94) 16%, rgba(5,8,16,.72) 48%, rgba(5,8,16,.22) 100%),
    radial-gradient(circle at 78% 24%, rgba(239,68,68,.22), transparent 28%),
    radial-gradient(circle at 85% 55%, rgba(139,92,246,.2), transparent 26%);
  pointer-events:none;
}
.hero-surface > * { position: relative; z-index: 1; }
.pill-row { display:flex; flex-wrap:wrap; gap:.7rem; }
.pill-chip {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.8rem 1rem; border-radius:9999px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08);
  font-size:.72rem; font-weight:900; text-transform:uppercase; letter-spacing:.12em;
}
.feature-strip {
  display:grid; gap:1rem;
  grid-template-columns: repeat(3, minmax(0,1fr));
}
.feature-card {
  border-radius:1.6rem; padding:1.25rem;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.08);
}
.server-banner-card {
  position:relative; overflow:hidden; min-height: 250px;
  border-radius:1.8rem; border:1px solid rgba(255,255,255,.08);
  background:
    linear-gradient(180deg, rgba(2,6,23,.18), rgba(2,6,23,.92)),
    url('https://images.unsplash.com/photo-1542751371-adc38448a05e?auto=format&fit=crop&w=1400&q=80') center/cover no-repeat;
  box-shadow: var(--shadow);
}
.server-banner-card::after {
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 20%, rgba(2,6,23,.92) 78%);
  pointer-events:none;
}
.server-banner-content { position:relative; z-index:1; height:100%; display:flex; flex-direction:column; justify-content:space-between; padding:1.35rem; }
.metric-grid { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:1rem; }
.metric-box {
  border-radius:1.3rem; padding:1rem; background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
}
.browse-grid { display:grid; gap:1.2rem; grid-template-columns: repeat(12, minmax(0,1fr)); }
.browse-main { grid-column: span 8 / span 8; }
.browse-side { grid-column: span 4 / span 4; display:grid; gap:1rem; }
.category-card {
  position:relative; overflow:hidden; min-height:180px; border-radius:1.7rem;
  border:1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(15,23,42,.15), rgba(15,23,42,.92));
}
.category-card img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.5; }
.category-card .overlay { position:absolute; inset:0; background:linear-gradient(180deg, transparent 30%, rgba(2,6,23,.94) 88%); }
.category-card .inner { position:relative; z-index:1; padding:1.25rem; display:flex; flex-direction:column; justify-content:end; min-height:180px; }
.server-card-large {
  position:relative; overflow:hidden; min-height:320px; border-radius:1.9rem;
  border:1px solid rgba(255,255,255,.08);
  background:
    linear-gradient(180deg, rgba(15,23,42,.12), rgba(2,6,23,.92)),
    radial-gradient(circle at top right, rgba(239,68,68,.18), transparent 24%),
    url('https://images.unsplash.com/photo-1511512578047-dfb367046420?auto=format&fit=crop&w=1400&q=80') center/cover no-repeat;
}
.server-card-large .content { position:relative; z-index:1; padding:1.4rem; display:flex; flex-direction:column; justify-content:end; min-height:320px; }
.server-mini-list { display:grid; gap:1rem; }
.server-mini-card {
  display:flex; gap:1rem; align-items:center; justify-content:space-between;
  padding:1rem 1.05rem; border-radius:1.35rem;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
}
.rank-row {
  display:grid; grid-template-columns: auto 1fr auto; gap:1rem; align-items:center;
  border-radius:1.45rem; padding:1rem 1.1rem;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
}
.topbar-alt {
  display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap;
}
.section-shell { border-radius: 1.9rem; padding:1.35rem; }
.server-cta-card {
  border-radius:1.7rem; padding:1.4rem;
  background: linear-gradient(135deg, rgba(239,68,68,.14), rgba(139,92,246,.14));
  border:1px solid rgba(255,255,255,.08);
}
@media (max-width: 1100px) {
  .browse-main, .browse-side { grid-column: span 12 / span 12; }
  .feature-strip { grid-template-columns:1fr; }
}
@media (max-width: 768px) {
  .metric-grid { grid-template-columns:1fr; }
  .hero-surface { padding:1rem; }
}

.games-page-cta { border-radius: 2rem; padding: 1.4rem; }
.games-page-cta-grid { display:grid; gap:1rem; }
.games-page-mini-card {
  border-radius:1.6rem; padding:1.2rem;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
}
.filter-shell {
  display:grid; gap:1rem;
  grid-template-columns: 1.35fr .8fr .8fr;
}
.filter-label {
  display:block; margin:0 0 .55rem; font-size:.72rem; font-weight:900;
  text-transform:uppercase; letter-spacing:.18em; color:#94a3b8;
}
.category-card-active {
  border-color: rgba(239,68,68,.45);
  box-shadow: 0 0 0 1px rgba(239,68,68,.25), 0 24px 80px rgba(0,0,0,.45);
}
.games-results-grid { display:grid; gap:1rem; }
.server-result-card {
  border-radius:1.7rem; padding:1.25rem;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
}
.server-inline-chip {
  display:inline-flex; align-items:center; padding:.65rem .8rem; border-radius:9999px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08);
}
@media (max-width: 900px) {
  .filter-shell { grid-template-columns: 1fr; }
}

.mobile-menu-button {
  display:inline-flex; align-items:center; justify-content:center; width:3rem; height:3rem;
  border-radius:1rem; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08);
}
.mobile-menu-panel {
  margin-top:1rem; border-radius:1.4rem; padding:1rem;
  background:rgba(8,12,22,.96); border:1px solid rgba(255,255,255,.08); box-shadow:var(--shadow);
}
.mobile-nav-link {
  display:flex; align-items:center; justify-content:space-between; padding:1rem 1rem;
  border-radius:1rem; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  font-size:.8rem; font-weight:900; text-transform:uppercase; letter-spacing:.12em; color:white;
}
.servers-toolbar {
  display:grid; gap:1rem; grid-template-columns:1.2fr .8fr .8fr .8fr;
}
.servers-grid { display:grid; gap:1rem; }
.server-directory-card {
  border-radius:1.8rem; padding:1.3rem; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
}
.pagination-row { display:flex; gap:.75rem; flex-wrap:wrap; align-items:center; justify-content:center; }
.page-btn {
  display:inline-flex; align-items:center; justify-content:center; min-width:3rem; height:3rem; padding:0 1rem;
  border-radius:1rem; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); font-weight:900;
}
.page-btn.active { background:linear-gradient(135deg, var(--primary), #fb7185); border-color:transparent; }
.directory-stats { display:grid; gap:1rem; grid-template-columns:repeat(4, minmax(0,1fr)); }
@media (max-width: 980px) {
  .servers-toolbar { grid-template-columns:1fr; }
  .directory-stats { grid-template-columns:repeat(2, minmax(0,1fr)); }
}
@media (max-width: 640px) {
  .directory-stats { grid-template-columns:1fr; }
}

.hidden { display: none !important; }
.desktop-nav { align-items: center; }
.nav-dropdown { position: relative; }
.nav-dropdown-summary {
  list-style: none;
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  cursor: pointer;
  padding: .8rem 1rem;
  border-radius: 1rem;
  background: rgba(255,255,255,.02);
  border: 1px solid transparent;
}
.nav-dropdown-summary::-webkit-details-marker { display: none; }
.nav-dropdown[open] .nav-dropdown-summary {
  color: white;
  border-color: rgba(255,255,255,.08);
  background: rgba(255,255,255,.05);
}
.nav-caret { opacity: .72; }
.nav-dropdown-menu {
  position: absolute;
  top: calc(100% + .65rem);
  left: 0;
  min-width: 250px;
  border-radius: 1.2rem;
  padding: .7rem;
  display: grid;
  gap: .35rem;
  z-index: 60;
}
.nav-dropdown-link {
  display: block;
  color: white;
  padding: .9rem 1rem;
  border-radius: .95rem;
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
}
.nav-dropdown-link:hover,
.nav-dropdown-link.active { background: rgba(239,68,68,.14); border-color: rgba(239,68,68,.24); }
.mobile-dropdown { border-radius: 1rem; }
.mobile-dropdown[open] .mobile-nav-link {
  border-color: rgba(239,68,68,.24);
  background: rgba(239,68,68,.08);
}
.mobile-dropdown-menu {
  display: grid;
  gap: .5rem;
  margin-top: .65rem;
  padding-left: .75rem;
}
.mobile-subnav-link {
  display: block;
  padding: .85rem 1rem;
  border-radius: .95rem;
  color: #e5e7eb;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
}
.mobile-subnav-link.active,
.mobile-subnav-link:hover { background: rgba(239,68,68,.12); border-color: rgba(239,68,68,.24); color: white; }
.nav-link {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .8rem 1rem;
  border-radius: 1rem;
  background: rgba(255,255,255,.02);
  border: 1px solid transparent;
}
.nav-link:hover,
.nav-link.active {
  color: white;
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.08);
}
.mobile-nav-link.active {
  background: rgba(239,68,68,.12);
  border-color: rgba(239,68,68,.24);
}
.people-grid,
.teams-grid { display: grid; gap: 1rem; }
.player-card,
.team-card {
  border-radius: 1.8rem;
  padding: 1.25rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}
.player-avatar {
  width: 4rem;
  height: 4rem;
  border-radius: 1.2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: 1.4rem;
  background: linear-gradient(135deg, rgba(239,68,68,.3), rgba(139,92,246,.3));
  border: 1px solid rgba(255,255,255,.1);
}
.info-grid-3 { display: grid; gap: 1rem; grid-template-columns: repeat(3, minmax(0,1fr)); }
.info-grid-2 { display: grid; gap: 1rem; grid-template-columns: repeat(2, minmax(0,1fr)); }
@media (max-width: 900px) {
  .info-grid-3,
  .info-grid-2 { grid-template-columns: 1fr; }
}


.desktop-nav-wrap,
.desktop-auth-wrap {
  display:flex;
  align-items:center;
}
.mobile-only {
  display:none;
}
@media (max-width: 1023px) {
  .desktop-nav-wrap,
  .desktop-auth-wrap {
    display:none !important;
  }
  .mobile-only {
    display:inline-flex !important;
  }
}
@media (min-width: 1024px) {
  .mobile-only {
    display:none !important;
  }
  .mobile-menu-panel {
    display:none !important;
  }
}

.admin-layout {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 1.25rem;
  align-items: start;
}
.admin-sidebar {
  position: sticky;
  top: 6.5rem;
}
.admin-sidebar-head {
  display: grid;
  gap: .45rem;
}
.admin-chip {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  border-radius: 9999px;
  padding: .45rem .8rem;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  color: #cbd5e1;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.admin-nav {
  display: grid;
  gap: .6rem;
}
.admin-nav-btn {
  width: 100%;
  display: flex;
  align-items: center;
  gap: .95rem;
  text-align: left;
  padding: 1rem 1rem;
  border-radius: 1.25rem;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.07);
  transition: .18s ease;
}
.admin-nav-btn:hover,
.admin-nav-btn.active {
  background: linear-gradient(135deg, rgba(239,68,68,.15), rgba(139,92,246,.15));
  border-color: rgba(239,68,68,.24);
  transform: translateY(-1px);
}
.admin-nav-icon {
  width: 2.8rem;
  height: 2.8rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 1rem;
  font-size: 1.25rem;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  flex: 0 0 auto;
}
.admin-nav-copy {
  display: grid;
  gap: .2rem;
}
.admin-nav-title {
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .02em;
  color: white;
}
.admin-nav-desc {
  color: #94a3b8;
  font-size: .82rem;
}
.admin-content { min-width: 0; }
.admin-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.admin-mini-card {
  border-radius: 1.5rem;
  padding: 1.2rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}
.admin-mini-label {
  color: #94a3b8;
  font-size: .72rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .18em;
}
.admin-mini-value {
  margin-top: .75rem;
  font-size: 2.1rem;
  font-weight: 900;
  letter-spacing: -.04em;
}
.admin-banner-card,
.admin-offer-card {
  border-radius: 1.7rem;
  padding: 1.35rem;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(135deg, rgba(239,68,68,.14), rgba(15,23,42,.7));
}
.admin-banner-card.alt { background: linear-gradient(135deg, rgba(139,92,246,.16), rgba(15,23,42,.7)); }
.admin-banner-card.alt-2 { background: linear-gradient(135deg, rgba(14,165,233,.16), rgba(15,23,42,.7)); }
.admin-banner-card.alt-3 { background: linear-gradient(135deg, rgba(34,197,94,.16), rgba(15,23,42,.7)); }
.admin-offer-card.premium { background: linear-gradient(135deg, rgba(239,68,68,.22), rgba(139,92,246,.22)); }
.admin-offer-card.alt { background: linear-gradient(135deg, rgba(250,204,21,.18), rgba(239,68,68,.18)); }
.admin-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.1rem;
  border-radius: 1.15rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  font-weight: 700;
}
.admin-toggle-row input {
  width: 1.15rem;
  height: 1.15rem;
  accent-color: #ef4444;
}
.admin-log-row {
  display: flex;
  align-items: center;
  gap: .85rem;
  padding: 1rem 1.1rem;
  border-radius: 1.15rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}
.admin-bar-track {
  width: 100%;
  height: .9rem;
  border-radius: 9999px;
  background: rgba(255,255,255,.05);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
}
.admin-bar-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(135deg, #ef4444, #8b5cf6);
}
@media (max-width: 1100px) {
  .admin-layout {
    grid-template-columns: 1fr;
  }
  .admin-sidebar {
    position: static;
  }
}

.hero-highlight-card {
  position: relative;
  overflow: hidden;
  border-radius: 2rem;
  min-height: 420px;
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: var(--shadow);
}
.hero-highlight-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(2,6,23,.05), rgba(2,6,23,.92));
}
.hero-highlight-content { position: relative; z-index: 1; height: 100%; padding: 1.5rem; display: flex; flex-direction: column; justify-content: space-between; }
.info-chip {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  border-radius: 9999px;
  padding: .45rem .8rem;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
}
.hero-cta-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .7rem;
  border-radius: 1.2rem;
  padding: 1.2rem 1.5rem;
  font-size: .92rem;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: white;
  background: linear-gradient(135deg, #ef4444, #f97316);
  box-shadow: 0 18px 40px rgba(239,68,68,.35);
  border: 1px solid rgba(255,255,255,.08);
}
.hero-cta-primary:hover { transform: translateY(-1px); }
.mega-stat {
  border-radius: 1.5rem;
  padding: 1.15rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}
.section-grid-3 { display: grid; gap: 1rem; grid-template-columns: repeat(3, minmax(0,1fr)); }
.section-grid-4 { display: grid; gap: 1rem; grid-template-columns: repeat(4, minmax(0,1fr)); }
.server-tile {
  overflow: hidden;
  border-radius: 1.7rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}
.server-tile-image { width: 100%; height: 200px; object-fit: cover; display: block; }
.server-tile-body { padding: 1.15rem; }
.server-meta-wrap { display: flex; flex-wrap: wrap; gap: .55rem; }
.vip-price-card {
  border-radius: 1.8rem;
  padding: 1.35rem;
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025));
  border: 1px solid rgba(255,255,255,.08);
}
.step-card, .blog-card, .mini-metric-card {
  border-radius: 1.5rem;
  padding: 1.15rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}
.blog-card { min-height: 100%; }
.server-directory-media {
  width: 100%;
  height: 180px;
  object-fit: cover;
  border-radius: 1.3rem;
}
.server-directory-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, minmax(0,1fr));
}
.detail-hero {
  position: relative;
  overflow: hidden;
  border-radius: 2rem;
  min-height: 340px;
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(255,255,255,.08);
}
.detail-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(2,6,23,.08), rgba(2,6,23,.94));
}
.detail-hero-content { position: relative; z-index: 1; padding: 1.5rem; min-height: 340px; display: flex; flex-direction: column; justify-content: space-between; }
.gallery-grid { display: grid; gap: 1rem; grid-template-columns: repeat(2, minmax(0,1fr)); }
.gallery-grid img { width: 100%; height: 220px; object-fit: cover; border-radius: 1.4rem; border: 1px solid rgba(255,255,255,.08); }

.server-address-copy {
  appearance: none;
  cursor: pointer;
  transition: transform .15s ease, border-color .15s ease, background .15s ease;
}
.server-address-copy:hover,
.server-address-copy:focus-visible,
.discord-open-link:hover,
.discord-open-link:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.22);
}
.server-address-inline {
  appearance: none;
  border: 0;
  background: transparent;
  padding: 0;
  color: #f8fafc;
  font: inherit;
  font-weight: 800;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: .18em;
}
.server-address-inline:hover,
.server-address-inline:focus-visible {
  color: #fca5a5;
}

.discord-badge {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  border-radius: 9999px;
  padding: .55rem .85rem;
  background: rgba(88,101,242,.16);
  color: #c7d2fe;
  border: 1px solid rgba(88,101,242,.26);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
@media (max-width: 1100px) {
  .section-grid-4, .server-directory-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 768px) {
  .section-grid-3, .section-grid-4, .server-directory-grid, .gallery-grid { grid-template-columns: 1fr; }
  .hero-highlight-card { min-height: 320px; }
}


.games-search-shell {
  border-radius: 1.7rem;
  padding: 1.15rem;
}
.games-search-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: minmax(0, 1.5fr) repeat(2, minmax(220px, .75fr));
  align-items: end;
}
.games-search-field {
  display: grid;
  gap: .6rem;
}
.games-search-field-wide {
  min-width: 0;
}
.games-search-label {
  color: #d8def0;
  font-size: .82rem;
  font-weight: 800;
}
.games-search-input {
  min-height: 3.45rem;
  border-radius: 1rem;
}
.results-toolbar-wide {
  width: min(100%, 320px);
  grid-template-columns: 1fr;
}
@media (max-width: 980px) {
  .games-search-grid {
    grid-template-columns: 1fr;
  }
  .results-toolbar-wide {
    width: 100%;
  }
}

.game-category-grid {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.game-category-cover {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .34;
  transform: scale(1.03);
}
.game-category-card {
  position: relative;
  overflow: hidden;
  min-height: 210px;
  width: 100%;
  text-align: left;
  border-radius: 1.7rem;
  padding: 1.15rem 1.15rem 1.25rem;
  border: 1px solid rgba(255,255,255,.1);
  background:
    radial-gradient(circle at 10% 10%, color-mix(in srgb, var(--theme-a) 78%, white 0%) 0%, transparent 55%),
    linear-gradient(135deg, var(--theme-a), var(--theme-b) 72%);
  box-shadow: var(--shadow);
}
.game-category-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(3,7,18,.14) 35%, rgba(2,6,23,.62) 100%);
  pointer-events: none;
}
.game-category-card.active {
  border-color: rgba(239,68,68,.45);
  box-shadow: 0 0 0 1px rgba(239,68,68,.25), var(--shadow);
}
.game-category-pill {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  padding: .38rem .7rem;
  border-radius: 9999px;
  border: 1px solid rgba(196,181,253,.28);
  background: rgba(139,92,246,.12);
  color: #ddd6fe;
  font-size: .68rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .14em;
}
.game-category-watermark {
  position: absolute;
  right: 1.35rem;
  top: 1.35rem;
  z-index: 1;
  font-size: clamp(3rem, 6vw, 5rem);
  line-height: .9;
  font-weight: 800;
  color: rgba(255,255,255,.3);
  pointer-events: none;
  user-select: none;
}
.game-category-content {
  position: relative;
  z-index: 1;
  display: flex;
  min-height: 150px;
  flex-direction: column;
  justify-content: space-between;
  padding-top: 1.4rem;
}
.game-category-title {
  max-width: 65%;
  font-size: clamp(1.7rem, 3vw, 2.2rem);
  line-height: .95;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: -.05em;
}
.game-category-copy {
  max-width: 72%;
  margin-top: .9rem;
  color: #dbe4f4;
  font-size: .98rem;
  line-height: 1.45;
}
.game-category-meta {
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 1rem;
  color: #dbe4f4;
  font-size: .76rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.results-toolbar {
  display: grid;
  gap: 1rem;
  grid-template-columns: minmax(0, 1fr) 260px;
  width: min(100%, 760px);
}
@media (max-width: 980px) {
  .game-category-grid { grid-template-columns: 1fr; }
  .results-toolbar { grid-template-columns: 1fr; width: 100%; }
  .game-category-watermark { font-size: clamp(2.8rem, 18vw, 4.5rem); }
  .game-category-title,
  .game-category-copy { max-width: 78%; }
}
@media (max-width: 640px) {
  .game-category-card { min-height: 220px; }
  .game-category-title,
  .game-category-copy { max-width: 100%; }
  .game-category-watermark {
    right: 1rem;
    top: 2.5rem;
    font-size: clamp(3rem, 20vw, 4.8rem);
  }
}


.server-vote-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem;
  border-radius: 1.2rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}
.server-vote-count {
  font-size: 1rem;
  font-weight: 900;
  letter-spacing: -.03em;
}
.server-vote-hint {
  margin-top: .25rem;
  color: #94a3b8;
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.server-vote-feedback {
  margin-top: .45rem;
  min-height: 1.1rem;
  color: #94a3b8;
  font-size: .82rem;
}
.server-vote-feedback.success { color: #86efac; }
.server-vote-feedback.error { color: #fca5a5; }
.server-vote-button[disabled] {
  opacity: .7;
  cursor: not-allowed;
}
.vote-hero-shell {
  max-width: 720px;
}
.vote-hero-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.1rem;
  border-radius: 1.35rem;
  background: rgba(2,6,23,.48);
  border: 1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(12px);
}
@media (max-width: 768px) {
  .server-vote-box,
  .vote-hero-card {
    flex-direction: column;
    align-items: stretch;
  }
  .server-vote-button {
    width: 100%;
  }
}


.social-auth-block { display:grid; gap:1rem; }
.social-divider { position:relative; text-align:center; color:#94a3b8; font-size:.75rem; font-weight:800; text-transform:uppercase; letter-spacing:.16em; }
.social-divider::before { content:''; position:absolute; top:50%; left:0; right:0; height:1px; background:rgba(148,163,184,.18); }
.social-divider span { position:relative; z-index:1; display:inline-block; padding:0 .9rem; background:rgba(5,8,16,.9); }
.social-auth-grid { display:grid; gap:.85rem; }
.social-auth-btn {
  display:flex; align-items:center; justify-content:center; gap:.8rem;
  min-height:3.5rem; border-radius:1rem; padding:.95rem 1rem;
  font-weight:900; letter-spacing:.04em; border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04); color:#fff; transition:transform .18s ease, border-color .18s ease, opacity .18s ease;
}
.social-auth-btn:hover { transform:translateY(-1px); border-color:rgba(255,255,255,.18); }
.social-auth-btn.social-auth-google { background:linear-gradient(135deg, rgba(37,99,235,.22), rgba(255,255,255,.06)); }
.social-auth-btn.social-auth-steam { background:linear-gradient(135deg, rgba(37,99,235,.26), rgba(15,23,42,.72)); }
.social-auth-btn.social-auth-discord { background:linear-gradient(135deg, rgba(139,92,246,.3), rgba(30,41,59,.72)); }
.social-auth-btn.social-auth-disabled { opacity:.55; cursor:not-allowed; }
.social-auth-feedback { color:#94a3b8; font-size:.86rem; }
