*{box-sizing:border-box;margin:0;padding:0}
/* Hilangkan spinner panah pada input angka (uang) */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
input[type="number"]{-moz-appearance:textfield}
:root{--blue:#1a56a0;--bll:#e8f0fb;--bdk:#0d3d7a;--gr:#2d6a0a;--grb:#e8f4de;--am:#7d4800;--amb:#fef3e2;--rd:#9b2121;--rdb:#fdeaea;--bd:#dde1e9;--tx:#1e2330;--bg:#f4f5f8;--wh:#fff;--muted:#6b7280;--sidebar:#1e2330}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--tx);font-size:13px;line-height:1.5;min-height:100vh}
#login{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0d3d7a,#1a56a0 60%,#2e7fc1)}
.lbox{background:#fff;border-radius:16px;padding:2.5rem;width:380px;max-width:95vw;box-shadow:0 24px 64px rgba(0,0,0,.3)}
.llogo{text-align:center;margin-bottom:1.75rem}
.llogo-img{max-height:72px;max-width:200px;object-fit:contain;margin:0 auto .75rem;display:none}
.llogo h1{font-size:28px;font-weight:800;color:#1a56a0;letter-spacing:-.5px;margin:0}
.login-pt-nama{font-size:14px;font-weight:600;color:#374151;margin:.45rem 0 0;line-height:1.4;text-transform:none;letter-spacing:0}
.login-tagline{font-size:11px;color:#9ca3af;margin-top:6px;text-transform:uppercase;letter-spacing:.5px}
.fg{margin-bottom:.85rem}
.fg label{display:block;font-size:10px;font-weight:700;color:#6b7280;margin-bottom:4px;text-transform:uppercase;letter-spacing:.6px}
.fg input,.fg select,.fg textarea{width:100%;padding:9px 12px;border:1.5px solid #dde1e9;border-radius:8px;font-size:13px;font-family:inherit;outline:none;background:#fff;transition:border .15s}
.fg input:focus,.fg select:focus{border-color:#1a56a0;box-shadow:0 0 0 3px rgba(26,86,160,.12)}
.btn{padding:8px 16px;border:none;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s}
.btn-p{background:#1a56a0;color:#fff}.btn-p:hover{background:#0d3d7a}
.btn-g{background:#2d6a0a;color:#fff}.btn-g:hover{background:#1e4a07}
.btn-r{background:#9b2121;color:#fff}.btn-r:hover{background:#7a1a1a}
.btn-a{background:#7d4800;color:#fff}.btn-a:hover{background:#5a3400}
.btn-pu{background:#5b21b6;color:#fff}.btn-pu:hover{background:#4c1d95}
.btn-out{background:transparent;border:1.5px solid #dde1e9;color:#4b5563}.btn-out:hover{border-color:#9ca3af;background:#f9fafb}
.btn-sm{padding:5px 11px;font-size:11px}.btn-xs{padding:3px 8px;font-size:10px;font-weight:700}
.btn-full{width:100%}
.chip-login{display:inline-block;padding:3px 10px;background:#e8f0fb;color:#1a56a0;border-radius:20px;font-size:11px;font-weight:700;cursor:pointer;margin:2px;border:none;font-family:inherit}
#app{display:none;min-height:100vh;flex-direction:column}
.topbar{background:#fff;border-bottom:1px solid var(--bd);padding:0 1.25rem;height:52px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.tl{display:flex;align-items:center;gap:.65rem}
.topbar-logo-img{max-height:34px;max-width:90px;object-fit:contain;display:none;border-radius:4px}
.alogo{font-size:17px;font-weight:800;color:#1a56a0;letter-spacing:-.5px}
.periode-pill{padding:4px 12px;background:#e8f0fb;color:#1a56a0;border-radius:20px;font-size:11px;font-weight:700;cursor:pointer;border:1px solid #c5d9f5}
.save-ind{font-size:10px;color:#2d6a0a;font-weight:700}
.notif-btn{position:relative;background:none;border:none;cursor:pointer;font-size:17px;padding:5px;border-radius:8px}.notif-btn:hover{background:#f3f4f6}
.ndot{position:absolute;top:3px;right:3px;width:7px;height:7px;background:#e24b4a;border-radius:50%;display:none}.ndot.on{display:block}
.av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;background:#1a56a0;flex-shrink:0}
.uname{font-size:12px;font-weight:700}
.rbadge{font-size:10px;padding:2px 7px;border-radius:20px;font-weight:700;background:#e8f0fb;color:#1a56a0}
.layout{display:flex;flex:1}
.sidebar{width:200px;background:var(--sidebar);padding:.6rem 0;flex-shrink:0;min-height:calc(100vh - 52px);display:flex;flex-direction:column;justify-content:space-between;overflow-y:auto}
.nsec{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:#6b7280;padding:.7rem 1rem .3rem}
.ni{display:flex;align-items:center;gap:7px;padding:8px 1rem;cursor:pointer;color:#9ca3af;font-size:12px;font-weight:500;border-left:3px solid transparent;transition:all .15s;user-select:none}
.ni:hover{background:rgba(255,255,255,.06);color:#e5e7eb}
.ni.active{background:rgba(26,86,160,.25);color:#60a5fa;border-left-color:#3b82f6;font-weight:700}
.ni.danger{color:#f87171}.ni.danger:hover{background:rgba(155,33,33,.2);border-left-color:#ef4444}
.nic{width:15px;text-align:center;font-size:13px;flex-shrink:0}
.nbadge{background:#e24b4a;color:#fff;border-radius:20px;font-size:9px;padding:1px 5px;margin-left:auto}
.content{flex:1;padding:1.1rem;overflow:auto}
.pg{display:none}.pg.active{display:block}
.card{background:#fff;border-radius:10px;border:1px solid var(--bd);padding:1rem;margin-bottom:.75rem;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.ct{font-size:13px;font-weight:700;margin-bottom:.75rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.4rem}
.sg4{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:.75rem}
.sc{background:#fff;border-radius:8px;border:1px solid var(--bd);padding:.85rem}
.sl{font-size:9px;color:#9ca3af;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.sv{font-size:20px;font-weight:800;color:#1a56a0}
table{width:100%;border-collapse:collapse;font-size:12px}
th{text-align:left;padding:7px 10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:#6b7280;border-bottom:2px solid var(--bd);white-space:nowrap}
td{padding:8px 10px;border-bottom:1px solid #f3f4f6;vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:#f8f9fc}
.ka{width:28px;height:28px;border-radius:50%;background:#e8f0fb;color:#1a56a0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;flex-shrink:0}
.knl{color:#1a56a0;font-weight:700;cursor:pointer}.knl:hover{text-decoration:underline}
.bdg{display:inline-block;padding:2px 7px;border-radius:20px;font-size:10px;font-weight:700}
.b-ok{background:#e8f4de;color:#2d6a0a}.b-warn{background:#fef3e2;color:#7d4800}
.b-err{background:#fdeaea;color:#9b2121}.b-info{background:#e8f0fb;color:#1a56a0}
.b-gray{background:#f3f4f6;color:#6b7280}.b-pu{background:#ede9fe;color:#5b21b6}.b-teal{background:#d1fae5;color:#065f46}
.ph{display:flex;justify-content:space-between;align-items:center;margin-bottom:.9rem;flex-wrap:wrap;gap:.5rem}
.pt{font-size:17px;font-weight:800}.pst{font-size:11px;color:#6b7280;margin-top:1px}
.stit{font-size:10px;font-weight:700;color:#1a56a0;text-transform:uppercase;letter-spacing:.6px;margin:.9rem 0 .5rem;padding-bottom:4px;border-bottom:2px solid #e8f0fb}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:.65rem}
.fg3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.65rem}
.ff{grid-column:1/-1}
.fl{display:flex}.flb{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.gap1{gap:.4rem}.gap2{gap:.65rem}
.mb1{margin-bottom:.4rem}.mb2{margin-bottom:.75rem}.mt1{margin-top:.4rem}.mt2{margin-top:.75rem}
.tabs{display:flex;border-bottom:2px solid var(--bd);margin-bottom:.9rem;flex-wrap:wrap}
.tab{padding:7px 14px;cursor:pointer;font-size:12px;font-weight:600;color:#6b7280;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;user-select:none;-webkit-tap-highlight-color:transparent}
.tab.active{color:#1a56a0;border-bottom-color:#1a56a0}
#pg-backup .backup-tabs-bar{position:relative;z-index:5;background:#fff;margin-bottom:.75rem}
#pg-backup .backup-tab-panels{position:relative;z-index:1}
.pr-row-info{display:flex;justify-content:space-between;font-size:12px;padding:3px 0}
.pph-box{background:#e8f0fb;border-radius:8px;padding:.85rem;margin-top:.6rem}
.pph-box-tit{font-weight:700;font-size:12px;color:#1a56a0;border-top:1.5px solid #b8d0f0;margin-top:5px;padding-top:5px;display:flex;justify-content:space-between}
.info-box{border-radius:8px;padding:.65rem .9rem;font-size:11px;margin-bottom:.65rem}
.info-blue{background:#e8f0fb;color:#0d3d7a;border-left:3px solid #1a56a0}
.info-green{background:#e8f4de;color:#1e4a07;border-left:3px solid #2d6a0a}
.info-amber{background:#fef3e2;color:#5a3400;border-left:3px solid #7d4800}
.info-red{background:#fdeaea;color:#7a1a1a;border-left:3px solid #9b2121}
.info-pu{background:#ede9fe;color:#4c1d95;border-left:3px solid #5b21b6}
.pb{background:linear-gradient(135deg,#0d3d7a,#2e7fc1);color:#fff;border-radius:10px;padding:1rem 1.25rem;margin-bottom:.75rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.po{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.45);z-index:300;display:none;opacity:0;transition:opacity .25s}
.po.show{display:block;opacity:1}
.sp{position:fixed;top:0;right:0;width:min(820px,100vw);height:100vh;background:#fff;z-index:301;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;display:flex;flex-direction:column;box-shadow:-4px 0 32px rgba(0,0,0,.18)}
.sp.show{transform:translateX(0)}
.sph{background:linear-gradient(135deg,#0d3d7a,#1a56a0);color:#fff;padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:flex-start;flex-shrink:0}
.spc{background:rgba(255,255,255,.2);border:none;color:#fff;width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center}
.spc:hover{background:rgba(255,255,255,.35)}
.spt-wrap{display:flex;padding:0 1.5rem;background:#f8f9fc;border-bottom:2px solid var(--bd);overflow-x:auto;flex-shrink:0}
.spt{padding:8px 14px;cursor:pointer;font-size:12px;font-weight:600;color:#6b7280;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;white-space:nowrap}
.spt.active{color:#1a56a0;border-bottom-color:#1a56a0}
.spb{flex:1;overflow-y:auto;padding:1.25rem 1.5rem}
.spf{padding:1rem 1.5rem;border-top:1px solid var(--bd);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background:#f8f9fc}
.tr-row{display:grid;grid-template-columns:1.4fr 1fr 1.2fr auto;gap:.4rem;align-items:start;padding:.5rem .6rem;background:#f8f9fc;border-radius:7px;border:1px solid var(--bd);margin-bottom:.4rem}
.tr-row.harian{border-color:#f5a623;background:#fffbf5}
.tr-harian-note{grid-column:1/-1;font-size:10px;color:#7d4800;padding:4px 8px;background:#fff3e0;border-radius:5px;border:1px solid #f5a623;margin-top:2px}
.bpjs-aktif-bar{display:flex;gap:1.5rem;padding:.75rem 1rem;background:#f8f9fc;border-radius:8px;border:1px solid var(--bd);margin-bottom:.75rem;flex-wrap:wrap}
.bpjs-chk{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:12px;font-weight:600}
.bpjs-chk input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#1a56a0}
.bpjs-row{display:grid;grid-template-columns:auto 2fr 1fr 1fr auto;gap:.5rem;align-items:center;padding:.5rem .6rem;background:#f8f9fc;border-radius:7px;border:1px solid var(--bd);margin-bottom:.4rem}
.bpjs-row.off{opacity:.4}
.bi{padding:5px 8px;border:1.5px solid #dde1e9;border-radius:6px;font-size:12px;width:100%;font-family:inherit;outline:none}
.bi.manual{border-color:#7d4800;background:#fffbf5}
.tm{font-size:10px;padding:3px 7px;border-radius:5px;cursor:pointer;font-weight:700;white-space:nowrap;border:none;font-family:inherit}
.tm.auto{background:#e8f4de;color:#2d6a0a}.tm.manual{background:#fef3e2;color:#7d4800}
.nat-row{display:grid;grid-template-columns:1.5fr 1fr 1fr auto;gap:.4rem;align-items:center;padding:.5rem .6rem;border-radius:7px;border:1px solid var(--bd);margin-bottom:.4rem;background:#f8f9fc}
.nat-row.kp{border-color:#f5a3a3;background:#fdeaea}
.slip{background:#fff;border:1px solid #c5d9f5;border-radius:10px;padding:1.5rem;max-width:680px;margin:0 auto;font-size:11px}
.slip-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #1a56a0}
.slip-logo{max-height:44px;max-width:130px;object-fit:contain;margin-bottom:4px}
.sr{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px solid #f3f4f6}
.sr:last-child{border-bottom:none}
.sr.bold{font-weight:700}
.sr.pph-return{color:#2d6a0a;font-weight:700}
.sr.indent{padding-left:14px;color:#6b7280}
.stotal{background:#1a56a0;color:#fff;border-radius:7px;padding:10px 14px;display:flex;justify-content:space-between;font-weight:800;font-size:13px;margin-top:8px}
.stotal-thr{background:linear-gradient(90deg,#5b21b6,#7c3aed);color:#fff;border-radius:7px;padding:10px 14px;display:flex;justify-content:space-between;font-weight:800;font-size:13px;margin-top:8px}
.ssec{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#6b7280;margin:10px 0 4px}
.semp{background:#f8f9fc;border-radius:7px;padding:8px;margin-bottom:.75rem;display:grid;grid-template-columns:1fr 1fr;gap:4px}
.gross-sec{background:#e8f0fb;border-radius:8px;padding:.85rem 1rem;margin:.6rem 0;border:1px solid #c5d9f5;font-size:11px}
.gross-tit{font-size:10px;font-weight:800;color:#0d3d7a;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}
.pph-calc-sec{background:#fffbf5;border-radius:8px;padding:.85rem 1rem;margin:.6rem 0;border:1px solid #f5a623;font-size:11px}
.pph-calc-tit{font-size:10px;font-weight:800;color:#5a3400;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}
.thr-sec{background:#f5f0ff;border-radius:8px;padding:.85rem 1rem;margin:.6rem 0;border:1px solid #c4b5fd;font-size:11px}
.thr-sec-tit{font-size:10px;font-weight:800;color:#4c1d95;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}
.cr{display:flex;justify-content:space-between;padding:2px 0;font-size:11px}
.cr.bold{font-weight:700;color:#0d3d7a;border-top:1px solid #c5d9f5;margin-top:4px;padding-top:4px}
.cr.result{font-weight:800;color:#2d6a0a;font-size:12px}
.pr-toggle{background:none;border:none;cursor:pointer;font-size:10px;font-weight:700;font-family:inherit;padding:2px 7px;border-radius:5px}
.pr-toggle.off{background:#e8f0fb;color:#1a56a0}.pr-toggle.on{background:#fef3e2;color:#7d4800}
.pr-row-tbl{background:#fffbf5;border-left:3px solid #f5a623}
.pr-input{width:65px;padding:4px 7px;border:1.5px solid #f5a623;border-radius:6px;font-size:11px;font-family:inherit;outline:none;text-align:center}
.gs{background:linear-gradient(135deg,#e8f0fb,#f0f6ff);border-radius:10px;padding:1rem;border:1px solid #c5d9f5}
.gs-row{display:flex;justify-content:space-between;font-size:12px;padding:3px 0;border-bottom:1px solid rgba(0,0,0,.06)}
.gs-row:last-child{border-bottom:none}
.gs-total{font-weight:800;font-size:14px;color:#1a56a0;border-top:2px solid #1a56a0;margin-top:6px;padding-top:6px;display:flex;justify-content:space-between}
.logo-drop{border:2px dashed var(--bd);border-radius:10px;padding:1.25rem;text-align:center;cursor:pointer;transition:border .15s;background:#fafafa}
.logo-drop:hover{border-color:#1a56a0;background:#f0f6ff}
.logo-drop input{display:none}
.logo-prev{max-height:60px;max-width:160px;object-fit:contain;border-radius:7px;border:1px solid var(--bd);background:#f8f9fc;display:none;margin-bottom:.5rem}
.cuti-bar{background:#e5e7eb;border-radius:20px;height:8px;overflow:hidden;margin-top:4px}
.cuti-fill{height:100%;background:#5b21b6;border-radius:20px;transition:width .3s}
.mbd{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);align-items:flex-start;justify-content:center;padding-top:40px;z-index:400;overflow-y:auto}
.mbd.show{display:flex}
.modal{background:#fff;border-radius:12px;padding:1.4rem;width:540px;max-width:96vw;position:relative;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.modal-sm{width:400px}
.mtit{font-size:14px;font-weight:800;margin-bottom:.9rem}
.mclose{position:absolute;top:.8rem;right:.8rem;background:none;border:none;font-size:18px;cursor:pointer;color:#9ca3af}
.mfoot{display:flex;gap:6px;justify-content:flex-end;margin-top:.9rem;padding-top:.8rem;border-top:1px solid #f3f4f6}
.libur-item{display:flex;justify-content:space-between;align-items:center;padding:7px 10px;border-radius:7px;border:1px solid var(--bd);margin-bottom:.4rem;font-size:12px}
.libur-item:hover{background:#f8f9fc}
.nat-tmpl{padding:7px 10px;border:1px solid var(--bd);border-radius:7px;cursor:pointer;margin-bottom:.35rem;font-size:12px;transition:background .1s}
.nat-tmpl:hover{background:#f0f6ff;border-color:#1a56a0}
.toast9{background:#1e2330;color:#fff;padding:10px 18px;border-radius:8px;font-size:12px;font-weight:600;position:fixed;bottom:20px;right:20px;z-index:9999;opacity:0;transition:opacity .3s;pointer-events:none}
.toast9.show{opacity:1}
/* USER MANAGEMENT */
.perm-grid{display:grid;gap:3px;overflow-x:auto}
.perm-hdr{display:flex;background:#1e2330;color:#9ca3af;font-size:10px;font-weight:700;border-radius:6px;overflow:hidden}
.perm-hdr-cell{padding:7px 10px;flex:1;text-align:center;border-right:1px solid #374151;min-width:80px}
.perm-hdr-cell:first-child{min-width:180px;text-align:left;flex:2}
.perm-row{display:flex;font-size:12px;border-radius:6px;border:1px solid var(--bd);margin-top:3px;overflow:hidden}
.perm-row:hover{background:#f8f9fc}
.perm-row.per-mod-head{background:#f8f9fc;border-color:#dbeafe}
.perm-row.per-sub{background:#fafbfc;margin-left:2px}
.perm-row.per-sub:hover{background:#f1f5f9}
.tunjvar-inp{width:100%;max-width:120px;padding:6px 8px;border:1.5px solid #dde1e9;border-radius:6px;font-size:13px;font-family:inherit;outline:none}
.perm-cell{padding:6px 10px;flex:1;text-align:center;border-right:1px solid #f3f4f6;min-width:80px;display:flex;align-items:center;justify-content:center}
.perm-cell:first-child{min-width:180px;text-align:left;justify-content:flex-start;flex:2;font-weight:600}
.perm-cell input[type=checkbox]{width:15px;height:15px;cursor:pointer;accent-color:#1a56a0}
.thr-badge{display:inline-block;padding:2px 8px;background:#ede9fe;color:#5b21b6;border-radius:20px;font-size:10px;font-weight:700;border:1px solid #c4b5fd}

/* ── Ponsel / tablet (drawer — class .sigaji-mobile-nav dari JS) ── */
:root{--topbar-h:52px}
.nav-drawer-btn{display:none}
.nav-backdrop{display:none}
html.sigaji-nav-open,html.sigaji-nav-open body{overflow:hidden;touch-action:none}
#app{min-height:100vh;min-height:100dvh}
.btn,.ni,.notif-btn,.periode-pill,.nav-drawer-btn{-webkit-tap-highlight-color:rgba(26,86,160,.15)}
html.sigaji-mobile-nav .nav-drawer-btn{
  display:flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;min-height:44px;
  margin-right:2px;border:none;background:#e8f0fb;color:#1a56a0;border-radius:10px;font-size:22px;line-height:1;
  cursor:pointer;flex-shrink:0;font-family:inherit;position:relative;z-index:2;touch-action:manipulation;
  -webkit-user-select:none;user-select:none;-webkit-appearance:none;appearance:none
}
html.sigaji-mobile-nav .topbar{
  position:sticky;top:0;z-index:800;
  padding:.45rem max(.65rem,env(safe-area-inset-left)) .45rem max(.65rem,env(safe-area-inset-right));
  flex-wrap:wrap;row-gap:6px;height:auto;min-height:48px;
  padding-top:max(.45rem,env(safe-area-inset-top));
}
html.sigaji-mobile-nav .layout{position:relative;min-height:0;flex:1}
/* Slot kosong di layout; sidebar asli dipindah ke body lewat JS saat HP */
html.sigaji-mobile-nav .layout>.sidebar-slot{display:none}
html.sigaji-mobile-nav #sidebar-wrap{
  display:none;position:fixed;top:0;left:0;bottom:0;width:min(300px,88vw);
  min-height:unset;max-height:none;height:100%;height:100dvh;
  z-index:1200;padding-top:calc(var(--topbar-h) + env(safe-area-inset-top,0px));
  padding-bottom:calc(.75rem + env(safe-area-inset-bottom,0px));
  box-shadow:none;-webkit-overflow-scrolling:touch;overflow-y:auto;
  -webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);
  flex-direction:column;justify-content:space-between
}
html.sigaji-mobile-nav #sidebar-wrap.sigaji-nav-drawer-open{
  display:flex;box-shadow:8px 0 32px rgba(0,0,0,.28)
}
body:not(.sigaji-app-active) #sidebar-wrap,
body:not(.sigaji-app-active) .nav-backdrop{display:none!important}
html.sigaji-mobile-nav .nav-backdrop{
  display:none;position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:1100;
  -webkit-tap-highlight-color:transparent;touch-action:manipulation
}
html.sigaji-mobile-nav .nav-backdrop.sigaji-nav-drawer-open{display:block}
html.sigaji-mobile-nav .content{
  width:100%;min-width:0;padding:.65rem max(.65rem,env(safe-area-inset-left)) calc(.85rem + env(safe-area-inset-bottom,0px)) max(.65rem,env(safe-area-inset-right))
}
html.sigaji-mobile-nav .topbar .tl{flex-wrap:wrap;gap:.45rem;max-width:100%}
html.sigaji-mobile-nav .alogo{font-size:15px;max-width:min(160px,34vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
html.sigaji-mobile-nav .periode-pill{max-width:min(200px,42vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:6px 10px;font-size:10px}
html.sigaji-mobile-nav .uname{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media (max-width:900px){
  .btn-sm{padding:7px 12px;font-size:11px;min-height:36px}
  .sg4{grid-template-columns:repeat(2,1fr);gap:6px}
  .sv{font-size:16px}
  .pt{font-size:15px}
  .ni{padding:11px 1rem;font-size:13px}
  .tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:0;scrollbar-width:thin}
  .tabs .tab{flex:0 0 auto}
  .spt-wrap{scroll-padding-inline:8px}
  .toast9{
    left:max(12px,env(safe-area-inset-left));
    right:max(12px,env(safe-area-inset-right));
    bottom:max(16px,env(safe-area-inset-bottom));
    width:auto;max-width:none;text-align:center;
  }
}
@media (max-width:380px){
  .save-ind{display:none}
  .rbadge{display:none}
}
