/* =====================================================
   NALE v5 — Modern HRIS 2026
   Zero CDN · System Fonts · SVG Icons via JS
   ===================================================== */

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

:root{
  --font:-apple-system,BlinkMacSystemFont,'Segoe UI','Helvetica Neue',Arial,sans-serif;
  --font-mono:'SF Mono','Fira Code',Consolas,monospace;
  --nav-h:60px;--nav-bottom-h:72px;
  --z-nav:100;--z-modal:200;--z-snack:300;--z-lb:400;
}

[data-theme="light"]{
  --bg:#F1F5F9;--surface:#FFF;--surface-2:#F8FAFC;
  --border:#E2E8F0;--border-strong:#CBD5E1;
  --primary:#2563EB;--primary-dk:#1D4ED8;--primary-lt:#EFF6FF;--primary-text:#1E40AF;
  --success:#059669;--success-lt:#ECFDF5;--success-text:#065F46;
  --warning:#D97706;--warning-lt:#FFFBEB;--warning-text:#92400E;
  --error:#DC2626;--error-lt:#FEF2F2;--error-text:#991B1B;
  --purple:#7C3AED;--purple-lt:#F5F3FF;
  --text:#0F172A;--text-2:#334155;--text-3:#64748B;--text-4:#94A3B8;
  --shadow-sm:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06);
  --shadow-lg:0 10px 15px rgba(0,0,0,.08),0 4px 6px rgba(0,0,0,.05);
  --shadow-xl:0 20px 25px rgba(0,0,0,.08),0 10px 10px rgba(0,0,0,.04);
  --inp-bg:#F8FAFC;--inp-focus:#FFF;
}
[data-theme="dark"]{
  --bg:#0F172A;--surface:#1E293B;--surface-2:#162032;
  --border:#334155;--border-strong:#475569;
  --primary:#3B82F6;--primary-dk:#2563EB;--primary-lt:#1E3A8A;--primary-text:#93C5FD;
  --success:#10B981;--success-lt:#064E3B;--success-text:#6EE7B7;
  --warning:#F59E0B;--warning-lt:#451A03;--warning-text:#FCD34D;
  --error:#EF4444;--error-lt:#450A0A;--error-text:#FCA5A5;
  --purple:#A78BFA;--purple-lt:#2E1065;
  --text:#F1F5F9;--text-2:#CBD5E1;--text-3:#94A3B8;--text-4:#64748B;
  --shadow-sm:0 1px 3px rgba(0,0,0,.3);
  --shadow-md:0 4px 6px rgba(0,0,0,.3);
  --shadow-lg:0 10px 15px rgba(0,0,0,.3);
  --shadow-xl:0 20px 25px rgba(0,0,0,.3);
  --inp-bg:#1E293B;--inp-focus:#263348;
}

html{font-size:16px;}
body{
  font-family:var(--font);background:var(--bg);color:var(--text);
  line-height:1.5;-webkit-font-smoothing:antialiased;
  padding-top:var(--nav-h);
  padding-bottom:calc(var(--nav-bottom-h) + 16px);
  min-height:100vh;
}
a{color:var(--primary);text-decoration:none;}
a:hover{text-decoration:underline;}

/* ── Icon System ── */
.ms{
  display:inline-flex;align-items:center;justify-content:center;
  width:20px;height:20px;flex-shrink:0;vertical-align:middle;
  color:currentColor;font-size:0;user-select:none;line-height:1;
}
.ms svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.ms.sm{width:15px;height:15px;}
.ms.lg{width:30px;height:30px;}
.ms.filled svg{stroke-width:2.5;}
.ms svg{pointer-events:none;}

