/* Legacy Microfinance CTLS — Card Monitoring System v2.0 */
:root {
  --navy:#0f1623;--navy2:#141c2b;--navy3:#1b2438;--navy4:#2c3a52;--navy5:#4a5f7a;--navy6:#7a92b0;
  --gold:#c9933a;--gold2:#e8b96a;--gold3:#9a6e22;--goldbg:rgba(201,147,58,.09);--goldglow:rgba(201,147,58,.22);
  --bg:#f4f6f9;--card:#fff;--raised:#fafbfc;--border:#e4e8ef;--border2:#d0d7e3;
  --t1:#0f1623;--t2:#3d4f6b;--t3:#7a92b0;--t4:#b0bfd4;
  --green:#10a96e;--greenbg:rgba(16,169,110,.09);
  --red:#e03c3c;--redbg:rgba(224,60,60,.09);
  --blue:#2c6ff5;--bluebg:rgba(44,111,245,.09);
  --amber:#d97706;--amberbg:rgba(217,119,6,.09);
  --purple:#7c3aed;--purplebg:rgba(124,58,237,.09);
  --cyan:#0891b2;--cyanbg:rgba(8,145,178,.09);
  --sbw:258px;--tbh:60px;
  --r:12px;--rs:8px;--rx:4px;
  --sh:0 1px 3px rgba(15,22,35,.08),0 1px 2px rgba(15,22,35,.04);
  --shm:0 4px 16px rgba(15,22,35,.10),0 1px 4px rgba(15,22,35,.06);
  --shl:0 12px 40px rgba(15,22,35,.14),0 4px 12px rgba(15,22,35,.08);
  --ff:'Plus Jakarta Sans',system-ui,sans-serif;
  --fs:'Instrument Serif',Georgia,serif;
  --fm:'JetBrains Mono','Fira Code',monospace;
  --tr:all .18s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;-webkit-font-smoothing:antialiased;scroll-behavior:smooth}
body{font-family:var(--ff);background:var(--bg);color:var(--t1);line-height:1.6}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit}
a{text-decoration:none;color:inherit}
.hidden{display:none!important}

/* ── LOGIN ────────────────────────────────── */
.login-mode{background:var(--navy)}
.login-root{display:flex;min-height:100vh}

.login-left{flex:1.1;background:var(--navy);display:flex;flex-direction:column;padding:48px;position:relative;overflow:hidden}
.login-left::before{content:'';position:absolute;top:-120px;right:-120px;width:500px;height:500px;background:radial-gradient(circle,rgba(201,147,58,.13) 0%,transparent 70%);pointer-events:none}
.ll-inner{position:relative;z-index:1;flex:1}

