/* ============================================================
   === WHOLESOME LAYERS PAYROLL — STYLESHEET BERSAMA ===
   === DESIGN TOKENS === */
:root{
  --bg:#1a1a1a; --bg-2:#242424; --bg-3:#2e2e2e;
  --amber:#e8a020; --amber-soft:rgba(232,160,32,.13);
  --cream:#f5f0e8; --muted:#9a948a; --line:#3a3a3a;
  --green:#3fb950; --green-soft:rgba(63,185,80,.13);
  --red:#f0584e; --red-soft:rgba(240,88,78,.12);
  --yellow:#e3a008; --blue:#4a9eff; --gray:#6b7280;
  --radius:14px; --radius-sm:10px;
  --font-head:Georgia,"Times New Roman",serif;
  --font-ui:system-ui,-apple-system,"Segoe UI",sans-serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;padding:0;}
body{
  background:
    radial-gradient(1100px 460px at 100% -8%, rgba(232,160,32,.07), transparent 60%),
    var(--bg);
  color:var(--cream); font-family:var(--font-ui); min-height:100vh; line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--amber);text-decoration:none;}

/* === LAYOUT APP (sidebar + main) === */
.app-shell{display:flex;min-height:100vh;}
.sidebar{
  width:230px;flex:0 0 230px;background:var(--bg-2);border-right:1px solid var(--line);
  padding:18px 12px;position:sticky;top:0;height:100vh;overflow-y:auto;
  display:flex;flex-direction:column;
}
.sb-brand{display:flex;align-items:center;gap:10px;padding:4px 8px 18px;}
.sb-logo{width:38px;height:38px;border-radius:10px;background:linear-gradient(145deg,var(--amber),#c8821a);
  display:grid;place-items:center;color:#241a08;font-family:var(--font-head);font-weight:bold;font-size:18px;flex:0 0 auto;}
.sb-brand .t{font-family:var(--font-head);font-size:15px;line-height:1.2;}
.sb-brand .s{font-size:10.5px;color:var(--muted);}
.nav a{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:var(--radius-sm);
  color:var(--cream);font-size:14px;margin-bottom:3px;cursor:pointer;transition:background .12s;}
.nav a:hover{background:var(--bg-3);}
.nav a.active{background:var(--amber);color:#241a08;font-weight:600;}
.nav a .ico{font-size:17px;width:22px;text-align:center;}
.sb-foot{margin-top:auto;font-size:11px;color:var(--muted);text-align:center;padding-top:14px;}

.main{flex:1;min-width:0;padding:20px 22px 60px;}
.topbar{display:flex;align-items:center;gap:12px;margin-bottom:18px;}
.hamburger{display:none;background:var(--bg-3);border:1px solid var(--line);color:var(--cream);
  width:42px;height:42px;border-radius:10px;font-size:20px;cursor:pointer;flex:0 0 auto;}
.page-title{font-family:var(--font-head);font-size:23px;margin:0;flex:1;}

/* === MOBILE === */
@media(max-width:820px){
  .sidebar{position:fixed;left:0;top:0;z-index:200;transform:translateX(-100%);transition:transform .22s;}
  .sidebar.open{transform:translateX(0);box-shadow:0 0 40px rgba(0,0,0,.6);}
  .hamburger{display:block;}
  .overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:150;}
  .overlay.show{display:block;}
  .main{padding:16px 14px 60px;}
  .page-title{font-size:19px;}
}

/* === CARD === */
.card{background:linear-gradient(180deg,var(--bg-2),#202020);border:1px solid var(--line);
  border-radius:var(--radius);padding:16px;margin-bottom:16px;}
.card h2{font-size:12px;letter-spacing:1.3px;text-transform:uppercase;color:var(--amber);
  margin:0 0 14px;font-weight:700;}

/* === STAT CARDS === */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:16px;}
.stat{background:linear-gradient(180deg,var(--bg-2),#1e1e1e);border:1px solid var(--line);
  border-radius:var(--radius);padding:16px;}
.stat .lbl{font-size:12px;color:var(--muted);margin-bottom:7px;}
.stat .val{font-size:24px;font-weight:700;font-family:var(--font-head);}
.stat.green .val{color:var(--green);}
.stat.red .val{color:var(--red);}
.stat.amber .val{color:var(--amber);}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:44px;
  padding:0 16px;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;
  font-family:var(--font-ui);cursor:pointer;transition:transform .08s,filter .14s;letter-spacing:.2px;}
.btn:active{transform:scale(.98);}
.btn:disabled{opacity:.4;cursor:not-allowed;}
.btn-primary{background:var(--amber);color:#241a08;}
.btn-primary:hover:not(:disabled){filter:brightness(1.07);}
.btn-ghost{background:var(--bg-3);color:var(--cream);border:1.5px solid var(--line);}
.btn-ghost:hover:not(:disabled){border-color:var(--amber);}
.btn-green{background:var(--green);color:#04240c;}
.btn-danger{background:var(--red-soft);color:var(--red);border:1px solid var(--red);}
.btn-sm{min-height:36px;font-size:13px;padding:0 11px;}
.btn-xs{min-height:30px;font-size:12px;padding:0 9px;border-radius:8px;}

/* === FORM === */
label.fld{display:block;font-size:12px;color:var(--muted);margin:11px 0 4px;}
input,select,textarea{width:100%;background:var(--bg-3);border:1.5px solid var(--line);color:var(--cream);
  border-radius:var(--radius-sm);padding:10px 12px;font-size:14.5px;font-family:var(--font-ui);}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--amber);}
input.num{text-align:right;}
.row{display:flex;gap:10px;flex-wrap:wrap;}
.row>*{flex:1;min-width:120px;}
.controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:14px;}
.controls .grow{flex:1;}

/* === TABLE === */
.tbl-wrap{overflow-x:auto;border-radius:var(--radius-sm);}
table{width:100%;border-collapse:collapse;font-size:13.5px;}
th,td{text-align:left;padding:10px 11px;border-bottom:1px solid var(--line);white-space:nowrap;}
th{font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);background:var(--bg-3);position:sticky;top:0;}
tbody tr:hover{background:rgba(255,255,255,.02);}
td.num,th.num{text-align:right;}
tfoot td{font-weight:700;border-top:2px solid var(--line);background:var(--bg-3);}

