/* ═══════════════════════════════════════════════════════════
   HyperWiFi — app.css  (Phase 2 Full Stylesheet)
═══════════════════════════════════════════════════════════ */

/* Design Tokens */
:root {
  --font-display:'Exo 2',sans-serif; --font-body:'DM Sans',sans-serif; --font-mono:'JetBrains Mono',monospace;
  --a1:#1A6FFF; --a2:#7C3FF0; --a3:#E83A9C;
  --grad:linear-gradient(135deg,#1A6FFF 0%,#7C3FF0 50%,#E83A9C 100%);
  --grad-h:linear-gradient(90deg,#1A6FFF,#7C3FF0);
  --glow:rgba(26,111,255,.25);
  --success:#10B981; --warning:#F59E0B; --danger:#EF4444; --info:#3B82F6;
}
[data-color="cobalt"]  {--a1:#0EA5E9;--a2:#0284C7;--a3:#06B6D4;--grad:linear-gradient(135deg,#0EA5E9,#0284C7);--glow:rgba(14,165,233,.25);}
[data-color="emerald"] {--a1:#10B981;--a2:#059669;--a3:#34D399;--grad:linear-gradient(135deg,#10B981,#059669);--glow:rgba(16,185,129,.25);}
[data-color="violet"]  {--a1:#8B5CF6;--a2:#7C3AED;--a3:#A78BFA;--grad:linear-gradient(135deg,#8B5CF6,#7C3AED);--glow:rgba(139,92,246,.25);}
[data-color="amber"]   {--a1:#F59E0B;--a2:#D97706;--a3:#FCD34D;--grad:linear-gradient(135deg,#F59E0B,#D97706);--glow:rgba(245,158,11,.25);}
[data-color="teal"]    {--a1:#14B8A6;--a2:#0D9488;--a3:#2DD4BF;--grad:linear-gradient(135deg,#14B8A6,#0D9488);--glow:rgba(20,184,166,.25);}
[data-color="rose"]    {--a1:#F43F5E;--a2:#E11D48;--a3:#FB7185;--grad:linear-gradient(135deg,#F43F5E,#E11D48);--glow:rgba(244,63,94,.25);}

[data-theme="dark"] {
  --bg:#07090F; --bg-s:#0C1018; --bg-c:#111520; --bg-c2:#161B28; --bg-in:#1C2235;
  --border:rgba(255,255,255,.06); --border-a:rgba(26,111,255,.3);
  --text:#E8EEF8; --text-s:#8897B8; --text-m:#3D4F6E;
  --shadow:0 8px 32px rgba(0,0,0,.6); --sidebar-bg:#090C15; --topbar-bg:rgba(9,12,21,.92);
}
[data-theme="light"] {
  --bg:#F0F4FC; --bg-s:#E4EBF8; --bg-c:#FFFFFF; --bg-c2:#F6F9FF; --bg-in:#EBF0FA;
  --border:rgba(0,0,0,.07); --border-a:rgba(26,111,255,.2);
  --text:#0F1729; --text-s:#4A5780; --text-m:#9BA8C4;
  --shadow:0 4px 24px rgba(0,0,0,.08); --sidebar-bg:#FFFFFF; --topbar-bg:rgba(255,255,255,.94);
}

/* Reset */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:14px;}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);height:100vh;overflow:hidden;transition:background .3s,color .3s;}
::-webkit-scrollbar{width:3px;height:3px;}
::-webkit-scrollbar-thumb{background:var(--border-a);border-radius:2px;}
a{text-decoration:none;color:inherit;}
button{font-family:var(--font-body);}
input,select,textarea{font-family:var(--font-body);}

/* Layout */
#app{display:grid;grid-template-columns:248px 1fr;grid-template-rows:52px 1fr;height:100vh;overflow:hidden;}

/* Impersonation bar */
.impersonate-bar{
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:linear-gradient(90deg,#F59E0B,#D97706);
  color:#000;font-size:12px;font-weight:700;
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:4px 16px;
}
.btn-stop-imp{background:rgba(0,0,0,.15);border:1px solid rgba(0,0,0,.2);border-radius:5px;padding:2px 10px;font-size:11px;font-weight:700;cursor:pointer;color:#000;margin-left:10px;}

/* Topbar */
.topbar{grid-column:1/-1;background:var(--topbar-bg);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px 0 0;position:relative;z-index:50;}
.tb-brand{width:248px;flex-shrink:0;display:flex;align-items:center;gap:10px;padding:0 18px;height:100%;border-right:1px solid var(--border);}
.brand-mark{width:32px;height:32px;border-radius:9px;background:var(--grad);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:900;font-size:18px;color:#fff;box-shadow:0 4px 14px var(--glow);flex-shrink:0;}
.brand-name{font-family:var(--font-display);font-size:16px;font-weight:800;letter-spacing:-.3px;}
.brand-name em{font-style:normal;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.brand-phase{font-size:8px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--a1);background:rgba(26,111,255,.1);border:1px solid rgba(26,111,255,.2);border-radius:4px;padding:1px 5px;margin-left:2px;}
.tb-center{flex:1;display:flex;align-items:center;gap:10px;padding:0 14px;}
.tb-search{display:flex;align-items:center;gap:7px;background:var(--bg-in);border:1px solid var(--border);border-radius:8px;padding:6px 12px;width:280px;transition:all .2s;}
.tb-search:focus-within{border-color:var(--a1);box-shadow:0 0 0 3px var(--glow);}
.tb-search input{background:none;border:none;outline:none;color:var(--text);font-size:12.5px;width:100%;}
.tb-badge{display:flex;align-items:center;gap:6px;background:var(--bg-in);border:1px solid var(--border-a);border-radius:20px;padding:4px 12px 4px 8px;font-size:11px;font-weight:600;color:var(--a1);font-family:var(--font-display);}
.tb-badge-dot{width:7px;height:7px;border-radius:50%;background:var(--a1);animation:pulse 2s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 var(--glow)}70%{box-shadow:0 0 0 5px transparent}100%{box-shadow:0 0 0 0 transparent}}
.tb-live{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:700;font-family:var(--font-mono);color:var(--success);}
.tb-live-dot{width:6px;height:6px;border-radius:50%;background:var(--success);animation:liveDot 2s infinite;}
@keyframes liveDot{0%{box-shadow:0 0 0 0 rgba(16,185,129,.4)}70%{box-shadow:0 0 0 5px transparent}100%{box-shadow:0 0 0 0 transparent}}
.tb-right{display:flex;align-items:center;gap:6px;}
.tb-icon-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:var(--bg-in);color:var(--text-s);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;position:relative;}
.tb-icon-btn:hover{border-color:var(--a1);color:var(--a1);}
.notif-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--danger);border:1.5px solid var(--bg-c);}
.tb-avatar{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border:1px solid var(--border);border-radius:24px;background:var(--bg-in);cursor:pointer;transition:all .2s;position:relative;}
.tb-avatar:hover{border-color:var(--a1);}
.av-circle{width:26px;height:26px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;font-family:var(--font-display);}
.av-name{font-size:11.5px;font-weight:600;line-height:1.2;}
.av-role{font-size:9.5px;color:var(--text-m);text-transform:capitalize;}
.av-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:200px;background:var(--bg-c);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);z-index:100;display:none;overflow:hidden;}
.av-dropdown.open{display:block;}
.av-dd-header{padding:12px 14px;border-bottom:1px solid var(--border);}
.av-dd-name{font-size:13px;font-weight:700;}
.av-dd-email{font-size:10.5px;color:var(--text-m);font-family:var(--font-mono);}
.av-dd-item{display:flex;align-items:center;gap:8px;padding:10px 14px;font-size:12.5px;color:var(--text-s);transition:all .15s;}
.av-dd-item:hover{background:var(--bg-in);color:var(--text);}
.av-dd-item.danger:hover{color:var(--danger);}
.av-dd-sep{height:1px;background:var(--border);}

/* Sidebar */
.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--border);overflow:hidden;display:flex;flex-direction:column;position:relative;}
.sidebar::before{content:'';position:absolute;left:0;top:0;width:2px;height:100%;background:var(--grad);opacity:.6;z-index:1;}
.sidebar-scroll{overflow-y:auto;flex:1;padding:8px 0 20px;}
.sidebar-entity{margin:8px 10px 4px;background:var(--bg-c2);border:1px solid var(--border);border-radius:10px;padding:10px 12px;}
.se-title{font-size:8.5px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-m);margin-bottom:6px;font-family:var(--font-display);}
.se-current{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--a1);}
.se-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.nav-group{margin-bottom:4px;}
.nav-group-label{font-size:8.5px;font-weight:800;letter-spacing:1.8px;text-transform:uppercase;color:var(--text-m);padding:12px 16px 4px;font-family:var(--font-display);}
.nav-item{display:flex;align-items:center;gap:9px;padding:7px 16px;cursor:pointer;transition:all .15s;font-size:12.5px;font-weight:500;color:var(--text-s);position:relative;text-decoration:none;}
.nav-item:hover{color:var(--text);background:rgba(255,255,255,.03);}
.nav-item.active{color:var(--text);}
.nav-item.active::after{content:'';position:absolute;left:0;top:4px;bottom:4px;width:3px;background:var(--grad);border-radius:0 3px 3px 0;}
.nav-item.active::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(26,111,255,.08),transparent);pointer-events:none;}
.nav-item-icon{flex-shrink:0;width:15px;height:15px;}
.nav-item-label{flex:1;}
.nav-badge{font-size:9px;font-weight:700;padding:2px 5px;border-radius:4px;font-family:var(--font-mono);}
.nb-red{background:rgba(239,68,68,.15);color:var(--danger);}
.nb-blue{background:rgba(26,111,255,.15);color:var(--a1);}
.nb-green{background:rgba(16,185,129,.15);color:var(--success);}
.nb-yellow{background:rgba(245,158,11,.15);color:var(--warning);}

