/* ============================================
   ADMIN PANEL — OBSIDIAN COMMAND CENTER
   Modern glassmorphism dark panel
   ============================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',system-ui,sans-serif;line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit;color:inherit;border:none;background:none}
table{border-collapse:collapse;width:100%}

/* --- THEME VARIABLES --- */
[data-theme="dark"]{
  --bg:          #0a0b10;
  --bg-card:     rgba(18,19,28,.85);
  --bg-card-solid: #12131c;
  --bg-card2:    rgba(24,26,38,.9);
  --bg-glass:    rgba(255,255,255,.03);
  --bg-hover:    rgba(255,255,255,.05);
  --bg-active:   rgba(110,86,255,.12);
  --border:      rgba(255,255,255,.06);
  --border2:     rgba(255,255,255,.1);
  --border-glow: rgba(110,86,255,.25);
  --text:        #eaedf3;
  --text2:       #b0b5c3;
  --muted:       #6b7083;
  --accent:      #6e56ff;
  --accent2:     #8b6fff;
  --accent-soft: rgba(110,86,255,.12);
  --accent-glow: rgba(110,86,255,.4);
  --green:       #34d399;
  --green-soft:  rgba(52,211,153,.1);
  --amber:       #fbbf24;
  --amber-soft:  rgba(251,191,36,.1);
  --rose:        #fb7185;
  --rose-soft:   rgba(251,113,133,.1);
  --purple:      #a78bfa;
  --purple-soft: rgba(167,139,250,.1);
  --blue:        #60a5fa;
  --blue-soft:   rgba(96,165,250,.1);
  --teal:        #2dd4bf;
  --teal-soft:   rgba(45,212,191,.1);
  --orange:      #fb923c;
  --orange-soft: rgba(251,146,60,.1);
  --shadow:      0 8px 32px rgba(0,0,0,.4);
  --shadow-sm:   0 2px 8px rgba(0,0,0,.3);
  --nav-w:       270px;
  --gradient-1:  linear-gradient(135deg,#6e56ff 0%,#a78bfa 50%,#60a5fa 100%);
  --gradient-2:  linear-gradient(135deg,#34d399 0%,#2dd4bf 100%);
  --gradient-3:  linear-gradient(135deg,#fb7185 0%,#fbbf24 100%);
  --glass-blur:  blur(20px);
}
[data-theme="light"]{
  --bg:          #f0f2f7;
  --bg-card:     rgba(255,255,255,.92);
  --bg-card-solid: #ffffff;
  --bg-card2:    rgba(245,247,251,.95);
  --bg-glass:    rgba(255,255,255,.6);
  --bg-hover:    rgba(0,0,0,.03);
  --bg-active:   rgba(110,86,255,.08);
  --border:      rgba(0,0,0,.06);
  --border2:     rgba(0,0,0,.1);
  --border-glow: rgba(110,86,255,.2);
  --text:        #111827;
  --text2:       #4b5563;
  --muted:       #9ca3af;
  --accent:      #5b43e6;
  --accent2:     #6e56ff;
  --accent-soft: rgba(91,67,230,.08);
  --accent-glow: rgba(91,67,230,.3);
  --green:       #059669;
  --green-soft:  rgba(5,150,105,.08);
  --amber:       #d97706;
  --amber-soft:  rgba(217,119,6,.08);
  --rose:        #e11d48;
  --rose-soft:   rgba(225,29,72,.06);
  --purple:      #7c3aed;
  --purple-soft: rgba(124,58,237,.08);
  --blue:        #2563eb;
  --blue-soft:   rgba(37,99,235,.08);
  --teal:        #0d9488;
  --teal-soft:   rgba(13,148,136,.08);
  --orange:      #ea580c;
  --orange-soft: rgba(234,88,12,.08);
  --shadow:      0 8px 32px rgba(0,0,0,.08);
  --shadow-sm:   0 2px 8px rgba(0,0,0,.05);
  --nav-w:       270px;
  --gradient-1:  linear-gradient(135deg,#5b43e6 0%,#7c3aed 50%,#2563eb 100%);
  --gradient-2:  linear-gradient(135deg,#059669 0%,#0d9488 100%);
  --gradient-3:  linear-gradient(135deg,#e11d48 0%,#d97706 100%);
  --glass-blur:  blur(16px);
}

body{background:var(--bg);color:var(--text)}
.muted{color:var(--muted)}

/* --- BG MESH --- */
body::before{content:'';position:fixed;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse 80% 50% at 20% 20%, rgba(110,86,255,.08) 0%, transparent 50%),
    radial-gradient(ellipse 60% 40% at 80% 80%, rgba(96,165,250,.06) 0%, transparent 50%);
  pointer-events:none;
}

/* --- LOADER --- */
#app-loader{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:var(--bg);transition:opacity .6s}
#app-loader.hidden{opacity:0;pointer-events:none}
.loader-inner{text-align:center}
.loader-brand{font-size:28px;font-weight:900;letter-spacing:3px;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:20px}
.loader-bar{width:140px;height:3px;background:var(--border);border-radius:3px;overflow:hidden;margin:0 auto}
.loader-bar div{width:30%;height:100%;background:var(--gradient-1);border-radius:3px;animation:loaderSlide 1s ease infinite}
@keyframes loaderSlide{0%{transform:translateX(-100%)}100%{transform:translateX(450%)}}

/* --- SHELL --- */
.admin-shell{display:flex;min-height:100vh}

/* --- SIDEBAR --- */
.admin-nav{width:var(--nav-w);min-width:var(--nav-w);background:var(--bg-card);backdrop-filter:var(--glass-blur);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;position:sticky;top:0;height:100vh;z-index:100;transition:transform .3s cubic-bezier(.4,0,.2,1)}
.admin-main{flex:1;min-width:0;display:flex;flex-direction:column;padding-bottom:40px}

/* Brand */
.admin-brand-card{padding:24px 22px 16px;border-bottom:1px solid var(--border)}
.brand-main{font-size:22px;font-weight:900;letter-spacing:2px;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.brand-sub{font-size:10px;font-weight:800;letter-spacing:3px;color:var(--muted);margin-top:4px;text-transform:uppercase}

/* Who */
.admin-who-card{padding:16px 22px;border-bottom:1px solid var(--border)}
.admin-who-head{display:flex;justify-content:space-between;align-items:center;gap:8px}
.admin-who-name{font-weight:800;font-size:15px}
.admin-who-role{font-size:12px;color:var(--muted);font-family:'JetBrains Mono',monospace}
.who-meta-row{margin-top:10px;display:flex;gap:6px;flex-wrap:wrap}
.who-meta-chip{font-size:11px;font-family:'JetBrains Mono',monospace;background:var(--bg-glass);border:1px solid var(--border);border-radius:8px;padding:3px 10px;color:var(--text2)}
.mini-role-pill{font-size:10px;font-weight:800;padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.8px}
.mini-role-pill.admin{background:var(--accent-soft);color:var(--accent2);border:1px solid var(--border-glow)}
.mini-role-pill.staff{background:var(--green-soft);color:var(--green);border:1px solid rgba(52,211,153,.2)}

/* Theme Toggle */
.theme-row{margin-top:12px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.theme-toggle{position:relative;width:52px;height:28px;border-radius:14px;background:var(--border2);cursor:pointer;transition:background .3s}
.theme-toggle .ico{position:absolute;top:50%;transform:translateY(-50%);font-size:14px;transition:opacity .3s}
.theme-toggle .sun{left:6px;opacity:0}
.theme-toggle .moon{right:6px;opacity:1}
.theme-toggle .knob{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:var(--accent);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px var(--accent-glow)}
[data-theme="light"] .theme-toggle .sun{opacity:1}
[data-theme="light"] .theme-toggle .moon{opacity:0}
[data-theme="light"] .theme-toggle .knob{transform:translateX(24px)}

/* Nav Collapse */
.admin-side-collapse{display:flex;align-items:center;gap:10px;width:100%;padding:12px 22px;color:var(--muted);font-size:13px;cursor:pointer;border-bottom:1px solid var(--border);transition:all .2s}
.admin-side-collapse:hover{background:var(--bg-hover);color:var(--text)}
.admin-side-collapse__icon{font-size:18px}

/* Nav Items */
.nav-group{padding:18px 22px 8px;font-size:10px;font-weight:900;letter-spacing:2px;color:var(--muted);text-transform:uppercase}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 22px;font-size:14px;font-weight:500;color:var(--text2);transition:all .2s cubic-bezier(.4,0,.2,1);border-left:3px solid transparent;cursor:pointer;position:relative}
.nav-item:hover{background:var(--bg-hover);color:var(--text);padding-left:26px}
.nav-item.active{background:var(--bg-active);color:var(--accent2);border-left-color:var(--accent);font-weight:700}
.nav-item.active::after{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--accent);border-radius:0 2px 2px 0;box-shadow:0 0 12px var(--accent-glow)}
.nav-ic{width:20px;height:20px;flex-shrink:0;opacity:.7}
.nav-item.active .nav-ic{opacity:1}
.nav-ic svg{width:100%;height:100%}
.nav-logout{color:var(--rose)!important;margin-top:auto}
.nav-logout:hover{background:var(--rose-soft)!important;padding-left:26px}
.admin-nav-fill{flex:1}
.admin-nav-footer-card{padding:16px 22px;border-top:1px solid var(--border);font-size:12px}
.admin-nav-footer-card__eyebrow{font-size:9px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:6px;font-weight:800}

/* --- TOPBAR --- */
.admin-topbar{display:flex;justify-content:space-between;align-items:center;padding:18px 28px;background:var(--bg-card);backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:90}
.admin-topbar-left{display:flex;flex-direction:column;gap:2px}
.admin-page-kicker{font-size:10px;font-weight:800;letter-spacing:2px;text-transform:uppercase;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.admin-page-title{font-size:22px;font-weight:900;letter-spacing:-.3px}
.admin-page-sub{font-size:12px;color:var(--muted)}
.admin-topbar-right{display:flex;align-items:center;gap:14px}
.admin-nav-toggle{display:none;font-size:22px;cursor:pointer;padding:6px 10px;color:var(--text);border-radius:8px;transition:background .2s}
.admin-nav-toggle:hover{background:var(--bg-hover)}
.topbar-user-pill{display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:12px;background:var(--bg-glass);border:1px solid var(--border);backdrop-filter:var(--glass-blur)}
.topbar-user-ic{width:18px;height:18px;opacity:.7}
.topbar-user-ic svg{width:100%;height:100%}
.topbar-user-name{font-size:13px;font-weight:700}
.topbar-user-role{font-size:11px;color:var(--muted);font-family:'JetBrains Mono',monospace}

/* --- NOTIFICATION --- */
.notif-bell{position:relative;cursor:pointer;padding:8px;color:var(--text2);border-radius:10px;transition:all .2s}
.notif-bell:hover{background:var(--bg-hover);color:var(--text)}
.notif-bell svg{width:22px;height:22px}
.notif-badge{position:absolute;top:2px;right:2px;background:var(--rose);color:#fff;font-size:10px;font-weight:800;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 8px rgba(251,113,133,.4)}
.notif-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:360px;max-height:420px;background:var(--bg-card-solid);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;z-index:200;display:none}
.notif-dropdown[aria-hidden="false"]{display:block}
.notif-hd{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border)}
.notif-hd .ttl{font-weight:800;font-size:15px}
.notif-list{overflow-y:auto;max-height:360px;padding:8px}

/* --- BUTTONS --- */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid var(--border);background:var(--bg-glass);color:var(--text);backdrop-filter:blur(8px)}
.btn:hover{background:var(--bg-hover);border-color:var(--border2);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 16px var(--accent-glow)}
.btn-primary:hover{opacity:.9;box-shadow:0 6px 24px var(--accent-glow)}
.btn-xs{padding:5px 11px;font-size:11px;border-radius:8px;font-weight:700}
.btn-sm{padding:7px 14px;font-size:12px}
.btn-icon{padding:6px 10px;font-size:16px;border:none;background:none;border-radius:8px}
.btn-icon:hover{background:var(--bg-hover)}
.btn-ghost{border-color:transparent;background:transparent}
.btn-ghost:hover{background:var(--bg-hover)}
.btn-soft-blue{background:var(--blue-soft);color:var(--blue);border-color:transparent}
.btn-soft-blue:hover{background:rgba(96,165,250,.18)}
.btn-soft-green{background:var(--green-soft);color:var(--green);border-color:transparent}
.btn-soft-green:hover{background:rgba(52,211,153,.18)}
.btn-soft-purple{background:var(--purple-soft);color:var(--purple);border-color:transparent}
.btn-soft-purple:hover{background:rgba(167,139,250,.18)}
.btn-soft-amber{background:var(--amber-soft);color:var(--amber);border-color:transparent}
.btn-soft-danger{background:var(--rose-soft);color:var(--rose);border-color:transparent}
.btn-soft-danger:hover{background:rgba(251,113,133,.18)}
.btn-soft-orange{background:var(--orange-soft);color:var(--orange);border-color:transparent}
.btn-soft-teal{background:var(--teal-soft);color:var(--teal);border-color:transparent}
.btn-soft{background:var(--bg-glass);color:var(--text2);border-color:var(--border)}
.btn-group{display:flex;gap:6px;flex-wrap:wrap}

/* --- CARD --- */
.card{background:var(--bg-card);backdrop-filter:var(--glass-blur);border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:border-color .3s}
.card:hover{border-color:var(--border2)}
.card.panel{padding:22px 24px}
.admin-surface-card{margin:0 28px}
.admin-top{display:flex;gap:10px;flex-wrap:wrap;padding:20px 28px 0;align-items:center}

/* --- BADGE --- */
.badge{display:inline-flex;align-items:center;font-size:12px;font-weight:700;padding:4px 12px;border-radius:8px;background:var(--bg-glass);border:1px solid var(--border);color:var(--text2);backdrop-filter:blur(8px)}
.badge.success{background:var(--green-soft);color:var(--green);border-color:rgba(52,211,153,.2)}
.badge.warning{background:var(--amber-soft);color:var(--amber);border-color:rgba(251,191,36,.2)}
.badge.danger{background:var(--rose-soft);color:var(--rose);border-color:rgba(251,113,133,.2)}
.badge.info{background:var(--blue-soft);color:var(--blue);border-color:rgba(96,165,250,.2)}
.badge.no-answer{background:var(--orange-soft);color:var(--orange);border-color:rgba(251,146,60,.2)}

/* --- PILL --- */
.pill{display:inline-flex;font-size:11px;font-weight:800;padding:3px 12px;border-radius:20px;border:1px solid transparent}

/* --- FORM --- */
.form{display:flex;flex-direction:column;gap:16px}
.field{display:flex;flex-direction:column;gap:5px}
.field>span{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
input[type="text"],input[type="email"],input[type="password"],input[type="date"],input[type="datetime-local"],input[type="number"],
input:not([type]),select,textarea,.input{width:100%;padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:var(--bg-glass);color:var(--text);font-size:14px;transition:all .2s;backdrop-filter:blur(4px)}
input:focus,select:focus,textarea:focus,.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
textarea{min-height:80px;resize:vertical}
select{cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7083' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:30px}
[data-theme="dark"] select,[data-theme="dark"] select option{background-color:var(--bg-card-solid);color:var(--text)}
[data-theme="dark"] input:not([type]),[data-theme="dark"] textarea,[data-theme="dark"] .input{background-color:rgba(18,19,28,.9);color:var(--text)}
[data-theme="dark"] .modal .box{background:var(--bg-card-solid)}
input[type="checkbox"]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent)}
.choice-group{display:flex;gap:6px;flex-wrap:wrap}
.choice-pill{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;border:1px solid var(--border);cursor:pointer;transition:all .2s;font-weight:600}
.choice-pill:has(input:checked){background:var(--accent-soft);border-color:var(--accent);color:var(--accent2)}
.choice-pill input{display:none}
.grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
@media(max-width:700px){.grid2{grid-template-columns:1fr}}

/* --- STAT CARDS --- */
.admin-stat-grid{display:grid;gap:16px;padding:16px 28px;grid-template-columns:repeat(4,minmax(0,1fr))}
@media(max-width:1100px){.admin-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:600px){.admin-stat-grid{grid-template-columns:1fr}}
.admin-stat-card{padding:20px;border-radius:14px;background:var(--bg-card);backdrop-filter:var(--glass-blur);border:1px solid var(--border);position:relative;overflow:hidden;transition:all .3s}
.admin-stat-card:hover{border-color:var(--border2);transform:translateY(-2px)}
.admin-stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:3px 3px 0 0}
.admin-stat-label{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.admin-stat-value{font-size:32px;font-weight:900;margin-top:6px;font-family:'Plus Jakarta Sans',sans-serif;letter-spacing:-1px}
.admin-stat-sub{font-size:11px;color:var(--muted);margin-top:6px}
.admin-stat-card.is-blue::before{background:var(--blue)}.admin-stat-card.is-blue .admin-stat-value{color:var(--blue)}
.admin-stat-card.is-green::before{background:var(--green)}.admin-stat-card.is-green .admin-stat-value{color:var(--green)}
.admin-stat-card.is-amber::before{background:var(--amber)}.admin-stat-card.is-amber .admin-stat-value{color:var(--amber)}
.admin-stat-card.is-rose::before{background:var(--rose)}.admin-stat-card.is-rose .admin-stat-value{color:var(--rose)}
.admin-stat-card.is-purple::before{background:var(--purple)}.admin-stat-card.is-purple .admin-stat-value{color:var(--purple)}

/* --- ALERT --- */
.alert{padding:14px 18px;border-radius:12px;font-size:13px;background:var(--bg-glass);border:1px solid var(--border);color:var(--text2);backdrop-filter:blur(4px)}

/* --- TABLE --- */
.table{width:100%;font-size:13px}
.table thead{background:var(--bg-glass)}
.table th{padding:12px 14px;font-weight:800;font-size:11px;color:var(--muted);text-align:left;text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border)}
.table td{padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:top}
.table tbody tr{transition:all .2s}
.table tbody tr:hover{background:var(--bg-hover)}

/* App Row States */
.app-row--active{border-left:3px solid var(--accent)}
.app-row--cancelled{opacity:.5}
.app-row--no-answer{opacity:.65;border-left:3px solid var(--orange)}
.app-row--paid{border-left:3px solid var(--green)}

/* --- SEGMENTED TABS --- */
.apps-segmented{display:flex;gap:6px;flex-wrap:wrap;padding:0 28px;margin:16px 0}
.apps-segment{padding:9px 18px;border-radius:10px;font-size:13px;font-weight:700;color:var(--text2);border:1px solid var(--border);transition:all .2s;display:flex;align-items:center;gap:7px;cursor:pointer}
.apps-segment span{font-size:11px;opacity:.6;font-family:'JetBrains Mono',monospace}
.apps-segment:hover{background:var(--bg-hover);border-color:var(--border2)}
.apps-segment.is-active{background:var(--accent-soft);color:var(--accent2);border-color:var(--border-glow);box-shadow:0 0 16px rgba(110,86,255,.1)}
.apps-segment.is-paid-soft.is-active{background:var(--green-soft);color:var(--green);border-color:rgba(52,211,153,.3)}
.apps-segment.is-cancelled-soft.is-active{background:var(--rose-soft);color:var(--rose);border-color:rgba(251,113,133,.3)}
.apps-segment.is-no-answer-soft.is-active{background:var(--orange-soft);color:var(--orange);border-color:rgba(251,146,60,.3)}

/* --- ROW ACTIONS --- */
.row-actions{display:flex;gap:5px;flex-wrap:wrap}
.apps-actions-cell{min-width:200px}

/* --- INLINE CODE --- */
.inline-code-pill{font-size:11px;font-weight:700;padding:3px 10px;border-radius:6px;background:var(--bg-glass);border:1px solid var(--border);font-family:'JetBrains Mono',monospace}

/* --- SOURCE PILL --- */
.source-pill{font-size:11px;padding:3px 10px;border-radius:6px;background:var(--blue-soft);color:var(--blue);border:1px solid rgba(96,165,250,.15)}

/* --- PAGINATION --- */
.apps-pagination-wrap{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;flex-wrap:wrap;gap:10px}
.apps-pagination{display:flex;gap:6px;align-items:center}
.apps-page-indicator{font-size:13px;font-weight:700;color:var(--muted);font-family:'JetBrains Mono',monospace}

/* --- MODAL --- */
.modal{position:fixed;inset:0;z-index:500;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);padding:16px}
.modal.open{display:flex}
.modal .box{background:var(--bg-card-solid);border:1px solid var(--border);border-radius:20px;width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 64px rgba(0,0,0,.5)}
.modal .box--pay{max-width:720px}
.modal .hd{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--border)}
.modal .bd{padding:22px;overflow-y:auto;flex:1}
.modal .ft{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--border)}
.modal-scrim{position:fixed;inset:0;z-index:600;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);padding:16px}
.modal-scrim[aria-hidden="false"]{display:flex}
.modal-card{background:var(--bg-card-solid);border-radius:20px;padding:32px;text-align:center;max-width:440px;width:100%;box-shadow:0 24px 64px rgba(0,0,0,.5)}
.idle-modal-badge{font-size:11px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--amber);margin-bottom:14px}
.idle-timer-row{display:flex;justify-content:center;gap:14px;align-items:center;margin:18px 0}
.idle-timer{font-size:32px;font-weight:900;color:var(--rose);font-family:'JetBrains Mono',monospace}
.modal-actions{display:flex;gap:12px;justify-content:center;margin-top:18px}

