/* ═══════════════════════════════════════════════
   7DTD SERVER LIST — Dark Gaming Theme
   Fonts: Barlow Condensed (headings) + Barlow (body) + JetBrains Mono
   ═══════════════════════════════════════════════ */

:root {
  --bg:        #111318;
  --bg-2:      #181b22;
  --bg-3:      #1e2229;
  --bg-4:      #252a34;
  --bg-5:      #2d3340;

  --border:    rgba(255,255,255,0.06);
  --border-2:  rgba(255,255,255,0.10);

  --tx-1:      #eef0f5;
  --tx-2:      #9aa0b0;
  --tx-3:      #5a6070;
  --tx-4:      #363c4a;

  /* Orange fire accent */
  --ac:        #f07020;
  --ac-2:      #ff8c40;
  --ac-dim:    rgba(240,112,32,0.12);
  --ac-glow:   rgba(240,112,32,0.35);

  /* Status */
  --green:     #30d070;
  --green-dim: rgba(48,208,112,0.10);
  --red:       #e04040;
  --red-dim:   rgba(224,64,64,0.12);
  --yellow:    #e0b030;
  --yellow-dim:rgba(224,176,48,0.12);
  --blue:      #4080e0;

  --font-head: 'Barlow Condensed', sans-serif;
  --font-body: 'Barlow', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;

  --r:   6px;
  --r-lg:10px;
  --t:   0.15s ease;
}

/* ── Base ──────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--tx-1);
  min-height: 100vh;
  font-size: 14px;
  line-height: 1.5;
  overflow-x: hidden;
}
a { color: var(--ac); text-decoration: none; }
a:hover { color: var(--ac-2); }
button { cursor: pointer; font-family: inherit; border: none; background: none; }

/* ── Background mesh ────────────────────────────── */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 0;
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -10%, rgba(240,112,32,0.07), transparent),
    linear-gradient(rgba(255,255,255,.015) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.015) 1px, transparent 1px);
  background-size: 100% 100%, 60px 60px, 60px 60px;
  pointer-events: none;
}
.container-xl, nav, footer, .hero-bar, .filter-bar { position: relative; z-index: 1; }

/* ══════════════════════════════════════════════════
   NAVBAR
   ══════════════════════════════════════════════════ */
.site-nav {
  background: rgba(14,16,20,0.95);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 1px 0 rgba(240,112,32,0.25);
}
.nav-inner {
  display: flex;
  align-items: center;
  height: 58px;
  gap: 6px;
}

/* Brand */
.brand { display: flex; align-items: center; gap: 9px; text-decoration: none; margin-right: 20px; flex-shrink: 0; }
.brand-mark {
  width: 32px; height: 32px;
  background: var(--ac);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-head);
  font-size: .75rem; font-weight: 900;
  color: #fff;
  border-radius: 5px;
  box-shadow: 0 0 16px var(--ac-glow);
}
.brand-name {
  font-family: var(--font-head);
  font-size: 1.25rem; font-weight: 800;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--tx-1);
}
.brand-accent { color: var(--ac); }

/* Nav links */
.nav-links { display: flex; gap: 2px; }
.nav-lnk {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 12px;
  border-radius: var(--r);
  font-family: var(--font-head);
  font-size: .82rem; font-weight: 600; letter-spacing: .8px; text-transform: uppercase;
  color: var(--tx-2);
  transition: all var(--t);
  text-decoration: none;
}
.nav-lnk:hover { color: var(--tx-1); background: var(--bg-4); }
.nav-lnk.active { color: var(--ac); background: var(--ac-dim); }
.nav-admin { color: var(--yellow) !important; }
.nav-admin:hover { background: var(--yellow-dim) !important; }

/* Auth area */
.nav-auth { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.user-pill { display: flex; align-items: center; gap: 7px; }
.user-av { width: 28px; height: 28px; border-radius: 50%; border: 2px solid var(--ac); }
.user-nm { font-family: var(--font-head); font-size: .85rem; font-weight: 600; color: var(--tx-1); }
.btn-icon { color: var(--tx-2); font-size: 1.1rem; padding: 4px 6px; border-radius: var(--r); transition: all var(--t); }
.btn-icon:hover { color: var(--tx-1); background: var(--bg-4); }
.btn-steam-nav {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 14px;
  background: #1b2838;
  color: #c6d4df;
  border: 1px solid #2a475e;
  border-radius: var(--r);
  font-family: var(--font-head);
  font-size: .8rem; font-weight: 700; letter-spacing: .6px; text-transform: uppercase;
  transition: all var(--t);
}
.btn-steam-nav:hover { background: #2a475e; color: #fff; }

/* ══════════════════════════════════════════════════
   HERO BAR
   ══════════════════════════════════════════════════ */
.hero-bar {
  background: linear-gradient(135deg, var(--bg-2) 0%, var(--bg-3) 100%);
  border-bottom: 1px solid var(--border);
  padding: 28px 0 24px;
}
.hero-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.hero-title {
  font-family: var(--font-head);
  font-size: 2.2rem; font-weight: 900;
  letter-spacing: 1.5px; text-transform: uppercase;
  line-height: 1.05;
  color: var(--tx-1);
}
.hero-accent { color: var(--ac); }
.hero-sub { font-size: .82rem; color: var(--tx-2); margin-top: 6px; }

/* Stats */
.hero-stats {
  display: flex;
  align-items: center;
  gap: 0;
  background: var(--bg-4);
  border: 1px solid var(--border-2);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.hstat { padding: 12px 24px; text-align: center; }
.hstat-div { width: 1px; background: var(--border-2); align-self: stretch; }
.hstat-n {
  font-family: var(--font-head);
  font-size: 2rem; font-weight: 900;
  color: var(--tx-1);
  line-height: 1;
  letter-spacing: -.5px;
}
.hstat-n.online { color: var(--green); text-shadow: 0 0 20px rgba(48,208,112,0.4); }
.hstat-l {
  font-family: var(--font-head);
  font-size: .65rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--tx-3);
  margin-top: 1px;
}

/* ══════════════════════════════════════════════════
   FILTER BAR
   ══════════════════════════════════════════════════ */
.filter-bar {
  background: rgba(20,23,30,0.97);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  top: 0;
  z-index: 100;
}
.filter-inner {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 0;
  flex-wrap: wrap;
}

/* Search */
.search-group { display: flex; align-items: center; position: relative; }
.search-ico { position: absolute; left: 10px; color: var(--tx-3); font-size: .85rem; pointer-events: none; }
.search-inp {
  padding: 7px 10px 7px 32px;
  background: var(--bg-4);
  border: 1px solid var(--border-2);
  border-radius: var(--r) 0 0 var(--r);
  color: var(--tx-1);
  font-size: .82rem;
  width: 210px;
  transition: border-color var(--t);
}
.search-inp:focus { outline: none; border-color: var(--ac); }
.search-inp::placeholder { color: var(--tx-3); }
.search-btn {
  padding: 7px 13px;
  background: var(--ac);
  color: #fff;
  border-radius: 0 var(--r) var(--r) 0;
  font-family: var(--font-head);
  font-size: .78rem; font-weight: 700; letter-spacing: .6px; text-transform: uppercase;
  transition: background var(--t);
  border: none; cursor: pointer;
}
.search-btn:hover { background: var(--ac-2); }

.filter-divider { width: 1px; height: 22px; background: var(--border-2); flex-shrink: 0; }
.filter-seg { display: flex; align-items: center; gap: 2px; }
.filter-lbl {
  font-family: var(--font-head);
  font-size: .65rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.2px;
  color: var(--tx-4);
  margin-right: 4px;
}

/* Pills */
.fpill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px;
  border-radius: 20px;
  font-family: var(--font-head);
  font-size: .76rem; font-weight: 700; letter-spacing: .5px; text-transform: uppercase;
  color: var(--tx-3);
  background: transparent;
  border: 1px solid transparent;
  transition: all var(--t);
  text-decoration: none;
}
.fpill:hover { color: var(--tx-1); background: var(--bg-5); }
.fpill.on { color: var(--tx-1); background: var(--bg-5); border-color: var(--border-2); }
.fpill-pvp.on { color: #ff6060; border-color: rgba(224,64,64,.4); }
.fpill-pve.on { color: var(--green); border-color: rgba(48,208,112,.4); }
.fpill-live.on { color: var(--green); border-color: rgba(48,208,112,.4); }

.live-dot {
  display: inline-block; width: 6px; height: 6px;
  border-radius: 50%; background: var(--green);
  animation: pulse 2s infinite;
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.7)} }