/* Main content */
.main-content{overflow-y:auto;background:var(--bg);position:relative;}
.main-content::before{content:'';position:fixed;inset:52px 0 0 248px;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:36px 36px;pointer-events:none;z-index:0;opacity:.5;}
[data-theme="light"] .main-content::before{opacity:.25;}

/* Page container */
.page{padding:20px;position:relative;z-index:1;animation:pageIn .2s ease;}
@keyframes pageIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px;}
.ph-left .breadcrumb{font-size:10px;color:var(--text-m);font-family:var(--font-mono);margin-bottom:4px;display:flex;align-items:center;gap:5px;}
.ph-left h1{font-family:var(--font-display);font-size:22px;font-weight:800;letter-spacing:-.3px;line-height:1.2;}
.ph-left p{font-size:12px;color:var(--text-s);margin-top:3px;}
.ph-right{display:flex;align-items:center;gap:8px;flex-shrink:0;}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;border:1px solid transparent;font-size:12.5px;font-weight:600;cursor:pointer;transition:all .2s;font-family:var(--font-display);letter-spacing:.2px;white-space:nowrap;text-decoration:none;}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 4px 14px var(--glow);}
.btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 6px 20px var(--glow);}
.btn-outline{background:transparent;border-color:var(--border);color:var(--text-s);}
.btn-outline:hover{border-color:var(--a1);color:var(--a1);background:rgba(26,111,255,.05);}
.btn-ghost{background:var(--bg-in);border-color:var(--border);color:var(--text-s);}
.btn-ghost:hover{color:var(--text);border-color:var(--border-a);}
.btn-danger{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.3);color:var(--danger);}
.btn-danger:hover{background:rgba(239,68,68,.2);}
.btn-success{background:rgba(16,185,129,.1);border-color:rgba(16,185,129,.3);color:var(--success);}
.btn-sm{padding:5px 10px;font-size:11.5px;}
.btn-xs{padding:3px 8px;font-size:10.5px;}
.btn-icon{padding:7px;width:34px;height:34px;justify-content:center;}
.w-full{width:100%;justify-content:center;}

