/* ============================================================
   MiME Go Admin — Theme CSS
   Brand: Deep Purple #6B21D6 → Blue #2563EB → Cyan #00B4D8
   Health: Teal #0EA5A0 → Green #10B981
   ============================================================ */
:root {
  --mime-purple:      #6B21D6;
  --mime-purple-dark: #4A0FA8;
  --mime-blue:        #2563EB;
  --mime-cyan:        #00B4D8;
  --mime-cyan-b:      #22D3EE;
  --health-p:         #0EA5A0;
  --health-g:         linear-gradient(135deg,#0EA5A0,#10B981);
  --health-light:     rgba(14,165,160,0.12);
  --health-border:    rgba(14,165,160,0.25);
  --sidebar-bg:       #130B2E;
  --sidebar-border:   rgba(107,33,214,0.25);
  --sidebar-w:        256px;
  --bg-base:          #0F0A24;
  --bg-card:          #1A1035;
  --border-c:         rgba(107,33,214,0.2);
  --border-s:         rgba(255,255,255,0.06);
  --text-p:           #F0EBFF;
  --text-s:           #9B8EC4;
  --text-m:           #5E4F8A;
  --accent-g:         #10B981;
  --accent-a:         #F59E0B;
  --accent-r:         #EF4444;
  --accent-b:         #38BDF8;
  --grad-brand:       linear-gradient(135deg,#6B21D6 0%,#2563EB 60%,#00B4D8 100%);
  --grad-glow:        radial-gradient(ellipse at 50% 0%,rgba(107,33,214,0.35) 0%,transparent 65%);
  --shadow-card:      0 4px 24px rgba(0,0,0,0.4),0 1px 0 rgba(107,33,214,0.15);
  --topbar-bg:        rgba(19,11,46,0.92);
  --table-head-bg:    rgba(255,255,255,0.025);
  --table-row-border: rgba(255,255,255,0.04);
  --input-bg:         rgba(255,255,255,0.04);
  --input-bg-focus:   rgba(107,33,214,0.07);
  --mg-tabs-bg:       rgba(255,255,255,0.03);
  --stat-change-flat: rgba(255,255,255,0.05);
  --mg-progress-bg:   rgba(255,255,255,0.06);
  --toggle-track:     rgba(255,255,255,0.1);
  --doc-preview-bg:   rgba(255,255,255,0.03);
  --rbac-off-bg:      rgba(255,255,255,0.06);
  --rbac-off-border:  rgba(255,255,255,0.1);
  --nav-active-color: #fff;
  --logo-mark-shadow: 0 0 16px rgba(107,33,214,0.5);
  --r-sm: 6px; --r-md: 10px; --r-lg: 16px;
  --font-d: 'Outfit',sans-serif;
  --font-b: 'DM Sans',sans-serif;
  --tr: 0.18s cubic-bezier(0.4,0,0.2,1);
}

[data-theme="light"] {
  color-scheme: light;
  --sidebar-bg:       #f4f1fb;
  --sidebar-border:   rgba(107,33,214,0.14);
  --bg-base:          #e8e4f2;
  --bg-card:          #ffffff;
  --border-c:         rgba(107,33,214,0.16);
  --border-s:         rgba(22,16,48,0.1);
  --text-p:           #14101f;
  --text-s:           #3f3656;
  --text-m:           #5b5370;
  --health-light:     rgba(14,165,160,0.14);
  --health-border:    rgba(14,165,160,0.35);
  --grad-glow:        radial-gradient(ellipse at 50% 0%, rgba(107,33,214,0.12), transparent 70%);
  --shadow-card:      0 2px 14px rgba(22,16,48,0.07), 0 1px 0 rgba(107,33,214,0.06);
  --topbar-bg:        rgba(255,255,255,0.88);
  --table-head-bg:    rgba(107,33,214,0.06);
  --table-row-border: rgba(22,16,48,0.07);
  --input-bg:         #f3f1f8;
  --input-bg-focus:   #ede8f7;
  --mg-tabs-bg:       rgba(107,33,214,0.06);
  --stat-change-flat: rgba(22,16,48,0.06);
  --mg-progress-bg:   rgba(22,16,48,0.08);
  --toggle-track:     rgba(22,16,48,0.12);
  --doc-preview-bg:   rgba(107,33,214,0.04);
  --rbac-off-bg:      rgba(22,16,48,0.06);
  --rbac-off-border:  rgba(22,16,48,0.12);
  --nav-active-color: #fff;
  --logo-mark-shadow: 0 4px 14px rgba(107,33,214,0.25);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);font-size:14px;background:var(--bg-base);color:var(--text-p);min-height:100vh;min-height:100dvh;overflow-x:hidden;
  padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0)}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(107,33,214,0.4);border-radius:99px}
