:root{
  --navy:#0A2540; --navy2:#13355c; --blue:#2563eb;
  --green:#16a34a; --green-bg:#dcfce7; --amber:#d97706; --amber-bg:#fef3c7;
  --red:#dc2626; --red-bg:#fee2e2; --ink:#0f172a; --muted:#64748b;
  --line:#e2e8f0; --bg:#f1f5f9; --card:#fff; --wa-bg:#e5ddd5; --wa-bubble:#dcf8c6;
  --radius:14px;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:var(--navy);color:var(--ink);min-height:100vh}
body:has(.stage){background:#e9eef4}
a{color:inherit;text-decoration:none}

/* stage = full-page app, no device frame */
.stage{min-height:calc(100vh - 33px);display:flex;justify-content:center;align-items:stretch;background:#e9eef4}
.topnav{position:sticky;top:0;display:flex;align-items:center;gap:11px;padding:6px 14px;background:#0A2540;color:#9fb3cc;font-size:12px;z-index:50}
.topnav a{color:#9fb3cc;font-weight:600}
.topnav a:hover{color:#fff}
.topnav .code{color:#5b8fd6;font-weight:800}
.topnav .sep{opacity:.4}
.topnav .pill{display:none}
.pill{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700}
.p1{background:#1f5fbf;color:#fff}.p2{background:#3a4a5e;color:#cdd8e6}

/* mobile app: centered column on desktop, full width on phone */
.phone{width:100%;max-width:460px;background:none;border-radius:0;padding:0;box-shadow:none;position:relative;display:flex;flex-direction:column}
.phone .notch{display:none}
.screen{background:var(--bg);overflow:hidden;flex:1;display:flex;flex-direction:column;position:relative;box-shadow:0 0 40px rgba(0,0,0,.07)}
.sbody{flex:1;overflow:auto;padding:16px 16px 22px}

.appbar{background:var(--navy);color:#fff;padding:15px 16px;display:flex;align-items:center;gap:10px;font-weight:700;font-size:15px}
.appbar .logo{width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,#5b8fd6,#2563eb);display:grid;place-items:center;font-size:13px;font-weight:800;color:#fff}
.appbar .right{margin-left:auto;font-size:12px;font-weight:500;opacity:.85;display:flex;align-items:center;gap:8px}
.appbar .switch{font-size:11px;background:rgba(255,255,255,.14);padding:2px 8px;border-radius:999px}

.progress{display:flex;gap:6px;padding:12px 16px 0}
.progress .bar{flex:1;height:5px;border-radius:3px;background:var(--line)}
.progress .bar.on{background:var(--blue)}

h3.s{font-size:18px;font-weight:800;margin-bottom:4px}
p.lead{font-size:13px;color:var(--muted);line-height:1.5;margin-bottom:14px}
.label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin:14px 0 5px}
.input{background:#fff;border:1px solid var(--line);border-radius:10px;padding:11px 12px;font-size:13px;color:var(--ink);width:100%}
.input.ph{color:#9aa7b8}
.help{font-size:11px;color:var(--muted);margin-top:5px;line-height:1.4}
.upload{background:#fff;border:1.5px dashed #b8c4d4;border-radius:12px;padding:22px;text-align:center;color:var(--muted);font-size:12.5px}
.upload .ic{font-size:26px;margin-bottom:6px}
.upload.done{border-style:solid;border-color:var(--green);color:var(--green);background:var(--green-bg)}

.btn{display:block;width:100%;text-align:center;padding:13px;border-radius:11px;font-size:14px;font-weight:700;cursor:pointer;border:none;margin-top:8px}
.btn.primary{background:var(--blue);color:#fff}
.btn.ghost{background:transparent;color:var(--muted)}
.btn.green{background:var(--green);color:#fff}
.btn.red{background:var(--red);color:#fff}
.btn.outline{background:#fff;border:1px solid var(--line);color:var(--ink)}
.btn.sm{padding:9px;font-size:12.5px;margin-top:0}

.radio{display:flex;gap:10px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:10px;padding:11px 12px;font-size:13px;margin-bottom:8px}
.radio .dot{width:16px;height:16px;border-radius:50%;border:2px solid #b8c4d4;flex:none}
.radio.on{border-color:var(--blue)}.radio.on .dot{border-color:var(--blue);background:radial-gradient(circle,#2563eb 40%,#fff 45%)}

.status{display:flex;flex-direction:column;align-items:center;text-align:center;padding-top:44px}
.status .ic{width:80px;height:80px;border-radius:50%;display:grid;place-items:center;font-size:38px;margin-bottom:18px}
.ic.wait{background:var(--amber-bg);color:var(--amber)}
.ic.ok{background:var(--green-bg);color:var(--green)}
.ic.bad{background:var(--red-bg);color:var(--red)}
.badge{display:inline-block;padding:5px 12px;border-radius:999px;font-size:12px;font-weight:700;margin-top:14px}
.badge.wait{background:var(--amber-bg);color:var(--amber)}
.badge.ok{background:var(--green-bg);color:var(--green)}
.badge.bad{background:var(--red-bg);color:var(--red)}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:15px;margin-bottom:12px}
.card .ttl{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.balance{background:linear-gradient(135deg,var(--navy),var(--navy2));color:#fff;border:none}
.balance .ttl{color:#a9c2e3}
.balance .big{font-size:30px;font-weight:800;margin:6px 0 2px}
.balance .note{font-size:11px;color:#a9c2e3;margin-bottom:12px}
.balance .btn.primary{background:#fff;color:var(--navy)}
.stat-big{font-size:24px;font-weight:800;margin:4px 0 2px}
.stat-sub{font-size:12px;color:var(--muted)}
.row2{display:flex;gap:10px}.row2>*{flex:1}

.txn{display:flex;justify-content:space-between;align-items:flex-start;padding:11px 0;border-bottom:1px solid var(--line)}
.txn:last-child{border-bottom:none}
.txn .amt{font-weight:800;font-size:14px}
.txn .meta{font-size:11px;color:var(--muted);margin-top:2px}
.seeall{display:block;text-align:center;color:var(--blue);font-weight:700;font-size:13px;padding:10px}

.tabbar{display:flex;border-top:1px solid var(--line);background:#fff}
.tabbar a{flex:1;text-align:center;padding:9px 0 11px;font-size:10px;color:var(--muted)}
.tabbar a .ic{display:block;font-size:18px;margin-bottom:2px}
.tabbar a.on{color:var(--blue);font-weight:700}

.filterbar{display:flex;gap:6px;overflow:auto;padding-bottom:12px}
.chip{flex:none;padding:7px 13px;border-radius:999px;font-size:12px;font-weight:600;background:#fff;border:1px solid var(--line);color:var(--muted)}
.chip.on{background:var(--navy);color:#fff;border-color:var(--navy)}

.kv{display:flex;justify-content:space-between;font-size:13px;padding:7px 0;border-bottom:1px dashed var(--line)}
.kv:last-child{border-bottom:none}.kv .k{color:var(--muted)}.kv .v{font-weight:700}
.summary{background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px;margin:12px 0}

.staff{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px}
.staff .nm{font-weight:700;font-size:13px}.staff .wa{font-size:11px;color:var(--muted)}
.toggle{margin-left:auto;width:38px;height:22px;border-radius:999px;background:var(--green);position:relative;flex:none}
.toggle::after{content:"";position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;background:#fff}
.toggle.off{background:#cbd5e1}.toggle.off::after{right:auto;left:2px}
.banner{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af;border-radius:10px;padding:11px;font-size:12px;line-height:1.5;margin-top:6px}

.set-sec{background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px;margin-bottom:10px}
.set-sec .k{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-weight:700}
.set-sec .v{font-size:14px;font-weight:600;margin-top:3px}
.set-sec .lk{color:var(--blue);font-size:12px;font-weight:700;margin-top:6px;display:inline-block}

/* WhatsApp */
.wa{background:var(--wa-bg);height:100%;display:flex;flex-direction:column}
.wa-bar{background:#075e54;color:#fff;padding:12px 14px;display:flex;align-items:center;gap:10px;font-weight:700;font-size:14px}
.wa-bar .av{width:30px;height:30px;border-radius:50%;background:#25d366;display:grid;place-items:center;font-size:14px}
.wa-bar .st{font-size:11px;font-weight:400;opacity:.85}
.wa-body{flex:1;overflow:auto;padding:14px 12px;display:flex;flex-direction:column;gap:8px}
.bub{max-width:88%;padding:8px 10px 6px;border-radius:9px;font-size:12.5px;line-height:1.45;box-shadow:0 1px .5px rgba(0,0,0,.13);white-space:pre-wrap}
.bub .t{font-size:9.5px;color:#667;text-align:right;margin-top:2px}
.bub.in{background:#fff;align-self:flex-start;border-top-left-radius:0}
.bub.out{background:var(--wa-bubble);align-self:flex-end;border-top-right-radius:0}
.bub b{font-weight:700}
.wa-input{background:#f0f0f0;padding:8px 12px;display:flex;gap:8px;align-items:center}
.wa-input .box{flex:1;background:#fff;border-radius:999px;padding:8px 14px;font-size:12px;color:#9aa7b8}
.wa-input .send{width:34px;height:34px;border-radius:50%;background:#075e54;color:#fff;display:grid;place-items:center}

/* receipt */
.receipt{background:#fff;border-radius:12px;border:1px dashed #94a3b8;padding:18px;margin:8px 0;font-family:ui-monospace,monospace}
.receipt .rh{text-align:center;border-bottom:1px dashed #94a3b8;padding-bottom:10px;margin-bottom:10px}
.receipt .rh .b{font-weight:800;font-size:16px;letter-spacing:1px;font-family:-apple-system,sans-serif}
.receipt .rk{font-size:10px;color:var(--muted);text-transform:uppercase;margin-top:9px}
.receipt .rv{font-size:14px;font-weight:700;margin-top:1px}

/* desktop (admin) */
.desktop{width:100%;max-width:1200px;background:none;border-radius:0;padding:0;box-shadow:none;display:flex;flex-direction:column}
.desktop .bar{display:none}
.dscreen{background:var(--bg);overflow:hidden;flex:1;display:flex;flex-direction:column;box-shadow:0 0 40px rgba(0,0,0,.07)}
.dtop{background:#fff;border-bottom:1px solid var(--line);padding:14px 20px;display:flex;align-items:center;gap:10px;font-weight:800}
.dtop .logo{width:24px;height:24px;border-radius:6px;background:linear-gradient(135deg,#5b8fd6,#2563eb);display:grid;place-items:center;color:#fff;font-size:12px}
.dtop .right{margin-left:auto;font-size:12px;font-weight:500;color:var(--muted)}
.dbody{flex:1;overflow:auto;padding:22px}
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:11px 10px;border-bottom:1px solid var(--line)}
th{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted)}
.login-box{max-width:300px;margin:46px auto;text-align:center}
.ktp{width:100%;height:170px;border-radius:10px;background:repeating-linear-gradient(45deg,#e2e8f0,#e2e8f0 12px,#edf2f7 12px,#edf2f7 24px);display:grid;place-items:center;color:var(--muted);font-size:13px;border:1px solid var(--line)}

/* index gallery */
.idx{max-width:1100px;margin:0 auto;padding:40px 20px 60px}
.idx h1{color:#e8eef6;font-size:34px;font-weight:800;text-align:center}
.idx .sub{color:#7a95b5;text-align:center;margin:6px 0 8px;font-size:15px}
.idx .meta{color:#9fb3cc;text-align:center;font-size:12px;margin-bottom:30px}
.mod{margin-bottom:30px}
.mod h2{color:#cfe0f3;font-size:18px;font-weight:800;border-left:4px solid var(--blue);padding-left:12px;margin-bottom:4px}
.mod p{color:#7a95b5;font-size:12.5px;margin:0 0 14px 16px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px}
.scard{background:#10294a;border:1px solid #1c3a5e;border-radius:12px;padding:14px;color:#dbe7f5;transition:.12s}
.scard:hover{border-color:var(--blue);transform:translateY(-2px);background:#143258}
.scard .c{color:#5b8fd6;font-weight:800;font-size:13px}
.scard .n{font-weight:700;font-size:14px;margin:4px 0 8px}
.scard .pf{font-size:11px;color:#8aa3c2}
.start{display:block;max-width:320px;margin:0 auto 30px;text-align:center;background:var(--blue);color:#fff;font-weight:700;padding:14px;border-radius:12px}