/* Cards */
.card{background:var(--bg-c);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:border-color .2s;}
.card:hover{border-color:rgba(26,111,255,.12);}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);}
.card-title{font-family:var(--font-display);font-size:13.5px;font-weight:700;display:flex;align-items:center;gap:8px;}
.card-body{padding:16px 18px;}
.card-footer{padding:12px 18px;border-top:1px solid var(--border);background:var(--bg-s);}

/* Stat cards */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;margin-bottom:16px;}
.stat-card{background:var(--bg-c);border:1px solid var(--border);border-radius:14px;padding:16px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;}
.stat-card::after{content:'';position:absolute;top:0;right:0;width:70px;height:70px;border-radius:50%;transform:translate(20px,-20px);background:var(--sc-color,var(--a1));opacity:.07;}
.stat-card:hover{transform:translateY(-2px);border-color:var(--border-a);box-shadow:0 0 30px var(--glow);}
.sc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.sc-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:rgba(26,111,255,.1);color:var(--sc-color,var(--a1));}
.sc-trend{font-size:9.5px;font-weight:700;padding:2px 6px;border-radius:5px;font-family:var(--font-mono);}
.sc-up{background:rgba(16,185,129,.12);color:var(--success);}
.sc-down{background:rgba(239,68,68,.12);color:var(--danger);}
.sc-neutral{background:rgba(245,158,11,.12);color:var(--warning);}
.sc-val{font-family:var(--font-display);font-size:28px;font-weight:800;line-height:1;letter-spacing:-1px;}
.sc-label{font-size:11px;color:var(--text-s);margin-top:3px;}
.sc-sub{font-size:10px;color:var(--text-m);margin-top:5px;}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:5px;font-size:9.5px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;font-family:var(--font-display);white-space:nowrap;}
.badge-success{background:rgba(16,185,129,.12);color:var(--success);}
.badge-danger{background:rgba(239,68,68,.12);color:var(--danger);}
.badge-warning{background:rgba(245,158,11,.12);color:var(--warning);}
.badge-info{background:rgba(59,130,246,.12);color:var(--info);}
.badge-purple{background:rgba(139,92,246,.12);color:#8B5CF6;}
.badge-pink{background:rgba(232,58,156,.12);color:#E83A9C;}
.badge-blue{background:rgba(26,111,255,.12);color:var(--a1);}
.badge-gray{background:var(--bg-in);color:var(--text-m);}

/* Tables */
.table-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
th{text-align:left;padding:9px 14px;font-size:9.5px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-m);border-bottom:1px solid var(--border);background:var(--bg-s);white-space:nowrap;font-family:var(--font-display);}
td{padding:10px 14px;font-size:12px;border-bottom:1px solid var(--border);vertical-align:middle;}
tr:last-child td{border-bottom:none;}
tr:hover td{background:rgba(255,255,255,.01);}
[data-theme="light"] tr:hover td{background:rgba(0,0,0,.02);}
.mono{font-family:var(--font-mono);font-size:11px;}
.text-muted{color:var(--text-m);}
.text-s{color:var(--text-s);}

/* Forms */
.form-group{margin-bottom:16px;}
.form-label{font-size:10.5px;font-weight:700;color:var(--text-s);margin-bottom:5px;display:block;letter-spacing:.3px;font-family:var(--font-display);}
.form-ctrl{width:100%;padding:9px 12px;background:var(--bg-in);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;outline:none;transition:all .2s;}
.form-ctrl:focus{border-color:var(--a1);box-shadow:0 0 0 3px var(--glow);}
.form-ctrl::placeholder{color:var(--text-m);}
select.form-ctrl{cursor:pointer;}
textarea.form-ctrl{resize:vertical;min-height:80px;}
.form-help{font-size:10.5px;color:var(--text-m);margin-top:4px;}
.form-error{font-size:10.5px;color:var(--danger);margin-top:4px;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;}

/* Toggle */
.toggle{position:relative;display:inline-flex;align-items:center;gap:8px;cursor:pointer;}
.toggle input{position:absolute;opacity:0;width:0;height:0;}
.toggle-track{width:36px;height:20px;border-radius:10px;background:var(--bg-in);border:1px solid var(--border);transition:all .2s;position:relative;flex-shrink:0;}
.toggle input:checked + .toggle-track{background:var(--a1);border-color:var(--a1);}
.toggle-track::after{content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:left .2s;}
.toggle input:checked + .toggle-track::after{left:18px;}
.toggle-label{font-size:12px;color:var(--text-s);}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:500;display:none;align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal{background:var(--bg-c);border:1px solid var(--border);border-radius:16px;width:540px;max-width:95vw;max-height:90vh;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.6);animation:modalIn .25s ease;}
@keyframes modalIn{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border);}
.modal-title{font-family:var(--font-display);font-size:15px;font-weight:800;}
.modal-body{padding:20px;overflow-y:auto;max-height:60vh;}
.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;}
.btn-close{font-size:18px;cursor:pointer;color:var(--text-m);background:none;border:none;line-height:1;}
.btn-close:hover{color:var(--text);}

