/* ===================================================================
   Bombom PVP v3 — Modern Dark Design System
   Display: Oxanium  ·  Body: Plus Jakarta Sans
   Cross-browser animations, card/list views, cookie banner, modal
=================================================================== */

/* ---------- 1. Design Tokens ---------- */
:root{
  --bg:#0c0e13;
  --bg-2:#10131a;
  --bg-3:#141720;
  --surface:#1a1d26;
  --surface-2:#1f232f;
  --surface-3:#262b38;
  --line:rgba(255,255,255,.06);
  --line-2:rgba(255,255,255,.11);
  --text:#e8eaed;
  --muted:#9aa0a6;
  --faint:#5f6368;

  --amber:#f59e0b;
  --amber-2:#fbbf24;
  --ember:#ef4444;
  --gold-1:#fde68a;
  --gold-2:#fbbf24;
  --gold-3:#f59e0b;
  --gold-grad:linear-gradient(135deg,var(--gold-1),var(--gold-2) 40%,var(--gold-3));
  --ember-grad:linear-gradient(135deg,#f87171,#ef4444);

  --online:#4ade80;
  --closed:#f43f5e;
  --fire:#fb923c;
  --love:#f472b6;
  --star:#fde047;

  --primary:#7c3aed;
  --primary-soft:rgba(124,58,237,.14);
  --primary-border:rgba(124,58,237,.35);

  --maxw:1280px;
  --radius:14px;
  --radius-sm:10px;
  --radius-lg:20px;
  --radius-xl:26px;

  --shadow:0 20px 60px -24px rgba(0,0,0,.8);
  --shadow-sm:0 8px 24px -16px rgba(0,0,0,.6);
  --shadow-glow:0 0 0 1px rgba(245,158,11,.3), 0 16px 48px -16px rgba(245,158,11,.3);

  --ff-display:"Oxanium",system-ui,sans-serif;
  --ff-body:"Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  --header-h:68px;
}

/* ---------- 2. Reset & Base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{
  margin:0;font-family:var(--ff-body);background:var(--bg);color:var(--text);
  line-height:1.6;font-size:16px;overflow-x:hidden;min-height:100vh;position:relative;
}

body::before{
  content:"";position:fixed;inset:0;z-index:-3;pointer-events:none;
  background:
    radial-gradient(900px 520px at 8% -6%, rgba(124,58,237,.08), transparent 60%),
    radial-gradient(800px 600px at 96% -4%, rgba(245,158,11,.06), transparent 60%),
    radial-gradient(1100px 800px at 50% 115%, rgba(99,102,241,.04), transparent 60%),
    var(--bg);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.25;
  background-image:
    linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);
  background-size:48px 48px;
  -webkit-mask-image:radial-gradient(ellipse 75% 55% at 50% 0%,#000 25%,transparent 75%);
          mask-image:radial-gradient(ellipse 75% 55% at 50% 0%,#000 25%,transparent 75%);
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:700;line-height:1.1;margin:0 0 .5em;letter-spacing:-.01em}
p{margin:0 0 1em}
ul,ol{margin:0;padding:0;list-style:none}
::selection{background:var(--amber);color:#1a0e00}

/* ---------- 3. Layout Utilities ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.center{text-align:center}
.muted{color:var(--muted)}
.faint{color:var(--faint)}
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--amber-2);
  outline-offset:3px;
}

.eyebrow{
  font-family:var(--ff-display);font-weight:600;font-size:.74rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--amber-2);display:inline-flex;gap:.5em;align-items:center;
}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--gold-grad);border-radius:2px}

/* ---------- 4. Buttons & Badges ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;justify-content:center;
  font-family:var(--ff-display);font-weight:700;font-size:.92rem;
  padding:.68em 1.15em;border-radius:var(--radius-sm);border:1px solid transparent;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
  white-space:nowrap;line-height:1;
}
.btn:active{transform:translateY(1px)}
.btn-primary{
  background:var(--gold-grad);color:#2a1500;
  box-shadow:0 6px 20px -10px rgba(245,158,11,.55);
}
.btn-primary:hover{
  box-shadow:0 10px 32px -12px rgba(245,158,11,.7);
  transform:translateY(-2px);
}
.btn-ghost{
  background:rgba(255,255,255,.04);border-color:var(--line-2);color:var(--text);
}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:var(--amber)}
.btn-danger{background:var(--ember-grad);color:#fff}
.btn-sm{padding:.48em .8em;font-size:.8rem;border-radius:8px}
.btn-block{display:flex;width:100%}
.btn-lg{padding:.9em 1.4em;font-size:1.1rem}

.pill{
  display:inline-flex;align-items:center;gap:.35em;padding:.24em .65em;border-radius:999px;
  font-size:.7rem;font-weight:700;font-family:var(--ff-display);letter-spacing:.03em;
  border:1px solid var(--line-2);line-height:1;
}
.pill-online{color:var(--online);background:rgba(74,222,128,.1);border-color:rgba(74,222,128,.28)}
.pill-closed{color:var(--closed);background:rgba(244,63,94,.1);border-color:rgba(244,63,94,.28)}
.pill-ver{color:var(--amber-2);background:rgba(245,158,11,.1);border-color:rgba(245,158,11,.25)}
.pill-primary{color:#c4b5fd;background:var(--primary-soft);border-color:var(--primary-border)}

.dot{width:7px;height:7px;border-radius:50%;background:currentColor;box-shadow:0 0 0 0 currentColor}
.dot-pulse{animation:dotPulse 2.2s infinite}
@keyframes dotPulse{
  0%{box-shadow:0 0 0 0 rgba(74,222,128,.45)}
  70%{box-shadow:0 0 0 8px rgba(74,222,128,0)}
  100%{box-shadow:0 0 0 0 rgba(74,222,128,0)}
}

/* ---------- 5. Header & Navigation ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(180deg,rgba(12,14,19,.95),rgba(12,14,19,.78));
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
}
.header-in{display:flex;align-items:center;gap:18px;height:var(--header-h)}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--ff-display);font-weight:800;font-size:1.28rem;letter-spacing:-.02em}
.brand .mark{width:36px;height:36px;flex:0 0 auto;filter:drop-shadow(0 4px 12px rgba(245,158,11,.4))}
.brand b{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}

.nav{display:flex;align-items:center;gap:3px;margin-left:auto}
.nav a{padding:.55em .9em;border-radius:10px;color:var(--muted);font-weight:600;font-size:.93rem;transition:.16s}
.nav a:hover,.nav a.active{color:var(--text);background:rgba(255,255,255,.05)}
.nav .btn{margin-left:10px}
.site-header .nav a.btn-primary,
.site-header .nav a.btn-primary:hover,
.site-header .nav a.btn-primary:focus-visible{
  color:#2a1500;
}
.site-header .nav a.btn-primary:hover{
  background:var(--gold-grad);
}

.nav-toggle{display:none;margin-left:auto;background:rgba(255,255,255,.05);border:1px solid var(--line-2);
  width:42px;height:42px;border-radius:10px;color:var(--text);font-size:1.15rem;place-items:center}

/* ---------- 6. View Toggle ---------- */
.view-toggle{display:inline-flex;gap:6px;padding:6px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:12px}
.view-toggle-btn{
  display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;
  border-radius:10px;border:none;background:transparent;color:var(--muted);
  transition:.2s;cursor:pointer;font-weight:600;
}
.view-toggle-btn:hover{color:var(--text);background:rgba(255,255,255,.06)}
.view-toggle-btn.is-active{
  background:var(--gold-grad);color:#2a1500;
  box-shadow:0 0 0 2px rgba(245,158,11,.3);
}

/* ---------- 7. Layout Shell & Ads ---------- */
.shell{display:grid;grid-template-columns:220px minmax(0,1fr) 220px;gap:24px;
  max-width:calc(var(--maxw) + 100px);margin:0 auto;padding:28px 20px 70px;align-items:start}
.rail{position:sticky;top:calc(var(--header-h) + 16px)}
.rail-right{justify-self:end}
.col-main{min-width:0}

.ad{display:none !important}

/* ---------- 8. Hero ---------- */
.hero{padding:10px 0 32px}
.hero h1{font-size:clamp(1.9rem,4.4vw,3.1rem);margin-bottom:.35em;line-height:1.08}
.hero h1 em{font-style:normal;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .lead{font-size:1.05rem;color:var(--muted);max-width:62ch;margin-bottom:1.2em}
.hero-stats{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.hero-stats .st{
  display:flex;flex-direction:column;gap:4px;
  padding:12px 16px;border:1px solid var(--line);border-radius:var(--radius-sm);
  background:rgba(255,255,255,.025);min-width:100px;
}
.hero-stats .st b{font-family:var(--ff-display);font-size:1.35rem;color:var(--text);line-height:1}
.hero-stats .st small{color:var(--faint);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}

/* ---------- 9. Featured Server Card (Animated) ---------- */
.featured-wrap{margin:10px 0 34px}
.featured{
  position:relative;border-radius:var(--radius-lg);padding:3px;
  background:linear-gradient(135deg,#f59e0b,#a855f7 50%,#ec4899);
  background-size:300% 300%;
  animation:featGrad 5s ease infinite;
  box-shadow:0 20px 60px -20px rgba(168,85,247,.45), 0 12px 32px -12px rgba(245,158,11,.3);
}
@keyframes featGrad{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}
.featured-in{
  position:relative;border-radius:calc(var(--radius-lg) - 3px);
  background:
    radial-gradient(140% 150% at 0% 0%,rgba(245,158,11,.16),transparent 45%),
    radial-gradient(120% 120% at 100% 100%,rgba(168,85,247,.12),transparent 45%),
    linear-gradient(180deg,#1e2230,#181b26);
  padding:32px;display:flex;align-items:center;gap:28px;overflow:hidden;
}
.featured-in::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,.15) 50%,transparent 65%);
  background-size:200% 100%;animation:featShimmer 3.5s ease-in-out infinite;
}
@keyframes featShimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}
.featured-badge{
  position:absolute;top:0;left:16px;z-index:2;
  background:linear-gradient(180deg,var(--gold-1),var(--gold-3));
  color:#2a1500;font-family:var(--ff-display);font-weight:800;font-size:.75rem;
  letter-spacing:.08em;text-transform:uppercase;padding:6px 14px 7px;border-radius:0 0 8px 8px;
  box-shadow:0 4px 14px rgba(245,158,11,.45);display:inline-flex;gap:5px;align-items:center;
}
.featured-badge .crown{font-size:.9rem}
.featured-in:hover{
  transform:translateY(-4px);
  box-shadow:0 0 0 1px rgba(255,255,255,.2), 0 16px 48px -16px rgba(245,158,11,.4);
}

.featured .logo{width:110px;height:110px;border-radius:20px;flex:0 0 auto;object-fit:cover;
  border:2px solid rgba(255,200,120,.35);box-shadow:0 12px 32px rgba(0,0,0,.45);position:relative;z-index:1}
.featured .body{flex:1;min-width:0;position:relative;z-index:1}
.featured h2{font-size:clamp(1.6rem,3.2vw,2.2rem);margin:.2em 0 .3em}
.featured .meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:.55em}
.featured .desc{color:var(--muted);font-size:1.05rem;margin-bottom:1.1em;max-width:60ch;line-height:1.6}
.featured .cta{display:flex;gap:16px;flex-wrap:wrap;align-items:center}

