/* ── Reset ──────────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --sidebar-bg:   #1a3558;
  --sidebar-w:    152px;
  --topbar-bg:    #142d4a;
  --topbar-h:     55px; /* also hardcoded in login.html and qwerty.html inline <style> — update all three */
  --footer-h:     36px;
  --content-grad: linear-gradient(150deg,#1a2f48 0%,#1e3a58 55%,#172f4c 100%);
  --plex-color:   #e8a020;
  --emby-color:   #3ab54a;
  --jelly-color:  #00a4dc;
  --teal:         #17a2b8;
  --green:        #28a745;
  --red:          #dc3545;
  --amber:        #e8a020;
  --text:         #d0e4f7;
  --text-muted:   #8ab0d0;
  --border:       #243f60;
  --card-bg:      #1d3555;
  --input-bg:     #152d4a;
  --radius:       4px;
  --c-hint:       #888;
  --c-meta:       #64748b;
  --c-val:        #e2e8f0;
}

body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--content-grad);
  color:var(--text);
  font-size:13.5px;
  overflow:hidden;
  height:100vh;
  height:100dvh;
}

/* ── Layout ─────────────────────────────────────────────────────────────────── */
.app{display:flex;height:100vh;height:100dvh;overflow:hidden}

.sidebar{
  width:var(--sidebar-w);min-width:var(--sidebar-w);
  background:var(--sidebar-bg);
  overflow:hidden;
  flex-shrink:0;
  border-right:1px solid #0f2038;
  display:flex;flex-direction:column;
}
.sidebar-nav{overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;padding:6px 0}
.sidebar-font-controls{
  flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  padding:8px 10px;
  border-top:1px solid rgba(255,255,255,.07);
  background:rgba(0,0,0,.15);
}
.sidebar-font-controls .lang-toggle{width:100%;border-radius:5px}
.sidebar-font-controls .lang-opt{flex:1;padding:5px 0;font-size:11px}
html.light-mode .sidebar-font-controls{background:rgba(0,0,0,.06);border-top-color:rgba(0,0,0,.1)}

.main-wrap{
  flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;
}

