/* ───── L2Rebirth — modern Interlude theme ───── */
:root{
  --bg:#06070a;
  --bg2:#0c0e14;
  --panel:rgba(14,18,28,.75);
  --panel-solid:#0e1320;
  --line:#2a3144;
  --line-dim:rgba(110,140,180,.18);
  --gold:#d9b56b;
  --gold-bright:#f0d189;
  --gold-dim:#7d6633;
  --ink:#dde6f3;
  --ink-dim:#8e9bb3;
  --blue:#5d8fbf;
  --teal:#3fb4c6;
  --orange:#ff7826;
  --orange-bright:#ffae3a;
  --green:#5ec46a;
  --red:#e25656;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Inter','Segoe UI',Verdana,sans-serif;
  /* one fixed atmospheric backdrop visible behind all sections (parallax-style) */
  background:
    linear-gradient(180deg, rgba(6,7,10,.55) 0%, rgba(6,7,10,.85) 60%, rgba(6,7,10,.95) 100%),
    url('/img/ai/hero_main.png') right top / cover no-repeat fixed,
    var(--bg);
  background-color:var(--bg);
  color:var(--ink);
  font-size:14px;line-height:1.55;
  overflow-x:hidden;
}

a{color:var(--gold);text-decoration:none;transition:color .15s}
a:hover{color:var(--gold-bright)}

h1,h2,h3,h4{font-family:'Cinzel','Trajan Pro',serif;color:var(--gold-bright);letter-spacing:.04em;font-weight:600}
h1{font-size:32px;margin-bottom:10px}
h2{font-size:22px;margin:18px 0 10px}
h3{font-size:16px;margin:10px 0 6px;color:var(--gold)}
p{margin:6px 0}

/* ── Header / Nav ── */
header.hd{
  position:fixed;top:0;left:0;right:0;z-index:50;
  /* ornament ribbon only (slate margins cropped off), centred in the bar;
     top/bottom margins are fully transparent so the page background shows
     through — no black bands */
  background:
    url('/img/ai/ui_header_strip_t.png?v=8') center/auto 64% repeat-x,
    transparent;
  border-bottom:1px solid var(--line-dim);
  -webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  will-change:transform;
}
/* hidden when scrolling down; JS toggles the class, slides back on scroll-up */
header.hd.nav-hidden{transform:translateY(-100%)}
.hd-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;gap:14px;padding:11px 22px}
.brand{display:flex;align-items:center;gap:14px}
.brand .logo{
  width:62px;height:62px;
  /* logo_main_t.png = pre-processed by strip_black_bg.js, fully transparent */
  background:url('/img/ai/logo_main_t.png') center/contain no-repeat;
  animation:logoPulse 3.6s ease-in-out infinite;
}
@keyframes logoPulse{
  0%,100%{filter:drop-shadow(0 0 5px rgba(240,209,137,.3));transform:scale(1)}
  50%{filter:drop-shadow(0 0 13px rgba(240,209,137,.6)) drop-shadow(0 0 22px rgba(63,180,198,.35));transform:scale(1.05)}
}
.brand .name{font-family:'Cinzel',serif;font-size:22px;color:var(--gold-bright);letter-spacing:.16em;text-shadow:0 0 14px rgba(240,209,137,.4)}
.brand .sub{font-size:10px;color:var(--ink-dim);letter-spacing:.34em;text-transform:uppercase;margin-top:2px}
nav.main{display:flex;gap:0;margin-left:auto;flex-wrap:nowrap}
nav.main a{
  position:relative;padding:8px 11px;color:var(--ink);font-size:12.5px;
  text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;
}
nav.main a::after{
  content:"";position:absolute;left:50%;bottom:4px;width:0;height:1px;background:var(--gold);transition:all .2s;transform:translateX(-50%);
}
nav.main a:hover{color:var(--gold-bright)}
nav.main a:hover::after,nav.main a.active::after{width:60%}
nav.main a.active{color:var(--gold-bright)}

.status-pill{
  display:inline-flex;align-items:center;gap:7px;font-size:11px;
  padding:6px 13px;border-radius:99px;border:1px solid var(--line-dim);
  background:rgba(6,7,10,.6);backdrop-filter:blur(6px);white-space:nowrap;
}
.status-pill .sep{width:1px;height:12px;background:var(--line);display:inline-block;opacity:.7}
.online-num{color:var(--green);font-weight:700;text-shadow:0 0 8px rgba(94,196,106,.55)}

