
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:#0b0f19;color:#c8d0e8;min-height:100vh;overflow-x:hidden}
a{color:inherit;text-decoration:none} button{font-family:inherit;cursor:pointer}
select,input,textarea{font-family:inherit}

/* ===== STRUCTURE ===== */
#app{display:flex;flex-direction:column;min-height:100vh}

/* ===== TOPBAR ===== */
.tb{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#090d15;border-bottom:1px solid #1a2240;position:sticky;top:0;z-index:100}
.lg{display:flex;align-items:center;gap:10px}
.lg-box{width:36px;height:36px;background:linear-gradient(135deg,#00d4ff,#00a8cc);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;color:#0b0f19;font-size:14px}
.lg-t{font-weight:700;font-size:16px;color:#c8d0e8}
.lg-s{font-size:11px;color:#6b7a9e;margin-top:-2px}
.ua{display:flex;align-items:center;gap:12px}
.bd{padding:6px 14px;border-radius:8px;font-size:12px;background:#0e1528;border:1px solid #1a2240;color:#8a9bc4}
.bt-sm{padding:6px 14px;border-radius:8px;font-size:12px;background:#1a2240;border:1px solid #2a3a60;color:#c8d0e8;transition:.2s}
.bt-sm:hover{background:#2a3a60}

/* ===== NAV ===== */
.mn{display:flex;align-items:center;gap:2px;padding:6px 16px;background:#090d15;border-bottom:1px solid #1a2240;overflow-x:auto;scrollbar-width:none}
.mn::-webkit-scrollbar{display:none}
.nt{color:#8a9bc4;background:transparent;border:none;padding:10px 16px;border-radius:8px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:6px;cursor:pointer;transition:all .2s;white-space:nowrap;border:1px solid transparent}
.nt:hover{background:#111827;color:#c8d0e8}
.nt.active{background:#0e1528;color:#00d4ff;border-color:#1a2240}

/* group nav bar (primary, 6 grup) */
.ng-bar{display:flex;align-items:center;gap:6px;padding:8px 16px 0;background:#090d15;flex-wrap:wrap}
.ng{color:#9aa7c8;background:transparent;border:1px solid transparent;padding:9px 18px;border-radius:9px 9px 0 0;font-size:13.5px;font-weight:650;letter-spacing:.2px;display:flex;align-items:center;gap:7px;cursor:pointer;transition:all .18s;white-space:nowrap}
.ng:hover{background:#111827;color:#d6def2}
.ng.active{background:#0e1528;color:#00d4ff;border-color:#1a2240;border-bottom-color:#0e1528}
@media(max-width:760px){.ng{flex:1 1 auto;justify-content:center;padding:9px 10px;font-size:12.5px}}

/* ===== SECTIONS ===== */
.sc{display:none;padding:20px;max-width:1600px;margin:0 auto;min-height:calc(100vh - 180px);animation:fi .3s ease-out}
.sc.active{display:block}
@keyframes fi{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ===== CARDS ===== */
.cd{background:#0e1528;border-radius:14px;border:1px solid #1a2240;padding:18px;transition:border-color .2s}
.cd:hover{border-color:#2a3a60}
.cd-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px}
.cd-t{font-size:16px;font-weight:600;color:#c8d0e8}
.cd-sub{font-size:12px;color:#6b7a9e;margin-top:2px}
.ar-c{background:#0a1124;border:1px solid #243056;border-radius:8px;padding:8px 10px}
.ar-l{font-size:11px;color:#7a86a8;text-transform:uppercase;letter-spacing:.3px}
.ar-v{font-size:16px;font-weight:700;color:#c8d0e8;margin-top:2px}
@media(max-width:600px){#ar-cards{grid-template-columns:repeat(2,1fr)!important}}
.cd-ic{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}
.i1{background:rgba(0,212,255,.1);color:#00d4ff} .i2{background:rgba(245,158,11,.1);color:#f59e0b}
.i3{background:rgba(16,185,129,.1);color:#10b981} .i4{background:rgba(239,68,68,.1);color:#ef4444}
.i5{background:rgba(139,92,246,.1);color:#8b5cf6} .i6{background:rgba(6,182,212,.1);color:#06b6d4}
.i7{background:rgba(217,70,239,.1);color:#d946ef} .i8{background:rgba(250,204,21,.1);color:#facc15}
.i9{background:rgba(14,165,233,.1);color:#0ea5e9} .i10{background:rgba(168,85,247,.1);color:#a855f7}

/* ===== KPI ===== */
.kg{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px;margin-bottom:20px}
.kc{background:#0e1528;border-radius:14px;border:1px solid #1a2240;padding:18px;text-align:center;transition:border-color .2s}
.kc:hover{border-color:#2a3a60}
.kl{font-size:11px;color:#8a9bc4;letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px}
.kv{font-size:32px;font-weight:700;color:#00d4ff;line-height:1}
.ku{font-size:11px;color:#6b7a9e;margin-top:4px}
.kp{font-size:13px;margin-top:6px}

/* ===== GRIDS ===== */
.g1{grid-template-columns:1fr}
.g2{display:grid;grid-template-columns:1fr;gap:16px}
.g3{display:grid;grid-template-columns:1fr;gap:16px}
.g4{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:700px){.g2{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.g3{grid-template-columns:1fr 1fr 1fr}.g4{grid-template-columns:1fr 1fr}}
@media(min-width:1300px){.g4{grid-template-columns:1fr 1fr 1fr 1fr}}
/* Rhythm vertikal konsisten: tiap blok top-level di section (.sc) & sub-tab (.ss)
   punya jarak ke bawah. Additive — kartu di dalam grid (.gN>.cd) & inline-grid TIDAK
   kena (spasinya sudah dari gap). Inline margin-bottom per-blok tetap menang. */
.sc>.cd,.sc>.g2,.sc>.g3,.sc>.g4,
.ss>.cd,.ss>.g2,.ss>.g3,.ss>.g4{margin-bottom:16px}

/* ===== FILTER BAR ===== */
.fb{display:flex;align-items:center;gap:12px;padding:14px 18px;background:#0e1528;border-radius:12px;border:1px solid #1a2240;margin-bottom:16px;flex-wrap:wrap}
.sel{background:#0b101c;border:1px solid #1a2240;color:#c8d0e8;padding:8px 12px;border-radius:8px;font-size:13px;outline:none;cursor:pointer}
.sel:focus{border-color:#00d4ff}
.fl{display:flex;flex-direction:column;gap:4px;font-size:11px;color:#9aa6c8;font-weight:600}
.fi{background:#0b101c;border:1px solid #1a2240;color:#c8d0e8;padding:8px 10px;border-radius:8px;font-size:13px;outline:none;font-weight:400}
.fi:focus{border-color:#00d4ff}
html[data-theme="light"] .fi{background:#ffffff;color:#1c2640;border-color:#d4dcec}
html[data-theme="light"] .fl{color:#5a6680}
.go{background:#00d4ff;border:none;color:#0b0f19;padding:9px 20px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer}
.go:hover{opacity:.85}
.sd{width:8px;height:8px;border-radius:50%;background:#10b981;animation:pulse 2s infinite;margin-left:auto}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.la{color:#6b7a9e;font-size:12px}

/* ===== TABLES ===== */
.tw{overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.tbl th{background:#0a0f1c;padding:10px 12px;text-align:left;font-weight:600;color:#8a9bc4;font-size:11px;text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid #1a2240;white-space:nowrap}
.tbl td{padding:10px 12px;border-bottom:1px solid rgba(26,34,64,.5);color:#c8d0e8;white-space:nowrap;vertical-align:middle}
.tbl tbody tr:hover{background:rgba(0,212,255,.03)}
.pill{display:inline-block;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:500;white-space:nowrap}
.pok{background:rgba(16,185,129,.15);color:#10b981}.pw{background:rgba(245,158,11,.15);color:#f59e0b}.pe{background:rgba(239,68,68,.15);color:#ef4444}
.pd{background:rgba(239,68,68,.15);color:#ef4444}.pi{background:rgba(6,182,212,.15);color:#06b6d4}
.pg{background:rgba(100,116,139,.15);color:#94a3b8}

/* ===== FORMS ===== */
.frow{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.fg label{display:block;font-size:11px;color:#8a9bc4;letter-spacing:.5px;margin-bottom:6px}
.fg input,.fg select,.fg textarea{width:100%;background:#0b101c;border:1px solid #1a2240;color:#c8d0e8;padding:10px 12px;border-radius:8px;font-size:13px;outline:none}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:#00d4ff}
.fg textarea{min-height:80px;resize:vertical}
.btr{display:flex;gap:10px;justify-content:flex-end;margin-top:18px;flex-wrap:wrap}
.btn{padding:10px 20px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid transparent}
.btd{background:#0b101c;border-color:#1a2240;color:#c8d0e8}
.btd:hover{background:#111827}
.btp{background:#00d4ff;border-color:#00d4ff;color:#0b0f19}
.btp:hover{opacity:.9}
.btw{background:rgba(245,158,11,.15);border-color:rgba(245,158,11,.3);color:#f59e0b}
.btr2{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.3);color:#ef4444}
.btg{background:rgba(16,185,129,.15);border-color:rgba(16,185,129,.3);color:#10b981}

/* ===== SUB NAV ===== */
.sbn{display:flex;gap:6px;padding:0 0 12px;border-bottom:1px solid #1a2240;margin-bottom:16px;overflow-x:auto}
.sbt{background:transparent;border:none;color:#6b7a9e;padding:8px 16px;border-radius:8px;font-size:13px;cursor:pointer;transition:.2s;border-bottom:2px solid transparent;margin-bottom:-13px;white-space:nowrap}
.sbt:hover{color:#c8d0e8}
.sbt.active{color:#00d4ff;border-bottom-color:#00d4ff;font-weight:600}
.ss{display:none}
.ss.active{display:block;animation:fi .3s ease}

/* ===== FOOTER ===== */
.ft{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:#090d15;border-top:1px solid #1a2240;margin-top:auto;flex-wrap:wrap;gap:10px}
.ftl,.ftr{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.ftl a,.ftl button{color:#6b7a9e;font-size:12px;background:transparent;border:1px solid #1a2240;padding:6px 12px;border-radius:6px;cursor:pointer;transition:.2s}
.ftl a:hover,.ftl button:hover{color:#c8d0e8;background:#111827}
.ftr{color:#4a5578;font-size:12px}
.fnew{position:relative}
.fnew::after{content:'';position:absolute;top:0;right:-2px;width:7px;height:7px;background:#ef4444;border-radius:50%}

/* ===== UTILS ===== */
.g{color:#10b981} .r{color:#ef4444} .b{color:#00d4ff} .y{color:#f59e0b} .p{color:#8b5cf6}
.gr{color:#6b7a9e} .mt12{margin-top:12px} .mt16{margin-top:16px} .mb12{margin-bottom:12px}
.c{text-align:center} .w100{width:100%}
.es{padding:60px 20px;text-align:center;color:#6b7a9e;font-size:13px}
.es h3{color:#c8d0e8;margin-bottom:8px;font-size:16px}
.ch{height:220px;display:flex;align-items:center;justify-content:center;background:#0b101c;border-radius:10px;color:#4a5578;font-size:12px;border:1px dashed #1a2240}
.ln{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:8px;background:#0b101c;border:1px solid transparent;margin-bottom:8px;cursor:pointer;transition:.2s}
.ln:hover{background:#111827;border-color:#1a2240}
.ln .ar{color:#4a5578}
.ql a{padding:8px 14px;background:#0b101c;border:1px solid #1a2240;border-radius:8px;font-size:12px;color:#8a9bc4;display:inline-block;margin:0 6px 6px 0;transition:.2s}
.ql a:hover{background:#111827;color:#c8d0e8;border-color:#2a3a60}

/* ===== TOAST ===== */
#toast{position:fixed;bottom:24px;right:24px;background:#00d4ff;color:#0b0f19;padding:14px 24px;border-radius:12px;font-size:13px;font-weight:600;opacity:0;transform:translateY(10px);transition:all .3s;z-index:9999;pointer-events:none;max-width:min(420px,90vw);text-align:left;line-height:1.45;box-shadow:0 10px 30px -8px rgba(0,0,0,.5)}
#toast.show{opacity:1;transform:translateY(0)}
#toast.to-ok{background:#2fbf71;color:#04140b}
#toast.to-err{background:#ef5d6b;color:#fff}
#toast.to-warn{background:#e0b15a;color:#1a1304}

/* ===== MODAL ===== */
.mdl{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:none;align-items:center;justify-content:center;z-index:200;padding:20px}
.mdl.show{display:flex}
.mdl-bx{background:#0e1528;border-radius:16px;border:1px solid #1a2240;max-width:560px;width:100%;max-height:90vh;overflow-y:auto;padding:24px;animation:fi .3s ease}
.mdl-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.mdl-h h3{font-size:17px;color:#c8d0e8}
.mdl-x{background:transparent;border:none;color:#8a9bc4;font-size:20px;cursor:pointer}
.mdl-x:hover{color:#ef4444}

/* ===== UPLOAD ===== */
.up-zn{border:2px dashed #1a2240;border-radius:12px;padding:30px;text-align:center;cursor:pointer;transition:.2s;background:#0b101c}
.up-zn:hover{border-color:#00d4ff;background:#0f1526}
.up-ic{font-size:36px;margin-bottom:10px;color:#4a5578}
.up-tx{font-size:14px;color:#8a9bc4}

/* ===== WELCOME ===== */
.wc{background:#0e1528;border-radius:16px;border:1px solid #1a2240;padding:24px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.wc h1{font-size:22px;color:#c8d0e8;margin-bottom:6px}
.wc p{color:#6b7a9e;font-size:13px}

/* ===== RESPONSIVE ===== */
@media(max-width:600px){
  .kg{grid-template-columns:1fr 1fr}
  .g2,.g3,.g4{grid-template-columns:1fr}
  .ft{flex-direction:column;align-items:flex-start}
  .tb{flex-wrap:wrap}
  .ua{flex-wrap:wrap}
  .fb{flex-direction:column;align-items:stretch}
}

/* ===== PAGINATION ===== */
.pgn{display:flex;align-items:center;gap:6px;justify-content:flex-end;margin-top:10px}
.pgn button{padding:5px 12px;background:#0b101c;border:1px solid #1a2240;color:#8a9bc4;border-radius:6px;font-size:12px;cursor:pointer}
.pgn button:hover{background:#111827;color:#c8d0e8}
.pgn button:disabled{opacity:.3;cursor:not-allowed}
.pgn .inf{color:#6b7a9e;font-size:12px}

/* ===== TAG ===== */
.tg{display:inline-block;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:500;background:rgba(99,130,255,.1);color:#6382ff}

/* ===== PROGRESS BAR ===== */
.pb{width:100%;height:6px;background:#1a2240;border-radius:3px;overflow:hidden;margin-top:6px}
.pb-in{height:100%;background:linear-gradient(90deg,#00d4ff,#00a8cc);border-radius:3px;transition:width .5s ease}