[data-theme="light"] ::-webkit-scrollbar-thumb{background:rgba(107,33,214,0.35)}
a{text-decoration:none;color:inherit}
h1,h2,h3,h4,h5,h6{font-family:var(--font-d)}

/* LAYOUT */
.admin-shell{display:flex;min-height:100vh}
.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100vh;display:flex;flex-direction:column}
.page-container{flex:1;padding:24px;min-width:0;width:100%}

/* SIDEBAR */
.sidebar{width:var(--sidebar-w);min-height:100vh;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100;overflow:hidden;transition:width var(--tr)}
.sidebar::before{content:'';position:absolute;top:0;left:0;right:0;height:280px;background:var(--grad-glow);pointer-events:none;z-index:0}

.sidebar-logo{padding:20px 18px 16px;border-bottom:1px solid var(--sidebar-border);display:flex;align-items:center;gap:11px;position:relative;z-index:1;flex-shrink:0}
.logo-mark{width:36px;height:36px;border-radius:var(--r-md);background:var(--grad-brand);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-d);font-weight:800;font-size:14px;color:white;box-shadow:var(--logo-mark-shadow)}
.logo-text .brand-name{font-family:var(--font-d);font-weight:800;font-size:17px;color:var(--text-p);letter-spacing:-0.3px}
.logo-text .brand-name span{color:var(--mime-cyan-b)}
.logo-text .brand-sub{font-size:9.5px;color:var(--text-m);font-weight:500;letter-spacing:1.5px;text-transform:uppercase}

.sidebar-nav{flex:1;overflow-y:auto;padding:10px 0;position:relative;z-index:1}
.nav-section-label{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-m);padding:14px 18px 5px;display:block}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 12px 8px 16px;margin:1px 8px;border-radius:var(--r-md);cursor:pointer;transition:all var(--tr);font-size:13px;font-weight:500;color:var(--text-s);white-space:nowrap;position:relative}
.nav-item:hover{background:rgba(107,33,214,0.15);color:var(--text-p)}
.nav-item.active{background:linear-gradient(135deg,rgba(107,33,214,0.3),rgba(37,99,235,0.2));color:var(--nav-active-color);box-shadow:inset 0 0 0 1px rgba(107,33,214,0.4)}
.nav-item.active::before{content:'';position:absolute;left:0;top:20%;bottom:20%;width:3px;background:var(--grad-brand);border-radius:0 3px 3px 0}
.nav-icon{width:17px;font-size:14px;text-align:center;flex-shrink:0}
.nav-label{flex:1}
.nav-badge{font-size:10px;font-weight:700;padding:2px 6px;border-radius:99px;background:var(--mime-purple);color:white;line-height:1.4}
.nav-badge.danger{background:var(--accent-r)}
.nav-badge.success{background:var(--accent-g)}
.nav-badge.amber{background:var(--accent-a);color:#111}
.health-tag{font-size:9px;font-weight:700;padding:2px 6px;border-radius:99px;background:var(--health-light);color:#2DD4BF;border:1px solid var(--health-border);white-space:nowrap}
.nav-arrow{font-size:10px;transition:transform 0.2s;color:var(--text-m);margin-left:auto}
.nav-item.open .nav-arrow{transform:rotate(90deg)}
.nav-submenu{overflow:hidden;max-height:0;transition:max-height 0.3s ease}
.nav-submenu.open{max-height:400px}
.nav-sub-item{display:flex;align-items:center;gap:8px;padding:7px 16px 7px 44px;margin:1px 8px;border-radius:var(--r-md);font-size:12.5px;color:var(--text-m);cursor:pointer;transition:all var(--tr)}
.nav-sub-item:hover{color:var(--text-p);background:rgba(107,33,214,0.1)}
.nav-sub-item.active{color:var(--mime-cyan-b)}
[data-theme="light"] .nav-sub-item.active{color:var(--mime-purple-dark)}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--accent-g);animation:pulseDot 1.6s ease infinite}
@keyframes pulseDot{0%,100%{opacity:1}50%{opacity:.4}}

