/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#0D1B3E;--navy2:#162040;--blue:#1A56DB;--blue-l:#2563EB;--blue-xl:#EFF6FF;
  --green:#16A34A;--green-l:#DCFCE7;--red:#DC2626;--red-l:#FEE2E2;
  --amber:#D97706;--amber-l:#FEF3C7;
  --gray-50:#F8FAFC;--gray-100:#F1F5F9;--gray-200:#E2E8F0;
  --gray-400:#94A3B8;--gray-500:#64748B;--gray-700:#334155;--gray-900:#0F172A;
  --white:#FFFFFF;
  --sidebar-w:240px;--topbar-h:56px;--radius:10px;
  --shadow:0 1px 4px rgba(0,0,0,.08),0 4px 16px rgba(0,0,0,.06);
  --shadow-md:0 4px 24px rgba(0,0,0,.12);
}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--gray-50);color:var(--gray-900);font-size:14px;line-height:1.5}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:inherit;border:none;outline:none}
input,select,textarea{font-family:inherit;outline:none;border:none}
ul{list-style:none}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:99px}

/* ===== LOGIN ===== */
#loginPage{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#EEF2FF}
.login-card{background:var(--white);border-radius:16px;padding:48px 40px;width:100%;max-width:440px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;align-items:center}
.login-logo{width:52px;height:52px;margin-bottom:16px}
.login-logo svg{width:48px;height:48px}
.login-brand{font-size:24px;font-weight:800;letter-spacing:.08em;color:var(--navy)}
.login-sub{font-size:11px;letter-spacing:.2em;color:var(--gray-500);margin-top:4px;margin-bottom:32px}
.form-group{width:100%;margin-bottom:16px}
.form-group label{display:block;font-size:13px;font-weight:500;color:var(--gray-700);margin-bottom:6px}
.input-wrap{display:flex;align-items:center;gap:10px;border:1.5px solid var(--gray-200);border-radius:var(--radius);padding:10px 14px;background:var(--gray-50);transition:border .2s}
.input-wrap:focus-within{border-color:var(--blue);background:var(--white)}
.input-wrap svg{color:var(--gray-400);flex-shrink:0}
.input-wrap input{flex:1;background:transparent;font-size:14px;color:var(--gray-900)}
.input-wrap input::placeholder{color:var(--gray-400)}
.eye-btn{background:none;color:var(--gray-400);display:flex;align-items:center}
.btn-primary{width:100%;padding:12px;border-radius:var(--radius);background:var(--blue);color:var(--white);font-size:13px;font-weight:700;letter-spacing:.1em;transition:background .2s,transform .1s;margin-top:8px}
.btn-primary:hover{background:var(--blue-l)}
.btn-primary:active{transform:scale(.98)}
.login-footer{display:flex;justify-content:space-between;width:100%;margin-top:20px;font-size:13px}
.login-footer a{color:var(--blue)}
.login-version{margin-top:28px;font-size:12px;color:var(--gray-400);display:flex;align-items:center;gap:6px}
.login-error{width:100%;background:var(--red-l);border:1px solid #FCA5A5;border-radius:8px;padding:10px 14px;color:var(--red);font-size:13px;display:none;margin-bottom:8px}

/* ===== APP SHELL ===== */
#appShell{display:none;height:100vh;overflow:hidden}

/* SIDEBAR */
.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:var(--navy);display:flex;flex-direction:column;z-index:100}
.sidebar-brand{padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.08)}
.brand-name{font-size:18px;font-weight:800;color:var(--white);letter-spacing:.06em}
.brand-sub{font-size:9px;letter-spacing:.18em;color:rgba(255,255,255,.4);margin-top:2px}
.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;color:rgba(255,255,255,.55);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,color .15s;margin-bottom:2px}
.nav-item:hover{background:rgba(255,255,255,.07);color:rgba(255,255,255,.85)}
.nav-item.active{background:var(--blue);color:var(--white)}
.nav-item svg{flex-shrink:0;width:17px;height:17px}
.sidebar-bottom{padding:12px;border-top:1px solid rgba(255,255,255,.08)}