.brand{display:flex;align-items:center;gap:14px;margin-bottom:56px;animation:fadeUp .6s ease both}
.brand-mark{width:48px;height:48px;background:var(--gold);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--fs);font-size:22px;color:var(--navy);flex-shrink:0}
.brand-words{display:flex;flex-direction:column}
.brand-name{font-weight:700;font-size:15px;color:#fff}
.brand-sub{font-size:10px;color:rgba(255,255,255,.3);font-family:var(--fm);letter-spacing:.1em}

.login-hero{margin-bottom:40px;animation:fadeUp .6s .1s ease both}
.login-hero h1{font-family:var(--fs);font-size:clamp(28px,3.5vw,50px);color:#fff;line-height:1.1;letter-spacing:-.02em;margin-bottom:14px}
.login-hero h1 em{color:var(--gold);font-style:italic}
.login-hero p{font-size:14px;color:rgba(255,255,255,.4);max-width:360px;line-height:1.7}

.login-stats{display:flex;gap:32px;animation:fadeUp .6s .2s ease both}
.lstat{display:flex;flex-direction:column;gap:2px}
.lstat-n{font-family:var(--fs);font-size:26px;color:var(--gold);letter-spacing:-.02em}
.lstat-l{font-size:10px;color:rgba(255,255,255,.3);text-transform:uppercase;letter-spacing:.08em}

.card-visual{position:absolute;bottom:48px;right:0;padding-right:48px;display:flex;flex-direction:column;gap:16px;animation:fadeUp .7s .3s ease both}
.scard{width:272px;background:linear-gradient(135deg,#1b2d4a 0%,#0f1e36 100%);border:1px solid rgba(201,147,58,.25);border-radius:14px;padding:20px 22px 16px;box-shadow:0 20px 60px rgba(0,0,0,.4);transition:transform .4s ease}
.scard:hover{transform:translateY(-4px)}
.c2{transform:translateX(22px) rotate(2deg);opacity:.82}
.scard-chip{width:30px;height:22px;background:linear-gradient(135deg,var(--gold2),var(--gold));border-radius:4px;margin-bottom:18px}
.scard-serial{font-family:var(--fm);font-size:11px;color:var(--gold);letter-spacing:.07em;margin-bottom:3px}
.scard-issuer{font-size:10px;color:rgba(255,255,255,.35);margin-bottom:14px}
.scard-foot{display:flex;justify-content:space-between;align-items:center;font-size:10px;color:rgba(255,255,255,.3)}
.sc-pill{padding:2px 8px;border-radius:10px;font-family:var(--fm);font-size:9px;letter-spacing:.05em}
.active-pill{background:rgba(16,169,110,.2);color:#4ade80}
.closed-pill{background:rgba(176,191,212,.12);color:rgba(176,191,212,.6)}

.login-right{width:460px;background:#fff;display:flex;align-items:center;justify-content:center;padding:40px}
.login-box{width:100%;max-width:370px}
.lb-head{margin-bottom:28px}
.lb-head h2{font-family:var(--fs);font-size:28px;color:var(--navy);margin-bottom:5px;letter-spacing:-.02em}
.lb-head p{color:var(--t3);font-size:13px}

.lb-form{display:flex;flex-direction:column;gap:16px}
.fg{display:flex;flex-direction:column;gap:5px}
.fg label{font-size:11.5px;font-weight:600;color:var(--t2);letter-spacing:.03em}
.fg input{padding:10px 13px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--rs);font-size:13px;color:var(--t1);outline:none;transition:var(--tr)}
.fg input:focus{border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px var(--goldglow)}
.fg input::placeholder{color:var(--t4)}
.pass-wrap{position:relative;display:flex;align-items:center}
.pass-wrap input{width:100%;padding-right:40px}
.eye-btn{position:absolute;right:10px;background:none;border:none;color:var(--t3);padding:4px;display:flex;align-items:center;transition:color .15s}
.eye-btn:hover{color:var(--t1)}

.quick-logins{background:var(--bg);border:1px solid var(--border);border-radius:var(--rs);padding:12px}
.ql-label{font-size:10.5px;color:var(--t3);margin-bottom:8px;font-weight:500}
.ql-grid{display:flex;flex-wrap:wrap;gap:6px}
.ql-btn{padding:5px 12px;border-radius:20px;font-size:11px;font-weight:600;border:none;transition:var(--tr)}
.ql-btn:hover{opacity:.8;transform:scale(.97)}
.ql-admin  {background:var(--goldbg);color:var(--gold3)}
.ql-gm     {background:var(--bluebg);color:var(--blue)}
.ql-hop    {background:var(--purplebg);color:var(--purple)}
.ql-auditor{background:var(--cyanbg);color:var(--cyan)}
.ql-mkt    {background:var(--greenbg);color:var(--green)}

.signin-btn{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--navy);color:#fff;border:none;border-radius:var(--rs);padding:12px 20px;font-size:14px;font-weight:600;transition:var(--tr);margin-top:4px}
.signin-btn:hover{background:var(--navy3);transform:translateY(-1px);box-shadow:var(--shm)}
.signin-btn:active{transform:none}
.signin-btn.loading{opacity:.7;pointer-events:none}

.err-box{background:var(--redbg);color:var(--red);border:1px solid rgba(224,60,60,.2);border-radius:var(--rs);padding:9px 13px;font-size:12.5px;margin-bottom:4px}
.lb-foot{text-align:center;font-size:10.5px;color:var(--t4);margin-top:28px;font-family:var(--fm)}

/* ── APP LAYOUT ───────────────────────────── */
.app-mode{background:var(--bg)}
.app-root{display:flex;min-height:100vh}
.mob-overlay{position:fixed;inset:0;background:rgba(15,22,35,.55);z-index:90;backdrop-filter:blur(2px)}

/* SIDEBAR */
.sidebar{width:var(--sbw);background:var(--navy);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;border-right:1px solid rgba(255,255,255,.04);transition:transform .3s cubic-bezier(.4,0,.2,1)}
.sb-top{display:flex;align-items:center;justify-content:space-between;padding:18px;border-bottom:1px solid rgba(255,255,255,.06);min-height:var(--tbh)}
.sb-brand{display:flex;align-items:center;gap:10px}
.sb-mark{width:30px;height:30px;background:var(--gold);border-radius:7px;display:flex;align-items:center;justify-content:center;font-family:var(--fs);font-size:15px;color:var(--navy);flex-shrink:0}
.sb-btext{display:flex;flex-direction:column}
.sb-co{font-weight:700;font-size:13px;color:#fff}
.sb-tagline{font-size:9.5px;color:rgba(255,255,255,.28);font-family:var(--fm);letter-spacing:.06em}
.sb-x{background:none;border:none;color:rgba(255,255,255,.28);font-size:16px;display:none;padding:4px}

.sb-user{display:flex;align-items:center;gap:10px;margin:10px;padding:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:var(--rs)}
.sb-av{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;flex-shrink:0}
.sb-ui{display:flex;flex-direction:column;gap:3px;overflow:hidden}
.sb-uname{font-size:12px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.sb-nav{flex:1;overflow-y:auto;padding:6px 10px}
.sb-nav::-webkit-scrollbar{width:3px}
.sb-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
.sng{margin-bottom:2px}
.sng-lbl{display:block;font-size:9px;font-family:var(--fm);color:rgba(255,255,255,.22);letter-spacing:.12em;text-transform:uppercase;padding:13px 10px 5px}
.sni{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--rs);color:rgba(255,255,255,.48);font-size:13px;font-weight:500;transition:var(--tr);cursor:pointer;position:relative;user-select:none}
.sni:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.85)}
.sni.active{background:rgba(201,147,58,.12);color:var(--gold)}
.sni.active::before{content:'';position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--gold);border-radius:0 2px 2px 0}
.sni i{width:16px;font-style:normal;font-size:13px;text-align:center;flex-shrink:0}
.sni-badge{margin-left:auto;background:var(--red);color:#fff;font-size:9px;font-family:var(--fm);padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}
.sb-logout{display:flex;align-items:center;gap:8px;padding:14px 20px;color:rgba(255,255,255,.3);font-size:12.5px;font-weight:500;border-top:1px solid rgba(255,255,255,.06);transition:var(--tr)}
.sb-logout:hover{color:var(--red)}

/* ROLE COLORS */
.av-admin           ,.tb-av.av-admin           {background:var(--gold)}
.av-general_manager ,.tb-av.av-general_manager {background:var(--blue)}
.av-hop             ,.tb-av.av-hop             {background:var(--purple)}
.av-auditor         ,.tb-av.av-auditor         {background:var(--cyan)}
.av-marketer        ,.tb-av.av-marketer        {background:var(--green)}

.role-pill{font-size:9.5px;font-weight:600;padding:2px 8px;border-radius:10px;display:inline-block;letter-spacing:.02em}
.rp-admin           {background:var(--goldbg);color:var(--gold3)}
.rp-general_manager {background:var(--bluebg);color:var(--blue)}
.rp-hop             {background:var(--purplebg);color:var(--purple)}
.rp-auditor         {background:var(--cyanbg);color:var(--cyan)}
.rp-marketer        {background:var(--greenbg);color:var(--green)}

/* APP BODY */
.app-body{margin-left:var(--sbw);flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .3s ease}

/* TOPBAR */
.topbar{height:var(--tbh);background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 22px 0 18px;position:sticky;top:0;z-index:50;box-shadow:var(--sh)}
.tb-l{display:flex;align-items:center;gap:12px}
.tb-title{font-family:var(--fs);font-size:19px;color:var(--navy);font-weight:400;letter-spacing:-.01em}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:34px;height:34px;background:var(--bg);border:1px solid var(--border);border-radius:var(--rs);padding:8px}
.hamburger span{display:block;height:1.5px;background:var(--navy);border-radius:1px;transition:var(--tr)}
.tb-r{display:flex;align-items:center;gap:10px}
.tb-branch{display:flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--border);border-radius:var(--rs);padding:6px 10px}
.tb-branch select{background:none;border:none;color:var(--t2);font-size:12px;font-weight:600;cursor:pointer;outline:none;font-family:var(--fm)}
.tb-bell{position:relative;width:34px;height:34px;background:var(--bg);border:1px solid var(--border);border-radius:var(--rs);display:flex;align-items:center;justify-content:center;color:var(--t2);font-size:15px;transition:var(--tr)}
.tb-bell:hover{background:var(--redbg);border-color:var(--red);color:var(--red)}
.bell-badge{position:absolute;top:-6px;right:-6px;background:var(--red);color:#fff;font-size:9px;font-family:var(--fm);padding:1px 5px;border-radius:10px;min-width:16px;text-align:center;border:2px solid #fff}
.tb-pill{display:flex;align-items:center;gap:7px;padding:4px 12px 4px 4px;background:var(--bg);border:1px solid var(--border);border-radius:20px;font-size:12px;font-weight:600;color:var(--t2)}
.tb-av{width:25px;height:25px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}
.tb-uname{white-space:nowrap}

/* PAGE */
.page-area{flex:1;padding:22px}
@keyframes pgIn{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:none}}
#pageContent{animation:pgIn .2s ease both}

/* STAT CARDS */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-bottom:18px}
.sc{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:17px 19px;transition:var(--tr)}
.sc:hover{box-shadow:var(--shm);transform:translateY(-2px)}
.sc-bar{height:3px;border-radius:2px;margin-bottom:13px}
.sc-lbl{font-size:10.5px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:7px}
.sc-val{font-family:var(--fs);font-size:34px;letter-spacing:-.03em;line-height:1;margin-bottom:4px}
.sc-sub{font-size:11px;color:var(--t3)}
.sc-total    .sc-bar{background:var(--gold)}   .sc-total    .sc-val{color:var(--gold3)}
.sc-storage  .sc-bar{background:var(--t4)}     .sc-storage  .sc-val{color:var(--t3)}
.sc-issued   .sc-bar{background:var(--blue)}   .sc-issued   .sc-val{color:var(--blue)}
.sc-assigned .sc-bar{background:var(--purple)} .sc-assigned .sc-val{color:var(--purple)}
.sc-active   .sc-bar{background:var(--green)}  .sc-active   .sc-val{color:var(--green)}
.sc-closed   .sc-bar{background:var(--cyan)}   .sc-closed   .sc-val{color:var(--cyan)}
.sc-cancel   .sc-bar{background:var(--amber)}  .sc-cancel   .sc-val{color:var(--amber)}
.sc-fraud    .sc-bar{background:var(--red)}    .sc-fraud    .sc-val{color:var(--red)}

/* PANELS */
.panel{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.panel-hd{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}
.panel-title{font-weight:600;font-size:13.5px;color:var(--t1)}
.live-tag{font-size:10px;font-family:var(--fm);color:var(--green);background:var(--greenbg);padding:2px 8px;border-radius:10px}

/* SAVINGS BANNER */
.savings-banner{background:linear-gradient(135deg,var(--navy) 0%,var(--navy3) 100%);border-radius:var(--r);padding:22px 26px;color:#fff;display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;position:relative;overflow:hidden}
.savings-banner::before{content:'';position:absolute;right:-50px;top:-50px;width:180px;height:180px;background:radial-gradient(circle,rgba(201,147,58,.2) 0%,transparent 70%)}
.sb-lbl{font-size:11px;color:rgba(255,255,255,.45);margin-bottom:6px;font-family:var(--fm);letter-spacing:.08em}
.sb-amt{font-family:var(--fs);font-size:34px;color:var(--gold);letter-spacing:-.03em}
.sb-branch{font-size:10.5px;color:rgba(255,255,255,.3);margin-top:3px}
.sb-circle{width:60px;height:60px;background:rgba(201,147,58,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--fs);font-size:24px;color:var(--gold);position:relative;z-index:1}

/* DASH ROW */
.dash-row{display:grid;grid-template-columns:1.4fr 1fr;gap:15px;margin-bottom:16px}
.dash-row.full{grid-template-columns:1fr}

/* RECENT TX */
.recent-item{display:flex;align-items:center;gap:10px;padding:9px 16px;border-bottom:1px solid var(--border)}
.ri-cname{font-size:12px;font-weight:600;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ri-card{font-size:10px;font-family:var(--fm);color:var(--t3)}
.ri-amt{font-family:var(--fm);font-size:13px;color:var(--green);font-weight:500;white-space:nowrap}
.ri-date{font-size:10px;color:var(--t4);font-family:var(--fm);text-align:right}

/* TABLE */
.tbl-wrap{overflow-x:auto}
.dtbl{width:100%;border-collapse:collapse;font-size:12.5px}
.dtbl th{padding:9px 15px;text-align:left;font-size:10px;font-family:var(--fm);font-weight:500;color:var(--t3);letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--border);background:var(--raised);white-space:nowrap}
.dtbl td{padding:11px 15px;border-bottom:1px solid var(--border);color:var(--t2);vertical-align:middle}
.dtbl tr:last-child td{border-bottom:none}
.dtbl tr:hover td{background:var(--raised)}
.mono{font-family:var(--fm);font-size:11.5px;color:var(--t1)}
.amtcell{font-family:var(--fm);color:var(--green);font-weight:500}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 9px;border-radius:20px;font-size:10px;font-weight:600;letter-spacing:.03em;white-space:nowrap}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.65}
.s-storage  {background:#f1f3f6;color:var(--t3)}
.s-issued   {background:var(--bluebg);color:var(--blue)}
.s-assigned {background:var(--purplebg);color:var(--purple)}
.s-active   {background:var(--greenbg);color:var(--green)}
.s-closed   {background:var(--cyanbg);color:var(--cyan)}
.s-cancelled{background:var(--amberbg);color:var(--amber)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:var(--rs);font-size:12.5px;font-weight:600;border:none;transition:var(--tr);cursor:pointer;white-space:nowrap}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy3);box-shadow:var(--shm);transform:translateY(-1px)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold2);box-shadow:var(--shm);transform:translateY(-1px)}
.btn-outline{background:#fff;color:var(--t2);border:1.5px solid var(--border)}
.btn-outline:hover{border-color:var(--navy);color:var(--navy)}
.btn-ghost{background:var(--bg);color:var(--t2);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--border)}
.btn-danger{background:var(--redbg);color:var(--red);border:1px solid rgba(224,60,60,.2)}
.btn-danger:hover{background:var(--red);color:#fff}
.btn-success{background:var(--greenbg);color:var(--green);border:1px solid rgba(16,169,110,.2)}
.btn-success:hover{background:var(--green);color:#fff}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-xs{padding:4px 9px;font-size:11px}

/* TOOLBAR */
.pg-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}

/* FILTER */
.filter-bar{display:flex;gap:10px;align-items:center;padding:11px 16px;background:var(--raised);border-bottom:1px solid var(--border);flex-wrap:wrap}
.filter-bar input,.filter-bar select{background:#fff;border:1px solid var(--border);border-radius:var(--rs);padding:7px 11px;font-size:12.5px;color:var(--t1);outline:none;transition:var(--tr)}
.filter-bar input{flex:1;min-width:160px}
.filter-bar input:focus,.filter-bar select:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--goldglow)}
.filter-bar input::placeholder{color:var(--t4)}