.sidebar-footer{padding:12px;border-top:1px solid var(--sidebar-border);position:relative;z-index:1;flex-shrink:0}
.user-card{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:var(--r-md);background:rgba(107,33,214,0.1);border:1px solid var(--border-c);cursor:pointer;transition:all var(--tr)}
.user-card:hover{background:rgba(107,33,214,0.2)}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--grad-brand);display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-weight:700;font-size:12px;color:white;flex-shrink:0}
.user-name{font-size:12.5px;font-weight:600;color:var(--text-p);line-height:1.2}
.user-role{font-size:10.5px;color:var(--text-m);margin-top:1px}

/* TOPBAR */
.topbar{height:58px;background:var(--topbar-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-s);display:flex;align-items:center;padding:0 22px;gap:14px;position:sticky;top:0;z-index:50}
.topbar-breadcrumb{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--text-m)}
.topbar-breadcrumb .current{color:var(--text-p);font-weight:600;font-family:var(--font-d)}
.topbar-search{flex:1;max-width:320px;min-width:0;position:relative}
@media (min-width:768px) and (max-width:991.98px){
  .topbar-search{max-width:none;flex:1 1 200px;order:3;width:100%}
  .topbar-actions{order:2;margin-left:auto}
}
.topbar-search .bi{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-m);font-size:13px}
.topbar-search input{width:100%;padding:7px 12px 7px 32px;background:var(--input-bg);border:1px solid var(--border-s);border-radius:var(--r-md);color:var(--text-p);font-size:12.5px;font-family:var(--font-b);outline:none;transition:all var(--tr)}
.topbar-search input::placeholder{color:var(--text-m)}
.topbar-search input:focus{border-color:rgba(107,33,214,0.5);background:var(--input-bg-focus);box-shadow:0 0 0 3px rgba(107,33,214,0.1)}
.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:4px}
.topbar-btn{width:36px;height:36px;border-radius:var(--r-md);background:transparent;border:1px solid transparent;color:var(--text-s);display:flex;align-items:center;justify-content:center;font-size:15px;cursor:pointer;transition:all var(--tr);position:relative}
.topbar-btn:hover{background:rgba(107,33,214,0.15);border-color:var(--border-c);color:var(--text-p)}
.topbar-badge{position:absolute;top:4px;right:4px;width:8px;height:8px;background:var(--accent-r);border-radius:50%;border:2px solid var(--bg-card)}
.topbar-divider{width:1px;height:20px;background:var(--border-s);margin:0 3px}
.topbar-user-dropdown{position:relative}
.topbar-user-dropdown .topbar-user-toggle{display:flex;align-items:center;justify-content:center;padding:0;line-height:1;box-shadow:none}
.topbar-user-dropdown .topbar-user-toggle:focus-visible{outline:2px solid rgba(107,33,214,0.5);outline-offset:2px}
.mime-user-menu{min-width:228px;padding:6px 0;background:var(--bg-card);border-color:var(--border-s)!important}
.mime-user-menu .dropdown-header{background:transparent;border:0;padding:8px 14px 6px;font-size:12px}
.mime-user-menu .dropdown-item{color:var(--text-p);font-size:13px;padding:8px 14px;display:flex;align-items:center;gap:8px}
.mime-user-menu .dropdown-item:hover,.mime-user-menu .dropdown-item:focus{background:rgba(107,33,214,0.14);color:var(--text-p)}
.mime-user-menu .dropdown-item.text-danger{color:var(--accent-r)!important}
.mime-user-menu .dropdown-item.text-danger:hover,.mime-user-menu .dropdown-item.text-danger:focus{background:rgba(239,68,68,0.12);color:var(--accent-r)!important}
.mime-user-menu .dropdown-divider{border-color:var(--border-s);opacity:1;margin:6px 0}
.mime-user-menu form.dropdown-item-form{padding:0;margin:0}
.mime-user-menu form.dropdown-item-form button.dropdown-item{border:0;background:transparent;width:100%;text-align:left}
[data-theme="light"] .mime-user-menu .dropdown-item:hover,[data-theme="light"] .mime-user-menu .dropdown-item:focus{background:rgba(107,33,214,0.1)}