/* TOPBAR */
.topbar{position:fixed;left:var(--sidebar-w);right:0;top:0;height:var(--topbar-h);background:var(--white);border-bottom:1px solid var(--gray-200);display:flex;align-items:center;gap:12px;padding:0 24px;z-index:99}
.search-bar{flex:1;max-width:420px;display:flex;align-items:center;gap:8px;background:var(--gray-100);border-radius:8px;padding:8px 14px;border:1.5px solid transparent;transition:border .2s,background .2s}
.search-bar:focus-within{border-color:var(--blue);background:var(--white)}
.search-bar input{flex:1;background:transparent;font-size:13px;color:var(--gray-900)}
.search-bar input::placeholder{color:var(--gray-400)}
.topbar-right{display:flex;align-items:center;gap:16px;margin-left:auto}
.icon-btn{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--gray-500);position:relative;cursor:pointer;border:none}
.icon-btn:hover{background:var(--gray-100)}
.notif-badge{position:absolute;top:4px;right:4px;width:8px;height:8px;background:var(--red);border-radius:50%;border:2px solid var(--white)}
.user-chip{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--gray-700);cursor:pointer;padding:4px 8px;border-radius:8px;transition:background .15s}
.user-chip:hover{background:var(--gray-100)}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;color:var(--white);font-size:12px;font-weight:700}
.logout-btn{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--gray-400);transition:color .15s,background .15s;border:none;cursor:pointer}
.logout-btn:hover{color:var(--red);background:var(--red-l)}

/* MAIN */
.main{margin-left:var(--sidebar-w);margin-top:var(--topbar-h);padding:28px;overflow-y:auto;height:calc(100vh - var(--topbar-h))}