/* FORM ELEMENTS */
.form-grid{display:flex;flex-direction:column;gap:13px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.form-row.three{grid-template-columns:1fr 1fr 1fr}
.fgroup{display:flex;flex-direction:column;gap:5px}
.fgroup label{font-size:11.5px;font-weight:600;color:var(--t2)}
.fgroup input,.fgroup select,.fgroup textarea{padding:9px 12px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--rs);font-size:13px;color:var(--t1);outline:none;transition:var(--tr)}
.fgroup input:focus,.fgroup select:focus,.fgroup textarea:focus{border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px var(--goldglow)}
.fgroup input::placeholder{color:var(--t4)}
.fhint{font-size:11px;color:var(--t3)}
.fok  {font-size:11px;color:var(--green)}
.ferr {font-size:11px;color:var(--red)}
.preview-pill{background:var(--goldbg);border:1px dashed var(--gold);border-radius:var(--rs);padding:8px 12px;font-family:var(--fm);font-size:11px;color:var(--gold3)}

/* MODAL */
.modal-mask{position:fixed;inset:0;background:rgba(15,22,35,.58);z-index:200;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(3px);padding:20px}
.modal-box{background:#fff;border-radius:var(--r);width:100%;max-width:530px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shl);animation:mIn .2s cubic-bezier(.34,1.4,.64,1)}
.modal-box.wide{max-width:750px}
@keyframes mIn{from{opacity:0;transform:scale(.94) translateY(10px)}to{opacity:1;transform:none}}
.modal-hd{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);font-family:var(--fs);font-size:17px;color:var(--navy)}
.modal-x{background:none;border:none;font-size:17px;color:var(--t3);padding:2px 6px;border-radius:4px;transition:var(--tr)}
.modal-x:hover{background:var(--bg);color:var(--t1)}
.modal-bd{padding:18px 20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:13px}
.modal-ft{padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:9px;justify-content:flex-end}