/* Flash */
.flash{display:flex;align-items:center;gap:10px;padding:11px 16px;margin:16px 20px 0;border-radius:10px;font-size:12.5px;font-weight:500;border:1px solid;}
.flash-success{background:rgba(16,185,129,.08);border-color:rgba(16,185,129,.3);color:var(--success);}
.flash-error{background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.3);color:var(--danger);}
.flash-info{background:rgba(26,111,255,.08);border-color:rgba(26,111,255,.3);color:var(--a1);}
.flash-warning{background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.3);color:var(--warning);}

/* Toast */
.toast-container{position:fixed;bottom:20px;right:20px;z-index:999;display:flex;flex-direction:column;gap:8px;}
.toast{display:flex;align-items:flex-start;gap:10px;background:var(--bg-c);border:1px solid var(--border);border-radius:12px;padding:12px 16px;min-width:280px;max-width:340px;box-shadow:var(--shadow);animation:toastIn .3s ease;}
@keyframes toastIn{from{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}
.toast.exit{animation:toastOut .3s ease forwards;}
@keyframes toastOut{to{opacity:0;transform:translateX(100%)}}
.toast-title{font-size:12.5px;font-weight:700;}
.toast-msg{font-size:11px;color:var(--text-s);margin-top:2px;}
.toast.t-success{border-left:3px solid var(--success);}
.toast.t-error{border-left:3px solid var(--danger);}
.toast.t-info{border-left:3px solid var(--a1);}
.toast.t-warning{border-left:3px solid var(--warning);}

/* Theme panel */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:199;display:none;backdrop-filter:blur(2px);}
.overlay.open{display:block;}
.theme-panel{position:fixed;top:0;right:-310px;width:290px;height:100%;background:var(--sidebar-bg);border-left:1px solid var(--border);z-index:200;transition:right .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;box-shadow:-20px 0 60px rgba(0,0,0,.3);}
.theme-panel.open{right:0;}
.tp-header{padding:16px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.tp-title{font-family:var(--font-display);font-size:14px;font-weight:800;}
.tp-body{padding:16px;display:flex;flex-direction:column;gap:18px;}
.tp-label{font-size:9px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-m);margin-bottom:8px;font-family:var(--font-display);}
.mode-toggle{display:flex;background:var(--bg-in);border-radius:9px;padding:3px;gap:3px;}
.mode-btn{flex:1;padding:7px;border-radius:7px;border:none;background:none;color:var(--text-m);cursor:pointer;font-size:12px;font-weight:700;transition:all .2s;font-family:var(--font-display);display:flex;align-items:center;justify-content:center;gap:5px;}
.mode-btn.active{background:var(--bg-c);color:var(--text);box-shadow:0 2px 8px rgba(0,0,0,.2);}
.color-swatches{display:flex;flex-wrap:wrap;gap:7px;}
.cs-item{width:34px;height:34px;border-radius:9px;cursor:pointer;border:2px solid transparent;transition:all .2s;position:relative;}
.cs-item:hover{transform:scale(1.1);}
.cs-item.active{border-color:var(--text);box-shadow:0 4px 12px rgba(0,0,0,.3);}
.cs-item.active::after{content:'✓';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:800;}

