@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

/* ━━ STREAM SHIELD DESIGN SYSTEM ━━━━━━━━━━━━━━━
   Premium dark-mode SaaS admin panel
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

:root {
  --bg:          #111318;
  --bg2:         #161922;
  --card:        #1c2030;
  --card2:       #232839;
  --border:      rgba(255,255,255,0.08);
  --text:        #e4e8f0;
  --muted:       #7a8599;
  --accent:      #6366f1;
  --accent-h:    #5558e6;
  --green:       #10b981;
  --red:         #ef4444;
  --orange:      #f59e0b;
  --purple:      #8b5cf6;
  --pink:        #ec4899;
  --cyan:        #06b6d4;
  --yellow:      #eab308;
  --sidebar-w:   260px;
  --input:       #161922;
}

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

html { overflow-x: hidden; }

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  font-size: 14px;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── UTILITY CLASSES ───────────────────────────── */

/* Text sizes */
.text-xxs { font-size: 9px; }
.text-xs  { font-size: 10px; }
.text-s   { font-size: 11px; }
.text-sm  { font-size: 12px; }
.text-md  { font-size: 13px; }
.text-base { font-size: 14px; }
.text-lg  { font-size: 15px; }
.text-xl  { font-size: 16px; }
.text-2xl { font-size: 17px; }
.text-3xl { font-size: 18px; }
.text-4xl { font-size: 32px; }

/* Font weights */
.font-normal   { font-weight: 400; }
.font-medium   { font-weight: 500; }
.font-semibold { font-weight: 600; }
.font-bold     { font-weight: 700; }

/* Colors */
.text-muted   { color: var(--muted); }
.text-accent  { color: var(--accent); }
.text-green   { color: var(--green); }
.text-red     { color: var(--red); }
.text-orange  { color: var(--orange); }
.text-cyan    { color: var(--cyan); }
.text-purple  { color: var(--purple); }
.text-white   { color: #fff; }
.text-default { color: var(--text); }

/* Display */
.d-none    { display: none; }
.d-inline  { display: inline; }
.d-block   { display: block; }
.d-flex    { display: flex; }
.d-grid    { display: grid; }
.d-inline-flex { display: inline-flex; }

/* Flexbox */
.flex-center    { display: flex; align-items: center; }
.flex-between   { display: flex; align-items: center; justify-content: space-between; }
.flex-col       { flex-direction: column; }
.flex-wrap      { flex-wrap: wrap; }
.flex-1         { flex: 1; }
.flex-1-min     { flex: 1; min-width: 0; }
.flex-shrink-0  { flex-shrink: 0; }
.items-start    { align-items: flex-start; }
.items-center   { align-items: center; }
.justify-center { justify-content: center; }
.gap-2  { gap: 2px; }
.gap-3  { gap: 3px; }
.gap-4  { gap: 4px; }
.gap-6  { gap: 6px; }
.gap-8  { gap: 8px; }
.gap-10 { gap: 10px; }
.gap-12 { gap: 12px; }
.gap-14 { gap: 14px; }
.gap-16 { gap: 16px; }
.gap-20 { gap: 20px; }
.gap-24 { gap: 24px; }

/* Margins */
.mb-0  { margin-bottom: 0; }
.mb-1  { margin-bottom: 1px; }
.mb-2  { margin-bottom: 2px; }
.mb-4  { margin-bottom: 4px; }
.mb-6  { margin-bottom: 6px; }
.mb-8  { margin-bottom: 8px; }
.mb-10 { margin-bottom: 10px; }
.mb-12 { margin-bottom: 12px; }
.mb-14 { margin-bottom: 14px; }
.mb-16 { margin-bottom: 16px; }
.mb-20 { margin-bottom: 20px; }
.mb-24 { margin-bottom: 24px; }
.mt-4  { margin-top: 4px; }
.mt-6  { margin-top: 6px; }
.mt-8  { margin-top: 8px; }
.mt-10 { margin-top: 10px; }
.mt-12 { margin-top: 12px; }
.mt-14 { margin-top: 14px; }
.mt-16 { margin-top: 16px; }
.m-0   { margin: 0; }

/* Padding */
.p-0   { padding: 0; }
.p-sm  { padding: 16px 20px; }
.p-md  { padding: 24px; }
.p-20  { padding: 20px; }
.pb-0  { padding-bottom: 0; }
.pt-12 { padding-top: 12px; }

/* Text alignment */
.text-center { text-align: center; }
.text-right  { text-align: right; }

/* Text helpers */
.text-muted-sm  { font-size: 11px; color: var(--muted); }
.text-muted-xs  { font-size: 10px; color: var(--muted); }
.text-muted-md  { font-size: 12px; color: var(--muted); }
.text-muted-lg  { font-size: 13px; color: var(--muted); }
.text-truncate  { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.text-nowrap    { white-space: nowrap; }
.uppercase      { text-transform: uppercase; }
.tracking-wide  { letter-spacing: 0.4px; }
.no-decoration  { text-decoration: none; }

/* Opacity */
.opacity-30 { opacity: 0.3; }
.opacity-40 { opacity: 0.4; }
.opacity-50 { opacity: 0.5; }
.opacity-60 { opacity: 0.6; }
.opacity-70 { opacity: 0.7; }

/* Width */
.w-full { width: 100%; }
.w-auto { width: auto; }
.min-w-0 { min-width: 0; }

/* Position */
.relative { position: relative; }
.absolute { position: absolute; }

/* Overflow */
.overflow-hidden { overflow: hidden; }
.overflow-y-auto { overflow-y: auto; }

/* Inline display */
.d-inline-block { display: inline-block; }

/* Border */
.border-top    { border-top: 1px solid var(--border); }
.border-bottom { border-bottom: 1px solid var(--border); }
.border-none   { border: none; }
.rounded-sm { border-radius: 4px; }
.rounded    { border-radius: 8px; }
.rounded-md { border-radius: 10px; }
.rounded-lg { border-radius: 12px; }

/* Cursor */
.cursor-pointer { cursor: pointer; }
.cursor-default { cursor: default; }

/* Transition */
.transition { transition: all 0.15s; }

/* ── COMMON COMPONENT PATTERNS ───────────────── */

/* Section header used in settings tabs */
.section-title     { font-size: 13px; font-weight: 600; }
.section-subtitle  { font-size: 11px; color: var(--muted); }
.section-header    { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }

/* Settings card (compact padding) */
.card-compact { padding: 16px 20px; margin-bottom: 12px; }
.card-compact-flush { padding: 16px 20px; }

/* Stat/info label (uppercase muted) */
.stat-label {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 4px;
}

/* Field label (small) */
.field-label { font-size: 11px; margin-bottom: 4px; }

/* Input compact */
.input-compact { padding: 8px 12px; }
.input-sm      { padding: 7px 12px; font-size: 12px; }
.input-mono    { font-family: monospace; font-size: 12px; padding: 8px 12px; }

/* Toggle switch (used in footer/settings) */
.toggle       { position: relative; width: 36px; height: 20px; flex-shrink: 0; }
.toggle input { opacity: 0; width: 0; height: 0; position: absolute; }
.toggle-track {
  position: absolute; inset: 0;
  background: rgba(255,255,255,0.08);
  border-radius: 10px;
  cursor: pointer;
  transition: background 0.2s;
}
.toggle-track::after {
  content: '';
  position: absolute;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: #fff;
  top: 2px; left: 2px;
  transition: transform 0.2s;
}
.toggle input:checked + .toggle-track { background: var(--accent); }
.toggle input:checked + .toggle-track::after { transform: translateX(16px); }

/* Social row (footer settings) */
.social-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.social-row:last-child { border-bottom: none; }
.social-icon {
  width: 28px; height: 28px;
  border-radius: 6px;
  background: rgba(255,255,255,0.04);
  display: flex; align-items: center; justify-content: center;
  color: var(--muted);
  flex-shrink: 0;
}
.social-icon-active {
  color: var(--accent);
  background: rgba(99,102,241,0.08);
  border: 1px solid rgba(99,102,241,0.15);
}
.social-name { font-size: 12px; font-weight: 500; min-width: 80px; }
.social-url  { flex: 1; min-width: 0; }
.social-url input { font-size: 12px; padding: 7px 10px; }

/* Empty state */
.empty-state {
  text-align: center;
  padding: 32px;
  color: var(--muted);
  font-size: 13px;
}
.empty-state-lg {
  text-align: center;
  padding: 48px 20px;
  color: var(--muted);
}
.empty-state-icon { font-size: 32px; margin-bottom: 10px; opacity: 0.3; }

/* Hint / code inline */
.code-inline {
  background: rgba(255,255,255,0.06);
  padding: 1px 5px;
  border-radius: 3px;
}

/* Info box */
.info-box {
  font-size: 12px; color: var(--muted);
  line-height: 1.6;
  padding: 10px 14px;
  background: rgba(99,102,241,0.04);
  border: 1px solid rgba(99,102,241,0.1);
  border-radius: 8px;
}

/* Warning alert */
.alert-warning {
  padding: 8px 12px;
  background: rgba(245,158,11,0.04);
  border: 1px solid rgba(245,158,11,0.1);
  border-radius: 6px;
}

/* Icon container (small icon box) */
.icon-box-sm {
  width: 28px; height: 28px;
  border-radius: 6px;
  background: rgba(99,102,241,0.1);
  color: var(--accent);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

/* Slide-in panel (used for detail drawers) */
.slide-panel {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: 520px; max-width: 100vw;
  background: var(--card);
  border-left: 1px solid var(--border);
  box-shadow: -8px 0 32px rgba(0,0,0,0.4);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.slide-panel-header {
  padding: 20px 24px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}

/* Poster / thumbnail card */
.poster-card {
  width: 170px; height: 245px;
  border-radius: 8px;
  overflow: hidden;
  flex-shrink: 0;
  position: relative;
  background: var(--bg);
}
.poster-badge {
  position: absolute; bottom: 6px; left: 6px;
  background: rgba(99,102,241,0.85);
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 10px; font-weight: 600;
  color: #fff;
}

/* Nav icon size (used across sidebar and tables) */
.icon-sm { flex-shrink: 0; width: 13px; height: 13px; }

/* Tab bar (settings page) */
.tab-bar { display: flex; gap: 3px; margin-bottom: 16px; }
.tab-btn  { padding: 6px 14px; font-size: 12px; }

/* Sub tab (inline tabs within a card) */
.sub-tab {
  flex: 1; text-align: center;
  padding: 8px;
  border-bottom: 2px solid var(--border);
  font-size: 12px; font-weight: 500;
  color: var(--muted);
  transition: all 0.2s;
  cursor: pointer;
}
.sub-tab-active {
  color: var(--accent);
  border-color: var(--accent);
}

/* View-only notice alt */
.notice-box {
  padding: 12px 16px;
  background: rgba(99,102,241,0.04);
  border: 1px solid rgba(99,102,241,0.1);
  border-radius: 8px;
  font-size: 12px;
  color: var(--muted);
}

[x-cloak] { display: none !important; }

/* ── LAYOUT ─────────────────────────────────── */
.app-shell { display: flex; min-height: 100vh; overflow-x: hidden; max-width: 100vw; }

/* ── SIDEBAR ────────────────────────────────── */
.sidebar {
  width: var(--sidebar-w);
  background: #13161f;
  border-right: 1px solid rgba(255,255,255,0.06);
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0; left: 0;
  height: 100vh;
  z-index: 1100;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar-logo {
  padding: 20px 20px 18px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 12px;
}

.sidebar-logo-icon {
  width: 38px; height: 38px;
  background: linear-gradient(135deg, var(--accent), var(--purple));
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 800; color: #fff;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(99,102,241,0.25);
}

.sidebar-logo-text { font-size: 14px; font-weight: 700; line-height: 1.2; letter-spacing: -0.01em; }
.sidebar-logo-text span { display: block; font-size: 11px; font-weight: 400; color: var(--muted); margin-top: 2px; }

.sidebar-user {
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 12px;
}

.sidebar-avatar {
  width: 36px; height: 36px;
  background: linear-gradient(135deg, var(--accent), var(--cyan));
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 14px; color: #fff;
  flex-shrink: 0;
}

.sidebar-user-info { flex: 1; min-width: 0; }
.sidebar-user-info strong { display: block; font-size: 13px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sidebar-user-info small { font-size: 11px; color: var(--muted); }

.sidebar-nav {
  flex: 1;
  padding: 12px 12px;
  display: flex; flex-direction: column; gap: 2px;
  overflow-y: auto;
}

/* Scrollbar styling for sidebar */
.sidebar-nav::-webkit-scrollbar { width: 4px; }
.sidebar-nav::-webkit-scrollbar-track { background: transparent; }
.sidebar-nav::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.08); border-radius: 4px; }
.sidebar-nav::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.12); }

.nav-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px;
  border-radius: 8px;
  color: var(--muted);
  text-decoration: none;
  font-size: 13px; font-weight: 500;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  border-left: 2px solid transparent;
  margin-left: 2px;
}

.nav-item:hover {
  background: rgba(255,255,255,0.05);
  color: var(--text);
}

.nav-item.active {
  background: rgba(99,102,241,0.1);
  color: var(--accent);
  border-left-color: var(--accent);
}

.nav-item.active::after {
  content: '';
  position: absolute; right: 10px; top: 50%; transform: translateY(-50%);
  width: 5px; height: 5px;
  background: var(--accent);
  border-radius: 50%;
  opacity: 0.8;
}

.nav-icon { width: 18px; height: 18px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }

.sidebar-footer { padding: 12px; border-top: 1px solid var(--border); }
.sidebar-footer .nav-item:hover { background: rgba(239,68,68,.08); color: var(--red); border-left-color: var(--red); }

/* ── VPN SIDEBAR WIDGET ─────────────────────── */
.vpn-sidebar-widget {
  padding: 10px 12px;
  border-top: 1px solid var(--border);
  position: relative;
}

.vpn-sidebar-btn {
  width: 100%;
  display: flex; align-items: center; gap: 9px;
  padding: 9px 11px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--muted);
  cursor: pointer;
  font-size: 12px; font-family: inherit; font-weight: 500;
  text-align: left;
  transition: border-color .2s, color .2s, background .2s;
}
.vpn-sidebar-btn:hover { border-color: rgba(99,102,241,0.3); color: var(--text); background: rgba(255,255,255,0.03); }
.vpn-sidebar-btn.vpn-is-connected { border-color: rgba(16,185,129,0.3); color: var(--text); }

.vpn-sidebar-icon { flex-shrink: 0; display: flex; align-items: center; }
.vpn-sidebar-label { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.vpn-sidebar-dot {
  width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
}
.vpn-sidebar-dot.dot-on  { background: var(--green); box-shadow: 0 0 6px rgba(16,185,129,0.5); }
.vpn-sidebar-dot.dot-off { background: var(--muted); }

.vpn-sidebar-popup {
  position: absolute;
  bottom: calc(100% + 6px);
  left: 12px; right: 12px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  z-index: 300;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.03);
}
.vpn-popup-header {
  font-size: 10px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .07em; color: var(--muted); margin-bottom: 8px;
}
.vpn-popup-name  { font-weight: 600; font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; margin-bottom: 3px; }
.vpn-popup-proxy { font-size: 10px; color: var(--muted); word-break: break-all; margin-bottom: 10px; }

/* ── SEARCHABLE VPN SELECT ──────────────────── */
.vpn-sel-wrap { position: relative; }

.vpn-sel-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 10px;
  background: var(--input);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text);
  font-size: 12px; font-family: inherit;
  cursor: pointer;
  min-width: 160px; max-width: 200px;
  transition: border-color .2s, box-shadow .2s;
}
.vpn-sel-btn:hover          { border-color: rgba(99,102,241,0.3); }
.vpn-sel-btn.vpn-sel-active { border-color: rgba(16,185,129,0.4); }
.vpn-sel-btn.vpn-sel-direct { border-color: rgba(6,182,212,0.4); color: var(--cyan); }

.vpn-sel-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 4px;
  min-width: 260px; width: 300px; max-width: 320px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  z-index: 9999;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5);
  overflow: hidden;
}
.vpn-sel-search {
  width: 100%; padding: 10px 12px;
  background: var(--card2); border: none; border-bottom: 1px solid var(--border);
  color: var(--text); font-size: 12px; font-family: inherit; outline: none;
}
.vpn-sel-options { max-height: 200px; overflow-y: auto; }
.vpn-sel-opt {
  padding: 8px 12px; font-size: 12px; cursor: pointer; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  display: flex; align-items: center; gap: 4px;
  transition: background 0.15s;
}
.vpn-sel-opt:hover { background: rgba(255,255,255,0.03); }
.vpn-sel-opt.vpn-sel-cur { color: var(--accent); font-weight: 600; }

/* ── MAIN ───────────────────────────────────── */
.main-wrap {
  margin-left: var(--sidebar-w);
  flex: 1;
  display: flex; flex-direction: column;
  min-height: 100vh;
  min-width: 0;
  overflow-x: hidden;
  max-width: 100%;
}

.main-header {
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  padding: 0 28px;
  height: 60px;
  display: flex; align-items: center; gap: 16px;
  position: sticky; top: 0; z-index: 100;
  backdrop-filter: blur(12px);
  background: rgba(22,25,34,0.88);
}

.main-header h1 {
  font-size: 18px;
  font-weight: 600;
  flex: 1;
  letter-spacing: -0.01em;
  color: var(--text);
}

.header-search {
  display: flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 8px 14px;
  width: 260px;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.header-search:focus-within {
  border-color: rgba(99,102,241,0.3);
  box-shadow: 0 0 0 3px rgba(99,102,241,0.06);
}

.header-search input {
  background: none; border: none;
  color: var(--text); font-size: 13px; width: 100%; outline: none;
}

.header-search input::placeholder { color: var(--muted); }

.main-content { padding: 28px 32px; flex: 1; width: 100%; min-width: 0; }

/* ── GLOBAL SITE FOOTER ────────────────────── */
.site-footer {
  border-top: 1px solid var(--border);
  background: var(--bg);
  padding: 14px 32px;
  flex-shrink: 0;
}
.site-footer-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}
.site-footer-left {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--muted);
}
.site-footer-left strong { color: var(--text); font-weight: 600; }
.site-footer-right {
  display: flex;
  align-items: center;
  gap: 10px;
}
.site-footer-social {
  color: var(--muted);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.05);
  transition: all .15s;
}
.site-footer-social:hover {
  color: var(--accent);
  background: rgba(99,102,241,0.08);
  border-color: rgba(99,102,241,0.2);
}
.site-footer-ver {
  font-size: 10px;
  color: var(--muted);
  opacity: .4;
  margin-left: 4px;
}

/* ── FLASH ──────────────────────────────────── */
.flash {
  padding: 12px 16px; border-radius: 10px; margin-bottom: 20px;
  font-size: 13px; font-weight: 500;
  display: flex; align-items: center; gap: 10px;
  border-left: 3px solid transparent;
}
.flash.success {
  background: rgba(16,185,129,.08);
  border: 1px solid rgba(16,185,129,.15);
  border-left: 3px solid var(--green);
  color: #6ee7b7;
}
.flash.error {
  background: rgba(239,68,68,.06);
  border: 1px solid rgba(239,68,68,.15);
  border-left: 3px solid var(--red);
  color: #fca5a5;
}
.flash.info {
  background: rgba(99,102,241,.06);
  border: 1px solid rgba(99,102,241,.15);
  border-left: 3px solid var(--accent);
  color: #a5b4fc;
}

/* ── CARDS ──────────────────────────────────── */
.card {
  background: var(--card);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 12px;
  padding: 24px;
  margin-bottom: 20px;
  min-width: 0;
  max-width: 100%;
  box-shadow: 0 1px 3px rgba(0,0,0,0.15), 0 0 0 1px rgba(255,255,255,0.03);
  transition: border-color 0.2s;
}

.card-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}

.card-title { font-size: 14px; font-weight: 600; letter-spacing: -0.01em; }

/* Card row: full-width cards, equally distributed when side-by-side */
.card-row {
  display: flex; gap: 12px; width: 100%;
  margin-bottom: 12px;
  align-items: stretch;
}
.card-row > .card {
  flex: 1; min-width: 0;
  margin-bottom: 0;
}
@media (max-width: 640px) {
  .card-row { flex-direction: column; }
}

