/* BASA ADMIN — Master CSS
   Warm, traditional, human — not AI-tool aesthetic
   Inspired by classic banking/ERP software done well
   ─────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Warm neutrals — not cold grey */
  --bg:    #F2F0EB;
  --su:    #FFFFFF;
  --su2:   #F8F6F2;
  --su3:   #EFECE6;
  --bd:    #DDD9D2;
  --bd2:   #C8C3BB;

  /* Text */
  --t1: #1A1816;
  --t2: #5A5650;
  --t3: #9B9790;

  /* Accents */
  --pu:  #5B4FD4;   --pu-s: #ECEAF8;   --pu-d: #3F35A0;
  --gr:  #1A7A4C;   --gr-s: #E3F4EC;
  --am:  #8A5C00;   --am-s: #FDF3DC;
  --rd:  #A8261A;   --rd-s: #FAEAEA;
  --bl:  #1660A8;   --bl-s: #E1EEFB;
  --go:  #7A5A00;   --go-s: #FFF8DC;

  /* Sidebar */
  --sb:  #1A1816;
  --sbt: rgba(255,255,255,0.60);
  --sbh: rgba(255,255,255,0.07);
  --sbb: rgba(255,255,255,0.06);

  --f:   'Inter',system-ui,sans-serif;
  --m:   'JetBrains Mono','Courier New',monospace;
  --r:   5px;
  --rl:  8px;
  --sh:  0 1px 3px rgba(0,0,0,0.07);
  --shm: 0 4px 18px rgba(0,0,0,0.10);
}

html,body{height:100%;font-family:var(--f);font-size:14px;line-height:1.5;color:var(--t1);background:var(--bg);-webkit-font-smoothing:antialiased}
button{font-family:var(--f);cursor:pointer}
input,select,textarea{font-family:var(--f);font-size:14px}
a{color:var(--pu);text-decoration:none}

/* ── LAYOUT ────────────────────────────────────────────── */
.wrap{display:flex;height:100vh;overflow:hidden}

/* ── SIDEBAR ───────────────────────────────────────────── */
.sb{
  width:215px;flex-shrink:0;background:var(--sb);
  display:flex;flex-direction:column;overflow:hidden;
}
.sb-top{flex:1;overflow-y:auto;display:flex;flex-direction:column}
.sb-top::-webkit-scrollbar{width:3px}
.sb-top::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.08)}

.sb-brand{padding:18px 16px 14px;border-bottom:1px solid var(--sbb);flex-shrink:0}
.sb-name{font-size:17px;font-weight:700;color:#fff;letter-spacing:-.3px}
.sb-tag{font-family:var(--m);font-size:9px;color:rgba(255,255,255,0.28);letter-spacing:1.4px;text-transform:uppercase;display:block;margin-top:1px}

.sb-nav{padding:8px 0;flex:1}
.sb-sec{font-size:9.5px;font-family:var(--m);letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,0.22);padding:12px 16px 4px}

