/* Dara Hitam — SPA styles. Token & komponen mengikuti docs/mockup-dara-hitam-v4.html */
:root{
  --bg:#eef1f4; --surface:#fff; --ink:#13202c; --ink-soft:#5d6b79; --line:#e6ebf0;
  --brand:#00b9a3; --brand-dark:#00917f; --brand-soft:#e2f7f3;
  --green:#16a34a; --green-soft:#e7f6ec; --red:#e0524b; --red-soft:#fcebe9;
  --amber:#e6a012; --amber-soft:#fcf3df; --blue:#2f6fed; --blue-soft:#e8f0fe;
  --purple:#7c4ddb; --purple-soft:#f0e9fb;
  --radius:14px; --shadow:0 1px 2px rgba(16,40,60,.04),0 8px 22px rgba(16,40,60,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Plus Jakarta Sans',system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.4}
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}

/* SIDEBAR */
.side{background:var(--surface);border-right:1px solid var(--line);position:sticky;top:0;height:100vh;display:flex;flex-direction:column;overflow:auto}
.side-head{display:flex;align-items:center;gap:11px;padding:18px 16px 12px}
.logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,#15202c,#3a3a3a);display:grid;place-items:center;color:#00b9a3;font-weight:800;font-size:19px;font-family:'Sora',sans-serif;box-shadow:0 6px 16px rgba(0,0,0,.25);flex:none}
.brand b{font-family:'Sora',sans-serif;font-size:15.5px;letter-spacing:-.3px;display:block;white-space:nowrap}
.brand span{font-size:10px;color:var(--ink-soft);font-weight:600;white-space:nowrap}
.nav-body{flex:1;padding:8px 13px 10px}
.nav-ghead{padding:12px 10px 5px;color:var(--ink-soft);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.07em}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;color:var(--ink-soft);font-weight:600;font-size:12.5px;cursor:pointer;transition:.12s;margin-bottom:1px;position:relative;white-space:nowrap}
.nav-item:hover{background:var(--bg);color:var(--ink)}
.nav-item.active{background:var(--brand-soft);color:var(--brand-dark);font-weight:700}
.nav-item.active::before{content:"";position:absolute;left:-13px;top:50%;transform:translateY(-50%);width:3px;height:17px;background:var(--brand);border-radius:0 3px 3px 0}
.nav-item .ic{width:16px;height:16px;flex:none;stroke:currentColor;fill:none;stroke-width:2}
.nav-item.soon{opacity:.5;cursor:not-allowed}
.nav-item .pill{margin-left:auto;font-size:9px;font-weight:800;color:var(--ink-soft);background:var(--bg);padding:1px 6px;border-radius:20px}
.nav-foot{border-top:1px solid var(--line);padding:11px 14px;display:flex;align-items:center;gap:10px}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--brand-soft);color:var(--brand-dark);display:grid;place-items:center;font-weight:800;font-size:13px;font-family:'Sora',sans-serif;flex:none}
.nav-foot .who b{font-size:12.5px;display:block}.nav-foot .who span{font-size:10.5px;color:var(--ink-soft)}

/* MAIN */
.main{padding:22px 30px;overflow:auto}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:12px}
.topbar h1{font-family:'Sora',sans-serif;font-size:23px;letter-spacing:-.5px}
.topbar p{color:var(--ink-soft);font-size:12.5px;margin-top:2px}
.tb-actions{display:flex;gap:9px;flex-wrap:wrap}

.btn{border:none;border-radius:10px;padding:9px 15px;font-weight:700;font-size:12.5px;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:7px;transition:.15s}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 6px 14px rgba(0,185,163,.3)}
.btn-primary:hover{background:var(--brand-dark)}
.btn-amber{background:var(--amber);color:#fff}
.btn-ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line)}
.btn-danger{background:var(--red-soft);color:var(--red)}
.btn-sm{padding:6px 11px;font-size:11.5px;border-radius:8px}
.ic-sm{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}

.note{background:#fff;border:1px solid var(--line);border-left:4px solid var(--brand);border-radius:10px;padding:11px 15px;font-size:12px;color:var(--ink-soft);margin-bottom:16px;line-height:1.55}
.note b{color:var(--ink)} .note.amber{border-left-color:var(--amber)}

.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-bottom:16px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:15px 16px;box-shadow:var(--shadow)}
.kpi .lbl{font-size:11.5px;color:var(--ink-soft);font-weight:600;display:flex;align-items:center;gap:7px}
.kpi .dot{width:8px;height:8px;border-radius:50%}
.kpi .val{font-family:'Sora',sans-serif;font-size:21px;letter-spacing:-.5px;font-weight:700;margin:8px 0 3px}
.kpi .cmp{font-size:11px;font-weight:600;color:var(--ink-soft)}

.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;margin-bottom:14px}
.ph{display:flex;align-items:center;justify-content:space-between;padding:14px 17px;border-bottom:1px solid var(--line);gap:10px;flex-wrap:wrap}
.ph h3{font-family:'Sora',sans-serif;font-size:14px}
.ph .tag{font-size:11px;font-weight:700;color:var(--ink-soft)}