/* ── KPI CARDS ──────────────────────────────── */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 12px;
  margin-bottom: 20px;
  width: 100%;
  align-items: stretch;
}

.kpi-card {
  background: var(--card);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 12px;
  padding: 16px 18px 18px;
  display: flex; flex-direction: column; gap: 6px;
  position: relative; overflow: hidden;
  box-shadow: 0 1px 3px rgba(0,0,0,0.12);
  min-width: 0;
  box-shadow: 0 1px 2px rgba(0,0,0,0.15);
  transition: border-color 0.2s, box-shadow 0.2s;
}

.kpi-card:hover {
  border-color: rgba(255,255,255,0.09);
  box-shadow: 0 2px 8px rgba(0,0,0,0.2);
}

.kpi-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px; border-radius: 0 0 12px 12px;
}
.kpi-card.blue::after   { background: linear-gradient(90deg, var(--accent), var(--cyan)); }
.kpi-card.green::after  { background: linear-gradient(90deg, var(--green), #6ee7b7); }
.kpi-card.orange::after { background: linear-gradient(90deg, var(--orange), var(--yellow)); }
.kpi-card.purple::after { background: linear-gradient(90deg, var(--purple), var(--pink)); }
.kpi-card.cyan::after   { background: linear-gradient(90deg, var(--cyan), #67e8f9); }

.kpi-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 2px; }
.kpi-label { font-size: 10px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: .5px; }

.kpi-icon {
  width: 30px; height: 30px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center; font-size: 14px;
}
.kpi-icon.blue   { background: rgba(99,102,241,.1);  color: var(--accent); }
.kpi-icon.green  { background: rgba(16,185,129,.1);   color: var(--green); }
.kpi-icon.orange { background: rgba(245,158,11,.1);   color: var(--orange); }
.kpi-icon.purple { background: rgba(139,92,246,.1);   color: var(--purple); }
.kpi-icon.cyan   { background: rgba(6,182,212,.1);    color: var(--cyan); }

.kpi-value { font-size: 24px; font-weight: 700; line-height: 1; letter-spacing: -0.02em; }
.kpi-footer { font-size: 10px; color: var(--muted); }

/* ── CHARTS GRID ────────────────────────────── */
.charts-grid {
  display: grid;
  grid-template-columns: 1fr 1.7fr;
  gap: 16px;
  margin-bottom: 20px;
  width: 100%;
  min-width: 0;
}

.chart-wrap {
  position: relative; height: 200px;
  width: 100%; min-width: 0;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}

canvas { display: block; max-width: 100%; }

.donut-center {
  position: absolute; text-align: center; pointer-events: none;
}
.donut-center .val { font-size: 22px; font-weight: 700; letter-spacing: -0.02em; }
.donut-center .lbl { font-size: 11px; color: var(--muted); }

.chart-legend {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 10px; margin-top: 16px;
}

.legend-item { display: flex; align-items: center; gap: 8px; font-size: 12px; }
.legend-dot { width: 10px; height: 10px; border-radius: 3px; flex-shrink: 0; }
.legend-item strong { display: block; font-size: 15px; font-weight: 600; margin-top: 1px; }
.legend-item span { color: var(--muted); font-size: 11px; }

/* ── GRID HELPERS ───────────────────────────── */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-items: stretch; }
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; align-items: stretch; }
.gap-16 { gap: 16px; }

/* ── TABLES ─────────────────────────────────── */
.table-wrap {
  overflow: visible;
  width: 100%;
  max-width: 100%;
  display: block;
}
@media (max-width: 900px) {
  .table-wrap { overflow-x: auto; overflow-y: visible; -webkit-overflow-scrolling: touch; }
}

table { width: 100%; border-collapse: collapse; font-size: 13px; }
thead tr { border-bottom: 1px solid var(--border); }

th {
  padding: 12px 16px; text-align: left;
  font-size: 12px; font-weight: 500; color: var(--muted);
  white-space: nowrap;
}

td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}
tr:last-child td { border-bottom: none; }

tbody tr {
  transition: background 0.15s;
}
tbody tr:nth-child(even) { background: rgba(255,255,255,0.01); }
tbody tr:hover { background: rgba(255,255,255,0.04); }

/* ── BADGES ─────────────────────────────────── */
.badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: 999px;
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.01em;
}
.badge-ok,
.badge-enabled,
.badge-success {
  background: rgba(16,185,129,.1);
  color: #6ee7b7;
  border: 1px solid rgba(16,185,129,.15);
}
.badge-off,
.badge-disabled,
.badge-error,
.badge-danger {
  background: rgba(239,68,68,.08);
  color: #fca5a5;
  border: 1px solid rgba(239,68,68,.15);
}
.badge-warning, .badge-warn {
  background: rgba(234,179,8,.08);
  color: #fde68a;
  border: 1px solid rgba(234,179,8,.15);
}
.badge-info {
  background: rgba(99,102,241,.1);
  color: #a5b4fc;
  border: 1px solid rgba(99,102,241,.18);
}

/* ── FORMS ──────────────────────────────────── */
.form-group { margin-bottom: 18px; }
.form-row { display: flex; gap: 16px; flex-wrap: wrap; }
.form-row > * { flex: 1; min-width: 200px; }

label {
  display: block;
  font-size: 12px; font-weight: 500; color: var(--muted);
  margin-bottom: 6px;
  letter-spacing: 0;
}

input, select, textarea {
  width: 100%;
  background: var(--bg);
  border: 1px solid rgba(255,255,255,0.1);
  color: var(--text);
  border-radius: 8px;
  padding: 11px 14px;
  font-size: 13px; font-family: inherit;
  transition: border-color .2s, box-shadow .2s;
  outline: none;
}

input:focus, select:focus, textarea:focus {
  border-color: rgba(99,102,241,0.4);
  box-shadow: 0 0 0 3px rgba(99,102,241,0.08);
}

option {
  background: var(--card);
  color: var(--text);
}

option:hover, option:checked {
  background: var(--accent);
  color: #fff;
}

input[type="checkbox"] { width: auto; accent-color: var(--accent); }
input[type="time"] { width: auto; }
input[readonly] { opacity: .6; cursor: default; }

.checkbox-row { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; }
.checkbox-row input { margin: 0; }
.checkbox-row label { margin: 0; text-transform: none; font-size: 13px; color: var(--text); letter-spacing: 0; font-weight: 500; }

/* ── BUTTONS ────────────────────────────────── */
button, .btn {
  border: none; border-radius: 8px;
  padding: 10px 20px; cursor: pointer;
  font-size: 13px; font-weight: 600; font-family: inherit;
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 6px;
  transition: all .2s cubic-bezier(0.4, 0, 0.2, 1);
  white-space: nowrap;
}

button:disabled, .btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

.btn, button.btn { background: var(--accent); color: #fff; }
.btn:hover, button.btn:hover {
  background: var(--accent-h);
  transform: scale(1.01);
  box-shadow: 0 2px 8px rgba(99,102,241,0.25);
}

.btn-secondary {
  background: rgba(255,255,255,0.04);
  color: var(--text);
  border: 1px solid var(--border);
}
.btn-secondary:hover {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.12);
}

.btn-danger {
  background: rgba(239,68,68,.08);
  color: #fca5a5;
  border: 1px solid rgba(239,68,68,.15);
}
.btn-danger:hover {
  background: rgba(239,68,68,.14);
  transform: scale(1.01);
}

.btn-success {
  background: rgba(16,185,129,.08);
  color: #6ee7b7;
  border: 1px solid rgba(16,185,129,.15);
}
.btn-success:hover {
  background: rgba(16,185,129,.14);
  transform: scale(1.01);
}

.btn-sm { padding: 7px 14px; font-size: 12px; }

/* ── ACTION STACK (legacy compat) ───────────── */
.action-stack { display: flex; flex-direction: column; gap: 6px; }
.action-stack form { margin: 0; }
.action-stack button { width: 100%; }
.action-btns { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.row { display: flex; gap: 12px; flex-wrap: wrap; align-items: stretch; }
.row > * { flex: 1; min-width: 140px; }

/* ── LOADING OVERLAY ────────────────────────── */
#loading-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.7);
  backdrop-filter: blur(8px);
  display: none; align-items: center; justify-content: center;
  z-index: 9999;
}
#loading-overlay.show { display: flex; }
#loading-text {
  background: var(--card); border: 1px solid var(--border);
  color: var(--text); padding: 20px 32px; border-radius: 14px;
  font-weight: 600; font-size: 14px;
  display: flex; align-items: center; gap: 12px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.4);
}
.spinner {
  width: 20px; height: 20px;
  border: 2px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin .8s linear infinite;
}
.spinner-sm { width: 14px; height: 14px; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── MISC ───────────────────────────────────── */
pre {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 8px; padding: 14px;
  font-size: 12px; overflow-x: auto;
  white-space: pre-wrap; word-break: break-word;
  color: #94a3b8;
  font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
}

small, .muted { color: var(--muted); }
.text-green  { color: var(--green); }
.text-red    { color: var(--red); }
.text-accent { color: var(--accent); }

/* .section-title defined in utility section (13px) — this was a duplicate, removed */

details summary { cursor: pointer; color: var(--muted); font-size: .85em; transition: color 0.15s; }
details summary:hover { color: var(--text); }
details pre { margin-top: 8px; }

/* ── PAGINATION ─────────────────────────────── */
.pagination {
  display: flex; gap: 6px; flex-wrap: wrap;
  align-items: center; margin-top: 16px;
  padding-top: 16px; border-top: 1px solid var(--border);
}
.page-link {
  padding: 7px 14px; border-radius: 999px;
  background: transparent; color: var(--muted);
  text-decoration: none; font-size: 12px; font-weight: 500;
  border: 1px solid var(--border);
  transition: all .2s;
}
.page-link:hover {
  background: rgba(255,255,255,0.04);
  color: var(--text);
  border-color: rgba(255,255,255,0.12);
}
.page-link.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

/* ── SUPERADMIN BADGE / NAV ─────────────────── */
.badge-sa {
  background: rgba(245,158,11,.1);
  color: #fbbf24;
  border: 1px solid rgba(245,158,11,.2);
}
.nav-item-sa { color: #fbbf24 !important; }
.nav-item-sa .nav-icon svg { stroke: #fbbf24; }
.nav-item-sa:hover,
.nav-item-sa.active { background: rgba(245,158,11,.08) !important; }
.nav-section-divider {
  height: 1px;
  background: var(--border);
  margin: 8px 12px;
}

/* ── SUPERADMIN PAGE HEADER ─────────────────── */
.sa-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 20px;
}

/* ── ADMIN ACCOUNT ROWS ─────────────────────── */
.admin-row {
  border-top: 1px solid var(--border);
  padding: 16px 0;
}
.admin-row:first-of-type { border-top: none; padding-top: 0; }
.admin-row-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

/* ── PERMISSION MATRIX ──────────────────────── */
.perm-matrix {
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
}
.perm-group-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: rgba(255,255,255,0.03);
  padding: 10px 14px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--accent);
  border-bottom: 1px solid var(--border);
}
.perm-group-header:not(:first-child) { border-top: 1px solid var(--border); }
.perm-matrix-row {
  padding: 4px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.03);
  transition: background .15s;
}
.perm-matrix-row:last-child { border-bottom: none; }
.perm-matrix-row:hover { background: rgba(255,255,255,0.02); }
.perm-check-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  padding: 4px 0;
  user-select: none;
  text-transform: none;
  letter-spacing: 0;
  margin: 0;
}
.perm-check-label input[type=checkbox] {
  accent-color: var(--green);
  width: 14px; height: 14px;
  cursor: pointer;
  flex-shrink: 0;
}
.perm-check-label:has(input:checked) { color: var(--green); }
.perm-check-label:has(input:not(:checked)) span { color: var(--muted); }
@media (max-width: 640px) {
  .perm-matrix-row { padding: 6px 10px; }
}

/* ── PASSWORD FIELD HELPERS ─────────────────── */
.pw-wrap {
  display: flex;
  gap: 6px;
  align-items: stretch;
}
.pw-input {
  flex: 1;
  min-width: 0;
}
.pw-btns {
  display: flex;
  gap: 3px;
  flex-shrink: 0;
}
.pw-btn {
  background: var(--card2);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 0 9px;
  font-size: 14px;
  cursor: pointer;
  color: var(--text);
  transition: background .15s, border-color .15s;
  line-height: 1;
  display: flex;
  align-items: center;
}
.pw-btn:hover { background: rgba(255,255,255,0.04); border-color: rgba(99,102,241,0.3); }
.pw-btn.copied { border-color: rgba(16,185,129,0.4); color: var(--green); }

/* ── PERMISSION GROUP TOGGLE ────────────────── */
.perm-group-toggle { cursor: pointer; }

/* ── VIEW-ONLY NOTICE ───────────────────────── */
.view-only-notice {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(99,102,241,.06);
  border: 1px solid rgba(99,102,241,.15);
  border-left: 3px solid var(--accent);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 13px;
  color: #a5b4fc;
  margin-bottom: 16px;
}

/* ── CONNECTED USER CARDS ───────────────────── */
.cu-card {
  background: var(--card2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 10px;
  margin-bottom: 6px;
  transition: border-color 0.15s;
}
.cu-card:hover { border-color: rgba(255,255,255,0.09); }
.cu-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  margin-bottom: 3px;
}
.cu-user {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
}
.cu-meta {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 10px;
  color: var(--muted);
}
.cu-time {
  font-size: 10px;
  color: var(--muted);
  margin-top: 2px;
}

/* World map responsive */
.connected-users-grid {
  grid-template-columns: 1fr 280px;
}
@media (max-width: 900px) {
  .connected-users-grid { grid-template-columns: 1fr; }
  .connected-users-grid > div:last-child {
    border-left: none;
    border-top: 1px solid var(--border);
    max-height: 200px;
  }
  #world-map { height: 220px !important; }
}
@media (max-width: 640px) {
  #world-map { height: 180px !important; }
}
@media (max-width: 380px) {
  #world-map { height: 150px !important; }
}

/* ── MODAL ──────────────────────────────────── */
.modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.6);
  backdrop-filter: blur(6px);
  z-index: 1000;
  display: flex; align-items: center; justify-content: center; padding: 20px;
}
.modal-box {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px; width: 100%; max-width: 680px;
  max-height: 90vh; overflow-y: auto;
  box-shadow: 0 24px 64px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.03);
}
.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 24px; border-bottom: 1px solid var(--border);
  position: sticky; top: 0; background: var(--card); z-index: 1; border-radius: 16px 16px 0 0;
}
.modal-header h3 { font-size: 15px; font-weight: 600; margin: 0; letter-spacing: -0.01em; }
.modal-close {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 8px; color: var(--muted); cursor: pointer;
  font-size: 16px; width: 30px; height: 30px; display: flex;
  align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
.modal-close:hover { background: rgba(255,255,255,0.08); color: var(--text); }
.modal-body { padding: 24px; }

/* ── MAP LEGEND ─────────────────────────────── */
.map-legend {
  position: absolute; bottom: 10px; left: 10px; z-index: 999;
  background: rgba(10,12,16,.85);
  border: 1px solid var(--border);
  border-radius: 8px; padding: 8px 12px;
  display: flex; gap: 12px; flex-wrap: wrap;
  backdrop-filter: blur(8px);
}
.map-legend-item { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--text); }
.map-legend-dot { width: 10px; height: 10px; border-radius: 50%; border: 1.5px solid rgba(255,255,255,.3); flex-shrink: 0; }
.map-legend-dot-vpn    { background: #22c55e; }
.map-legend-dot-proxy  { background: #f97316; }
.map-legend-dot-direct { background: #5b8ef0; }

/* ── LEAFLET MAP Z-INDEX FIX ────────────────── */
.leaflet-container { isolation: isolate; }
#world-map { position: relative; z-index: 0; }

/* ── CONTENT NAV GROUP ──────────────────────── */
.nav-group-toggle {
  width: 100%; text-align: left; background: none;
  border: none; border-radius: 8px;
  color: var(--muted); cursor: pointer;
  font-size: 13px; font-weight: 500;
  padding: 10px 12px; display: flex; align-items: center; gap: 12px;
  transition: all 0.2s;
}
.nav-group-toggle:hover { background: rgba(255,255,255,0.03); color: var(--text); }
.nav-group-toggle.active { color: var(--accent); }
.nav-chevron { transition: transform 0.2s; color: var(--muted); flex-shrink: 0; }
.nav-sub { padding-left: 16px; font-size: 12px; }
.nav-sub-wrap { padding-left: 8px; border-left: 2px solid var(--border); margin: 2px 12px 2px 18px; display: flex; flex-direction: column; gap: 1px; }

/* ── MULTI-VPN WIDGET ───────────────────────── */
.vpn-connected-count {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--green); color: #fff;
  border-radius: 999px; font-size: 10px; font-weight: 700;
  min-width: 16px; height: 16px; padding: 0 4px; margin-left: 2px;
}
.vpn-popup-vpn-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px; padding: 6px 0; border-bottom: 1px solid var(--border);
}
.vpn-popup-vpn-row:last-child { border-bottom: none; }

/* ── CONNECTED USERS FILTER BAR ─────────────── */
.cu-filter-bar {
  display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
  padding: 8px; border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,0.01);
}
.cu-filter-bar input, .cu-filter-bar select {
  padding: 5px 8px; font-size: 11px; border-radius: 6px;
  background: var(--input); border: 1px solid var(--border); color: var(--text);
  height: 28px;
}
.cu-filter-bar input { flex: 1; min-width: 80px; }
.cu-filter-bar select { min-width: 90px; }

/* ── VPN ASSIGNMENT TOOLTIP ─────────────────── */
.vpn-clients-pill {
  cursor: pointer; position: relative;
  display: inline-flex; align-items: center; gap: 4px;
}
.vpn-clients-pill .vpn-clients-tooltip {
  display: none; position: absolute; bottom: calc(100% + 4px); left: 0;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; padding: 10px 14px; min-width: 160px; max-width: 280px;
  font-size: 11px; color: var(--text); z-index: 9999;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5);
  white-space: normal; word-break: break-word;
}
.vpn-clients-pill:hover .vpn-clients-tooltip { display: block; }

/* ── CHANNEL LIST VIEW ──────────────────────── */
.channel-list-row {
  display: flex; align-items: center; gap: 12px;
  padding: 8px 12px; border-bottom: 1px solid var(--border);
  transition: background .15s;
}
.channel-list-row:hover { background: rgba(255,255,255,0.02); }
.channel-list-row:last-child { border-bottom: none; }
.channel-list-thumb {
  width: 48px; height: 36px; border-radius: 6px;
  object-fit: contain; background: rgba(0,0,0,0.3); padding: 3px; flex-shrink: 0;
}
.channel-list-placeholder {
  width: 48px; height: 36px; border-radius: 6px;
  background: rgba(0,0,0,0.3); display: flex; align-items: center; justify-content: center;
  font-size: 14px; flex-shrink: 0;
}
.view-toggle-btn {
  background: transparent; border: 1px solid var(--border);
  border-radius: 6px; color: var(--muted); cursor: pointer;
  padding: 5px 10px; font-size: 13px; display: flex; align-items: center;
  gap: 4px; transition: all .2s;
}
.view-toggle-btn:hover { border-color: rgba(255,255,255,0.12); color: var(--text); }
.view-toggle-btn.active { background: var(--accent); border-color: var(--accent); color: #fff; }

/* ── SSL STATUS ALERT ───────────────────────── */
.ssl-alert {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px; border-radius: 10px; margin-bottom: 16px; font-size: 13px;
  border-left: 3px solid transparent;
}
.ssl-alert.warning {
  background: rgba(234,179,8,.06);
  border: 1px solid rgba(234,179,8,.15);
  border-left: 3px solid var(--orange);
  color: #fde68a;
}
.ssl-alert.ok {
  background: rgba(16,185,129,.06);
  border: 1px solid rgba(16,185,129,.15);
  border-left: 3px solid var(--green);
  color: #6ee7b7;
}
.ssl-alert.error {
  background: rgba(239,68,68,.06);
  border: 1px solid rgba(239,68,68,.15);
  border-left: 3px solid var(--red);
  color: #fca5a5;
}

/* ── VPN CONNECTED BANNER ───────────────────── */
.vpn-connected-banner {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 10px 16px; border-radius: 10px; margin-bottom: 16px;
  background: rgba(16,185,129,.05); border: 1px solid rgba(16,185,129,.15);
  font-size: 13px;
}
.vpn-connected-tag {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(16,185,129,.08); border: 1px solid rgba(16,185,129,.2);
  border-radius: 999px; padding: 3px 10px; font-size: 12px; color: var(--green);
}
.vpn-connected-dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--green);
  box-shadow: 0 0 6px rgba(16,185,129,0.4);
}