/* Hamburger toggle (hidden on desktop) */
.nav-toggle{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:38px;height:32px;padding:7px 7px;margin-left:auto;cursor:pointer;
  background:rgba(6,7,10,.5);border:1px solid var(--line);border-radius:6px;
}
.nav-toggle span{display:block;height:2px;width:100%;background:var(--gold);border-radius:2px;transition:.25s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── Responsive ── */
@media(max-width:980px){
  nav.main a{padding:8px 9px;font-size:12px}
  .status-pill .t{display:none}      /* keep dots + online number only */
}
@media(max-width:880px){
  .nav-toggle{display:flex}
  .hd-inner{flex-wrap:wrap;gap:10px}
  .brand{order:1}
  .status-pill{order:2;margin-left:auto}
  .nav-toggle{order:3;margin-left:0}
  nav.main{
    order:4;flex-basis:100%;
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:linear-gradient(180deg,#0c0e14 0%,#070809 100%);
    border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    box-shadow:0 14px 30px rgba(0,0,0,.5);
    padding:4px 0;display:none;
  }
  nav.main.open{display:flex}
  nav.main a{padding:13px 22px;font-size:13px;letter-spacing:.08em;border-bottom:1px solid var(--line-dim)}
  nav.main a:last-child{border-bottom:none}
  nav.main a::after{display:none}
  nav.main a.active{background:rgba(217,181,107,.08)}
}
@media(max-width:600px){
  .status-pill{font-size:10px;padding:5px 9px;gap:5px}
  .brand .name{font-size:18px}
  .brand .logo{width:48px;height:48px}
  .hd-inner{padding:9px 14px}
  .container{padding:0 16px}
}
.dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 8px var(--red)}
.dot.on{background:var(--green);box-shadow:0 0 10px var(--green)}

/* ── Hero — full bleed (uses body bg image, only adds darken overlay) ── */
.hero-full{
  position:relative;width:100%;min-height:100vh;
  /* purely an overlay — the actual image lives on the body */
  background:linear-gradient(90deg, rgba(6,7,10,.85) 0%, rgba(6,7,10,.4) 38%, rgba(6,7,10,0) 70%);
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.hero-full::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(6,7,10,0) 0%, rgba(6,7,10,0) 60%, rgba(6,7,10,.85) 100%);
  pointer-events:none;
}
.corner-ornament{
  position:absolute;width:280px;height:280px;pointer-events:none;
  background:url('/img/ai/ui_corner_ornament.png') no-repeat;background-size:contain;
  mix-blend-mode:screen;opacity:.85;
}
.corner-ornament.tl{top:-10px;left:-10px}
.corner-ornament.tr{top:-10px;right:-10px;transform:scaleX(-1)}

.hero-inner{
  position:relative;z-index:10;
  max-width:1280px;margin:0 auto;padding:140px 24px 60px;
  display:flex;align-items:center;min-height:100vh;
}
.hero-text{max-width:560px;width:100%}
.hero-tag{
  display:inline-block;font-size:11px;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);padding:5px 12px;border:1px solid var(--gold-dim);border-radius:99px;background:rgba(6,7,10,.4);
}
.hero-brand{
  font-family:'Cinzel',serif;font-size:80px;line-height:.95;margin:18px 0 6px;
  color:#fff;letter-spacing:.06em;
  text-shadow:
    0 0 18px rgba(240,209,137,.5),
    0 0 60px rgba(63,180,198,.4),
    0 4px 0 rgba(0,0,0,.65);
}
.hero-sub{font-family:'Cinzel',serif;font-size:18px;color:var(--ink-dim);letter-spacing:.18em;text-transform:uppercase;margin-bottom:28px}
.hero-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:30px}
.hero-meta .chip{
  background:rgba(14,18,28,.65);border:1px solid var(--line-dim);
  padding:8px 14px;border-radius:4px;font-size:12px;
  display:flex;align-items:center;gap:8px;
}
.hero-meta .chip b{color:var(--gold-bright)}
/* two-line hero tagline (replaces the old stat chips) */
.hero-lines{margin:10px 0 28px}
.hero-lines .l1{font-family:'Cinzel',serif;font-size:21px;color:var(--gold-bright);letter-spacing:.03em;text-shadow:0 0 14px rgba(240,209,137,.25)}
.hero-lines .l2{font-size:16px;color:var(--ink-dim);margin-top:6px;letter-spacing:.05em}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}

