*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,Segoe UI,Arial,sans-serif;
  color:#f4f6ff;
  background:
    radial-gradient(circle at 10% 10%, rgba(0,223,255,.08), transparent 18%),
    radial-gradient(circle at 90% 10%, rgba(255,0,140,.08), transparent 18%),
    linear-gradient(90deg,#04070f 0%,#060b1a 16%,#10163d 55%,#0c1438 100%);
  min-height:100vh;
}
.topbar{
  position:sticky; top:0; z-index:100;
  background:linear-gradient(90deg,rgba(34,35,42,.95),rgba(39,40,59,.95),rgba(51,54,87,.95));
  border-bottom:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(18px);
}
.topnav{
  display:flex; gap:8px; align-items:center; justify-content:flex-start;
  padding:10px 12px; overflow:visible; flex-wrap:wrap;
}
.navbtn{
  white-space:nowrap; padding:9px 14px; border-radius:999px;
  background:rgba(255,255,255,.09); border:1px solid rgba(255,255,255,.09);
  color:#fff; text-decoration:none; font-weight:700; font-size:11px;
  box-shadow:0 8px 18px rgba(0,0,0,.18);
}
.navbtn.active{
  background:linear-gradient(90deg,#49dfff,#ff0f78);
}
.navbtn.logout{
  background:linear-gradient(90deg,#ff4f86,#ff2b6f);
}
.navbtn.smallclear{padding:10px 14px; font-size:11px}
.pink-outline{border-color:#ff247f}
.pagewrap{padding:18px 0 40px}
.loginwrap{padding-top:80px}
.flashstack{max-width:1040px;margin:0 auto 16px;padding:0 14px}
.flash{padding:12px 16px;border-radius:14px;margin-bottom:8px}
.flash.success{background:rgba(0,230,120,.12);border:1px solid rgba(0,230,120,.25)}
.flash.error{background:rgba(255,70,100,.12);border:1px solid rgba(255,70,100,.25)}

.centerhead{text-align:center;margin:6px 0 16px}
.page-title{
  margin:0;
  font-size:28px; font-weight:900;
  background:linear-gradient(90deg,#43cfff,#ff5ab0);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.title-underline{
  width:72px;height:3px;border-radius:999px;margin:10px auto 0;
  background:linear-gradient(90deg,#00e7ff,#ff1f89);
}
.panel{
  background:linear-gradient(180deg,rgba(51,53,78,.88),rgba(43,45,72,.88));
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  box-shadow:0 10px 30px rgba(0,0,0,.28);
}
.single-column{max-width:760px;margin:0 auto;display:grid;gap:18px;padding:0 14px}
.single-column.widecol{max-width:1000px}
.form-card{max-width:430px;margin:0 auto;padding:20px}
.quick-card{max-width:430px;margin:0 auto;padding:18px}
.filters-panel{max-width:100%;margin:0 auto 20px;padding:20px 14px;border-radius:0}
.table-panel{margin:0 0 0;padding:0;border-radius:18px 18px 0 0;overflow:hidden}
.loginpanel{max-width:560px;margin:0 auto;padding:0 14px;text-align:center}
.loginpanel .panel.narrow{padding:24px;max-width:400px;margin:18px auto 0}
.logo-box{
  width:92px;height:92px;margin:0 auto 18px;border-radius:22px;display:grid;place-items:center;
  font-size:46px;background:linear-gradient(135deg,#00dfff,#ff1f89);
  box-shadow:0 0 40px rgba(0,223,255,.2);
}
.brand-logo-box{
  width:164px;height:164px;padding:12px;border-radius:28px;
  background:radial-gradient(circle at top, rgba(255,184,48,.18), rgba(0,223,255,.08) 45%, rgba(255,31,137,.08));
  border:1px solid rgba(255,184,48,.25);
  box-shadow:0 18px 48px rgba(0,0,0,.32), 0 0 42px rgba(255,184,48,.18);
}
.login-brand-logo{
  display:block;max-width:100%;max-height:100%;width:140px;height:140px;object-fit:contain;filter:drop-shadow(0 10px 20px rgba(0,0,0,.45));
}
.stack{display:grid}
.gap16{gap:16px}
label{display:block;font-size:12px;font-weight:800;color:#dbe3ff;margin-bottom:6px}
input,select,textarea{
  width:100%;padding:13px 14px;border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(118,120,144,.25); color:#fff;
  outline:none;
}
textarea{min-height:84px;resize:vertical}
input::placeholder, textarea::placeholder{color:#aeb6da}
.checkbox-row{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:700;color:#d7defe}
.checkbox-row.split{gap:18px;flex-wrap:wrap}
.checkbox-row input{width:auto}
.two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.btn-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.btn-row.single{grid-template-columns:1fr}
.gradient-btn,.quick-pill,.mini-delete{
  border:0;cursor:pointer;color:#fff;font-weight:900;border-radius:999px;
}
.gradient-btn{padding:13px 16px;background:linear-gradient(90deg,#2fdcff,#ff177f)}
.gradient-btn.cyan{background:linear-gradient(90deg,#72dfff,#33bbe0)}
.gradient-btn.pink{background:linear-gradient(90deg,#ff4f84,#f02b74)}
.gradient-btn.small{padding:11px 14px;font-size:11px}
.gradient-btn.wide{width:100%}
.quick-pill{padding:12px 18px;background:linear-gradient(90deg,#6f717e,#5a5d6f)}
.quick-pill.amber{background:linear-gradient(90deg,#ffbf1d,#ff9e00)}
.quick-pill.pink{background:linear-gradient(90deg,#ff4a89,#ea2e74)}
.mini-delete{
  padding:8px 14px;background:rgba(255,70,90,.18);border:1px solid rgba(255,90,110,.45)
}
.divider{height:1px;background:rgba(255,255,255,.08);margin:16px 0}
.softnote{color:#cfd5f1;font-size:13px;opacity:.85}
.cyan-title{margin:0 0 14px;color:#00e9ff;font-size:16px}

.searchline{
  max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center
}
.stats-grid{display:grid;gap:14px;max-width:100%;padding:0 12px;margin:20px 0}
.stats-grid.five{grid-template-columns:repeat(5,1fr)}
.stats-grid.two-center{grid-template-columns:repeat(2,165px);justify-content:center;max-width:500px;margin:14px auto}
.stats-grid.three-center{grid-template-columns:repeat(3,210px);justify-content:center;max-width:760px;margin:14px auto}
.stat-card{
  padding:18px;border-radius:16px;
  background:linear-gradient(180deg,rgba(44,47,66,.92),rgba(40,43,61,.92));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 10px 24px rgba(0,0,0,.22);
  text-align:center;
}
.stat-card.small{padding:14px}
.big{font-size:18px;font-weight:900;color:#24efff}
.mutedcaps{margin-top:8px;font-size:12px;color:#cfd2e6;opacity:.85}
.data-table{width:100%;border-collapse:collapse}
.data-table thead th{
  background:rgba(10,63,80,.85);color:#fff;font-size:12px;padding:14px 12px;text-align:left;
  border-bottom:2px solid #01dff9;
}
.data-table td{
  padding:14px 12px;border-bottom:1px solid rgba(255,255,255,.06);font-size:13px
}
.data-table tbody tr:nth-child(odd){background:rgba(255,255,255,.02)}
.cyantext{color:#10eaff;font-weight:800}
.pinktext{color:#ff2d86;font-weight:900}
.codepill{
  display:inline-block;padding:6px 8px;border-radius:8px;background:rgba(3,206,255,.16);
  border:1px solid rgba(3,206,255,.25);color:#1cf0ff;font-size:12px
}
.tag{
  display:inline-block;padding:7px 12px;border-radius:999px;background:linear-gradient(90deg,#ff0e79,#ff388e);
  font-size:11px;font-weight:900
}
.cyan-tag{background:linear-gradient(90deg,#00dfff,#32bde5)}
.emptybox{padding:40px 10px !important;text-align:left;color:#fff}

.inline-controls{
  max-width:780px;margin:0 auto;display:flex;gap:12px;align-items:flex-end;justify-content:center;flex-wrap:wrap
}
.selectblock{min-width:220px}
.search-grid{
  display:grid;grid-template-columns:repeat(4,1fr) 360px;gap:14px;align-items:end
}
.searchbtncell{display:flex;align-items:end}
.filterchips{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.empty-state{text-align:center;padding:36px 18px;max-width:100%;margin-top:18px}
.empty-icon{font-size:56px;margin-bottom:10px}
.consolebox{
  min-height:260px;margin:0;background:rgba(6,8,16,.5);padding:16px;border-radius:12px;
  border:1px solid rgba(255,255,255,.08);white-space:pre-wrap;color:#dbe7ff
}

.services-grid{
  max-width:1200px;margin:0 auto;padding:0 14px;
  display:grid;grid-template-columns:repeat(2,1fr);gap:18px
}
.span2{grid-column:1/-1}
.quick-service-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:12px 0 18px
}
.svcbox{
  padding:16px;border-radius:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)
}
.svcbox span{display:block;margin-top:8px;color:#c4cae9;font-size:13px}

.user-add-panel{max-width:660px;margin:0 auto 18px;padding:18px}
.user-create-grid{
  display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:14px;align-items:end
}
.btncell{display:flex;align-items:end}
.user-card{max-width:700px;margin:0 auto;padding:12px}
.user-header{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:10px}
.roles-line{display:flex;gap:8px;flex-wrap:wrap}
.user-update-grid{display:grid;grid-template-columns:1.5fr 1fr auto;gap:12px;align-items:end}
.delete-inline{display:flex;justify-content:flex-end;margin-top:10px}

@media (max-width:1200px){
  .stats-grid.five{grid-template-columns:repeat(3,1fr)}
  .search-grid{grid-template-columns:1fr 1fr}
  .services-grid,.quick-service-grid,.user-create-grid,.user-update-grid{grid-template-columns:1fr}
}
@media (max-width:900px){
  .topnav{justify-content:flex-start}
  .searchline{grid-template-columns:1fr}
  .stats-grid.five{grid-template-columns:repeat(2,1fr)}
  .two,.btn-row{grid-template-columns:1fr}
}
@media (max-width:640px){
  .page-title{font-size:24px}
  .stats-grid.five,.stats-grid.three-center,.stats-grid.two-center{grid-template-columns:1fr}
  .single-column,.services-grid{padding:0 10px}
}

/* ── Pagination ─────────────────────────────────────────────────────────── */
.pagination{
  display:flex;gap:6px;align-items:center;justify-content:center;
  padding:20px 14px 10px;flex-wrap:wrap
}
.page-btn{
  padding:9px 15px;border-radius:999px;font-size:12px;font-weight:800;
  background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.09);
  color:#fff;text-decoration:none;white-space:nowrap;cursor:pointer;
  transition:background .2s
}
.page-btn.active{background:linear-gradient(90deg,#49dfff,#ff0f78);border-color:transparent}
.page-btn.disabled{opacity:.35;cursor:default}
.page-btn.ellipsis{background:none;border:none;opacity:.5;cursor:default}
.page-btn:not(.active):not(.disabled):not(.ellipsis):hover{background:rgba(255,255,255,.18)}

/* ── Services grid panels need padding ──────────────────────────────────── */
.services-grid .panel{padding:20px}

/* ── Flash fade animation ───────────────────────────────────────────────── */
.flashstack{animation:fadein .3s ease}
@keyframes fadein{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* ── Input focus glow ───────────────────────────────────────────────────── */
input:focus,select:focus,textarea:focus{
  border-color:rgba(0,223,255,.45);
  box-shadow:0 0 0 3px rgba(0,223,255,.1)
}
input:disabled{cursor:not-allowed}

/* ── Nav role pill ──────────────────────────────────────────────────────────── */
.nav-role-pill{
  display:flex;align-items:center;gap:8px;
  padding:8px 16px;border-radius:999px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);
  font-size:12px;font-weight:700;color:#dbe3ff;white-space:nowrap;
}
.role-tag{
  padding:3px 9px;border-radius:999px;font-size:10px;font-weight:900;
  background:rgba(255,255,255,.12);
}
.role-tag.owner{background:linear-gradient(90deg,#ffb830,#ff7300);color:#fff}
.role-tag.admin{background:linear-gradient(90deg,#2fdcff,#0095cc);color:#fff}
.role-tag.guest{background:linear-gradient(90deg,#f59e0b,#d97706);color:#fff}

/* ── Dashboard server grid ──────────────────────────────────────────────────── */
.srv-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  max-width:1360px;margin:0 auto;padding:0 14px;
}
.srv-card{padding:20px}
.srv-card-head{
  display:flex;justify-content:space-between;align-items:flex-start;
  margin-bottom:16px;
}
.srv-name{margin:0 0 4px;font-size:17px;font-weight:900;color:#fff}
.srv-label{font-size:12px;color:#8b96c8}
.srv-badge{
  padding:5px 14px;border-radius:999px;font-size:11px;font-weight:900;
  background:rgba(0,223,255,.12);border:1px solid rgba(0,223,255,.28);color:#00e9ff;
  white-space:nowrap;
}
.srv-info-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid rgba(255,255,255,.07);border-radius:12px;overflow:hidden;
  margin-bottom:16px;
}
.srv-info-cell{
  padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.06);
}
.srv-info-cell:nth-child(odd){border-right:1px solid rgba(255,255,255,.06)}
.srv-info-cell:nth-last-child(-n+2){border-bottom:none}
.srv-info-label{display:block;font-size:11px;font-weight:800;color:#8b96c8;margin-bottom:4px}
.srv-info-val{font-size:13px;font-weight:700;color:#eef2ff}
.srv-muted{color:#616a96 !important;font-size:12px !important;font-style:italic}
.srv-actions{
  display:flex;gap:8px;margin-bottom:12px;
}
.srv-btn{
  flex:1;padding:11px 8px;border-radius:999px;border:0;
  font-size:12px;font-weight:900;cursor:pointer;color:#fff;
  transition:opacity .15s;
}
.srv-btn:disabled{opacity:.3;cursor:not-allowed}
.srv-btn.start{background:linear-gradient(90deg,#00e07a,#00b85e)}
.srv-btn.stop{background:linear-gradient(90deg,#ff5a5a,#e02020)}
.srv-btn.restart{background:linear-gradient(90deg,#2fdcff,#ff177f)}
.srv-broadcast{
  display:flex;gap:10px;align-items:center;
}
.srv-broadcast input{margin:0;flex:1;padding:11px 14px;font-size:13px}
@media(max-width:1100px){
  .srv-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:700px){
  .srv-grid{grid-template-columns:1fr}
}

/* ── Dashboard server status ────────────────────────────────────────────────── */
.srv-dot{
  display:inline-block;width:9px;height:9px;border-radius:50%;
  margin-right:6px;vertical-align:middle;
}
.srv-dot.online{background:#00e07a;box-shadow:0 0 6px rgba(0,224,122,.6)}
.srv-dot.degraded{background:#ffb347;box-shadow:0 0 6px rgba(255,179,71,.45)}
.srv-dot.unknown{background:#ffd24d;box-shadow:0 0 6px rgba(255,210,77,.4)}
.srv-dot.offline{background:#ff4a4a;box-shadow:0 0 6px rgba(255,74,74,.4)}
.srv-status-on{color:#00e07a !important;font-weight:800 !important}
.srv-status-warn{color:#ffb347 !important;font-weight:800 !important}
.srv-status-unknown{color:#ffd24d !important;font-weight:800 !important}

/* ── Player list action buttons ─────────────────────────────────────────────── */
.action-btn{
  display:inline-block;padding:6px 12px;border-radius:999px;font-size:11px;font-weight:900;
  border:0;cursor:pointer;color:#fff;text-decoration:none;white-space:nowrap;
}
.action-btn.kick{background:linear-gradient(90deg,#ff9900,#ff6600)}
.action-btn.ban-temp{background:linear-gradient(90deg,#ff4f84,#e02070)}
.action-btn.ban-perm{background:linear-gradient(90deg,#cc0044,#990033)}
.action-btn:hover{opacity:.85}

/* ── Configure link styled as badge ────────────────────────────────────────── */
a.srv-badge{
  text-decoration:none;
  background:linear-gradient(90deg,rgba(0,223,255,.15),rgba(0,223,255,.08));
  border:1px solid rgba(0,223,255,.35);color:#00e9ff;
  transition:background .2s;
}
a.srv-badge:hover{background:linear-gradient(90deg,rgba(0,223,255,.3),rgba(0,223,255,.15))}

/* ── Server Mode Panel ─────────────────────────────────────────────────────── */
.mode-panel-wrap{
  max-width:1360px;margin:0 auto 28px;padding:0 14px;
}
.mode-panel-head{
  display:flex;align-items:baseline;gap:14px;margin-bottom:14px;
}
.mode-panel-title{
  font-size:18px;font-weight:900;
  background:linear-gradient(90deg,#43cfff,#ff5ab0);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.mode-panel-sub{font-size:13px;color:#9aa2c4;}

.mode-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
@media(max-width:1100px){.mode-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:600px) {.mode-grid{grid-template-columns:1fr;}}

.mode-card{
  border-radius:18px;padding:18px 16px 14px;
  border:1px solid rgba(255,255,255,.09);
  display:flex;flex-direction:column;gap:14px;
  background:linear-gradient(160deg,rgba(34,37,58,.95),rgba(28,31,52,.95));
  box-shadow:0 8px 24px rgba(0,0,0,.28);
  transition:border-color .2s,box-shadow .2s;
}
.mode-card:hover{box-shadow:0 12px 32px rgba(0,0,0,.4);}

.reforged-mod{border-color:rgba(0,220,255,.2);}
.tourn-mod {border-color:rgba(255,180,0,.2);}
.maint-mod {border-color:rgba(255,60,80,.2);}
.prep-mod  {border-color:rgba(160,120,255,.2);}

.mode-card-top{display:flex;align-items:center;gap:12px;}
.mode-emoji{font-size:30px;line-height:1;flex-shrink:0;}
.mode-label{font-size:15px;font-weight:900;color:#fff;margin-bottom:2px;}
.mode-desc{font-size:12px;color:#9aa2c4;line-height:1.4;}

.mode-cores{
  list-style:none;margin:0;padding:0;
  display:flex;flex-direction:column;gap:7px;flex:1;
}
.mode-cores li{
  display:flex;align-items:center;gap:10px;
  font-size:13px;color:#cdd3f0;padding:2px 0;
}
.mode-cores strong{flex-shrink:0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
/* .core-range removed — core labels no longer shown in mode cards */
.core-dot{
  width:8px;height:8px;border-radius:50%;flex-shrink:0;
}
.core-dot.start{background:#00e57a;box-shadow:0 0 6px rgba(0,229,122,.6);}
.core-dot.stop {background:#ff4e60;box-shadow:0 0 6px rgba(255,78,96,.6);}
.core-dot.idle {background:#555870;}

.mode-form{margin-top:auto;}
.mode-btn{
  width:100%;padding:11px 10px;border-radius:12px;border:0;
  font-weight:900;font-size:12px;cursor:pointer;color:#fff;
  transition:filter .15s,transform .1s;letter-spacing:.3px;
}
.mode-btn:hover:not(:disabled){filter:brightness(1.12);transform:translateY(-1px);}
.mode-btn:active:not(:disabled){transform:translateY(0);}
.mode-btn:disabled{opacity:.35;cursor:not-allowed;}

.reforged-btn{background:linear-gradient(90deg,#00d4ff,#0099cc);}
.tourn-btn{background:linear-gradient(90deg,#ffb800,#e07000);}
.maint-btn{background:linear-gradient(90deg,#ff3c50,#cc1f30);}
.prep-start-btn{background:linear-gradient(90deg,#00c96e,#007d43);}
.prep-stop-btn {background:linear-gradient(90deg,#ff3c50,#cc1f30);}
.prep-actions{display:flex;gap:8px;}

/* ── Mode card active / inactive states ───────────────────────────────────── */
.mode-card-active{
  border-width:2px;
  box-shadow:0 0 0 1px rgba(255,255,255,.15), 0 16px 40px rgba(0,0,0,.45);
}
.mode-card-inactive{
  opacity:.52;
  filter:saturate(.4);
}
.mode-card-inactive .mode-btn{
  opacity:.5;cursor:not-allowed;
}
.mode-active-bar{
  height:3px;border-radius:3px 3px 0 0;
  margin:-18px -16px 14px;
  background:linear-gradient(90deg,#00d4ff,#0099cc);
}
.mode-running-pill{
  display:inline-block;margin-left:8px;
  padding:2px 8px;border-radius:999px;
  font-size:10px;font-weight:900;letter-spacing:.5px;
  background:#0099cc;color:#fff;vertical-align:middle;
}
.mode-active-badge{
  margin-left:auto;padding:5px 14px;border-radius:999px;
  background:rgba(0,220,255,.12);border:1px solid rgba(0,220,255,.3);
  color:#00e8ff;font-size:12px;font-weight:700;
}

/* ── Active mode status banner ───────────────────────────────────────────── */
.mode-status-banner{
  display:flex;align-items:center;gap:14px;
  max-width:1360px;margin:0 auto 18px;padding:14px 20px;
  border-radius:14px;border:1px solid rgba(255,255,255,.12);
  font-size:14px;
}
.msb-reforged   {background:linear-gradient(90deg,rgba(0,180,220,.15),rgba(0,100,150,.1));border-color:rgba(0,200,255,.3);}
.msb-tournament {background:linear-gradient(90deg,rgba(220,150,0,.15),rgba(160,80,0,.1));border-color:rgba(255,180,0,.35);}
.msb-maintenance{background:linear-gradient(90deg,rgba(200,40,60,.15),rgba(120,20,30,.1));border-color:rgba(255,60,80,.3);}
.msb-dot{
  width:12px;height:12px;border-radius:50%;flex-shrink:0;
}
.msb-reforged    .msb-dot{background:#00d4ff;box-shadow:0 0 8px #00d4ff;}
.msb-tournament  .msb-dot{background:#ffb800;box-shadow:0 0 8px #ffb800;}
.msb-maintenance .msb-dot{background:#ff3c50;box-shadow:0 0 8px #ff3c50;}
@keyframes msb-pulse{0%,100%{opacity:1}50%{opacity:.4}}
.msb-text{flex:1;color:#e8eeff;}
.msb-text strong{color:#fff;}
.msb-since{font-size:11px;color:#6a7090;white-space:nowrap;}

/* ── Hamburger nav (mobile) ───────────────────────────────────────────────── */
.hamburger{
  display:none;
  background:none;border:none;color:#fff;font-size:24px;
  cursor:pointer;padding:8px 12px;border-radius:8px;
  flex-shrink:0;
}
.hamburger:hover{background:rgba(255,255,255,.1)}
.nav-links{display:contents}

@media(max-width:1100px){
  .hamburger{display:block}
  .nav-links{
    display:none;
    flex-direction:column;
    position:absolute;top:100%;left:0;right:0;
    background:linear-gradient(180deg,rgba(34,35,42,.98),rgba(28,30,48,.98));
    border-bottom:2px solid rgba(0,223,255,.3);
    padding:10px 14px;gap:6px;z-index:200;
    box-shadow:0 12px 40px rgba(0,0,0,.5);
    max-height:80vh;overflow-y:auto;
  }
  .nav-links.nav-open{display:flex}
  .nav-links .navbtn{
    display:block;text-align:left;padding:12px 16px;
    border-radius:12px;font-size:13px;
  }
  .topnav{flex-wrap:wrap;position:relative}
}

/* ── Confirmation modal ───────────────────────────────────────────────────── */
.modal-overlay{
  display:none;position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,.65);backdrop-filter:blur(6px);
  align-items:center;justify-content:center;
}
.modal-overlay.modal-visible{display:flex}
.modal-box{
  background:linear-gradient(160deg,#1e2040,#161833);
  border:1px solid rgba(255,255,255,.15);
  border-radius:22px;padding:32px 36px;
  max-width:440px;width:90%;text-align:center;
  box-shadow:0 20px 60px rgba(0,0,0,.6);
  animation:modalIn .2s ease;
}
@keyframes modalIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
.modal-icon{font-size:42px;margin-bottom:12px}
.modal-msg{font-size:15px;line-height:1.6;color:#dbe3ff;margin-bottom:24px}
.modal-btns{display:flex;gap:12px;justify-content:center}

/* ── Loading spinner overlay ──────────────────────────────────────────────── */
.loading-overlay{
  display:none;position:fixed;inset:0;z-index:9998;
  background:rgba(6,8,18,.7);backdrop-filter:blur(3px);
  align-items:center;justify-content:center;
  flex-direction:column;gap:16px;
}
.loading-overlay.loading-visible{display:flex}
.loading-spinner{
  width:44px;height:44px;border-radius:50%;
  border:4px solid rgba(255,255,255,.15);
  border-top-color:#00d4ff;
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{color:#aeb6da;font-size:14px;font-weight:700}

/* ── Nav dropdowns ────────────────────────────────────────────────────────── */
.nav-dropdown{position:relative;display:inline-block}
.nav-dropdown > .navbtn{cursor:pointer;user-select:none}
.nav-dropdown-menu{
  display:none;position:absolute;top:100%;left:0;min-width:200px;
  background:linear-gradient(180deg,rgba(30,32,64,.99),rgba(22,24,51,.99));
  border:1px solid rgba(0,223,255,.2);border-radius:14px;
  padding:8px 0;z-index:999;
  box-shadow:0 12px 40px rgba(0,0,0,.6);
  backdrop-filter:blur(12px);
}
.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown:focus-within .nav-dropdown-menu{display:block}
.nav-dropdown-menu a{
  display:block;padding:10px 18px;color:#c8ccdf;text-decoration:none;
  font-size:13px;font-weight:600;transition:background .15s,color .15s;
  white-space:nowrap;
}
.nav-dropdown-menu a:hover{background:rgba(0,212,255,.1);color:#fff}
.nav-dropdown-divider{height:1px;background:rgba(255,255,255,.08);margin:6px 12px}

/* Mobile: dropdowns become inline in hamburger menu */
@media(max-width:1100px){
  .nav-dropdown{display:block}
  .nav-dropdown > .navbtn{display:block;text-align:left;padding:12px 16px;border-radius:12px;font-size:13px}
  .nav-dropdown-menu{
    position:static;display:none;border:none;box-shadow:none;
    background:rgba(0,0,0,.15);border-radius:10px;margin:4px 0 4px 16px;
    padding:4px 0;
  }
  .nav-dropdown.dropdown-open .nav-dropdown-menu{display:block}
  .nav-dropdown-menu a{padding:10px 16px;font-size:12px}
}

/* ── Sub-navigation (page group tabs) ─────────────────────────────────────── */
.subnav{
  max-width:1200px;margin:0 auto;padding:8px 14px 0;
  display:flex;gap:4px;flex-wrap:wrap;
}
.subnav a{
  padding:8px 16px;font-size:12px;font-weight:700;
  color:#8b96c8;text-decoration:none;border-radius:10px 10px 0 0;
  transition:background .15s,color .15s;
  border:1px solid transparent;border-bottom:none;
}
.subnav a:hover{background:rgba(255,255,255,.05);color:#c8ccdf}
.subnav a.sub-active{
  background:rgba(0,212,255,.08);color:#00d4ff;
  border-color:rgba(0,212,255,.15);
}
.subnav-line{
  max-width:1200px;margin:0 auto;padding:0 14px;
  border-bottom:1px solid rgba(255,255,255,.06);
}


.srv-player-list{
  margin-top:14px;padding:14px;border-radius:14px;
  background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08)
}
.srv-player-head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:10px}
.srv-player-head strong{font-size:13px;color:#fff}
.srv-player-head span{font-size:11px;color:#98dfff;font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.srv-player-items{display:flex;flex-wrap:wrap;gap:8px}
.srv-player-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 12px;border-radius:999px;
  background:rgba(0,223,255,.12);border:1px solid rgba(0,223,255,.22);
  color:#cfffff;font-size:12px;font-weight:700
}
.srv-player-empty{font-size:12px;color:#b7c0ea;opacity:.9}