/* SEARCH PAGE */
.search-hero{max-width:680px;margin:0 auto 24px}
.search-bar{display:flex;align-items:center;background:#fff;border:2px solid var(--border);border-radius:var(--r);padding:4px 14px;gap:10px;margin-bottom:13px;transition:var(--tr);box-shadow:var(--sh)}
.search-bar:focus-within{border-color:var(--gold);box-shadow:0 0 0 4px var(--goldglow)}
.search-bar input{flex:1;border:none;background:none;outline:none;font-size:15px;color:var(--t1);padding:12px 0}
.search-bar input::placeholder{color:var(--t4)}
.stabs{display:flex;gap:7px;flex-wrap:wrap}
.stab{padding:6px 15px;border-radius:20px;font-size:12px;font-weight:600;border:1.5px solid var(--border);background:#fff;color:var(--t3);transition:var(--tr)}
.stab:hover{border-color:var(--gold2);color:var(--gold3)}
.stab.on{background:var(--gold);border-color:var(--gold);color:#fff}
.search-results{max-width:680px;margin:0 auto;display:flex;flex-direction:column;gap:9px}
.src-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:15px 17px;cursor:pointer;transition:var(--tr);box-shadow:var(--sh)}
.src-card:hover{border-color:var(--gold);box-shadow:var(--shm);transform:translateX(4px)}
.src-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px}
.src-serial{font-family:var(--fm);font-size:12px;color:var(--gold3);font-weight:500}
.src-name{font-size:14px;font-weight:600;color:var(--t1);margin-bottom:5px}
.src-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:11.5px;color:var(--t3)}