.btn-add {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 7px 14px;
  background: var(--ac);
  color: #fff !important;
  border-radius: var(--r);
  font-family: var(--font-head);
  font-size: .8rem; font-weight: 700; letter-spacing: .6px; text-transform: uppercase;
  transition: all var(--t);
  text-decoration: none;
}
.btn-add:hover { background: var(--ac-2); box-shadow: 0 0 16px var(--ac-glow); transform: translateY(-1px); }

/* ══════════════════════════════════════════════════
   SERVER LIST META
   ══════════════════════════════════════════════════ */
.list-meta { display: flex; justify-content: space-between; align-items: center; }
.list-count { font-family: var(--font-mono); font-size: .72rem; color: var(--tx-3); }

/* ══════════════════════════════════════════════════
   SERVER CARD
   ══════════════════════════════════════════════════ */
.slist { display: flex; flex-direction: column; gap: 6px; }

.scard {
  display: grid;
  grid-template-columns: 52px 14px auto 1fr 110px;
  align-items: center;
  gap: 0;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: all var(--t);
  position: relative;
}
.scard::after {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--border-2);
  transition: background var(--t);
}
.scard:hover {
  background: var(--bg-3);
  border-color: var(--border-2);
  transform: translateX(2px);
  box-shadow: -3px 0 0 var(--ac), 0 4px 24px rgba(0,0,0,0.3);
}
.scard:hover::after { background: var(--ac); }
.scard.scard-offline { opacity: .55; }