table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft);font-weight:700;padding:10px 17px;background:#fafbfc}
td{padding:10px 17px;font-size:12.5px;border-top:1px solid var(--line);font-weight:500;vertical-align:middle}
tr:hover td{background:#fafdfc}
.right{text-align:right}
.code{font-weight:700;font-family:'Sora',sans-serif;font-size:12px}
.sub{color:var(--ink-soft);font-size:11px}
.money{font-variant-numeric:tabular-nums;font-weight:700}
.row-actions{display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap}
.linkbtn{font-size:11px;color:var(--brand-dark);font-weight:700;cursor:pointer;border:1px solid var(--line);padding:5px 9px;border-radius:7px;background:#fff;display:inline-flex;align-items:center;gap:5px}
.linkbtn:hover{background:var(--bg)}
.linkbtn.warn{color:#a9750a;border-color:var(--amber-soft);background:var(--amber-soft)}
.linkbtn.danger{color:var(--red)}

.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:10.5px;font-weight:700}
.c-jahit{background:var(--blue-soft);color:var(--blue)} .c-brand{background:var(--brand-soft);color:var(--brand-dark)}
.c-green{background:var(--green-soft);color:var(--green)} .c-neutral{background:var(--bg);color:var(--ink-soft)}
.c-amber{background:var(--amber-soft);color:#a9750a} .c-red{background:var(--red-soft);color:var(--red)}
.c-purple{background:var(--purple-soft);color:var(--purple)}
.warn-pill{font-size:10px;font-weight:700;color:#a9750a;background:var(--amber-soft);padding:2px 7px;border-radius:6px}
.empty{padding:26px 17px;text-align:center;color:var(--ink-soft);font-size:12.5px}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* MODAL */
.modal-back{position:fixed;inset:0;background:rgba(16,32,44,.5);display:none;align-items:flex-start;justify-content:center;z-index:80;padding:40px 16px;overflow:auto}
.modal-back.open{display:flex}
.modal{background:var(--surface);border-radius:16px;box-shadow:0 24px 60px rgba(16,40,60,.32);width:100%;max-width:520px;animation:pop .18s}
@keyframes pop{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line)}
.modal-head h3{font-family:'Sora',sans-serif;font-size:15px}
.modal-x{cursor:pointer;color:var(--ink-soft);font-size:20px;line-height:1;border:none;background:none}
.modal-body{padding:18px}
.modal-foot{display:flex;justify-content:flex-end;gap:9px;padding:14px 18px;border-top:1px solid var(--line)}
.sensitive-note{background:var(--amber-soft);color:#a9750a;border-radius:9px;padding:9px 12px;font-size:11.5px;font-weight:600;margin-bottom:14px;display:flex;gap:8px;align-items:center}

.form{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.fld{display:flex;flex-direction:column;gap:5px}
.fld.full{grid-column:1/-1}
.fld label{font-size:11.5px;font-weight:700;color:var(--ink-soft)}
.fld input,.fld select,.fld textarea{border:1px solid var(--line);border-radius:8px;padding:9px 11px;font-family:inherit;font-size:13px;background:var(--bg);color:var(--ink);width:100%}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:2px solid var(--brand-soft);border-color:var(--brand)}

/* TOAST */
.toasts{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:120}
.toast{background:var(--ink);color:#fff;padding:11px 15px;border-radius:10px;font-size:12.5px;font-weight:600;box-shadow:var(--shadow);animation:pop .18s}
.toast.ok{background:var(--green)} .toast.err{background:var(--red)}

/* Tahap produksi (steps) */
.steps{display:flex;flex-wrap:wrap;gap:6px;padding:14px 17px}
.step{font-size:11px;font-weight:700;padding:6px 10px;border-radius:8px;background:var(--bg);color:var(--ink-soft);transition:.12s}
.step.done{background:var(--green-soft);color:var(--green)}
.step.cur{background:var(--brand);color:#fff}
.step.next{background:#fff;border:1px dashed var(--line)}
.totbox{padding:4px 0}
.totline.big{font-family:'Sora',sans-serif}

/* Kartu laporan */
.rep-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:13px}
.rep-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:15px 16px;display:flex;flex-direction:column;gap:9px}
.rep-card .ti{display:flex;align-items:center;gap:10px}
.rep-ic{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;flex:none;background:var(--brand-soft);color:var(--brand-dark);font-weight:800;font-family:'Sora',sans-serif}
.rep-card h4{font-family:'Sora',sans-serif;font-size:13px}
.rep-card p{font-size:11px;color:var(--ink-soft);line-height:1.45;flex:1}
.rep-dl{display:flex;gap:7px;margin-top:auto;padding-top:4px;flex-wrap:wrap}
/* Baris laporan (lines block) */
.rl{display:flex;justify-content:space-between;gap:12px;padding:7px 17px;font-size:12.5px;border-top:1px solid var(--line)}
.rl.section{font-weight:700;color:var(--ink)} .rl.subtotal{font-weight:700;background:#fafbfc}
.rl.total{font-weight:800;font-family:'Sora',sans-serif;background:#fafbfc;border-top:2px solid var(--ink)}
.rl .lbl-ind{padding-left:18px;color:var(--ink-soft)}
@media(max-width:1100px){.rep-grid{grid-template-columns:1fr 1fr}}
@media(max-width:760px){.rep-grid{grid-template-columns:1fr}}

.led-acc{padding:10px 17px;font-family:'Sora',sans-serif;font-weight:700;font-size:12.5px;background:var(--brand-soft);color:var(--brand-dark);border-top:1px solid var(--line)}
.in{color:var(--green)} .out{color:var(--red)}

@media(max-width:1100px){.kpis{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}}
@media(max-width:760px){.app{grid-template-columns:1fr}.side{position:static;height:auto;flex-direction:row;flex-wrap:wrap;overflow:visible}.main{padding:14px 13px}.form{grid-template-columns:1fr}}