/* Pagination */
.pagination{display:flex;gap:4px;padding:12px 16px;justify-content:center;}
.page-btn{padding:5px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg-in);color:var(--text-s);font-size:12px;cursor:pointer;text-decoration:none;}
.page-btn.active,.page-btn:hover{background:var(--a1);border-color:var(--a1);color:#fff;}

/* Progress bar */
.progress-wrap{height:5px;background:var(--bg-in);border-radius:3px;overflow:hidden;margin-top:6px;}
.progress-fill{height:100%;border-radius:3px;transition:width .5s;}

/* Escalation trail */
.escalation-trail{display:flex;align-items:center;gap:5px;flex-wrap:wrap;font-size:10.5px;}
.et-node{padding:3px 8px;border-radius:5px;background:var(--bg-in);border:1px solid var(--border);color:var(--text-m);font-weight:600;font-family:var(--font-display);}
.et-node.done{background:rgba(16,185,129,.08);border-color:rgba(16,185,129,.3);color:var(--success);}
.et-node.current{background:rgba(26,111,255,.1);border-color:rgba(26,111,255,.3);color:var(--a1);font-weight:700;}
.et-arrow{color:var(--text-m);}

/* Auth pages */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden;}
.auth-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(26,111,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(26,111,255,.04) 1px,transparent 1px);background-size:48px 48px;}
.auth-card{position:relative;z-index:1;width:420px;background:var(--bg-c);border:1px solid var(--border);border-radius:20px;padding:38px;box-shadow:0 24px 80px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.04);animation:loginReveal .4s cubic-bezier(.4,0,.2,1);}
@keyframes loginReveal{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.auth-logo{text-align:center;margin-bottom:28px;}
.auth-logo-mark{width:52px;height:52px;border-radius:15px;background:var(--grad);display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:900;font-size:26px;color:#fff;box-shadow:0 8px 24px var(--glow);margin-bottom:10px;}
.auth-logo h1{font-family:var(--font-display);font-size:22px;font-weight:800;letter-spacing:-.5px;}
.auth-logo h1 em{font-style:normal;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.auth-logo p{font-size:11.5px;color:var(--text-m);margin-top:3px;}
.auth-tabs{display:flex;background:var(--bg-in);border-radius:10px;padding:3px;gap:3px;margin-bottom:22px;}
.auth-tab{flex:1;padding:8px;border-radius:8px;border:none;background:none;font-size:11px;font-weight:600;color:var(--text-m);cursor:pointer;transition:all .2s;font-family:var(--font-display);letter-spacing:.3px;}
.auth-tab.active{background:var(--bg-c);color:var(--text);box-shadow:0 2px 8px rgba(0,0,0,.2);}
.auth-btn{width:100%;padding:12px;border-radius:10px;border:none;background:var(--grad);color:#fff;font-size:14px;font-weight:700;font-family:var(--font-display);letter-spacing:.5px;box-shadow:0 8px 24px var(--glow);cursor:pointer;transition:all .2s;margin-top:6px;}
.auth-btn:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 12px 32px var(--glow);}
.input-icon{position:relative;}
.input-icon i{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-m);pointer-events:none;width:14px;height:14px;}
.input-icon .form-ctrl{padding-left:34px;}
.quick-logins{margin-top:22px;padding-top:18px;border-top:1px solid var(--border);}
.ql-title{font-size:9.5px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-m);margin-bottom:10px;font-family:var(--font-display);}
.ql-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;}
.ql-btn{padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:var(--bg-s);cursor:pointer;text-align:left;transition:all .15s;}
.ql-btn:hover{border-color:var(--a1);}
.ql-role{font-size:10px;font-weight:700;font-family:var(--font-display);margin-bottom:2px;}
.ql-email{font-size:10px;color:var(--text-s);font-family:var(--font-mono);}
.ql-pass{font-size:9px;color:var(--text-m);font-family:var(--font-mono);}
.otp-inputs{display:flex;gap:8px;}
.otp-input{flex:1;padding:12px;text-align:center;font-size:20px;font-weight:700;font-family:var(--font-mono);background:var(--bg-in);border:1px solid var(--border);border-radius:9px;color:var(--text);outline:none;transition:all .2s;}
.otp-input:focus{border-color:var(--a1);box-shadow:0 0 0 3px var(--glow);}