/* FRAUD */
.fraud-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px}
.fraud-headline{font-family:var(--fs);font-size:22px;color:var(--red)}
.fraud-list{display:flex;flex-direction:column;gap:9px}
.fraud-card{background:#fff;border:1px solid var(--border);border-left:4px solid var(--red);border-radius:var(--rs);padding:13px 17px;display:flex;gap:12px;box-shadow:var(--sh)}
.fraud-card.warn{border-left-color:var(--amber)}
.fc-ico{font-size:20px;flex-shrink:0;margin-top:1px}
.fc-body{flex:1}
.fc-type{font-weight:700;font-size:13px;color:var(--t1);margin-bottom:2px}
.fc-desc{font-size:12.5px;color:var(--t2)}
.fc-card{font-family:var(--fm);font-size:11px;color:var(--t3);margin-top:3px}
.fc-time{font-size:10px;font-family:var(--fm);color:var(--t4);white-space:nowrap}
.no-fraud{text-align:center;padding:70px 20px}
.no-fraud-ico{font-size:52px;margin-bottom:12px}
.no-fraud-title{font-family:var(--fs);font-size:22px;color:var(--green);margin-bottom:6px}

/* REPORTS */
.reports-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:13px;margin-bottom:22px}
.rcard{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:20px;cursor:pointer;transition:var(--tr);box-shadow:var(--sh)}
.rcard:hover{border-color:var(--gold);box-shadow:var(--shm);transform:translateY(-2px)}
.rcard-ico{width:38px;height:38px;border-radius:var(--rs);display:flex;align-items:center;justify-content:center;margin-bottom:12px;font-size:18px}
.rcard-name{font-weight:700;font-size:13.5px;color:var(--t1);margin-bottom:5px}
.rcard-desc{font-size:11.5px;color:var(--t3);margin-bottom:12px}
.rcard-acts{display:flex;gap:6px}
.rcard-acts button{padding:4px 12px;border-radius:var(--rx);font-size:10px;font-family:var(--fm);font-weight:600;border:none;cursor:pointer}
.r-csv{background:var(--greenbg);color:var(--green)}
.r-pdf{background:var(--redbg);color:var(--red)}
.report-out{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:20px;overflow-x:auto}

