:root{
  --bg:#0f1620; --panel:#16202c; --panel2:#1c2836; --line:#26313f;
  --txt:#e7eef6; --mut:#8aa0b4; --acc:#3b82f6; --acc2:#22d3ee;
  --ok:#22c55e; --warn:#f59e0b; --bad:#ef4444; --gray:#64748b;
  --radius:12px; --shadow:0 6px 22px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
body{margin:0;font-family:"Segoe UI",system-ui,Roboto,Arial,sans-serif;background:var(--bg);color:var(--txt);font-size:14px}
a{color:var(--acc)}
.wrap{max-width:1500px;margin:0 auto;padding:18px}
header{display:flex;flex-wrap:wrap;align-items:flex-end;gap:14px;justify-content:space-between;margin-bottom:14px}
h1{font-size:21px;margin:0;letter-spacing:.2px}
h1 .lp{color:var(--acc2)}
.sub{color:var(--mut);font-size:12.5px;margin-top:4px}
.htools{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin:6px 0 16px}
.tab{padding:9px 16px;background:var(--panel);border:1px solid var(--line);border-radius:999px;cursor:pointer;color:var(--mut);font-weight:600;user-select:none}
.tab:hover{color:var(--txt)}
.tab.active{background:var(--acc);border-color:var(--acc);color:#fff}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:12px;margin-bottom:16px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;position:relative}
.kpi.click{cursor:pointer;transition:border-color .15s,transform .1s}
.kpi.click:hover{border-color:var(--acc);transform:translateY(-2px)}
.kpi.click::after{content:"🔎 klik";position:absolute;top:10px;right:12px;font-size:10px;color:var(--mut)}
.kpi.danger .val{color:#f87171}
.kpi .lab{color:var(--mut);font-size:11.5px;text-transform:uppercase;letter-spacing:.6px}
.kpi .val{font-size:23px;font-weight:700;margin-top:6px}
.kpi .val small{font-size:13px;color:var(--mut);font-weight:500}
.grid{display:grid;gap:14px}
.g2{grid-template-columns:1fr 1fr}
@media(max-width:1100px){.g2{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.card h3{margin:0 0 12px;font-size:14px;font-weight:700}
.card h3 .hint{color:var(--mut);font-weight:400;font-size:12px;margin-left:6px}
.bars{display:flex;flex-direction:column;gap:8px}
.bar{display:grid;grid-template-columns:150px 1fr auto;align-items:center;gap:10px;font-size:12.5px}
.bar.click{cursor:pointer}
.bar.click:hover .nm{color:var(--txt)}
.bar.click:hover .fill{filter:brightness(1.2)}
.bar .nm{color:var(--mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar .track{background:var(--panel2);border-radius:6px;height:18px;overflow:hidden}
.bar .fill{height:100%;background:linear-gradient(90deg,var(--acc),var(--acc2));border-radius:6px}
.bar.hot .fill{background:linear-gradient(90deg,#ef4444,#f59e0b)}
.bar .vv{font-variant-numeric:tabular-nums;color:var(--txt);min-width:70px;text-align:right}
.cols{display:flex;align-items:flex-end;gap:6px;height:170px;padding-top:6px}
.col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;justify-content:flex-end;height:100%}
.col .b{width:100%;background:linear-gradient(180deg,var(--acc2),var(--acc));border-radius:6px 6px 0 0;min-height:2px}
.col .cl{color:var(--mut);font-size:11px;white-space:nowrap}
.col .cv{font-size:11px;color:var(--txt)}
.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;margin-bottom:12px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:12px}
.fld{display:flex;flex-direction:column;gap:4px}
.fld label{font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:.5px}
input,select{background:var(--panel2);border:1px solid var(--line);color:var(--txt);border-radius:8px;padding:8px 10px;font-size:13px;outline:none}
input:focus,select:focus{border-color:var(--acc)}
input[type=search]{min-width:240px}
.btn{background:var(--acc);color:#fff;border:none;border-radius:8px;padding:9px 14px;font-weight:600;cursor:pointer;font-size:13px}
.btn.ghost{background:var(--panel2);color:var(--txt);border:1px solid var(--line)}
.btn.ok{background:var(--ok)}
.btn:hover{filter:brightness(1.08)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.chips{display:flex;gap:6px;flex-wrap:wrap}
.chip{padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:var(--panel2);color:var(--mut);font-size:12px;user-select:none}
.chip.on{background:var(--acc);border-color:var(--acc);color:#fff}
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}
.count{color:var(--mut);font-size:13px}
.tblwrap{overflow:auto;border:1px solid var(--line);border-radius:var(--radius);max-height:70vh}
table{border-collapse:collapse;width:100%;font-size:12.8px}
th,td{padding:9px 11px;text-align:left;white-space:nowrap;border-bottom:1px solid var(--line)}
th{position:sticky;top:0;background:var(--panel2);cursor:pointer;user-select:none;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--mut);z-index:1}
th:hover{color:var(--txt)}
th .ar{font-size:10px;color:var(--acc2)}
tbody tr:hover{background:var(--panel2);cursor:pointer}
td.num{text-align:right;font-variant-numeric:tabular-nums}
.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:700}
.r0{background:#334155;color:#cbd5e1}.r1{background:rgba(34,197,94,.18);color:#4ade80}
.r2{background:rgba(245,158,11,.18);color:#fbbf24}.r3{background:rgba(239,68,68,.2);color:#f87171}
.sch{display:inline-block;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:600;background:var(--panel2);color:var(--mut)}
.pager{display:flex;gap:8px;align-items:center;justify-content:center;margin-top:12px;color:var(--mut)}
.refund{color:#f87171;font-weight:700}
.ov{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:50;padding:20px}
.ov.show{display:flex}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:14px;max-width:760px;width:100%;max-height:85vh;overflow:auto;box-shadow:var(--shadow)}
.modal .mh{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--panel)}
.modal .mh h3{margin:0;font-size:16px}
.x{cursor:pointer;color:var(--mut);font-size:22px;line-height:1}
.mb{padding:16px 18px}
.kv{display:grid;grid-template-columns:200px 1fr;gap:6px 14px;font-size:13px}
.kv .k{color:var(--mut)}
.note{background:rgba(59,130,246,.08);border:1px solid rgba(59,130,246,.3);border-radius:10px;padding:12px 14px;font-size:12.5px;color:var(--mut);margin-bottom:14px}
.note b{color:var(--txt)}
.hidden{display:none!important}
.sectitle{font-size:13px;color:var(--mut);text-transform:uppercase;letter-spacing:.6px;margin:18px 0 8px}
footer{color:var(--mut);font-size:11.5px;text-align:center;margin:24px 0 8px}
#toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:12px 18px;box-shadow:var(--shadow);z-index:90;display:none;font-size:13px}
#toast.show{display:block}
.help-li{margin:6px 0;color:var(--mut);font-size:13px}
.help-li b{color:var(--txt)}
/* brand */
.brand{display:flex;align-items:center;gap:14px}
#brandLogo{height:34px;width:auto;display:block}
.brandttl{font-size:15px;font-weight:600;color:var(--txt);letter-spacing:.2px}
/* login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:30px 28px;width:100%;max-width:380px}
.login-card img{height:34px;display:block;margin:0 auto 6px}
.login-card .tag{text-align:center;color:var(--mut);font-size:12.5px;margin-bottom:20px}
.login-card label{display:block;font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:.5px;margin:12px 0 4px}
.login-card input{width:100%}
.login-card .btn{width:100%;margin-top:20px;padding:11px}
.login-err{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.4);color:#f87171;border-radius:8px;padding:9px 12px;font-size:12.5px;margin-bottom:6px;text-align:center}
/* ===== PDF report (print only) ===== */
#report{display:none}
@media print{
  .wrap,#toast,.ov{display:none !important}
  #report{display:block !important}
  body{background:#fff}
  @page{margin:11mm}
}
#report{color:#1a2330;font-family:Arial,Helvetica,sans-serif;font-size:11px}
#report .rhead{background:#0f1620;color:#fff;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;-webkit-print-color-adjust:exact;print-color-adjust:exact}
#report .rhead img{height:34px}
#report .rhead .rttl{font-size:13px;font-weight:700;margin-top:4px;color:#dbe7f3}
#report .rhead .rmeta{text-align:right;font-size:9.5px;color:#9fb2c6;line-height:1.5}
#report h2.rsec{font-size:12.5px;color:#1f3a5f;border-bottom:2px solid #2e75b6;padding-bottom:3px;margin:16px 20px 6px;page-break-after:avoid}
#report .rkpis{display:flex;flex-wrap:wrap;gap:8px;margin:10px 20px}
#report .rkpi{border:1px solid #d3dde7;border-radius:8px;padding:7px 11px;min-width:135px}
#report .rkpi .l{font-size:8.5px;color:#667;text-transform:uppercase;letter-spacing:.4px}
#report .rkpi .v{font-size:15px;font-weight:700;color:#0f1620}
#report table.rtab{width:calc(100% - 40px);margin:4px 20px;border-collapse:collapse;font-size:10px}
#report table.rtab th{background:#eef3f8;text-align:left;padding:5px 7px;border-bottom:1px solid #c8d4e0;color:#33475b;-webkit-print-color-adjust:exact;print-color-adjust:exact}
#report table.rtab td{padding:4px 7px;border-bottom:1px solid #e6ecf2}
#report table.rtab td.n{text-align:right;font-variant-numeric:tabular-nums}
#report table.rtab tr{page-break-inside:avoid}
#report .rb{display:inline-block;padding:1px 7px;border-radius:9px;font-size:9px;font-weight:700;-webkit-print-color-adjust:exact;print-color-adjust:exact}
#report .rb3{background:#fde0e0;color:#b42318}
#report .rb2{background:#fdf0d5;color:#9a6700}
#report .rb1{background:#dcf5e3;color:#1a7f37}
#report .rb0{background:#e9edf2;color:#556}
#report .rnote{margin:4px 20px 0;font-size:10px;color:#445}
#report .rfoot{margin:16px 20px;font-size:9px;color:#778;border-top:1px solid #d3dde7;padding-top:8px}