/* Captive portal landing */
.portal-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;}
.portal-card{width:100%;max-width:440px;border-radius:20px;padding:36px;box-shadow:0 24px 80px rgba(0,0,0,.4);}
.portal-logo{text-align:center;margin-bottom:24px;}
.portal-logo img{max-height:60px;max-width:200px;}
.portal-title{font-family:var(--font-display);font-size:20px;font-weight:800;text-align:center;margin-bottom:8px;}
.portal-body{font-size:13px;text-align:center;margin-bottom:22px;line-height:1.6;}
.portal-btn{width:100%;padding:13px;border-radius:10px;border:none;font-size:14px;font-weight:700;font-family:var(--font-display);cursor:pointer;transition:all .2s;margin-top:6px;}
.portal-social{display:flex;gap:10px;margin-bottom:16px;}
.portal-social-btn{flex:1;padding:10px;border-radius:9px;border:1px solid;background:transparent;display:flex;align-items:center;justify-content:center;gap:7px;font-size:12.5px;font-weight:600;cursor:pointer;transition:all .2s;}

/* Kafka stream card */
.kafka-card{background:var(--bg-c);border:1px solid var(--border);border-radius:12px;padding:14px;transition:all .2s;}
.kafka-card:hover{border-color:var(--border-a);}
.kafka-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.kafka-topic{font-size:10.5px;font-family:var(--font-mono);color:var(--a1);font-weight:600;}
.kafka-rate{font-family:var(--font-display);font-size:15px;font-weight:800;}
.kafka-sub{font-size:10px;color:var(--text-m);}