/* CTA button — the AI-generated button art, baked to exact aspect by
   scripts/make_buttons.js (520x130) and shown at half size (260x65) as a plain
   fixed-size background — 1:1 mapping, so NO runtime stretch/distortion. */
.btn-cta{
  display:inline-flex;align-items:center;justify-content:center;
  box-sizing:border-box;width:260px;height:65px;
  background:url('/img/ai/btn_primary_wide.png') center/100% 100% no-repeat;
  padding:0 18px;
  font-family:'Cinzel',serif;font-weight:600;font-size:14px;
  letter-spacing:.12em;text-transform:uppercase;color:#fff;cursor:pointer;
  text-shadow:0 1px 3px rgba(0,0,0,.75),0 0 12px rgba(255,160,60,.4);
  transition:transform .15s, filter .15s;
}
.btn-cta:hover{transform:translateY(-1px);filter:brightness(1.1)}
.btn-cta:active{transform:translateY(0)}
/* secondary CTA (Download / Vote) — steel skin, gold text */
.btn-cta.ghost-cta{
  background-image:url('/img/ai/btn_secondary_wide.png');
  color:var(--gold-bright);
  text-shadow:0 1px 3px rgba(0,0,0,.8);
}
.btn-cta.ghost-cta:hover{filter:brightness(1.18)}
@media(max-width:480px){.btn-cta{width:100%}}

/* ── Living fire inside the PRIMARY button only ── */
.btn-cta:not(.ghost-cta){position:relative;overflow:hidden;isolation:isolate}

/* soft rising embers — blurred ovals (not hard dots), repeat vertically and drift up */
.btn-cta:not(.ghost-cta)::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    radial-gradient(2.6px 4px at 16% 84%, rgba(255,206,120,.95), rgba(255,150,60,0) 72%),
    radial-gradient(2px 3px   at 33% 58%, rgba(255,170,72,.9),  rgba(255,120,40,0) 72%),
    radial-gradient(3.4px 5px at 52% 92%, rgba(255,224,150,.85), rgba(255,150,60,0) 74%),
    radial-gradient(2px 3.2px at 68% 50%, rgba(255,160,60,.9),  rgba(255,110,30,0) 72%),
    radial-gradient(3px 4.4px at 84% 80%, rgba(255,210,124,.9), rgba(255,140,50,0) 74%),
    radial-gradient(1.8px 2.8px at 92% 40%, rgba(255,234,176,.8), rgba(255,150,60,0) 72%);
  background-repeat:repeat-y;
  background-size:100% 150px;            /* one seamless tile = 150px */
  filter:blur(.7px);
  animation:emberFloat 5s linear infinite;
  -webkit-mask:linear-gradient(180deg,transparent 0,#000 26%,#000 74%,transparent 100%);
          mask:linear-gradient(180deg,transparent 0,#000 26%,#000 74%,transparent 100%);
  opacity:.9;
}
/* wavering flame base licking up from the bottom (over text, screen blend, blurred) */
.btn-cta:not(.ghost-cta)::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:78%;pointer-events:none;z-index:1;
  background:
    radial-gradient(58% 100% at 28% 100%, rgba(255,150,42,.55), rgba(255,90,20,0) 70%),
    radial-gradient(52% 100% at 58% 100%, rgba(255,108,28,.5),  rgba(255,80,16,0) 72%),
    radial-gradient(64% 100% at 82% 100%, rgba(255,182,74,.45), rgba(255,120,40,0) 70%);
  mix-blend-mode:screen;filter:blur(3px);transform-origin:bottom center;
  animation:flameLick 2.8s ease-in-out infinite;
}
@keyframes emberFloat{
  0%  {background-position:0 0}
  50% {background-position:7px -75px}
  100%{background-position:0 -150px}
}
@keyframes flameLick{
  0%,100%{transform:scaleY(1) translateX(0);opacity:.5}
  20%{transform:scaleY(1.14) translateX(-4px);opacity:.8}
  40%{transform:scaleY(.92)  translateX(3px); opacity:.4}
  60%{transform:scaleY(1.1)  translateX(-2px);opacity:.72}
  80%{transform:scaleY(.97)  translateX(2px); opacity:.55}
}