/* CARD DETAIL */
.card-detail{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cd-sec-title{font-size:10px;font-family:var(--fm);color:var(--t3);text-transform:uppercase;letter-spacing:.1em;padding-bottom:7px;border-bottom:1px solid var(--border);margin-bottom:9px;margin-top:14px}
.cd-sec-title:first-child{margin-top:0}
.cd-row{display:flex;justify-content:space-between;align-items:flex-start;padding:4px 0;font-size:12.5px}
.cd-key{color:var(--t3)}
.cd-val{font-family:var(--fm);font-size:11.5px;color:var(--t1);text-align:right;max-width:58%;word-break:break-all}
.cd-val.green{color:var(--green);font-weight:500}

/* MINI TABLE */
.mtbl{width:100%;border-collapse:collapse;font-size:11.5px;margin-top:6px}
.mtbl th{padding:6px 8px;text-align:left;color:var(--t3);font-size:10px;font-family:var(--fm);border-bottom:1px solid var(--border);background:var(--raised)}
.mtbl td{padding:6px 8px;border-bottom:1px solid var(--border);color:var(--t2);font-family:var(--fm)}
.mtbl tr:last-child td{border-bottom:none}

/* AUDIT */
.audit-action{display:inline-block;padding:2px 7px;border-radius:4px;font-family:var(--fm);font-size:10px;font-weight:600;background:var(--bg);color:var(--t2);border:1px solid var(--border)}

/* TOAST */
.toast-zone{position:fixed;bottom:22px;right:22px;z-index:9999;display:flex;flex-direction:column;gap:7px;max-width:350px}
.toast{background:var(--navy);color:#fff;padding:11px 16px;border-radius:var(--rs);font-size:13px;box-shadow:var(--shl);animation:tIn .3s cubic-bezier(.34,1.2,.64,1);display:flex;align-items:center;gap:9px;border-left:4px solid var(--gold)}
.toast.t-ok  {border-left-color:var(--green)}
.toast.t-err {border-left-color:var(--red)}
.toast.t-warn{border-left-color:var(--amber)}
.toast.t-inf {border-left-color:var(--blue)}
@keyframes tIn{from{opacity:0;transform:translateX(18px)}to{opacity:1;transform:none}}

/* EMPTY STATE */
.empty{text-align:center;padding:55px 20px;color:var(--t3)}
.empty-ico{font-size:44px;margin-bottom:10px}
.empty-title{font-family:var(--fs);font-size:18px;color:var(--t2);margin-bottom:5px}
.empty-sub{font-size:12.5px}

/* SPINNER */
.spin-wrap{display:flex;justify-content:center;align-items:center;padding:50px}
.spinner{width:34px;height:34px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ── RESPONSIVE ────────────────────────────── */
@media(max-width:1100px){
  .stat-grid{grid-template-columns:repeat(4,1fr)}
  .reports-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .app-body{margin-left:0!important}
  .hamburger{display:flex}
  .sb-x{display:block}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .dash-row{grid-template-columns:1fr}
  .reports-grid{grid-template-columns:repeat(2,1fr)}
  .card-detail{grid-template-columns:1fr}
}
@media(max-width:768px){
  .login-left{display:none}
  .login-right{width:100%;padding:28px 20px}
  .page-area{padding:14px}
  .topbar{padding:0 14px}
  .form-row{grid-template-columns:1fr}
  .form-row.three{grid-template-columns:1fr}
  .tb-uname{display:none}
}
@media(max-width:480px){
  .stat-grid{grid-template-columns:1fr 1fr}
  .reports-grid{grid-template-columns:1fr}
  .savings-banner{flex-direction:column;gap:12px;align-items:flex-start}
  .modal-mask{align-items:flex-end;padding:0}
  .modal-box{border-radius:var(--r) var(--r) 0 0;max-height:95vh}
}
@media print{
  .sidebar,.topbar,.pg-toolbar,.filter-bar,.btn{display:none!important}
  .app-body{margin-left:0}
  .report-out{border:none;padding:0}
}

/* ── SETTINGS PAGE ─────────────────────────── */
.settings-page{max-width:1100px}
.settings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.settings-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--sh)}
.sc-head{display:flex;align-items:flex-start;gap:14px;padding:18px 20px;border-bottom:1px solid var(--border);background:var(--raised)}
.sc-icon{width:38px;height:38px;border-radius:var(--rs);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.sc-title{font-weight:700;font-size:14px;color:var(--t1);margin-bottom:3px}
.sc-desc{font-size:11.5px;color:var(--t3);line-height:1.5}
.sc-body{padding:18px 20px;flex:1;display:flex;flex-direction:column;gap:13px}
.sc-foot{padding:14px 20px;border-top:1px solid var(--border);background:var(--raised);display:flex;justify-content:flex-end}
.req{color:var(--red);font-size:12px}

/* theme preview */
.theme-preview{display:flex;border:1.5px solid var(--border);border-radius:var(--rs);overflow:hidden;margin-top:4px}
.tp-sidebar{width:70px;padding:12px 10px;display:flex;flex-direction:column;align-items:center;gap:8px}
.tp-logo{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:var(--fs);font-size:13px;font-weight:700}
.tp-body{flex:1;padding:14px 16px;background:var(--bg)}
.tp-stat{font-family:var(--fs);font-size:20px;font-weight:400;margin-bottom:4px}
.tp-btn{display:inline-block;padding:7px 14px;border-radius:var(--rs);color:#fff;font-size:12px;font-weight:600;margin-top:10px}

/* branch rows input styling */
.branch-row input{padding:8px 11px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--rs);font-size:13px;color:var(--t1);outline:none;transition:var(--tr);width:100%}
.branch-row input:focus{border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px var(--goldglow)}

@media(max-width:900px){.settings-grid{grid-template-columns:1fr}}