/* Live feed terminal */
.kafka-terminal{background:#000;border:1px solid rgba(16,185,129,.2);border-radius:10px;font-family:var(--font-mono);font-size:11px;overflow:hidden;}
.kt-header{background:rgba(16,185,129,.08);padding:8px 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(16,185,129,.15);}
.kt-dot{width:10px;height:10px;border-radius:50%;background:var(--success);animation:liveDot 1s infinite;}
.kt-title{color:var(--success);font-weight:700;}
.kt-body{padding:12px;height:300px;overflow-y:auto;color:#0f0;}
.kt-line{padding:1px 0;line-height:1.5;border-bottom:1px solid rgba(16,185,129,.05);}
.kt-ts{color:rgba(16,185,129,.5);}
.kt-topic{color:#FFB830;}
.kt-key{color:#1A6FFF;}

/* Ticket page */
.ticket-thread{display:flex;flex-direction:column;gap:0;}
.ticket-reply{padding:16px 18px;border-bottom:1px solid var(--border);}
.ticket-reply:last-child{border-bottom:none;}
.tr-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.tr-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;font-family:var(--font-display);flex-shrink:0;}
.tr-name{font-size:13px;font-weight:700;}
.tr-meta{font-size:10.5px;color:var(--text-m);}
.tr-body{font-size:12.5px;line-height:1.7;color:var(--text-s);white-space:pre-wrap;}
.tr-internal{background:rgba(245,158,11,.04);border-left:3px solid var(--warning);}
.tr-system{background:rgba(26,111,255,.04);border-left:3px solid var(--a1);}

/* Invoice print styles */
@media print {
  .sidebar,.topbar,.theme-panel,.overlay,.toast-container,.ph-right{display:none !important;}
  #app{display:block;}
  .main-content{overflow:visible;}
  .main-content::before{display:none;}
}

/* Utility */
.flex{display:flex;} .items-center{align-items:center;} .justify-between{justify-content:space-between;}
.gap-8{gap:8px;} .gap-12{gap:12px;} .gap-16{gap:16px;}
.mt-8{margin-top:8px;} .mt-12{margin-top:12px;} .mt-16{margin-top:16px;}
.mb-8{margin-bottom:8px;} .mb-12{margin-bottom:12px;} .mb-16{margin-bottom:16px;}
.ml-auto{margin-left:auto;}
.text-right{text-align:right;} .text-center{text-align:center;}
.font-mono{font-family:var(--font-mono);}
.font-display{font-family:var(--font-display);}
.fw-700{font-weight:700;} .fw-800{font-weight:800;}
.text-success{color:var(--success);} .text-danger{color:var(--danger);} .text-warning{color:var(--warning);}

.nb-purple{background:rgba(124,63,240,.15);color:#7C3FF0;}
.nb-teal{background:rgba(20,184,166,.15);color:#14B8A6;}