/* ── Topbar ─────────────────────────────────────────────────────────────────── */
.topbar{
  background:var(--topbar-bg);
  height:var(--topbar-h);min-height:var(--topbar-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;border-bottom:1px solid #0a1e35;flex-shrink:0;
}

/* Logo */
.logo{display:flex;align-items:center;gap:9px}
.logo-icon{
  width:34px;height:34px;position:relative;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.logo-icon::before{
  content:'';position:absolute;
  width:24px;height:9px;background:var(--amber);
  transform:skewX(-18deg) rotate(-28deg) translateY(-5px);
  border-radius:2px;
}
.logo-icon::after{
  content:'';position:absolute;
  width:24px;height:9px;background:#3a8fd4;
  transform:skewX(-18deg) rotate(-28deg) translateY(5px);
  border-radius:2px;
}
.logo-text{color:#fff;font-size:15px;font-weight:700;letter-spacing:.3px;white-space:nowrap}
.logo-text span{color:var(--amber)}

/* Topbar right */
.topbar-right{display:flex;align-items:center;gap:4px}
.lang-toggle{display:flex;background:rgba(255,255,255,.08);border-radius:4px;overflow:hidden;margin-right:2px}
.lang-opt{background:none;border:none;cursor:pointer;color:#aaa;padding:5px 9px;font-size:11px;font-weight:700;letter-spacing:.5px;transition:all .15s}
.lang-opt.active{background:rgba(255,255,255,.18);color:#fff}
.lang-opt:hover:not(.active){background:rgba(255,255,255,.1);color:#fff}
html.light-mode .lang-toggle{background:rgba(0,0,0,.07)}
html.light-mode .lang-opt{color:#3a5a78}
html.light-mode .lang-opt.active{background:rgba(45,110,168,.25);color:#1a2d45}
html.light-mode .lang-opt:hover:not(.active){background:rgba(45,110,168,.12);color:#1a2d45}
.tb-new{color:var(--red);font-size:11px;font-weight:700;margin-right:4px;letter-spacing:.3px}
.tb-btn{
  background:none;border:none;cursor:pointer;
  color:#aaa;width:32px;height:32px;border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;transition:color .15s,background .15s;
}
.tb-btn:hover{color:#fff;background:rgba(255,255,255,.1)}
.tb-credits{color:var(--amber)}
.tb-credits:hover{color:var(--amber)!important}
.tb-avatar{
  width:30px;height:30px;border-radius:50%;
  background:var(--red);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:13px;cursor:pointer;margin-left:4px;flex-shrink:0;
}

/* ── Sidebar Nav ────────────────────────────────────────────────────────────── */

.nav-item{
  display:flex;align-items:center;gap:9px;
  padding:7px 14px;color:#bbb;text-decoration:none;
  cursor:pointer;transition:background .12s,color .12s;
  font-size:13px;white-space:nowrap;
  border-left:3px solid transparent;
}
.nav-item:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-item.active{background:#2d6ea8;color:#fff;border-left-color:#4a8fcc}
.nav-item i{width:16px;text-align:center;font-size:13px;flex-shrink:0}

.nav-child{padding-left:24px;font-size:12.5px}

/* Collapsible groups */
.nav-group-header{
  display:flex;align-items:center;gap:8px;
  padding:7px 14px;color:#bbb;cursor:pointer;
  transition:background .12s,color .12s;
  font-size:13px;
  border-left:3px solid transparent;
}
.nav-group-header:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-group-arrow{font-size:9px;transition:transform .2s;flex-shrink:0;color:#5a82a8}
.nav-group.open .nav-group-arrow{transform:rotate(90deg)}
.nav-group-items{display:none}
.nav-group.open .nav-group-items{display:block}

/* Server dots & logos */
.srv-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.emby-dot{background:var(--emby-color)}
.jellyfin-dot{background:var(--jelly-color)}
.srv-logo{height:14px;width:auto;flex-shrink:0;filter:brightness(0) invert(1);opacity:.7}
.plex-logo{filter:none;opacity:1;height:18px}
.emby-logo{filter:none;opacity:1;height:18px}
.jellyfin-logo{filter:none;opacity:1;height:18px}

/* NEW badge */
.badge-new{
  background:var(--red);color:#fff;
  font-size:9px;font-weight:700;padding:1px 5px;
  border-radius:10px;vertical-align:middle;margin-left:3px;
}

/* ── Content ────────────────────────────────────────────────────────────────── */
.content{flex:1;overflow-y:auto;padding:0;min-height:0;overscroll-behavior-y:contain}

/* ── Pull-to-refresh ─────────────────────────────────────────────────────────── */
#ptr-indicator{
  height:0;overflow:hidden;display:flex;align-items:center;
  justify-content:center;flex-shrink:0;
  transition:height .12s ease;
}
.ptr-inner{
  display:flex;align-items:center;gap:8px;
  color:var(--text-muted);font-size:12px;font-weight:500;padding:6px 0;
}
.ptr-icon{font-size:15px;transition:transform .25s,color .25s}
#ptr-indicator.ptr-ready .ptr-icon{transform:rotate(180deg);color:var(--teal)}
#ptr-indicator.ptr-ready .ptr-text{color:var(--teal)}

/* ── Section Header Bars ────────────────────────────────────────────────────── */
.section-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 16px;font-size:13px;font-weight:600;
  flex-wrap:wrap;gap:6px;flex-shrink:0;
}
.section-bar.plex     {background:var(--plex-color);color:#fff}
.section-bar.emby     {background:var(--emby-color);color:#fff}
.section-bar.jellyfin {background:var(--jelly-color);color:#fff}
.section-bar.dark     {background:#1d3a58;color:#d0e4f7;border-bottom:1px solid #0f2540}
.section-bar.neutral{background:rgba(13,30,55,.6);color:#d0e4f7;border-bottom:1px solid rgba(74,143,204,.15)}
.section-bar-left{display:flex;align-items:center;gap:8px}
.section-bar-right{display:flex;align-items:center;gap:6px}

/* ── Page content wrapper ───────────────────────────────────────────────────── */
.page-wrap{padding:12px 16px}

/* ── Tabs ───────────────────────────────────────────────────────────────────── */
.tab-bar{
  display:flex;gap:4px;padding:8px 16px;
  background:rgba(0,0,0,.15);border-bottom:1px solid rgba(0,0,0,.2);
}
.tab-btn{
  padding:5px 14px;border-radius:4px;border:none;cursor:pointer;
  font-size:12.5px;font-weight:600;transition:opacity .15s;
  display:flex;align-items:center;gap:6px;
}
.tab-btn.green {background:var(--green);color:#fff}
.tab-btn.amber {background:var(--amber);color:#fff}
.tab-btn.teal  {background:var(--teal);color:#fff}
.tab-btn:not(.active){opacity:.7}
.tab-btn.active{opacity:1}
.tab-btn:hover{opacity:1}
.rf-tab-btn{
  flex:1;padding:8px 12px;border:none;border-bottom:2px solid transparent;
  cursor:pointer;font-size:13px;font-weight:600;
  transition:background .15s,border-bottom-color .15s,color .15s;
  background:transparent;color:var(--c-meta);margin-bottom:-2px;
}
.rf-tab-btn.active{background:rgba(255,255,255,.12);border-bottom-color:#3b82f6;color:#fff}
.rf-tab-btn:hover{color:#fff}

/* ── Buttons ────────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;border-radius:var(--radius);border:none;
  cursor:pointer;font-size:12.5px;font-weight:600;
  transition:opacity .15s;white-space:nowrap;
  touch-action:manipulation;
}
.btn:hover{opacity:.85}
.btn:disabled{opacity:.45;cursor:default}
.btn-dark   {background:#1d3a58;color:#d0e4f7;border:1px solid #2d5278}
.btn-outline{background:transparent;color:#d0e4f7;border:1px solid #4a7aaa}
.btn-outline:hover{background:rgba(74,143,204,.15)}
.btn-teal   {background:var(--teal);color:#fff}
.btn-green  {background:var(--green);color:#fff}
.btn-amber  {background:var(--amber);color:#fff}
.btn-red    {background:var(--red);color:#fff}
.btn-blue   {background:#2d6ea8;color:#fff}
.btn-purple {background:#7c3aed;color:#fff}
.btn-sm     {padding:3px 9px;font-size:12px}
.btn-circle {width:32px;height:32px;border-radius:50%;padding:0;justify-content:center;background:#2d6ea8;color:#fff;border:none;font-size:16px;line-height:1;cursor:pointer;transition:opacity .15s}
.btn-circle:hover{opacity:.85}

/* ── Filters / toolbar ──────────────────────────────────────────────────────── */
.toolbar{
  display:flex;align-items:center;gap:8px;
  padding:8px 16px;background:rgba(0,0,0,.15);
  flex-wrap:wrap;border-bottom:1px solid rgba(0,0,0,.2);
}
.filter-input,.filter-select{
  background:rgba(255,255,255,.9);border:1px solid #ccc;
  color:#333;padding:5px 10px;border-radius:var(--radius);font-size:12.5px;
}
.filter-input:focus,.filter-select:focus{outline:none;border-color:var(--teal)}
.filter-input::placeholder{color:#888}
.filter-input-dark{
  background:var(--input-bg);border:1px solid var(--border);color:var(--text);
  padding:5px 10px;border-radius:var(--radius);font-size:12.5px;
}
.filter-input-dark::placeholder{color:#555}
.filter-input-dark:focus{outline:none;border-color:var(--teal)}

/* ── Action bar ─────────────────────────────────────────────────────────────── */
.action-bar{
  display:flex;align-items:center;gap:6px;
  padding:6px 16px;background:rgba(255,255,255,.08);
  flex-wrap:wrap;border-bottom:1px solid rgba(0,0,0,.2);
}

/* ── Table ──────────────────────────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;padding:0 16px 16px}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{
  text-align:left;padding:8px 10px;
  font-size:11.5px;font-weight:600;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:.4px;
  border-bottom:1px solid rgba(255,255,255,.1);
  background:rgba(0,0,0,.2);white-space:nowrap;
}
tbody tr{border-bottom:1px solid rgba(255,255,255,.06);transition:background .1s}
tbody tr:hover{background:rgba(255,255,255,.06)}
tbody td{padding:8px 10px;vertical-align:middle}
td .sub{font-size:11px;color:var(--text-muted);margin-top:2px}

/* ── Info row ───────────────────────────────────────────────────────────────── */
.info-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:6px 16px;background:rgba(0,0,0,.2);
  font-size:13px;border-bottom:1px solid rgba(0,0,0,.2);
}
.total-count{font-weight:600}

/* ── Badges ─────────────────────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:3px;font-size:11px;font-weight:700;white-space:nowrap}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}
.badge-active   {background:rgba(40,167,69,.2); color:#5dde7a}
.badge-inactive {background:rgba(220,53,69,.2);  color:#f87171}
.badge-suspended{background:rgba(232,160,32,.2); color:#ffc555}
.badge-expired  {background:rgba(220,53,69,.2);  color:#f87171}
.badge-expiring {background:rgba(232,160,32,.2); color:#ffc555}
.badge-admin          {background:rgba(232,160,32,.2); color:#ffc555}
.badge-super_reseller {background:rgba(167,105,220,.2);color:#c084fc}
.badge-reseller       {background:rgba(23,162,184,.2); color:#4dd0e1}
.badge-user           {background:rgba(100,149,237,.2);color:#7eb5f5}
.badge-plex     {background:rgba(232,160,32,.2); color:var(--plex-color)}
.badge-emby     {background:rgba(58,181,74,.2);  color:var(--emby-color)}
.badge-jellyfin {background:rgba(0,164,220,.2);  color:var(--jelly-color)}
.badge-tag      {background:rgba(255,255,255,.12);color:#ccc}
.badge-direct   {background:rgba(40,167,69,.15); color:#5dde7a}
.badge-transcode{background:rgba(220,53,69,.15); color:#f87171}

/* ── Status indicators ──────────────────────────────────────────────────────── */
.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px}
.status-dot.online {background:#28a745}
.status-dot.offline{background:#dc3545}

/* ── Forms ──────────────────────────────────────────────────────────────────── */
.form-group{margin-bottom:11px}
.form-label{display:block;color:#aaa;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px}
.form-input,.form-select,.form-textarea{
  width:100%;background:var(--input-bg);border:1px solid var(--border);
  color:var(--text);padding:6px 10px;border-radius:var(--radius);font-size:13px;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--teal)}
.form-input::placeholder{color:#4a7090}
.form-textarea{resize:vertical;min-height:60px;font-family:inherit}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-hint{font-size:11px;color:#6a90b0;margin-top:2px}
.form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}
.form-check{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px}
.form-check input{width:auto;cursor:pointer}

/* ── Modal ──────────────────────────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}
.modal-overlay.hidden{display:none}
.modal{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;width:500px;max-width:100%;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 24px 72px rgba(0,0,0,.85),0 4px 16px rgba(0,0,0,.4);overflow:hidden}
.modal.modal-lg{width:680px}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;border-bottom:1px solid var(--border);background:var(--card-bg);z-index:1;flex-shrink:0}
.modal-header.plex     {background:linear-gradient(135deg,#e8a020 0%,#c88010 100%)}
.modal-header.emby     {background:linear-gradient(135deg,#3ab54a 0%,#289838 100%)}
.modal-header.jellyfin {background:linear-gradient(135deg,#00a4dc 0%,#0086c0 100%)}
.modal-header.dark     {background:linear-gradient(135deg,#1e3c64 0%,#152e4e 100%)}
.modal-header h3{font-size:13px;font-weight:700;color:#fff;letter-spacing:.1px}
.modal-close{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.65);font-size:16px;width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,color .15s;flex-shrink:0}
.modal-close:hover{color:#fff;background:rgba(255,255,255,.18)}
.modal-body{padding:14px 16px;overflow-y:auto;flex:1;min-height:0}
.modal-footer{padding:9px 14px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;flex-shrink:0;background:var(--card-bg)}

/* ── Progress ───────────────────────────────────────────────────────────────── */
.progress-wrap{display:flex;align-items:center;gap:7px}
.progress-bar{flex:1;height:4px;background:rgba(255,255,255,.15);border-radius:2px;min-width:60px}
.progress-fill{height:100%;border-radius:2px;background:var(--teal)}
.progress-pct{font-size:11px;color:var(--text-muted);width:26px;text-align:right}

/* ── Empty state ────────────────────────────────────────────────────────────── */
.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}
.empty-state .icon{font-size:28px;margin-bottom:10px;opacity:.4}
.empty-state p{font-size:13px}

/* ── Loading ────────────────────────────────────────────────────────────────── */
.loading-screen{display:flex;align-items:center;justify-content:center;height:100%;gap:12px;color:var(--text-muted)}
.spinner{width:26px;height:26px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--teal);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Stats row ──────────────────────────────────────────────────────────────── */
.stats-row{display:flex;flex-wrap:wrap;gap:10px;padding:12px 16px}
.stat-card{background:rgba(13,30,55,.5);border:1px solid rgba(74,143,204,.2);border-radius:6px;padding:12px 16px;min-width:120px}
.stat-card .num{font-size:24px;font-weight:700;line-height:1;margin-bottom:3px}
.stat-card .lbl{font-size:11px;color:var(--text-muted)}
.col-amber {color:var(--amber)}
.col-green {color:var(--emby-color)}
.col-teal  {color:var(--teal)}
.col-red   {color:var(--red)}
.col-blue  {color:#7eb5f5}
.stat-card.stat-clickable{cursor:pointer;transition:background .15s,border-color .15s,transform .1s}
.stat-card.stat-clickable:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.22);transform:translateY(-1px)}
.stat-svc-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:8px;background:rgba(255,255,255,.07);cursor:pointer;transition:background .15s;margin-bottom:0}
.stat-svc-row:hover{background:rgba(255,255,255,.14)}
.stat-svc-row .svc-label{font-size:13px;color:#e2e8f0}
.stat-svc-row .svc-count{font-size:20px;font-weight:700}

/* ── Stream cards ───────────────────────────────────────────────────────────── */
.stream-card{border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.3)}
.stream-card-hdr{background:rgba(0,0,0,.25);border-bottom:1px solid rgba(255,255,255,.07)}
.stream-card-badge{background:rgba(0,0,0,.35)}
.stream-card-bar{background:rgba(255,255,255,.1)}

/* ── Server status card ─────────────────────────────────────────────────────── */
.srv-status-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;padding:12px 16px}
.srv-status-card{background:rgba(13,30,55,.5);border:1px solid rgba(74,143,204,.2);border-radius:6px;overflow:hidden}
.srv-status-card-top{padding:10px 14px;display:flex;align-items:center;justify-content:space-between}
.srv-status-card-body{padding:8px 14px 12px;display:grid;grid-template-columns:1fr 1fr;gap:8px;border-top:1px solid rgba(255,255,255,.08)}
.srv-stat-lbl{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px}
.srv-stat-val{font-size:16px;font-weight:700}

/* ── Toast ──────────────────────────────────────────────────────────────────── */
#toast-container{position:fixed;bottom:16px;right:16px;display:flex;flex-direction:column;gap:6px;z-index:2000}
.toast{background:var(--card-bg);border:1px solid var(--border);border-radius:4px;padding:10px 14px;font-size:13px;min-width:200px;max-width:320px;box-shadow:0 4px 16px rgba(0,0,0,.5);animation:slideIn .18s ease}
.toast.success{border-left:3px solid var(--emby-color)}
.toast.error  {border-left:3px solid var(--red)}
.toast.info   {border-left:3px solid var(--teal)}
@keyframes slideIn{from{transform:translateX(16px);opacity:0}to{transform:none;opacity:1}}

/* ── Footer ─────────────────────────────────────────────────────────────────── */
.footer{
  background:#0f2038;color:#6a90b0;
  font-size:12px;padding:6px 16px;
  text-align:center;flex-shrink:0;
  height:var(--footer-h);display:flex;align-items:center;justify-content:center;gap:4px;
  border-top:1px solid #1a3558;
}
.footer a{color:#4a8fcc;text-decoration:underline}

/* ── Scrollbar ──────────────────────────────────────────────────────────────── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.25)}

/* ── User Cards (Emby / Jellyfin) ───────────────────────────────────────────── */
.uc-wrap{padding:10px 12px;display:grid;grid-template-columns:repeat(auto-fill,minmax(205px,1fr));gap:10px}
.uc-card{background:#162e4a;border-radius:6px;overflow:hidden;border:1px solid rgba(74,143,204,.18);display:flex;flex-direction:column}
.uc-card-hdr{padding:7px 10px;display:flex;align-items:center;gap:5px;min-width:0}
.uc-card-hdr.plex{background:var(--plex-color)}
.uc-card-hdr.emby{background:var(--emby-color)}
.uc-card-hdr.jellyfin{background:var(--jelly-color)}
.uc-card-hdr.inactive{background:#7f1d1d!important}
.uc-card.selectable{cursor:pointer;transition:border-color .15s}
.uc-card.selectable:hover{border-color:rgba(0,212,255,.4)}
.uc-card.selected{border-color:#00d4ff!important;box-shadow:0 0 0 2px rgba(0,212,255,.3),0 0 10px rgba(0,212,255,.15)!important}
.uc-card.selected .uc-card-hdr{box-shadow:inset 0 0 0 2px rgba(0,212,255,.15)}

.btn-multiselect-on{background:#0e4d6e!important;border-color:#00d4ff!important;color:#00d4ff!important}
.uc-email{flex:1;font-size:11.5px;font-weight:700;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.uc-tv{background:#1e2a38;color:#475569;font-size:9px;font-weight:800;border-radius:50%;width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:.3px;cursor:pointer;transition:background .18s,color .18s}
.uc-tv:hover{background:#253447;color:#94a3b8}
.uc-tv.uc-tv-on{background:#0d9488;color:#fff}
.uc-tv.uc-tv-on:hover{background:#0f766e}
.uc-menu-wrap{position:relative;flex-shrink:0}
.uc-menu{background:none;border:none;color:rgba(255,255,255,.8);cursor:pointer;font-size:16px;line-height:1;padding:2px 5px;border-radius:4px;transition:background .15s}
.uc-menu:hover{background:rgba(255,255,255,.15)}
.uc-dropdown{position:absolute;top:calc(100% + 4px);right:0;background:#1a3558;border:1px solid rgba(74,143,204,.25);border-radius:7px;min-width:185px;z-index:200;box-shadow:0 6px 20px rgba(0,0,0,.55);overflow:hidden;display:none}
.uc-dropdown.open{display:block}
.uc-dd-item{display:flex;align-items:center;gap:9px;width:100%;background:none;border:none;color:#ccc;font-size:12.5px;padding:9px 13px;cursor:pointer;text-align:left;transition:background .12s;white-space:nowrap}
.uc-dd-item:hover{background:rgba(255,255,255,.07);color:#fff}
.uc-body{padding:10px 12px;flex:1;text-align:center}
.uc-uname{font-size:13px;font-weight:600;color:#fff;margin-bottom:8px}
.uc-info{font-size:11px;color:#aaa;display:flex;align-items:center;justify-content:center;gap:5px;margin-bottom:4px;word-break:break-all}
.uc-actions{padding:8px 6px;display:flex;gap:5px;justify-content:center;border-top:1px solid rgba(255,255,255,.08);flex-wrap:wrap}
.uc-btn{width:30px;height:30px;border-radius:50%;border:2px solid #c04060;background:transparent;color:#e06070;cursor:pointer;font-size:11px;display:inline-flex;align-items:center;justify-content:center;transition:background .15s}
.uc-btn:hover{background:rgba(200,60,80,.2)}

/* ── Mobile sidebar toggle button ────────────────────────────────────────────── */
.sidebar-toggle{
  display:none;
  background:none;border:none;cursor:pointer;
  color:#aaa;width:32px;height:32px;border-radius:4px;
  align-items:center;justify-content:center;
  font-size:16px;transition:color .15s,background .15s;
  flex-shrink:0;
}
.sidebar-toggle:hover{color:#fff;background:rgba(255,255,255,.1)}
.topbar-left{display:flex;align-items:center;gap:4px}

/* ── Mobile sidebar overlay ──────────────────────────────────────────────────── */
.sidebar-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.55);z-index:199;
}
.sidebar-overlay.active{display:block}

/* ── Created account info modal ─────────────────────────────────────────────── */
.created-info-box{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px;
  overflow:hidden;
}
.created-info-row{
  display:flex;align-items:center;
  padding:10px 16px;
  border-bottom:1px solid rgba(255,255,255,.07);
  gap:12px;
}
.created-info-row:last-child{border-bottom:none}
.created-info-label{
  flex:0 0 100px;
  font-size:12px;color:#94a3b8;font-weight:600;text-transform:uppercase;letter-spacing:.5px;
}
.created-info-val{
  flex:1;font-size:14px;color:#f1f5f9;word-break:break-all;
}

/* ── Light mode ──────────────────────────────────────────────────────────────── */
html.light-mode{
  --content-grad: linear-gradient(150deg,#e8f2fb 0%,#eef5fc 55%,#e4eff9 100%);
  --text:         #1a2d45;
  --text-muted:   #1e293b;
  --border:       #bdd4e8;
  --card-bg:      #ffffff;
  --input-bg:     #f4f8fc;
  --c-hint:       #374151;
  --c-meta:       #374151;
  --c-val:        #1a2d45;
  --topbar-bg:    #dce8f5;
  --sidebar-bg:   #e4eef8;
}
/* Topbar */
html.light-mode .topbar{border-bottom-color:#bdd4e8}
html.light-mode .logo-text{color:#1a2d45}
html.light-mode .tb-btn{color:#3a5a78}
html.light-mode .tb-btn:hover{color:#1a2d45;background:rgba(45,110,168,.12)}
html.light-mode .sidebar-toggle{color:#3a5a78}
html.light-mode .sidebar-toggle:hover{color:#1a2d45;background:rgba(45,110,168,.12)}
/* Sidebar */
html.light-mode .sidebar{border-right-color:#bdd4e8}
html.light-mode .nav-item{color:#2d4a6a}
html.light-mode .nav-item:hover{background:rgba(45,110,168,.12);color:#1a2d45}
html.light-mode .nav-item.active{background:rgba(45,110,168,.18);color:#1a2d45;border-left-color:#3a7abd}
html.light-mode .nav-group-header{color:#2d4a6a}
html.light-mode .nav-group-header:hover{background:rgba(45,110,168,.12);color:#1a2d45}
html.light-mode .srv-logo{filter:brightness(0) saturate(0);opacity:.45}
html.light-mode .plex-logo,
html.light-mode .emby-logo,
html.light-mode .jellyfin-logo{filter:none;opacity:1}
html.light-mode .badge-tag{color:#374151;background:rgba(0,0,0,.08)}
html.light-mode .stat-svc-row .svc-label{color:#1a2d45}
/* Section bars */
html.light-mode .section-bar.dark   {background:#dce8f5;color:#1a2d45;border-bottom-color:#bdd4e8}
html.light-mode .section-bar.neutral{background:rgba(45,110,168,.1);color:#1a2d45;border-bottom-color:rgba(45,110,168,.2)}
/* Buttons */
html.light-mode .btn-dark   {background:#dce8f5;color:#1a2d45;border-color:#bdd4e8}
html.light-mode .btn-outline{color:#1a3558;border-color:#5a8ab0}
html.light-mode .btn-outline:hover{background:rgba(45,110,168,.1)}
/* Modal */
html.light-mode .modal-overlay{background:rgba(0,0,0,.4)}
html.light-mode .modal{border-color:#bdd4e8}
html.light-mode .modal-header.dark{background:linear-gradient(135deg,#dce8f5 0%,#c8ddf0 100%)}
html.light-mode .modal-header h3{color:#1a2d45}
html.light-mode .modal-close{color:rgba(26,45,69,.7)}
html.light-mode .modal-close:hover{color:#1a2d45;background:rgba(26,45,69,.12)}
/* TOS modal content */
.tos-modal-body{color:var(--text-muted);font-size:12.5px;line-height:1.7}
.tos-modal-body h3{font-size:11px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.4px;margin:14px 0 4px}
.tos-modal-body h3:first-child{margin-top:0}
.tos-modal-body p{margin:0 0 10px}
.tos-modal-body strong{color:var(--text)}
/* Tables */
html.light-mode thead th{border-bottom-color:rgba(0,0,0,.1);background:rgba(45,110,168,.08);color:#1e293b}
html.light-mode tbody tr{border-bottom-color:rgba(0,0,0,.06)}
html.light-mode tbody tr:hover{background:rgba(45,110,168,.06)}
/* Toolbars & bars */
html.light-mode .info-row  {background:rgba(45,110,168,.08);border-bottom-color:rgba(45,110,168,.15)}
html.light-mode .toolbar   {background:rgba(45,110,168,.08);border-bottom-color:rgba(45,110,168,.15)}
html.light-mode .tab-bar   {background:rgba(45,110,168,.08);border-bottom-color:rgba(45,110,168,.15)}
html.light-mode .action-bar{background:rgba(45,110,168,.06);border-bottom-color:rgba(45,110,168,.15)}
/* Stat & server cards */
html.light-mode .stat-card{background:rgba(255,255,255,.85);border-color:rgba(45,110,168,.25)}
html.light-mode .stat-card.stat-clickable:hover{background:rgba(45,110,168,.1);border-color:rgba(45,110,168,.4);transform:translateY(-1px)}
html.light-mode .stat-svc-row{background:rgba(45,110,168,.08)}
html.light-mode .stat-svc-row:hover{background:rgba(45,110,168,.15)}
html.light-mode .stat-svc-row .svc-label{color:#1a2d45}
html.light-mode .stream-card{border-color:var(--border);background:var(--input-bg)}
html.light-mode .stream-card-hdr{background:var(--card-bg);border-bottom-color:var(--border)}
html.light-mode .stream-card-badge{background:rgba(0,0,0,.06)}
html.light-mode .stream-card-bar{background:rgba(0,0,0,.1)}
html.light-mode .srv-status-card{background:rgba(255,255,255,.85);border-color:rgba(45,110,168,.25)}
html.light-mode .srv-status-card-body{border-top-color:rgba(0,0,0,.08)}
/* User cards */
html.light-mode .uc-card{background:#f0f6fc;border-color:rgba(45,110,168,.25)}
html.light-mode .uc-uname{color:#1a2d45}
html.light-mode .uc-info{color:#1e293b}
html.light-mode .uc-tv{background:#e8f0f8;color:#4a7090}
html.light-mode .uc-tv:hover{background:#d8e8f5;color:#2d5a80}
html.light-mode .uc-tv.uc-tv-on{background:#0d9488;color:#fff}
html.light-mode .uc-tv.uc-tv-on:hover{background:#0f766e}
html.light-mode .uc-menu{color:rgba(26,45,69,.8)}
html.light-mode .uc-menu:hover{background:rgba(45,110,168,.12)}
html.light-mode .uc-dropdown{background:#f0f6fc;border-color:rgba(45,110,168,.3);box-shadow:0 6px 20px rgba(0,0,0,.15)}
html.light-mode .uc-dd-item{color:#1a2d45}
html.light-mode .uc-dd-item:hover{background:rgba(45,110,168,.08);color:#1a3558}
html.light-mode .uc-actions{border-top-color:rgba(0,0,0,.08)}
/* Forms */
html.light-mode .form-label{color:#1e293b}
html.light-mode .form-hint{color:#1e293b}
html.light-mode .form-input::placeholder{color:#6a88a8}
html.light-mode .filter-input-dark{background:var(--input-bg);border-color:var(--border);color:var(--text)}
html.light-mode .filter-input-dark::placeholder{color:#6a88a8}
/* Created info box */
html.light-mode .created-info-box{background:rgba(45,110,168,.06);border-color:rgba(45,110,168,.15)}
html.light-mode .created-info-row{border-bottom-color:rgba(45,110,168,.1)}
html.light-mode .created-info-label{color:#1e293b}
html.light-mode .created-info-val{color:#1a2d45}
/* Misc */
html.light-mode .progress-bar{background:rgba(45,110,168,.15)}
html.light-mode .spinner{border-color:rgba(45,110,168,.2);border-top-color:var(--teal)}
html.light-mode .toast{box-shadow:0 4px 16px rgba(0,0,0,.15)}
html.light-mode .footer{background:#dce8f5;color:#1e293b;border-top-color:#bdd4e8}
html.light-mode .footer a{color:#2d6ea8}
html.light-mode ::-webkit-scrollbar-thumb{background:rgba(45,110,168,.25)}
html.light-mode ::-webkit-scrollbar-thumb:hover{background:rgba(45,110,168,.4)}
/* Unregistered users modal server tabs */
html.light-mode .unreg-tab{color:#4a7090 !important}
html.light-mode .unreg-tab.active{color:#1a2d45 !important;background:rgba(45,110,168,.15) !important;border-bottom-color:#2d6ea8 !important}

/* ── Responsive ─────────────────────────────────────────────────────────────── */
@media(max-width:640px){
  .sidebar-toggle{display:flex}
  .sidebar{
    position:fixed;top:0;left:0;bottom:0;
    z-index:200;
    transform:translateX(-100%);
    transition:transform .25s ease;
  }
  .sidebar.open{transform:translateX(0)}
  .form-row{grid-template-columns:1fr}
  .btn-label{display:none}
  .section-bar-right{flex-wrap:wrap;justify-content:flex-end}
  input,select,textarea{font-size:16px !important}
}
