:root{
  --adra:#00795D; --adra-d:#005C47; --adra-l:#E8F2EE;
  --bg:#F6F7F5; --surface:#fff; --line:#E6E8E4; --line-2:#d7dbd5;
  --text:#000; --muted:#000; --hint:#000;
  --danger:#A32D2D; --danger-bg:#FCEBEB;
  --warn:#854F0B; --warn-bg:#FAEEDA;
  --info:#185FA5; --info-bg:#E6F1FB;
  --ok:#0F6E56; --ok-bg:#E1F5EE;
  --radius:10px; --radius-sm:8px;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Plus Jakarta Sans',system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.55}
a{color:var(--adra);text-decoration:none}

/* top bar + nav */
.topbar{background:var(--adra);color:#fff;padding:11px 20px;display:flex;align-items:center;gap:12px}
.brand{display:flex;align-items:center;gap:10px}
.brand .logo{display:flex;align-items:center}
.brand .logo img{height:30px;width:auto;display:block}
.brand .t1{font-weight:600;font-size:15px;line-height:1.1}
.brand .t2{font-size:11px;opacity:.8}
.topbar .sp{flex:1}
.userchip{display:flex;align-items:center;gap:9px}
.avatar{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}
.userchip .nm{font-size:12px;line-height:1.15}
.userchip .nm small{opacity:.8}
.logout{color:#fff;opacity:.85;font-size:12px;border:0.5px solid rgba(255,255,255,.35);padding:6px 11px;border-radius:8px}
.logout:hover{opacity:1;background:rgba(255,255,255,.12)}
.nav{background:var(--surface);border-bottom:1px solid var(--line);padding:0 16px;display:flex;gap:2px}
.nav a{padding:12px 14px;color:var(--muted);font-size:13px;border-bottom:2px solid transparent}
.nav a.on{color:var(--adra);border-bottom-color:var(--adra);font-weight:600}

/* layout */
.wrap{max-width:1080px;margin:0 auto;padding:22px 16px 60px}
.page-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.page-head h1{font-size:19px;font-weight:600;margin:0}
.page-head .desc{font-size:12px;color:var(--muted)}
.page-head .sp{flex:1}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:7px;border-radius:var(--radius-sm);font-size:13px;padding:9px 14px;cursor:pointer;border:0.5px solid var(--line-2);background:var(--surface);color:var(--text);font-family:inherit}
.btn:hover{background:#f0f1ee}
.btn-primary{background:var(--adra);border-color:var(--adra);color:#fff}
.btn-primary:hover{background:var(--adra-d)}
.btn svg,.btn i{font-size:16px}

/* stat cards */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px}
.stat .l{font-size:12px;color:var(--muted)}
.stat .v{font-size:24px;font-weight:700;margin-top:2px}
.stat.ok .v{color:var(--ok)} .stat.info .v{color:var(--info)} .stat.danger .v{color:var(--danger)}

/* table card */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.table-scroll{overflow-x:auto}
table.data{width:100%;border-collapse:collapse;min-width:680px}
table.data th{text-align:left;font-size:11px;font-weight:600;color:var(--muted);padding:11px 14px;border-bottom:1px solid var(--line-2);white-space:nowrap}
table.data td{font-size:13px;padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
table.data tr:last-child td{border-bottom:none}
table.data .name{font-weight:600}
.muted{color:var(--muted)}

/* badges */
.badge{display:inline-block;font-size:11px;font-weight:500;padding:4px 10px;border-radius:8px;white-space:nowrap}
.b-success{background:var(--ok-bg);color:var(--ok)}
.b-info{background:var(--info-bg);color:var(--info)}
.b-warning{background:var(--warn-bg);color:var(--warn)}
.b-danger{background:var(--danger-bg);color:var(--danger)}
.b-secondary{background:#eceee9;color:var(--muted)}
.overdue{color:var(--danger);font-weight:500}

/* icon buttons */
.iconbtn{border:none;background:transparent;cursor:pointer;color:var(--muted);padding:6px;border-radius:7px;font-size:16px;line-height:1}
.iconbtn:hover{background:#f0f1ee;color:var(--text)}

/* forms */
.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;max-width:760px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:5px;margin-bottom:2px}
.field.full{grid-column:1/3}
.field label{font-size:12px;color:var(--muted);font-weight:500}
.field input,.field select,.field textarea{font-family:inherit;font-size:13px;padding:9px 11px;border:1px solid var(--line-2);border-radius:8px;background:#fff;color:var(--text);width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--adra);box-shadow:0 0 0 3px var(--adra-l)}
.field textarea{resize:vertical;min-height:64px}
.form-section{font-size:12px;color:var(--hint);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin:18px 0 10px;grid-column:1/3;border-top:1px solid var(--line);padding-top:16px}
.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}

/* auth */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.auth-card{width:370px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:34px 30px;text-align:center}
.auth-card .big{margin:0 auto 16px}
.auth-card .big img{height:54px;width:auto;display:inline-block}
.auth-card h2{font-size:19px;margin:0 0 6px}
.auth-card p{font-size:13px;color:var(--muted);margin:0 0 24px}
.gbtn{width:100%;height:46px;border:1px solid var(--line-2);background:#fff;border-radius:9px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;color:var(--text);font-family:inherit}
.gbtn:hover{background:#f7f8f6}
.lock{font-size:11px;color:var(--hint);margin-top:15px}
.empty{padding:50px 20px;text-align:center;color:var(--muted);font-size:13px}

@media(max-width:640px){.stats{grid-template-columns:repeat(2,1fr)}.grid2{grid-template-columns:1fr}.field.full,.form-section{grid-column:1}}

/* === Dashboard: animasi masuk halaman (kartu muncul, bar tumbuh, angka berhitung). Scoped .dpage. === */
@keyframes dashCardIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.dpage .stats .statx,.dpage .newstrip,.dpage .dgrid .dcard{animation:dashCardIn .55s cubic-bezier(.22,.61,.36,1) both}
.dpage .newstrip{animation-delay:.02s}
.dpage .stats .statx:nth-child(1){animation-delay:.05s}
.dpage .stats .statx:nth-child(2){animation-delay:.11s}
.dpage .stats .statx:nth-child(3){animation-delay:.17s}
.dpage .stats .statx:nth-child(4){animation-delay:.23s}
.dpage .dgrid .dcard:nth-child(1){animation-delay:.16s}
.dpage .dgrid .dcard:nth-child(2){animation-delay:.22s}
.dpage .dgrid .dcard:nth-child(3){animation-delay:.28s}
.dpage .dgrid .dcard:nth-child(4){animation-delay:.34s}
.dpage .dgrid .dcard:nth-child(5){animation-delay:.40s}
.dpage .dgrid .dcard:nth-child(6){animation-delay:.46s}
.dpage .dgrid .dcard:nth-child(7){animation-delay:.52s}
.dpage .dgrid .dcard:nth-child(8){animation-delay:.58s}
.dpage .dgrid .dcard:nth-child(9){animation-delay:.64s}
.dpage .bfill,.dpage .monbar{transition:width .9s cubic-bezier(.22,.61,.36,1),height .9s cubic-bezier(.22,.61,.36,1)}
.dpage .stack{transition:width .9s cubic-bezier(.22,.61,.36,1)}
/* Catatan: guard prefers-reduced-motion sengaja dihilangkan -> animasi selalu jalan (alat internal). */

/* === Jadwal Saya: sort per kolom (klik header) === */
.grid th.sortable{cursor:pointer;user-select:none}
.grid th.sortable:hover{background:#e3efe9;color:var(--adra)}
.grid th .sarr{font-size:9px;opacity:.4;margin-left:2px}
.grid th .sarr::after{content:'\2195'}
.grid th.sort-asc .sarr,.grid th.sort-desc .sarr{opacity:1;color:var(--adra)}
.grid th.sort-asc .sarr::after{content:'\25B2'}
.grid th.sort-desc .sarr::after{content:'\25BC'}

/* === Jadwal Saya: funnel filter per kolom + popup ala Excel === */
.grid th .filt{display:inline-block;margin-left:4px;cursor:pointer;opacity:.4;font-size:11px;vertical-align:middle}
.grid th .filt:hover{opacity:1;color:var(--adra)}
.grid th.filtered{background:#dff0e8}
.grid th.filtered .filt{opacity:1;color:var(--adra)}
.cfpop{position:absolute;z-index:60;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.16);padding:8px;min-width:180px;max-width:270px;font-size:13px;color:#000}
.cfpop-s{margin-bottom:6px}
.cfpop-s input{width:100%;box-sizing:border-box;border:1px solid var(--line);border-radius:6px;padding:4px 7px;font:inherit;font-size:12px;color:#000}
.cfpop-all{display:flex;align-items:center;gap:6px;font-weight:600;padding:3px 2px 6px;border-bottom:1px solid var(--line);margin-bottom:4px;cursor:pointer}
.cfpop-list{max-height:240px;overflow:auto}
.cfpop-i{display:flex;align-items:center;gap:6px;padding:3px 2px;cursor:pointer}
.cfpop-i:hover{background:#f3f7f5}
.cfpop-i span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cfpop-act{display:flex;justify-content:space-between;gap:8px;margin-top:8px}
.cfpop-act button{font:inherit;font-size:12px;border:1px solid var(--line);background:#fff;border-radius:6px;padding:5px 11px;cursor:pointer}
.cfpop-act .cf-apply{background:var(--adra);color:#fff;border-color:var(--adra)}
.cfpop-act .cf-apply:hover{filter:brightness(1.08)}
#orderToggle.on{border-color:var(--adra);color:var(--adra)}