/* ── LIVE CHANNELS PAGE ────────────────────── */
.lv-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.lv-header-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.lv-header-left select{width:auto;padding:7px 28px 7px 10px;font-size:12px;flex-shrink:0}
.lv-header-meta{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px}
.lv-header-meta .lv-epg-badge{font-size:9px;font-weight:600;padding:2px 8px;border-radius:99px;background:rgba(139,92,246,.1);color:#c4b5fd;border:1px solid rgba(139,92,246,.18)}
.lv-tabs{display:flex;gap:2px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:9px;padding:3px}
.lv-tab{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;font-size:12px;font-weight:500;color:var(--muted);text-decoration:none;border-radius:7px;transition:all .15s;white-space:nowrap}
.lv-tab:hover{color:var(--text);background:rgba(255,255,255,.04)}
.lv-tab.active{color:#fff;background:var(--accent);box-shadow:0 1px 4px rgba(99,102,241,.25)}
.lv-tab-badge{font-size:9px;background:rgba(239,68,68,.15);color:#fca5a5;padding:1px 6px;border-radius:99px;font-weight:600}
.lv-tab.active .lv-tab-badge{background:rgba(255,255,255,.2);color:#fff}
.lv-kpis{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.lv-kpi{flex:1;min-width:100px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:10px 14px;position:relative;overflow:hidden}
.lv-kpi::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;border-radius:0 0 10px 10px}
.lv-kpi.blue::after{background:linear-gradient(90deg,var(--accent),var(--purple))}
.lv-kpi.green::after{background:linear-gradient(90deg,var(--green),#34d399)}
.lv-kpi.cyan::after{background:linear-gradient(90deg,var(--cyan),#22d3ee)}
.lv-kpi.orange::after{background:linear-gradient(90deg,var(--orange),#fbbf24)}
.lv-kpi.red::after{background:linear-gradient(90deg,var(--red),#f87171)}
.lv-kpi-label{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:2px}
.lv-kpi-val{font-size:20px;font-weight:700;letter-spacing:-.02em;line-height:1.2}
.lv-kpi-sub{font-size:10px;color:var(--muted);margin-top:1px}
.lv-browse{display:grid;grid-template-columns:200px 1fr;gap:0;height:calc(100vh - 210px);min-height:460px}
.lv-rail{background:var(--card);border:1px solid var(--border);border-radius:12px 0 0 12px;display:flex;flex-direction:column;overflow:hidden;border-right:none}
.lv-rail-head{padding:10px;border-bottom:1px solid var(--border);flex-shrink:0}
.lv-rail-head input{width:100%;padding:7px 10px;font-size:11px;background:var(--bg);border-radius:6px}
.lv-rail-items{flex:1;overflow-y:auto;padding:4px 5px}
.lv-rail-sep{height:1px;background:var(--border);margin:4px 8px 6px}
.lv-rail-all{display:flex;align-items:center;gap:8px;width:100%;padding:9px 10px;font-size:12px;font-weight:600;background:rgba(255,255,255,.02);border:1px solid transparent;border-radius:8px;cursor:pointer;color:var(--text);text-align:left;font-family:inherit;transition:all .12s;margin-bottom:2px}
.lv-rail-all:hover{background:rgba(99,102,241,.05);border-color:rgba(99,102,241,.1)}
.lv-rail-all.active{background:linear-gradient(135deg,rgba(99,102,241,.1),rgba(139,92,246,.08));color:#a5b4fc;border-color:rgba(99,102,241,.2);box-shadow:0 1px 4px rgba(99,102,241,.1)}
.lv-rail-all-icon{width:22px;height:22px;border-radius:6px;background:linear-gradient(135deg,var(--accent),var(--purple));display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;box-shadow:0 1px 4px rgba(99,102,241,.2)}
.lv-rail-item{display:flex;align-items:center;gap:7px;width:100%;padding:6px 8px;font-size:12px;background:none;border:none;border-left:2px solid transparent;border-radius:0 6px 6px 0;cursor:pointer;color:var(--muted);text-align:left;font-family:inherit;transition:all .12s;margin-bottom:1px}
.lv-rail-item:hover{background:rgba(255,255,255,.035);color:var(--text)}
.lv-rail-item.active{background:rgba(99,102,241,.08);color:var(--accent);border-left-color:var(--accent);font-weight:500}
.lv-rail-dot{width:8px;height:8px;border-radius:3px;flex-shrink:0;opacity:.7;transition:opacity .12s}
.lv-rail-item:hover .lv-rail-dot{opacity:1}
.lv-rail-item.active .lv-rail-dot{opacity:1;box-shadow:0 0 6px currentColor}
.lv-rail-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lv-rail-count{font-size:10px;color:var(--muted);flex-shrink:0;background:rgba(255,255,255,.04);padding:1px 6px;border-radius:99px;min-width:22px;text-align:center;font-weight:400}
.lv-rail-item:hover .lv-rail-count{background:rgba(255,255,255,.07);color:var(--text)}
.lv-rail-item.active .lv-rail-count{background:rgba(99,102,241,.15);color:var(--accent);font-weight:500}
.lv-channels{background:var(--card);border:1px solid var(--border);border-radius:0 12px 12px 0;display:flex;flex-direction:column;overflow:hidden}
.lv-toolbar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);flex-shrink:0}
.lv-toolbar input{flex:1;max-width:260px;padding:7px 10px;font-size:11px;background:var(--bg);border-radius:6px}
.lv-toolbar-meta{font-size:11px;color:var(--muted);margin-left:auto;white-space:nowrap}
.lv-list-scroll{flex:1;overflow-y:auto}
.lv-section-hdr{display:flex;align-items:center;justify-content:space-between;padding:6px 14px;font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;background:rgba(0,0,0,.12);border-bottom:1px solid rgba(255,255,255,.04);position:sticky;top:0;z-index:2}
.lv-section-cnt{font-weight:400;font-size:10px;opacity:.6}
.lv-row{display:flex;align-items:center;gap:10px;padding:6px 14px;border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;transition:background .1s}
.lv-row:hover{background:rgba(255,255,255,.025)}
.lv-row.selected{background:rgba(99,102,241,.06);box-shadow:inset 3px 0 0 var(--accent)}
.lv-row-logo{width:38px;height:28px;flex-shrink:0;background:rgba(0,0,0,.18);border-radius:4px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.lv-row-logo img{max-width:100%;max-height:100%;object-fit:contain}
.lv-row-logo-ph{font-size:11px;opacity:.2}
.lv-row-info{flex:0 0 150px;min-width:0}
.lv-row-name{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.lv-row-cat{font-size:10px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.lv-row-epg{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.lv-row-now{display:flex;align-items:center;gap:6px;min-width:0}
.lv-live-dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0;box-shadow:0 0 6px rgba(16,185,129,.4);animation:lv-pulse 2s ease-in-out infinite}
@keyframes lv-pulse{0%,100%{opacity:1}50%{opacity:.4}}
.lv-row-now-title{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lv-row-progress{height:3px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden;max-width:260px}
.lv-row-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--purple));border-radius:2px;transition:width 30s linear}
.lv-row-no-epg{font-size:11px;color:var(--muted);opacity:.4;font-style:italic}
.lv-row-time{font-size:10px;color:var(--muted);flex-shrink:0;min-width:44px;text-align:right}
.lv-row-next{flex:0 0 130px;min-width:0}
.lv-row-next-label{font-size:9px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);opacity:.5;line-height:1.3}
.lv-row-next-title{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.lv-row-status{display:flex;gap:3px;flex-shrink:0}
.lv-dot{width:5px;height:5px;border-radius:50%}
.lv-dot.ok{background:var(--green)}
.lv-dot.warn{background:var(--orange);opacity:.45}
.lv-dot.err{background:var(--red);opacity:.45}
.lv-detail{position:fixed;top:0;right:0;bottom:0;width:380px;max-width:90vw;background:var(--card);border-left:1px solid var(--border);box-shadow:-12px 0 48px rgba(0,0,0,.4);z-index:1200;display:flex;flex-direction:column;overflow:hidden}
.lv-detail-head{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.lv-detail-head h3{font-size:13px;font-weight:600;margin:0}
.lv-detail-close{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:6px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);font-size:14px;font-family:inherit;transition:all .12s}
.lv-detail-close:hover{color:var(--text);background:rgba(255,255,255,.08)}
.lv-detail-body{flex:1;overflow-y:auto;padding:20px}
.lv-detail-logo{width:100%;height:80px;background:rgba(0,0,0,.12);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;overflow:hidden}
.lv-detail-logo img{max-height:56px;max-width:80%;object-fit:contain}
.lv-detail-name{font-size:16px;font-weight:600;margin-bottom:2px}
.lv-detail-cat{font-size:12px;color:var(--muted);margin-bottom:12px}
.lv-detail-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}
.lv-detail-section{margin-bottom:18px}
.lv-detail-section-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.lv-sched-item{padding:8px 10px;border-radius:6px;margin-bottom:4px;display:flex;flex-direction:column;gap:3px;transition:background .1s}
.lv-sched-item.now{background:rgba(99,102,241,.06);border:1px solid rgba(99,102,241,.12)}
.lv-sched-item:not(.now){padding-left:10px;border-left:2px solid rgba(255,255,255,.04)}
.lv-sched-time{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px}
.lv-sched-live{font-size:9px;font-weight:700;color:var(--green);text-transform:uppercase;letter-spacing:.03em}
.lv-sched-title{font-size:13px;font-weight:500}
.lv-sched-meta{font-size:10px;color:var(--muted);margin-top:2px}
.lv-meta{display:flex;flex-direction:column;gap:8px}
.lv-meta-row{display:flex;justify-content:space-between;gap:8px;font-size:12px}
.lv-meta-label{color:var(--muted);flex-shrink:0}
.lv-meta-val{text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}
.lv-list-card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.lv-filter-bar{display:flex;gap:6px;align-items:center;flex-wrap:wrap;padding:12px 16px;border-bottom:1px solid var(--border)}
.lv-filter-bar input,.lv-filter-bar select{padding:7px 10px;font-size:12px}
.lv-filter-bar input{flex:1;min-width:100px;max-width:200px}
.lv-filter-bar select{width:auto;padding-right:28px}
.lv-filter-meta{font-size:11px;color:var(--muted);margin-left:auto}
.lv-tbl{width:100%;border-collapse:collapse}
.lv-tbl th{padding:8px 12px;font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;background:rgba(0,0,0,.08)}
.lv-tbl td{padding:7px 12px;font-size:12px;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}
.lv-tbl tbody tr:hover{background:rgba(255,255,255,.02)}
.lv-tbl-logo{width:36px;height:24px;object-fit:contain;background:rgba(0,0,0,.15);border-radius:3px;display:block}
.lv-tbl-logo-ph{width:36px;height:24px;background:rgba(0,0,0,.15);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:10px;opacity:.2}
.lv-tbl-prog{display:inline-block;width:50px;height:3px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden;vertical-align:middle;margin-left:4px}
.lv-tbl-prog-fill{height:100%;background:var(--accent);border-radius:2px}
.lv-tbl-now{display:flex;align-items:center;gap:4px;min-width:0}
.lv-tbl-now-dot{width:5px;height:5px;border-radius:50%;background:var(--green);flex-shrink:0;box-shadow:0 0 4px rgba(16,185,129,.3)}
.lv-tbl-now-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}
.lv-tbl-next{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}
.lv-review-kpis{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.lv-review-kpi{flex:1;min-width:90px;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:10px 12px;text-align:center}
.lv-review-kpi-val{font-size:22px;font-weight:700;letter-spacing:-.02em}
.lv-review-kpi-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;margin-top:2px}
.lv-epg-notice{display:flex;align-items:center;gap:8px;padding:8px 14px;background:rgba(245,158,11,.06);border:1px solid rgba(245,158,11,.12);border-radius:8px;font-size:12px;color:#fde68a;margin-bottom:12px}
.lv-epg-notice a{color:var(--accent);text-decoration:none;font-weight:500}
@media(max-width:1100px){.lv-row-next{display:none}.lv-row-info{flex:0 0 120px}}
@media(max-width:900px){.lv-browse{grid-template-columns:1fr;height:auto}.lv-rail{border-radius:12px 12px 0 0;border-right:1px solid var(--border);border-bottom:none;max-height:180px}.lv-channels{border-radius:0 0 12px 12px}.lv-channels .lv-list-scroll{max-height:calc(100vh - 380px)}.lv-detail{width:320px}.lv-row-time{display:none}}
@media(max-width:640px){.lv-kpis{gap:4px}.lv-kpi{min-width:0;padding:8px 10px}.lv-kpi-val{font-size:16px}.lv-row-epg{display:none}.lv-row-info{flex:1}.lv-detail{width:100%;max-width:100vw}.lv-tbl .col-hide-sm{display:none}}

/* ── SERVICE PAGE ──────────────────────────── */
.svc-kpis{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.svc-kpi{flex:1;min-width:100px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:10px 14px;position:relative;overflow:hidden}
.svc-kpi::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;border-radius:0 0 10px 10px}
.svc-kpi.blue::after{background:linear-gradient(90deg,var(--accent),var(--purple))}
.svc-kpi.green::after{background:linear-gradient(90deg,var(--green),#34d399)}
.svc-kpi.cyan::after{background:linear-gradient(90deg,var(--cyan),#22d3ee)}
.svc-kpi.purple::after{background:linear-gradient(90deg,var(--purple),#a78bfa)}
.svc-kpi.orange::after{background:linear-gradient(90deg,var(--orange),#fbbf24)}
.svc-kpi.red::after{background:linear-gradient(90deg,var(--red),#f87171)}
.svc-kpi-label{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:2px}
.svc-kpi-val{font-size:20px;font-weight:700;letter-spacing:-.02em;line-height:1.2}
.svc-kpi-sub{font-size:10px;color:var(--muted);margin-top:1px}
.svc-action-menu{position:absolute;top:100%;right:0;margin-top:4px;z-index:9999;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:4px 0;min-width:170px;box-shadow:0 8px 24px rgba(0,0,0,.6)}
.svc-action-item{display:block;width:100%;padding:7px 14px;font-size:12px;color:var(--text);text-align:left;background:none;border:none;cursor:pointer;white-space:nowrap;font-family:inherit;transition:background .1s}
.svc-action-item:hover{background:rgba(255,255,255,.04)}
.svc-action-item.danger{color:var(--red)}
.svc-action-item.danger:hover{background:rgba(239,68,68,.06)}
.svc-action-sep{border-top:1px solid var(--border);margin:4px 0}

/* ── CLIENT PAGE ───────────────────────────── */
.cl-kpis{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.cl-kpi{flex:1;min-width:110px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:10px 14px;cursor:pointer;transition:all .15s;position:relative;overflow:hidden;text-decoration:none;display:block;color:inherit}
.cl-kpi:hover{border-color:rgba(99,102,241,.2);background:rgba(99,102,241,.03)}
.cl-kpi.active{border-color:var(--accent);background:rgba(99,102,241,.08);box-shadow:0 0 0 1px var(--accent)}
.cl-kpi::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;border-radius:0 0 10px 10px}
.cl-kpi.blue::after{background:linear-gradient(90deg,var(--accent),var(--purple))}
.cl-kpi.green::after{background:linear-gradient(90deg,var(--green),#34d399)}
.cl-kpi.red::after{background:linear-gradient(90deg,var(--red),#f87171)}
.cl-kpi.purple::after{background:linear-gradient(90deg,var(--purple),#a78bfa)}
.cl-kpi.cyan::after{background:linear-gradient(90deg,var(--cyan),#22d3ee)}
.cl-kpi-label{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:2px}
.cl-kpi-val{font-size:20px;font-weight:700;letter-spacing:-.02em;line-height:1.2}
.cl-bulk-bar{display:none;align-items:center;gap:6px;padding:10px 16px;background:rgba(99,102,241,.06);border:1px solid rgba(99,102,241,.15);border-radius:10px;margin-bottom:12px;flex-wrap:wrap}
.cl-bulk-bar.visible{display:flex}
.cl-bulk-count{background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:1px 8px;border-radius:10px}
.cl-bulk-sep{width:1px;height:18px;background:rgba(255,255,255,.06);margin:0 2px}
.cl-check{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}
.cl-reassign{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px 20px;margin-bottom:14px}
.cl-reassign-title{font-size:13px;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.cl-reassign-row{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}
.cl-reassign-row .form-group{margin-bottom:0;min-width:160px;flex:1}
.cl-reassign-row label{font-size:11px;color:var(--muted);margin-bottom:4px;display:block}
.cl-reassign-arrow{color:var(--muted);font-size:16px;align-self:center;padding-top:16px}
.cl-pagination{display:flex;gap:4px;justify-content:center;margin-top:16px;flex-wrap:wrap}
.cl-page{padding:5px 10px;border-radius:6px;font-size:12px;background:var(--card);border:1px solid var(--border);color:var(--text);text-decoration:none;transition:all .12s}
.cl-page.active{background:var(--accent);border-color:var(--accent);color:#fff}
.cl-page:hover:not(.active){border-color:rgba(99,102,241,.3)}

/* ── INLINE-STYLE REPLACEMENTS ─────────────── */

/* Shared tiny button (10px font, tight padding) */
.btn-tiny { font-size: 10px; padding: 4px 8px; }
.btn-micro { font-size: 10px; padding: 3px 7px; }
.btn-micro-narrow { font-size: 10px; padding: 3px 5px; }
.btn-filter { font-size: 11px; padding: 7px 14px; }
.btn-filter-sm { font-size: 11px; padding: 6px 12px; }

/* Badge text size overrides */
.badge-xs { font-size: 10px; }
.badge-xxs { font-size: 9px; }

/* Pagination ellipsis */
.page-ellipsis { padding: 5px 3px; color: var(--muted); }

/* Card header subtitle */
.card-title-sub { font-weight: 400; font-size: 13px; color: var(--muted); }

/* Inline form helpers */
.form-inline { display: flex; gap: 4px; align-items: center; }
.form-inline-wrap { display: flex; gap: 4px; align-items: center; flex-wrap: wrap; }
.form-inline-hidden { display: inline; }
.form-filter { display: flex; gap: 10px; flex-wrap: wrap; align-items: flex-end; margin-bottom: 16px; }

/* Form group compacted (no bottom margin) */
.form-group-compact { margin-bottom: 0; }

/* Action button row */
.action-row { display: flex; gap: 4px; }

/* Table column widths */
.col-w-30 { width: 30px; }
.col-w-44 { width: 44px; }
.col-w-48 { width: 48px; }
.col-w-50 { width: 50px; }
.col-w-56 { width: 56px; }
.col-w-80 { width: 80px; }

/* Inline select compact */
.select-compact { width: auto; padding: 5px 8px; font-size: 11px; max-width: 130px; }
.select-filter { font-size: 12px; padding: 8px 10px; }
.input-filter { font-size: 12px; padding: 8px 10px; }

/* Client-specific filter groups */
.client-filter-search { flex: 1; min-width: 140px; max-width: 220px; }
.client-filter-select { min-width: 140px; max-width: 200px; }

/* Reassign submit alignment */
.client-reassign-submit { padding-top: 16px; }

/* Service table helpers */
.service-url { font-size: 11px; color: var(--muted); max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.service-name { font-size: 13px; }
.service-routing-cell-edit { min-width: 190px; }
.service-routing-cell-view { min-width: 120px; }
.service-vpn-controls { display: flex; gap: 4px; margin-top: 4px; flex-wrap: wrap; align-items: center; }
.service-egress-info { font-size: 10px; color: var(--muted); margin-top: 4px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 160px; }
.service-vpn-name { font-size: 11px; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 130px; }
.service-routing-stack { display: flex; flex-direction: column; gap: 3px; }
.service-health-cell { min-width: 130px; }
.service-health-btn { font-size: 12px; padding: 6px 14px; white-space: nowrap; background: rgba(6,182,212,.12); color: var(--cyan); border: 1px solid rgba(6,182,212,.3); border-radius: 6px; font-weight: 600; }
.service-action-wrap { position: relative; display: inline-block; }
.service-action-dots { font-size: 16px; line-height: 1; padding: 2px 8px; }
.service-vpn-start-stop { font-size: 10px; padding: 2px 6px; }
.service-vpn-form { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }

/* VPN select label truncation */
.vpn-sel-label-truncate { max-width: 120px; overflow: hidden; text-overflow: ellipsis; display: block; }
.vpn-sel-label-truncate-lg { max-width: 110px; overflow: hidden; text-overflow: ellipsis; display: block; }

/* Modal helpers (services.php) */
.modal-box-wide { max-width: 760px; }
.form-label-hint { font-weight: 400; font-size: 12px; color: var(--muted); }
.form-label-hint-sm { font-weight: 400; font-size: 11px; color: var(--muted); }
.form-checkbox-inline { width: auto; margin: 0; }
.form-checkbox-label { font-weight: 400; font-size: 12px; color: var(--muted); margin: 0; cursor: pointer; }
.form-checkbox-label-md { font-weight: 400; font-size: 13px; margin: 0; cursor: pointer; }
.form-toggle-row { margin-top: 6px; display: flex; align-items: center; gap: 6px; }
.form-vod-group { display: flex; flex-direction: column; gap: 6px; margin-top: 4px; }
.form-vod-row { display: flex; align-items: center; gap: 8px; }
.form-hint { font-size: 11px; color: var(--muted); margin-top: 6px; }
.form-hint-sm { font-size: 11px; color: var(--muted); margin-top: 4px; }

/* VPN modal selector layout */
.vpn-modal-row { display: flex; gap: 8px; align-items: center; }
.vpn-sel-wrap-full { flex: 1; }
.vpn-sel-btn-full { width: 100%; max-width: none; }
.vpn-sel-label-full { flex: 1; text-align: left; overflow: hidden; text-overflow: ellipsis; }
.vpn-live-indicator { color: var(--green); font-size: 11px; }
.vpn-sel-no-results { color: var(--muted); cursor: default; }

/* Service card header row */
.card-header-actions { display: flex; align-items: center; gap: 8px; }

/* Client VPN labels */
.client-vpn-direct { color: var(--cyan); font-size: 11px; }
.client-vpn-override { color: var(--accent); font-size: 11px; }
.client-vpn-inherited { color: var(--muted); font-size: 11px; }

/* Health/test loading state */
.health-testing { font-size: 11px; color: var(--muted); }
.health-result-meta { font-size: 10px; color: var(--muted); margin-top: 1px; }
.health-result-egress { font-size: 10px; color: var(--muted); margin-top: 3px; }
.health-result-warn { font-size: 10px; color: var(--yellow, #f5a623); margin-top: 3px; }
.health-retest { font-size: 10px; padding: 1px 5px; margin-top: 4px; }
.health-badge { font-size: 10px; white-space: nowrap; }

/* Channel page helpers */
.channel-empty-state { text-align: center; padding: 48px 20px; }
.channel-empty-icon { font-size: 32px; margin-bottom: 10px; opacity: 0.3; }
.channel-empty-title { font-size: 14px; font-weight: 500; margin-bottom: 4px; }
.channel-empty-sub { font-size: 12px; color: var(--muted); }
.channel-no-schedule { font-size: 12px; color: var(--muted); opacity: 0.45; font-style: italic; padding: 6px 0; }
.channel-detail-placeholder { font-size: 24px; opacity: 0.2; }
.channel-detail-action { width: 100%; justify-content: center; text-decoration: none; font-size: 12px; margin-top: 4px; }
.channel-browse-more { text-align: center; padding: 12px; }
.channel-progress-full { margin-top: 4px; max-width: 100%; }
.channel-no-prog { font-size: 11px; color: var(--muted); opacity: 0.4; font-style: italic; }
.channel-no-epg-dash { font-size: 11px; color: var(--muted); opacity: 0.3; }
.channel-time-left { font-size: 10px; color: var(--muted); }

/* Channel review KPI colored vals */
.channel-review-orange { color: var(--orange); }
.channel-review-cyan { color: var(--cyan); }
.channel-review-red { color: var(--red); }
.channel-review-green { color: var(--green); }

/* Channel table empty state */
.channel-table-empty { text-align: center; padding: 32px; }
.channel-table-empty-text { font-size: 13px; color: var(--muted); }

/* Channel badge fit */
.badge-fit { font-size: 10px; width: fit-content; }

/* EPG dot inline */
.lv-dot-inline { display: inline-block; vertical-align: middle; }

/* Channels: load more btn */
.channel-load-more-btn { font-size: 11px; }

/* Client bulk bar selected label */
.cl-bulk-label { font-size: 11px; color: var(--muted); }

/* ── LOGIN PAGE ─────────────────────────────── */
.login-page {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #111318 0%, #141824 40%, #171c2a 100%);
  padding: 24px;
  position: relative;
}

.login-page::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background:
    radial-gradient(ellipse 600px 400px at 30% 20%, rgba(99,102,241,0.04), transparent),
    radial-gradient(ellipse 500px 300px at 70% 80%, rgba(139,92,246,0.03), transparent);
  pointer-events: none;
}

.login-card {
  width: 100%; max-width: 420px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 16px; padding: 40px;
  position: relative;
  box-shadow: 0 24px 64px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.03);
}
.login-logo { display: flex; align-items: center; gap: 14px; margin-bottom: 36px; }
.login-logo-icon {
  width: 48px; height: 48px;
  background: linear-gradient(135deg, var(--accent), var(--purple));
  border-radius: 12px; display: flex; align-items: center; justify-content: center;
  font-size: 22px; color: #fff;
  box-shadow: 0 4px 12px rgba(99,102,241,0.25);
}
.login-logo-text { font-size: 18px; font-weight: 700; letter-spacing: -0.01em; }
.login-logo-text small { display: block; font-size: 12px; font-weight: 400; color: var(--muted); margin-top: 2px; }
.login-card h2 { font-size: 20px; font-weight: 600; margin-bottom: 4px; letter-spacing: -0.01em; }
.login-card p { color: var(--muted); font-size: 13px; margin-bottom: 24px; }
.login-card .form-group { margin-bottom: 16px; }
.login-card input { margin-top: 0; }
.login-full { width: 100%; justify-content: center; padding: 12px; margin-top: 8px; }

/* ── HAMBURGER ──────────────────────────────── */
.hamburger {
  display: none;
  flex-direction: column; justify-content: center; align-items: center;
  gap: 5px;
  width: 38px; height: 38px;
  background: rgba(255,255,255,0.04); border: 1px solid var(--border);
  border-radius: 8px; cursor: pointer; flex-shrink: 0;
  padding: 0;
  transition: background 0.15s;
}
.hamburger:hover { background: rgba(255,255,255,0.06); }
.hamburger span {
  display: block; width: 18px; height: 2px;
  background: var(--text); border-radius: 2px;
  transition: all .2s;
}

/* ── SIDEBAR OVERLAY ────────────────────────── */
#sidebar-overlay {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 1050;
}
#sidebar-overlay.show { display: block; }

/* ── BRANDING PAGE ─────────────────────────────── */
.brand-heading { font-size: 15px; font-weight: 700; margin-bottom: 4px; }
.brand-subtext { font-size: 12px; color: var(--muted); }
.brand-section { margin-bottom: 20px; }

.brand-asset-card { padding: 0; margin-bottom: 12px; overflow: hidden; width: 100%; box-sizing: border-box; }
.brand-asset-preview {
  background: var(--bg);
  padding: 28px 24px;
  display: flex;
  align-items: center;
  gap: 16px;
}
.brand-asset-icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  overflow: hidden;
  background: linear-gradient(135deg, var(--accent), #6366f1);
  transition: opacity 0.15s;
  flex-shrink: 0;
  position: relative;
}
.brand-asset-icon:hover { opacity: 0.85; }
.brand-asset-icon img { width: 100%; height: 100%; object-fit: contain; padding: 4px; }

.brand-asset-remove {
  position: absolute; top: -4px; right: -4px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--red);
  border: 2px solid var(--bg);
  color: #fff; font-size: 8px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  padding: 0; line-height: 1;
}

.brand-title-input {
  background: transparent; border: none;
  color: var(--text);
  font-size: 17px; font-weight: 700;
  letter-spacing: 0.3px;
  padding: 0; width: 100%;
  outline: none;
  font-family: inherit;
}
.brand-title-input:focus {
  border-bottom: 1px solid var(--accent);
  padding-bottom: 2px;
}

.brand-asset-meta {
  padding: 8px 16px;
  display: flex; align-items: center;
  justify-content: space-between;
}
.brand-asset-meta-left {
  display: flex; align-items: center; gap: 8px;
}
.brand-format-badge {
  font-size: 10px; color: var(--muted);
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 2px 8px;
  font-weight: 500;
}
.brand-asset-meta .brand-desc { font-size: 11px; color: var(--muted); }
.brand-change-link {
  font-size: 10px; color: var(--accent);
  cursor: pointer; background: none; border: none;
  font-family: inherit;
}
.brand-change-link:hover { text-decoration: underline; }

.brand-preview-card { padding: 14px 20px; margin-bottom: 12px; }
.brand-preview-label {
  font-size: 11px; font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 10px;
}
.brand-preview-row {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px;
  background: var(--bg);
  border-radius: 10px;
  border: 1px solid var(--border);
}
.brand-preview-icon {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--accent), #6366f1);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.brand-preview-name { font-size: 13px; font-weight: 600; }
.brand-preview-sub { font-size: 10px; color: var(--muted); }

.brand-badge-card { padding: 14px 20px; margin-bottom: 12px; }
.brand-badge-row { display: flex; align-items: center; gap: 12px; }
.brand-badge-label { font-size: 11px; color: var(--muted); }
.brand-badge {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 6px 14px;
  display: inline-flex;
  align-items: center; gap: 8px;
}
.brand-badge-icon {
  width: 18px; height: 18px;
  border-radius: 5px;
  background: linear-gradient(135deg, var(--accent), #6366f1);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.brand-badge-text { font-size: 12px; font-weight: 600; }
.brand-badge-img  { width: 18px; height: 18px; object-fit: contain; }
.brand-preview-icon-transparent { background: none; }

/* ── SETTINGS PAGE ─────────────────────────────── */
.settings-container { max-width: 100%; }
.settings-container .card { width: 100%; }

.settings-ssl-pre {
  max-height: 160px; overflow-y: auto;
  font-size: 10px; margin-bottom: 12px; padding: 10px;
}
.settings-ssl-pre-sm { font-size: 10px; padding: 8px 10px; }
.settings-copy-btn { padding: 3px 8px; font-size: 10px; }
.settings-ssl-btn { padding: 5px 12px; font-size: 11px; }

.settings-cf-textarea {
  width: 100%; font-family: monospace; font-size: 12px;
  padding: 10px 12px; line-height: 1.6;
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 8px; color: var(--text); resize: vertical;
}
.settings-cf-rule-box {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 8px; padding: 10px 14px;
  margin-bottom: 14px; font-size: 11px;
  font-family: monospace; line-height: 1.8;
}
.settings-cf-guide-box {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 8px; padding: 12px 14px;
  font-family: monospace; font-size: 11px;
  line-height: 1.8; margin-bottom: 14px;
}
.settings-cf-alert-danger {
  padding: 8px 12px;
  background: rgba(239,68,68,.04);
  border: 1px solid rgba(239,68,68,.1);
  border-radius: 6px;
}
.settings-cf-alert-warning {
  padding: 8px 12px;
  background: rgba(245,158,11,.04);
  border: 1px solid rgba(245,158,11,.1);
  border-radius: 6px;
}
.settings-cf-hint { font-size: 10px; color: var(--muted); margin-top: 4px; }
.settings-cf-select-narrow { max-width: 300px; }

.settings-2fa-stats { margin-top: 12px; display: flex; gap: 12px; }

.settings-social-warning { font-size: 9px; color: var(--orange); flex-shrink: 0; }
.settings-social-row-warn { border-color: rgba(245,158,11,.2); }
.settings-social-input-warn { border-color: rgba(245,158,11,.3); }

.settings-save-footer { margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--border); }

.settings-guide-section { margin-bottom: 14px; }
.settings-guide-alerts { display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px; }

/* ── DASHBOARD ─────────────────────────────── */
.kpi-sub { font-size: 12px; color: var(--muted); }
.card-flex { margin-bottom: 0; display: flex; flex-direction: column; }
.card-flush { margin-bottom: 20px; padding: 0; overflow: hidden; }
.card-header-flush { padding: 12px 16px; margin-bottom: 0; border-bottom: 1px solid var(--border); }
.map-bg { position: relative; background: #1a2035; }
.map-loading-overlay { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(22,24,29,.8); pointer-events: none; }
.user-list-panel { border-left: 1px solid var(--border); display: flex; flex-direction: column; }
.user-list-scroll { flex: 1; overflow-y: auto; max-height: 320px; padding: 8px; }
.refresh-select { font-size: 11px; padding: 3px 6px; width: auto; border-radius: 6px; background: var(--card2); border: 1px solid var(--border); color: var(--text); }
.refresh-btn { background: var(--card2); border: 1px solid var(--border); color: var(--muted); border-radius: 6px; padding: 3px 7px; cursor: pointer; font-size: 12px; font-family: inherit; }
.link-accent { font-size: 12px; color: var(--accent); text-decoration: none; font-weight: 500; }
.mt-auto { margin-top: auto; }
.mt-2 { margin-top: 2px; }
.mt-20 { margin-top: 20px; }
.ml-4 { margin-left: 4px; }
.cu-grid-layout { display: grid; grid-template-columns: 1fr 300px; min-height: 360px; }
.map-container { height: 360px; width: 100%; }
.items-stretch { align-items: stretch; }
.db-kpi-link { text-decoration: none; color: inherit; display: block; transition: transform .12s, border-color .15s; }
.db-kpi-link:hover { transform: translateY(-2px); }
.db-kpi-link:hover .kpi-card { border-color: rgba(99,102,241,.25); }
.db-attn { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.db-attn-item { flex: 1; min-width: 140px; padding: 10px 14px; border-radius: 10px; font-size: 12px; display: flex; align-items: center; gap: 8px; border: 1px solid; text-decoration: none; }
.db-attn-ok { background: rgba(16,185,129,.04); border-color: rgba(16,185,129,.12); color: #6ee7b7; }
.db-attn-warn { background: rgba(245,158,11,.04); border-color: rgba(245,158,11,.12); color: #fde68a; }
.db-attn-err { background: rgba(239,68,68,.04); border-color: rgba(239,68,68,.12); color: #fca5a5; }
.db-attn-val { font-weight: 700; font-size: 16px; }
.db-health-row { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.db-health-pill { flex: 1; min-width: 120px; background: var(--card); border: 1px solid var(--border); border-radius: 8px; padding: 8px 12px; font-size: 11px; display: flex; align-items: center; gap: 6px; }
.db-health-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }

/* ── PROFILE PAGE ──────────────────────────── */
.profile-avatar { width: 64px; height: 64px; font-size: 26px; border-radius: 16px; }
.profile-header { display: flex; align-items: center; gap: 16px; margin-bottom: 24px; padding-bottom: 20px; border-bottom: 1px solid var(--border); }
.profile-name { font-size: 18px; font-weight: 700; }
.profile-detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.profile-form { flex: 1; display: flex; flex-direction: column; }
.label-hint { font-weight: 400; font-size: 11px; color: var(--muted); }

/* ── 2FA SECTION ───────────────────────────── */
.twofa-backup-box { padding: 12px 16px; background: rgba(245,158,11,.06); border: 1px solid rgba(245,158,11,.15); border-radius: 8px; margin-bottom: 16px; }
.twofa-backup-title { font-size: 13px; font-weight: 600; color: #fde68a; margin-bottom: 8px; }
.twofa-backup-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 6px; margin-bottom: 12px; }
.twofa-backup-code { background: var(--bg); padding: 6px 8px; border-radius: 4px; text-align: center; font-size: 13px; font-weight: 600; letter-spacing: 1px; border: 1px solid var(--border); }
.twofa-qr-box { background: var(--bg); padding: 12px; border-radius: 10px; border: 1px solid var(--border); }
.twofa-manual-key { display: block; background: var(--bg); padding: 8px 12px; border-radius: 6px; font-size: 12px; word-break: break-all; border: 1px solid var(--border); margin-bottom: 16px; }
.twofa-code-input { letter-spacing: 3px; font-size: 16px; text-align: center; padding: 10px; }
.twofa-disable-input { letter-spacing: 2px; font-size: 14px; width: 140px; text-align: center; }
.twofa-verify-btn { padding: 10px 16px; }
.twofa-disable-btn { padding: 8px 14px; }
.twofa-form-inline { display: flex; gap: 8px; align-items: flex-end; }
.twofa-forced-notice { margin-top: 8px; padding: 8px 12px; background: rgba(245,158,11,.06); border: 1px solid rgba(245,158,11,.12); border-radius: 6px; font-size: 11px; color: #fde68a; }
.twofa-required-alert { padding: 10px 14px; background: rgba(239,68,68,.06); border: 1px solid rgba(239,68,68,.12); border-radius: 8px; font-size: 12px; color: #fca5a5; margin-bottom: 14px; }
.twofa-step { font-size: 13px; font-weight: 500; margin-bottom: 12px; }
.twofa-step-inline { font-size: 13px; font-weight: 500; margin-bottom: 8px; }
.twofa-setup-row { display: flex; gap: 20px; align-items: flex-start; flex-wrap: wrap; }
.twofa-setup-detail { flex: 1; min-width: 200px; }
.attn-arrow { margin-left: auto; opacity: .5; }
.vpn-tooltip-header { font-weight: 600; margin-bottom: 4px; font-size: 10px; text-transform: uppercase; color: var(--muted); }

/* ── VPN PAGE ──────────────────────────────── */

/* Connected VPNs empty state */
.vpn-empty-state { padding: 24px 0; text-align: center; }
.vpn-empty-state-icon { opacity: .4; margin-bottom: 8px; }
.vpn-empty-state-text { color: var(--muted); font-size: 13px; margin: 0; }

/* Connected VPN cards grid */
.vpn-cards-grid { display: flex; flex-wrap: wrap; gap: 10px; padding: 4px 0; }
.vpn-card-item {
  flex: 1 1 280px; max-width: 400px;
  background: var(--card2); border: 1px solid var(--border); border-radius: 10px;
  padding: 14px 16px; display: flex; flex-direction: column; gap: 10px;
}
.vpn-card-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.vpn-card-name-row { display: flex; align-items: center; gap: 8px; min-width: 0; flex: 1; }
.vpn-card-flag { font-size: 22px; flex-shrink: 0; }
.vpn-card-name-wrap { min-width: 0; }
.vpn-card-name { font-size: 13px; display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.vpn-card-provider { font-size: 11px; color: var(--muted); }
.vpn-card-proxy-box {
  font-size: 11px; font-family: monospace; color: var(--muted);
  background: var(--bg); border-radius: 6px; padding: 8px 10px; word-break: break-all;
}
.vpn-card-egress { margin-top: 3px; color: var(--cyan); }
.vpn-card-actions { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.vpn-card-btn { font-size: 11px; }

/* Fix Routing / Test IP inline buttons */
.vpn-btn-routing {
  background: var(--card2); border: 1px solid var(--orange, #f97316);
  color: var(--orange, #f97316); font-size: 11px;
}
.vpn-btn-test-ip {
  background: var(--card2); border: 1px solid var(--cyan);
  color: var(--cyan); font-size: 11px;
}

/* Log viewer pre block */
.vpn-log-pre {
  font-size: 11px; color: #cdd9e5; background: #1a1d23;
  padding: 16px; border-radius: 6px; overflow-x: auto;
  max-height: 420px; white-space: pre-wrap; word-break: break-all; margin: 0;
}

/* Add VPN modal source tabs row */
.vpn-source-tabs {
  display: flex; gap: 8px; margin-bottom: 20px;
  border-bottom: 1px solid var(--border); padding-bottom: 12px;
}

/* Bulk ZIP info box */
.vpn-bulk-info {
  background: var(--card2); border: 1px solid var(--border); border-radius: 8px;
  padding: 14px; margin-bottom: 16px; font-size: 12px; line-height: 1.7; color: var(--muted);
}

/* VPN table toolbar */
.vpn-toolbar { display: flex; gap: 6px; margin-bottom: 14px; align-items: center; flex-wrap: wrap; }
.vpn-search-input { flex: 1; min-width: 100px; max-width: 220px; }
.vpn-filter-select { width: auto; min-width: 0; flex-shrink: 0; padding-right: 24px; }
.vpn-filter-count { font-size: 12px; color: var(--muted); white-space: nowrap; flex-shrink: 0; }
.vpn-toolbar-right { margin-left: auto; display: flex; gap: 8px; align-items: center; flex-shrink: 0; }
.vpn-selected-count { font-size: 12px; color: var(--muted); white-space: nowrap; }

/* VPN table checkbox column */
.vpn-th-check { width: 36px; text-align: center; }

/* VPN table cells */
.vpn-td-provider { font-size: 12px; color: var(--muted); }
.vpn-td-proxy { font-size: 11px; color: var(--muted); font-family: monospace; }
.vpn-td-egress-active { margin-top: 3px; color: var(--cyan, #22d3ee); }
.vpn-td-egress-none { margin-top: 3px; color: var(--muted); }
.vpn-td-date { font-size: 12px; color: var(--muted); white-space: nowrap; }
.vpn-name-cell { display: flex; align-items: center; gap: 6px; }
.vpn-flag { font-size: 20px; flex-shrink: 0; }
.vpn-badge-streaming { font-size: 9px; margin-left: 4px; vertical-align: middle; }
.vpn-badge-streaming-card { font-size: 9px; margin-left: 2px; }

/* VPN overflow menu (3-dot dropdown) */
.vpn-overflow-wrap { display: inline-block; }
.vpn-overflow-dots { font-size: 16px; line-height: 1; padding: 2px 8px; }
.vpn-overflow-menu-item {
  display: block; width: 100%; padding: 8px 14px; font-size: 13px;
  color: var(--text); text-align: left; background: none; border: none;
  cursor: pointer; white-space: nowrap; transition: background .1s;
  font-family: inherit;
}
.vpn-overflow-menu-item:hover { background: var(--card2); }
.vpn-overflow-menu-link {
  display: block; width: 100%; padding: 8px 14px; font-size: 13px;
  color: var(--text); text-align: left; background: none; border: none;
  cursor: pointer; white-space: nowrap; text-decoration: none; transition: background .1s;
}
.vpn-overflow-menu-link:hover { background: var(--card2); }
.vpn-overflow-menu-item.danger { color: var(--red); }
.vpn-overflow-menu-item.danger:hover { background: rgba(239,68,68,.08); }

/* VPN no-access dash */
.vpn-no-action { font-size: 12px; color: var(--muted); }

/* VPN error info */
.vpn-error-text { font-size: 11px; color: #e57373; margin-top: 4px; max-width: 280px; word-break: break-all; }
.vpn-error-log-link { font-size: 11px; color: #5b8ef0; text-decoration: none; margin-top: 3px; display: inline-block; }

/* VPN pagination bar */
.vpn-pagination { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px; margin-top: 16px; padding-top: 12px; border-top: 1px solid var(--border); }
.vpn-page-info { font-size: 12px; color: var(--muted); }
.vpn-page-btns { display: flex; gap: 4px; flex-wrap: wrap; }

/* How-to card */
.vpn-howto-header { cursor: pointer; user-select: none; }
.vpn-howto-chevron { transition: transform .2s; flex-shrink: 0; }
.vpn-howto-body { font-size: 13px; line-height: 1.8; color: var(--text); padding-top: 4px; }
.vpn-howto-note { color: var(--muted); font-size: 12px; }

/* ── RESPONSIVE ─────────────────────────────── */

/* Large tablet / laptop */
@media (max-width: 1024px) {
  .main-content { padding: 20px 22px; }
  .charts-grid { grid-template-columns: 1fr 1.4fr; }
  .site-footer { padding: 14px 16px; }
}

/* Tablet / large phone: sidebar becomes a slide-in drawer */
@media (max-width: 900px) {
  .hamburger { display: flex; }
  .sidebar { transform: translateX(calc(-1 * var(--sidebar-w))); }
  .sidebar.open { transform: translateX(0); box-shadow: 8px 0 40px rgba(0,0,0,.6); }
  .main-wrap { margin-left: 0; width: 100%; max-width: 100vw; }
  .charts-grid { grid-template-columns: 1fr; }
  .grid-2 { grid-template-columns: 1fr; }
  .grid-3 { grid-template-columns: 1fr 1fr; }
  .main-header { padding: 0 16px; gap: 12px; }
  .main-header h1 { font-size: 17px; }
  .chart-wrap { height: 220px; }
  .col-hide-tablet { display: none; }
  .kpi-grid { grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); }
  .modal-backdrop { padding: 16px; }
}

/* Mobile */
@media (max-width: 640px) {
  .main-content { padding: 12px; overflow-x: hidden; width: 100%; max-width: 100vw; }
  .col-hide-mobile { display: none; }
  .header-search { display: none; }

  /* 5-column KPI row */
  .kpi-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 6px; width: 100%; }
  .kpi-card { padding: 10px 5px 12px; border-radius: 10px; }
  .kpi-icon { display: none; }
  .kpi-top { justify-content: flex-start; }
  .kpi-label { font-size: 9px; letter-spacing: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }
  .kpi-value { font-size: 15px; margin-top: 4px; }
  .kpi-footer { display: none; }

  .grid-3 { grid-template-columns: 1fr; }
  .card { padding: 16px; margin-bottom: 14px; }
  .card-header { flex-wrap: wrap; gap: 8px; }
  .charts-grid { grid-template-columns: 1fr; gap: 12px; width: 100%; }
  .chart-wrap { height: 200px; width: 100%; }
  .chart-legend { grid-template-columns: 1fr 1fr; gap: 8px; }
  .action-btns { flex-direction: column; align-items: stretch; }
  .action-btns .btn { justify-content: center; }
  th, td { padding: 10px 8px; }
  .btn { padding: 8px 14px; }
  .btn-sm { padding: 5px 10px; font-size: 11px; }
  .form-row > * { min-width: 100%; flex: none; width: 100%; }
  .login-card { padding: 28px 20px; }
  .modal-backdrop { padding: 12px; }
  .modal-box { border-radius: 12px; max-height: 88vh; }
  .modal-body { padding: 16px; }
  .main-header h1 { font-size: 16px; }
  .pagination { gap: 4px; }
  .page-link { padding: 5px 9px; font-size: 11px; }
  /* VPN popup on mobile */
  .vpn-sidebar-popup { left: 8px; right: 8px; }
  /* Table: hide less critical columns */
  .col-hide-sm { display: none; }
}

/* Small mobile: further compaction */
@media (max-width: 480px) {
  .main-content { padding: 10px 8px; }
  .card { padding: 12px; }
  .card-header { gap: 6px; }
  th, td { padding: 8px 6px; font-size: 12px; }
  .kpi-value { font-size: 13px; }
  .kpi-label { font-size: 8px; }
  .main-header h1 { font-size: 15px; }
  /* Stack card-header buttons on very small phones */
  .card-header > div[style*="display:flex"] { flex-wrap: wrap; gap: 6px; }
}

/* Fold phones / extra-small */
@media (max-width: 380px) {
  :root { --sidebar-w: min(280px, 92vw); }
  .main-content { padding: 8px 6px; }
  .card { padding: 10px; border-radius: 10px; margin-bottom: 10px; }

  /* 3-column KPI (wraps to 2nd row) */
  .kpi-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 4px; }
  .kpi-card { padding: 8px 3px 10px; border-radius: 8px; }
  .kpi-label { font-size: 8px; }
  .kpi-value { font-size: 12px; }

  .main-header { height: 52px; padding: 0 10px; gap: 8px; }
  .main-header h1 { font-size: 13px; }

  th, td { padding: 6px 4px; font-size: 11px; }
  .btn { padding: 7px 10px; font-size: 12px; }
  .btn-sm { padding: 4px 7px; font-size: 10px; }
  .badge { font-size: 9px; padding: 2px 5px; }

  /* Bottom-sheet style modal on tiny screens */
  .modal-backdrop { padding: 0; align-items: flex-end; }
  .modal-box { border-radius: 16px 16px 0 0; max-height: 92vh; width: 100%; }

  .vpn-sidebar-popup { left: 4px; right: 4px; }
}

/* ━━ PAGE-SPECIFIC REFACTORED CLASSES ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* ── Shared: empty state card ──────────────────── */
.empty-card { text-align: center; padding: 48px 20px; }
.empty-card-sm { text-align: center; padding: 40px; }
.empty-card-icon { font-size: 32px; margin-bottom: 10px; opacity: 0.3; }
.empty-card-title { font-size: 14px; font-weight: 500; margin-bottom: 4px; }
.empty-card-sub { font-size: 12px; color: var(--muted); }
.empty-filter { text-align: center; padding: 32px; }

/* ── Shared: poster badge overlay ──────────────── */
.poster-year-badge { position: absolute; bottom: 6px; left: 6px; background: rgba(99,102,241,.85); padding: 2px 8px; border-radius: 4px; font-size: 10px; font-weight: 600; color: #fff; }

/* ── Shared: smart tag ─────────────────────────── */
.smart-tag { font-size: 10px; font-weight: 400; background: rgba(99,102,241,.1); padding: 1px 7px; border-radius: 99px; color: #a5b4fc; vertical-align: middle; margin-left: 4px; }

/* ── Shared: filter/action button (compact) ────── */
.btn-filter { font-size: 11px; padding: 6px 12px; }
.btn-clear { text-decoration: none; font-size: 11px; }

/* ── Shared: pagination ellipsis ───────────────── */
.page-ellipsis { padding: 5px 3px; color: var(--muted); }
.page-ellipsis-lg { padding: 5px 4px; color: var(--muted); }

/* ── Shared: detail modal ──────────────────────── */
.detail-poster-ph { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 32px; opacity: 0.15; }
.detail-rating { color: #f59e0b; }
.detail-src-badges { margin: 8px 0 10px; display: flex; gap: 6px; flex-wrap: wrap; }
.detail-src-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 11px; font-weight: 600; padding: 3px 10px; border-radius: 5px; }
.detail-src-fb { background: rgba(99,102,241,.12); color: #a5b4fc; border: 1px solid rgba(99,102,241,.2); }
.detail-src-iptv { background: rgba(16,185,129,.1); color: #6ee7b7; border: 1px solid rgba(16,185,129,.15); }
.detail-src-ms { background: rgba(6,182,212,.1); color: #67e8f9; border: 1px solid rgba(6,182,212,.15); }
.detail-field-val { color: var(--text); }

/* ── Shared: featured card overrides ───────────── */
.card-featured { flex: 0 0 170px; }
.poster-featured { width: 170px; height: 245px; }

/* ── Shared: review KPI colors ─────────────────── */
.kpi-val-orange { color: var(--orange); }
.kpi-val-cyan { color: var(--cyan); }
.kpi-val-red { color: var(--red); }
.kpi-val-green { color: var(--green); }

/* ── Shared: table column widths ───────────────── */
.col-w-44 { width: 44px; }
.col-w-60 { width: 60px; }
.col-w-80 { width: 80px; }

/* ── Shared: review table cells ────────────────── */
.review-tbl-name { font-weight: 500; }
.review-tbl-cat { color: var(--muted); font-size: 11px; }
.review-tbl-badge { font-size: 9px; }
.review-tbl-year { font-size: 11px; color: var(--muted); }

/* ── Shared: media server filter buttons ───────── */
.btn-ms-filter { font-size: 11px; text-decoration: none; border-color: #4f46e5; color: #818cf8; }
.btn-ms-excl { font-size: 11px; text-decoration: none; border-color: #0ea5e9; color: #38bdf8; }

/* ── Categories page ───────────────────────────── */
.cat-select-btn { font-size: 11px; display: flex; align-items: center; gap: 4px; margin-left: auto; }
.cat-bulk-selected { font-size: 11px; color: var(--muted); }
.cat-bulk-btn { font-size: 10px; padding: 4px 8px; }
.cat-bulk-hide { font-size: 10px; padding: 4px 8px; color: #fca5a5; border-color: rgba(239,68,68,.2); }
.cat-bulk-show { font-size: 10px; padding: 4px 8px; color: #6ee7b7; border-color: rgba(16,185,129,.2); }

/* ── Library page ──────────────────────────────── */
.lib-service-card { margin-bottom: 16px; padding: 14px 18px; }
.lib-service-label { font-size: 11px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: .5px; white-space: nowrap; }
.lib-service-select { min-width: 180px; max-width: 320px; padding: 7px 12px; background: var(--input); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 13px; }
.lib-btn-icon { vertical-align: -2px; margin-right: 3px; }
.lib-epg-status { font-size: 12px; color: var(--muted); display: none; }
.lib-tabs { display: flex; gap: 6px; margin-bottom: 16px; }
.lib-filter-form { display: flex; gap: 8px; align-items: flex-end; flex-wrap: wrap; }
.lib-filter-group { min-width: 180px; }
.lib-filter-group-sm { min-width: 130px; max-width: 200px; }
.lib-filter-group-md { min-width: 160px; max-width: 280px; }
.lib-filter-flex-2 { flex: 2; }
.lib-filter-flex-1 { flex: 1; }
.lib-field-label { font-size: 11px; font-weight: 600; color: var(--muted); display: block; margin-bottom: 4px; text-transform: uppercase; letter-spacing: .4px; }
.lib-input { width: 100%; padding: 7px 12px; background: var(--input); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 13px; box-sizing: border-box; }
.lib-input-sm { padding: 7px 12px; background: var(--input); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 12px; }
.lib-input-flex { flex: 1; padding: 7px 12px; background: var(--input); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 12px; }
.lib-file-input { flex: 1; font-size: 12px; color: var(--text); }
.lib-btn-group { display: flex; gap: 6px; padding-bottom: 1px; }
.lib-search-form { display: flex; gap: 8px; margin-bottom: 16px; }
.lib-search-input { flex: 1; padding: 8px 12px; background: var(--input); border: 1px solid var(--border); border-radius: 6px; color: var(--text); font-size: 13px; }
.lib-badges-min { min-width: 120px; }
.lib-panel-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-items: stretch; }
.lib-panel-heading { font-size: 13px; display: flex; align-items: center; gap: 6px; }
.lib-panel-section { margin-top: 10px; }
.lib-panel-tab-strip { display: flex; gap: 4px; margin-bottom: 10px; flex-wrap: wrap; }
.lib-panel-sub { width: 100%; margin-top: 8px; }
.lib-panel-sub-form { display: flex; gap: 6px; }
.lib-panel-sub-form-upload { display: flex; gap: 6px; align-items: center; }
.lib-logo-search-results { margin-top: 8px; max-height: 200px; overflow-y: auto; }
.lib-logo-override-row { margin-top: 10px; display: flex; align-items: center; gap: 10px; padding: 8px 10px; background: rgba(255,255,255,0.02); border-radius: 8px; border: 1px solid var(--border); }
.lib-logo-override-img { max-height: 30px; max-width: 80px; object-fit: contain; background: var(--bg2); border-radius: 6px; padding: 3px; }
.lib-epg-info { margin-top: 10px; font-size: 12px; color: var(--muted); }
.lib-epg-code { background: var(--bg); padding: 2px 6px; border-radius: 4px; font-size: 11px; }
.lib-epg-current { margin-top: 6px; font-size: 12px; }
.lib-epg-form { margin-top: 10px; }
.lib-epg-fields { display: flex; flex-direction: column; gap: 8px; }
.lib-repo-meta { display: flex; gap: 8px; font-size: 12px; color: var(--muted); }
.lib-logo-repo-name { color: #4b5563; }
.lib-logo-search-error { font-size: 11px; color: #f87171; }
.lib-logo-no-results { font-size: 11px; color: #6b7280; grid-column: 1 / -1; }
.lib-logo-item-img { max-width: 64px; max-height: 40px; object-fit: contain; }

/* ━━ MOVIES PAGE (moved from movies.php <style>) ━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.mv-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.mv-header-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.mv-header-left select{width:auto;padding:7px 28px 7px 10px;font-size:12px;flex-shrink:0}
.mv-header-meta{font-size:12px;color:var(--muted)}
.mv-tabs{display:flex;gap:2px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:9px;padding:3px}
.mv-tab{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;font-size:12px;font-weight:500;color:var(--muted);text-decoration:none;border-radius:7px;transition:all .15s;white-space:nowrap}
.mv-tab:hover{color:var(--text);background:rgba(255,255,255,.04)}
.mv-tab.active{color:#fff;background:var(--accent);box-shadow:0 1px 4px rgba(99,102,241,.25)}
.mv-tab-badge{font-size:9px;background:rgba(239,68,68,.15);color:#fca5a5;padding:1px 6px;border-radius:99px;font-weight:600}
.mv-tab.active .mv-tab-badge{background:rgba(255,255,255,.2);color:#fff}
.mv-kpis{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.mv-kpi{flex:1;min-width:100px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:10px 14px;position:relative;overflow:hidden}
.mv-kpi::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;border-radius:0 0 10px 10px}
.mv-kpi.blue::after{background:linear-gradient(90deg,var(--accent),var(--purple))}
.mv-kpi.green::after{background:linear-gradient(90deg,var(--green),#34d399)}
.mv-kpi.purple::after{background:linear-gradient(90deg,var(--purple),#a78bfa)}
.mv-kpi.orange::after{background:linear-gradient(90deg,var(--orange),#fbbf24)}
.mv-kpi.red::after{background:linear-gradient(90deg,var(--red),#f87171)}
.mv-kpi-label{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:2px}
.mv-kpi-val{font-size:20px;font-weight:700;letter-spacing:-.02em;line-height:1.2}
.mv-kpi-sub{font-size:10px;color:var(--muted);margin-top:1px}
.mv-hero{position:relative;border-radius:16px;overflow:hidden;min-height:260px;margin-bottom:28px;display:flex;align-items:center}
.mv-hero-bg{position:absolute;inset:-20px;background-size:cover;background-position:center;filter:blur(50px) brightness(.25) saturate(1.4);transform:scale(1.3)}
.mv-hero-grad{position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,16,64,.75),rgba(13,17,23,.85))}
.mv-hero-content{position:relative;z-index:2;display:flex;align-items:center;gap:28px;padding:36px 40px;width:100%}
.mv-hero-poster{width:160px;height:230px;flex-shrink:0;border-radius:10px;overflow:hidden;box-shadow:0 12px 40px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.08)}
.mv-hero-poster img{width:100%;height:100%;object-fit:cover}
.mv-hero-info{flex:1;min-width:0}
.mv-hero-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:99px;background:rgba(99,102,241,.15);color:#a5b4fc;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px;border:1px solid rgba(99,102,241,.2)}
.mv-hero-title{font-size:28px;font-weight:800;letter-spacing:-.02em;line-height:1.2;margin-bottom:8px}
.mv-hero-meta{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);margin-bottom:12px;flex-wrap:wrap}
.mv-hero-stars{color:#f59e0b;letter-spacing:1px}
.mv-hero-plot{font-size:13px;color:rgba(228,232,240,.6);line-height:1.6;max-width:500px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.mv-section{margin-bottom:28px}
.mv-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.mv-section-title{font-size:15px;font-weight:700;letter-spacing:-.01em}
.mv-section-more{font-size:12px;color:var(--accent);text-decoration:none;font-weight:500;transition:color .15s}
.mv-section-more:hover{color:#818cf8}
.mv-rail{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}
.mv-rail::-webkit-scrollbar{height:4px}.mv-rail::-webkit-scrollbar-track{background:transparent}.mv-rail::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:4px}.mv-rail:hover::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15)}
.mv-card{flex:0 0 145px;scroll-snap-align:start;cursor:pointer;transition:transform .15s}
.mv-card:hover{transform:translateY(-4px);z-index:2}
.mv-card-poster{width:145px;height:210px;border-radius:8px;overflow:hidden;background:#111827;border:1px solid rgba(255,255,255,.06);transition:border-color .15s;position:relative}
.mv-card:hover .mv-card-poster{border-color:rgba(99,102,241,.3);box-shadow:0 8px 24px rgba(0,0,0,.4)}
.mv-card-poster img{width:100%;height:100%;object-fit:cover}
.mv-card-poster-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:24px;opacity:.15}
.mv-card-body{padding:6px 2px 0}
.mv-card-title{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.mv-card-meta{font-size:10px;color:var(--muted);line-height:1.3}
.mv-card-meta .rating-star{color:#f59e0b;font-size:10px}
.mv-top10{flex:0 0 155px;display:flex;align-items:flex-end;position:relative;scroll-snap-align:start;cursor:pointer;transition:transform .15s}
.mv-top10:hover{transform:translateY(-4px)}
.mv-top10-rank{font-size:72px;font-weight:900;line-height:.75;color:transparent;-webkit-text-stroke:2px rgba(255,255,255,.12);letter-spacing:-.05em;position:absolute;bottom:0;left:-4px;z-index:1;pointer-events:none}
.mv-top10-poster{width:110px;height:160px;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.06);margin-left:28px;position:relative;z-index:2;transition:border-color .15s}
.mv-top10:hover .mv-top10-poster{border-color:rgba(99,102,241,.3);box-shadow:0 8px 24px rgba(0,0,0,.4)}
.mv-top10-poster img{width:100%;height:100%;object-fit:cover}
.mv-top10-info{position:absolute;bottom:-24px;left:28px;right:0;z-index:3}
.mv-top10-title{font-size:11px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}
.mv-top10-meta{font-size:10px;color:var(--muted)}
.mv-lib-card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.mv-lib-filter{display:flex;gap:6px;align-items:center;flex-wrap:wrap;padding:12px 16px;border-bottom:1px solid var(--border)}
.mv-lib-filter input,.mv-lib-filter select{padding:7px 10px;font-size:12px}
.mv-lib-filter input{flex:1;min-width:100px;max-width:200px}
.mv-lib-filter select{width:auto;padding-right:28px}
.mv-lib-filter-meta{font-size:11px;color:var(--muted);margin-left:auto}
.mv-lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;padding:16px}
.mv-lib-item{cursor:pointer;transition:transform .12s}
.mv-lib-item:hover{transform:translateY(-3px)}
.mv-lib-poster{width:100%;aspect-ratio:2/3;border-radius:6px;overflow:hidden;background:#111827;border:1px solid rgba(255,255,255,.05);transition:border-color .12s;position:relative}
.mv-lib-item:hover .mv-lib-poster{border-color:rgba(99,102,241,.25)}
.mv-lib-poster img{width:100%;height:100%;object-fit:cover}
.mv-lib-poster-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:20px;opacity:.12}
.mv-lib-info{padding:5px 1px 0}
.mv-lib-name{font-size:11px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.mv-lib-meta{font-size:10px;color:var(--muted);line-height:1.3}
.mv-review-kpis{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.mv-review-kpi{flex:1;min-width:90px;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:10px 12px;text-align:center}
.mv-review-kpi-val{font-size:22px;font-weight:700;letter-spacing:-.02em}
.mv-review-kpi-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;margin-top:2px}
.mv-tbl{width:100%;border-collapse:collapse}
.mv-tbl th{padding:8px 12px;font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;background:rgba(0,0,0,.08)}
.mv-tbl td{padding:7px 12px;font-size:12px;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}
.mv-tbl tbody tr:hover{background:rgba(255,255,255,.02)}
.mv-tbl-poster{width:32px;height:46px;object-fit:cover;border-radius:3px;background:#111827;display:block}
.mv-tbl-poster-ph{width:32px;height:46px;background:#111827;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:10px;opacity:.15}
.mv-detail-overlay{position:fixed;inset:0;z-index:1200;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}
.mv-detail{background:var(--card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:0 32px 80px rgba(0,0,0,.6)}
.mv-detail-top{display:flex;gap:24px;padding:24px 28px;align-items:flex-start}
.mv-detail-poster{width:140px;height:210px;flex-shrink:0;border-radius:8px;overflow:hidden;background:#111827;border:1px solid rgba(255,255,255,.06)}
.mv-detail-poster img{width:100%;height:100%;object-fit:cover}
.mv-detail-info{flex:1;min-width:0}
.mv-detail-title{font-size:20px;font-weight:700;letter-spacing:-.01em;margin-bottom:6px}
.mv-detail-meta{display:flex;gap:8px;font-size:12px;color:var(--muted);margin-bottom:10px;flex-wrap:wrap}
.mv-detail-plot{font-size:13px;color:rgba(228,232,240,.7);line-height:1.6;margin-bottom:12px}
.mv-detail-fields{display:flex;flex-direction:column;gap:6px;font-size:12px}
.mv-detail-fields span{color:var(--muted)}
.mv-detail-close{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);font-size:16px;font-family:inherit;transition:all .12s;z-index:2}
.mv-detail-close:hover{color:var(--text);background:rgba(255,255,255,.1)}
.mv-pagination{display:flex;gap:4px;justify-content:center;margin-top:16px;flex-wrap:wrap}
.mv-page{padding:5px 10px;border-radius:6px;font-size:12px;background:var(--card);border:1px solid var(--border);color:var(--text);text-decoration:none;transition:all .12s}
.mv-page.active{background:var(--accent);border-color:var(--accent);color:#fff}
.mv-page:hover:not(.active){border-color:rgba(99,102,241,.3)}
.mv-ms-badge{display:inline-block;font-size:9px;background:#4f46e5;color:#fff;padding:1px 6px;border-radius:3px;letter-spacing:.3px;white-space:nowrap}
.mv-src-tag{position:absolute;top:5px;left:5px;font-size:8px;font-weight:600;padding:2px 6px;border-radius:3px;letter-spacing:.3px;line-height:1.3;z-index:2;backdrop-filter:blur(4px)}
.mv-src-iptv{background:rgba(16,185,129,.8);color:#fff}
.mv-src-ms{background:rgba(6,182,212,.8);color:#fff}
.mv-src-fb{background:rgba(99,102,241,.85);color:#fff}
.rating-star{color:#f59e0b}
@media(max-width:900px){.mv-hero-content{flex-direction:column;align-items:flex-start;padding:24px}.mv-hero-poster{width:120px;height:175px}.mv-hero-title{font-size:22px}.mv-detail-top{flex-direction:column;align-items:center;text-align:center}}
@media(max-width:640px){.mv-kpis{gap:4px}.mv-kpi{min-width:0;padding:8px 10px}.mv-kpi-val{font-size:16px}.mv-hero-content{padding:20px}.mv-hero-poster{width:100px;height:145px}.mv-hero-title{font-size:18px}.mv-card{flex:0 0 120px}.mv-card-poster{width:120px;height:175px}.mv-lib-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;padding:10px}.mv-tbl .col-hide-sm{display:none}}

/* ━━ SERIES PAGE (moved from series.php <style>) ━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.sv-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}.sv-header-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.sv-header-left select{width:auto;padding:7px 28px 7px 10px;font-size:12px}.sv-header-meta{font-size:12px;color:var(--muted)}
.sv-tabs{display:flex;gap:2px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:9px;padding:3px}.sv-tab{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;font-size:12px;font-weight:500;color:var(--muted);text-decoration:none;border-radius:7px;transition:all .15s;white-space:nowrap}.sv-tab:hover{color:var(--text);background:rgba(255,255,255,.04)}.sv-tab.active{color:#fff;background:var(--accent);box-shadow:0 1px 4px rgba(99,102,241,.25)}.sv-tab-badge{font-size:9px;background:rgba(239,68,68,.15);color:#fca5a5;padding:1px 6px;border-radius:99px;font-weight:600}.sv-tab.active .sv-tab-badge{background:rgba(255,255,255,.2);color:#fff}
.sv-kpis{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}.sv-kpi{flex:1;min-width:100px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:10px 14px;position:relative;overflow:hidden}.sv-kpi::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;border-radius:0 0 10px 10px}.sv-kpi.blue::after{background:linear-gradient(90deg,var(--accent),var(--purple))}.sv-kpi.green::after{background:linear-gradient(90deg,var(--green),#34d399)}.sv-kpi.purple::after{background:linear-gradient(90deg,var(--purple),#a78bfa)}.sv-kpi.orange::after{background:linear-gradient(90deg,var(--orange),#fbbf24)}.sv-kpi.red::after{background:linear-gradient(90deg,var(--red),#f87171)}.sv-kpi-label{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:2px}.sv-kpi-val{font-size:20px;font-weight:700;letter-spacing:-.02em;line-height:1.2}.sv-kpi-sub{font-size:10px;color:var(--muted);margin-top:1px}
.sv-section{margin-bottom:28px}.sv-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.sv-section-title{font-size:15px;font-weight:700;letter-spacing:-.01em}.sv-section-more{font-size:12px;color:var(--accent);text-decoration:none;font-weight:500}.sv-section-more:hover{color:#818cf8}
.sv-rail{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.sv-rail::-webkit-scrollbar{height:4px}.sv-rail::-webkit-scrollbar-track{background:transparent}.sv-rail::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:4px}.sv-rail:hover::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15)}
.sv-card{flex:0 0 145px;scroll-snap-align:start;cursor:pointer;transition:transform .15s}.sv-card:hover{transform:translateY(-4px);z-index:2}.sv-card-poster{width:145px;height:210px;border-radius:8px;overflow:hidden;background:#111827;border:1px solid rgba(255,255,255,.06);transition:border-color .15s;position:relative}.sv-card:hover .sv-card-poster{border-color:rgba(99,102,241,.3);box-shadow:0 8px 24px rgba(0,0,0,.4)}.sv-card-poster img{width:100%;height:100%;object-fit:cover}.sv-card-poster-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:24px;opacity:.15}.sv-card-body{padding:6px 2px 0}.sv-card-title{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.sv-card-meta{font-size:10px;color:var(--muted);line-height:1.3}
.sv-src-tag{position:absolute;top:5px;left:5px;font-size:8px;font-weight:600;padding:2px 6px;border-radius:3px;letter-spacing:.3px;line-height:1.3;z-index:2;backdrop-filter:blur(4px)}.sv-src-iptv{background:rgba(16,185,129,.8);color:#fff}.sv-src-fb{background:rgba(99,102,241,.85);color:#fff}
.sv-lib-card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.sv-lib-filter{display:flex;gap:6px;align-items:center;flex-wrap:wrap;padding:12px 16px;border-bottom:1px solid var(--border)}.sv-lib-filter input,.sv-lib-filter select{padding:7px 10px;font-size:12px}.sv-lib-filter input{flex:1;min-width:100px;max-width:200px}.sv-lib-filter select{width:auto;padding-right:28px}.sv-lib-filter-meta{font-size:11px;color:var(--muted);margin-left:auto}
.sv-lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;padding:16px}.sv-lib-item{cursor:pointer;transition:transform .12s}.sv-lib-item:hover{transform:translateY(-3px)}.sv-lib-poster{width:100%;aspect-ratio:2/3;border-radius:6px;overflow:hidden;background:#111827;border:1px solid rgba(255,255,255,.05);transition:border-color .12s;position:relative}.sv-lib-item:hover .sv-lib-poster{border-color:rgba(99,102,241,.25)}.sv-lib-poster img{width:100%;height:100%;object-fit:cover}.sv-lib-poster-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:20px;opacity:.12}.sv-lib-info{padding:5px 1px 0}.sv-lib-name{font-size:11px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.sv-lib-meta{font-size:10px;color:var(--muted);line-height:1.3}
.sv-review-kpis{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.sv-review-kpi{flex:1;min-width:90px;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:10px 12px;text-align:center}.sv-review-kpi-val{font-size:22px;font-weight:700;letter-spacing:-.02em}.sv-review-kpi-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;margin-top:2px}
.sv-tbl{width:100%;border-collapse:collapse}.sv-tbl th{padding:8px 12px;font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;background:rgba(0,0,0,.08)}.sv-tbl td{padding:7px 12px;font-size:12px;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}.sv-tbl tbody tr:hover{background:rgba(255,255,255,.02)}.sv-tbl-poster{width:32px;height:46px;object-fit:cover;border-radius:3px;background:#111827;display:block}.sv-tbl-poster-ph{width:32px;height:46px;background:#111827;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:10px;opacity:.15}
.sv-detail-overlay{position:fixed;inset:0;z-index:1200;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}.sv-detail{background:var(--card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:0 32px 80px rgba(0,0,0,.6);position:relative}.sv-detail-top{display:flex;gap:24px;padding:24px 28px;align-items:flex-start}.sv-detail-poster{width:140px;height:210px;flex-shrink:0;border-radius:8px;overflow:hidden;background:#111827;border:1px solid rgba(255,255,255,.06)}.sv-detail-poster img{width:100%;height:100%;object-fit:cover}.sv-detail-info{flex:1;min-width:0}.sv-detail-title{font-size:20px;font-weight:700;letter-spacing:-.01em;margin-bottom:6px}.sv-detail-meta{display:flex;gap:8px;font-size:12px;color:var(--muted);margin-bottom:8px;flex-wrap:wrap}.sv-detail-plot{font-size:13px;color:rgba(228,232,240,.7);line-height:1.6;margin-bottom:12px}.sv-detail-fields{display:flex;flex-direction:column;gap:6px;font-size:12px}.sv-detail-fields span{color:var(--muted)}.sv-detail-close{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);font-size:16px;font-family:inherit;transition:all .12s;z-index:2}.sv-detail-close:hover{color:var(--text);background:rgba(255,255,255,.1)}
.sv-pagination{display:flex;gap:4px;justify-content:center;margin-top:16px;flex-wrap:wrap}.sv-page{padding:5px 10px;border-radius:6px;font-size:12px;background:var(--card);border:1px solid var(--border);color:var(--text);text-decoration:none;transition:all .12s}.sv-page.active{background:var(--accent);border-color:var(--accent);color:#fff}.sv-page:hover:not(.active){border-color:rgba(99,102,241,.3)}
@media(max-width:900px){.sv-detail-top{flex-direction:column;align-items:center;text-align:center}}
@media(max-width:640px){.sv-kpis{gap:4px}.sv-kpi{min-width:0;padding:8px 10px}.sv-kpi-val{font-size:16px}.sv-card{flex:0 0 120px}.sv-card-poster{width:120px;height:175px}.sv-lib-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;padding:10px}.sv-tbl .col-hide-sm{display:none}}

/* ━━ CATEGORIES PAGE (moved from categories.php <style>) ━━━━━━━━━━━━━━━━━━━ */
.co-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.co-header-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.co-header-left select{width:auto;padding:7px 28px 7px 10px;font-size:12px}
.co-tabs{display:flex;gap:2px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:9px;padding:3px}
.co-tab{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;font-size:12px;font-weight:500;color:var(--muted);text-decoration:none;border-radius:7px;transition:all .15s;white-space:nowrap}
.co-tab:hover{color:var(--text);background:rgba(255,255,255,.04)}
.co-tab.active{color:#fff;background:var(--accent);box-shadow:0 1px 4px rgba(99,102,241,.25)}
.co-card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.co-toolbar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.co-toolbar input[type=text]{flex:1;min-width:120px;max-width:240px;padding:7px 10px;font-size:12px}
.co-filter{display:flex;gap:2px;background:rgba(255,255,255,.03);border-radius:6px;padding:2px}
.co-filter-btn{padding:4px 10px;font-size:11px;font-weight:500;border:none;background:none;color:var(--muted);border-radius:5px;cursor:pointer;font-family:inherit;transition:all .12s}
.co-filter-btn:hover{color:var(--text)}
.co-filter-btn.active{background:rgba(255,255,255,.08);color:var(--text)}
.co-bulk{display:none;align-items:center;gap:6px;padding:8px 16px;background:rgba(99,102,241,.05);border-bottom:1px solid rgba(99,102,241,.12);flex-wrap:wrap}
.co-bulk.visible{display:flex}
.co-bulk-count{background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:1px 8px;border-radius:10px}
.co-bulk-sep{width:1px;height:18px;background:rgba(255,255,255,.06);margin:0 2px}
.co-src{font-size:10px;padding:1px 6px;border-radius:3px;flex-shrink:0;font-weight:500;letter-spacing:.02em}
.co-src-iptv{background:#374151;color:#9ca3af}
.co-src-tmdb{background:#1e3a5f;color:#60a5fa}
.co-src-media_server{background:#1a3a1a;color:#4ade80}
.co-list{list-style:none;margin:0;padding:8px 12px}
.co-item{display:flex;align-items:center;gap:10px;padding:9px 10px;background:var(--card);border:1px solid var(--border);border-radius:6px;margin-bottom:5px;cursor:default;user-select:none;transition:all .12s}
.co-item:hover{background:rgba(255,255,255,.025);border-color:rgba(255,255,255,.1)}
.co-item.hidden-cat{opacity:.4}
.co-item.hidden-cat .co-name{text-decoration:line-through;text-decoration-color:rgba(255,255,255,.15)}
.co-item.selected{background:rgba(99,102,241,.08);border-color:rgba(99,102,241,.2)}
.co-item.sortable-ghost{opacity:.15;background:rgba(99,102,241,.08)}
.co-item.sortable-chosen{background:var(--card);border-color:var(--accent);box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:10}
.co-item.sortable-drag{opacity:0}
.co-drag{color:var(--muted);cursor:grab;flex-shrink:0;opacity:.5;transition:opacity .12s;width:20px;display:flex;align-items:center;justify-content:center;padding:4px 0}
.co-item:hover .co-drag{opacity:.8}
.co-drag:active{cursor:grabbing}
.co-arrows{display:flex;flex-direction:column;gap:1px;flex-shrink:0}
.co-arrow{width:22px;height:14px;display:flex;align-items:center;justify-content:center;border:none;background:rgba(255,255,255,.04);color:var(--muted);border-radius:3px;cursor:pointer;font-size:10px;font-family:inherit;transition:all .1s;padding:0}
.co-arrow:hover{background:rgba(99,102,241,.15);color:var(--accent)}
.co-check{width:16px;height:16px;cursor:pointer;flex-shrink:0;accent-color:var(--accent);display:none}
.co-name{flex:1;font-size:13px;font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.co-vis-btn{flex-shrink:0;display:flex;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:500;border:1px solid var(--border);border-radius:5px;background:rgba(255,255,255,.02);color:var(--muted);cursor:pointer;font-family:inherit;transition:all .12s}
.co-vis-btn:hover{border-color:rgba(255,255,255,.15);color:var(--text)}
.co-vis-btn.is-hidden{color:#fca5a5;border-color:rgba(239,68,68,.15);background:rgba(239,68,68,.03)}
.select-active .co-check{display:inline-block}
.select-active .co-drag{display:none}
.select-active .co-arrows{display:none}
.select-active .co-item{cursor:pointer}
.co-save{padding:12px 16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.co-save-hint{font-size:11px;color:var(--muted)}
.co-empty{padding:24px;text-align:center;font-size:13px;color:var(--muted);display:none}

/* ━━ LIBRARY PAGE (moved from library.php <style>) ━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-row{display:flex;align-items:center;gap:14px;padding:10px 14px;border-bottom:1px solid var(--border);transition:background .15s;position:relative}
.ch-row:last-child{border-bottom:none}
.ch-row:hover{background:rgba(255,255,255,0.02)}
.ch-logo{width:44px;height:44px;object-fit:contain;background:var(--bg2);border-radius:8px;flex-shrink:0;border:1px solid var(--border);padding:3px}
.ch-logo-placeholder{width:44px;height:44px;background:var(--bg2);border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--muted);border:1px solid var(--border)}
.ch-info{flex:1;min-width:0}
.ch-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ch-cat{font-size:11px;color:var(--muted);margin-top:1px}
.ch-badges{display:flex;gap:5px;align-items:center;flex-wrap:wrap}
.overflow-trigger{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;color:var(--muted);cursor:pointer;transition:all .15s;flex-shrink:0;font-size:16px;line-height:1}
.overflow-trigger:hover{background:rgba(255,255,255,0.06);border-color:var(--border);color:var(--text)}
.overflow-trigger.active{background:rgba(99,102,241,0.1);border-color:rgba(99,102,241,0.3);color:var(--accent)}
.overflow-menu{position:fixed;z-index:9999;background:var(--card2);border:1px solid var(--border);border-radius:10px;padding:4px;min-width:170px;box-shadow:0 8px 30px rgba(0,0,0,0.4);display:none}
.overflow-menu.show{display:block}
.overflow-menu-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;font-size:12px;font-weight:500;color:var(--text);cursor:pointer;transition:background .12s;border:none;background:none;width:100%;text-align:left;font-family:inherit}
.overflow-menu-item:hover{background:rgba(255,255,255,0.06)}
.overflow-menu-item svg{flex-shrink:0;opacity:0.5}
.overflow-menu-sep{height:1px;background:var(--border);margin:4px 8px}
.logo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;margin-top:12px}
.logo-item{background:var(--bg2);border-radius:8px;padding:6px;text-align:center;cursor:pointer;border:2px solid transparent;transition:border-color .15s,box-shadow .15s}
.logo-item:hover{border-color:var(--accent);box-shadow:0 0 0 1px rgba(99,102,241,0.15)}
.logo-item img{max-width:64px;max-height:40px;object-fit:contain}
.logo-item .logo-name{font-size:10px;color:var(--muted);margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.inline-panel{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:18px;margin:4px 0 10px}
.inline-panel .form-row{margin-bottom:10px}
.epg-badge-auto{background:rgba(99,102,241,0.1);color:#a5b4fc;border:1px solid rgba(99,102,241,0.15)}
.epg-badge-manual{background:rgba(139,92,246,0.1);color:#c4b5fd;border:1px solid rgba(139,92,246,0.15)}
.epg-badge-none{background:rgba(239,68,68,0.08);color:#fca5a5;border:1px solid rgba(239,68,68,0.15)}
.filter-pills{display:flex;gap:6px;flex-wrap:wrap}
.filter-pill{padding:5px 14px;border-radius:999px;font-size:12px;font-weight:500;text-decoration:none;background:rgba(255,255,255,0.04);color:var(--muted);border:1px solid var(--border);transition:all .15s}
.filter-pill:hover{color:var(--text);border-color:rgba(255,255,255,0.12);background:rgba(255,255,255,0.06)}
.filter-pill.active{background:rgba(99,102,241,0.12);color:var(--accent);border-color:rgba(99,102,241,0.3)}
.lib-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:space-between}
.lib-toolbar-left{display:flex;align-items:center;gap:10px;flex:1;min-width:200px}
.lib-toolbar-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.help-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:12px;color:var(--muted);padding:10px 0;border:none;background:none;font-family:inherit}
.help-toggle:hover{color:var(--text)}
.help-toggle svg{transition:transform .2s}
.help-toggle.open svg{transform:rotate(90deg)}

/* ━━ REFACTORED INLINE-STYLE CLASSES ━━━━━━━━━━━ */
.sidebar-logo-icon-img { object-fit: contain; padding: 4px; background: transparent; }
.tq-widget-wrap { position: relative; padding: 4px 8px; }
.ml-auto { margin-left: auto; }
.tq-popup-scroll { max-height: 380px; overflow-y: auto; }
.tq-active-count { color: #f59e0b; font-size: 11px; }
.tq-popup-empty { padding: 16px 14px; color: var(--muted, #64748b); font-size: 12px; text-align: center; }
.tq-item-icon { font-size: 14px; flex-shrink: 0; width: 16px; text-align: center; }
.tq-spinner-sm { display: inline-block; width: 12px; height: 12px; border: 2px solid rgba(99,102,241,.3); border-top-color: #6366f1; border-radius: 50%; animation: taskSpin 1s linear infinite; vertical-align: middle; }
.tq-action-btn { background: none; border: 1px solid #374151; color: #9ca3af; border-radius: 4px; font-size: 10px; padding: 2px 6px; cursor: pointer; flex-shrink: 0; }
.tq-footer-btn { background: none; border: 1px solid var(--border, #374151); color: var(--muted, #64748b); border-radius: 5px; font-size: 11px; padding: 4px 10px; cursor: pointer; flex: 1; }
.tq-footer-btn-danger { background: none; border: 1px solid #7f1d1d; color: #f87171; border-radius: 5px; font-size: 11px; padding: 4px 10px; cursor: pointer; flex: 1; }
.btn-xs { font-size: 11px; padding: 4px 8px; }
.vpn-popup-link { display: block; text-align: center; font-size: 11px; color: var(--accent); margin-top: 8px; text-decoration: none; }
.vpn-popup-empty { color: var(--muted); font-size: 12px; text-align: center; padding: 6px 0; }
.header-profile-wrap { position: relative; margin-left: auto; }
.header-profile-btn { display: flex; align-items: center; gap: 8px; padding: 6px 12px; background: var(--card); border: 1px solid var(--border); border-radius: 10px; cursor: pointer; color: var(--text); font-family: inherit; font-size: 13px; font-weight: 500; transition: border-color .15s; }
.header-profile-btn:hover { border-color: var(--accent); }
.header-profile-avatar { width: 28px; height: 28px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 12px; color: #fff; flex-shrink: 0; }
.header-profile-avatar-sa { background: rgba(245,158,11,.8); }
.header-profile-avatar-admin { background: linear-gradient(135deg, var(--accent), var(--cyan)); }
.header-profile-menu { position: absolute; right: 0; top: calc(100% + 6px); background: var(--card); border: 1px solid var(--border); border-radius: 10px; min-width: 200px; box-shadow: 0 8px 24px rgba(0,0,0,.5); z-index: 9999; overflow: hidden; }
.header-profile-info { padding: 12px 14px; border-bottom: 1px solid var(--border); }
.header-profile-name { font-weight: 600; font-size: 13px; }
.header-profile-handle { font-size: 11px; color: var(--muted); }
.header-profile-role { margin-top: 4px; }
.header-profile-role .badge { font-size: 10px; }
.header-profile-item { display: flex; align-items: center; gap: 8px; padding: 10px 14px; color: var(--text); text-decoration: none; font-size: 13px; transition: background .1s; }
.header-profile-item:hover { background: var(--card2); }
.header-profile-item-logout { color: var(--red); }
.header-profile-item-logout:hover { background: rgba(239,68,68,.08); }
.header-profile-divider { border-top: 1px solid var(--border); }
.flash-floating { position: fixed; top: 20px; left: 50%; transform: translateX(-50%); z-index: 999; min-width: 320px; text-align: center; }
.login-2fa-wrap { margin-top: -8px; }
.login-2fa-notice { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; padding: 10px 14px; background: rgba(99,102,241,.06); border: 1px solid rgba(99,102,241,.15); border-radius: 8px; }
.login-2fa-notice-text { font-size: 12px; color: #a5b4fc; }
.login-totp-input { letter-spacing: 2px; font-size: 16px; }
.login-2fa-cancel { font-size: 11px; color: var(--muted); text-decoration: none; }
/* Login page styles (moved from login.php) */
.login-page { background: #0b0e14; background-image: radial-gradient(ellipse 900px 600px at 15% 25%,rgba(99,102,241,.07),transparent), radial-gradient(ellipse 700px 500px at 85% 75%,rgba(139,92,246,.05),transparent); padding: 20px; }
.login-page::before { display: none; }
.login-split { display: flex; width: 100%; max-width: 960px; min-height: 580px; border-radius: 24px; overflow: hidden; box-shadow: 0 40px 100px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.04), 0 0 80px rgba(99,102,241,.06); position: relative; z-index: 1; }
.login-hero { flex: 0 0 46%; background: linear-gradient(160deg,#4338ca 0%,#6d28d9 45%,#7c3aed 100%); padding: 48px 40px; display: flex; flex-direction: column; justify-content: center; position: relative; overflow: hidden; }
.lh-shapes { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.lh-s1 { position: absolute; width: 320px; height: 320px; border-radius: 50%; background: rgba(255,255,255,.045); top: -100px; right: -90px; }
.lh-s2 { position: absolute; width: 200px; height: 200px; border-radius: 50%; background: rgba(255,255,255,.035); bottom: -60px; left: -50px; }
.lh-s3 { position: absolute; width: 90px; height: 90px; border-radius: 50%; background: rgba(255,255,255,.04); top: 55%; right: 15%; }
.lh-s4 { position: absolute; width: 140%; height: 1px; background: linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent); transform: rotate(-32deg); top: 28%; left: -20%; }
.lh-s5 { position: absolute; width: 140%; height: 1px; background: linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent); transform: rotate(-32deg); top: 58%; left: -20%; }
.lh-s6 { position: absolute; width: 50px; height: 50px; border-radius: 12px; border: 1px solid rgba(255,255,255,.06); transform: rotate(25deg); top: 18%; left: 65%; }
.lh-s7 { position: absolute; width: 30px; height: 30px; border-radius: 8px; border: 1px solid rgba(255,255,255,.05); transform: rotate(40deg); bottom: 22%; right: 28%; }
.lh-wave { position: absolute; bottom: 0; left: 0; right: 0; height: 100px; pointer-events: none; }
.lh-wave svg { width: 100%; height: 100%; display: block; }
.login-hero-content { position: relative; z-index: 2; }
.login-hero-badge { display: inline-flex; align-items: center; gap: 8px; padding: 8px 16px; border-radius: 99px; background: rgba(255,255,255,.12); backdrop-filter: blur(8px); font-size: 12px; font-weight: 600; color: rgba(255,255,255,.9); margin-bottom: 28px; letter-spacing: .01em; border: 1px solid rgba(255,255,255,.1); }
.login-hero-badge svg { opacity: .8; }
.login-hero-content h1 { font-size: 38px; font-weight: 800; color: #fff; line-height: 1.15; letter-spacing: -.02em; margin-bottom: 14px; }
.login-hero-content p { font-size: 15px; color: rgba(255,255,255,.6); line-height: 1.6; max-width: 300px; }
.lh-watermark { position: absolute; bottom: 30px; right: 32px; opacity: .06; z-index: 1; pointer-events: none; color: #fff; }
.lh-watermark svg { width: 100px; height: 100px; }
.login-form-panel { flex: 1; background: #161a26; padding: 48px 44px; display: flex; flex-direction: column; justify-content: center; position: relative; }
.lfp-brand { display: flex; align-items: center; gap: 12px; margin-bottom: 36px; }
.lfp-brand-icon { width: 44px; height: 44px; border-radius: 12px; background: linear-gradient(135deg,var(--accent),var(--purple)); display: flex; align-items: center; justify-content: center; font-size: 20px; color: #fff; flex-shrink: 0; box-shadow: 0 4px 14px rgba(99,102,241,.3); }
.lfp-brand-icon img { width: 100%; height: 100%; object-fit: contain; border-radius: 12px; padding: 4px; }
.lfp-brand-text { font-size: 16px; font-weight: 700; letter-spacing: -.01em; line-height: 1.25; }
.lfp-brand-text small { display: block; font-size: 11px; font-weight: 400; color: var(--muted); margin-top: 1px; letter-spacing: 0; }
.lfp-heading { font-size: 22px; font-weight: 700; letter-spacing: -.01em; margin-bottom: 4px; }
.lfp-sub { font-size: 13px; color: var(--muted); margin-bottom: 28px; }
.login-field { margin-bottom: 18px; }
.login-field-label { display: block; font-size: 12px; font-weight: 500; color: var(--muted); margin-bottom: 6px; }
.login-field-wrap { position: relative; }
.login-field-icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); width: 18px; height: 18px; color: #4a5268; pointer-events: none; transition: color .2s; }
.login-field-wrap input { width: 100%; padding: 13px 14px 13px 42px; font-size: 14px; font-family: inherit; color: var(--text); background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 10px; transition: all .2s; outline: none; }
.login-field-wrap input::placeholder { color: rgba(122,133,153,.5); }
.login-field-wrap input:hover { border-color: rgba(255,255,255,.12); background: rgba(255,255,255,.055); }
.login-field-wrap input:focus { border-color: rgba(99,102,241,.5); background: rgba(99,102,241,.04); box-shadow: 0 0 0 3px rgba(99,102,241,.1); }
.login-field-wrap:focus-within .login-field-icon { color: var(--accent); }
.login-remember { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--muted); cursor: pointer; margin-bottom: 24px; margin-top: 2px; }
.login-remember input[type=checkbox] { width: 16px; height: 16px; border-radius: 4px; accent-color: var(--accent); cursor: pointer; }
.login-submit { width: 100%; padding: 13px 20px; font-size: 14px; font-weight: 600; font-family: inherit; color: #fff; background: linear-gradient(135deg,var(--accent),var(--purple)); border: none; border-radius: 10px; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px; transition: all .2s; box-shadow: 0 4px 16px rgba(99,102,241,.25); letter-spacing: .01em; }
.login-submit:hover { transform: translateY(-1px); box-shadow: 0 6px 24px rgba(99,102,241,.35); filter: brightness(1.08); }
.login-submit:active { transform: translateY(0); box-shadow: 0 2px 8px rgba(99,102,241,.2); }
.login-captcha { margin-bottom: 18px; }
.lfp-footer { margin-top: 28px; text-align: center; font-size: 11px; color: var(--muted); opacity: .35; }
@media(max-width:820px) { .login-split { flex-direction: column; max-width: 480px; min-height: auto; } .login-hero { flex: none; padding: 36px 32px 28px; } .login-hero-content h1 { font-size: 28px; } .lh-s1 { width: 200px; height: 200px; top: -60px; right: -60px; } .lh-s2 { width: 120px; height: 120px; bottom: -30px; left: -30px; } .lh-watermark { display: none; } .login-form-panel { padding: 36px 32px; } }
@media(max-width:480px) { .login-page { padding: 12px; } .login-split { border-radius: 18px; } .login-hero { padding: 28px 24px 20px; } .login-hero-content h1 { font-size: 24px; } .login-hero-content p { font-size: 13px; } .login-form-panel { padding: 28px 24px; } .lfp-heading { font-size: 19px; } }
/* Task queue styles (moved from _layout_bottom.php) */
@keyframes taskSlideIn { from { opacity: 0; transform: translateX(40px); } to { opacity: 1; transform: none; } }
@keyframes taskSpin { to { transform: rotate(360deg); } }
#tq-toast-container { position: fixed; bottom: 20px; right: 20px; z-index: 9999; display: flex; flex-direction: column; gap: 8px; max-width: 340px; pointer-events: none; }
.tq-toast { background: #1e2533; border: 1px solid #374151; border-radius: 10px; padding: 10px 12px; color: #e5e7eb; font-size: 13px; display: flex; align-items: flex-start; gap: 10px; box-shadow: 0 4px 16px rgba(0,0,0,.5); pointer-events: auto; animation: taskSlideIn .25s ease; }
.tq-spinner { width: 15px; height: 15px; border: 2px solid rgba(99,102,241,.3); border-top-color: #6366f1; border-radius: 50%; animation: taskSpin 1s linear infinite; flex-shrink: 0; margin-top: 2px; }
.tq-close { background: none; border: none; color: #6b7280; cursor: pointer; font-size: 17px; padding: 0; line-height: 1; flex-shrink: 0; align-self: center; margin-left: 4px; }
.tq-close:hover { color: #e5e7eb; }
.tq-sidebar-btn { display: flex; align-items: center; gap: 8px; width: 100%; padding: 10px 16px; background: none; border: none; color: var(--sidebar-text,#94a3b8); cursor: pointer; font-size: 13px; font-weight: 500; text-align: left; border-radius: 8px; transition: background .15s; }
.tq-sidebar-btn:hover { background: var(--sidebar-hover,rgba(255,255,255,.06)); }
.tq-sidebar-btn.tq-active { color: #f59e0b; }
.tq-badge { background: #f59e0b; color: #000; font-size: 10px; font-weight: 700; min-width: 17px; height: 17px; border-radius: 9px; display: inline-flex; align-items: center; justify-content: center; padding: 0 4px; }
.tq-dot { width: 7px; height: 7px; border-radius: 50%; margin-left: auto; }
.tq-dot-on { background: #f59e0b; box-shadow: 0 0 6px #f59e0b; }
.tq-dot-off { background: #374151; }
.tq-popup { position: absolute; bottom: calc(100% + 8px); left: 12px; right: 12px; background: var(--card,#1e2533); border: 1px solid var(--border,#374151); border-radius: 10px; box-shadow: 0 8px 30px rgba(0,0,0,.5); z-index: 10000; overflow: hidden; }
.tq-popup-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; border-bottom: 1px solid var(--border,#374151); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--muted,#64748b); }
.tq-item { display: flex; align-items: center; gap: 8px; padding: 9px 14px; border-bottom: 1px solid rgba(55,65,81,.5); font-size: 12px; }
.tq-item:last-child { border-bottom: none; }
.tq-item-info { flex: 1; min-width: 0; }
.tq-item-cat { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: #818cf8; margin-bottom: 1px; }
.tq-item-label { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-weight: 500; }
.tq-item-meta { font-size: 10px; color: var(--muted,#64748b); }
.tq-item-status-run { color: #818cf8; }
.tq-item-status-ok { color: #4ade80; }
.tq-item-status-fail { color: #f87171; }
.tq-item-status-pend { color: #94a3b8; }
.tq-popup-footer { padding: 8px 14px; border-top: 1px solid var(--border,#374151); display: flex; gap: 6px; }
.tq-toast-body { flex: 1; min-width: 0; }
.tq-toast-cat { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; margin-bottom: 2px; }
.tq-toast-label { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tq-toast-meta { font-size: 10px; color: #6b7280; margin-top: 1px; }
.tq-toast-done-icon { font-size: 18px; flex-shrink: 0; margin-top: -1px; }
.tq-toast-done-label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; margin-bottom: 2px; }
.tq-toast-done-title { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tq-toast-error { font-size: 11px; color: #9ca3af; margin-top: 2px; white-space: normal; }
/* ━━ PAGE-SPECIFIC CSS CLASSES ━━━━━━━━━━━━━━━━━━
   Extracted from inline styles in PHP templates.
   Imported by style.css or _layout_top.php.
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* ── SYNC (.sy-) ───────────────────────────────── */
.sy-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 12px;
  margin-bottom: 20px;
}
.sy-kpi {
  background: var(--card);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 12px;
  padding: 14px 16px;
  text-align: center;
}
.sy-kpi.blue   { border-left: 3px solid var(--accent); }
.sy-kpi.green  { border-left: 3px solid var(--green); }
.sy-kpi.cyan   { border-left: 3px solid var(--cyan); }
.sy-kpi.orange { border-left: 3px solid var(--orange); }
.sy-kpi.red    { border-left: 3px solid var(--red); }
.sy-kpi-label { font-size: 10px; color: var(--muted); text-transform: uppercase; font-weight: 600; letter-spacing: 0.4px; margin-bottom: 4px; }
.sy-kpi-val   { font-size: 22px; font-weight: 700; line-height: 1.2; }
.sy-kpi-sub   { font-size: 10px; color: var(--muted); margin-top: 2px; }
.sy-kpi-val-sm{font-size:14px}
.sy-twin {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  align-items: stretch;
  margin-bottom: 20px;
}
@media (max-width: 640px) {
  .sy-twin { grid-template-columns: 1fr; }
}
.sy-body { display: flex; flex-direction: column; flex: 1; }
.sy-spacer { flex: 1; }
.sy-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:14px;border-top:1px solid var(--border);margin-top:auto}
.sy-cron-details{flex:1}
.sy-cron-pre{margin-top:6px;font-size:10px;overflow-x:auto;color:var(--muted)}
.sy-alert{margin-bottom:10px;font-size:12px}
.sy-run-btns{display:flex;flex-direction:column;gap:8px}
.sy-run-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px}
.sy-run-spinner{width:14px;height:14px;border-color:rgba(255,255,255,.3);border-top-color:#fff}
.sy-run-spinner-accent{width:14px;height:14px;border-color:rgba(255,255,255,.3);border-top-color:var(--accent)}
.sy-hint{font-size:11px;color:var(--muted);margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.sy-hint a{color:var(--accent)}
.sy-svc-name{font-size:13px}
.sy-td-muted{font-size:11px;color:var(--muted);white-space:nowrap}
.sy-dash{opacity:.4}
.sy-status-dash{color:var(--muted);opacity:.4}
.sy-clear-form{display:inline}
.sy-clear-btn{font-size:10px;padding:3px 8px}

/* ── LOGS (.log-) ──────────────────────────────── */
.log-retention-bar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.log-retention-form{display:flex;align-items:center;gap:8px}
.log-retention-label{font-size:12px;color:var(--muted);margin:0;text-transform:none;letter-spacing:0;font-weight:500;white-space:nowrap}
.log-retention-input{width:80px;padding:6px 8px;font-size:12px}
.log-retention-suffix{font-size:12px;color:var(--muted)}
.log-clear-all-wrap{margin-left:auto;display:flex;gap:6px}
.log-tabs{display:flex;gap:4px;margin-bottom:16px;align-items:center;flex-wrap:wrap}
.log-tab-badge{font-size:10px;padding:1px 6px;margin-left:4px}
.log-per-page-wrap{margin-left:auto;display:flex;align-items:center;gap:6px}
.log-per-page-label{font-size:12px;color:var(--muted);margin:0;text-transform:none;letter-spacing:0;font-weight:500}
.log-per-page-select{width:auto;min-width:0;padding:5px 24px 5px 8px;font-size:12px}
.log-header-actions{display:flex;gap:8px;align-items:center}
.log-loading{padding:20px;text-align:center;color:var(--muted)}
.log-empty{color:var(--muted);font-size:13px;padding:8px 0}
.log-td-timestamp{font-size:12px;color:var(--muted);white-space:nowrap}
.log-td-detail{font-size:12px;color:var(--muted);max-width:300px;overflow:hidden;text-overflow:ellipsis}
.log-td-ip{font-size:12px;color:var(--muted)}
.log-td-sync-msg{font-size:12px;color:var(--muted);max-width:300px;overflow:hidden;text-overflow:ellipsis}
.log-td-ua{font-size:11px;color:var(--muted);max-width:200px;overflow:hidden;text-overflow:ellipsis}
.log-page-info{font-size:12px;color:var(--muted);margin-left:8px}

/* ── MEDIA SERVERS (.ms-) ──────────────────────── */
.ms-form-hint{font-size:11px;color:var(--muted);margin-top:3px}
.ms-test-flex{display:flex;gap:8px;align-items:center;margin-bottom:14px}
.ms-test-result{font-size:12px}
.ms-empty{text-align:center;padding:40px 20px}
.ms-empty-icon{font-size:28px;margin-bottom:8px;opacity:.5}
.ms-empty-title{font-size:14px;font-weight:500;margin-bottom:4px}
.ms-empty-subtitle{font-size:12px;color:var(--muted);margin-bottom:14px}
.ms-server-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.ms-server-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.ms-server-icon{width:40px;height:40px;border-radius:10px;background:rgba(99,102,241,.1);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ms-server-meta{min-width:0}
.ms-server-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ms-server-name{font-size:16px;font-weight:600}
.ms-server-url{font-size:11px;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ms-server-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.ms-action-btn{padding:6px 12px;font-size:11px}
.ms-rematch-action-btn{padding:6px 10px;font-size:11px}
.ms-kebab-btn{padding:5px 8px}
.ms-dropdown{position:absolute;right:0;top:calc(100%+4px);background:var(--card);border:1px solid var(--border);border-radius:8px;min-width:130px;box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:9999;overflow:hidden}
.ms-dropdown-item{display:block;width:100%;padding:8px 14px;font-size:12px;text-align:left;background:none;border:none;cursor:pointer}
.ms-dropdown-item:hover{background:var(--card2)}
.ms-stats-row{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:14px;padding:10px 14px;background:var(--bg);border-radius:8px;border:1px solid var(--border)}
.ms-stat-label{font-size:10px;color:var(--muted);margin-bottom:1px}
.ms-stat-val{font-size:15px;font-weight:600}
.ms-stat-services{display:flex;gap:4px;flex-wrap:wrap}
.ms-stat-right{margin-left:auto;text-align:right}
.ms-lib-toggle{display:flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;color:var(--muted);font-size:12px;font-weight:500;padding:0;font-family:inherit;transition:color .15s}
.ms-lib-toggle:hover{color:var(--text)}
.ms-lib-grid{margin-top:10px;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:8px}
.ms-lib-card{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px 12px}
.ms-lib-header{display:flex;align-items:center;justify-content:space-between;gap:6px}
.ms-lib-name{font-size:12px;font-weight:500}
.ms-lib-meta{font-size:10px;color:var(--muted);margin-top:2px}
.ms-lib-config-btn{margin-top:6px;font-size:10px;padding:3px 8px;width:100%}
.ms-lib-config-expand{margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}
.ms-lib-form-group{margin-bottom:6px}
.ms-lib-label{font-size:10px;margin-bottom:3px}
.ms-lib-select{width:100%;padding:4px 8px;font-size:11px}
.ms-lib-input{width:100%;padding:4px 8px;font-size:11px}
.ms-lib-check-label{display:flex;align-items:center;gap:5px;font-size:11px;cursor:pointer;margin:0;text-transform:none;letter-spacing:0;font-weight:400;color:var(--text)}
.ms-lib-checkbox{width:13px;height:13px}
.ms-lib-save-btn{font-size:10px;padding:4px 10px;width:100%}
.ms-how-card{padding:14px 18px}
.ms-how-toggle{display:flex;align-items:center;gap:6px;width:100%;background:none;border:none;cursor:pointer;color:var(--muted);font-size:12px;font-weight:500;padding:0;font-family:inherit}
.ms-how-body{margin-top:10px;font-size:12px;color:var(--muted);line-height:1.7}
.ms-how-body p{margin-top:6px}
.ms-chevron{transition:transform .15s}
.ms-modal-box{max-width:560px}
.ms-add-btn{padding:6px 14px;font-size:12px}
.ms-delete-form{margin:0}
.ms-dropdown-delete{color:var(--red);border-top:1px solid var(--border)}
.ms-dropdown-delete:hover{background:rgba(239,68,68,.06)}
.ms-stat-none{font-size:12px;color:var(--muted)}
.ms-stat-overflow{font-size:10px;color:var(--muted)}
.ms-stat-sync-date{font-size:12px}
.ms-lib-disabled{opacity:.5}
.ms-lib-form-mb8{margin-bottom:8px}
.ms-how-strong{color:var(--text)}
.ms-badge-svc{font-size:9px}
.ms-badge-mode{font-size:9px}

/* ── SUPERADMIN PAGE ───────────────────────── */

/* Page title */
.sa-title { margin: 0; font-size: 22px; font-weight: 700; letter-spacing: -0.02em; }
.sa-subtitle { margin: 4px 0 0; font-size: 13px; color: var(--muted); }

/* Tab badge (count pill inside tab buttons) */
.sa-tab-badge { font-size: 9px; padding: 1px 6px; margin-left: 4px; }

/* Admin avatar circle */
.sa-avatar {
  width: 32px; height: 32px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 13px; flex-shrink: 0;
}
.sa-avatar-super { background: rgba(245,158,11,.12); color: #f59e0b; }
.sa-avatar-admin { background: rgba(99,102,241,.1); color: var(--accent); }

/* Admin name / meta cells */
.sa-admin-name { font-weight: 600; font-size: 13px; line-height: 1.3; }
.sa-admin-you { font-size: 10px; color: var(--accent); font-weight: 400; margin-left: 4px; }
.sa-admin-handle { font-size: 11px; color: var(--muted); }
.sa-admin-access { font-size: 12px; color: var(--muted); }
.sa-admin-date { font-size: 12px; color: var(--muted); white-space: nowrap; }

/* 2FA status labels */
.sa-2fa-forced { font-size: 9px; color: var(--orange); margin-left: 2px; }
.sa-2fa-off { font-size: 11px; color: var(--muted); opacity: .5; }

/* Context menu (actions dropdown) */
.sa-ctx-menu {
  position: absolute; right: 0; top: calc(100% + 4px);
  background: var(--card); border: 1px solid var(--border); border-radius: 8px;
  min-width: 150px; box-shadow: 0 8px 24px rgba(0,0,0,.4);
  z-index: 9999; overflow: hidden;
}
.sa-ctx-btn {
  display: block; width: 100%; padding: 9px 14px; font-size: 13px;
  color: var(--text); text-align: left; background: none;
  border: none; cursor: pointer; transition: background .1s;
}
.sa-ctx-btn:hover { background: var(--card2); }
.sa-ctx-btn-sm {
  display: block; width: 100%; padding: 8px 14px; font-size: 12px;
  text-align: left; background: none; border: none;
  cursor: pointer; transition: background .1s;
}
.sa-ctx-btn-sm:hover { background: var(--card2); }
.sa-ctx-btn-sm.text-orange:hover { background: rgba(245,158,11,.06); }
.sa-ctx-delete {
  display: block; width: 100%; padding: 9px 14px; font-size: 13px;
  color: var(--red); text-align: left; background: none;
  border: none; cursor: pointer; border-top: 1px solid var(--border);
  transition: background .1s;
}
.sa-ctx-delete:hover { background: rgba(239,68,68,.06); }
.sa-ctx-sep { border-top: 1px solid var(--border); padding: 2px 0; }
.sa-ctx-dots { padding: 5px 8px; font-size: 14px; line-height: 1; }

/* Empty state (no admins) */
.sa-empty { padding: 40px 0; text-align: center; color: var(--muted); font-size: 13px; }

/* Role cards grid */
.sa-role-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px; margin-bottom: 20px;
}

/* Role card header area */
.sa-role-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; margin-bottom: 12px; }
.sa-role-name { font-weight: 600; font-size: 14px; }
.sa-role-desc { font-size: 12px; color: var(--muted); margin: 0; line-height: 1.5; }
.sa-role-builtin {
  font-size: 10px; color: var(--muted); white-space: nowrap;
  padding: 2px 6px; border: 1px solid var(--border); border-radius: 4px;
}

/* Role permission progress bar */
.sa-perm-bar { display: flex; align-items: center; gap: 6px; margin-bottom: 12px; }
.sa-perm-count { font-size: 12px; color: var(--muted); }
.sa-perm-track { flex: 1; height: 3px; background: var(--border); border-radius: 2px; overflow: hidden; }
.sa-perm-fill { height: 100%; background: var(--accent); border-radius: 2px; transition: width .3s; }

/* Role permission group tags */
.sa-perm-tags { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 14px; }
.sa-perm-tag { font-size: 10px; padding: 2px 7px; border-radius: 4px; }
.sa-perm-tag-on {
  background: rgba(16,185,129,.08); color: var(--green);
  border: 1px solid rgba(16,185,129,.15);
}
.sa-perm-tag-off {
  background: transparent; color: var(--muted);
  border: 1px solid var(--border); opacity: .5;
}

/* Role card footer */
.sa-role-footer { display: flex; gap: 6px; border-top: 1px solid var(--border); padding-top: 12px; }
.sa-role-edit-section { margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--border); }
.sa-role-delete-btn { color: var(--red); padding: 6px 10px; }

/* Create role card */
.sa-create-card { margin-bottom: 0; border-style: dashed; }
.sa-create-placeholder {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; min-height: 140px; cursor: pointer;
  color: var(--muted); gap: 8px; transition: color .15s;
}
.sa-create-placeholder:hover { color: var(--accent); }
.sa-create-label { font-size: 13px; font-weight: 500; }

/* Drawer overlay (create/edit admin) */
.sa-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.5);
  backdrop-filter: blur(4px); z-index: 9999;
}
.sa-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: 520px; max-width: 100vw; background: var(--card);
  border-left: 1px solid var(--border);
  box-shadow: -8px 0 32px rgba(0,0,0,.4);
  display: flex; flex-direction: column; overflow: hidden;
}
.sa-drawer-header {
  padding: 20px 24px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between; flex-shrink: 0;
}
.sa-drawer-title { font-size: 16px; font-weight: 600; margin: 0; }
.sa-drawer-subtitle { font-size: 12px; color: var(--muted); margin: 2px 0 0; }
.sa-drawer-close {
  background: rgba(239,68,68,.08); border: 1px solid rgba(239,68,68,.2); border-radius: 8px;
  width: 32px; height: 32px; display: flex; align-items: center;
  justify-content: center; cursor: pointer; color: var(--red);
  transition: all .15s; flex-shrink: 0;
  font-size: 20px; font-weight: 400; line-height: 1; font-family: inherit;
}
.sa-drawer-close:hover { background: rgba(239,68,68,.15); color: #f87171; border-color: rgba(239,68,68,.3); }
.sa-drawer-body { flex: 1; overflow-y: auto; padding: 24px; }
.sa-suspend-section { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--border); }

/* Step tabs (create admin wizard) */
.sa-steps { display: flex; gap: 8px; margin-bottom: 24px; }
.sa-step {
  flex: 1; text-align: center; padding: 8px;
  border-bottom: 2px solid var(--border); font-size: 12px;
  font-weight: 500; color: var(--muted); transition: all .2s; cursor: pointer;
}

/* Button helpers */
.sa-btn-row { display: flex; gap: 8px; }
.sa-btn-full { width: 100%; justify-content: center; }
.sa-btn-flex { flex: 1; justify-content: center; }

/* Form hint paragraph */
.sa-form-hint { font-size: 11px; color: var(--muted); margin-top: 4px; }

/* Label hint inline span */
.sa-label-hint { font-weight: 400; color: var(--muted); }

/* Permission editor (renderPermEditor) */
.sa-perm-header-cursor { cursor: pointer; user-select: none; }
.sa-perm-icon { opacity: .6; display: flex; }
.sa-perm-counter { font-size: 10px; font-weight: 400; color: var(--muted); }
.sa-perm-toggle-all {
  font-size: 11px; cursor: pointer; color: var(--accent); font-weight: 500;
  text-transform: none; letter-spacing: 0; margin: 0;
}
.sa-perm-chevron { transition: transform .15s; }
.sa-perm-body { padding: 4px 0; }

/* New role form header */
.sa-new-role-header { margin-bottom: 14px; display: flex; align-items: center; justify-content: space-between; }

/* Form row bottom margin */
.sa-form-row-mb { margin-bottom: 16px; }

/* Edit drawer footer */
.sa-edit-footer { display: flex; gap: 8px; padding-top: 8px; }

/* Col widths for admin table */
.sa-col-avatar { width: 40px; }
.sa-col-actions { width: 60px; }

/* ── TMDB PAGE (.tmdb-) ───────────────────────── */

/* Top grid layout */
.tmdb-top-grid{align-items:stretch;margin-bottom:16px}

/* Card status grid (2-col info display) */
.tmdb-status-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;font-size:12px}
.tmdb-status-label{color:var(--muted);font-size:10px;margin-bottom:2px}

/* Sync-all status bar */
.tmdb-sync-status{font-size:11px;padding:6px 10px;border-radius:5px;margin-top:10px;background:var(--card2);border:1px solid var(--border);color:var(--muted)}

/* How-it-works body */
.tmdb-how-body{font-size:12px;line-height:1.7;color:var(--muted)}
.tmdb-how-body p{margin-bottom:8px}
.tmdb-how-body p:last-child{margin-bottom:0}
.tmdb-how-strong{color:var(--text)}

/* No-services message */
.tmdb-empty-msg{color:var(--muted);font-size:13px}

/* Category toggle label (service cards) */
.tmdb-cat-toggle{display:flex;align-items:center;gap:5px;cursor:pointer;padding:4px 7px;border-radius:5px;background:var(--card2);border:1px solid var(--border);white-space:nowrap;font-size:11px;text-transform:none;letter-spacing:0;font-weight:400;color:var(--text);margin:0}

/* Category toggle label (master card variant) */
.tmdb-cat-toggle-master{display:flex;align-items:center;gap:5px;cursor:pointer;padding:4px 7px;border-radius:5px;background:rgba(129,140,248,.1);border:1px solid rgba(129,140,248,.25);white-space:nowrap;font-size:11px;color:#c7d2fe;text-transform:none;letter-spacing:0;font-weight:400;margin:0}

/* Category toggle checkbox */
.tmdb-cat-checkbox{flex-shrink:0;width:13px;height:13px}

/* Item count badge inside toggle */
.tmdb-cat-count{font-size:9px;padding:1px 5px;margin-left:2px}

/* Year input inside toggle */
.tmdb-year-input{width:60px;padding:1px 4px;font-size:11px;border-radius:3px;border:1px solid var(--border);background:var(--bg);color:var(--text)}
.tmdb-year-input-master{width:56px;padding:1px 3px;font-size:10px;border-radius:3px;border:1px solid rgba(129,140,248,.25);background:rgba(0,0,0,.3);color:#c7d2fe}

/* Service cards grid */
.tmdb-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}

/* Master card */
.tmdb-master-card{margin-bottom:0;border:1px solid rgba(129,140,248,.3);background:linear-gradient(135deg,rgba(99,102,241,.06) 0%,rgba(139,92,246,.03) 100%)}

/* Card header row */
.tmdb-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:10px}
.tmdb-card-name-row{display:flex;align-items:center;gap:7px;margin-bottom:3px}

/* Master icon box */
.tmdb-master-icon{width:28px;height:28px;border-radius:6px;background:linear-gradient(135deg,#818cf8,#a78bfa);display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* Master title */
.tmdb-master-title{font-weight:600;font-size:14px;color:#a5b4fc}

/* Progress bar row */
.tmdb-progress-row{display:flex;align-items:center;gap:6px;margin-bottom:10px}
.tmdb-progress-track{flex:1;height:3px;background:var(--border);border-radius:2px;overflow:hidden}
.tmdb-progress-track-master{flex:1;height:3px;background:rgba(129,140,248,.15);border-radius:2px;overflow:hidden}
.tmdb-progress-fill{height:100%;border-radius:2px;background:var(--accent)}
.tmdb-progress-fill-master{height:100%;border-radius:2px;background:#818cf8}

/* Category summary badges row */
.tmdb-badge-row{display:flex;flex-wrap:wrap;gap:3px;margin-bottom:12px}
.tmdb-badge-cat{font-size:9px;padding:2px 6px;border-radius:4px}
.tmdb-badge-cat-on{background:rgba(16,185,129,.08);color:var(--green);border:1px solid rgba(16,185,129,.15)}
.tmdb-badge-cat-off{background:transparent;color:var(--muted);border:1px solid var(--border);opacity:.4}
.tmdb-badge-cat-master-on{background:rgba(129,140,248,.12);color:#a5b4fc;border:1px solid rgba(129,140,248,.25)}
.tmdb-badge-cat-master-off{background:transparent;color:var(--muted);border:1px solid var(--border);opacity:.4}

/* Card actions footer */
.tmdb-card-actions{display:flex;gap:6px;border-top:1px solid var(--border);padding-top:10px}
.tmdb-card-actions-master{display:flex;gap:6px;border-top:1px solid rgba(129,140,248,.2);padding-top:10px}

/* Master-accent button overrides */
.tmdb-btn-master{border-color:rgba(129,140,248,.25);color:#c7d2fe}
.tmdb-btn-master-primary{background:#818cf8;border-color:#818cf8;color:#fff}

/* Expandable edit section */
.tmdb-edit-section{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.tmdb-edit-section-master{margin-top:12px;padding-top:12px;border-top:1px solid rgba(129,140,248,.2)}

/* Category section heading */
.tmdb-cat-heading{font-size:10px;font-weight:600;color:var(--muted);margin-bottom:6px}
.tmdb-cat-heading-master{font-size:10px;font-weight:600;color:#a5b4fc;margin-bottom:6px}

/* Category toggles wrap */
.tmdb-cat-wrap{display:flex;flex-wrap:wrap;gap:4px}

/* Sync status box */
.tmdb-sync-status-box{font-size:10px;padding:5px 8px;border-radius:5px;margin-bottom:10px;background:var(--card2);border:1px solid var(--border);color:var(--muted)}
.tmdb-sync-status-break{word-break:break-word}

/* Master save-all status */
.tmdb-master-save-status{font-size:11px;padding:5px 8px;border-radius:5px;margin-top:8px;background:rgba(129,140,248,.06);border:1px solid rgba(129,140,248,.15);color:#c7d2fe}

/* Service card name */
.tmdb-svc-name{font-weight:600;font-size:14px}

/* Test key result */
.tmdb-test-result{font-size:12px;display:flex;align-items:center}

/* Modal narrow */
.tmdb-modal-narrow{max-width:520px}

/* Auto-sync checkbox alignment */
.tmdb-autosync-group{margin-bottom:0;display:flex;align-items:flex-end;padding-bottom:1px}

/* Small button variant */
.tmdb-btn-xs{padding:5px 12px;font-size:11px}
.tmdb-btn-xs-narrow{padding:5px 10px;font-size:11px}