/* ── Top Bar ── */
.top-bar{position:fixed;top:0;left:0;right:0;height:var(--nav-h);background:var(--surface);border-bottom:1px solid var(--border);z-index:var(--z-nav);transition:box-shadow .2s;}
.top-bar.elevated{box-shadow:var(--shadow-md);}
.top-bar-inner{max-width:1200px;margin:0 auto;height:100%;display:flex;align-items:center;gap:8px;padding:0 16px;}
.top-bar-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);}
.top-bar-logo:hover{text-decoration:none;}
.top-bar-icon{width:34px;height:34px;background:var(--primary);border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;}
.top-bar-icon .ms{width:18px;height:18px;color:#fff;}
.top-bar-icon .ms svg{stroke:#fff;}
.top-bar-title{font-size:.95rem;font-weight:700;letter-spacing:-.01em;color:var(--text);}
.top-bar-leading{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--text-3);cursor:pointer;transition:background .15s;text-decoration:none;}
.top-bar-leading:hover{background:var(--bg);color:var(--text);text-decoration:none;}
.top-bar-actions{display:flex;align-items:center;gap:6px;}
@media(min-width:1024px){
  /* Desktop dgn sidebar: topnav inner full-width, logo flush kiri, actions flush kanan */
  body:has(.sidebar) .top-bar-inner{max-width:none;padding-left:20px;padding-right:24px;}
  /* Logo alignment: lebih dekat ke sidebar column (kiri viewport) */
  body:has(.sidebar) .top-bar-logo{margin-left:0;}
}
.icon-btn{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-3);transition:background .15s,color .15s;}
.icon-btn:hover{background:var(--bg);color:var(--text);}
.avatar-btn{width:34px;height:34px;border-radius:50%;background:var(--primary);color:#fff;font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;border:2px solid var(--border);transition:border-color .15s;user-select:none;}
.avatar-btn:hover{border-color:var(--primary);}

/* ── Dropdown ── */
.md-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-xl);min-width:200px;padding:6px;z-index:999;opacity:0;pointer-events:none;transform:translateY(-6px) scale(.97);transition:opacity .15s,transform .15s;}
.md-menu.open{opacity:1;pointer-events:all;transform:translateY(0) scale(1);}
.md-menu-email{padding:8px 10px 6px;font-size:.75rem;color:var(--text-3);font-weight:500;}
.md-menu-divider{height:1px;background:var(--border);margin:4px 0;}
.md-menu-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;font-size:.875rem;color:var(--text-2);cursor:pointer;transition:background .12s;text-decoration:none;}
.md-menu-item:hover{background:var(--bg);text-decoration:none;color:var(--text);}
.md-menu-item.danger{color:var(--error);}
.md-menu-item.danger:hover{background:var(--error-lt);}
.md-menu-item .ms{width:16px;height:16px;color:var(--text-3);}

/* ── Bottom Nav ── */
.nav-bar{position:fixed;bottom:0;left:0;right:0;height:var(--nav-bottom-h);background:var(--surface);border-top:1px solid var(--border);z-index:var(--z-nav);box-shadow:0 -4px 12px rgba(0,0,0,.06);}
.nav-bar-inner{max-width:480px;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-around;padding:0 8px;padding-bottom:env(safe-area-inset-bottom);}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;padding:6px 8px;border-radius:12px;color:var(--text-3);text-decoration:none;cursor:pointer;transition:color .15s;}
.nav-item:hover{color:var(--primary);text-decoration:none;}
.nav-item.active{color:var(--primary);}
.nav-item-pill{width:46px;height:28px;border-radius:14px;display:flex;align-items:center;justify-content:center;transition:background .15s;position:relative;}
.nav-item.active .nav-item-pill{background:var(--primary-lt);}
.nav-item .ms{width:22px;height:22px;}
.nav-label{font-size:.68rem;font-weight:600;white-space:nowrap;}
.nav-badge{position:absolute;top:-3px;right:-3px;background:var(--error);color:#fff;font-size:.58rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid var(--surface);}
.nav-fab-wrap{flex:1;display:flex;justify-content:center;}
.nav-fab{width:50px;height:50px;border-radius:16px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:transform .15s,box-shadow .15s;text-decoration:none;}
.nav-fab:hover{transform:scale(1.06);box-shadow:var(--shadow-lg);text-decoration:none;}
.nav-fab .ms{width:22px;height:22px;color:#fff;}
.nav-fab .ms svg{stroke:#fff;}

/* ── Sidebar (Persistent desktop ≥1024px, drawer mobile <1024px) ── */
:root{--sidebar-w:240px;}
.sidebar{position:fixed;top:var(--nav-h);left:0;bottom:0;width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:var(--z-nav);transform:translateX(-100%);transition:transform .25s cubic-bezier(0.32,0.72,0,1);overflow-y:auto;}
.sidebar.open{transform:translateX(0);}
@media(min-width:1024px){
  /* Hanya apply layout sidebar kalau page-nya memang punya sidebar (login.php tidak punya) */
  body:has(.sidebar) .sidebar{transform:translateX(0);box-shadow:none;}
  body:has(.sidebar){padding-left:var(--sidebar-w);padding-bottom:24px;}
  body:has(.sidebar) .nav-bar{display:none;}
  /* Topnav tetap full-width (left:0, right:0) supaya tidak ada empty corner di kiri-atas.
     Sidebar dimulai di top:60 (di bawah topnav). Pattern standar Gmail/Notion/Linear. */
}
.sb-header{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border);}
.sb-avatar{width:34px;height:34px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;flex-shrink:0;}
.sb-user{flex:1;min-width:0;}
.sb-user-name{font-size:.875rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sb-user-meta{font-size:.72rem;color:var(--text-3);margin-top:1px;}
.sb-close{display:none;}
@media(max-width:1023px){.sb-close{display:flex;}}
.sb-nav{flex:1;padding:8px;display:flex;flex-direction:column;gap:2px;}
.sb-section{font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);padding:10px 12px 6px;}
.sb-section:first-child{padding-top:6px;}
.sb-item{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:10px;font-size:.875rem;color:var(--text-2);cursor:pointer;text-decoration:none;background:none;border:0;width:100%;text-align:left;font-family:inherit;transition:background .12s,color .12s;}
.sb-item:hover{background:var(--bg);color:var(--text);text-decoration:none;}
.sb-item.active{background:var(--primary-lt);color:var(--primary);font-weight:600;}
.sb-item.active .ms{color:var(--primary);}
.sb-item .ms{width:20px;height:20px;flex-shrink:0;color:var(--text-3);}
.sb-item-lbl{flex:1;}
.sb-item-danger{color:var(--error);margin-top:6px;}
.sb-item-danger:hover{background:var(--error-lt);color:var(--error);}
.sb-item-danger .ms{color:var(--error);}
.sb-footer{padding:14px 16px;border-top:1px solid var(--border);font-size:.7rem;color:var(--text-3);}
.sb-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(2px);z-index:calc(var(--z-nav) - 1);opacity:0;pointer-events:none;transition:opacity .25s;}
.sb-backdrop.open{opacity:1;pointer-events:all;}
@media(min-width:1024px){.sb-backdrop{display:none;}}

/* Hamburger button di topnav (hanya muncul saat sidebar collapsed di mobile) */
.top-bar-hamburger{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:none;border:0;cursor:pointer;color:var(--text-2);transition:background .12s;}
.top-bar-hamburger:hover{background:var(--bg);}
.top-bar-hamburger .ms{width:22px;height:22px;}
@media(min-width:1024px){.top-bar-hamburger{display:none;}}

/* ── Page ── */
.page-content{max-width:1100px;margin:0 auto;padding:20px 16px;}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap;}
.page-headline{font-size:1.35rem;font-weight:700;color:var(--text);letter-spacing:-.02em;line-height:1.2;}
.page-sub{font-size:.85rem;color:var(--text-3);margin-top:3px;}