/* ── Download icon with a photon-in-a-tunnel highlight running the contour ── */
.btn-cta.with-icon{gap:9px}
.dl-ico{flex:0 0 auto;color:inherit}
.dl-ico .run{
  stroke-dasharray:16 84;          /* one bright 16% segment (pathLength=100) */
  stroke-dashoffset:0;
  filter:drop-shadow(0 0 3px var(--gold-bright)) drop-shadow(0 0 6px rgba(240,209,137,.6));
  animation:dlPhoton 2.2s linear infinite;
}
@keyframes dlPhoton{ to{ stroke-dashoffset:-100 } }

/* Glass card variant */
.gcard{
  background:linear-gradient(180deg, rgba(14,18,28,.78) 0%, rgba(8,10,16,.85) 100%);
  border:1px solid var(--line);border-radius:6px;
  backdrop-filter:blur(8px);
  box-shadow:0 8px 30px rgba(0,0,0,.55),inset 0 0 1px rgba(240,209,137,.12);
}
/* Dates card now flows inline under the CTA row (not absolute) */
.gcard.dates{
  margin-top:28px;padding:16px 20px;max-width:380px;
}
.gcard.dates h4{font-family:'Cinzel',serif;color:var(--gold-bright);font-size:13px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.gcard.dates .row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px dotted var(--line-dim);font-size:13px}
.gcard.dates .row:last-child{border:none}
.gcard.dates .row .v{font-family:'Cinzel',serif;color:var(--gold-bright);letter-spacing:.1em}

/* ── Below-hero content ── */
.section{padding:60px 0;position:relative;background:linear-gradient(180deg, rgba(6,7,10,.92) 0%, rgba(6,7,10,.95) 100%)}
.section.alt{background:linear-gradient(180deg, rgba(6,7,10,.96) 0%, rgba(10,12,20,.99) 100%)}
.container{max-width:1280px;margin:0 auto;padding:0 24px}
.row{display:flex;gap:24px;flex-wrap:wrap}
.col{flex:1;min-width:0}

.layout-split{display:grid;grid-template-columns:300px 1fr;gap:24px}
@media(max-width:880px){.layout-split{grid-template-columns:1fr}}

/* Sidebar */
.sidebar .gcard{padding:16px 18px;margin-bottom:16px}
.sidebar h3{margin-bottom:10px;font-size:14px;letter-spacing:.2em;text-transform:uppercase}
.server-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border:1px solid var(--line-dim);border-radius:4px;margin-bottom:6px;background:rgba(0,0,0,.25)}
.server-row .name{font-size:13px;color:var(--ink)}
.server-row .stt{font-size:11px;color:var(--ink-dim);display:flex;align-items:center;gap:6px}

/* Section title with bar */
.s-title{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.s-title h2{margin:0}
.s-title .bar{flex:1;height:1px;background:linear-gradient(90deg,var(--gold-dim) 0%, transparent 100%)}

/* Feature grid */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.features{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.features{grid-template-columns:1fr}}
.feature{
  padding:26px 24px;border:1px solid var(--line);border-radius:8px;
  background:linear-gradient(180deg, rgba(20,26,40,.6) 0%, rgba(8,10,16,.88) 100%);
  position:relative;
  transition:transform .2s,border-color .2s;
}
/* inner ornamental frame — wide (close to card edge) so content never spills past it */
.feature::before{
  content:"";position:absolute;inset:6px;border:1px solid rgba(217,181,107,.13);border-radius:5px;pointer-events:none;
}
.feature:hover{transform:translateY(-3px);border-color:var(--gold-dim)}
.feature:hover::before{border-color:rgba(217,181,107,.26)}
/* Circular frame around each feature icon — bg fills, edges get clipped to circle */
.feature .ico{
  width:56px;height:56px;margin-bottom:14px;border-radius:50%;
  background-position:center;background-repeat:no-repeat;background-size:cover;
  border:1px solid var(--gold-dim);
  box-shadow:
    inset 0 0 14px rgba(0,0,0,.55),
    0 0 14px rgba(240,209,137,.22);
  overflow:hidden;
  position:relative;
}
.feature .ico::after{
  /* subtle inner gold rim */
  content:"";position:absolute;inset:2px;border-radius:50%;
  box-shadow:inset 0 0 0 1px rgba(240,209,137,.18);
  pointer-events:none;
}
.feature h3{margin-top:0;color:var(--gold-bright)}
.feature p{font-size:13px;color:var(--ink-dim)}

/* Character cards row */
.chars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:24px}
@media(max-width:900px){.chars{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.chars{grid-template-columns:1fr}}
.char-card{
  position:relative;height:380px;border-radius:8px;overflow:hidden;
  border:1px solid var(--line);
  background:#000;cursor:pointer;
  transition:transform .25s, border-color .2s;
}
.char-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s}
.char-card::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(6,7,10,.95) 100%);
  pointer-events:none;
}
.char-card .cap{position:absolute;left:0;right:0;bottom:0;padding:16px 18px;z-index:2}
.char-card .cap h3{margin:0;color:var(--gold-bright);font-size:18px}
.char-card .cap p{font-size:12px;color:var(--ink-dim);letter-spacing:.04em}
.char-card:hover{transform:translateY(-3px);border-color:var(--gold-dim)}
.char-card:hover img{transform:scale(1.04)}