/* CARDS */
.mg-card{background:var(--bg-card);border:1px solid var(--border-c);border-radius:var(--r-lg);box-shadow:var(--shadow-card);transition:all var(--tr)}
.mg-card:hover{border-color:rgba(107,33,214,0.4)}
.mg-card .card-header{padding:14px 18px;border-bottom:1px solid var(--border-s);background:transparent;display:flex;align-items:center;justify-content:space-between;gap:10px}
.card-title{font-family:var(--font-d);font-size:14.5px;font-weight:600;color:var(--text-p)}
.mg-card .card-body{padding:18px}

/* STAT CARDS */
.stat-card{background:var(--bg-card);border:1px solid var(--border-c);border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow-card);transition:all var(--tr);position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;border-radius:var(--r-lg) var(--r-lg) 0 0}
.stat-card.purple::before{background:var(--grad-brand)}
.stat-card.green::before{background:linear-gradient(90deg,#10B981,#34D399)}
.stat-card.amber::before{background:linear-gradient(90deg,#F59E0B,#FCD34D)}
.stat-card.red::before{background:linear-gradient(90deg,#EF4444,#F87171)}
.stat-card.cyan::before{background:linear-gradient(90deg,#00B4D8,#67E8F9)}
.stat-card.blue::before{background:linear-gradient(90deg,#2563EB,#60A5FA)}
.stat-card.teal::before{background:var(--health-g)}
.stat-card:hover{border-color:rgba(107,33,214,0.45);transform:translateY(-1px);box-shadow:0 0 30px rgba(107,33,214,0.2)}
.stat-icon{width:40px;height:40px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:17px;margin-bottom:12px}
.stat-icon.purple{background:rgba(107,33,214,0.2);color:#A78BFA}
.stat-icon.green{background:rgba(16,185,129,0.15);color:#34D399}
.stat-icon.amber{background:rgba(245,158,11,0.15);color:#FCD34D}
.stat-icon.red{background:rgba(239,68,68,0.15);color:#F87171}
.stat-icon.cyan{background:rgba(0,180,216,0.15);color:var(--mime-cyan-b)}
.stat-icon.blue{background:rgba(37,99,235,0.15);color:#60A5FA}
.stat-icon.teal{background:var(--health-light);color:#2DD4BF}
.stat-value{font-family:var(--font-d);font-size:24px;font-weight:700;color:var(--text-p);line-height:1;margin-bottom:3px;letter-spacing:-0.5px}
.stat-label{font-size:11.5px;color:var(--text-s);font-weight:500;margin-bottom:10px}
.stat-change{display:inline-flex;align-items:center;gap:3px;font-size:11.5px;font-weight:600;padding:2px 8px;border-radius:99px}
.stat-change.up{background:rgba(16,185,129,0.12);color:#34D399}
.stat-change.down{background:rgba(239,68,68,0.12);color:#F87171}
.stat-change.flat{background:var(--stat-change-flat);color:var(--text-m)}

/* TABLES */
.mg-table{width:100%;border-collapse:separate;border-spacing:0;font-size:12.5px}
.mg-table th{padding:10px 14px;text-align:left;font-size:10.5px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;color:var(--text-m);background:var(--table-head-bg);border-bottom:1px solid var(--border-s);white-space:nowrap}
.mg-table td{padding:11px 14px;border-bottom:1px solid var(--table-row-border);vertical-align:middle;color:var(--text-s)}
.mg-table tr:last-child td{border-bottom:none}
.mg-table tbody tr:hover td{background:rgba(107,33,214,0.06);color:var(--text-p)}

/* BADGES */
.badge-mg{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:99px;font-size:11px;font-weight:600;white-space:nowrap}
.badge-mg::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}
.badge-mg.success,.badge-mg.active,.badge-mg.issued,.badge-mg.ticketed,.badge-mg.boarded{background:rgba(16,185,129,0.12);color:#34D399;border:1px solid rgba(16,185,129,0.2)}
.badge-mg.danger,.badge-mg.inactive,.badge-mg.expired,.badge-mg.cancelled,.badge-mg.failed{background:rgba(239,68,68,0.1);color:#F87171;border:1px solid rgba(239,68,68,0.2)}
.badge-mg.warning,.badge-mg.pending,.badge-mg.scheduled,.badge-mg.expiring{background:rgba(245,158,11,0.12);color:#FCD34D;border:1px solid rgba(245,158,11,0.2)}
.badge-mg.info,.badge-mg.processing,.badge-mg.on-hold{background:rgba(37,99,235,0.12);color:#60A5FA;border:1px solid rgba(37,99,235,0.2)}
.badge-mg.purple,.badge-mg.draft,.badge-mg.refunded{background:rgba(107,33,214,0.12);color:#A78BFA;border:1px solid rgba(107,33,214,0.2)}
.badge-mg.teal{background:var(--health-light);color:#2DD4BF;border:1px solid var(--health-border)}

/* BUTTONS */
.btn-mg{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--r-md);font-family:var(--font-b);font-size:12.5px;font-weight:600;cursor:pointer;border:none;transition:all var(--tr);white-space:nowrap}
.btn-mg.primary{background:var(--grad-brand);color:white;box-shadow:0 4px 14px rgba(107,33,214,0.3)}
.btn-mg.primary:hover{box-shadow:0 4px 20px rgba(107,33,214,0.5);transform:translateY(-1px)}
.btn-mg.secondary{background:rgba(107,33,214,0.15);color:#A78BFA;border:1px solid rgba(107,33,214,0.3)}
.btn-mg.secondary:hover{background:rgba(107,33,214,0.25)}
.btn-mg.ghost{background:transparent;color:var(--text-s);border:1px solid var(--border-s)}
.btn-mg.ghost:hover{background:rgba(255,255,255,0.05);color:var(--text-p)}
.btn-mg.danger{background:rgba(239,68,68,0.15);color:#F87171;border:1px solid rgba(239,68,68,0.3)}
.btn-mg.danger:hover{background:rgba(239,68,68,0.25)}
.btn-mg.success{background:rgba(16,185,129,0.15);color:#34D399;border:1px solid rgba(16,185,129,0.3)}
.btn-mg.health{background:var(--health-g);color:white;box-shadow:0 4px 14px rgba(14,165,160,0.3)}
.btn-mg.sm{padding:6px 12px;font-size:11.5px}
.btn-mg.xs{padding:4px 9px;font-size:11px;border-radius:var(--r-sm)}

/* FORM */
.mg-input,.mg-select{background:var(--input-bg);border:1px solid var(--border-s);border-radius:var(--r-md);color:var(--text-p);font-size:12.5px;font-family:var(--font-b);padding:8px 12px;outline:none;width:100%;transition:all var(--tr);-webkit-appearance:none}
.mg-input::placeholder{color:var(--text-m)}
.mg-input:focus,.mg-select:focus{border-color:rgba(107,33,214,0.6);background:var(--input-bg-focus);box-shadow:0 0 0 3px rgba(107,33,214,0.1)}
.mg-label{font-size:11.5px;font-weight:600;color:var(--text-s);margin-bottom:5px;display:block}
.form-group{margin-bottom:14px}

/* TABS */
.mg-tabs{display:flex;gap:2px;background:var(--mg-tabs-bg);border-radius:var(--r-md);padding:3px;border:1px solid var(--border-s);width:fit-content}
.mg-tab{padding:6px 14px;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;transition:all var(--tr);color:var(--text-m);white-space:nowrap}
.mg-tab:hover{color:var(--text-p)}
.mg-tab.active{background:var(--grad-brand);color:white;box-shadow:0 2px 8px rgba(107,33,214,0.3)}

/* PROGRESS */
.mg-progress{height:5px;background:var(--mg-progress-bg);border-radius:99px;overflow:hidden}
.mg-progress-bar{height:100%;border-radius:99px;background:var(--grad-brand);transition:width 0.6s ease}
.mg-progress-bar.green{background:linear-gradient(90deg,#10B981,#34D399)}
.mg-progress-bar.amber{background:linear-gradient(90deg,#F59E0B,#FCD34D)}
.mg-progress-bar.red{background:linear-gradient(90deg,#EF4444,#F87171)}
.mg-progress-bar.teal{background:var(--health-g)}

/* AVATARS */
.av{width:30px;height:30px;border-radius:50%;background:var(--grad-brand);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:white;flex-shrink:0}
.av.g{background:linear-gradient(135deg,#10B981,#34D399)}
.av.a{background:linear-gradient(135deg,#F59E0B,#FCD34D)}
.av.r{background:linear-gradient(135deg,#EF4444,#F87171)}
.av.b{background:linear-gradient(135deg,#2563EB,#60A5FA)}
.av.t{background:var(--health-g)}

/* PAGE HEADER */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:22px;gap:14px;flex-wrap:wrap}
.page-title{font-family:var(--font-d);font-size:21px;font-weight:700;color:var(--text-p);line-height:1.2}
.page-subtitle{font-size:12.5px;color:var(--text-s);margin-top:3px}

/* WALLET HERO */
.wallet-hero{background:var(--grad-brand);border-radius:var(--r-lg);padding:22px;position:relative;overflow:hidden}
.wallet-hero::after{content:'';position:absolute;right:-30px;top:-30px;width:130px;height:130px;border-radius:50%;background:rgba(255,255,255,0.07)}
.wallet-hero::before{content:'';position:absolute;right:40px;bottom:-40px;width:90px;height:90px;border-radius:50%;background:rgba(255,255,255,0.05)}

/* HEALTH SPECIFIC */
.api-balance-card{background:linear-gradient(135deg,rgba(14,165,160,0.2),rgba(16,185,129,0.1));border:1px solid rgba(14,165,160,0.3);border-radius:var(--r-lg);padding:18px;position:relative;overflow:hidden}
.api-balance-card::before{content:'INTELLIPROVE';position:absolute;top:11px;right:14px;font-size:8.5px;font-weight:800;letter-spacing:2px;color:rgba(45,212,191,0.3);font-family:var(--font-d)}
.biomarker-card{background:rgba(14,165,160,0.07);border:1px solid rgba(14,165,160,0.18);border-radius:var(--r-md);padding:12px 14px;transition:all var(--tr)}
.biomarker-card:hover{background:rgba(14,165,160,0.14)}
.bm-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#5EEAD4}
.bm-value{font-family:var(--font-d);font-size:20px;font-weight:700;color:var(--text-p);letter-spacing:-0.5px}
.bm-unit{font-size:10.5px;color:var(--text-m)}
.plan-card{background:var(--bg-card);border:1px solid var(--border-c);border-radius:var(--r-lg);padding:20px;transition:all var(--tr);position:relative;overflow:hidden}
.plan-card.featured{border-color:rgba(14,165,160,0.5);box-shadow:0 0 28px rgba(14,165,160,0.1)}
.plan-badge-corner{position:absolute;top:12px;right:12px;font-size:9.5px;font-weight:700;padding:2px 8px;border-radius:99px;background:var(--health-g);color:white}
.plan-price{font-family:var(--font-d);font-size:26px;font-weight:800;color:var(--text-p);letter-spacing:-1px}
.plan-feature{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--text-s);padding:4px 0}
.plan-feature i{color:#2DD4BF;font-size:12px;width:13px}
.plan-feature.off{color:var(--text-m);text-decoration:line-through}
.plan-feature.off i{color:var(--text-m)}

/* NOTIF */
.notif-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-s);align-items:flex-start}
.notif-item:last-child{border-bottom:none}
.notif-dot{width:7px;height:7px;border-radius:50%;margin-top:4px;flex-shrink:0}
.notif-dot.purple{background:var(--mime-purple)}
.notif-dot.green{background:var(--accent-g)}
.notif-dot.amber{background:var(--accent-a)}
.notif-dot.red{background:var(--accent-r)}
.notif-dot.teal{background:var(--health-p)}
.notif-text{font-size:12.5px;color:var(--text-s);line-height:1.5;flex:1}
.notif-text strong{color:var(--text-p);font-weight:600}
.notif-time{font-size:10.5px;color:var(--text-m);white-space:nowrap}

/* PAGINATION */
.mg-pagination{display:flex;align-items:center;gap:4px;padding:12px 16px;border-top:1px solid var(--border-s)}

/* FOOTER */
.page-footer{padding:14px 22px;border-top:1px solid var(--border-s);display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:6px;text-align:center}
.page-footer p{font-size:11.5px;color:var(--text-m);margin:0}
.page-footer span{color:var(--mime-cyan-b);font-weight:600}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp 0.3s ease forwards}
.d1{animation-delay:.05s;opacity:0}.d2{animation-delay:.1s;opacity:0}.d3{animation-delay:.15s;opacity:0}
.d4{animation-delay:.2s;opacity:0}.d5{animation-delay:.25s;opacity:0}.d6{animation-delay:.3s;opacity:0}

/* RBAC */
.rbac-cell{width:22px;height:22px;border-radius:5px;margin:0 auto;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;font-size:11px;color:white}
.rbac-cell.on{background:linear-gradient(135deg,#6B21D6,#2563EB);border:1px solid rgba(107,33,214,0.5)}
.rbac-cell.off{background:var(--rbac-off-bg);border:1px solid var(--rbac-off-border)}

/* MODAL OVERLAY */
.mg-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center}
.mg-modal{background:var(--bg-card);border:1px solid var(--border-c);border-radius:var(--r-lg);padding:24px;width:90%;max-width:520px;box-shadow:0 20px 60px rgba(0,0,0,0.5)}
.mg-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.mg-modal-title{font-family:var(--font-d);font-size:16px;font-weight:700;color:var(--text-p)}
.mg-modal-close{background:transparent;border:none;color:var(--text-m);font-size:20px;cursor:pointer;line-height:1}

/* TOGGLE SWITCH */
.mg-toggle{display:flex;align-items:center;gap:8px;cursor:pointer}
.toggle-track{width:36px;height:20px;background:var(--toggle-track);border-radius:99px;position:relative;transition:all .2s}
.toggle-track.on{background:var(--accent-g)}
.toggle-thumb{width:14px;height:14px;background:white;border-radius:50%;position:absolute;top:3px;left:3px;transition:all .2s}
.toggle-track.on .toggle-thumb{left:19px}

/* ——— Sidebar overlay (mobile / < lg) ——— */
.sidebar-backdrop{
  display:none;position:fixed;inset:0;z-index:90;
  background:rgba(0,0,0,.48);backdrop-filter:blur(3px);
  -webkit-tap-highlight-color:transparent;
}
.sidebar-backdrop.show{display:block}
@media (min-width:992px){
  .sidebar-backdrop{display:none!important}
}

@media (max-width:991.98px){
  .sidebar{
    transform:translateX(-100%);
    width:min(288px,88vw);
    box-shadow:none;
    transition:transform .25s ease,box-shadow .25s ease;
    padding-bottom:env(safe-area-inset-bottom,0);
  }
  .sidebar.open{
    transform:translateX(0);
    box-shadow:16px 0 48px rgba(0,0,0,.45);
  }
  .main-content{margin-left:0;width:100%;min-width:0}
  .topbar{
    padding:10px max(12px,env(safe-area-inset-left)) 10px max(12px,env(safe-area-inset-right));
    flex-wrap:wrap;row-gap:8px;height:auto;min-height:56px;
  }
  .page-container{padding:16px max(12px,env(safe-area-inset-left)) 20px max(12px,env(safe-area-inset-right))}
  .page-title{font-size:clamp(1.1rem,4vw,1.35rem)}
  .stat-value{font-size:clamp(1.15rem,5vw,1.5rem)}
  .page-footer{flex-direction:column;align-items:center;text-align:center}
  .mg-table{min-width:520px}
}

@media (max-width:575.98px){
  .page-container{padding:12px max(10px,env(safe-area-inset-left)) 16px max(10px,env(safe-area-inset-right))}
  .mg-card .card-header{flex-direction:column;align-items:stretch!important}
  .mg-card .card-header .d-flex.gap-2{flex-wrap:wrap}
  .mg-tabs{width:100%;overflow-x:auto;flex-wrap:nowrap;max-width:100%}
  .mg-tab{flex:0 0 auto}
  .btn-mg{max-width:100%;justify-content:center}
  .mg-pagination{flex-direction:column;align-items:stretch!important;gap:10px}
  .mg-pagination .ms-auto{margin-left:0!important}
}

/* Tables: horizontal scroll inside cards (mobile-first) */
.mg-card .card-body:has(.mg-table){
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  overscroll-behavior-x:contain;
}

/* RBAC matrix */
.mg-card .card-body:has(#rbac-body){
  overflow-x:auto;-webkit-overflow-scrolling:touch;
}

/* Chart container */
.chart-wrap{position:relative;width:100%}

/* KYC doc preview */
.doc-preview{background:var(--doc-preview-bg);border:1px dashed var(--border-c);border-radius:var(--r-md);padding:14px;text-align:center;color:var(--text-m);font-size:12px}

/* Settings card */
.setting-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border-s)}
.setting-row:last-child{border-bottom:none}
.setting-label{font-size:13px;font-weight:500;color:var(--text-p)}
.setting-desc{font-size:11.5px;color:var(--text-m);margin-top:2px}

/* ——— Light theme: contrast tweaks (brand colors unchanged) ——— */
[data-theme="light"] .btn-mg.secondary{
  color:var(--mime-purple-dark);
  border-color:rgba(107,33,214,0.28);
  background:rgba(107,33,214,0.1);
}
[data-theme="light"] .btn-mg.secondary:hover{background:rgba(107,33,214,0.16)}
[data-theme="light"] .btn-mg.ghost:hover{background:rgba(107,33,214,0.06)}
[data-theme="light"] .stat-icon.purple{background:rgba(107,33,214,0.12);color:var(--mime-purple-dark)}
[data-theme="light"] .nav-item:hover{background:rgba(107,33,214,0.08)}
[data-theme="light"] .nav-item.active{
  background:linear-gradient(135deg,rgba(107,33,214,0.88),rgba(37,99,235,0.75));
  color:#fff;
  box-shadow:inset 0 0 0 1px rgba(107,33,214,0.35);
}
[data-theme="light"] .mg-card:hover{border-color:rgba(107,33,214,0.28)}
[data-theme="light"] .health-tag{color:#0f766e;border-color:rgba(14,165,160,0.35)}
[data-theme="light"] .api-balance-card::before{color:rgba(14,165,160,0.28)}
[data-theme="light"] .sidebar.open{box-shadow:16px 0 40px rgba(22,16,48,.1)}
[data-theme="light"] .sidebar-backdrop{background:rgba(22,16,48,.22)}
[data-theme="light"] .mg-modal{box-shadow:0 20px 50px rgba(22,16,48,.12)}
[data-theme="light"] .wallet-hero{color:#fff}
[data-theme="light"] .bm-label{color:#0d9488}
[data-theme="light"] .plan-card.featured{box-shadow:0 0 24px rgba(14,165,160,0.15)}
[data-theme="light"] .topbar-btn:hover{background:rgba(107,33,214,0.1)}
[data-theme="light"] .user-card{background:rgba(107,33,214,0.08)}
[data-theme="light"] .user-card:hover{background:rgba(107,33,214,0.12)}
[data-theme="light"] .page-footer span{color:var(--mime-purple)}