.nl{
  display:flex;align-items:center;gap:9px;padding:8px 16px;
  color:var(--sbt);font-size:13.5px;border-left:2px solid transparent;
  transition:background .1s,color .1s;text-decoration:none;
}
.nl:hover{background:var(--sbh);color:rgba(255,255,255,0.9);text-decoration:none}
.nl.act{background:rgba(91,79,212,0.18);border-left-color:var(--pu);color:#fff}
.nl svg{opacity:.65;flex-shrink:0}
.nl.act svg,.nl:hover svg{opacity:1}

.nb{
  margin-left:auto;background:var(--rd);color:#fff;
  font-size:10px;font-family:var(--m);padding:1px 6px;
  border-radius:10px;min-width:18px;text-align:center;line-height:16px;
}

.sb-foot{padding:12px 16px;border-top:1px solid var(--sbb);flex-shrink:0}
.sb-user{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.sb-av{
  width:28px;height:28px;border-radius:50%;background:var(--pu);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:600;color:#fff;flex-shrink:0;
}
.sb-un{font-size:12.5px;color:rgba(255,255,255,0.75);font-weight:500}
.sb-ur{font-size:10px;color:rgba(255,255,255,0.32);font-family:var(--m)}
.sb-logout{display:flex;align-items:center;gap:6px;color:rgba(255,255,255,0.32);font-size:12px;cursor:pointer;transition:color .12s;text-decoration:none}
.sb-logout:hover{color:rgba(255,255,255,0.65);text-decoration:none}

/* ── MAIN ──────────────────────────────────────────────── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}

/* ── TOPBAR ─────────────────────────────────────────────── */
.topbar{
  height:48px;background:var(--su);border-bottom:1px solid var(--bd);
  display:flex;align-items:center;padding:0 20px;gap:12px;flex-shrink:0;
}
.tb-title{font-size:14.5px;font-weight:600;flex:1}
.tb-right{display:flex;gap:8px}
.tb-btn{
  display:flex;align-items:center;gap:5px;padding:6px 11px;
  border:1px solid var(--bd);border-radius:var(--r);background:var(--su);
  color:var(--t2);font-size:12.5px;transition:all .1s;
}
.tb-btn:hover{border-color:var(--bd2);color:var(--t1)}

/* ── CONTENT ─────────────────────────────────────────────── */
.content{flex:1;overflow-y:auto;padding:20px}
.content::-webkit-scrollbar{width:5px}
.content::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:3px}

/* ── METRIC GRID ─────────────────────────────────────────── */
.mg{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px}
.mc{background:var(--su);border:1px solid var(--bd);border-radius:var(--rl);padding:15px 17px}
.mc-lbl{font-size:10.5px;font-family:var(--m);color:var(--t3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:9px}
.mc-val{font-size:27px;font-weight:600;letter-spacing:-.5px;line-height:1;font-variant-numeric:tabular-nums}
.mc-sub{font-size:11.5px;color:var(--t3);margin-top:4px}
.mc-tr{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:500;margin-top:6px;padding:2px 7px;border-radius:10px}
.tr-up{background:var(--gr-s);color:var(--gr)}
.tr-dn{background:var(--rd-s);color:var(--rd)}
.tr-fl{background:var(--su3);color:var(--t3)}

/* ── CARD ────────────────────────────────────────────────── */
.card{background:var(--su);border:1px solid var(--bd);border-radius:var(--rl);margin-bottom:16px;overflow:hidden}
.ch{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid var(--bd);min-height:46px;gap:10px}
.ch-title{font-size:13.5px;font-weight:600}
.ch-sub{font-size:12px;color:var(--t3);margin-left:auto}
.ch-acts{display:flex;gap:8px;margin-left:auto}
.cb{padding:14px 16px}

/* ── TWO / THREE COL ─────────────────────────────────────── */
.g2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:16px}
.g3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:16px}

/* ── FILTER BAR ──────────────────────────────────────────── */
.fb{
  display:flex;align-items:center;gap:9px;padding:10px 14px;
  background:var(--su2);border-bottom:1px solid var(--bd);flex-wrap:wrap;
}
.fb-count{margin-left:auto;font-size:11.5px;color:var(--t3);font-family:var(--m);white-space:nowrap}
.fb-search{
  display:flex;align-items:center;gap:6px;background:var(--su);
  border:1px solid var(--bd);border-radius:var(--r);padding:5px 10px;
  min-width:0;flex:1;max-width:240px;
}
.fb-search:focus-within{border-color:var(--pu)}
.fb-search input{border:none;background:none;outline:none;font-size:13px;color:var(--t1);width:100%}
.fb-search input::placeholder{color:var(--t3)}
.fb-search svg{color:var(--t3);flex-shrink:0}

/* ── FORM ────────────────────────────────────────────────── */
.fi,.fs,.fta{
  width:100%;padding:7px 10px;border:1px solid var(--bd);border-radius:var(--r);
  background:var(--su);color:var(--t1);font-size:13.5px;outline:none;
  transition:border-color .12s;line-height:1.4;
}
.fi:focus,.fs:focus,.fta:focus{border-color:var(--pu);box-shadow:0 0 0 2px rgba(91,79,212,0.08)}
.fta{min-height:78px;resize:vertical}
.fg{margin-bottom:13px}
.fl{display:block;font-size:12px;font-weight:500;color:var(--t2);margin-bottom:4px}