/* ── Cards ── */
.md-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;margin-bottom:14px;position:relative;}
.md-card.elevated{box-shadow:var(--shadow-sm);}
.md-card-p{padding:18px;}

/* ── Stats ── */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin-bottom:18px;}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px;display:flex;align-items:center;gap:12px;transition:box-shadow .2s;}
.stat-card:hover{box-shadow:var(--shadow-sm);}
.stat-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.stat-icon .ms{width:22px;height:22px;}
.si-blue{background:var(--primary-lt);color:var(--primary);}
.si-green{background:var(--success-lt);color:var(--success);}
.si-red{background:var(--error-lt);color:var(--error);}
.si-orange{background:var(--warning-lt);color:var(--warning);}
.si-purple{background:var(--purple-lt);color:var(--purple);}
.stat-label{font-size:.7rem;color:var(--text-3);font-weight:600;margin-bottom:2px;text-transform:uppercase;letter-spacing:.05em;}
.stat-value{font-size:1.5rem;font-weight:700;color:var(--text);letter-spacing:-.02em;line-height:1;}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:9px;font-size:.875rem;font-weight:600;font-family:var(--font);cursor:pointer;border:none;transition:all .15s;text-decoration:none;white-space:nowrap;line-height:1;letter-spacing:-.01em;}
.btn:hover{text-decoration:none;}
.btn:disabled{opacity:.45;cursor:not-allowed;}
.btn .ms{width:16px;height:16px;}
.btn-filled{background:var(--primary);color:#fff;}
.btn-filled:hover{background:var(--primary-dk);}
.btn-filled-danger{background:var(--error);color:#fff;}
.btn-filled-danger:hover{background:#B91C1C;}
.btn-outlined{background:transparent;color:var(--primary);border:1.5px solid var(--primary);}
.btn-outlined:hover{background:var(--primary-lt);}
.btn-text{background:transparent;color:var(--text-2);}
.btn-text:hover{background:var(--bg);color:var(--text);}
.btn-tonal{background:var(--primary-lt);color:var(--primary-text);}
.btn-tonal:hover{background:#DBEAFE;}
[data-theme="dark"] .btn-tonal:hover{background:#1E3A8A;}
.btn-tonal-success{background:var(--success-lt);color:var(--success-text);}
.btn-tonal-success:hover{background:#D1FAE5;}
[data-theme="dark"] .btn-tonal-success:hover{background:#065F46;}
.btn-tonal-danger{background:var(--error-lt);color:var(--error-text);}
.btn-tonal-danger:hover{background:#FEE2E2;}
[data-theme="dark"] .btn-tonal-danger:hover{background:#450A0A;}
.btn-tonal-warning{background:var(--warning-lt);color:var(--warning-text);}
.btn-tonal-warning:hover{background:#FEF3C7;}
.btn-wa{background:rgba(37,211,102,0.12);color:#128C7E;border:none;}
.btn-wa:hover{background:rgba(37,211,102,0.22);}
[data-theme="dark"] .btn-wa{color:#25D366;}
[data-theme="dark"] .btn-wa:hover{background:rgba(37,211,102,0.18);}
.btn-sm{padding:6px 12px;font-size:.8rem;border-radius:7px;}
.btn-sm .ms{width:14px;height:14px;}
.btn-block{width:100%;justify-content:center;}

/* ── Chips ── */
.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:600;letter-spacing:.01em;white-space:nowrap;line-height:1.4;}
.chip .ms{width:12px;height:12px;}
.chip-primary{background:var(--primary-lt);color:var(--primary-text);}
.chip-success{background:var(--success-lt);color:var(--success-text);}
.chip-error{background:var(--error-lt);color:var(--error-text);}
.chip-warning{background:var(--warning-lt);color:var(--warning-text);}
.chip-neutral{background:var(--bg);color:var(--text-3);border:1px solid var(--border);}

/* ── Forms ── */
.md-field{margin-bottom:16px;}
.md-label{display:block;font-size:.8rem;font-weight:600;color:var(--text-2);margin-bottom:6px;letter-spacing:.01em;}
.md-label span{font-weight:400;color:var(--text-4);margin-left:4px;}
.md-input{display:block;width:100%;padding:9px 13px;font-size:.875rem;font-family:var(--font);color:var(--text);background:var(--inp-bg);border:1.5px solid var(--border);border-radius:9px;transition:border-color .15s,background .15s,box-shadow .15s;outline:none;appearance:none;-webkit-appearance:none;}
.md-input:focus{border-color:var(--primary);background:var(--inp-focus);box-shadow:0 0 0 3px rgba(37,99,235,.12);}
.md-input::placeholder{color:var(--text-4);}
textarea.md-input{resize:vertical;min-height:80px;}
select.md-input{cursor:pointer;}
.md-input.has-lead{padding-left:42px;}
.md-input.has-trail{padding-right:42px;}
.md-field-lead,.md-field-trail{position:absolute;width:20px;height:20px;color:var(--text-3);pointer-events:none;}
.md-field-lead{left:13px;}
.md-field-trail{right:13px;cursor:pointer;pointer-events:all;z-index:2;}
.md-helper{font-size:.75rem;color:var(--text-3);margin-top:5px;display:flex;align-items:center;gap:4px;line-height:1.4;}

/* ── Tables ── */
.md-table-wrap{overflow-x:auto;width:100%;}
.md-table{width:100%;border-collapse:collapse;font-size:.875rem;}
.md-table th{padding:10px 16px;text-align:left;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap;}
.md-table td{padding:13px 16px;border-bottom:1px solid var(--border);color:var(--text-2);vertical-align:middle;}
.md-table tr:last-child td{border-bottom:none;}
.md-table tbody tr{transition:background .1s;}
.md-table tbody tr:hover{background:var(--surface-2);}
.md-table tfoot td{background:var(--surface-2);font-weight:600;color:var(--text);border-top:2px solid var(--border);}
@media(max-width:700px){.md-table-wrap{display:none;}}

/* ── Bottom Sheet (mobile) → Centered Modal (desktop ≥768px) ── */
.md-scrim{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:var(--z-modal);display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;backdrop-filter:blur(2px);}
.md-scrim.open{opacity:1;pointer-events:all;}
.md-sheet{background:var(--surface);border-radius:20px 20px 0 0;width:100%;max-width:600px;max-height:92vh;overflow-y:auto;transform:translateY(100%);transition:transform .3s cubic-bezier(0.32,0.72,0,1);padding-bottom:env(safe-area-inset-bottom);
  /* Custom scrollbar: thin, themed, lebih halus dari default browser */
  scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent;}
.md-sheet::-webkit-scrollbar{width:8px;}
.md-sheet::-webkit-scrollbar-track{background:transparent;}
.md-sheet::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px;border:2px solid transparent;background-clip:content-box;}
.md-sheet::-webkit-scrollbar-thumb:hover{background:var(--text-3);background-clip:content-box;border:2px solid transparent;}
.md-scrim.open .md-sheet{transform:translateY(0);}
.md-sheet-handle{width:36px;height:4px;background:var(--border-strong);border-radius:2px;margin:12px auto 6px;}
.md-sheet-head{display:flex;align-items:center;justify-content:space-between;padding:10px 18px 14px;border-bottom:1px solid var(--border);}
.md-sheet-title{font-size:1rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px;}
.md-sheet-body{padding:18px;}

/* Desktop: sheet jadi centered modal lebar, lebih cocok utk landscape */
@media(min-width:768px){
  .md-scrim:not(.center){align-items:center;padding:24px;}
  .md-sheet{border-radius:20px;max-width:720px;max-height:90vh;transform:scale(.96);transition:transform .2s cubic-bezier(0.32,0.72,0,1),opacity .2s;opacity:0;padding-bottom:0;}
  .md-scrim.open .md-sheet{transform:scale(1);opacity:1;}
  .md-sheet-handle{display:none;} /* handle bottom-sheet tidak relevan di centered modal */
  .md-sheet-head{padding:18px 24px;}
  .md-sheet-body{padding:22px 24px;}
}

/* ── Centered Dialog (untuk confirm destructive: logout, hapus, batal cair, dst.) ── */
.md-scrim.center{align-items:center;padding:16px;}
.md-dialog{background:var(--surface);border-radius:20px;width:100%;max-width:400px;padding:24px;box-shadow:var(--shadow-xl);transform:scale(.92);opacity:0;transition:transform .2s cubic-bezier(0.32,0.72,0,1),opacity .2s;}
.md-scrim.open .md-dialog{transform:scale(1);opacity:1;}
.md-dialog-head{display:flex;align-items:center;gap:12px;margin-bottom:10px;}
.md-dialog-icon{flex-shrink:0;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.md-dialog-icon .ms{width:24px;height:24px;}
.md-dialog-icon.danger{background:var(--error-lt);color:var(--error);}
.md-dialog-icon.warning{background:var(--warning-lt);color:var(--warning-text);}
.md-dialog-icon.primary{background:var(--primary-lt);color:var(--primary);}
.md-dialog-title{font-size:1.05rem;font-weight:700;color:var(--text);margin:0;line-height:1.3;}
.md-dialog-body{font-size:.9rem;color:var(--text-2);line-height:1.55;margin-bottom:20px;}
.md-dialog-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;}
.md-dialog-actions form{margin:0;display:inline-block;}

/* ── Custom Month Picker (replace native <input type="month">) ── */
.md-monthpicker{position:relative;display:inline-block;}
.md-monthpicker-trigger{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border-strong);border-radius:8px;padding:7px 10px 7px 12px;font-size:.875rem;color:var(--text);cursor:pointer;font-family:inherit;min-width:180px;justify-content:space-between;transition:border-color .15s,box-shadow .15s;}
.md-monthpicker-trigger:hover{border-color:var(--primary);}
.md-monthpicker-trigger:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-lt);}
.md-monthpicker-trigger .ms{width:18px;height:18px;color:var(--text-3);}
.md-monthpicker-popup{position:absolute;top:calc(100% + 6px);left:0;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-xl);min-width:280px;padding:12px;z-index:calc(var(--z-modal) - 10);opacity:0;pointer-events:none;transform:translateY(-6px) scale(.97);transform-origin:top left;transition:opacity .15s,transform .15s;}
.md-monthpicker.open .md-monthpicker-popup{opacity:1;pointer-events:all;transform:translateY(0) scale(1);}
.md-monthpicker-year{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding:0 4px;}
.md-monthpicker-year button{background:none;border:0;cursor:pointer;color:var(--text-2);padding:4px 8px;border-radius:8px;font-family:inherit;display:flex;align-items:center;justify-content:center;}
.md-monthpicker-year button:hover{background:var(--bg);color:var(--text);}
.md-monthpicker-year button .ms{width:18px;height:18px;}
.md-monthpicker-year-label{font-size:.95rem;font-weight:600;color:var(--text);}
.md-monthpicker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;}
.md-monthpicker-grid button{background:var(--surface-2);border:1px solid transparent;border-radius:10px;padding:10px 8px;font-size:.85rem;color:var(--text-2);cursor:pointer;font-family:inherit;transition:background .12s,color .12s,border-color .12s;}
.md-monthpicker-grid button:hover{background:var(--bg);color:var(--text);border-color:var(--border-strong);}
.md-monthpicker-grid button.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600;}
.md-monthpicker-grid button.today{border-color:var(--primary);color:var(--primary);}
.md-monthpicker-grid button.active.today{color:#fff;}
@media(max-width:480px){
  .md-monthpicker-popup{left:auto;right:0;min-width:260px;}
  .md-monthpicker-trigger{min-width:160px;}
}

/* ── Alerts ── */
.md-alert{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:10px;font-size:.875rem;line-height:1.5;margin-bottom:12px;}
.md-alert .ms{flex-shrink:0;margin-top:1px;width:18px;height:18px;}
.alert-info{background:var(--primary-lt);color:var(--primary-text);border:1px solid #BFDBFE;}
.alert-success{background:var(--success-lt);color:var(--success-text);border:1px solid #A7F3D0;}
.alert-warning{background:var(--warning-lt);color:var(--warning-text);border:1px solid #FDE68A;}
.alert-error{background:var(--error-lt);color:var(--error-text);border:1px solid #FECACA;}

/* ── Snackbar ── */
.snack-stack{position:fixed;bottom:calc(var(--nav-bottom-h) + 12px);left:50%;transform:translateX(-50%);z-index:var(--z-snack);display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none;width:100%;max-width:400px;padding:0 16px;}
.snack{display:flex;align-items:center;gap:10px;background:#1E293B;color:#F1F5F9;padding:11px 16px;border-radius:12px;font-size:.875rem;font-weight:500;box-shadow:var(--shadow-xl);pointer-events:all;animation:snackIn .25s ease;width:100%;cursor:pointer;}
[data-theme="dark"] .snack{background:#334155;}
.snack.out{animation:snackOut .2s ease forwards;}
.snack .ms{width:18px;height:18px;flex-shrink:0;}
.snack-action{margin-left:auto;font-weight:700;font-size:.75rem;color:#93C5FD;cursor:pointer;}
.s-success .ms{color:#6EE7B7;} .s-error .ms{color:#FCA5A5;} .s-warning .ms{color:#FCD34D;} .s-info .ms{color:#93C5FD;}
@keyframes snackIn{from{opacity:0;transform:translateY(8px) scale(.96);}to{opacity:1;transform:none;}}
@keyframes snackOut{to{opacity:0;transform:translateY(4px) scale(.96);}}

/* ── Mobile Cards ── */
.m-list{display:none;width:100%;box-sizing:border-box;}
@media(max-width:700px){.m-list{display:block;}}
.m-card{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:10px;transition:box-shadow .15s;width:100%;}
.m-card:hover{box-shadow:var(--shadow-sm);}
.m-card-stripe{width:4px;flex-shrink:0;border-radius:12px 0 0 12px;}
.m-card-body{flex:1;padding:14px 14px 12px;min-width:0;overflow:hidden;}
.m-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:10px;}
.m-card-title{font-size:.9rem;font-weight:600;color:var(--text);}
.m-card-sub{font-size:.75rem;color:var(--text-3);margin-top:2px;}
.m-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px;}
.m-card-actions{display:flex;gap:6px;flex-wrap:wrap;}
.m-field-lbl{font-size:.67rem;font-weight:600;color:var(--text-4);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px;}
.m-field-val{font-size:.82rem;color:var(--text-2);font-weight:500;}

/* ── Info Grid ── */
.info-grid{display:grid;grid-template-columns:1fr 1fr;}
@media(max-width:500px){.info-grid{grid-template-columns:1fr;}}
.info-cell{padding:13px 16px;border-bottom:1px solid var(--border);}
.info-cell:nth-last-child(-n+2){border-bottom:none;}
.info-cell.full{grid-column:1/-1;}
.info-cell-lbl{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-4);margin-bottom:4px;}
.info-cell-val{font-size:.9rem;color:var(--text);font-weight:500;}
.info-cell-val.pre{white-space:pre-wrap;line-height:1.5;}

/* ── Section Label & Toolbar ── */
.section-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);display:flex;align-items:center;gap:6px;margin-bottom:10px;}
.section-label .ms{width:14px;height:14px;}
.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.divider{height:1px;background:var(--border);margin:14px 0;}

/* ── Login (split layout desktop, stacked mobile) ── */
body:has(.login-surface){padding:0 !important;} /* override global topnav/bottom-nav padding */
.login-surface{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#EFF6FF 0%,#F1F5F9 50%,#F0FDF4 100%);}
[data-theme="dark"] .login-surface{background:linear-gradient(135deg,#0F172A 0%,#1E293B 100%);}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow-xl);width:100%;max-width:440px;overflow:hidden;display:flex;flex-direction:column;}
.login-hero{background:linear-gradient(135deg,var(--primary) 0%,#7C3AED 100%);padding:32px 24px 28px;text-align:center;color:#fff;}
.login-hero img{max-width:180px;width:100%;height:auto;object-fit:contain;margin:0 auto 14px;display:block;}
.login-app-title{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:#fff;}
.login-app-sub{font-size:.85rem;color:rgba(255,255,255,.82);margin-top:4px;}
.login-features{display:none;}
.login-body{padding:30px 28px;display:flex;flex-direction:column;justify-content:center;}
.login-body-title{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:4px;}
.login-body-sub{font-size:.85rem;color:var(--text-3);margin-bottom:20px;}
.login-footer{font-size:.72rem;color:var(--text-3);text-align:center;margin-top:18px;padding:14px 0 0;border-top:1px solid var(--border);}

/* Desktop split: hero kiri + form kanan */
@media(min-width:768px){
  .login-card{max-width:860px;flex-direction:row;}
  .login-hero{flex:0 0 42%;padding:48px 36px;display:flex;flex-direction:column;justify-content:center;text-align:left;}
  .login-hero img{margin:0 0 20px 0;align-self:flex-start;}
  .login-app-title{font-size:1.6rem;}
  .login-app-sub{font-size:.92rem;}
  .login-features{display:block;margin-top:28px;}
  .login-feature-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:14px;font-size:.82rem;color:rgba(255,255,255,.9);}
  .login-feature-item .ms{flex-shrink:0;width:20px;height:20px;color:#fff;margin-top:1px;}
  .login-body{flex:1;padding:48px 40px;}
  .login-body-title{font-size:1.3rem;margin-bottom:6px;}
  .login-body-sub{margin-bottom:24px;}
}

/* ── Cetak Laporan sheet (shared component, dipakai via components/sheet_cetak_laporan.php) ── */
.cetak-grid{display:grid;grid-template-columns:1fr;gap:12px;}
@media(min-width:680px){.cetak-grid{grid-template-columns:1fr 1fr;}}
.cetak-card{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:14px;}
.cetak-card-rentang,.cetak-card-quick{grid-column:1/-1;}
.cetak-card-head{display:flex;align-items:center;gap:8px;margin-bottom:10px;}
.cetak-card-head .ms{width:20px;height:20px;}
.cetak-card-title{font-size:.875rem;font-weight:600;color:var(--text);}
.cetak-card-row{display:flex;gap:8px;align-items:center;}
.cetak-card-grid2{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.cetak-field{display:flex;flex-direction:column;gap:4px;}
.cetak-field-lbl{font-size:.72rem;font-weight:500;color:var(--text-3);}
.cetak-quick-links{display:flex;flex-direction:column;gap:6px;}
.cetak-quick-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;font-size:.85rem;color:var(--text-2);text-decoration:none;background:var(--surface);border:1px solid var(--border);transition:background .12s;}
.cetak-quick-item:hover{background:var(--bg);color:var(--text);text-decoration:none;}

/* ── Foto ── */
.foto-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;}
.foto-thumb{width:88px;height:88px;border-radius:10px;overflow:hidden;border:2px solid var(--border);cursor:pointer;transition:transform .15s,border-color .15s;}
.foto-thumb:hover{transform:scale(1.04);border-color:var(--primary);}
.foto-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.foto-thumb-grid{display:flex;flex-wrap:wrap;gap:10px;}

/* ── Calc Preview ── */
.calc-preview{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:9px;background:var(--primary-lt);color:var(--primary-text);font-size:.875rem;margin-bottom:14px;border:1px solid #BFDBFE;}
.calc-preview.err{background:var(--error-lt);color:var(--error-text);border-color:#FECACA;}
.calc-preview .ms{width:18px;height:18px;flex-shrink:0;}

/* ── Animations ── */
.anim-up{animation:animUp .3s ease both;}
@keyframes animUp{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}

/* ── Empty State ── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;color:var(--text-4);gap:10px;text-align:center;}
.empty-state .ms{width:44px;height:44px;opacity:.4;}
.empty-state p{font-size:.9rem;}

/* ── Utilities ── */
.flex-c{display:flex;align-items:center;}
.gap-1{gap:4px;} .gap-2{gap:8px;}
.flex-wrap{flex-wrap:wrap;}
.text-sm{font-size:.875rem;} .text-xs{font-size:.75rem;}
.text-muted{color:var(--text-3);}
.mono{font-family:var(--font-mono);}
.mb-2{margin-bottom:8px;} .mb-3{margin-bottom:14px;}
.mt-1{margin-top:4px;} .mt-2{margin-top:8px;} .mt-3{margin-top:14px;}
@media(max-width:600px){.hide-sm{display:none;}}
.ripple{cursor:pointer;}

/* ── Log Timeline ── */
.log-timeline{display:flex;flex-direction:column;}
.log-item{display:flex;gap:14px;padding:14px 0;}
.log-item+.log-item{border-top:1px solid var(--border);}
.log-dot{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.log-dot .ms{width:18px;height:18px;}
.log-dot.approved{background:var(--success-lt);color:var(--success);}
.log-dot.rejected{background:var(--error-lt);color:var(--error);}
.log-dot.cair{background:var(--primary-lt);color:var(--primary);}
.log-content{flex:1;}
.log-label{font-size:.9rem;font-weight:600;color:var(--text);}
.log-meta{font-size:.75rem;color:var(--text-3);margin-top:4px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;}

/* ── Cut-off Banner ── */
.cutoff-banner{display:flex;align-items:center;justify-content:space-between;background:var(--primary-lt);border:1px solid #BFDBFE;border-radius:12px;padding:13px 16px;margin-bottom:18px;cursor:pointer;gap:12px;transition:box-shadow .15s;}
.cutoff-banner:hover{box-shadow:var(--shadow-sm);}
.cutoff-banner-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0;}
.cutoff-banner-title{font-weight:600;font-size:.875rem;color:var(--primary-text);}
.cutoff-banner-sub{font-size:.73rem;color:var(--text-3);margin-top:2px;}
.cutoff-banner-action{display:flex;align-items:center;gap:4px;font-size:.78rem;font-weight:600;color:var(--primary);white-space:nowrap;flex-shrink:0;}
.cutoff-sim{background:var(--surface-2);border-radius:10px;padding:14px 16px;margin-bottom:16px;border:1px solid var(--border);}
.cutoff-sim-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-4);margin-bottom:10px;}
.cutoff-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;font-size:.75rem;}
.cutoff-day-head{text-align:center;font-weight:600;color:var(--text-4);padding:4px 0;font-size:.64rem;}
.cutoff-day{text-align:center;padding:6px 3px;border-radius:7px;font-size:.78rem;line-height:1;}
.cutoff-day.today{font-weight:700;outline:2px solid var(--primary);outline-offset:1px;}
.cutoff-day.in-cur{background:var(--primary-lt);color:var(--primary-text);}
.cutoff-day.in-next{background:var(--purple-lt);color:var(--purple);}
.cutoff-day.empty{opacity:0;}
.cutoff-legend{display:flex;gap:12px;margin-top:10px;flex-wrap:wrap;}
.cutoff-legend-item{display:flex;align-items:center;gap:6px;font-size:.72rem;color:var(--text-3);}
.cutoff-legend-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0;}
.cutoff-month-preview{background:var(--surface-2);border-radius:10px;padding:12px 14px;margin-bottom:12px;border:1px solid var(--border);}
.cmp-row{display:flex;gap:8px;align-items:center;margin-bottom:6px;font-size:.8rem;}
.cmp-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.cmp-label{color:var(--text-3);}
.cmp-value{font-weight:600;}

/* ── Responsive ── */
@media(max-width:600px){
  .page-content{padding:14px 12px;}
  .page-headline{font-size:1.15rem;}
  .stat-value{font-size:1.25rem;}
  .stat-row{grid-template-columns:repeat(2,1fr);}
  .md-card-p{padding:14px;}
  .login-body{padding:20px;}
}
@media(min-width:701px){
  .m-list{display:none!important;}
  .md-table-wrap{display:block!important;}
}

/* ── Password Toggle Button ── */
.pw-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);
  background:none;border:none;cursor:pointer;color:var(--text-3);
  padding:5px;border-radius:6px;display:flex;align-items:center;justify-content:center;
  transition:color .15s,background .15s;z-index:2;line-height:1;}
.pw-toggle:hover{color:var(--text);background:var(--bg);}
.pw-toggle .ms{width:18px;height:18px;pointer-events:none;}