.online-big{font-family:var(--ff-display);font-weight:800;display:flex;align-items:baseline;gap:8px}
.online-big b{font-size:1.8rem;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.online-big small{color:var(--faint);font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700}

/* Empty featured state */
.featured-empty{
  position:relative;border-radius:var(--radius-lg);padding:2px;
  background:linear-gradient(135deg,rgba(245,158,11,.35),rgba(168,85,247,.35),rgba(236,72,153,.35));
  background-size:300% 300%;animation:featGrad 6s ease infinite;
  cursor:pointer;transition:transform .2s,box-shadow .2s;
  box-shadow:0 14px 40px -16px rgba(168,85,247,.3);
}
.featured-empty:hover{
  transform:translateY(-2px);
  box-shadow:0 20px 56px -16px rgba(168,85,247,.45),0 10px 24px rgba(245,158,11,.2);
}
.featured-empty-in{
  border-radius:calc(var(--radius-lg) - 2px);padding:24px;
  background:
    radial-gradient(140% 150% at 0% 0%,rgba(245,158,11,.08),transparent 40%),
    linear-gradient(180deg,#1e2230,#181b26);
  display:flex;align-items:center;gap:18px;position:relative;overflow:hidden;
}
.featured-empty-in::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(105deg,transparent 40%,rgba(168,85,247,.12) 50%,transparent 60%);
  animation:featShimmer 4s ease-in-out infinite;
}
.featured-empty-icon{
  width:56px;height:56px;border-radius:14px;
  background:linear-gradient(135deg,rgba(245,158,11,.18),rgba(168,85,247,.22));
  border:1px solid rgba(245,158,11,.3);display:grid;place-items:center;
  box-shadow:0 0 24px rgba(245,158,11,.15);flex:0 0 auto;position:relative;z-index:1;
}
.featured-empty-icon svg{color:var(--gold-2);width:28px;height:28px}
.featured-empty-text{flex:1;min-width:0;position:relative;z-index:1}
.featured-empty-tag{
  display:inline-block;font-size:.65rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  padding:3px 8px;border-radius:5px;background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.25);
  color:var(--gold-2);margin-bottom:6px;
}
.featured-empty-title{
  font-size:1.15rem;font-weight:800;font-family:var(--ff-display);margin-bottom:3px;
  background:linear-gradient(90deg,var(--gold-2),var(--gold-3));-webkit-background-clip:text;background-clip:text;color:transparent;
}
.featured-empty-desc{color:var(--faint);font-size:.85rem;line-height:1.4;max-width:340px}
.featured-empty-cta{
  display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:9px;
  background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;font-size:.82rem;font-weight:700;
  box-shadow:0 4px 14px rgba(168,85,247,.35);position:relative;z-index:1;transition:transform .2s;
}
.featured-empty:hover .featured-empty-cta{transform:translateX(3px)}