/* Tables */
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl th{
  text-align:left;padding:10px 12px;
  background:linear-gradient(180deg,#15192a,#0d1018);
  color:var(--gold);border-bottom:1px solid var(--line);
  font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:11px;
}
table.tbl td{padding:9px 12px;border-bottom:1px solid var(--line-dim)}
table.tbl tr:hover td{background:rgba(217,181,107,.04)}
table.tbl td.rank{width:42px;text-align:center;color:var(--gold);font-weight:600;font-family:'Cinzel',serif}

/* Generic buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;
  border:1px solid var(--gold-dim);background:linear-gradient(180deg,#1a1d2a 0%,#0c0e16 100%);
  color:var(--gold-bright);font-size:13px;text-transform:uppercase;letter-spacing:.12em;
  border-radius:4px;cursor:pointer;font-family:inherit;transition:all .15s;
}
.btn:hover{background:linear-gradient(180deg,#252a3a 0%,#11151f 100%);color:#fff;box-shadow:0 0 14px rgba(240,209,137,.25)}
.btn.primary{background:linear-gradient(180deg,#5a4623 0%,#3a2c14 100%);color:#fff}
.btn.primary:hover{background:linear-gradient(180deg,#7a5e30 0%,#4d3a1a 100%)}
.btn.ghost{background:transparent}

/* Forms */
form.form label{display:block;margin:10px 0 4px;color:var(--ink-dim);font-size:12px;text-transform:uppercase;letter-spacing:.08em}
form.form input[type=text],form.form input[type=password],form.form input[type=email],form.form textarea,form.form select{
  width:100%;padding:11px 14px;background:#0a0d17;color:var(--ink);
  border:1px solid var(--line);border-radius:4px;font-family:inherit;font-size:14px;
  outline:none;transition:border-color .15s;
}
form.form input:focus,form.form textarea:focus,form.form select:focus{border-color:var(--gold);box-shadow:0 0 0 1px rgba(217,181,107,.2)}

.alert{padding:11px 16px;border-radius:4px;margin-bottom:14px;font-size:13px}
.alert.err{background:rgba(226,86,86,.12);border:1px solid #6a2222;color:#f6b1b1}
.alert.ok{background:rgba(94,196,106,.12);border:1px solid #2d5e34;color:#bce6c2}
.alert.info{background:rgba(93,143,191,.12);border:1px solid #2b4a6e;color:#c3d8f6}

/* Stats cards */
.stat-card{padding:18px;border:1px solid var(--line);border-radius:6px;background:rgba(14,18,28,.65);text-align:center}
.stat-card .v{font-size:28px;color:var(--gold-bright);font-family:'Cinzel',serif;line-height:1}
.stat-card .l{font-size:11px;color:var(--ink-dim);text-transform:uppercase;letter-spacing:.2em;margin-top:6px}

.list-clean{list-style:none;padding:0}
.list-clean li{padding:8px 0;border-bottom:1px dotted var(--line-dim);display:flex;align-items:flex-start;gap:10px}
.list-clean li:last-child{border-bottom:none}
.list-clean .check{flex-shrink:0;color:var(--green);font-weight:700;width:22px;text-align:center}
.list-clean b{color:var(--gold-bright)}

/* Footer */
footer.ft{
  background:linear-gradient(0deg,#04050a 0%,#0a0c14 100%);
  border-top:1px solid var(--line);padding:24px 0;font-size:12px;color:var(--ink-dim);text-align:center;
  margin-top:60px;
}

/* Misc */
.muted{color:var(--ink-dim)}
.gold{color:var(--gold)}
.right{text-align:right}
.center{text-align:center}
.mt{margin-top:14px}.mb{margin-bottom:14px}.mt2{margin-top:30px}
.flex{display:flex;gap:10px;align-items:center}
.between{justify-content:space-between}
.badge{display:inline-block;padding:2px 8px;font-size:11px;border-radius:99px;background:rgba(217,181,107,.12);color:var(--gold);border:1px solid var(--gold-dim)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:780px){.grid-2,.grid-3{grid-template-columns:1fr};.hero-brand{font-size:54px}}
@media(max-width:780px){
  /* fixed background performs poorly on mobile; release it */
  body{background-attachment:scroll;background-position:60% top}
  .hero-inner{padding:110px 18px 50px;min-height:88vh}
  .hero-brand{font-size:46px}
  .hero-lines .l1{font-size:18px}
  .hero-lines .l2{font-size:14px}
  .section{padding:42px 0}
  .features{gap:14px}
}
@media(max-width:480px){
  .hero-brand{font-size:38px}
  .hero-sub{font-size:14px;letter-spacing:.1em}
  .cta-row{width:100%}
  .btn-cta{width:100%}
}

.video-embed{position:relative;padding-top:56.25%;border:1px solid var(--line);border-radius:6px;overflow:hidden;background:#000}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* Generic page wrapper for non-home pages */
.page-content{padding:120px 0 40px}

/* ── Server status fieldset — Login/Game grouped under the server name ── */
.srv-group{
  border:1px solid var(--gold-dim);border-radius:6px;
  padding:8px 14px 6px;margin-top:8px;background:rgba(0,0,0,.22);
}
.srv-group legend{
  padding:0 8px;color:var(--gold-bright);
  font-family:'Cinzel',serif;font-size:14px;letter-spacing:.08em;
}
.srv-line{display:flex;align-items:center;justify-content:space-between;padding:7px 2px;border-bottom:1px dotted var(--line-dim);font-size:13px}
.srv-line:last-child{border-bottom:none}
.srv-line .stt{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;letter-spacing:.06em}
.srv-line .stt.up{color:var(--green)}
.srv-line .stt.down{color:var(--red)}

/* ── Toplist badges hanging from the header on chains ── */
.hang-badges{
  position:absolute;top:100%;right:60px;z-index:45;
  display:flex;gap:34px;pointer-events:none;
}
.hang{
  pointer-events:auto;display:flex;flex-direction:column;align-items:center;
  text-decoration:none;transform-origin:top center;
  animation:sway 6s ease-in-out infinite;
}
.hang:nth-child(2){animation-delay:-3s}
.hang .chain{
  display:block;width:16px;height:var(--len,80px);
  filter:drop-shadow(0 1px 1.5px rgba(0,0,0,.65));
}
.hang .plate{
  margin-top:-1px;padding:9px 15px;white-space:nowrap;
  font-family:'Cinzel',serif;font-size:13px;letter-spacing:.06em;color:var(--gold-bright);
  background:linear-gradient(180deg,#23262f 0%,#11131b 100%);
  border:1px solid var(--gold-dim);border-radius:4px;
  box-shadow:0 7px 16px rgba(0,0,0,.55),inset 0 0 0 1px rgba(240,209,137,.08);
}
.hang .plate b{color:#fff;margin-right:1px}
.hang:hover .plate{border-color:var(--gold);box-shadow:0 0 16px rgba(240,209,137,.45)}
@keyframes sway{0%,100%{transform:rotate(-2.5deg)}50%{transform:rotate(2.5deg)}}
@media(max-width:900px){.hang-badges{display:none}}

/* Particles — pure CSS embers floating up */
.embers{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:5}
.embers span{
  position:absolute;bottom:-10px;width:4px;height:4px;border-radius:50%;
  background:radial-gradient(circle, #ff9a3c 0%, rgba(255,154,60,0) 70%);
  animation:ember 8s linear infinite;opacity:.7;
}
@keyframes ember{
  0%{transform:translateY(0) translateX(0);opacity:0}
  10%{opacity:.9}
  90%{opacity:.6}
  100%{transform:translateY(-110vh) translateX(40px);opacity:0}
}