/* Rank col */
.scard-rank {
  display: flex; align-items: center; justify-content: center;
  padding: 0 10px;
  height: 100%;
}
.rank-badge {
  font-family: var(--font-head);
  font-size: .8rem; font-weight: 900;
  padding: 3px 7px;
  border-radius: var(--r);
  text-align: center;
}
.rank-gold   { background: rgba(224,176,48,.15);  color: #d4a020; border: 1px solid rgba(224,176,48,.3);  }
.rank-silver { background: rgba(160,168,180,.1);  color: #8898aa; border: 1px solid rgba(160,168,180,.25); }
.rank-bronze { background: rgba(180,100,40,.12);  color: #a05828; border: 1px solid rgba(180,100,40,.28); }
.rank-num { font-family: var(--font-mono); font-size: .72rem; color: var(--tx-4); }

/* Dot col */
.scard-dot { padding: 0 4px; display: flex; align-items: center; }
.sdot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.sdot-on { background: var(--green); box-shadow: 0 0 6px var(--green); }
.sdot-off { background: var(--tx-4); }

/* Banner col */
.scard-banner {
  width: 120px;
  height: 100%;
  flex-shrink: 0;
  overflow: hidden;
  border-right: 1px solid var(--border);
}
.scard-banner img,
.scard-banner video {
  width: 120px;
  height: 68px;
  object-fit: cover;
  display: block;
}

/* Info col */
.scard-info { padding: 12px 14px; min-width: 0; }
.scard-name {
  display: block;
  font-family: var(--font-head);
  font-size: 1rem; font-weight: 800; letter-spacing: .3px;
  color: var(--tx-1);
  margin-bottom: 4px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  transition: color var(--t);
  text-decoration: none;
}
.scard-name:hover { color: var(--ac); }
.scard-meta { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 6px; }
.smeta-item { display: inline-flex; align-items: center; gap: 4px; font-size: .74rem; color: var(--tx-2); }
.smeta-item i { font-size: .68rem; color: var(--tx-3); }
.smeta-addr { font-family: var(--font-mono); font-size: .68rem; }
.smeta-ver { font-family: var(--font-mono); }

/* Tags */
.scard-tags { display: flex; flex-wrap: wrap; gap: 4px; }
.stag {
  display: inline-flex; align-items: center;
  padding: 1px 7px;
  border-radius: 20px;
  font-family: var(--font-head);
  font-size: .68rem; font-weight: 700; letter-spacing: .5px; text-transform: uppercase;
}
.stag-pvp     { background: var(--red-dim);    color: #ff7070; border: 1px solid rgba(224,64,64,.3);    }
.stag-pve     { background: var(--green-dim);   color: var(--green); border: 1px solid rgba(48,208,112,.3); }
.stag-mod     { background: rgba(140,80,220,.1); color: #a070e0; border: 1px solid rgba(140,80,220,.3); }
.stag-van     { background: rgba(64,128,224,.1); color: #6090e0; border: 1px solid rgba(64,128,224,.3); }
.stag-generic { background: var(--bg-5); color: var(--tx-2); border: 1px solid var(--border-2); }

/* Vote col */
.scard-vote {
  display: flex; flex-direction: column; align-items: center;
  gap: 6px;
  padding: 12px 16px;
  border-left: 1px solid var(--border);
  background: var(--bg-3);
  height: 100%;
  justify-content: center;
}
.vote-count {
  font-family: var(--font-head);
  font-size: 1.5rem; font-weight: 900;
  color: var(--tx-1);
  line-height: 1;
  text-align: center;
}
.vote-word {
  display: block;
  font-size: .6rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1px;
  color: var(--tx-3);
  font-family: var(--font-head);
}
.vote-btn {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 5px 12px;
  background: var(--ac-dim);
  color: var(--ac);
  border: 1px solid rgba(240,112,32,.3);
  border-radius: 20px;
  font-family: var(--font-head);
  font-size: .75rem; font-weight: 700; letter-spacing: .5px; text-transform: uppercase;
  transition: all var(--t);
  cursor: pointer;
  text-decoration: none;
}
.vote-btn:hover { background: var(--ac); color: #fff; box-shadow: 0 0 14px var(--ac-glow); }
.vote-btn.voted { background: var(--green-dim); color: var(--green); border-color: rgba(48,208,112,.3); cursor: default; }
.vote-btn-steam { background: rgba(27,40,56,.5); color: #8ca8c0; border-color: #2a475e; }
.vote-btn-steam:hover { background: #2a475e; color: #fff; box-shadow: none; }

/* ── Empty state ─────────────────────────────────── */
.empty-state { text-align: center; padding: 4rem 2rem; }
.empty-state i { font-size: 3rem; color: var(--tx-4); display: block; margin-bottom: 1rem; }
.empty-title { font-family: var(--font-head); font-size: 1.1rem; font-weight: 700; color: var(--tx-2); margin-bottom: .4rem; }
.empty-sub { font-size: .85rem; color: var(--tx-3); }
.empty-sub a { color: var(--ac); }

/* ── Pagination ──────────────────────────────────── */
.pagination-custom { display: flex; gap: 4px; list-style: none; padding: 0; margin: 0; }
.pagination-custom li a {
  display: flex; align-items: center; justify-content: center;
  min-width: 36px; height: 36px; padding: 0 8px;
  background: var(--bg-3);
  border: 1px solid var(--border-2);
  border-radius: var(--r);
  color: var(--tx-2);
  font-family: var(--font-head);
  font-size: .82rem; font-weight: 700;
  transition: all var(--t);
  text-decoration: none;
}
.pagination-custom li a:hover { border-color: var(--ac); color: var(--ac); }
.pagination-custom li a.active { background: var(--ac); border-color: var(--ac); color: #fff; }

/* ══════════════════════════════════════════════════
   SERVER DETAIL PAGE
   ══════════════════════════════════════════════════ */
.sdetail-wrap { max-width: 1180px; margin: 0 auto; padding: 24px 20px 60px; }
.sdetail-grid { display: grid; grid-template-columns: 1fr 300px; gap: 20px; }

.sd-banner { border-radius: var(--r-lg); overflow: hidden; margin-bottom: 14px; border: 1px solid var(--border); }
.sd-banner img, .sd-banner video { width: 100%; display: block; }

.sd-status { display: flex; align-items: center; gap: 8px; font-size: .75rem; color: var(--tx-2); font-family: var(--font-mono); margin-bottom: 6px; }
.sd-name { font-family: var(--font-head); font-size: 1.8rem; font-weight: 900; letter-spacing: 1px; text-transform: uppercase; line-height: 1.1; margin-bottom: 8px; }
.sd-tags { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 12px; }

.sd-stats-grid {
  display: grid; grid-template-columns: repeat(4,1fr);
  background: var(--border); gap: 1px;
  border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; margin-bottom: 16px;
}
.sd-stat { background: var(--bg-2); padding: 14px; text-align: center; }
.sd-stat-n { font-family: var(--font-head); font-size: 1.5rem; font-weight: 900; color: var(--ac); line-height: 1; display: block; margin-bottom: 2px; }
.sd-stat-l { font-family: var(--font-head); font-size: .62rem; text-transform: uppercase; letter-spacing: 1.2px; color: var(--tx-3); font-weight: 700; }

.info-block { background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--r-lg); margin-bottom: 12px; overflow: hidden; }
.info-block-title { padding: 9px 14px; background: var(--bg-4); border-bottom: 1px solid var(--border); font-family: var(--font-head); font-size: .68rem; text-transform: uppercase; letter-spacing: 1.8px; color: var(--tx-2); font-weight: 700; }
.info-block-body { padding: 14px; }

.config-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--border); }
.cfg-item { background: var(--bg-2); padding: 10px 13px; }
.cfg-key { font-family: var(--font-head); font-size: .62rem; text-transform: uppercase; letter-spacing: .8px; color: var(--tx-3); margin-bottom: 3px; font-weight: 700; }
.cfg-val { font-size: .85rem; font-weight: 600; color: var(--tx-1); font-family: var(--font-mono); }
.cfg-val.on-val { color: var(--green); }
.cfg-val.off-val { color: var(--red); }

.player-list { display: grid; grid-template-columns: repeat(2,1fr); gap: 4px; }
.player-item { display: flex; align-items: center; gap: 8px; padding: 6px 10px; background: var(--bg-4); border-radius: var(--r); font-size: .8rem; }
.player-score { font-family: var(--font-mono); font-size: .7rem; color: var(--tx-3); margin-left: auto; }

.uptime-bar { display: flex; gap: 2px; height: 28px; align-items: flex-end; }
.ub-seg { flex: 1; min-width: 3px; border-radius: 2px 2px 0 0; transition: opacity var(--t); }
.ub-seg:hover { opacity: .8; }

.conn-box { background: var(--bg-4); border: 1px solid var(--border); border-radius: var(--r); padding: 12px; margin-bottom: 10px; }
.conn-row { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.conn-lbl { font-family: var(--font-head); font-size: .65rem; text-transform: uppercase; letter-spacing: .8px; color: var(--tx-3); min-width: 60px; font-weight: 700; }
.conn-val { font-family: var(--font-mono); font-size: .88rem; color: var(--tx-1); flex: 1; }
.btn-copy { padding: 3px 8px; background: var(--bg-5); border: 1px solid var(--border-2); border-radius: var(--r); color: var(--tx-3); font-size: .75rem; cursor: pointer; transition: all var(--t); }
.btn-copy:hover { color: var(--ac); border-color: var(--ac); }
.conn-tip { font-size: .75rem; color: var(--tx-3); line-height: 1.6; }
.conn-tip strong { color: var(--tx-2); }

/* Sidebar */
.sd-sidebar { display: flex; flex-direction: column; gap: 12px; }
.vote-card { background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 18px; text-align: center; }
.vc-nums { display: flex; justify-content: center; gap: 20px; margin-bottom: 14px; }
.vc-total .vn { font-family: var(--font-head); font-size: 2.4rem; font-weight: 900; color: var(--ac); line-height: 1; display: block; }
.vc-monthly .vn { font-family: var(--font-head); font-size: 1.4rem; font-weight: 700; color: var(--tx-2); line-height: 1; display: block; }
.vl { font-family: var(--font-head); font-size: .6rem; text-transform: uppercase; letter-spacing: 1.2px; color: var(--tx-3); margin-top: 2px; font-weight: 700; }
.bvote-main {
  display: flex; align-items: center; justify-content: center; gap: 7px;
  width: 100%; padding: 11px;
  background: var(--ac); color: #fff;
  border: none; border-radius: var(--r);
  font-family: var(--font-head); font-size: .88rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1px;
  cursor: pointer; transition: all var(--t);
}
.bvote-main:hover:not(:disabled) { background: var(--ac-2); box-shadow: 0 0 20px var(--ac-glow); transform: translateY(-1px); }
.bvote-main.voted { background: var(--green-dim); color: var(--green); border: 1px solid rgba(48,208,112,.3); cursor: default; }
.bvote-main:disabled { opacity: .6; cursor: not-allowed; }
.vnote { font-size: .7rem; color: var(--tx-3); margin-top: 6px; font-family: var(--font-head); }

.sc { background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 14px; }
.sc-title { font-family: var(--font-head); font-size: .66rem; text-transform: uppercase; letter-spacing: 1.8px; color: var(--tx-3); font-weight: 700; margin-bottom: 10px; }
.sc-rows { display: flex; flex-direction: column; gap: 6px; }
.sc-row { display: flex; justify-content: space-between; align-items: center; font-size: .8rem; }
.sc-key { color: var(--tx-3); }
.sc-val { color: var(--tx-2); text-align: right; display: flex; align-items: center; gap: 4px; }

/* ══════════════════════════════════════════════════
   FORMS
   ══════════════════════════════════════════════════ */
.form-page { max-width: 720px; margin: 0 auto; padding: 24px 20px 60px; }
.form-card { background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.form-head { padding: 20px 24px; background: linear-gradient(135deg, var(--bg-4), var(--bg-3)); border-bottom: 1px solid var(--border); }
.form-head h1 { font-family: var(--font-head); font-size: 1.4rem; font-weight: 900; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 3px; }
.form-head p { font-size: .83rem; color: var(--tx-2); }
.form-body { padding: 22px 24px; }
.fsec { margin-bottom: 22px; }
.fsec-title { font-family: var(--font-head); font-size: .68rem; text-transform: uppercase; letter-spacing: 1.8px; color: var(--tx-3); font-weight: 700; margin-bottom: 12px; padding-bottom: 7px; border-bottom: 1px solid var(--border); }
.fg { display: flex; flex-direction: column; gap: 5px; margin-bottom: 10px; }
.fg-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.fg-sm { max-width: 110px; }
label.lbl { font-family: var(--font-head); font-size: .72rem; font-weight: 700; color: var(--tx-2); text-transform: uppercase; letter-spacing: .5px; }
.hint { font-weight: 400; color: var(--tx-3); text-transform: none; letter-spacing: 0; }
.req { color: var(--ac); }
.finp, .fsel, .ftxt {
  padding: 8px 11px;
  background: var(--bg-4);
  border: 1px solid var(--border-2);
  border-radius: var(--r);
  color: var(--tx-1);
  font-size: .83rem;
  transition: border-color var(--t);
  font-family: var(--font-body);
}
.finp:focus, .fsel:focus, .ftxt:focus { outline: none; border-color: var(--ac); box-shadow: 0 0 0 3px var(--ac-dim); }
.finp::placeholder, .ftxt::placeholder { color: var(--tx-3); }
.finp[readonly] { opacity: .5; cursor: not-allowed; }
.fsel { appearance: none; cursor: pointer; }
.ftxt { resize: vertical; min-height: 80px; }
.fcheck-group { display: flex; flex-direction: column; gap: 8px; }
.fcheck { display: flex; align-items: center; gap: 8px; cursor: pointer; font-size: .83rem; color: var(--tx-2); }
.fcheck input { display: none; }
.fcheck-box { width: 16px; height: 16px; border: 1px solid var(--border-2); border-radius: 3px; background: var(--bg-4); position: relative; transition: all var(--t); flex-shrink: 0; }
.fcheck input:checked + .fcheck-box { background: var(--ac); border-color: var(--ac); }
.fcheck input:checked + .fcheck-box::after { content: '✓'; position: absolute; top: -1px; left: 2px; font-size: 10px; color: #fff; font-weight: 900; }
.tag-sugg { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px; }
.tag-sugg-lbl { font-size: .68rem; color: var(--tx-3); width: 100%; }
.tag-s { cursor: pointer; transition: all var(--t); }
.tag-s:hover { background: var(--bg-5); color: var(--tx-1); }
.form-actions { display: flex; justify-content: flex-end; gap: 8px; padding-top: 16px; border-top: 1px solid var(--border); }

/* Banner upload */
.banner-upload-area {
  border: 2px dashed var(--border-2);
  border-radius: var(--r-lg);
  padding: 20px;
  text-align: center;
  background: var(--bg-4);
  transition: all var(--t);
  cursor: pointer;
}
.banner-upload-area:hover { border-color: var(--ac); background: var(--ac-dim); }
.banner-upload-area i { font-size: 1.6rem; color: var(--tx-3); display: block; margin-bottom: 6px; }
.banner-upload-area p { font-size: .78rem; color: var(--tx-2); }
.banner-upload-area small { font-size: .68rem; color: var(--tx-3); }
.banner-preview { margin-top: 10px; border: 1px solid var(--border-2); border-radius: var(--r); overflow: hidden; }
.banner-preview img, .banner-preview video { width: 468px; height: 60px; object-fit: cover; display: block; max-width: 100%; }

/* ══════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════ */
.btn { display: inline-flex; align-items: center; gap: 5px; padding: 7px 14px; border-radius: var(--r); font-family: var(--font-head); font-size: .8rem; font-weight: 700; letter-spacing: .6px; text-transform: uppercase; transition: all var(--t); cursor: pointer; border: none; text-decoration: none; }
.btn-primary { background: var(--ac); color: #fff; }
.btn-primary:hover { background: var(--ac-2); color: #fff; box-shadow: 0 0 16px var(--ac-glow); }
.btn-ghost { background: transparent; color: var(--tx-2); border: 1px solid var(--border-2); }
.btn-ghost:hover { background: var(--bg-4); color: var(--tx-1); }
.btn-danger { background: var(--red-dim); color: #ff7070; border: 1px solid rgba(224,64,64,.3); }
.btn-danger:hover { background: var(--red); color: #fff; }
.btn-warn { background: var(--yellow-dim); color: var(--yellow); border: 1px solid rgba(224,176,48,.3); }
.btn-warn:hover { background: var(--yellow); color: #000; }
.btn-sm { padding: 3px 9px; font-size: .74rem; }
.btn-lg { padding: 10px 22px; font-size: .86rem; }
.btn-full { width: 100%; justify-content: center; }
.btn-steam { display: inline-flex; align-items: center; gap: 7px; padding: 7px 14px; border-radius: var(--r); background: #1b2838; color: #c6d4df; font-family: var(--font-head); font-size: .8rem; font-weight: 700; letter-spacing: .6px; text-transform: uppercase; border: 1px solid #2a475e; transition: all var(--t); }
.btn-steam:hover { background: #2a475e; color: #fff; }
.steam-icon { width: 15px; height: 15px; }

/* ══════════════════════════════════════════════════
   TAGS
   ══════════════════════════════════════════════════ */
.tag { display: inline-flex; align-items: center; gap: 3px; padding: 1px 7px; border-radius: 20px; font-family: var(--font-head); font-size: .68rem; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; }
.t-pvp { background: var(--red-dim); color: #ff7070; border: 1px solid rgba(224,64,64,.3); }
.t-pve { background: var(--green-dim); color: var(--green); border: 1px solid rgba(48,208,112,.3); }
.t-mod { background: rgba(140,80,220,.1); color: #a070e0; border: 1px solid rgba(140,80,220,.3); }
.t-van { background: rgba(64,128,224,.1); color: #6090e0; border: 1px solid rgba(64,128,224,.3); }
.t-lock { background: var(--yellow-dim); color: var(--yellow); border: 1px solid rgba(224,176,48,.3); }
.t-custom { background: var(--bg-4); color: var(--tx-2); border: 1px solid var(--border-2); }

/* ══════════════════════════════════════════════════
   STATUS DOTS
   ══════════════════════════════════════════════════ */
.dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.dot.on { background: var(--green); box-shadow: 0 0 5px var(--green); }
.dot.off { background: var(--tx-4); }
.dot-lg { width: 10px; height: 10px; }
.dot-lg.on { background: var(--green); box-shadow: 0 0 7px var(--green); }
.dot-lg.off { background: var(--red); }

/* ══════════════════════════════════════════════════
   PROFILE
   ══════════════════════════════════════════════════ */
.prof-wrap { max-width: 960px; margin: 0 auto; padding: 24px 20px 60px; }
.prof-head { display: flex; align-items: center; gap: 14px; padding: 18px; background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--r-lg); margin-bottom: 16px; }
.prof-av { width: 60px; height: 60px; border-radius: 50%; border: 3px solid var(--ac); box-shadow: 0 0 20px var(--ac-glow); }
.prof-name { font-family: var(--font-head); font-size: 1.4rem; font-weight: 900; letter-spacing: .5px; text-transform: uppercase; margin-bottom: 3px; }
.prof-meta { display: flex; gap: 14px; font-size: .75rem; color: var(--tx-3); font-family: var(--font-head); }
.prof-grid { display: grid; grid-template-columns: 3fr 2fr; gap: 14px; }
.prof-sec { background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.prof-sec-h { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; background: var(--bg-4); border-bottom: 1px solid var(--border); }
.prof-sec-h h3 { font-family: var(--font-head); font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .8px; color: var(--tx-2); }
.msrow { display: grid; grid-template-columns: 14px 1fr auto auto; align-items: center; gap: 8px; padding: 8px 14px; border-bottom: 1px solid var(--border); transition: background var(--t); }
.msrow:last-child { border-bottom: none; }
.msrow:hover { background: var(--bg-3); }
.msrow-n { font-family: var(--font-head); font-weight: 700; font-size: .84rem; }.msrow-n:hover { color: var(--ac); }
.msrow-ip { font-family: var(--font-mono); font-size: .65rem; color: var(--tx-4); }
.msrow-s { display: flex; gap: 8px; font-size: .73rem; color: var(--tx-3); }
.msrow-s i { color: var(--ac); }
.vhrow { display: flex; justify-content: space-between; align-items: center; padding: 7px 14px; border-bottom: 1px solid var(--border); transition: background var(--t); }
.vhrow:last-child { border-bottom: none; }
.vhrow:hover { background: var(--bg-3); }
.vhrow a { font-size: .82rem; color: var(--tx-2); }.vhrow a:hover { color: var(--ac); }
.vhrow-d { font-size: .68rem; color: var(--tx-4); font-family: var(--font-mono); }

/* ══════════════════════════════════════════════════
   ADMIN
   ══════════════════════════════════════════════════ */
.adm-wrap { max-width: 1280px; margin: 0 auto; padding: 24px 20px 60px; }
.adm-title { font-family: var(--font-head); font-size: 1.4rem; font-weight: 900; letter-spacing: 1px; text-transform: uppercase; display: flex; align-items: center; gap: 8px; margin-bottom: 20px; }
.adm-badge { font-family: var(--font-head); font-size: .6rem; padding: 2px 7px; border-radius: 3px; font-weight: 700; letter-spacing: 1.5px; background: var(--yellow-dim); color: var(--yellow); border: 1px solid rgba(224,176,48,.3); text-transform: uppercase; }
.adm-stats { display: grid; grid-template-columns: repeat(5,1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; margin-bottom: 20px; }
.adm-stat { background: var(--bg-2); padding: 14px; }
.adm-stat-l { font-family: var(--font-head); font-size: .62rem; text-transform: uppercase; letter-spacing: 1.2px; color: var(--tx-3); margin-bottom: 4px; font-weight: 700; }
.adm-stat-n { font-family: var(--font-head); font-size: 1.7rem; font-weight: 900; line-height: 1; color: var(--ac); }
.adm-stat-s { font-size: .68rem; color: var(--tx-3); margin-top: 2px; }
.adm-tabs { display: flex; gap: 0; margin-bottom: 14px; border-bottom: 1px solid var(--border); }
.adm-tab { padding: 7px 16px; font-family: var(--font-head); font-size: .76rem; font-weight: 700; text-transform: uppercase; letter-spacing: .8px; color: var(--tx-3); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: all var(--t); display: inline-flex; align-items: center; gap: 5px; text-decoration: none; }
.adm-tab:hover { color: var(--tx-1); }
.adm-tab.on { color: var(--ac); border-bottom-color: var(--ac); }
.adm-sec { display: none; }
.adm-sec.on { display: block; }
.adm-card { background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.adm-card-h { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; background: var(--bg-4); border-bottom: 1px solid var(--border); }
.adm-card-t { font-family: var(--font-head); font-size: .73rem; font-weight: 700; text-transform: uppercase; letter-spacing: .8px; color: var(--tx-2); }
.adm-srch { padding: 6px 9px; background: var(--bg-5); border: 1px solid var(--border-2); border-radius: var(--r); color: var(--tx-1); font-size: .78rem; width: 220px; }
.adm-srch:focus { outline: none; border-color: var(--ac); }
.tbl { width: 100%; border-collapse: collapse; font-size: .78rem; }
.tbl th { text-align: left; padding: 8px 12px; background: var(--bg-4); font-family: var(--font-head); font-size: .63rem; text-transform: uppercase; letter-spacing: 1.2px; color: var(--tx-3); border-bottom: 1px solid var(--border); white-space: nowrap; font-weight: 700; }
.tbl td { padding: 9px 12px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.tbl tbody tr { transition: background var(--t); }
.tbl tbody tr:hover { background: var(--bg-3); }
.tbl tbody tr:last-child td { border-bottom: none; }
.tbl-sname { font-family: var(--font-head); font-weight: 700; color: var(--tx-1); font-size: .88rem; }
.tbl-sname a { color: var(--tx-1); }.tbl-sname a:hover { color: var(--ac); }
.tbl-ip { font-family: var(--font-mono); font-size: .7rem; color: var(--tx-3); }
.tbl-votes { font-family: var(--font-head); font-weight: 900; font-size: .95rem; color: var(--ac); }
.tbl-acts { display: flex; gap: 3px; flex-wrap: wrap; }
.rbadge { font-family: var(--font-head); padding: 1px 6px; border-radius: 3px; font-size: .62rem; font-weight: 700; letter-spacing: .4px; text-transform: uppercase; }
.rbadge.admin { background: var(--yellow-dim); color: var(--yellow); border: 1px solid rgba(224,176,48,.3); }
.rbadge.user { background: var(--bg-4); color: var(--tx-3); border: 1px solid var(--border-2); }
.urow-av { width: 24px; height: 24px; border-radius: 50%; border: 1px solid var(--border); }
.crawler-card { background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 16px; margin-bottom: 14px; }
.crawler-status { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.cr-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 6px var(--green); }
.cr-dot.idle { background: var(--tx-4); box-shadow: none; }
.cr-info { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; margin-bottom: 12px; }
.cr-info-item label { font-family: var(--font-head); font-size: .63rem; text-transform: uppercase; letter-spacing: .8px; color: var(--tx-3); display: block; margin-bottom: 2px; font-weight: 700; }
.cr-info-item span { font-family: var(--font-head); font-size: 1rem; font-weight: 900; color: var(--ac); }

/* ══════════════════════════════════════════════════
   ALERTS / TOASTS
   ══════════════════════════════════════════════════ */
.alert { padding: 9px 13px; border-radius: var(--r); font-size: .8rem; margin-bottom: 12px; display: flex; align-items: center; gap: 7px; }
.alert-ok { background: var(--green-dim); color: var(--green); border: 1px solid rgba(48,208,112,.25); }
.alert-err { background: var(--red-dim); color: #ff7070; border: 1px solid rgba(224,64,64,.25); }
.alert-warn { background: var(--yellow-dim); color: var(--yellow); border: 1px solid rgba(224,176,48,.25); }
#toast-box { position: fixed; bottom: 20px; right: 20px; z-index: 9999; display: flex; flex-direction: column; gap: 6px; }
.toast { padding: 10px 14px; border-radius: var(--r); font-size: .8rem; font-weight: 600; box-shadow: 0 8px 32px rgba(0,0,0,.5); animation: tIn .25s ease; display: flex; align-items: center; gap: 7px; min-width: 200px; max-width: 320px; opacity: 1 !important; }
.toast-ok { background: var(--bg-3); color: var(--green); border: 1px solid rgba(48,208,112,.3); }
.toast-err { background: var(--bg-3); color: #ff7070; border: 1px solid rgba(224,64,64,.3); }
.toast-info { background: var(--bg-3); color: var(--tx-1); border: 1px solid var(--border-2); }
@keyframes tIn { from { opacity: 0; transform: translateX(14px); } to { opacity: 1; transform: translateX(0); } }

/* ══════════════════════════════════════════════════
   ERROR PAGE
   ══════════════════════════════════════════════════ */
.err-page { min-height: 60vh; display: flex; align-items: center; justify-content: center; padding: 2rem; }
.err-box { text-align: center; max-width: 360px; }
.err-icon { font-size: 3rem; color: var(--tx-4); margin-bottom: .75rem; }
.err-t { font-family: var(--font-head); font-size: 1.4rem; font-weight: 900; letter-spacing: 1px; text-transform: uppercase; margin-bottom: .5rem; }
.err-m { color: var(--tx-3); margin-bottom: 1.25rem; font-size: .85rem; }

/* ══════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════ */
.site-footer {
  background: var(--bg-2);
  border-top: 1px solid var(--border);
  padding: 32px 0 0;
  margin-top: 40px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.5fr;
  gap: 24px;
  padding-bottom: 24px;
}
.footer-brand-col p { font-size: .78rem; color: var(--tx-3); margin-top: 10px; line-height: 1.7; }
.footer-col-title {
  font-family: var(--font-head);
  font-size: .63rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.8px;
  color: var(--tx-3);
  margin-bottom: 10px;
}
.site-footer a { display: block; font-size: .78rem; color: var(--tx-2); margin-bottom: 4px; }
.site-footer a:hover { color: var(--ac); }
.site-footer p { font-size: .77rem; color: var(--tx-3); line-height: 1.6; }
.footer-bottom {
  border-top: 1px solid var(--border);
  padding: 12px 0;
  text-align: center;
  font-size: .68rem;
  color: var(--tx-4);
}

/* ══════════════════════════════════════════════════
   PAGE HEADER (shared)
   ══════════════════════════════════════════════════ */
.page-header { border-bottom: 1px solid var(--border); background: var(--bg-2); padding: 22px 0; }
.page-header-inner { max-width: 1280px; margin: 0 auto; padding: 0 20px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.page-title { font-family: var(--font-head); font-size: 1.4rem; font-weight: 900; letter-spacing: 1px; text-transform: uppercase; }
.page-stats { display: flex; gap: 0; border: 1px solid var(--border-2); border-radius: var(--r-lg); overflow: hidden; }
.pstat { text-align: center; padding: 8px 20px; background: var(--bg-3); border-right: 1px solid var(--border-2); }
.pstat:last-child { border-right: none; }
.pstat-n { font-family: var(--font-head); font-size: 1.4rem; font-weight: 900; color: var(--ac); display: block; line-height: 1; }
.pstat-l { font-family: var(--font-head); font-size: .6rem; text-transform: uppercase; letter-spacing: 1.5px; color: var(--tx-3); font-weight: 700; }

/* Breadcrumb */
.breadcrumb { display: flex; align-items: center; gap: 6px; font-size: .74rem; color: var(--tx-3); margin-bottom: 14px; }
.breadcrumb a { color: var(--tx-3); }.breadcrumb a:hover { color: var(--ac); }

/* ══════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════ */
@media (max-width: 1000px) {
  .scard { grid-template-columns: 46px 12px auto 1fr 96px; }
  .sdetail-grid { grid-template-columns: 1fr; }
  .sd-sidebar { order: -1; }
  .sd-stats-grid { grid-template-columns: 1fr 1fr; }
  .config-grid { grid-template-columns: 1fr 1fr; }
  .adm-stats { grid-template-columns: repeat(3,1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .prof-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .nav-links .nav-lnk span { display: none; }
  .filter-inner { gap: 5px; }
  .scard { grid-template-columns: 40px 10px 1fr 90px; }
  .scard-banner { display: none; }
  .smeta-addr { display: none; }
  .hero-inner { flex-direction: column; align-items: flex-start; }
  .footer-grid { grid-template-columns: 1fr; }
  .fg-row { grid-template-columns: 1fr; }
  .adm-stats { grid-template-columns: 1fr 1fr; }
  .sd-stats-grid { grid-template-columns: 1fr 1fr; }
}

/* ── LAYOUT FIX PATCH ────────────────────────────────────────────────────── */
.scard {
  grid-template-columns: 52px 16px 1fr 110px !important;
  min-height: 72px;
}
.scard-dot { padding: 0 8px; }
.scard-info { padding: 14px 16px; }
.scard-name { font-size: 1.05rem; margin-bottom: 5px; }
.scard-meta { gap: 12px; margin-bottom: 7px; }
.smeta-item { font-size: .78rem; }
.scard-vote { min-width: 110px; padding: 14px 18px; }
.vote-count { font-size: 1.7rem; }

/* Hero fix — tighten on large screens */
.hero-bar { padding: 24px 0 20px; }
.hero-title { font-size: 2rem; }
.hstat { padding: 10px 20px; }
.hstat-n { font-size: 1.8rem; }

/* Filter bar always visible */
.filter-bar { position: sticky; top: 0; z-index: 100; }
.filter-inner { min-height: 50px; }

/* Remove stagger on hover - cleaner */
.scard:hover { transform: none; box-shadow: inset 3px 0 0 var(--ac), 0 2px 16px rgba(0,0,0,0.25); }

/* ── FONT + PLAYER FIX ───────────────────────────────────────────────────── */
.scard-name { font-weight: 600 !important; font-size: .95rem !important; letter-spacing: .1px !important; }
.smeta-players { font-weight: 700; color: var(--tx-1) !important; }
.smeta-players .smeta-slash { color: var(--tx-3); font-weight: 400; }
.smeta-players .smeta-max { color: var(--tx-3); }
.smeta-online { color: var(--green) !important; }

/* ── SERVER DETAIL WIDTH FIX ─────────────────────────────────────────────── */
.sdetail-wrap { max-width: 100% !important; padding: 24px 0 60px !important; }
.container-xl .sdetail-grid,
.container-xl > .breadcrumb,
.container-xl > .alert { width: 100%; }
.sdetail-grid { display: grid; grid-template-columns: 1fr 310px; gap: 24px; }

/* Also fix the info-block-title to use orange accent bar */
.info-block-title {
  background: var(--bg-4) !important;
  border-left: 3px solid var(--ac);
  color: var(--tx-2) !important;
}

/* ── SERVER DETAIL CENTERING FIX ─────────────────────────────────────────── */
.container-xl {
  max-width: 1320px;
  margin: 0 auto;
  padding-left: 20px;
  padding-right: 20px;
  width: 100%;
}

/* ── PAGE WRAP (shared centered container) ───────────────────────────────── */
.page-wrap {
  max-width: 1280px;
  margin: 0 auto;
  padding: 24px 20px 60px;
  width: 100%;
}

/* ── REGION BAR & FLAGS ──────────────────────────────────────────────────── */
.region-bar {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 6px 0 8px;
  flex-wrap: wrap;
  border-top: 1px solid var(--border);
  margin-top: 4px;
}
.region-cnt {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-5);
  color: var(--tx-3);
  border-radius: 10px;
  font-size: .65rem;
  font-weight: 700;
  padding: 0 5px;
  min-width: 18px;
  height: 16px;
  margin-left: 2px;
}
.fpill.on .region-cnt { background: rgba(255,255,255,.2); color: #fff; }

/* Country flag + region on card */
.scard-region {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .72rem;
  color: var(--tx-3);
  margin-bottom: 4px;
}
.scard-region img {
  border-radius: 2px;
  border: 1px solid var(--border);
  flex-shrink: 0;
}
.region-badge {
  font-family: var(--font-head);
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .6px;
  text-transform: uppercase;
  background: var(--ac-dim);
  color: var(--ac);
  border: 1px solid rgba(240,112,32,.25);
  border-radius: 3px;
  padding: 0 5px;
}

/* Flag on server detail page */
.sd-country {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .78rem;
  color: var(--tx-2);
  margin-bottom: 8px;
}
.sd-country img { border-radius: 2px; border: 1px solid var(--border); }

/* ══════════════════════════════════════════════════
   SERVER CARD v2 — redesigned layout
   ══════════════════════════════════════════════════ */
.slist { display: flex; flex-direction: column; gap: 5px; }

.scard2 {
  display: grid;
  grid-template-columns: 52px 1fr auto;
  align-items: stretch;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: border-color .15s, box-shadow .15s;
  position: relative;
}
.scard2::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--green);
  border-radius: 3px 0 0 3px;
  transition: background .15s;
}
.scard2.scard2-offline::before { background: var(--tx-4); }
.scard2.scard2-offline { opacity: .6; }
.scard2:hover { border-color: var(--ac); box-shadow: 0 0 0 1px var(--ac), 0 4px 20px rgba(0,0,0,.3); }
.scard2:hover::before { background: var(--ac); }

/* With banner: 4 cols */
.scard2.has-banner { grid-template-columns: 52px 130px 1fr auto; }

/* Rank col */
.sc2-rank {
  display: flex; align-items: center; justify-content: center;
  padding: 0 8px; flex-shrink: 0;
}

/* Banner col */
.sc2-banner {
  width: 130px; overflow: hidden; flex-shrink: 0;
  border-right: 1px solid var(--border);
}
.sc2-banner img, .sc2-banner video {
  width: 130px; height: 100%; object-fit: cover; display: block;
}

/* Info col */
.sc2-info {
  padding: 11px 14px; min-width: 0; display: flex; flex-direction: column; gap: 5px; justify-content: center;
}
.sc2-top {
  display: flex; align-items: center; gap: 7px; flex-wrap: wrap;
}
.sc2-status-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.dot-on  { background: var(--green); box-shadow: 0 0 6px var(--green); }
.dot-off { background: var(--tx-4); }
.sc2-name {
  font-family: var(--font-head);
  font-size: .98rem; font-weight: 700; letter-spacing: .2px;
  color: var(--tx-1); text-decoration: none;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 500px;
  transition: color .15s;
}
.sc2-name:hover { color: var(--ac); }
.sc2-flag {
  display: inline-flex; align-items: center; gap: 4px;
  flex-shrink: 0;
}
.sc2-flag img { border-radius: 2px; border: 1px solid var(--border); }
.sc2-country { font-size: .7rem; color: var(--tx-3); }

.sc2-meta {
  display: flex; flex-wrap: wrap; gap: 10px;
}
.sc2-mi {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: .73rem; color: var(--tx-2);
}
.sc2-mi i { font-size: .65rem; color: var(--tx-3); }
.sc2-addr { font-family: var(--font-mono); font-size: .68rem; }
.sc2-ver  { font-family: var(--font-mono); }

.sc2-tags { display: flex; flex-wrap: wrap; gap: 3px; }

/* Right panel */
.sc2-right {
  display: flex; align-items: stretch;
  border-left: 1px solid var(--border);
  flex-shrink: 0;
}

/* Players section */
.sc2-players {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 10px 16px; gap: 3px;
  border-right: 1px solid var(--border);
  min-width: 90px;
}
.sc2-pico { font-size: .8rem; color: var(--tx-3); }
.sc2-pcur {
  font-family: var(--font-head); font-size: 1.3rem; font-weight: 900;
  line-height: 1; color: var(--tx-2);
}
.sc2-pon { color: var(--green) !important; text-shadow: 0 0 10px rgba(48,208,112,.4); }
.sc2-psep { font-size: .75rem; color: var(--tx-4); line-height: 1; }
.sc2-pmax { font-family: var(--font-mono); font-size: .72rem; color: var(--tx-3); line-height: 1; }
.sc2-pbar {
  width: 60px; height: 4px; background: var(--bg-5);
  border-radius: 2px; overflow: hidden; margin-top: 3px;
}
.sc2-pbar-fill {
  height: 100%; background: var(--green); border-radius: 2px;
  transition: width .3s;
}

/* Uptime section */
.sc2-uptime {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 10px 14px; gap: 3px;
  border-right: 1px solid var(--border);
  min-width: 80px;
}
.sc2-uptime-ring { position: relative; width: 44px; height: 44px; }
.uptime-svg { width: 44px; height: 44px; }
.uptime-pct {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  font-family: var(--font-head); font-size: .62rem; font-weight: 900;
  line-height: 1;
}
.sc2-uptime-lbl {
  font-family: var(--font-head); font-size: .58rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .8px; color: var(--tx-4);
}
.sc2-uptime-new {
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  font-size: .65rem; color: var(--tx-4);
}
.sc2-uptime-new i { font-size: .9rem; }

/* Vote section */
.sc2-vote-col {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 10px 16px; gap: 6px; min-width: 90px;
  background: var(--bg-3);
}
.sc2-votes {
  font-family: var(--font-head); font-size: 1.5rem; font-weight: 900;
  color: var(--ac); line-height: 1; text-align: center;
}
.sc2-vlbl {
  display: block; font-family: var(--font-head); font-size: .58rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1px; color: var(--tx-3);
}

/* List meta */
.list-meta { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.list-count { font-family: var(--font-mono); font-size: .72rem; color: var(--tx-3); }
.list-hint { font-size: .7rem; color: var(--tx-4); display: flex; align-items: center; gap: 4px; }

/* Offline pill */
.fpill-off.on { color: var(--red); border-color: rgba(224,64,64,.35); }

/* Responsive */
@media(max-width:900px){
  .scard2 { grid-template-columns: 44px 1fr auto; }
  .scard2.has-banner { grid-template-columns: 44px 1fr auto; }
  .sc2-banner { display: none; }
  .sc2-uptime { display: none; }
  .sc2-addr { display: none; }
}
@media(max-width:600px){
  .scard2 { grid-template-columns: 36px 1fr auto; }
  .sc2-players { min-width: 70px; padding: 8px 10px; }
  .sc2-vote-col { min-width: 70px; padding: 8px 10px; }
  .sc2-pcur { font-size: 1.1rem; }
  .sc2-votes { font-size: 1.2rem; }
}

/* Top 10 rank badge */
.rank-top10 {
  font-family: var(--font-head);
  font-size: .75rem; font-weight: 900;
  padding: 3px 6px;
  border-radius: var(--r);
  background: rgba(240,112,32,.1);
  color: var(--ac);
  border: 1px solid rgba(240,112,32,.25);
  text-align: center;
}
/* Rank tooltip cursor */
.sc2-rank { cursor: help; }