/* ---------- 10. Section Header & Controls ---------- */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin:0 0 18px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(1.35rem,2.4vw,1.85rem);margin:0}
.sec-head p{margin:.25em 0 0;color:var(--muted);font-size:.92rem}

/* ---------- 11. Filters ---------- */
.filters{display:flex;gap:6px;flex-wrap:wrap}
.filter{
  padding:.45em .85em;border-radius:999px;border:1px solid var(--line-2);background:rgba(255,255,255,.03);
  color:var(--muted);font-family:var(--ff-display);font-weight:600;font-size:.8rem;transition:.16s;cursor:pointer;
}
.filter:hover{color:var(--text);border-color:var(--amber)}
.filter.active{background:var(--gold-grad);color:#2a1500;border-color:transparent}

/* ---------- 12. Server List (List View) ---------- */
.servers{display:flex;flex-direction:column;gap:10px}
.srv{
  display:grid;grid-template-columns:44px 56px minmax(0,1fr) auto;align-items:center;gap:14px;
  padding:16px 20px;border-radius:var(--radius-lg);border:1px solid var(--line);
  background:linear-gradient(180deg,var(--surface),var(--surface-2));
  transition:border-color .2s, transform .2s, box-shadow .2s, background .2s;position:relative;
}
.srv:hover{border-color:var(--line-2);transform:translateY(-4px);box-shadow:var(--shadow);background:linear-gradient(180deg,var(--surface-2),var(--surface-3))}
.srv.closed{opacity:.6}
.srv.is-top-pick{
  border-color:rgba(245,158,11,.4);
  box-shadow:0 0 0 1px rgba(245,158,11,.12), 0 6px 22px -8px rgba(245,158,11,.35);
  background:linear-gradient(135deg,rgba(245,158,11,.05),var(--surface) 40%);
}
.srv.is-top-pick:hover{border-color:rgba(245,158,11,.55);box-shadow:0 0 0 1px rgba(245,158,11,.18), 0 8px 28px -8px rgba(245,158,11,.45);transform:translateY(-4px);background:linear-gradient(135deg,rgba(245,158,11,.1),var(--surface-2) 40%)}

.srv .rank{font-family:var(--ff-display);font-weight:800;font-size:1.15rem;color:var(--faint);text-align:center;line-height:1}
.srv:nth-child(1) .rank{color:var(--gold-2)}
.srv:nth-child(2) .rank{color:#c8d0df}
.srv:nth-child(3) .rank{color:#d8915a}

.srv .logo{width:56px;height:56px;border-radius:13px;object-fit:cover;border:1px solid var(--line-2);background:var(--surface-3);flex:0 0 auto}
.logo-ph{
  display:grid;place-items:center;font-family:var(--ff-display);font-weight:800;color:#1a0e00;
  background:linear-gradient(135deg,var(--c1,#f59e0b),var(--c2,#ef4444));border:none!important;letter-spacing:-.02em;
}
.featured .logo-ph{font-size:2.2rem}.srv .logo-ph{font-size:1.35rem}.srv-hero .logo-ph{font-size:2.6rem}

.srv .info{min-width:0}
.srv .name{font-family:var(--ff-display);font-weight:700;font-size:1.08rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.srv .name a:hover{color:var(--amber-2)}
.srv .sub{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:5px}

.top-pick-star{
  color:var(--gold-2);display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;
  filter:drop-shadow(0 0 4px rgba(245,158,11,.5));flex-shrink:0;
}

.reacts{display:flex;gap:6px}
.react{
  display:inline-flex;align-items:center;gap:4px;font-size:.76rem;font-weight:700;color:var(--muted);
  background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:999px;padding:.2em .55em;
  transition:.15s;cursor:pointer;font-family:var(--ff-display);line-height:1;border:none;
}
.react:hover{border-color:rgba(255,255,255,.14);transform:translateY(-1px)}
.react .ico{font-size:.88rem;line-height:1}
.react.on.fire{color:var(--fire);background:rgba(251,146,60,.12);border-color:rgba(251,146,60,.4)}
.react.on.love{color:var(--love);background:rgba(244,114,182,.12);border-color:rgba(244,114,182,.4)}
.react.on.star{color:var(--star);background:rgba(253,224,71,.12);border-color:rgba(253,224,71,.4)}

.srv .right{display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.srv .online{font-family:var(--ff-display);font-weight:800;font-size:1.05rem;color:var(--text);display:flex;align-items:center;gap:5px}
.srv .online .n{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.srv .online small{color:var(--faint);font-size:.65rem;text-transform:uppercase;letter-spacing:.07em;font-weight:700}

/* ---------- 13. Server List (Card View) ---------- */
.servers.is-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.servers.is-cards .srv{
  display:block;padding:16px;border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
}
.servers.is-cards .srv .rank{float:right;min-width:32px;text-align:right;font-size:.95rem;color:var(--faint)}
.servers.is-cards .srv .logo{float:left;width:50px;height:50px;margin:0 12px 10px 0;border-radius:11px}
.servers.is-cards .srv .info{min-height:62px}
.servers.is-cards .srv .name{display:block;padding-right:40px;font-size:1rem;line-height:1.2}
.servers.is-cards .srv .name a{color:var(--text)}
.servers.is-cards .srv .name .pill{margin-left:6px;vertical-align:2px}
.servers.is-cards .srv .sub{clear:both;margin-top:10px}
.servers.is-cards .srv .right{
  clear:both;margin-top:11px;padding-top:10px;border-top:1px solid var(--line);
  flex-direction:row;justify-content:space-between;align-items:center;
}
.servers.is-cards .srv .online{font-size:.98rem}
.servers.is-cards .srv .reacts{flex-wrap:wrap}

/* ---------- 14. Panels & Articles ---------- */
.panel{
  background:linear-gradient(180deg,var(--surface),var(--surface-2));
  border:1px solid var(--line);border-radius:var(--radius);padding:26px;margin-top:32px;
}
.article h2,.article h3{font-family:var(--ff-display)}
.article h3{font-size:1.18rem;margin-top:1.3em;color:var(--amber-2)}
.article p{color:var(--muted);line-height:1.7}
.article p:first-child{font-size:1.02rem}

/* ---------- 15. FAQ ---------- */
.faq{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.qa{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);overflow:hidden;transition:.15s}
.qa:hover{border-color:rgba(255,255,255,.1)}
.qa summary{
  list-style:none;cursor:pointer;padding:15px 18px;font-family:var(--ff-display);font-weight:700;
  font-size:.96rem;display:flex;justify-content:space-between;gap:14px;align-items:center;transition:.15s
}
.qa summary::-webkit-details-marker{display:none}
.qa summary:hover{color:var(--amber-2)}
.qa summary::after{content:"+";font-size:1.3rem;color:var(--amber);transition:transform .2s;line-height:1;font-weight:400}
.qa[open] summary::after{transform:rotate(45deg)}
.qa .a{padding:0 18px 16px;color:var(--muted);font-size:.94rem;line-height:1.65}

/* ---------- 16. Packages, Steps, Benefits ---------- */
.page-hero{padding:44px 0 20px;text-align:center}
.page-hero h1{font-size:clamp(1.9rem,4.2vw,2.9rem);line-height:1.1}
.page-hero h1 em{font-style:normal;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.page-hero p{color:var(--muted);max-width:62ch;margin:0 auto;font-size:1.04rem}

.pkg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin:24px 0}
.pkg{
  border:1px solid var(--line);border-radius:var(--radius);padding:22px;
  background:linear-gradient(180deg,var(--surface),var(--surface-2));position:relative;transition:.2s;
}
.pkg:hover{border-color:var(--amber);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.pkg.hot{border-color:rgba(245,158,11,.5);box-shadow:0 0 0 1px rgba(245,158,11,.2), 0 18px 48px -24px rgba(245,158,11,.55)}
.pkg .tag{
  position:absolute;top:-10px;left:20px;background:var(--gold-grad);color:#2a1500;font-family:var(--ff-display);
  font-weight:800;font-size:.64rem;letter-spacing:.1em;padding:.3em .7em;border-radius:7px;
}
.pkg h3{font-size:1.12rem;margin-bottom:.15em}
.pkg .price{font-family:var(--ff-display);font-weight:800;font-size:1.65rem;background:var(--gold-grad);
  -webkit-background-clip:text;background-clip:text;color:transparent;margin:.15em 0}
.pkg .size{font-size:.76rem;color:var(--faint);letter-spacing:.04em;margin-bottom:.7em}
.pkg p{color:var(--muted);font-size:.88rem}

.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin:24px 0;counter-reset:s}
.step{
  border:1px solid var(--line);border-radius:var(--radius);padding:20px;background:var(--surface);position:relative;
}
.step::before{
  counter-increment:s;content:counter(s);position:absolute;top:-14px;left:18px;width:36px;height:36px;
  display:grid;place-items:center;border-radius:10px;background:var(--gold-grad);color:#2a1500;font-family:var(--ff-display);font-weight:800;
}
.step h4{margin:.35em 0 .25em;font-size:1rem}
.step p{color:var(--muted);font-size:.87rem;margin:0;line-height:1.55}

.benefits{list-style:none;padding:0;margin:18px 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}
.benefits li{display:flex;gap:10px;align-items:flex-start;color:var(--muted);font-size:.92rem;line-height:1.5}
.benefits li::before{
  content:"";flex:0 0 auto;width:20px;height:20px;margin-top:1px;border-radius:6px;
  background:var(--ember-grad) center/55% no-repeat;
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2l-3.5-3.5L4 14.2 9 19l11-11-1.4-1.4z'/></svg>") center/14px no-repeat;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2l-3.5-3.5L4 14.2 9 19l11-11-1.4-1.4z'/></svg>") center/14px no-repeat;
}

/* ---------- 17. Forms ---------- */
.form{display:flex;flex-direction:column;gap:14px;max-width:560px}
.form.wide{max-width:none}
.field label{display:block;font-size:.82rem;font-weight:600;color:var(--faint);margin-bottom:5px;font-family:var(--ff-display)}
.field input,.field textarea,.field select{
  width:100%;padding:.75em 1em;border-radius:var(--radius-sm);
  background:var(--bg-3);border:1px solid var(--line-2);color:var(--text);font-family:inherit;font-size:.95rem;transition:.15s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(245,158,11,.12)}
.field textarea{min-height:120px;resize:vertical}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.alert{padding:.85em 1.1em;border-radius:var(--radius-sm);font-size:.9rem;border:1px solid}
.alert-ok{background:rgba(74,222,128,.1);border-color:rgba(74,222,128,.3);color:#86efac}
.alert-err{background:rgba(244,63,94,.1);border-color:rgba(244,63,94,.3);color:#fda4af}

/* ---------- 18. Tabs ---------- */
.tabs{display:flex;gap:5px;background:var(--bg-3);padding:5px;border-radius:12px;border:1px solid var(--line);margin-bottom:16px}
.tabs button{flex:1;padding:.65em;border:none;border-radius:9px;background:transparent;color:var(--muted);font-family:var(--ff-display);font-weight:700;font-size:.9rem;transition:.15s}
.tabs button.active{background:var(--gold-grad);color:#2a1500}

/* ---------- 19. Cookie Banner ---------- */
.cookie-banner{
  position:fixed;bottom:16px;left:16px;right:16px;z-index:100;
  display:flex;justify-content:center;pointer-events:none;
}
.cookie-banner__inner{
  display:flex;align-items:center;gap:16px;
  background:rgba(24,27,38,.96);border:1px solid var(--line-2);border-radius:var(--radius);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  box-shadow:0 12px 40px rgba(0,0,0,.5);
  max-width:860px;width:100%;padding:14px 18px;pointer-events:auto;flex-wrap:wrap;
}
.cookie-banner__icon{
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
  width:40px;height:40px;border-radius:10px;
  background:rgba(251,191,36,.12);border:1px solid rgba(251,191,36,.2);color:#fbbf24;
}
.cookie-banner__text{flex:1;min-width:0;color:#a8b0be;font-size:.85rem;line-height:1.5}
.cookie-banner__text strong{color:var(--text);display:block;font-size:.92rem;margin-bottom:2px}
.cookie-banner__text a{color:#c4b5fd;text-decoration:underline}
.cookie-banner__text a:hover{color:#ddd6fe}
.cookie-banner__btn{
  flex-shrink:0;background:linear-gradient(135deg,var(--primary),#8b5cf6);border:none;border-radius:9px;
  box-shadow:0 4px 14px rgba(124,58,237,.35);color:#fff;cursor:pointer;font-size:.82rem;font-weight:700;
  padding:10px 20px;transition:all .2s;font-family:var(--ff-display);
}
.cookie-banner__btn:hover{box-shadow:0 6px 18px rgba(124,58,237,.5);transform:translateY(-1px)}

/* ---------- 20. Modal ---------- */
.modal-overlay{
  position:fixed;inset:0;z-index:110;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.65);padding:16px;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;
}
.modal-overlay.is-open{opacity:1;visibility:visible}
.modal{
  background:var(--surface);border:1px solid var(--line-2);border-radius:var(--radius-lg);
  box-shadow:0 24px 70px rgba(0,0,0,.55);max-width:480px;width:100%;
  transform:scale(.96) translateY(8px);transition:transform .2s ease;
}
.modal-overlay.is-open .modal{transform:scale(1) translateY(0)}
.modal__header{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:16px 20px;border-bottom:1px solid var(--line);
}
.modal__title{font-size:1.1rem;font-weight:700;margin:0;font-family:var(--ff-display)}
.modal__close{
  background:transparent;border:none;border-radius:8px;color:var(--faint);cursor:pointer;
  display:inline-flex;padding:5px;transition:.15s;
}
.modal__close:hover{background:rgba(255,255,255,.06);color:var(--text)}
.modal__body{padding:18px 20px 20px}
.modal__footer{
  display:flex;gap:8px;justify-content:flex-end;padding:0 20px 18px;
}

/* ---------- 21. Footer ---------- */
.site-footer{
  border-top:1px solid var(--line);background:linear-gradient(180deg,transparent,rgba(0,0,0,.4));margin-top:24px;
}
.footer-in{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:30px;padding:46px 22px 28px;max-width:var(--maxw);margin:0 auto}
.footer-in h4{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);font-family:var(--ff-display);margin:0 0 12px}
.footer-in a{color:var(--muted);display:block;padding:.28em 0;font-size:.92rem;transition:.15s}
.footer-in a:hover{color:var(--amber-2)}
.foot-brand{display:flex;align-items:center;gap:10px;font-family:var(--ff-display);font-weight:800;font-size:1.15rem;margin-bottom:.55em}
.foot-brand .mark{width:32px;height:32px}
.foot-note{color:var(--faint);font-size:.86rem;max-width:42ch;line-height:1.55}
.footer-bottom{
  border-top:1px solid var(--line);padding:16px 22px;text-align:center;color:var(--faint);
  font-size:.82rem;max-width:var(--maxw);margin:0 auto;
}
.footer-bottom a{color:var(--muted);transition:.15s}
.footer-bottom a:hover{color:var(--amber-2)}

/* ---------- 22. Server Detail ---------- */
.srv-hero{display:flex;gap:22px;align-items:center;flex-wrap:wrap;margin:24px 0 28px}
.srv-hero .logo{width:110px;height:110px;border-radius:20px;object-fit:cover;border:2px solid var(--line-2);flex:0 0 auto}
.srv-hero h1{font-size:clamp(1.75rem,3.8vw,2.5rem);margin-bottom:.15em}
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin:22px 0}
.info-box{border:1px solid var(--line);border-radius:var(--radius);padding:16px;background:var(--surface);text-align:center}
.info-box b{font-family:var(--ff-display);font-size:1.3rem;display:block;color:var(--text)}
.info-box small{color:var(--faint);text-transform:uppercase;letter-spacing:.06em;font-size:.68rem;font-weight:700}

.socials{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.soc{
  display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:10px;
  background:var(--surface-2);border:1px solid var(--line-2);color:var(--muted);font-size:.85rem;font-weight:600;transition:.15s;
}
.soc:hover{color:var(--amber-2);border-color:rgba(245,158,11,.35);transform:translateY(-2px)}
.soc svg{flex-shrink:0;width:16px;height:16px}

/* ---------- 23. Legal / Doc ---------- */
.doc{max-width:780px;margin:0 auto}
.doc h3{font-size:1.15rem;margin-top:1.5em;color:var(--amber-2)}
.doc p,.doc li{color:var(--muted);line-height:1.7}
.doc ul{padding-left:1.3em;list-style:disc}
.doc li{margin-bottom:.4em}

/* ---------- 24. 404 ---------- */
.page-404{text-align:center;padding:80px 20px}
.page-404 h1{font-size:clamp(4rem,12vw,8rem);background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;margin-bottom:.1em}
.page-404 p{color:var(--muted);margin-bottom:1.5em;font-size:1.1rem}

/* ---------- 25. Admin Panel Helpers ---------- */
.ad-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.ad-side{background:var(--bg-2);border-right:1px solid var(--line);padding:20px 14px;position:sticky;top:0;height:100vh;overflow-y:auto}
.ad-side .brand{font-size:1.05rem;margin-bottom:20px;padding:0 8px}
.ad-side nav{display:flex;flex-direction:column;gap:2px}
.ad-side a{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:.65em .85em;border-radius:10px;color:var(--muted);font-weight:600;font-size:.88rem;transition:.15s}
.ad-side a:hover{background:rgba(255,255,255,.05);color:var(--text)}
.ad-side a.on{background:var(--gold-grad);color:#2a1500}
.ad-side a.on:hover{color:#2a1500}
.ad-side .badge{background:var(--ember);color:#fff;font-size:.68rem;font-weight:700;padding:.06em .45em;border-radius:999px}
.ad-side a.on .badge{background:#2a1500;color:var(--gold-1)}
.ad-main{padding:24px 28px 60px;min-width:0}
.ad-main h1{font-size:1.6rem;margin-bottom:16px}
.ad-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:24px}
.ad-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:18px;
  transition:.15s;
}
.ad-card:hover{border-color:var(--line-2)}
.ad-card b{font-family:var(--ff-display);font-size:1.9rem;display:block;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.ad-card small{color:var(--faint);text-transform:uppercase;letter-spacing:.06em;font-size:.68rem;font-weight:700}
.ad-tbl{width:100%;border-collapse:collapse;font-size:.88rem}
.ad-tbl th,.ad-tbl td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
.ad-tbl th{color:var(--faint);font-size:.68rem;text-transform:uppercase;letter-spacing:.07em;font-weight:700}
.ad-tbl tr:hover td{background:rgba(255,255,255,.02)}
.ad-tbl .tbl-logo{width:38px;height:38px;border-radius:9px;object-fit:cover}
.ad-tools{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;align-items:center}
.ad-row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ad-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.ad-field{margin-bottom:12px}
.ad-field label{display:block;font-size:.8rem;font-weight:600;color:var(--faint);margin-bottom:4px;font-family:var(--ff-display)}
.ad-field input,.ad-field select,.ad-field textarea{
  width:100%;padding:.65em .85em;border-radius:8px;background:var(--bg-3);border:1px solid var(--line-2);
  color:var(--text);font-family:inherit;font-size:.9rem;transition:.15s;
}
.ad-field input:focus,.ad-field select:focus,.ad-field textarea:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(245,158,11,.1)}
.ad-btm{display:flex;gap:8px;margin-top:16px}
.ad-btm .btn{font-size:.85rem;padding:.6em 1em}

/* ---------- 26. Advertiser Panel Helpers ---------- */
.adv-wrap{max-width:520px;margin:0 auto;padding:30px 20px 60px}
.adv-hero{padding:30px 0 10px;text-align:center}
.adv-hero h1{font-size:clamp(1.6rem,3.5vw,2.2rem)}
.adv-panel{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start}
.adv-sidebar{position:sticky;top:calc(var(--header-h) + 20px)}
.adv-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-bottom:16px;
}
.adv-card h3{font-size:1.1rem;margin-bottom:.4em}
.adv-card p{color:var(--muted);font-size:.88rem}

/* ---------- 27. Misc ---------- */
.list-enter{opacity:0;transform:translateY(10px)}
.list-enter-active{transition:opacity .25s,transform .25s}
.list-exit{opacity:1;transform:translateY(0)}
.list-exit-active{transition:opacity .2s,transform .2s;opacity:0;transform:translateY(-6px)}

/* ---------- 28. Responsive ---------- */
@media(max-width:1120px){
  .shell{grid-template-columns:200px minmax(0,1fr);gap:20px}
  .rail-right{display:none}
}
@media(max-width:900px){
  .shell{grid-template-columns:1fr;padding-top:20px}
  .rail{position:static;display:none}
  .ad-banner{min-height:100px}
  .home-grid{grid-template-columns:1fr}
  .filter-panel{position:static}
  .adv-panel{grid-template-columns:1fr}
  .adv-sidebar{position:static}
}
@media(max-width:820px){
  .nav{position:fixed;inset:var(--header-h) 0 auto 0;flex-direction:column;align-items:stretch;gap:0;padding:10px;
    background:var(--bg-2);border-bottom:1px solid var(--line);transform:translateY(-125%);transition:transform .25s;margin:0}
  .nav.open{transform:translateY(0)}
  .nav a{padding:.85em 1em}
  .nav .btn{margin:8px 0 0}
  .nav-toggle{display:grid}
  .featured-in{flex-direction:column;text-align:center;gap:18px}
  .featured .cta{justify-content:center}
  .srv-hero{justify-content:center;text-align:center}
  .srv{grid-template-columns:36px 48px minmax(0,1fr);gap:12px;padding:12px}
  .srv .logo{width:48px;height:48px}
  .srv .right{grid-column:1/-1;flex-direction:row;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:10px;margin-top:4px}
  .footer-in{grid-template-columns:1fr 1fr}
  .servers.is-cards{grid-template-columns:1fr}
}
@media(max-width:640px){
  .wrap{padding:0 16px}
  .hero{min-height:0;margin-bottom:24px}
  .hero-content{padding:28px 28px 30px}
  .hero h1{font-size:clamp(1.78rem,8vw,2.25rem)}
  .hero .lead{font-size:1rem;line-height:1.55}
  .featured{margin-top:6px}
  .featured-in{padding:34px 24px 24px;gap:14px}
  .featured .logo{width:86px;height:86px;border-radius:18px}
  .featured h2{font-size:1.55rem}
  .featured .desc{
    display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;
    overflow:hidden;font-size:.96rem;line-height:1.55;margin-bottom:.8em;
  }
  .hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
  .hero-stats .st{min-width:0;padding:10px}
  .hero-stats .st b{font-size:1.1rem}
  .grid-2{grid-template-columns:1fr}
  .cookie-banner__inner{flex-direction:column;text-align:center;gap:12px;padding:16px}
  .cookie-banner__btn{width:100%;justify-content:center}
}
@media(max-width:520px){
  .footer-in{grid-template-columns:1fr}
  .srv .reacts{display:none}
  .srv .right{gap:8px}
  .ad-shell{grid-template-columns:1fr}
  .ad-side{position:static;height:auto;border-right:none;border-bottom:1px solid var(--line)}
  .ad-row2,.ad-row3{grid-template-columns:1fr}
  .pkg-grid,.steps,.benefits{grid-template-columns:1fr}
}
@media(max-width:420px){
  .featured .cta{flex-direction:column;align-items:stretch}
  .featured .cta .btn{width:100%}
  .srv .online{font-size:.92rem}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
}

/* =========================================================
   v6 overrides - Clean Cards, Left Filter, Hero BG
   ========================================================= */
.hero{position:relative;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:32px;min-height:260px;display:flex;align-items:flex-end}
.hero-bg{position:absolute;inset:0;z-index:0;background:linear-gradient(135deg,#111318 0%,#1a1d26 50%,#1c1e22 100%)}
.hero-bg::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(124,58,237,.12),transparent 55%),radial-gradient(ellipse at 70% 50%,rgba(245,158,11,.08),transparent 55%)}
.hero-content{position:relative;z-index:1;padding:32px 28px;width:100%}
.hero-stats .st{background:rgba(0,0,0,.3)}

.home-grid{display:grid;grid-template-columns:260px 1fr;gap:24px;align-items:start;margin-top:24px}
.filter-panel{position:sticky;top:calc(var(--header-h) + 20px)}
.filter-card{border:1px solid var(--line-2);border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--surface),var(--surface-2));padding:28px;box-shadow:var(--shadow-sm);}
.filter-card h2{font-size:1.25rem;margin-bottom:20px;color:var(--text);}
.filter-search input{width:100%;border:1px solid var(--line-2);border-radius:8px;background:var(--bg-2);color:var(--text);padding:.65em .85em;font:inherit;font-size:.9rem}
.filter-search input:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(245,158,11,.12)}
.filter-card .filters{display:grid;gap:10px;margin-top:16px}
.filter{border-radius:8px;padding:.55em .75em;background:var(--bg-3);border:1px solid var(--line);color:var(--muted);font-family:var(--ff-body);font-size:.8rem;font-weight:600;cursor:pointer;transition:.15s}
.filter:hover{border-color:var(--line-2);color:var(--text)}
.filter.active{background:rgba(245,158,11,.15);color:var(--amber-2);border-color:rgba(245,158,11,.4)}

.srv-card{display:flex;align-items:center;gap:16px;padding:14px 18px;border-radius:var(--radius);border:1px solid var(--line);background:var(--surface);transition:border-color .2s, transform .2s, box-shadow .2s}
.srv-card:hover{border-color:var(--line-2);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.srv-closed{opacity:.55}
.srv-logo{width:60px;height:60px;border-radius:14px;object-fit:cover;border:2px solid var(--line-2);background:var(--surface-3);flex-shrink:0;overflow:hidden;display:block;transition:transform .2s}
.srv-logo .logo-ph{width:100%;height:100%;font-size:1.5rem}
.srv-card:hover .srv-logo{transform:scale(1.05)}
.srv-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}
.srv-title-line{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.srv-name{font-family:var(--ff-display);font-size:1.1rem;font-weight:700;margin:0}
.srv-name a{color:var(--text)}
.srv-name a:hover{color:var(--amber-2)}
.srv-meta-line{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.srv-click-badge{font-family:var(--ff-display);font-size:.85rem;font-weight:700;color:var(--muted);white-space:nowrap;margin-left:auto}
.srv-meta-line .reacts{display:flex;gap:5px}
.srv-meta-line .react{font-size:.72rem;padding:.15em .45em}

.servers.is-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.servers.is-cards .srv-card{flex-direction:column;align-items:stretch;gap:16px;padding:24px;border-radius:var(--radius-lg);border:1px solid var(--line);background:linear-gradient(180deg,var(--surface),var(--surface-2));transition:border-color .2s, transform .2s, box-shadow .2s, background .2s;}
.servers.is-cards .srv-card:hover{border-color:var(--line-2);transform:translateY(-4px);box-shadow:var(--shadow);background:linear-gradient(180deg,var(--surface-2),var(--surface-3))}
.servers.is-cards .srv-logo{width:56px;height:56px;align-self:flex-start}
.servers.is-cards .srv-meta-line{width:100%;margin-top:auto}

@media(max-width:900px){
  .home-grid{grid-template-columns:1fr}
  .filter-panel{position:static;margin-bottom:20px}
  .filter-card{padding:22px}
  .filter-card .filters{grid-template-columns:repeat(auto-fit,minmax(118px,1fr))}
  .servers.is-cards{grid-template-columns:1fr}
}
@media(max-width:640px){
  .home-grid{grid-template-columns:1fr}
  .filter-card h2{margin-bottom:12px}
  .filter-card .filters{grid-template-columns:1fr 1fr}
  .srv-card{align-items:flex-start;gap:12px;padding:14px}
  .srv-logo{width:52px;height:52px;border-radius:12px}
  .srv-logo .logo-ph{font-size:1.25rem}
  .srv-title-line{gap:7px}
  .srv-name{font-size:1rem;line-height:1.18}
  .srv-meta-line{gap:8px}
  .srv-meta-line .reacts{order:2;width:100%;flex-wrap:wrap}
  .srv-meta-line .srv-click-badge{order:-1;width:100%;margin-left:0}
  .srv-meta-line .btn{margin-left:0}
  .cookie-banner{bottom:10px;left:10px;right:10px}
  .cookie-banner__inner{
    display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;
    gap:8px 12px;text-align:left;padding:12px;border-radius:12px;
  }
  .cookie-banner__icon{display:none}
  .cookie-banner__text{font-size:.78rem;line-height:1.35}
  .cookie-banner__text strong{font-size:.86rem;margin-bottom:1px}
  .cookie-banner__btn{width:auto;min-width:92px;padding:9px 12px}
}
@media(max-width:420px){
  .filter-card{padding:18px}
  .filter-card .filters{grid-template-columns:1fr 1fr}
  .srv-card{display:grid;grid-template-columns:52px minmax(0,1fr)}
  .srv-logo{grid-row:1 / span 2}
  .srv-meta-line{grid-column:1 / -1}
}

/* =========================================================
   v7 simplification - reference-aligned listing experience
   ========================================================= */
body::before{
  background:
    radial-gradient(760px 420px at 50% -10%,rgba(245,158,11,.05),transparent 60%),
    var(--bg);
}
body::after{opacity:.12}

.wrap{max-width:1120px}

.hero{
  display:block;min-height:0;margin:16px 0 14px;border:1px solid var(--line);
  border-radius:12px;background:#151820;box-shadow:none;
}
.hero-bg{background:linear-gradient(180deg,#171a22,#14171f)}
.hero-bg::before{background:linear-gradient(90deg,rgba(245,158,11,.06),transparent 42%)}
.hero-content{
  display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;
  gap:8px 18px;padding:20px 22px;
}
.hero .eyebrow{grid-column:1 / -1;font-size:.66rem;letter-spacing:.16em}
.hero h1{font-size:clamp(1.65rem,3.1vw,2.35rem);margin:0;max-width:900px}
.hero .lead{font-size:.98rem;line-height:1.55;max-width:68ch;margin:0;color:#adb3bd}
.hero-stats{grid-column:2;grid-row:2;gap:8px;margin:0;justify-content:flex-end}
.hero-stats .st{
  min-width:86px;padding:9px 11px;border-radius:8px;background:rgba(0,0,0,.22);
}
.hero-stats .st b{font-size:1.08rem}
.hero-stats .st small{font-size:.62rem}
.hero .btn-lg{display:none}

.featured{
  margin:0 0 18px;padding:1px;border-radius:12px;
  background:linear-gradient(135deg,rgba(245,158,11,.8),rgba(236,72,153,.7));
  animation:none;box-shadow:0 10px 30px -24px rgba(236,72,153,.55);
}
.featured-in{
  border-radius:11px;padding:18px 18px 16px;gap:16px;
  background:linear-gradient(180deg,#1a1d25,#171a22);
}
.featured-in::before{display:none}
.featured-in:hover{transform:none;box-shadow:none}
.featured-badge{
  left:14px;font-size:.66rem;padding:5px 11px 6px;border-radius:0 0 7px 7px;
  box-shadow:0 5px 16px rgba(245,158,11,.22);
}
.featured .logo{
  width:68px;height:68px;border-radius:14px;border-width:1px;
  box-shadow:0 8px 20px rgba(0,0,0,.32);
}
.featured h2{font-size:1.45rem;margin:.05em 0 .25em}
.featured .meta{gap:7px;margin-bottom:.35em}
.featured .desc{
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;font-size:.92rem;line-height:1.5;margin-bottom:.75em;max-width:78ch;
}
.featured .cta{gap:8px}
.featured .btn{padding:.55em .85em;font-size:.82rem;border-radius:8px}
.online-big b{font-size:1.42rem}
.online-big small{font-size:.68rem;letter-spacing:.08em}

.home-grid{
  grid-template-columns:minmax(0,1fr) 300px;gap:18px;margin-top:0;
}
.server-section{grid-column:1;grid-row:1}
.filter-panel{grid-column:2;grid-row:1}
.filter-card{
  border-radius:10px;padding:18px;background:linear-gradient(180deg,#1b1f28,#171b23);
  box-shadow:none;
}
.filter-card h2{font-size:1.08rem;margin-bottom:12px}
.filter-search input{border-radius:7px;padding:.62em .78em}
.filter-card .filters{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.filter{
  border-radius:6px;padding:.38em .68em;font-size:.77rem;line-height:1.15;
  background:rgba(0,0,0,.24);
}

.sec-head{
  margin-bottom:12px;padding:0 2px;align-items:center;
}
.sec-head h2{font-size:1.55rem}
.sec-head p{font-size:.86rem}
.view-toggle{border-radius:9px;padding:4px}
.view-toggle-btn{width:34px;height:34px;border-radius:7px}

.servers{gap:8px}
.srv-card{
  min-height:74px;padding:12px 14px;border-radius:10px;
  background:linear-gradient(180deg,#181c25,#151922);
}
.srv-card:hover{transform:none;box-shadow:none}
.srv-logo{width:52px;height:52px;border-radius:11px;border-width:1px}
.srv-logo .logo-ph{font-size:1.22rem}
.srv-card:hover .srv-logo{transform:none}
.srv-title-line{gap:7px}
.srv-name{font-size:1rem}
.pill{font-size:.64rem;padding:.22em .52em}
.srv-meta-line{gap:7px}
.srv-meta-line .react{font-size:.68rem;padding:.12em .42em;background:rgba(255,255,255,.035)}
.srv-click-badge{font-size:.78rem}
.srv-meta-line .btn{padding:.48em .7em;font-size:.76rem;border-radius:7px}

.servers.is-cards{gap:10px}
.servers.is-cards .srv-card{padding:16px;border-radius:10px;gap:12px}
.servers.is-cards .srv-card:hover{transform:none;box-shadow:none}

.panel{border-radius:10px;padding:22px;margin-top:24px}

@media(max-width:900px){
  .home-grid{display:grid;grid-template-columns:1fr;gap:16px}
  .server-section{grid-column:1;grid-row:1;order:1}
  .filter-panel{grid-column:1;grid-row:2;order:2;position:static;margin-bottom:0}
  .filter-card .filters{display:flex;grid-template-columns:none}
}

@media(max-width:640px){
  .wrap{padding:0 16px}
  .hero{margin:14px 0 14px;border-radius:12px}
  .hero-content{display:block;padding:22px 28px}
  .hero .eyebrow{margin-bottom:8px}
  .hero h1{font-size:clamp(1.6rem,7vw,2rem);line-height:1.12;margin-bottom:10px}
  .hero .lead{font-size:.94rem;line-height:1.52}
  .hero-stats{display:none}
  .featured{margin-bottom:18px}
  .featured-in{padding:34px 18px 18px;gap:12px}
  .featured .logo{width:74px;height:74px}
  .featured h2{font-size:1.38rem}
  .featured .desc{-webkit-line-clamp:2;font-size:.9rem}
  .featured .cta{display:grid;grid-template-columns:1fr 1fr;width:100%}
  .featured .cta .reacts{grid-column:1 / -1}
  .featured .btn{width:100%}
  .sec-head{align-items:center;gap:10px}
  .srv-card{display:grid;grid-template-columns:50px minmax(0,1fr);align-items:center}
  .srv-logo{width:50px;height:50px}
  .srv-body{gap:7px}
  .srv-title-line{align-items:center}
  .srv-meta-line{grid-column:auto;display:flex;align-items:center;gap:8px}
  .srv-meta-line .reacts{display:none}
  .srv-meta-line .srv-click-badge{order:0;width:auto;margin:0 auto 0 0}
  .srv-meta-line .btn{order:1;margin-left:0}
  .filter-card{padding:16px}
}

@media(max-width:420px){
  .featured .cta{grid-template-columns:1fr}
  .featured .cta .reacts{justify-content:center}
}