.fs-sm{width:auto;font-size:12.5px;padding:5px 8px}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:5px;padding:7px 13px;
  border-radius:var(--r);font-size:13px;font-weight:500;border:1px solid;
  transition:all .1s;white-space:nowrap;cursor:pointer;line-height:1;
}
.btn-p{background:var(--pu);border-color:var(--pu);color:#fff}
.btn-p:hover{background:var(--pu-d);border-color:var(--pu-d)}
.btn-g{background:var(--su);border-color:var(--bd);color:var(--t2)}
.btn-g:hover{border-color:var(--bd2);color:var(--t1);background:var(--su2)}
.btn-r{background:var(--rd-s);border-color:var(--rd);color:var(--rd)}
.btn-r:hover{background:var(--rd);color:#fff}
.btn-ok{background:var(--gr-s);border-color:var(--gr);color:var(--gr)}
.btn-ok:hover{background:var(--gr);color:#fff}
.btn-sm{padding:5px 9px;font-size:12px}
.btn:disabled{opacity:.45;cursor:not-allowed}

/* ── TABLE ───────────────────────────────────────────────── */
.tbl{width:100%;border-collapse:collapse}
.tbl th{
  text-align:left;font-size:10.5px;font-family:var(--m);color:var(--t3);
  text-transform:uppercase;letter-spacing:.6px;padding:9px 13px;
  border-bottom:1px solid var(--bd);background:var(--su2);font-weight:500;white-space:nowrap;
}
.tbl td{padding:10px 13px;border-bottom:1px solid var(--bd);font-size:13.5px;vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:#FAFAF8}
.td-m{font-family:var(--m);font-size:12px;color:var(--t2)}
.td-dim{color:var(--t2)}
.td-str{font-weight:600}
.td-act{white-space:nowrap;display:flex;gap:5px;align-items:center}

/* ── BADGES ──────────────────────────────────────────────── */
.bd{display:inline-flex;align-items:center;font-size:10.5px;font-weight:500;font-family:var(--m);padding:2px 7px;border-radius:4px;white-space:nowrap}
.bd-green{background:var(--gr-s);color:var(--gr)}
.bd-amber{background:var(--am-s);color:var(--am)}
.bd-red{background:var(--rd-s);color:var(--rd)}
.bd-dim{background:var(--su3);color:var(--t3)}
.bd-blue{background:var(--bl-s);color:var(--bl)}
.bd-purple{background:var(--pu-s);color:var(--pu)}
.bd-gold{background:var(--go-s);color:var(--go)}
.bd-dark{background:#1A1816;color:#fff}

/* ── TABS ────────────────────────────────────────────────── */
.tabs{display:flex;border-bottom:1px solid var(--bd);padding:0 14px;background:var(--su)}
.tab{padding:10px 13px;font-size:13px;color:var(--t3);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;transition:all .1s;white-space:nowrap}
.tab:hover{color:var(--t2)}
.tab.on{color:var(--pu);border-bottom-color:var(--pu);font-weight:500}

/* ── MODAL ───────────────────────────────────────────────── */
.modal{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,0.42);
  z-index:200;align-items:center;justify-content:center;padding:16px;
}
.modal-box{
  background:var(--su);border-radius:var(--rl);width:500px;max-width:100%;
  max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shm);
  border:1px solid var(--bd);overflow:hidden;
}
.modal-lg .modal-box{width:660px}
.modal-sm .modal-box{width:370px}
.mh{display:flex;align-items:center;padding:14px 18px;border-bottom:1px solid var(--bd);flex-shrink:0}
.mh-title{font-size:14.5px;font-weight:600;flex:1}
.mx{width:27px;height:27px;border:1px solid var(--bd);border-radius:var(--r);background:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--t2);font-size:17px;transition:all .1s}
.mx:hover{background:var(--su2);color:var(--t1)}
.mb{padding:16px 18px;overflow-y:auto;flex:1}
.mf{padding:11px 18px;border-top:1px solid var(--bd);display:flex;justify-content:flex-end;gap:7px;background:var(--su2);flex-shrink:0}

/* ── DETAIL GRID ─────────────────────────────────────────── */
.dg{display:grid;grid-template-columns:120px 1fr;gap:7px 10px;margin-bottom:14px}
.dk{font-size:12px;color:var(--t3)}
.dv{font-size:13.5px;font-weight:500}

/* ── STAT ROW ─────────────────────────────────────────────── */
.sr{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--bd);font-size:13px}
.sr:last-child{border-bottom:none}
.sr-l{color:var(--t2)}
.sr-v{font-weight:600;font-family:var(--m)}

/* ── PROGRESS BAR ─────────────────────────────────────────── */
.pr{height:4px;background:var(--su3);border-radius:2px;overflow:hidden}
.pr-f{height:100%;border-radius:2px;transition:width .4s}
.pr-gr{background:var(--gr)} .pr-am{background:var(--am)} .pr-rd{background:var(--rd)} .pr-pu{background:var(--pu)}

/* ── BAR CHART ───────────────────────────────────────────── */
.bc{display:flex;align-items:flex-end;gap:5px;height:76px}
.bar{flex:1;background:var(--pu-s);border-radius:3px 3px 0 0;min-height:3px;position:relative;transition:background .12s;cursor:default}
.bar:hover{background:var(--pu)}
.bar-v{position:absolute;bottom:calc(100% + 2px);left:50%;transform:translateX(-50%);font-size:8.5px;font-family:var(--m);color:var(--t3);white-space:nowrap}
.bl{display:flex;gap:5px;margin-top:4px}
.bl-l{flex:1;text-align:center;font-size:9px;font-family:var(--m);color:var(--t3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── ACTIVITY ─────────────────────────────────────────────── */
.ai{display:flex;gap:10px;padding:9px 0;border-bottom:1px solid var(--bd)}
.ai:last-child{border-bottom:none}
.ad{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:5px}
.ad-gr{background:var(--gr)} .ad-am{background:var(--am)} .ad-rd{background:var(--rd)} .ad-pu{background:var(--pu)} .ad-bl{background:var(--bl)}
.at{font-size:13px}
.atime{font-size:11px;color:var(--t3);font-family:var(--m);margin-top:1px}

/* ── HEALTH DOT ───────────────────────────────────────────── */
.hd{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:5px;flex-shrink:0}
.hd-ok{background:var(--gr)} .hd-w{background:var(--am)} .hd-err{background:var(--rd)}

/* ── ID PREVIEW ───────────────────────────────────────────── */
.id-box{background:var(--su2);border:1px dashed var(--bd2);border-radius:var(--r);padding:12px;text-align:center;font-size:11.5px;color:var(--t3);margin-bottom:13px;font-family:var(--m)}

/* ── PAGINATION ───────────────────────────────────────────── */
.pag{display:flex;align-items:center;gap:3px;padding:10px 14px;border-top:1px solid var(--bd)}
.pg{min-width:28px;height:28px;padding:0 7px;border:1px solid var(--bd);border-radius:var(--r);background:var(--su);color:var(--t2);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s;font-family:var(--m)}
.pg:hover{border-color:var(--pu);color:var(--pu)}
.pg.on{background:var(--pu);border-color:var(--pu);color:#fff}
.pg.off{opacity:.38;cursor:not-allowed;pointer-events:none}
.pg-dot{font-size:12px;color:var(--t3);padding:0 3px}

/* ── TOAST ────────────────────────────────────────────────── */
#toasts{position:fixed;bottom:18px;right:18px;z-index:500;display:flex;flex-direction:column;gap:7px;pointer-events:none}
.toast{
  padding:10px 15px;border-radius:var(--rl);font-size:13px;font-weight:500;border:1px solid;
  box-shadow:var(--shm);max-width:300px;opacity:0;transform:translateY(6px);
  transition:all .22s;pointer-events:all;
}
.toast.in{opacity:1;transform:translateY(0)}
.toast-success{background:var(--gr-s);border-color:var(--gr);color:var(--gr)}
.toast-error{background:var(--rd-s);border-color:var(--rd);color:var(--rd)}
.toast-info{background:var(--pu-s);border-color:var(--pu);color:var(--pu)}
.toast-warning{background:var(--am-s);border-color:var(--am);color:var(--am)}

/* ── SKELETON ─────────────────────────────────────────────── */
@keyframes sh{from{background-position:-200% 0}to{background-position:200% 0}}
.sk{height:13px;width:80%;border-radius:3px;background:linear-gradient(90deg,var(--su3) 25%,#EDEAE4 50%,var(--su3) 75%);background-size:200%;animation:sh 1.4s infinite}

/* ── SPINNER ──────────────────────────────────────────────── */
@keyframes spin{to{transform:rotate(360deg)}}
.sp{display:inline-block;width:13px;height:13px;border:2px solid rgba(91,79,212,.2);border-top-color:var(--pu);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}

/* ── LOGIN PAGE ───────────────────────────────────────────── */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}
.login-card{width:360px;background:var(--su);border:1px solid var(--bd);border-radius:var(--rl);padding:30px;box-shadow:var(--shm)}
.login-brand-name{font-size:21px;font-weight:700;color:var(--t1)}
.login-brand-sub{font-size:11.5px;color:var(--t3);font-family:var(--m);margin-top:2px;margin-bottom:22px}
.login-err{background:var(--rd-s);border:1px solid var(--rd);color:var(--rd);border-radius:var(--r);padding:8px 11px;font-size:13px;margin-bottom:12px;display:none}
.login-submit{width:100%;padding:10px;justify-content:center;font-size:14px}
.login-sec{text-align:center;margin-top:16px;font-size:11px;color:var(--t3);font-family:var(--m)}
.login-div{height:1px;background:var(--bd);margin:18px 0}

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media(max-width:900px){.mg{grid-template-columns:repeat(2,1fr)}.sb{display:none}}

/* ── CONFIRM DIALOG ───────────────────────────────────────── */
#confirm-dlg .modal-box{width:360px}