/* === BADGE === */
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11.5px;font-weight:600;}
.b-green{background:var(--green-soft);color:var(--green);}
.b-red{background:var(--red-soft);color:var(--red);}
.b-yellow{background:rgba(227,160,8,.14);color:var(--yellow);}
.b-gray{background:rgba(107,114,128,.18);color:#b6bcc6;}
.b-amber{background:var(--amber-soft);color:var(--amber);}

/* === STATUS PILL (toggle absensi) === */
.status-pills{display:inline-flex;gap:4px;background:var(--bg);padding:3px;border-radius:9px;}
.status-pills button{border:none;background:transparent;color:var(--muted);padding:5px 9px;border-radius:6px;
  font-size:12px;cursor:pointer;font-weight:600;}
.status-pills button.on-hadir{background:var(--green);color:#04240c;}
.status-pills button.on-izin{background:var(--yellow);color:#241a08;}
.status-pills button.on-sakit{background:var(--blue);color:#04243f;}
.status-pills button.on-alpha{background:var(--red);color:#fff;}

/* === GRID CALENDAR CELL === */
.cell-hadir{background:var(--green-soft);}
.cell-izin,.cell-sakit{background:rgba(227,160,8,.10);}
.cell-alpha{background:var(--red-soft);}
.cell-empty{color:var(--muted);}

/* === ALERT === */
.alert{border-radius:var(--radius-sm);padding:11px 14px;font-size:13px;margin-bottom:10px;line-height:1.6;}
.alert-warn{background:var(--amber-soft);border:1px solid rgba(232,160,32,.3);}
.alert-info{background:rgba(74,158,255,.1);border:1px solid rgba(74,158,255,.3);}
.alert b{color:var(--cream);}

/* === TOP LIST === */
.toplist{display:flex;flex-direction:column;gap:8px;}
.toprow{display:flex;align-items:center;gap:12px;padding:9px 12px;background:var(--bg-3);border-radius:var(--radius-sm);}
.toprow .rank{width:26px;height:26px;border-radius:50%;background:var(--amber);color:#241a08;
  display:grid;place-items:center;font-weight:700;font-size:13px;flex:0 0 auto;}
.toprow .info{flex:1;min-width:0;}
.toprow .info .n{font-weight:600;}
.toprow .info .s{font-size:12px;color:var(--muted);}
.toprow .amt{font-weight:700;color:var(--amber);}

/* === MODAL === */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.7);display:none;align-items:center;
  justify-content:center;z-index:300;padding:18px;}
.modal.show{display:flex;}
.modal .box{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;max-width:460px;width:100%;max-height:88vh;overflow-y:auto;}
.modal h3{margin:0 0 14px;font-family:var(--font-head);font-size:18px;}
.modal-actions{display:flex;gap:10px;margin-top:18px;}
.modal-actions .btn{flex:1;}

/* === TOAST === */
#toasts{position:fixed;left:0;right:0;bottom:18px;display:flex;flex-direction:column;align-items:center;
  gap:8px;z-index:9999;pointer-events:none;padding:0 14px;}
.toast{background:#111;color:var(--cream);border:1px solid var(--line);padding:11px 18px;border-radius:30px;
  font-size:13.5px;box-shadow:0 8px 24px rgba(0,0,0,.5);max-width:92%;border-left:4px solid var(--amber);
  animation:slideUp .25s ease;}
.toast.ok{border-left-color:var(--green);}
.toast.err{border-left-color:var(--red);}
@keyframes slideUp{from{transform:translateY(18px);opacity:0;}to{transform:translateY(0);opacity:1;}}

.muted{color:var(--muted);}
.center{text-align:center;}
.mt{margin-top:14px;}
.empty-state{text-align:center;color:var(--muted);padding:30px 14px;font-size:14px;}
.hide{display:none!important;}
.chart-box{position:relative;height:300px;}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--amber-soft);color:var(--amber);
  display:grid;place-items:center;font-weight:700;font-size:14px;flex:0 0 auto;}