/* --- DIVIDERS --- */
.hr{height:1px;background:var(--border);margin:14px 0}
.dashboard-divider{height:1px;background:var(--border);margin:18px 0}

/* --- KV --- */
.kv{display:flex;justify-content:space-between;padding:8px 0;font-size:13px;border-bottom:1px solid var(--border)}
.kv:last-child{border-bottom:none}

/* --- TILE --- */
.tile{padding:16px;border-radius:12px;background:var(--bg-glass);border:1px solid var(--border);transition:all .2s}
.tile:hover{background:var(--bg-hover);border-color:var(--border2)}

/* --- DASHBOARD --- */
.dashboard-hero{display:grid;grid-template-columns:1.5fr 1fr;gap:28px;margin:20px 28px 0;padding:32px;position:relative;overflow:hidden}
.dashboard-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(110,86,255,.05) 0%,transparent 60%);pointer-events:none}
.dashboard-hero__eyebrow{font-size:10px;font-weight:900;letter-spacing:2px;text-transform:uppercase;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:10px}
.dashboard-hero h1{font-size:24px;font-weight:900;line-height:1.35;letter-spacing:-.3px}
.dashboard-hero p{color:var(--muted);font-size:13px;margin-top:8px;line-height:1.7}
.dashboard-hero__chips{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.dashboard-hero__aside{display:flex;flex-direction:column;gap:12px}
.dashboard-hero__card{padding:20px;border-radius:14px;background:var(--bg-glass);border:1px solid var(--border);transition:all .3s}
.dashboard-hero__card:hover{border-color:var(--border2)}
.dashboard-hero__card strong{font-size:28px;font-weight:900;display:block;margin-bottom:6px}
.dashboard-hero__card span{font-size:12px;color:var(--muted)}
.dashboard-hero__card.is-accent{border-color:var(--border-glow);background:var(--accent-soft)}
.dashboard-hero__card.is-accent strong{background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
@media(max-width:900px){.dashboard-hero{grid-template-columns:1fr}}

.dashboard-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;padding:0 28px;margin-top:20px}
@media(max-width:1000px){.dashboard-grid{grid-template-columns:1fr}}
.dashboard-side-stack{display:flex;flex-direction:column;gap:20px}

.admin-section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px}
.admin-section-head h2{font-size:17px;font-weight:900}
.admin-section-head h3{font-size:14px;font-weight:800}
.admin-section-head--compact{margin-bottom:12px}

