/* ── THEME VARIABLES ── */
:root {
    --sidebar-w: 230px;
    --font: 'Plus Jakarta Sans', sans-serif;
    --mono: 'JetBrains Mono', monospace;
    --radius: 10px;
    --radius-lg: 14px;
}
.t-dark {
    --bg: #0D1B2A; --bg2: #1A2940; --bg3: #243650;
    --nav: #080F1A; --nav2: #1A2940;
    --surface: #1A2940; --surface2: #1E2F48;
    --text: #F0F4F8; --text2: #94A3B8; --text3: #64748B;
    --bd: rgba(255,255,255,0.07); --bd2: rgba(255,255,255,0.13);
    --accent: #06B6D4; --accent-bg: rgba(6,182,212,0.12); --accent-text: #67E8F9;
    --green: #10B981; --green-bg: rgba(16,185,129,0.12); --green-text: #6EE7B7;
    --amber: #F59E0B; --amber-bg: rgba(245,158,11,0.12); --amber-text: #FCD34D;
    --red: #F43F5E; --red-bg: rgba(244,63,94,0.12); --red-text: #FDA4AF;
    --shadow: 0 2px 8px rgba(0,0,0,0.4);
    --login-bg: #060D18;
}
.t-light {
    --bg: #F1F5F9; --bg2: #E8EEF5; --bg3: #DDE4EE;
    --nav: #0F172A; --nav2: #1E293B;
    --surface: #FFFFFF; --surface2: #F8FAFC;
    --text: #0F172A; --text2: #475569; --text3: #94A3B8;
    --bd: #E2E8F0; --bd2: #CBD5E1;
    --accent: #0EA5E9; --accent-bg: #EFF8FF; --accent-text: #0369A1;
    --green: #059669; --green-bg: #ECFDF5; --green-text: #065F46;
    --amber: #D97706; --amber-bg: #FFFBEB; --amber-text: #92400E;
    --red: #DC2626; --red-bg: #FEF2F2; --red-text: #991B1B;
    --shadow: 0 1px 4px rgba(0,0,0,0.08);
    --login-bg: #0F172A;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body { font-family: var(--font); background: var(--bg); color: var(--text); font-size: 13px; line-height: 1.6; transition: background 0.25s, color 0.25s; }

/* ── LOGIN ── */
.login-page { min-height: 100vh; background: var(--login-bg); display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.login-glow { position: absolute; inset: 0; background: radial-gradient(ellipse 70% 60% at 25% 50%, rgba(6,182,212,0.15) 0%, transparent 60%), radial-gradient(ellipse 50% 70% at 80% 20%, rgba(245,158,11,0.08) 0%, transparent 55%); }
.login-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(6,182,212,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(6,182,212,0.04) 1px,transparent 1px); background-size: 44px 44px; }
.login-box { position: relative; z-index: 10; background: rgba(15,32,64,0.88); border: 1px solid rgba(6,182,212,0.18); border-radius: 20px; padding: 48px 44px; width: 420px; backdrop-filter: blur(20px); box-shadow: 0 40px 80px rgba(0,0,0,0.5); }
.login-logo { text-align: center; margin-bottom: 36px; }
.login-logo h1 { font-size: 20px; font-weight: 700; color: #fff; letter-spacing: 3px; }
.login-logo p { color: #06B6D4; font-size: 10px; letter-spacing: 2.5px; text-transform: uppercase; margin-top: 5px; }
.login-divider { width: 36px; height: 2px; background: linear-gradient(90deg,#06B6D4,#F59E0B); margin: 14px auto 0; border-radius: 2px; }
.login-label { display: block; font-size: 10px; font-weight: 700; color: #94A3B8; text-transform: uppercase; letter-spacing: 1.2px; margin-bottom: 8px; margin-top: 16px; }
.login-input { width: 100%; padding: 13px 15px; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); border-radius: 9px; color: #fff; font-family: var(--font); font-size: 14px; outline: none; transition: all 0.2s; }
.login-input:focus { border-color: #06B6D4; background: rgba(6,182,212,0.08); box-shadow: 0 0 0 3px rgba(6,182,212,0.15); }
.login-input::placeholder { color: rgba(255,255,255,0.2); }
.login-btn { width: 100%; padding: 14px; background: #06B6D4; color: #fff; border: none; border-radius: 9px; font-family: var(--font); font-size: 13px; font-weight: 700; letter-spacing: 2px; cursor: pointer; transition: all 0.2s; margin-top: 22px; }
.login-btn:hover { background: #0891B2; transform: translateY(-1px); box-shadow: 0 8px 24px rgba(6,182,212,0.4); }
.login-error { background: rgba(244,63,94,0.15); border: 1px solid rgba(244,63,94,0.3); color: #FDA4AF; padding: 11px 14px; border-radius: 8px; font-size: 12px; margin-top: 14px; }
.login-footer { text-align: center; color: rgba(255,255,255,0.18); font-size: 10px; margin-top: 28px; }

/* ── LAYOUT ── */
.app { display: flex; min-height: 100vh; }
.sidebar { width: var(--sidebar-w); background: var(--nav); position: fixed; top: 0; left: 0; bottom: 0; display: flex; flex-direction: column; z-index: 100; border-right: 1px solid var(--bd); transition: background 0.25s; overflow-y: auto; }
.main { margin-left: var(--sidebar-w); flex: 1; display: flex; flex-direction: column; min-height: 100vh; position: relative; z-index: 1; }

/* ── SIDEBAR ── */
.slogo { padding: 22px 18px 18px; border-bottom: 1px solid var(--bd); }
.slogo-brand { font-size: 14px; font-weight: 700; color: #fff; letter-spacing: 1.5px; }
.slogo-sub { font-size: 9px; color: var(--accent); letter-spacing: 2px; text-transform: uppercase; margin-top: 3px; }
.nav-sec { padding: 16px 14px 5px; font-size: 9px; font-weight: 700; color: rgba(255,255,255,0.2); letter-spacing: 2px; text-transform: uppercase; }
.ni { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border-radius: 9px; color: rgba(255,255,255,0.45); text-decoration: none; font-size: 13px; font-weight: 500; transition: all 0.18s; margin: 2px 6px; }
.ni:hover { background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.8); }
.ni.active { background: rgba(6,182,212,0.16); color: var(--accent); }
.ni svg { width: 16px; height: 16px; flex-shrink: 0; }
.nbadge { margin-left: auto; font-size: 9px; font-weight: 700; padding: 2px 7px; border-radius: 20px; }
.nbadge.red { background: var(--red); color: #fff; }
.nbadge.amber { background: var(--amber); color: #fff; }
.nbadge.gray { background: rgba(255,255,255,0.12); color: rgba(255,255,255,0.5); }
.nbadge.green { background: rgba(16,185,129,0.18); color: #34d399; }
.nbadge.secret { background: rgba(245,158,11,0.12); color: #f59e0b; border: 1px dashed rgba(245,158,11,0.5); }
.sfoot { margin-top: auto; border-top: 1px solid var(--bd); padding: 10px 8px; }
.theme-toggle { display: flex; align-items: center; justify-content: space-between; padding: 9px 12px; border-radius: 9px; background: rgba(255,255,255,0.04); border: 1px solid var(--bd2); cursor: pointer; margin-bottom: 8px; width: calc(100% - 0px); }
.theme-label { font-size: 11px; color: rgba(255,255,255,0.4); font-weight: 500; }
.ttrack { width: 34px; height: 18px; border-radius: 20px; background: #1E3A5F; position: relative; transition: background 0.2s; flex-shrink: 0; }
.ttrack.on { background: var(--accent); }
.tthumb { width: 14px; height: 14px; border-radius: 50%; background: #fff; position: absolute; top: 2px; left: 2px; transition: left 0.2s; }
.ttrack.on .tthumb { left: 18px; }
.user-row { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border-radius: 9px; }
.uavatar { width: 30px; height: 30px; border-radius: 8px; background: var(--accent); display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; color: #fff; flex-shrink: 0; }
.uname { font-size: 12px; font-weight: 600; color: rgba(255,255,255,0.8); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.urole { font-size: 10px; color: var(--accent); text-transform: uppercase; letter-spacing: 1px; }
.logout-a { color: rgba(255,255,255,0.5); text-decoration: none; font-size: 16px; margin-left: auto; flex-shrink: 0; transition: color 0.2s; display: flex; align-items: center; }
.logout-a:hover { color: var(--red); }
.t-light .logout-a { color: rgba(15,23,42,0.5) !important; }
.t-light .logout-a:hover { color: var(--red) !important; }

/* ── TOPBAR ── */
.topbar { background: var(--surface); border-bottom: 1px solid var(--bd); padding: 0 28px; height: 60px; display: flex; align-items: center; gap: 12px; position: sticky; top: 0; z-index: 50; transition: background 0.25s; }
.tb-title { font-size: 16px; font-weight: 700; color: var(--text); flex: 1; }
.tb-date { font-size: 11px; color: var(--text3); }

/* ── BUTTONS ── */
.btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px; border-radius: 8px; font-family: var(--font); font-size: 12px; font-weight: 600; cursor: pointer; border: none; transition: all 0.18s; text-decoration: none; white-space: nowrap; }
.btn-primary { background: var(--accent); color: #fff; }
.btn-primary:hover { opacity: 0.88; transform: translateY(-1px); }
.btn-ghost { background: transparent; color: var(--text2); border: 1px solid var(--bd2); }
.btn-ghost:hover { background: var(--bg2); color: var(--text); }
.btn-sm { padding: 5px 11px; font-size: 11px; }
.btn-edit { background: var(--amber-bg); color: var(--amber-text); border: 1px solid var(--amber); }
.btn-edit:hover { opacity: 0.85; }
.btn-pdf { background: var(--accent-bg); color: var(--accent-text); border: 1px solid var(--accent); }
.btn-pdf:hover { opacity: 0.85; }
.btn-print { background: var(--green-bg); color: var(--green-text); border: 1px solid var(--green); }
.btn-print:hover { opacity: 0.85; }
.btn-share { background: rgba(139,92,246,0.1); color: #7C3AED; border: 1px solid #7C3AED; }
.t-dark .btn-share { color: #C4B5FD; border-color: #7C3AED; background: rgba(124,58,237,0.12); }
.btn-share:hover { opacity: 0.85; }
.btn-danger { background: var(--red-bg); color: var(--red-text); border: 1px solid var(--red); }
.btn-danger:hover { opacity: 0.85; }

/* ── CONTENT ── */
.content { padding: 24px 28px; flex: 1; }
.flash { background: var(--green-bg); border: 1px solid var(--green); color: var(--green-text); padding: 11px 18px; border-radius: 9px; margin-bottom: 20px; font-weight: 600; font-size: 12px; }
#toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 20px;border-radius:10px;font-size:13px;font-weight:600;font-family:inherit;box-shadow:0 4px 16px rgba(0,0,0,0.15);animation:toastIn .3s ease;max-width:380px}
.toast-ok{background:#DCFCE7;color:#166534;border:1px solid #86EFAC}
.toast-err{background:#FEE2E2;color:#991B1B;border:1px solid #FCA5A5}
@keyframes toastIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ── ALERT BANNER ── */
.alert-banner { background: var(--amber-bg); border: 1px solid var(--amber); border-radius: 10px; padding: 11px 16px; display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.alert-text { font-size: 12px; font-weight: 600; color: var(--amber-text); flex: 1; }
.alert-link { font-size: 11px; font-weight: 700; color: var(--accent); text-decoration: none; white-space: nowrap; }
.alert-link:hover { text-decoration: underline; }
.hov-link { color:inherit;text-decoration:none;transition:color .15s; }
.hov-link:hover { text-decoration:underline;text-underline-offset:3px;color:var(--accent) !important; }
a.stat-card { display:block;text-decoration:none; }
a.stat-card:hover { color:inherit; }

/* ── STATS ── */
.stats-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-bottom: 20px; }
.stat-card { background: var(--surface); border: 1px solid var(--bd); border-radius: var(--radius-lg); padding: 18px; position: relative; overflow: hidden; transition: transform 0.2s, box-shadow 0.2s, background 0.25s; }
.stat-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.stat-card::after { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; }
.stat-card.c1::after { background: var(--accent); }
.stat-card.c2::after { background: var(--green); }
.stat-card.c3::after { background: var(--amber); }
.stat-card.c4::after { background: var(--red); }
.stat-val { font-size: 30px; font-weight: 700; color: var(--text); line-height: 1; margin-bottom: 5px; }
.stat-label { font-size: 10px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: 0.8px; }
.stat-bar { height: 3px; border-radius: 2px; margin-top: 12px; background: var(--bg2); overflow: hidden; }
.stat-bar-fill { height: 100%; border-radius: 2px; }

/* ── CHARTS ROW ── */
.charts-row { display: grid; grid-template-columns: 1fr 260px; gap: 14px; margin-bottom: 4px; }
.card { background: var(--surface); border: 1px solid var(--bd); border-radius: var(--radius-lg); transition: background 0.25s; }
.card-head { padding: 14px 18px; border-bottom: 1px solid var(--bd); display: flex; align-items: center; justify-content: space-between; }
.card-title { font-size: 11px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: 0.9px; }
.card-body { padding: 16px 18px; }
.card-body table { min-width: unset; width: 100%; }

/* ── QUICK ACTIONS ── */
.qa-list { display: flex; flex-direction: column; gap: 8px; }
.qa-item { display: flex; align-items: center; gap: 11px; padding: 10px 12px; border-radius: 9px; background: var(--bg2); border: 1px solid var(--bd); cursor: pointer; text-decoration: none; transition: all 0.18s; }
.qa-item:hover { background: var(--accent-bg); border-color: var(--accent); }
.qa-icon { width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 15px; flex-shrink: 0; }
.qa-title { font-size: 12px; font-weight: 600; color: var(--text); }
.qa-sub { font-size: 10px; color: var(--text3); margin-top: 1px; }

/* ── TABLE WRAP ── */
.table-wrap { background: var(--surface); border: 1px solid var(--bd); border-radius: var(--radius-lg); overflow: hidden; transition: background 0.25s; }
.tb-toolbar { display: flex; align-items: center; gap: 10px; padding: 12px 16px; border-bottom: 1px solid var(--bd); flex-wrap: wrap; }
.srch { display: flex; align-items: center; gap: 8px; flex: 1; min-width: 200px; background: var(--bg2); border: 1.5px solid var(--bd2); border-radius: 8px; padding: 8px 12px; }
.srch input { background: none; border: none; outline: none; font-size: 13px; color: var(--text); font-family: var(--font); width: 100%; }
.srch input::placeholder { color: var(--text3); }
.filter-pills { display: flex; gap: 5px; flex-wrap: wrap; }
.pill { padding: 5px 12px; border-radius: 20px; font-size: 11px; font-weight: 600; cursor: pointer; border: 1.5px solid var(--bd2); color: var(--text3); background: transparent; text-decoration: none; transition: all 0.18s; }
.pill:hover { border-color: var(--accent); color: var(--accent); }
.pill.active { background: var(--nav); color: #fff; border-color: var(--nav); }
table { width: 100%; border-collapse: collapse; }
thead th { padding: 10px 14px; text-align: left; font-size: 9px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: 1px; border-bottom: 1px solid var(--bd); background: var(--bg2); white-space: nowrap; }
tbody td { padding: 12px 14px; border-bottom: 1px solid var(--bd); color: var(--text2); vertical-align: middle; }
tbody tr:last-child td { border-bottom: none; }
tbody tr:hover td { background: var(--bg2); }
.cert-num { font-family: var(--mono); font-size: 10px; font-weight: 600; color: var(--accent); }
.holder-name { color: var(--text); font-weight: 600; font-size: 13px; }

/* ── BADGES ── */
.badge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 9px; border-radius: 20px; font-size: 10px; font-weight: 700; }
.badge::before { content: '●'; font-size: 7px; }
.badge.active { background: var(--green-bg); color: var(--green-text); }
.badge.expiring { background: var(--amber-bg); color: var(--amber-text); }
.badge.expired { background: var(--red-bg); color: var(--red-text); }
.badge.revoked { background: var(--bd2); color: var(--text3); }
.badge.badmin { background: var(--accent-bg); color: var(--accent-text); }
.badge.bstaff { background: var(--bg2); color: var(--text2); border: 1px solid var(--bd2); }
/* ── BRAND BADGES ── */
.badge-bw { display:inline-block; padding:5px 11px; border-radius:8px; background:#e8f0fa; color:#1a3a5c; border:1px solid #a0bcd8; font-size:11px; font-weight:600; letter-spacing:0.3px; }
.badge-adtco { display:inline-block; padding:5px 11px; border-radius:8px; background:#fde8e8; color:#7c1d1d; border:1px solid #e8a0a0; font-size:11px; font-weight:600; letter-spacing:0.3px; }

/* ── ROW ACTIONS ── */
.row-actions { display: flex; gap: 4px; flex-wrap: nowrap; }

/* ── PAGINATION ── */
.pg-bar { display: flex; align-items: center; justify-content: space-between; padding: 10px 16px; border-top: 1px solid var(--bd); background: var(--bg2); }
.pg-info { font-size: 11px; color: var(--text3); }
.pg-btns { display: flex; gap: 4px; }
.pg-btn { padding: 4px 11px; border-radius: 6px; font-size: 11px; font-weight: 600; border: 1px solid var(--bd2); background: var(--surface); cursor: pointer; color: var(--text2); font-family: var(--font); transition: all 0.15s; }
.pg-btn:hover { background: var(--nav); color: #fff; border-color: var(--nav); }

/* ── DRAWER ── */
.drawer-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 200; opacity: 0; pointer-events: none; transition: opacity 0.3s; }
.drawer-overlay.open { opacity: 1; pointer-events: all; }
.drawer { position: fixed; top: 0; right: 0; bottom: 0; width: 520px; background: var(--surface); z-index: 201; transform: translateX(100%); transition: transform 0.3s cubic-bezier(0.4,0,0.2,1); box-shadow: -20px 0 60px rgba(0,0,0,0.2); display: flex; flex-direction: column; }
.drawer.open { transform: translateX(0); }
.drawer-head { padding: 20px 24px; border-bottom: 1px solid var(--bd); display: flex; align-items: center; justify-content: space-between; flex-shrink: 0; }
.drawer-title { font-size: 16px; font-weight: 700; color: var(--text); }
.drawer-close { background: var(--bg2); border: none; width: 30px; height: 30px; border-radius: 7px; cursor: pointer; font-size: 15px; color: var(--text2); display: flex; align-items: center; justify-content: center; transition: all 0.18s; }
.drawer-close:hover { background: var(--red-bg); color: var(--red); }
.drawer-body { padding: 24px; overflow-y: auto; flex: 1; }
.drawer-foot { padding: 16px 24px; border-top: 1px solid var(--bd); display: flex; gap: 10px; flex-shrink: 0; }

/* ── FORM ── */
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.form-row.full { grid-template-columns: 1fr; }
.form-group { display: flex; flex-direction: column; }
.form-label { font-size: 10px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; }
.form-input, .form-select { padding: 9px 12px; border: 1.5px solid var(--bd2); border-radius: 8px; font-family: var(--font); font-size: 13px; color: var(--text); outline: none; background: var(--bg2); transition: all 0.2s; }
.form-input:focus, .form-select:focus { border-color: var(--accent); background: var(--surface); box-shadow: 0 0 0 3px var(--accent-bg); }
.form-section-label { font-size: 10px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: 1px; padding: 14px 0 10px; border-top: 1px solid var(--bd); margin-top: 4px; }
.expiry-preview { margin-top: 6px; font-size: 11px; color: var(--green); font-weight: 600; min-height: 16px; }

/* ── STAFF ── */
.staff-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(280px,1fr)); gap: 14px; }
.staff-card { background: var(--surface); border: 1px solid var(--bd); border-radius: var(--radius-lg); padding: 18px; display: flex; align-items: center; gap: 14px; transition: all 0.2s; }
.staff-card:hover { box-shadow: var(--shadow); transform: translateY(-1px); }
.staff-avatar { width: 42px; height: 42px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 15px; font-weight: 700; color: #fff; flex-shrink: 0; }
.staff-info { flex: 1; min-width: 0; }
.staff-name { font-weight: 600; color: var(--text); font-size: 13px; }
.staff-username { font-size: 11px; color: var(--text3); }
.staff-meta { display: flex; align-items: center; gap: 8px; margin-top: 5px; }
.staff-actions { display: flex; flex-direction: column; gap: 5px; flex-shrink: 0; }
.inactive-card { opacity: 0.5; }

/* ── RESPONSIVE ── */
@media (max-width: 1200px) { .stats-grid { grid-template-columns: repeat(2,1fr); } .charts-row { grid-template-columns: 1fr; } }
@media (max-width: 900px) { .sidebar { width: 60px; } .slogo-brand, .slogo-sub, .nav-sec, .ni span, .nbadge, .theme-label, .uname, .urole { display: none; } .ni { padding: 10px; justify-content: center; } .main { margin-left: 60px; } }
@media (max-width: 768px) { .drawer { width: 100%; } .topbar { padding: 0 16px; } .content { padding: 16px; } .stats-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .stats-grid { grid-template-columns: 1fr; } .row-actions { flex-wrap: wrap; } }
/* Responsive polish */
.table-wrap table { min-width: 800px; }
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
@media (max-width: 1440px) {
    :root { --sidebar-w: 200px; }
    .content { padding: 18px; }
    .topbar { padding: 0 18px; }
    .ni { padding: 9px 14px; font-size: 12px; }
    .stat-val { font-size: 22px; }
    .stat-label { font-size: 9px; }
    .card-title { font-size: 12px; }
    .tb-title { font-size: 15px; }
    .btn-sm { font-size: 10px; padding: 5px 10px; }
}
@media (max-width: 1366px) {
    :root { --sidebar-w: 190px; }
    .content { padding: 16px; }
    .charts-row { grid-template-columns: 1fr 220px; gap: 12px; }
    .stats-grid { gap: 10px; }
    .stat-card { padding: 14px; }
    .stat-val { font-size: 24px; }
    .table-wrap table { min-width: 700px; }
}
@media (max-width: 1280px) {
    :root { --sidebar-w: 190px; }
    .content { padding: 14px; }
    .stats-grid { gap: 10px; }
    .stat-card { padding: 16px; }
    .charts-row { grid-template-columns: 1fr; }
    .staff-grid { grid-template-columns: repeat(auto-fill,minmax(240px,1fr)); }
    .row-actions { gap: 3px; }
    .row-actions .btn { font-size: 10px; padding: 4px 8px; }
}
@media (max-width: 1024px) {
    .sidebar { width: 60px; }
    .slogo-brand, .slogo-sub, .nav-sec, .ni span, .nbadge, .theme-label, .uname, .urole { display: none; }
    .ni { padding: 10px; justify-content: center; }
    .main { margin-left: 60px; }
    .drawer { width: 100%; max-width: 480px; }
    .sp-panel { width: 280px; }
}
@media (max-width: 768px) {
    .sp-panel { width: 100%; }
    .form-row { grid-template-columns: 1fr; }
    .staff-grid { grid-template-columns: 1fr; }
    table { min-width: 700px; }
}

/* ═══════════════════════════════════════════════════════
   COLOUR SCHEMES  (ocean = default, violet, arctic)
   Each works with both .t-dark and .t-light
═══════════════════════════════════════════════════════ */
/* ── VIOLET DARK ── */
[data-scheme="violet"].t-dark {
    --bg:#111114; --bg2:#1A1A20; --bg3:#222228;
    --nav:#0C0C0F; --nav2:#1A1A20;
    --surface:#1A1A20; --surface2:#222228;
    --text:#FAFAFA; --text2:#A1A1AA; --text3:#52525B;
    --bd:rgba(255,255,255,0.06); --bd2:rgba(255,255,255,0.11);
    --accent:#818CF8; --accent-bg:rgba(129,140,248,0.12); --accent-text:#C7D2FE;
    --green:#22C55E; --green-bg:rgba(34,197,94,0.12); --green-text:#86EFAC;
    --amber:#F59E0B; --amber-bg:rgba(245,158,11,0.12); --amber-text:#FCD34D;
    --red:#F43F5E; --red-bg:rgba(244,63,94,0.12); --red-text:#FDA4AF;
    --shadow:0 2px 8px rgba(0,0,0,0.5); --login-bg:#060609;
}
/* ── VIOLET LIGHT ── */
[data-scheme="violet"].t-light {
    --bg:#F5F3FF; --bg2:#EDE9FE; --bg3:#DDD6FE;
    --nav:#1E1B4B; --nav2:#312E81;
    --surface:#FFFFFF; --surface2:#F5F3FF;
    --text:#1E1B4B; --text2:#4C1D95; --text3:#7C3AED;
    --bd:#DDD6FE; --bd2:#C4B5FD;
    --accent:#6366F1; --accent-bg:#EEF2FF; --accent-text:#4338CA;
    --green:#059669; --green-bg:#ECFDF5; --green-text:#065F46;
    --amber:#D97706; --amber-bg:#FFFBEB; --amber-text:#92400E;
    --red:#DC2626; --red-bg:#FEF2F2; --red-text:#991B1B;
    --shadow:0 1px 4px rgba(99,102,241,0.15); --login-bg:#1E1B4B;
}
/* ── ARCTIC DARK ── */
[data-scheme="arctic"].t-dark {
    --bg:#0B1628; --bg2:#162038; --bg3:#1E2E4A;
    --nav:#050E1C; --nav2:#162038;
    --surface:#162038; --surface2:#1A2744;
    --text:#E2F0FF; --text2:#7BA8D4; --text3:#3D6A96;
    --bd:rgba(56,189,248,0.08); --bd2:rgba(56,189,248,0.16);
    --accent:#38BDF8; --accent-bg:rgba(56,189,248,0.12); --accent-text:#7DD3FC;
    --green:#10B981; --green-bg:rgba(16,185,129,0.12); --green-text:#6EE7B7;
    --amber:#F59E0B; --amber-bg:rgba(245,158,11,0.12); --amber-text:#FCD34D;
    --red:#F43F5E; --red-bg:rgba(244,63,94,0.12); --red-text:#FDA4AF;
    --shadow:0 2px 10px rgba(56,189,248,0.1); --login-bg:#020810;
}
/* ── ARCTIC LIGHT ── */
[data-scheme="arctic"].t-light {
    --bg:#F0F9FF; --bg2:#E0F2FE; --bg3:#BAE6FD;
    --nav:#0C4A6E; --nav2:#075985;
    --surface:#FFFFFF; --surface2:#F0F9FF;
    --text:#0C4A6E; --text2:#0369A1; --text3:#0EA5E9;
    --bd:#BAE6FD; --bd2:#7DD3FC;
    --accent:#0284C7; --accent-bg:#E0F2FE; --accent-text:#0C4A6E;
    --green:#059669; --green-bg:#ECFDF5; --green-text:#065F46;
    --amber:#D97706; --amber-bg:#FFFBEB; --amber-text:#92400E;
    --red:#DC2626; --red-bg:#FEF2F2; --red-text:#991B1B;
    --shadow:0 1px 4px rgba(2,132,199,0.12); --login-bg:#0C4A6E;
}

/* ── MIDNIGHT ── */
[data-scheme="midnight"].t-dark {
    --accent:#8B5CF6;--accent-bg:rgba(139,92,246,0.12);--accent-text:#C4B5FD;
    --bg:#0D0B1E;--bg2:#14112B;--bg3:#1C1838;--nav:#080616;--surface:#14112B;--surface2:#1C1838;
    --text:#EDE9FF;--text2:#9D99C8;--text3:#5B5887;--bd:rgba(139,92,246,0.1);--bd2:rgba(139,92,246,0.2);
    --green:#10B981;--green-bg:rgba(16,185,129,0.12);--green-text:#6EE7B7;
    --amber:#F59E0B;--amber-bg:rgba(245,158,11,0.12);--amber-text:#FCD34D;
    --red:#F43F5E;--red-bg:rgba(244,63,94,0.12);--red-text:#FDA4AF;--shadow:0 2px 12px rgba(139,92,246,0.15);--login-bg:#050310;
}
[data-scheme="midnight"].t-light {
    --accent:#6D28D9;--accent-bg:#EEF2FF;--accent-text:#3730A3;
    --bg:#F5F3FF;--bg2:#EDE9FE;--bg3:#DDD6FE;--nav:#1E1B4B;--surface:#FFFFFF;--surface2:#F5F3FF;
    --text:#1E1B4B;--text2:#4C1D95;--text3:#7C3AED;--bd:#DDD6FE;--bd2:#C4B5FD;
    --green:#059669;--green-bg:#ECFDF5;--green-text:#065F46;--amber:#D97706;--amber-bg:#FFFBEB;--amber-text:#92400E;
    --red:#DC2626;--red-bg:#FEF2F2;--red-text:#991B1B;--shadow:0 1px 4px rgba(109,40,217,0.15);--login-bg:#1E1B4B;
}
/* ── ROSE ── */
[data-scheme="rose"].t-dark {
    --accent:#FB7185;--accent-bg:rgba(251,113,133,0.12);--accent-text:#FECDD3;
    --bg:#150A0D;--bg2:#1F1215;--bg3:#2A181C;--nav:#0D060A;--surface:#1F1215;--surface2:#2A181C;
    --text:#FFF0F2;--text2:#C99BA2;--text3:#7A5560;--bd:rgba(244,63,94,0.1);--bd2:rgba(244,63,94,0.2);
    --green:#10B981;--green-bg:rgba(16,185,129,0.12);--green-text:#6EE7B7;
    --amber:#F59E0B;--amber-bg:rgba(245,158,11,0.12);--amber-text:#FCD34D;
    --red:#F43F5E;--red-bg:rgba(244,63,94,0.12);--red-text:#FDA4AF;--shadow:0 2px 12px rgba(251,113,133,0.12);--login-bg:#0A0306;
}
[data-scheme="rose"].t-light {
    --accent:#E11D48;--accent-bg:#FFF1F2;--accent-text:#881337;
    --bg:#FFF1F2;--bg2:#FFE4E6;--bg3:#FECDD3;--nav:#881337;--surface:#FFFFFF;--surface2:#FFF1F2;
    --text:#881337;--text2:#BE123C;--text3:#E11D48;--bd:#FECDD3;--bd2:#FDA4AF;
    --green:#059669;--green-bg:#ECFDF5;--green-text:#065F46;--amber:#D97706;--amber-bg:#FFFBEB;--amber-text:#92400E;
    --red:#DC2626;--red-bg:#FEF2F2;--red-text:#991B1B;--shadow:0 1px 4px rgba(225,29,72,0.12);--login-bg:#881337;
}
/* ── OLIVE ── */
[data-scheme="olive"].t-dark {
    --accent:#84CC16;--accent-bg:rgba(132,204,22,0.12);--accent-text:#D9F99D;
    --bg:#0A0F08;--bg2:#111A0E;--bg3:#182415;--nav:#060B05;--surface:#111A0E;--surface2:#182415;
    --text:#EDFCE8;--text2:#8BB087;--text3:#4F7248;--bd:rgba(132,204,22,0.08);--bd2:rgba(132,204,22,0.16);
    --green:#22C55E;--green-bg:rgba(34,197,94,0.12);--green-text:#86EFAC;
    --amber:#F59E0B;--amber-bg:rgba(245,158,11,0.12);--amber-text:#FCD34D;
    --red:#F43F5E;--red-bg:rgba(244,63,94,0.12);--red-text:#FDA4AF;--shadow:0 2px 12px rgba(132,204,22,0.08);--login-bg:#040704;
}
[data-scheme="olive"].t-light {
    --accent:#4D7C0F;--accent-bg:#F7FEE7;--accent-text:#1A2E05;
    --bg:#F7FEE7;--bg2:#ECFCCB;--bg3:#D9F99D;--nav:#1A2E05;--surface:#FFFFFF;--surface2:#F7FEE7;
    --text:#1A2E05;--text2:#3F6212;--text3:#4D7C0F;--bd:#D9F99D;--bd2:#BEF264;
    --green:#15803D;--green-bg:#DCFCE7;--green-text:#14532D;--amber:#D97706;--amber-bg:#FFFBEB;--amber-text:#92400E;
    --red:#DC2626;--red-bg:#FEF2F2;--red-text:#991B1B;--shadow:0 1px 4px rgba(77,124,15,0.12);--login-bg:#1A2E05;
}
/* ── AMBER ── */
[data-scheme="amber"].t-dark {
    --accent:#F59E0B;--accent-bg:rgba(245,158,11,0.12);--accent-text:#FDE68A;
    --bg:#110D00;--bg2:#1C1500;--bg3:#261D00;--nav:#0A0800;--surface:#1C1500;--surface2:#261D00;
    --text:#FFFBEB;--text2:#C8A84B;--text3:#78621A;--bd:rgba(245,158,11,0.1);--bd2:rgba(245,158,11,0.2);
    --green:#10B981;--green-bg:rgba(16,185,129,0.12);--green-text:#6EE7B7;
    --amber:#F59E0B;--amber-bg:rgba(245,158,11,0.12);--amber-text:#FCD34D;
    --red:#F43F5E;--red-bg:rgba(244,63,94,0.12);--red-text:#FDA4AF;--shadow:0 2px 12px rgba(245,158,11,0.1);--login-bg:#080600;
}
[data-scheme="amber"].t-light {
    --accent:#B45309;--accent-bg:#FFFBEB;--accent-text:#451A03;
    --bg:#FFFBEB;--bg2:#FEF3C7;--bg3:#FDE68A;--nav:#451A03;--surface:#FFFFFF;--surface2:#FFFBEB;
    --text:#451A03;--text2:#92400E;--text3:#B45309;--bd:#FDE68A;--bd2:#FCD34D;
    --green:#059669;--green-bg:#ECFDF5;--green-text:#065F46;--amber:#D97706;--amber-bg:#FFFBEB;--amber-text:#92400E;
    --red:#DC2626;--red-bg:#FEF2F2;--red-text:#991B1B;--shadow:0 1px 4px rgba(180,83,9,0.12);--login-bg:#451A03;
}

/* ═══════════════════════════════════════════════════════
   BOX UI  — Bento grid layout, sidebar unchanged
═══════════════════════════════════════════════════════ */
[data-ui="box"] .stats-grid {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
[data-ui="box"] .stat-card {
    border-radius: 20px;
    padding: 22px 24px;
    border-top: none !important;
    border-left: 4px solid var(--accent);
}
[data-ui="box"] .stat-card.c1 { border-left-color: var(--accent) !important; }
[data-ui="box"] .stat-card.c2 { border-left-color: var(--green) !important; }
[data-ui="box"] .stat-card.c3 { border-left-color: var(--amber) !important; }
[data-ui="box"] .stat-card.c4 { border-left-color: var(--red) !important; }
[data-ui="box"] .stat-card::after { display: none; }
[data-ui="box"] .stat-val { font-size: 34px; }
[data-ui="box"] .card, [data-ui="box"] .table-wrap { border-radius: 20px; }
[data-ui="box"] .btn { border-radius: 12px; }
[data-ui="box"] .badge { border-radius: 8px; }
[data-ui="box"] .stat-card:hover { transform: translateY(-3px) scale(1.01); }

/* ═══════════════════════════════════════════════════════
   GLASS UI  — Frosted glass macOS style
═══════════════════════════════════════════════════════ */
/* Glass UI - scheme-aware backgrounds, no colour bleeding */
[data-ui="glass"] .main::before {
    content: '';
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    opacity: var(--zl-grad-opacity, 0);
    transition: opacity 0.4s ease;
    background:
        radial-gradient(ellipse 80% 70% at 15% 25%, var(--zl-g1, rgba(6,182,212,0.35)), transparent 60%),
        radial-gradient(ellipse 70% 60% at 85% 20%, var(--zl-g2, rgba(139,92,246,0.28)), transparent 55%),
        radial-gradient(ellipse 90% 80% at 50% 85%, var(--zl-g3, rgba(59,130,246,0.22)), transparent 60%),
        radial-gradient(ellipse 60% 50% at 78% 65%, var(--zl-g4, rgba(16,185,129,0.18)), transparent 50%);
}
[data-ui="glass"].t-dark  { background: #0A1628 !important; background-attachment: fixed !important; }
[data-ui="glass"].t-light { background: #E8EEF8 !important; background-attachment: fixed !important; }
[data-ui="glass"][data-scheme="midnight"].t-dark  { background: #0D0B1E !important; }
[data-ui="glass"][data-scheme="midnight"].t-light { background: #EDE9FE !important; }
[data-ui="glass"][data-scheme="rose"].t-dark      { background: #150A0D !important; }
[data-ui="glass"][data-scheme="rose"].t-light     { background: #FFF0F2 !important; }
[data-ui="glass"][data-scheme="olive"].t-dark     { background: #0A0F08 !important; }
[data-ui="glass"][data-scheme="olive"].t-light    { background: #F0F9E8 !important; }
[data-ui="glass"][data-scheme="amber"].t-dark     { background: #110D00 !important; }
[data-ui="glass"][data-scheme="amber"].t-light    { background: #FFFBEB !important; }
[data-ui="glass"][data-scheme="arctic"].t-dark    { background: #0B1628 !important; }
[data-ui="glass"][data-scheme="arctic"].t-light   { background: #EFF8FF !important; }
/* Glass gradient blob colors per scheme */
[data-ui="glass"].t-dark  { --zl-g1:rgba(6,182,212,0.35); --zl-g2:rgba(139,92,246,0.28); --zl-g3:rgba(59,130,246,0.22); --zl-g4:rgba(16,185,129,0.18); }
[data-ui="glass"].t-light { --zl-g1:rgba(6,182,212,0.40); --zl-g2:rgba(139,92,246,0.32); --zl-g3:rgba(99,102,241,0.28); --zl-g4:rgba(16,185,129,0.22); }
[data-ui="glass"][data-scheme="midnight"].t-dark  { --zl-g1:rgba(139,92,246,0.40); --zl-g2:rgba(99,102,241,0.30); --zl-g3:rgba(168,85,247,0.22); --zl-g4:rgba(79,70,229,0.18); }
[data-ui="glass"][data-scheme="midnight"].t-light { --zl-g1:rgba(139,92,246,0.40); --zl-g2:rgba(99,102,241,0.32); --zl-g3:rgba(168,85,247,0.26); --zl-g4:rgba(192,132,252,0.20); }
[data-ui="glass"][data-scheme="rose"].t-dark      { --zl-g1:rgba(251,113,133,0.35); --zl-g2:rgba(244,63,94,0.25); --zl-g3:rgba(236,72,153,0.20); --zl-g4:rgba(190,18,60,0.15); }
[data-ui="glass"][data-scheme="rose"].t-light     { --zl-g1:rgba(251,113,133,0.38); --zl-g2:rgba(244,63,94,0.30); --zl-g3:rgba(236,72,153,0.24); --zl-g4:rgba(253,164,175,0.18); }
[data-ui="glass"][data-scheme="olive"].t-dark     { --zl-g1:rgba(132,204,22,0.30); --zl-g2:rgba(34,197,94,0.25); --zl-g3:rgba(16,185,129,0.20); --zl-g4:rgba(74,222,128,0.15); }
[data-ui="glass"][data-scheme="olive"].t-light    { --zl-g1:rgba(132,204,22,0.35); --zl-g2:rgba(34,197,94,0.28); --zl-g3:rgba(22,163,74,0.22); --zl-g4:rgba(74,222,128,0.18); }
[data-ui="glass"][data-scheme="amber"].t-dark     { --zl-g1:rgba(245,158,11,0.35); --zl-g2:rgba(234,88,12,0.25); --zl-g3:rgba(251,191,36,0.20); --zl-g4:rgba(217,119,6,0.15); }
[data-ui="glass"][data-scheme="amber"].t-light    { --zl-g1:rgba(245,158,11,0.38); --zl-g2:rgba(234,88,12,0.28); --zl-g3:rgba(251,191,36,0.22); --zl-g4:rgba(252,211,77,0.18); }
[data-ui="glass"][data-scheme="arctic"].t-dark    { --zl-g1:rgba(56,189,248,0.35); --zl-g2:rgba(14,165,233,0.28); --zl-g3:rgba(2,132,199,0.22); --zl-g4:rgba(59,130,246,0.18); }
[data-ui="glass"][data-scheme="arctic"].t-light   { --zl-g1:rgba(56,189,248,0.38); --zl-g2:rgba(14,165,233,0.30); --zl-g3:rgba(2,132,199,0.24); --zl-g4:rgba(125,211,252,0.18); }
[data-ui="glass"].t-dark .stat-card,
[data-ui="glass"].t-dark .card,
[data-ui="glass"].t-dark .table-wrap,
[data-ui="glass"].t-dark .topbar {
    background: var(--zl-card-bg-d, rgba(255,255,255,0.05)) !important;
    border: 1px solid var(--zl-card-bd-d, rgba(255,255,255,0.10)) !important;
    backdrop-filter: var(--zl-blur, blur(20px) saturate(180%));
    -webkit-backdrop-filter: var(--zl-blur, blur(20px) saturate(180%));
    box-shadow: var(--zl-card-sh, 0 4px 24px rgba(0,0,0,0.25)), inset 0 1px 0 rgba(255,255,255,0.08) !important;
    transition: background 0.3s, border-color 0.3s, box-shadow 0.3s;
}
[data-ui="glass"].t-light .stat-card,
[data-ui="glass"].t-light .card,
[data-ui="glass"].t-light .table-wrap,
[data-ui="glass"].t-light .topbar {
    background: var(--zl-card-bg-l, rgba(255,255,255,0.72)) !important;
    border: 1px solid var(--zl-card-bd-l, rgba(255,255,255,0.85)) !important;
    backdrop-filter: var(--zl-blur, blur(20px) saturate(180%));
    -webkit-backdrop-filter: var(--zl-blur, blur(20px) saturate(180%));
    box-shadow: var(--zl-card-sh, 0 2px 16px rgba(0,0,0,0.08)), inset 0 1px 0 rgba(255,255,255,0.5) !important;
    color: #0F172A !important;
    transition: background 0.3s, border-color 0.3s, box-shadow 0.3s;
}
[data-ui="glass"].t-light .stat-val,
[data-ui="glass"].t-light .stat-label,
[data-ui="glass"].t-light .card-title,
[data-ui="glass"].t-light .tb-title,
[data-ui="glass"].t-light .holder-name,
[data-ui="glass"].t-light .qa-title,
[data-ui="glass"].t-light tbody td,
[data-ui="glass"].t-light thead th { color: inherit !important; }
/* Glass sidebar - tinted by scheme */
[data-ui="glass"].t-dark .sidebar {
    background: var(--zl-sb-bg-d, rgba(6,13,24,0.6)) !important;
    backdrop-filter: var(--zl-blur, blur(28px) saturate(160%));
    -webkit-backdrop-filter: var(--zl-blur, blur(28px) saturate(160%));
    border-right: 1px solid var(--zl-sb-bd-d, rgba(255,255,255,0.07)) !important;
    transition: background 0.3s, border-color 0.3s;
}
[data-ui="glass"][data-scheme="midnight"].t-dark .sidebar { background: rgba(10,6,25,0.65) !important; }
[data-ui="glass"][data-scheme="rose"].t-dark .sidebar     { background: rgba(18,5,10,0.65) !important; }
[data-ui="glass"][data-scheme="olive"].t-dark .sidebar    { background: rgba(5,10,4,0.65) !important; }
[data-ui="glass"][data-scheme="amber"].t-dark .sidebar    { background: rgba(14,10,0,0.65) !important; }
[data-ui="glass"][data-scheme="arctic"].t-dark .sidebar   { background: rgba(4,10,22,0.65) !important; }
[data-ui="glass"].t-light .sidebar {
    background: var(--zl-sb-bg-l, rgba(255,255,255,0.55)) !important;
    backdrop-filter: var(--zl-blur, blur(28px) saturate(160%));
    -webkit-backdrop-filter: var(--zl-blur, blur(28px) saturate(160%));
    border-right: 1px solid var(--zl-sb-bd-l, rgba(255,255,255,0.9)) !important;
    transition: background 0.3s, border-color 0.3s;
}
[data-ui="glass"][data-scheme="midnight"].t-light .sidebar { background: rgba(235,229,255,0.6) !important; }
[data-ui="glass"][data-scheme="rose"].t-light .sidebar     { background: rgba(255,235,238,0.6) !important; }
[data-ui="glass"][data-scheme="olive"].t-light .sidebar    { background: rgba(235,252,220,0.6) !important; }
[data-ui="glass"][data-scheme="amber"].t-light .sidebar    { background: rgba(255,250,235,0.6) !important; }
[data-ui="glass"][data-scheme="arctic"].t-light .sidebar   { background: rgba(230,245,255,0.6) !important; }
/* Sidebar always readable - nav text forced to high contrast */
.sidebar .slogo-brand, .sidebar .nav-sec,
.sidebar .ni, .sidebar .uname, .sidebar .urole,
.sidebar .theme-label { color: rgba(240,244,248,0.9) !important; }
.sidebar .ni { color: rgba(180,200,220,0.75) !important; }
.sidebar .ni.active { color: #fff !important; background: rgba(255,255,255,0.1) !important; }
.sidebar .ni:hover:not(.active) { color: #fff !important; background: rgba(255,255,255,0.08) !important; }
.sidebar .nav-sec { color: rgba(255,255,255,0.3) !important; }
.t-light .sidebar .slogo-brand { color: rgba(240,244,248,0.95) !important; }
[data-ui="glass"].t-light .slogo-brand { color: #0F172A !important; }
[data-ui="glass"].t-light .ni { color: rgba(15,23,42,0.55) !important; }
[data-ui="glass"].t-light .ni.active { color: var(--accent) !important; }
[data-ui="glass"].t-light .ni:hover { color: rgba(15,23,42,0.9) !important; background: rgba(0,0,0,0.06) !important; }
[data-ui="glass"].t-light .uname { color: #0F172A !important; }
[data-ui="glass"].t-light .nav-sec { color: rgba(15,23,42,0.3) !important; }
[data-ui="glass"].t-light .theme-label { color: rgba(15,23,42,0.5) !important; }
[data-ui="glass"] .alert-banner { backdrop-filter: blur(10px); }
/* Transparent sidebar -- now controlled via CSS vars from glass slider JS */
[data-ui="glass"].t-dark .stat-card::after { display: none; }
[data-ui="glass"].t-light .stat-card::after { display: none; }
[data-ui="glass"] .stat-card { border-radius: 16px !important; }

/* Glass -- table rows */
[data-ui="glass"].t-dark thead th {
    background: var(--zl-th-bg, var(--bg2)) !important;
    backdrop-filter: blur(8px);
    transition: background 0.3s;
}
[data-ui="glass"].t-dark tbody tr {
    background: transparent !important;
    transition: background 0.2s;
}
[data-ui="glass"].t-dark tbody tr:nth-child(even) td {
    background: var(--zl-tr-alt-d, transparent) !important;
}
[data-ui="glass"].t-dark tbody tr:hover td {
    background: var(--zl-tr-hov-d, var(--bg2)) !important;
}
[data-ui="glass"].t-light thead th {
    background: var(--zl-th-bg-l, var(--bg2)) !important;
    backdrop-filter: blur(8px);
    transition: background 0.3s;
}
[data-ui="glass"].t-light tbody tr {
    background: transparent !important;
    transition: background 0.2s;
}
[data-ui="glass"].t-light tbody tr:nth-child(even) td {
    background: var(--zl-tr-alt-l, transparent) !important;
}
[data-ui="glass"].t-light tbody tr:hover td {
    background: var(--zl-tr-hov-l, var(--bg2)) !important;
}

/* Glass -- search bar */
[data-ui="glass"].t-dark .srch {
    background: var(--zl-srch-bg-d, var(--bg2)) !important;
    border-color: var(--zl-srch-bd-d, var(--bd2)) !important;
    backdrop-filter: blur(12px);
    transition: background 0.3s, border-color 0.3s;
}
[data-ui="glass"].t-light .srch {
    background: var(--zl-srch-bg-l, var(--bg2)) !important;
    border-color: var(--zl-srch-bd-l, var(--bd2)) !important;
    backdrop-filter: blur(12px);
    transition: background 0.3s, border-color 0.3s;
}

/* Glass -- form inputs */
[data-ui="glass"].t-dark .form-input,
[data-ui="glass"].t-dark .form-select {
    background: var(--zl-input-bg-d, var(--bg2)) !important;
    border-color: var(--zl-input-bd-d, var(--bd2)) !important;
    backdrop-filter: blur(8px);
    transition: background 0.3s, border-color 0.3s;
}
[data-ui="glass"].t-light .form-input,
[data-ui="glass"].t-light .form-select {
    background: var(--zl-input-bg-l, var(--bg2)) !important;
    border-color: var(--zl-input-bd-l, var(--bd2)) !important;
    backdrop-filter: blur(8px);
    transition: background 0.3s, border-color 0.3s;
}

/* Glass -- drawers and modals */
[data-ui="glass"].t-dark .drawer {
    background: var(--zl-drawer-bg-d, var(--surface)) !important;
    backdrop-filter: blur(24px) saturate(150%);
    -webkit-backdrop-filter: blur(24px) saturate(150%);
    border-left: 1px solid rgba(255,255,255,0.08);
}
[data-ui="glass"].t-light .drawer {
    background: var(--zl-drawer-bg-l, var(--surface)) !important;
    backdrop-filter: blur(24px) saturate(150%);
    -webkit-backdrop-filter: blur(24px) saturate(150%);
    border-left: 1px solid rgba(255,255,255,0.3);
}
[data-ui="glass"] .drawer-overlay.open {
    background: rgba(0,0,0,var(--zl-overlay-op, 0.5)) !important;
    backdrop-filter: blur(var(--zl-overlay-blur, 0px));
}

/* Glass -- settings panel */
[data-ui="glass"].t-dark .sp-panel {
    background: var(--zl-sp-bg-d, var(--surface)) !important;
    backdrop-filter: blur(28px) saturate(150%);
    -webkit-backdrop-filter: blur(28px) saturate(150%);
    border-left: 1px solid rgba(255,255,255,0.08);
}
[data-ui="glass"].t-light .sp-panel {
    background: var(--zl-sp-bg-l, var(--surface)) !important;
    backdrop-filter: blur(28px) saturate(150%);
    -webkit-backdrop-filter: blur(28px) saturate(150%);
    border-left: 1px solid rgba(255,255,255,0.3);
}
[data-ui="glass"] .sp-overlay.open {
    background: rgba(0,0,0,var(--zl-overlay-op, 0.5)) !important;
    backdrop-filter: blur(var(--zl-overlay-blur, 0px));
}

/* Glass -- filter pills */
[data-ui="glass"].t-dark .pill {
    backdrop-filter: blur(8px);
    transition: background 0.2s, border-color 0.2s;
}
[data-ui="glass"].t-light .pill {
    backdrop-filter: blur(8px);
    transition: background 0.2s, border-color 0.2s;
}

/* ═══════════════════════════════════════════════════════
   SETTINGS PANEL
═══════════════════════════════════════════════════════ */
.sp-overlay { position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:400;opacity:0;pointer-events:none;transition:opacity 0.25s; }
.sp-overlay.open { opacity:1;pointer-events:all; }
.sp-panel { position:fixed;top:0;right:0;bottom:0;width:300px;background:var(--surface);z-index:401;transform:translateX(100%);transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);display:flex;flex-direction:column;border-left:1px solid var(--bd); }
.sp-panel.open { transform:translateX(0); }
.sp-head { padding:18px 20px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;flex-shrink:0; }
.sp-title { font-size:14px;font-weight:700;color:var(--text); }
.sp-body { padding:18px 20px;overflow-y:auto;flex:1; }
.sp-sec { font-size:9px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1.5px;margin:16px 0 8px; }
.sp-sec:first-child { margin-top:0; }
/* UI layout cards */
.ui-cards { display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:4px; }
.ui-card { border-radius:10px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:border-color .15s; }
.ui-card.sel { border-color:var(--accent); }
.ui-prev { height:44px;background:var(--bg2);position:relative; }
/* classic preview */
.ui-classic .ui-prev::before { content:'';position:absolute;left:0;top:0;bottom:0;width:30%;background:var(--nav); }
.ui-classic .ui-prev::after { content:'';position:absolute;left:34%;right:6%;top:10px;height:5px;background:var(--accent);border-radius:2px;opacity:.8; }
/* box preview */
.ui-box .ui-prev { padding:5px 5px 5px 36%; }
.ui-box .ui-prev::before { content:'';position:absolute;left:0;top:0;bottom:0;width:30%;background:var(--nav); }
.ui-box .ui-prev { display:grid;grid-template-columns:1fr 1fr;gap:3px;padding-left:34%;padding-right:4px;padding-top:5px;padding-bottom:5px; }
.ui-box .bp { background:var(--surface);border-radius:4px; }
/* glass preview */
.ui-glass .ui-prev { background:linear-gradient(135deg,rgba(99,102,241,0.25),rgba(16,185,129,0.2)); }
.ui-glass .ui-prev::before { content:'';position:absolute;left:0;top:0;bottom:0;width:30%;background:rgba(0,0,0,0.3); }
.ui-glass .ui-prev::after { content:'';position:absolute;left:34%;right:6%;top:8px;height:28px;background:rgba(255,255,255,0.1);border-radius:6px;border:1px solid rgba(255,255,255,0.2); }
.ui-name { font-size:9px;text-align:center;padding:5px 0;color:var(--text3);font-weight:600;background:var(--bg2); }
.ui-card.sel .ui-name { color:var(--accent); }
/* Colour swatches */
.swatches { display:flex;gap:8px; }
.sw { width:30px;height:30px;border-radius:9px;cursor:pointer;border:2.5px solid transparent;transition:all .15s;position:relative;flex-shrink:0; }
.sw.sel { border-color:#fff;box-shadow:0 0 0 1px var(--accent); }
.sw-ocean    { background:linear-gradient(135deg,#060D18,#06B6D4); }
.sw-midnight { background:linear-gradient(135deg,#0D0B1E,#8B5CF6); }
.sw-rose     { background:linear-gradient(135deg,#150A0D,#FB7185); }
.sw-olive    { background:linear-gradient(135deg,#0A0F08,#84CC16); }
.sw-slate    { background:linear-gradient(135deg,#0F1117,#94A3B8); }
.sw-amber    { background:linear-gradient(135deg,#110D00,#F59E0B); }
.sw-arctic   { background:linear-gradient(135deg,#0B1628,#38BDF8); }
/* Settings toggles */
.sp-toggle { display:flex;align-items:center;justify-content:space-between;padding:9px 12px;background:var(--bg2);border-radius:9px;border:1px solid var(--bd);margin-bottom:7px;cursor:pointer;transition:background .15s; }
.sp-toggle:hover { background:var(--bg3); }
.sp-tl { font-size:12px;font-weight:600;color:var(--text); }
.sp-ts { font-size:10px;color:var(--text3);margin-top:1px; }
.mini-t { width:32px;height:17px;border-radius:20px;position:relative;flex-shrink:0;transition:background .2s; }
.mini-t .mth { width:13px;height:13px;border-radius:50%;background:#fff;position:absolute;top:2px;transition:left .2s; }
.mini-t.on { background:var(--accent); }
.mini-t.on .mth { left:17px; }
.mini-t.off { background:#1E3A5F; }
.mini-t.off .mth { left:2px; }
/* Density */
.den-row { display:flex;gap:5px; }
.den-opt { flex:1;padding:7px 4px;background:var(--bg2);border:1px solid var(--bd);border-radius:8px;cursor:pointer;text-align:center;font-size:10px;font-weight:600;color:var(--text3);transition:all .15s; }
.den-opt:hover { background:var(--bg3); }
.den-opt.sel { background:var(--accent-bg);border-color:var(--accent);color:var(--accent-text); }
/* About */
.sp-about { margin-top:4px;padding:14px;background:var(--bg2);border-radius:10px;border:1px solid var(--bd); }
.sp-about-row { display:flex;justify-content:space-between;align-items:center;padding:3px 0;font-size:11px;color:var(--text2); }
.sp-about-row:not(:last-child) { border-bottom:1px solid var(--bd); padding-bottom:6px; margin-bottom:6px; }
.sp-about-val { color:var(--text3);font-size:10px;font-family:var(--mono); }
/* Chart type buttons */
.ct-btns { display:flex;gap:3px; }
.ct-btn { padding:3px 8px;border-radius:5px;font-size:9px;font-weight:700;cursor:pointer;border:1px solid var(--bd2);color:var(--text3);background:transparent;font-family:var(--font);transition:all .15s; }
.ct-btn.active { background:var(--accent);color:#fff;border-color:var(--accent); }
.ct-btn:hover:not(.active) { border-color:var(--accent);color:var(--accent); }
/* Density modifiers */
body.den-compact tbody td { padding:7px 14px !important; }
body.den-dense tbody td { padding:4px 14px !important;font-size:11px; }
body.den-compact .stat-card { padding:12px 16px; }
body.den-compact .stat-val { font-size:24px; }
/* Settings nav item */
.bulk-bar { display:none;align-items:center;gap:10px;padding:10px 16px;background:var(--accent-bg);border-bottom:1px solid var(--accent);animation:slideDown .2s }
.bulk-bar.show { display:flex; }
@keyframes slideDown { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }
.pd-wrap { position: relative; display: inline-block; }
.btn-pd { background: var(--green-bg); color: var(--green-text); border: 1px solid var(--green); white-space: nowrap; }
.btn-pd:hover { opacity: 0.85; }
.pd-menu { position: fixed; z-index: 9999; display: none; background: var(--surface); border: 1px solid var(--bd2); border-radius: 10px; padding: 6px; min-width: 270px; box-shadow: 0 8px 28px rgba(0,0,0,0.35); }
.pd-menu.show { display: block; }
.pd-section-label { font-size: 10px; font-weight: 700; padding: 4px 6px 5px; text-transform: uppercase; letter-spacing: .07em; }
.pd-bw .pd-section-label { color: #3b82f6; }
.pd-ad .pd-section-label { color: #ef4444; }
.pd-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 3px; margin-bottom: 3px; }
.pd-btn { padding: 5px 4px; border-radius: 6px; font-size: 10px; font-weight: 600; cursor: pointer; border: 1px solid; text-align: center; line-height: 1.4; background: transparent; font-family: inherit; }
.pd-btn small { font-weight: 400; font-size: 9px; display: block; opacity: 0.8; }
.pd-btn.bw { color: #3b82f6; border-color: rgba(59,130,246,0.35); }
.pd-btn.bw:hover { background: rgba(59,130,246,0.1); }
.pd-btn.ad { color: #ef4444; border-color: rgba(239,68,68,0.35); }
.pd-btn.ad:hover { background: rgba(239,68,68,0.1); }
.pd-divider { height: 0.5px; background: var(--bd); margin: 4px 2px; }
.ni-settings { background:rgba(99,102,241,0.08) !important;color:rgba(99,102,241,0.8) !important;border:1px solid rgba(99,102,241,0.15); }
.ni-settings:hover { background:rgba(99,102,241,0.15) !important;color:#818CF8 !important; }
.ni-settings svg { stroke:#818CF8 !important; }