/* ===== SHARED ===== */
.card{background:var(--white);border-radius:var(--radius);border:1px solid var(--gray-200);box-shadow:var(--shadow)}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}
.page-title{font-size:22px;font-weight:700;color:var(--gray-900)}
.page-sub{font-size:13px;color:var(--gray-500);margin-top:3px}
.page-actions{display:flex;gap:10px;flex-shrink:0}
.btn-secondary{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:8px;background:var(--white);border:1.5px solid var(--gray-200);color:var(--gray-700);font-size:13px;font-weight:500;transition:background .15s;cursor:pointer}
.btn-secondary:hover{background:var(--gray-50)}
.btn-blue{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:8px;background:var(--blue);color:var(--white);font-size:13px;font-weight:600;transition:background .15s;cursor:pointer;border:none}
.btn-blue:hover{background:var(--blue-l)}
.btn-dark{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:8px;background:var(--navy);color:var(--white);font-size:13px;font-weight:600;cursor:pointer;border:none}
.btn-dark:hover{background:var(--navy2)}
.btn-red{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:8px;background:var(--red-l);color:var(--red);font-size:13px;font-weight:600;cursor:pointer;border:none}
.btn-red:hover{background:#FECACA}
.btn-edit{padding:5px 11px;border-radius:6px;background:var(--blue-xl);color:var(--blue);font-size:12px;font-weight:600;cursor:pointer;border:none;display:inline-flex;align-items:center;gap:4px}
.btn-edit:hover{background:#DBEAFE}
.btn-del{padding:5px 11px;border-radius:6px;background:var(--red-l);color:var(--red);font-size:12px;font-weight:600;cursor:pointer;border:none;display:inline-flex;align-items:center;gap:4px}
.btn-del:hover{background:#FECACA}

/* BADGES */
.badge-green{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;background:var(--green-l);color:var(--green);font-size:12px;font-weight:600}
.badge-red{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;background:var(--red-l);color:var(--red);font-size:12px;font-weight:600}
.badge-gray{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;background:var(--gray-100);color:var(--gray-500);font-size:12px;font-weight:600}
.badge-amber{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;background:var(--amber-l);color:var(--amber);font-size:12px;font-weight:600}

/* TABLE */
.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
thead tr{border-bottom:1.5px solid var(--gray-200)}
th{text-align:left;font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--gray-500);padding:10px 16px;white-space:nowrap;text-transform:uppercase}
td{padding:13px 16px;font-size:13px;color:var(--gray-700);border-bottom:1px solid var(--gray-100);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:var(--gray-50)}
.tbl-footer{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-top:1px solid var(--gray-100)}
.tbl-footer span{font-size:13px;color:var(--gray-500)}

/* PAGINATION */
.pagination{display:flex;align-items:center;gap:4px}
.pg-btn{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;background:var(--white);border:1.5px solid var(--gray-200);color:var(--gray-700);cursor:pointer;transition:all .15s}
.pg-btn.active{background:var(--blue);border-color:var(--blue);color:var(--white)}
.pg-btn:hover:not(.active){background:var(--gray-100)}

/* FILTER LABEL */
.filter-label{display:block;font-size:11px;font-weight:600;color:var(--gray-500);margin-bottom:5px;letter-spacing:.06em;text-transform:uppercase}
.filter-input{width:100%;padding:8px 12px;border-radius:8px;border:1.5px solid var(--gray-200);font-size:13px;color:var(--gray-700);background:var(--white)}
.filter-input:focus{border-color:var(--blue);outline:none}
.select-sm{padding:6px 10px;border-radius:6px;border:1.5px solid var(--gray-200);font-size:12px;color:var(--gray-700);background:var(--white);cursor:pointer}

/* ===== DASHBOARD ===== */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.stat-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--gray-200);padding:20px;display:flex;align-items:center;gap:16px}
.stat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stat-icon.navy{background:var(--navy);color:var(--white)}
.stat-icon.green{background:var(--green-l);color:var(--green)}
.stat-icon.blue{background:var(--blue-xl);color:var(--blue)}
.stat-icon.gray{background:var(--gray-100);color:var(--gray-500)}
.stat-label{font-size:12px;color:var(--gray-500);font-weight:500}
.stat-value{font-size:22px;font-weight:700;color:var(--gray-900);margin-top:2px}
.dash-grid{display:grid;grid-template-columns:1fr 300px;gap:20px;margin-bottom:20px}
.chart-card{padding:20px}
.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.chart-title{font-size:15px;font-weight:600}
.chart-bars{display:flex;align-items:flex-end;gap:8px;height:160px;padding-bottom:24px}
.chart-bar-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}
.chart-bar{width:100%;background:var(--blue);border-radius:4px 4px 0 0;transition:opacity .2s;cursor:pointer}
.chart-bar:hover{opacity:.8}
.chart-label{font-size:10px;color:var(--gray-500);white-space:nowrap}
.integrity-card{background:var(--navy);border-radius:var(--radius);padding:20px;color:var(--white);display:flex;flex-direction:column;gap:14px}
.integrity-title{font-size:16px;font-weight:700}
.integrity-text{font-size:12px;color:rgba(255,255,255,.65);line-height:1.6}
.integrity-row{display:flex;align-items:center;justify-content:space-between}
.integrity-label{font-size:12px;font-weight:600}
.integrity-ok{font-size:12px;font-weight:700;color:#4ADE80}
.integrity-bar{height:6px;background:rgba(255,255,255,.15);border-radius:99px;overflow:hidden}
.integrity-fill{height:100%;background:#4ADE80;border-radius:99px}
.btn-outline-white{padding:9px 16px;border-radius:8px;border:1.5px solid rgba(255,255,255,.3);color:var(--white);font-size:13px;font-weight:500;background:transparent;cursor:pointer;transition:background .15s;display:inline-block}
.btn-outline-white:hover{background:rgba(255,255,255,.1)}
.prog-card{border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray-200)}
.prog-img-header{width:100%;height:110px;background:linear-gradient(135deg,#1e3a5f,#2563eb);display:flex;align-items:flex-end;padding:12px}
.prog-tag{font-size:10px;letter-spacing:.12em;color:rgba(255,255,255,.7);font-weight:600}
.prog-name{font-size:15px;font-weight:700;color:var(--white)}
.prog-body{padding:14px}
.prog-loc{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--gray-500);margin-bottom:10px}
.prog-loc-name{font-weight:600;font-size:13px;color:var(--gray-900)}
.prog-desc{font-size:12px;color:var(--gray-500);line-height:1.5}
.prog-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.prog-stat{background:var(--gray-50);border-radius:8px;padding:10px}
.prog-stat-label{font-size:11px;color:var(--gray-500);font-weight:500}
.prog-stat-val{font-size:16px;font-weight:700;color:var(--gray-900)}
.ledger-card{padding:20px}
.ledger-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.ledger-title{font-size:15px;font-weight:600}
.link-blue{color:var(--blue);font-size:13px;cursor:pointer}
.link-blue:hover{text-decoration:underline}

/* ===== CATEGORY ===== */
.page-actions-row{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:10px}
.bottom-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:20px}
.bstat{padding:20px;display:flex;flex-direction:column;gap:6px}
.bstat-icon{width:36px;height:36px;border-radius:8px;background:var(--blue-xl);display:flex;align-items:center;justify-content:center;color:var(--blue)}
.bstat-label{font-size:12px;color:var(--gray-500);font-weight:500}
.bstat-value{font-size:24px;font-weight:700}
.bstat-sub{font-size:12px;color:var(--gray-500)}

/* ===== AID TYPE ===== */
.toggle-group{display:flex;border:1.5px solid var(--gray-200);border-radius:8px;overflow:hidden}
.toggle-btn{padding:8px 16px;font-size:13px;font-weight:500;background:var(--white);color:var(--gray-500);cursor:pointer;transition:all .15s;border:none}
.toggle-btn.active{background:var(--blue);color:var(--white)}
.tag-pill{display:inline-block;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:700;letter-spacing:.06em}
.tag-essential{background:#EDE9FE;color:#7C3AED}
.tag-financial{background:var(--amber-l);color:#92400E}
.tag-medical{background:#FCE7F3;color:#9D174D}
.tag-other{background:var(--gray-100);color:var(--gray-500)}
.quota-bar-wrap{display:flex;flex-direction:column;gap:3px;min-width:120px}
.quota-txt{font-size:12px;font-weight:600}
.quota-txt.crit{color:var(--red)}
.quota-txt.warn{color:var(--amber)}
.quota-bar{height:5px;border-radius:99px;background:var(--gray-200);overflow:hidden}
.quota-fill{height:100%;border-radius:99px}
.quota-fill.ok{background:var(--blue)}
.quota-fill.warn{background:var(--amber)}
.quota-fill.crit{background:var(--red)}
.at-bottom-grid{display:grid;grid-template-columns:1fr 280px;gap:16px;margin-top:20px}
.bulk-card{padding:20px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.policy-card{background:#14532D;color:var(--white);border-radius:var(--radius);padding:20px}
.policy-title{font-size:14px;font-weight:700;margin-bottom:8px}
.policy-text{font-size:12px;color:rgba(255,255,255,.7);line-height:1.6;margin-bottom:12px}
.policy-link{color:#86EFAC;font-size:13px;font-weight:600;cursor:pointer}

/* ===== BATCH IMPORT ===== */
.bi-grid{display:grid;grid-template-columns:340px 1fr;gap:20px}
.upload-card{padding:20px}
.step-circle{width:24px;height:24px;border-radius:50%;background:var(--blue);color:var(--white);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.drop-zone{border:2px dashed var(--gray-200);border-radius:12px;padding:36px 20px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;cursor:pointer;transition:border .2s,background .2s;margin-bottom:16px}
.drop-zone:hover,.drop-zone.dragover{border-color:var(--blue);background:var(--blue-xl)}
.drop-icon{width:52px;height:52px;background:var(--blue-xl);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--blue)}
.drop-title{font-size:14px;font-weight:600;color:var(--gray-700)}
.drop-sub{font-size:12px;color:var(--gray-400)}
.btn-browse{padding:8px 20px;border-radius:8px;background:var(--blue);color:var(--white);font-size:13px;font-weight:600;border:none;cursor:pointer}
.instructions-box{background:var(--gray-50);border-radius:10px;padding:14px}
.instructions-box h4{font-size:12px;font-weight:700;color:var(--gray-700);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.instructions-box li{font-size:12px;color:var(--gray-500);padding:3px 0 3px 14px;position:relative}
.instructions-box li::before{content:'•';position:absolute;left:4px;color:var(--blue)}
.validation-card{padding:20px}
.val-valid{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--green)}
.val-err{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--red)}
.val-dot{width:8px;height:8px;border-radius:50%}
.val-dot.green{background:var(--green)}
.val-dot.red{background:var(--red)}
.val-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 0 0}
.val-total{font-size:13px;color:var(--gray-500)}
.bi-security{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:20px}
.security-item{padding:16px;display:flex;align-items:flex-start;gap:12px}
.sec-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sec-icon.blue{background:var(--blue-xl);color:var(--blue)}
.sec-icon.gray{background:var(--gray-100);color:var(--gray-500)}
.sec-title{font-size:13px;font-weight:600;margin-bottom:4px}
.sec-text{font-size:12px;color:var(--gray-500);line-height:1.5}
.issue-text{color:var(--red);font-size:12px;font-weight:500}

/* ===== AUDIT TRAIL ===== */
.action-tag{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600}
.action-update{background:var(--blue-xl);color:var(--blue)}
.action-create{background:var(--green-l);color:var(--green)}
.action-delete{background:var(--red-l);color:var(--red)}
.action-import{background:var(--amber-l);color:var(--amber)}
.user-cell{display:flex;align-items:center;gap:10px}
.user-av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--white);flex-shrink:0}
.user-name-cell{font-size:13px;font-weight:600;color:var(--gray-900)}
.user-ip{font-size:11px;color:var(--gray-400)}
.entity-id-cell{font-size:11px;color:var(--gray-400)}
.view-icon{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--gray-400);background:transparent;cursor:pointer;border:none}
.view-icon:hover{background:var(--gray-100);color:var(--gray-700)}

/* ===== SETTINGS ===== */
.settings-grid{display:grid;grid-template-columns:280px 1fr;gap:20px}
.profile-card{padding:24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}
.profile-avatar-wrap{position:relative}
.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#3B82F6,#1D4ED8);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:var(--white)}
.edit-avatar-btn{position:absolute;bottom:0;right:0;width:26px;height:26px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;cursor:pointer;border:2px solid white}
.profile-name-text{font-size:17px;font-weight:700}
.profile-email-text{font-size:13px;color:var(--gray-500)}
.profile-role{display:inline-block;padding:4px 12px;border-radius:99px;background:var(--blue-xl);color:var(--blue);font-size:11px;font-weight:700;letter-spacing:.08em}
.ws-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--gray-100)}
.ws-row:last-child{border-bottom:none}
.ws-label{font-size:13px;color:var(--gray-700)}
.settings-section{padding:20px}
.section-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.section-title{font-size:15px;font-weight:600}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-field label{font-size:12px;font-weight:600;color:var(--gray-500);margin-bottom:6px;display:block;text-transform:uppercase;letter-spacing:.06em}
.form-field select,.form-field input[type=text],.form-field input[type=number],.form-field input[type=email],.form-field input[type=password]{width:100%;padding:9px 12px;border-radius:8px;border:1.5px solid var(--gray-200);font-size:13px;color:var(--gray-700);background:var(--white)}
.form-field select:focus,.form-field input:focus{border-color:var(--blue);outline:none}
.notif-row{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--gray-100)}
.notif-row:last-child{border-bottom:none}
.notif-label{font-size:13px;font-weight:600}
.notif-sub{font-size:12px;color:var(--gray-500);margin-top:2px}
.toggle-switch{position:relative;width:42px;height:24px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0}
.toggle-track{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--gray-200);border-radius:99px;transition:.2s}
.toggle-track::before{content:'';position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:var(--white);border-radius:50%;transition:.2s}
.toggle-switch input:checked+.toggle-track{background:var(--blue)}
.toggle-switch input:checked+.toggle-track::before{transform:translateX(18px)}
.security-row{display:flex;justify-content:space-between;align-items:flex-start;gap:20px}
.tfa-card{background:var(--gray-50);border-radius:10px;padding:14px;min-width:160px}
.tfa-title{font-size:12px;font-weight:700;margin-bottom:4px}
.tfa-sub{font-size:11px;color:var(--gray-500);line-height:1.4}
.tfa-status{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:12px;font-weight:600;color:var(--green)}
.btn-sm-red{padding:5px 12px;border-radius:6px;background:var(--red-l);color:var(--red);font-size:12px;font-weight:600;cursor:pointer;border:none}
.apikey-box{background:#0F172A;border-radius:10px;padding:14px 16px;margin-top:12px}
.apikey-label-row{font-size:11px;color:rgba(255,255,255,.4);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.apikey-val{display:flex;align-items:center;gap:10px}
.apikey-text{font-family:'Courier New',monospace;font-size:12px;color:#7DD3FC;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.copy-btn{width:28px;height:28px;border-radius:6px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);cursor:pointer;border:none}
.copy-btn:hover{background:rgba(255,255,255,.15);color:var(--white)}
.apikey-warn{font-size:11px;color:rgba(255,255,255,.3);margin-top:6px;font-style:italic}
.storage-bar{height:8px;background:var(--gray-200);border-radius:99px;overflow:hidden}
.storage-fill{height:100%;background:var(--red);border-radius:99px}

/* ===== MODAL ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:999;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .2s}
.modal-overlay.show{opacity:1;pointer-events:auto}
.modal{background:var(--white);border-radius:14px;padding:28px;max-width:500px;width:calc(100% - 32px);box-shadow:var(--shadow-md);transform:translateY(12px);transition:transform .2s;max-height:90vh;overflow-y:auto}
.modal-overlay.show .modal{transform:translateY(0)}
.modal-sm .modal{max-width:380px}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.modal-title{font-size:17px;font-weight:700}
.modal-close{width:32px;height:32px;border-radius:50%;background:var(--gray-100);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--gray-500);border:none;font-size:16px}
.modal-close:hover{background:var(--gray-200)}
.modal-field{margin-bottom:14px}
.modal-field label{font-size:12px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;display:block}
.modal-field input,.modal-field select,.modal-field textarea{width:100%;padding:9px 12px;border-radius:8px;border:1.5px solid var(--gray-200);font-size:13px;color:var(--gray-700);background:var(--white);font-family:inherit}
.modal-field input:focus,.modal-field select:focus,.modal-field textarea:focus{border-color:var(--blue);outline:none}
.modal-field textarea{resize:vertical;min-height:72px}
.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}
.confirm-icon{width:52px;height:52px;border-radius:50%;background:var(--red-l);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.confirm-title{text-align:center;font-size:17px;font-weight:700;margin-bottom:8px}
.confirm-sub{text-align:center;font-size:13px;color:var(--gray-500)}

/* ===== AUDIT DETAIL ===== */
.audit-detail-row{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--gray-100)}
.audit-detail-row:last-child{border-bottom:none}
.audit-detail-label{font-size:12px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;min-width:120px;padding-top:1px}
.audit-detail-val{font-size:13px;color:var(--gray-900)}

/* ===== TOAST ===== */
.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:10px;background:var(--white);box-shadow:var(--shadow-md);border:1px solid var(--gray-200);min-width:260px;max-width:340px;animation:toastIn .3s ease;font-size:13px;font-weight:500}
.toast.success{border-left:4px solid var(--green)}
.toast.error{border-left:4px solid var(--red)}
.toast.info{border-left:4px solid var(--blue)}
@keyframes toastIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* ===== EMPTY STATE ===== */
.empty-state{padding:48px 20px;text-align:center;color:var(--gray-400)}
.empty-state svg{margin:0 auto 12px;opacity:.4}
.empty-state p{font-size:14px}

@media(max-width:900px){
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .dash-grid,.settings-grid,.at-bottom-grid,.bi-grid{grid-template-columns:1fr}
  .bottom-stats{grid-template-columns:1fr}
}