.dashboard-recent-list{display:flex;flex-direction:column;gap:8px}
.dashboard-recent-item{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-radius:10px;background:var(--bg-glass);border:1px solid var(--border);gap:10px;flex-wrap:wrap;transition:all .2s}
.dashboard-recent-item:hover{border-color:var(--border2);background:var(--bg-hover)}
.dashboard-recent-item__main{display:flex;flex-direction:column;gap:2px}
.dashboard-recent-item__main strong{font-size:13px;font-weight:700}
.dashboard-recent-item__main span{font-size:12px;color:var(--muted)}
.dashboard-recent-item__meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

.dashboard-trend-list{display:flex;flex-direction:column;gap:10px}
.dashboard-trend-item__head{display:flex;justify-content:space-between;font-size:13px;font-family:'JetBrains Mono',monospace}
.dashboard-trend-item__bar{height:6px;border-radius:3px;background:var(--border);margin-top:6px;overflow:hidden}
.dashboard-trend-item__bar span{display:block;height:100%;background:var(--gradient-1);border-radius:3px;transition:width .8s cubic-bezier(.4,0,.2,1)}

.dashboard-quick-links{display:flex;gap:8px;flex-wrap:wrap}

/* --- PAGE ACTIONS --- */
.page-actions{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;padding:16px 28px;flex-wrap:wrap}
.apps-filter{display:flex;flex-direction:column;gap:12px}
.apps-filter-row{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}

