@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Sora:wght@600;700&display=swap');

:root{
  --bg:#f5f6f9; --surface:#ffffff; --ink:#161a23; --muted:#697086;
  --border:#e7e9ef; --border-2:#eef0f4;
  --primary:#0ea672; --primary-d:#0b8a5e; --primary-soft:#e6f7f0;
  --danger:#e23b53; --warn:#f59e0b;
  --sidebar:#141824; --sidebar-2:#1d2231; --sidebar-ink:#aeb4c4;
  --radius:14px; --radius-sm:10px;
  --shadow:0 1px 2px rgba(16,24,40,.05),0 4px 16px rgba(16,24,40,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--ink);font-size:14.5px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:Sora,Inter,sans-serif;margin:0}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9em}
.muted{color:var(--muted)}
.nowrap{white-space:nowrap}

/* ---------- AUTH ---------- */
.auth-bg{min-height:100vh;display:grid;place-items:center;background:radial-gradient(120% 120% at 0% 0%,#13351f 0%,#141824 45%,#0c0f17 100%);padding:20px}
.auth-card{background:var(--surface);width:100%;max-width:380px;padding:34px 30px;border-radius:18px;box-shadow:0 20px 60px rgba(0,0,0,.35)}
.auth-card h1{font-size:21px;margin:14px 0 4px}
.auth-card .muted{margin:0 0 18px}
.auth-card label{display:block;font-weight:600;font-size:13px;margin:14px 0 6px}
.auth-card input{width:100%}
.brand-mark{display:inline-grid;place-items:center;width:46px;height:46px;border-radius:13px;background:linear-gradient(135deg,var(--primary),#13b981);color:#fff;font-family:Sora;font-weight:700;font-size:18px}
.brand-mark.sm{width:30px;height:30px;border-radius:9px;font-size:13px}
.ok{color:var(--primary-d);font-weight:600}
.alert{background:#fdeaed;color:#a11833;padding:10px 12px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:6px}
.alert-ok{background:var(--primary-soft);color:var(--primary-d)}

/* ---------- INPUTS ---------- */
input,select,textarea{font:inherit;color:var(--ink);background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;width:100%;outline:none;transition:border .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}
textarea{resize:vertical}
label{font-weight:600;font-size:13px}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:6px;justify-content:center;background:#fff;color:var(--ink);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 15px;font-weight:600;font-size:13.5px;cursor:pointer;transition:.15s;white-space:nowrap}
.btn:hover{background:#f7f8fa;border-color:#d8dbe3}
.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-d);border-color:var(--primary-d)}
.btn-danger{background:#fff;border-color:#f3c6ce;color:var(--danger)}
.btn-danger:hover{background:#fdeaed}
.btn-sm{padding:6px 11px;font-size:12.5px}
.btn-block{width:100%;margin-top:18px}

/* ---------- APP SHELL ---------- */
.app{display:flex;min-height:100vh}
.sidebar{width:248px;background:var(--sidebar);color:var(--sidebar-ink);display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;z-index:40}
.side-brand{display:flex;align-items:center;gap:10px;padding:20px 18px;color:#fff;font-family:Sora;font-weight:700;font-size:15px;border-bottom:1px solid var(--sidebar-2)}
.sidebar nav{flex:1;padding:14px 12px;overflow:auto}
.sidebar nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:var(--sidebar-ink);font-weight:500;margin-bottom:3px;transition:.15s}
.sidebar nav a:hover{background:var(--sidebar-2);color:#fff}
.sidebar nav a.on{background:var(--primary);color:#fff}
.nav-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#5b6175;margin:16px 12px 6px}
.side-foot{border-top:1px solid var(--sidebar-2);padding:14px}
.who{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.who-name{color:#fff;font-weight:600;font-size:13px;margin-bottom:3px}
.avatar{width:34px;height:34px;border-radius:9px;background:var(--sidebar-2);color:#fff;display:grid;place-items:center;font-weight:700;flex:none}
.logout{display:block;text-align:center;padding:8px;border-radius:9px;font-size:13px;font-weight:600;color:var(--sidebar-ink);border:1px solid var(--sidebar-2)}
.logout:hover{background:var(--sidebar-2);color:#fff}

.content{flex:1;margin-left:248px;min-width:0}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:16px 28px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}
.topbar h1{font-size:18px}
.topbar-right{display:flex;align-items:center;gap:12px}
.hello{font-size:13px;color:var(--muted)}
.page{padding:24px 28px;max-width:1180px}

.menu-toggle{display:none}
.scrim{display:none}

/* ---------- BADGES / CHIPS ---------- */
.badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;letter-spacing:.02em}
.badge-admin{background:#fff4e0;color:#b46b00}
.badge-user{background:#e8f0ff;color:#2557c7}
.chip{display:inline-flex;align-items:center;font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;color:var(--c);background:color-mix(in srgb,var(--c) 13%,#fff);border:1px solid color-mix(in srgb,var(--c) 28%,#fff)}
.tag{display:inline-flex;font-size:12px;font-weight:600;background:#f1f2f6;color:#525a6e;padding:4px 10px;border-radius:8px}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:7px}

/* ---------- CARDS / KPI ---------- */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);margin-bottom:20px}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.card-head h2,.card h2{font-size:16px}
.card h3{font-size:14px;margin-bottom:12px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.kpi-label{font-size:12.5px;color:var(--muted);font-weight:600}
.kpi-num{font-family:Sora;font-size:30px;font-weight:700;margin-top:6px}
.kpi-warn .kpi-num{color:var(--warn)}

/* ---------- PERIOD CARDS ---------- */
.pcards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}
.pcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.pcard-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.pcard-title{font-family:Sora;font-weight:600;font-size:15px}
.pcard-sub{font-size:12px;color:var(--muted);margin-top:2px}
.pcard-num{font-family:Sora;font-size:30px;font-weight:700;line-height:1}
.pcard-num span{font-size:12px;font-weight:600;color:var(--muted);margin-left:4px}
.pbar{height:8px;background:#eef0f4;border-radius:999px;overflow:hidden;margin-bottom:10px}
.pbar span{display:block;height:100%;background:linear-gradient(90deg,#13b981,var(--primary));border-radius:999px;transition:width .5s}
.pcard-foot{display:flex;align-items:center;gap:14px;font-size:12.5px;font-weight:600}
.pdot{display:inline-flex;align-items:center;gap:6px;color:var(--muted)}
.pdot::before{content:"";width:8px;height:8px;border-radius:50%}
.pdot.done::before{background:var(--primary)}
.pdot.active::before{background:#cbd0db}
.ppct{margin-left:auto;color:var(--primary-d);font-weight:700}

/* period toggle */
.seg-toggle{display:inline-flex;background:#eef0f4;border-radius:10px;padding:3px;gap:2px}
.seg-toggle a{padding:6px 14px;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted)}
.seg-toggle a.on{background:#fff;color:var(--ink);box-shadow:0 1px 2px rgba(16,24,40,.08)}
.period-summary{display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.ps-num{display:flex;flex-direction:column;min-width:130px}
.ps-big{font-family:Sora;font-size:42px;font-weight:700;line-height:1}
.ps-unit{font-size:13px;font-weight:600;color:var(--ink);margin-top:4px}
.ps-sub{font-size:12px;color:var(--muted)}
.ps-bars{flex:1;min-width:220px}
.ps-legend{display:flex;align-items:center;gap:16px;margin-top:10px;font-size:13px;font-weight:600;flex-wrap:wrap}
.pdot{display:inline-flex;align-items:center;gap:6px;color:var(--muted)}
.pdot::before{content:"";width:9px;height:9px;border-radius:50%}
.pdot.done::before{background:var(--primary)}
.pdot.active::before{background:#cbd0db}
.pdot.cancel::before{background:#94a3b8}
.pbar{height:9px;background:#eef0f4;border-radius:999px;overflow:hidden}
.pbar span{display:block;height:100%;background:linear-gradient(90deg,#13b981,var(--primary));border-radius:999px;transition:width .5s}

/* URGENT */
.kpi-urgent{border-color:#f6c6cd;background:linear-gradient(180deg,#fff,#fff6f7)}
.kpi-urgent .kpi-num{color:var(--danger)}
.badge-urgent{display:inline-block;background:var(--danger);color:#fff;font-size:10px;font-weight:800;letter-spacing:.04em;padding:2px 7px;border-radius:6px;vertical-align:middle}
.row-urgent{background:#fff6f7 !important;box-shadow:inset 3px 0 0 var(--danger)}
.row-urgent:hover{background:#fdeef0 !important}
.urgent-banner{background:#fdecee;color:#a11833;border:1px solid #f6c6cd;border-left:4px solid var(--danger);padding:11px 14px;border-radius:10px;margin-bottom:16px;font-size:13.5px}
.detail-head.is-urgent{border-left:4px solid var(--danger)}
.urgent-toggle{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:#fafbfc;border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:16px;cursor:pointer}
.urgent-toggle input{width:auto;margin:0}
.urgent-toggle.on{background:#fff6f7;border-color:#f6c6cd}
.urgent-flag{font-weight:700;color:var(--danger);font-size:13px}
.urgent-desc{font-size:12.5px;color:var(--muted)}

/* CANCELLED / Tidak Dilanjutkan */
.cancel-banner{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;border-left:4px solid #94a3b8;padding:11px 14px;border-radius:10px;margin-bottom:16px;font-size:13.5px}
.detail-head.is-cancel{border-left:4px solid #94a3b8}
.detail-head.is-cancel .item-title{color:#64748b}
.cancel-state{background:#f8fafc;border:1px dashed #cbd5e1;color:#64748b;border-radius:10px;padding:16px;text-align:center;margin-bottom:16px;font-weight:600}
.row-cancel{opacity:.66}
.row-cancel .mono{text-decoration:line-through;text-decoration-color:#cbd5e1}
.btn-ghost-danger{background:#fff;border-color:var(--border);color:#94a3b8;margin-left:auto}
.btn-ghost-danger:hover{border-color:#cbd5e1;color:#64748b;background:#f8fafc}

/* ---------- TREND CHART ---------- */
.chart-wrap{width:100%;overflow:hidden}
.trend-chart{width:100%;height:auto;display:block}

/* ---------- HORIZONTAL BAR RANKING ---------- */
.grid-cards-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid-cards-2 .card{margin-bottom:0}
.hbars{display:flex;flex-direction:column;gap:11px}
.hbar{display:grid;grid-template-columns:130px 1fr auto;align-items:center;gap:12px}
.hbar-label{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hbar-track{height:10px;background:#eef0f4;border-radius:999px;overflow:hidden}
.hbar-fill{display:block;height:100%;background:linear-gradient(90deg,#13b981,var(--primary));border-radius:999px;min-width:4px;transition:width .4s}
.hbar-val{font-weight:700;font-size:14px;text-align:right;white-space:nowrap}
.hbar-done{display:block;font-weight:500;font-size:11px;color:var(--muted)}
@media(max-width:760px){.grid-cards-2{grid-template-columns:1fr}.hbar{grid-template-columns:96px 1fr auto}}

/* ---------- FUNNEL ---------- */
.funnel{display:flex;flex-direction:column;gap:9px}
.funnel-row{display:grid;grid-template-columns:170px 1fr 40px;align-items:center;gap:12px}
.funnel-row:hover .funnel-name{color:var(--ink)}
.funnel-name{font-size:13px;font-weight:500;color:var(--muted);display:flex;align-items:center}
.funnel-bar{height:9px;background:#f0f1f5;border-radius:999px;overflow:hidden}
.funnel-bar span{display:block;height:100%;border-radius:999px;min-width:3px;transition:width .4s}
.funnel-count{text-align:right;font-weight:700;font-size:13px}

/* ---------- TABLE ---------- */
.table-wrap{overflow-x:auto;margin:-4px}
table{width:100%;border-collapse:collapse;font-size:13.5px}
thead th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700;padding:10px 12px;border-bottom:1px solid var(--border)}
tbody td{padding:12px;border-bottom:1px solid var(--border-2);vertical-align:middle}
tbody tr{cursor:pointer;transition:background .12s}
tbody tr:hover{background:#fafbfc}
tbody tr:last-child td{border-bottom:0}
.row-go{color:#c3c8d4;font-size:18px;text-align:right}
.overdue{color:var(--danger);font-weight:600}
.empty{text-align:center;color:var(--muted);padding:34px}

/* mini flow segments in list */
.mini-flow{display:flex;gap:2px;margin-bottom:6px}
.seg{height:5px;width:13px;border-radius:2px;background:#e7e9ef}
.seg.fill{background:var(--c)}

/* ---------- TOOLBAR / FILTERS ---------- */
.toolbar{display:flex;justify-content:space-between;gap:12px;margin-bottom:16px;align-items:center;flex-wrap:wrap}
.search{display:flex;gap:8px;flex:1;max-width:480px}
.search input{flex:1}
.filters{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:18px}
.pill{font-size:12.5px;font-weight:600;padding:6px 13px;border-radius:999px;background:#fff;border:1px solid var(--border);color:var(--muted)}
.pill:hover{border-color:#d2d6df}
.pill.on{background:var(--c,var(--ink));border-color:var(--c,var(--ink));color:#fff}

/* list bar + per-page + pagination */
.list-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.list-count{font-size:13px;color:var(--muted)}
.per-page{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:6px}
.per-opt{display:inline-flex;min-width:30px;justify-content:center;padding:4px 9px;border:1px solid var(--border);border-radius:8px;font-weight:600;color:var(--muted)}
.per-opt:hover{border-color:#d2d6df}
.per-opt.on{background:var(--ink);border-color:var(--ink);color:#fff}
.pagination{display:flex;align-items:center;gap:6px;justify-content:center;flex-wrap:wrap;margin-top:4px}
.pg{display:inline-flex;min-width:38px;height:38px;align-items:center;justify-content:center;padding:0 12px;border:1px solid var(--border);border-radius:9px;font-weight:600;font-size:13.5px;background:#fff;color:var(--ink)}
.pg:hover{background:#f7f8fa;border-color:#d2d6df}
.pg.on{background:var(--primary);border-color:var(--primary);color:#fff}
.pg.disabled{opacity:.45;pointer-events:none}
.pg-gap{padding:0 4px;color:var(--muted)}
@media(max-width:600px){.pg{min-width:34px;height:34px;padding:0 9px}}

/* bulk select + recycle bin */
.chk-cell{width:34px;text-align:center}
.chk-cell input{width:auto;cursor:pointer;width:17px;height:17px}
.bulk-bar{display:none;position:sticky;bottom:14px;z-index:25;align-items:center;gap:14px;background:var(--ink);color:#fff;border-radius:12px;padding:10px 16px;box-shadow:0 8px 30px rgba(0,0,0,.25);margin:0 auto 14px;width:fit-content}
.bulk-bar.show{display:flex}
.bulk-count{font-weight:600;font-size:13.5px}
.bulk-clear{color:#cbd0db;font-size:13px;font-weight:600}
.bulk-clear:hover{color:#fff}
.bin-note{background:#fff8e6;border:1px solid #f3e3b3;border-left:4px solid var(--warn);color:#7a5b00;padding:12px 14px;border-radius:10px;margin-bottom:16px;font-size:13.5px}

/* Butuh Tindakan (worklist) */
.todo-card{border-top:3px solid var(--warn)}
.todo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.todo-h{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding-bottom:8px;margin-bottom:6px;border-bottom:1px solid var(--border)}
.todo-h-red{color:#dc2626}.todo-h-orange{color:#d97706}.todo-h-grey{color:#64748b}
.todo-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;margin-bottom:4px;transition:background .15s}
.todo-item:hover{background:#f5f7fa}
.todo-item-t{font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.todo-item-m{font-size:11.5px;color:var(--muted);white-space:nowrap}
.todo-item-m.todo-late{color:#dc2626;font-weight:600}
.todo-empty{font-size:12.5px;color:var(--muted);padding:8px 10px}
@media(max-width:760px){.todo-grid{grid-template-columns:1fr;gap:12px}}

/* ---------- LACAK PAKET ---------- */
.track-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}
.track-controls label{margin:0;font-size:13px;color:var(--muted)}
.track-controls select{width:auto;min-width:150px}
.trk-loading,.trk-error,.trk-advanced,.trk-cached{padding:12px 14px;border-radius:10px;font-size:13.5px;margin-top:14px}
.trk-loading{background:#f4f6f9;color:var(--muted)}
.trk-error{background:#fdecee;color:#a11833;border:1px solid #f6c6cd}
.trk-advanced{background:#e9f9f1;color:#0a7d50;border:1px solid #b8ead0}
.trk-cached{background:transparent;color:var(--muted);font-size:12px;padding:8px 0 0}
.trk-status{font-weight:700;font-size:15px;margin:18px 0 4px}
.trk-status.ok{color:var(--primary-d)}

/* progress line pengiriman (4 fase) */
.ship-track{position:relative;display:flex;justify-content:space-between;margin:22px 0 6px;padding:0 4px}
.ship-line{position:absolute;top:11px;left:24px;right:24px;height:4px;background:#e6e9ef;border-radius:999px;overflow:hidden}
.ship-line>span{display:block;height:100%;background:linear-gradient(90deg,#13b981,var(--primary));border-radius:999px;transition:width .7s ease}
.ship-node{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:7px;flex:1}
.ship-dot{width:24px;height:24px;border-radius:50%;background:#fff;border:3px solid #d3d8e0;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;font-weight:800}
.ship-node.done .ship-dot{background:var(--primary);border-color:var(--primary)}
.ship-node.now .ship-dot{border-color:var(--primary);background:var(--primary);box-shadow:0 0 0 5px rgba(14,166,114,.18)}
.ship-lbl{font-size:11.5px;font-weight:600;color:var(--muted)}
.ship-node.done .ship-lbl,.ship-node.now .ship-lbl{color:var(--ink)}
/* animasi "sedang dikirim" — denyut di node aktif kalau belum delivered */
.ship-track:not(.done) .ship-node.now .ship-dot{animation:shipPulse 1.3s infinite}
@keyframes shipPulse{0%{box-shadow:0 0 0 0 rgba(14,166,114,.35)}70%{box-shadow:0 0 0 9px rgba(14,166,114,0)}100%{box-shadow:0 0 0 0 rgba(14,166,114,0)}}
.ship-track.done .ship-line>span{background:var(--primary)}

/* timeline riwayat */
.trk-timeline{margin-top:14px;border-left:2px solid var(--border);padding-left:0}
.trk-item{position:relative;padding:0 0 16px 22px}
.trk-item:last-child{padding-bottom:0}
.trk-dot{position:absolute;left:-7px;top:3px;width:12px;height:12px;border-radius:50%;background:#cbd2dc;border:2px solid #fff}
.trk-item.first .trk-dot{background:var(--primary);box-shadow:0 0 0 3px rgba(14,166,114,.15)}
.trk-desc{font-size:13.5px;color:var(--ink);line-height:1.45}
.trk-item.first .trk-desc{font-weight:600}
.trk-meta{font-size:12px;color:var(--muted);margin-top:2px}

/* ---------- FORM ---------- */
.form-section{font-family:Sora;font-weight:600;font-size:13px;color:var(--primary-d);text-transform:uppercase;letter-spacing:.04em;margin:22px 0 12px;padding-bottom:7px;border-bottom:1px solid var(--border-2)}
.form-section:first-child{margin-top:0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid-2 label{display:block;margin-bottom:6px}
.col-span{grid-column:1/-1}
.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px}
#newUser{display:none}
#newUser.show{display:block}

/* ---------- DETAIL + STEPPER ---------- */
.back{display:inline-block;color:var(--muted);font-weight:600;font-size:13px;margin-bottom:14px}
.back:hover{color:var(--ink)}
.detail-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}
.item-title{font-size:20px;margin:6px 0 12px;line-height:1.3}
.meta-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.detail-actions{display:flex;gap:8px;flex:none}

.stepper{position:relative;display:flex;justify-content:space-between;margin:30px 4px 8px}
.stepper-line{position:absolute;top:15px;left:5%;right:5%;height:3px;background:#e7e9ef;border-radius:2px}
.stepper-line span{display:block;height:100%;background:var(--primary);border-radius:2px;transition:width .5s;position:relative}
.step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;text-align:center}
.step-dot{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:13px;background:#fff;border:3px solid #e7e9ef;color:#aeb4c4}
.step-label{font-size:11.5px;font-weight:600;color:var(--muted);max-width:78px}
.step-done .step-dot{background:var(--c);border-color:var(--c);color:#fff}
.step-done .step-label{color:var(--ink)}
.step-current .step-dot{border-color:var(--c);color:var(--c);box-shadow:0 0 0 4px color-mix(in srgb,var(--c) 18%,#fff)}
.step-current .step-label{color:var(--ink)}
.stage-quick{display:flex;justify-content:space-between;gap:10px;margin-top:26px;flex-wrap:wrap}
.done-tag{margin-left:auto;color:var(--primary-d);font-weight:700;align-self:center}

.grid-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-cards .card{margin-bottom:0}
.kv{display:grid;grid-template-columns:auto 1fr;gap:8px 14px;margin:0;font-size:13.5px}
.kv dt{color:var(--muted);font-weight:600}
.kv dd{margin:0;text-align:right;word-break:break-word}
.pre{white-space:pre-wrap;color:#3a4150;font-size:13.5px}
.audit{font-size:12.5px;color:var(--muted);padding:4px 2px}
.flow-legend{display:flex;flex-wrap:wrap;gap:8px}

/* ---------- IMAGES ---------- */
.export-row{display:flex;gap:8px;margin:-6px 0 16px;flex-wrap:wrap}
.thumb-cell{width:52px}
.thumb-wrap{position:relative;display:inline-block}
.img-thumb{width:42px;height:42px;object-fit:cover;border-radius:8px;border:1px solid var(--border);display:block}
.thumb-count{position:absolute;right:-6px;bottom:-6px;background:var(--ink);color:#fff;font-size:10px;font-weight:700;min-width:17px;height:17px;border-radius:9px;display:grid;place-items:center;padding:0 4px;border:2px solid #fff}
.no-thumb{color:#cfd3dc}

/* detail gallery */
.detail-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}
.gphoto{display:block;border-radius:10px;overflow:hidden;border:1px solid var(--border);aspect-ratio:1/1}
.gphoto img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}
.gphoto:hover img{transform:scale(1.06)}

/* edit form image grid */
.img-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px;margin-bottom:12px}
.img-cell{position:relative;display:block;cursor:pointer}
.img-cell img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:10px;border:1px solid var(--border);display:block}
.img-cell:has(input:checked) img{outline:2px solid var(--danger);opacity:.5}
.img-del{position:absolute;left:6px;bottom:6px;display:flex;align-items:center;gap:4px;background:rgba(255,255,255,.92);border-radius:7px;padding:2px 7px;font-size:11px;font-weight:600;color:var(--danger)}
.img-del input{width:auto;margin:0}
.hint{display:block;font-size:12px;color:var(--muted);margin-top:6px}
.mig-list{margin:0 0 14px;padding-left:18px;font-size:13.5px;color:#3a4150}
.mig-list li{margin-bottom:4px}

/* storage stats */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:6px 0 14px}
.stat{background:#f7f8fa;border:1px solid var(--border-2);border-radius:12px;padding:14px}
.stat-n{display:block;font-family:Sora;font-size:22px;font-weight:700}
.stat-l{display:block;font-size:12px;color:var(--muted);margin-top:3px}
@media(max-width:760px){.stat-row{grid-template-columns:1fr 1fr}}

/* ---------- ICONS (CSS, no deps) ---------- */
i[data-i]{width:17px;height:17px;display:inline-block;flex:none;background:currentColor;-webkit-mask:center/contain no-repeat;mask:center/contain no-repeat;opacity:.9}
i[data-i=grid]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2'%3E%3Crect x='3' y='3' width='7' height='7' rx='1'/%3E%3Crect x='14' y='3' width='7' height='7' rx='1'/%3E%3Crect x='3' y='14' width='7' height='7' rx='1'/%3E%3Crect x='14' y='14' width='7' height='7' rx='1'/%3E%3C/svg%3E")}
i[data-i=list]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2'%3E%3Cline x1='8' y1='6' x2='21' y2='6'/%3E%3Cline x1='8' y1='12' x2='21' y2='12'/%3E%3Cline x1='8' y1='18' x2='21' y2='18'/%3E%3Cline x1='3' y1='6' x2='3.01' y2='6'/%3E%3Cline x1='3' y1='12' x2='3.01' y2='12'/%3E%3Cline x1='3' y1='18' x2='3.01' y2='18'/%3E%3C/svg%3E")}
i[data-i=clock]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpolyline points='12 7 12 12 15 14'/%3E%3C/svg%3E")}
i[data-i=users]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2'%3E%3Cpath d='M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M23 21v-2a4 4 0 0 0-3-3.87'/%3E%3C/svg%3E")}
i[data-i=cog]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2'%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3Cpath d='M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 1 1-2.83 2.83l-.06-.06a1.65 1.65 0 0 0-2.82 1.17V21a2 2 0 0 1-4 0v-.09A1.65 1.65 0 0 0 8 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 1 1-2.83-2.83l.06-.06A1.65 1.65 0 0 0 4.6 15a1.65 1.65 0 0 0-1.51-1H3a2 2 0 0 1 0-4h.09A1.65 1.65 0 0 0 4.6 8.6L4.27 8.5a2 2 0 1 1 2.83-2.83l.06.06A1.65 1.65 0 0 0 9 6.6 1.65 1.65 0 0 0 10 5.09V5a2 2 0 0 1 4 0v.09a1.65 1.65 0 0 0 2.82 1.17l.06-.06a2 2 0 1 1 2.83 2.83l-.06.06A1.65 1.65 0 0 0 19.4 9c.36.14.62.46.6.85V10a2 2 0 0 1 0 4h-.09c-.39 0-.71.26-.85.6z'/%3E%3C/svg%3E")}
i[data-i=chart]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2'%3E%3Cline x1='18' y1='20' x2='18' y2='10'/%3E%3Cline x1='12' y1='20' x2='12' y2='4'/%3E%3Cline x1='6' y1='20' x2='6' y2='14'/%3E%3C/svg%3E")}
i[data-i=trash]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2'%3E%3Cpolyline points='3 6 5 6 21 6'/%3E%3Cpath d='M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6m3 0V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2'/%3E%3C/svg%3E")}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .kpis{grid-template-columns:1fr 1fr}
  .grid-cards{grid-template-columns:1fr}
}
@media(max-width:760px){
  .sidebar{transform:translateX(-100%);transition:transform .25s;box-shadow:0 0 40px rgba(0,0,0,.3)}
  body.nav-open .sidebar{transform:none}
  body.nav-open .scrim{display:block;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:35}
  .content{margin-left:0}
  .menu-toggle{display:grid;place-items:center;position:fixed;top:11px;left:12px;z-index:45;width:40px;height:40px;border:1px solid var(--border);background:#fff;border-radius:10px;font-size:18px;cursor:pointer}
  .topbar{padding-left:62px}
  .topbar h1{font-size:16px}
  .hello{display:none}
  .page{padding:16px}
  .grid-2{grid-template-columns:1fr}
  .kpis{grid-template-columns:1fr 1fr;gap:12px}
  .kpi-num{font-size:24px}
  .pcards{grid-template-columns:1fr}
  .funnel-row{grid-template-columns:120px 1fr 32px}
  .stepper{overflow-x:auto;gap:4px;padding-bottom:14px}
  .step{min-width:64px}
  .detail-head{flex-direction:column}
  .step-label{font-size:10px}

  /* ringkasan order + toggle periode */
  .card-head{flex-wrap:wrap;gap:10px}
  .seg-toggle{width:100%;display:flex}
  .seg-toggle a{flex:1;text-align:center;padding:8px 6px;font-size:12.5px}
  .period-summary{gap:16px}
  .ps-num{min-width:0;width:100%;flex-direction:row;align-items:baseline;gap:8px;flex-wrap:wrap}
  .ps-big{font-size:34px}
  .ps-bars{min-width:0;width:100%}
  .ps-legend{gap:12px}

  /* list bar + per-page + pagination */
  .list-bar{flex-direction:column;align-items:flex-start;gap:8px}
  .per-page{flex-wrap:wrap}
  .pagination{gap:5px}
  .pg{min-width:40px;height:40px;font-size:14px}
}

/* ============ ANIMASI & MICRO-INTERAKSI ============ */
@media (prefers-reduced-motion: no-preference){
  @keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
  @keyframes popIn{0%{opacity:0;transform:scale(.95)}100%{opacity:1;transform:none}}
  @keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
  @keyframes slideInLeft{from{opacity:0;transform:translateX(-14px)}to{opacity:1;transform:none}}
  @keyframes barGrow{from{transform:scaleX(0)}to{transform:scaleX(1)}}

  /* entrance konten halaman (staggered) */
  .page > *{animation:fadeUp .45s cubic-bezier(.22,.61,.36,1) both}
  .page > *:nth-child(1){animation-delay:.03s}
  .page > *:nth-child(2){animation-delay:.08s}
  .page > *:nth-child(3){animation-delay:.13s}
  .page > *:nth-child(4){animation-delay:.18s}
  .page > *:nth-child(5){animation-delay:.23s}
  .page > *:nth-child(6){animation-delay:.28s}
  .page > *:nth-child(7){animation-delay:.33s}
  .page > *:nth-child(n+8){animation-delay:.36s}

  /* topbar + sidebar */
  .topbar{animation:slideDown .5s ease both}
  .nav a{animation:slideInLeft .4s ease both}
  .nav a:nth-child(1){animation-delay:.04s}.nav a:nth-child(2){animation-delay:.08s}
  .nav a:nth-child(3){animation-delay:.12s}.nav a:nth-child(4){animation-delay:.16s}
  .nav a:nth-child(5){animation-delay:.2s}.nav a:nth-child(6){animation-delay:.24s}
  .nav a:nth-child(7){animation-delay:.28s}.nav a:nth-child(n+8){animation-delay:.3s}

  /* KPI pop-in */
  .kpi{animation:popIn .5s cubic-bezier(.34,1.3,.64,1) both}
  .kpi:nth-child(1){animation-delay:.06s}.kpi:nth-child(2){animation-delay:.13s}
  .kpi:nth-child(3){animation-delay:.2s}.kpi:nth-child(4){animation-delay:.27s}

  /* alert & bulk bar */
  .alert{animation:slideDown .4s ease both}
  .bulk-bar.show{animation:slideDown .35s cubic-bezier(.34,1.3,.64,1) both}

  /* bar yang "tumbuh" */
  .funnel-bar>span,.hbar-fill>span,.hbar-fill{transform-origin:left;animation:barGrow .8s cubic-bezier(.22,.61,.36,1) both}

  /* hover lift kartu interaktif */
  .kpi,.funnel-row{transition:transform .18s ease, box-shadow .18s ease}
  .kpi:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(16,24,40,.08)}

  /* tombol & elemen klik */
  .btn{transition:transform .09s ease, box-shadow .18s ease, background .15s, border-color .15s, color .15s}
  .btn:hover{transform:translateY(-1px)}
  .btn:active{transform:translateY(0) scale(.97)}
  .pill,.chip,.per-opt,.pg,.seg-toggle a{transition:all .16s ease}
  .per-opt:hover,.pg:hover{transform:translateY(-1px)}

  /* baris tabel & progress */
  tbody tr{transition:background .16s ease, box-shadow .16s ease}
  .thumb-wrap img{transition:transform .25s ease}
  tbody tr:hover .thumb-wrap img{transform:scale(1.08)}
  .stepper-line>span,.pbar span,.ship-line>span{transition:width .8s cubic-bezier(.22,.61,.36,1)}
  .step-dot,.ship-dot{transition:background .3s ease, border-color .3s ease, box-shadow .3s ease}

  /* spinner loading lacak */
  .trk-loading{position:relative;padding-left:38px}
  .trk-loading::before{content:"";position:absolute;left:14px;top:50%;width:14px;height:14px;margin-top:-7px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}
  @keyframes spin{to{transform:rotate(360deg)}}

  /* timeline item muncul berurutan */
  .trk-item{animation:fadeUp .4s ease both}
  .trk-item:nth-child(1){animation-delay:.02s}.trk-item:nth-child(2){animation-delay:.07s}
  .trk-item:nth-child(3){animation-delay:.12s}.trk-item:nth-child(4){animation-delay:.17s}
  .trk-item:nth-child(n+5){animation-delay:.2s}

  /* chart tren: bar tumbuh dari bawah (sweep kiri→kanan) */
  .trend-chart rect.bar{transform-box:fill-box;transform-origin:center bottom;animation:barRise .6s cubic-bezier(.22,.61,.36,1) both}
  @keyframes barRise{from{transform:scaleY(0)}to{transform:scaleY(1)}}
  .trend-chart text{animation:fadeIn .5s ease both;animation-delay:.45s}
  @keyframes fadeIn{from{opacity:0}to{opacity:1}}

  /* garis flow Status PR — cahaya berjalan sepanjang garis saat PR berjalan */
  .stepper-line.active>span{
    background:linear-gradient(90deg,#0c9568 0%,#0ea672 38%,#7bedb4 50%,#0ea672 62%,#0c9568 100%);
    background-size:200% 100%;
    animation:lineFlow 1.4s linear infinite;
  }
  @keyframes lineFlow{0%{background-position:100% 0}100%{background-position:-100% 0}}
  .stepper-line.active>span::after{content:"";position:absolute;right:-4px;top:50%;width:11px;height:11px;margin-top:-5.5px;border-radius:50%;background:var(--primary);animation:dotPulse 1.5s ease-in-out infinite}
  @keyframes dotPulse{0%{box-shadow:0 0 0 0 rgba(14,166,114,.55)}70%{box-shadow:0 0 0 9px rgba(14,166,114,0)}100%{box-shadow:0 0 0 0 rgba(14,166,114,0)}}

  /* garis pengiriman juga mengalir saat paket masih jalan */
  .ship-track:not(.done) .ship-line>span{
    background:linear-gradient(90deg,#0c9568 0%,#0ea672 38%,#7bedb4 50%,#0ea672 62%,#0c9568 100%);
    background-size:200% 100%;
    animation:lineFlow 1.4s linear infinite;
  }
}

/* hormati pengguna yang matikan animasi (aksesibilitas + hemat baterai) */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
}