/* --- EMPTY STATE --- */
.admin-empty-state{text-align:center;padding:48px 20px;color:var(--muted);font-size:14px;font-weight:600}

/* --- APPOINTMENTS --- */
.appointments-shell{padding:0 28px}
.appointments-hero{margin:20px 0 0;padding:32px;display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap}
.appointments-hero h1{font-size:22px;font-weight:900}
.appointments-hero p{color:var(--muted);font-size:13px;margin-top:8px;max-width:500px}
.appointments-hero__meta{display:flex;gap:8px;flex-wrap:wrap}
.appointments-panel{margin-top:20px}
.appointments-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:16px}

/* --- NOTE COL --- */
.note-col{max-width:180px}
.note-snippet{font-size:12px;max-height:40px;overflow:hidden;text-overflow:ellipsis}

/* --- USERS PAGE --- */
.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-top:16px}
.user-card{padding:22px;border-radius:14px;background:var(--bg-card);backdrop-filter:var(--glass-blur);border:1px solid var(--border);display:flex;flex-direction:column;gap:10px;transition:all .3s}
.user-card:hover{border-color:var(--border2);transform:translateY(-2px)}
.user-card__head{display:flex;justify-content:space-between;align-items:center}
.user-card__name{font-weight:800;font-size:16px}
.user-card__meta{font-size:12px;color:var(--muted);font-family:'JetBrains Mono',monospace}

/* --- TOAST --- */
.toast-container{position:fixed;top:20px;right:20px;z-index:9000;display:flex;flex-direction:column;gap:10px}
.toast{padding:14px 22px;border-radius:12px;font-size:13px;font-weight:700;color:#fff;animation:toastIn .4s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 32px rgba(0,0,0,.3);backdrop-filter:blur(8px)}
.toast.success{background:linear-gradient(135deg,#059669,#34d399)}
.toast.error{background:linear-gradient(135deg,#e11d48,#fb7185)}
.toast.info{background:linear-gradient(135deg,#2563eb,#60a5fa)}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

/* --- LOGIN --- */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px;position:relative;overflow:hidden}
.login-page::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at 30% 30%,rgba(110,86,255,.08) 0%,transparent 50%),radial-gradient(ellipse at 70% 70%,rgba(96,165,250,.06) 0%,transparent 50%);animation:loginBg 20s ease-in-out infinite alternate;pointer-events:none}
@keyframes loginBg{0%{transform:translate(0,0)}100%{transform:translate(-5%,-5%)}}
.login-card{width:100%;max-width:420px;background:var(--bg-card);backdrop-filter:var(--glass-blur);border:1px solid var(--border);border-radius:20px;padding:40px 36px;box-shadow:var(--shadow);position:relative;z-index:1}
.login-card h1{font-size:26px;font-weight:900;text-align:center;margin-bottom:6px;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.login-card .sub{text-align:center;color:var(--muted);font-size:13px;margin-bottom:28px}
.login-error{background:var(--rose-soft);color:var(--rose);padding:12px 16px;border-radius:10px;font-size:13px;font-weight:600;margin-bottom:16px;border:1px solid rgba(251,113,133,.2)}

/* --- ANIMATIONS --- */
@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.card,.admin-stat-card,.tile,.dashboard-recent-item{animation:fadeInUp .4s ease both}

/* --- RESPONSIVE --- */
@media(max-width:900px){
  .admin-nav{position:fixed;left:0;top:0;bottom:0;transform:translateX(-100%);z-index:200;backdrop-filter:var(--glass-blur)}
  .admin-nav.open{transform:translateX(0)}
  .admin-nav-toggle{display:block!important}
  .admin-surface-card{margin:0 14px}
  .admin-top{padding:16px 14px 0}
  .admin-stat-grid{padding:16px 14px}
  .dashboard-hero{margin:14px 14px 0}
  .dashboard-grid{padding:0 14px}
  .apps-segmented{padding:0 14px}
  .page-actions{padding:16px 14px}
  .appointments-shell{padding:0 14px}
  .admin-topbar{padding:14px 16px}
}
