*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:#f5f7fa;color:#1a1a1a;font-size:14px;line-height:1.5}
a{color:#1b347c;text-decoration:none}a:hover{text-decoration:underline}

/* ===== LOGIN ===== */
.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#1b347c 0%,#2d4ea3 100%)}
.login-card{background:#fff;border-radius:14px;box-shadow:0 10px 40px rgba(0,0,0,.15);padding:32px;width:100%;max-width:420px}
.login-card .login-logo{display:flex;justify-content:center;margin-bottom:18px}
.login-card .login-logo img{height:64px;width:auto}
.login-card .brand{text-align:center;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #f0f0f0}
.login-card .brand h1{font-size:22px;color:#1b347c;margin-bottom:6px}
.login-card .brand p{font-size:12px;color:#888}
.login-card label{display:block;font-size:12px;color:#555;font-weight:600;margin-bottom:6px;margin-top:14px}
.login-card input{width:100%;padding:11px 13px;border:1px solid #d0d7de;border-radius:8px;font-size:14px}
.login-card input:focus{border-color:#1b347c;outline:none}
.login-card button{width:100%;padding:12px;background:#1b347c;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;margin-top:18px}
.login-card button:hover{background:#152a63}
.login-card .hint{font-size:12px;color:#888;text-align:center;margin-top:16px}
.periode-banner{background:#dbeafe;color:#1e40af;padding:10px 12px;border-radius:8px;font-size:13px;text-align:center;margin-bottom:14px}

/* ===== ALERTS ===== */
.alert{padding:11px 13px;border-radius:8px;margin-bottom:14px;font-size:13px}
.alert.ok{background:#dcfce7;color:#166534;border:1px solid #86efac}
.alert.err{background:#fee;color:#c00;border:1px solid #fca5a5}
.alert.info{background:#dbeafe;color:#1e40af;border:1px solid #93c5fd}
.alert.warn{background:#fef3c7;color:#92400e;border:1px solid #fde68a}

/* ===== TOPBAR (peserta) ===== */
.p-top{background:#fff;border-bottom:1px solid #e5e7eb;padding:14px 20px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10}
.p-top h1{font-size:15px;color:#1b347c}
.p-top .me{font-size:13px;color:#555}
.p-top a{margin-left:14px;font-size:13px}

/* ===== WRAP ===== */
.p-wrap{max-width:880px;margin:0 auto;padding:20px}
.p-wrap h2{font-size:18px;margin-bottom:6px}
.p-wrap .subtitle{font-size:13px;color:#888;margin-bottom:18px}

/* ===== STEPPER ===== */
.stepper{display:flex;background:#fff;border-radius:10px;padding:14px;box-shadow:0 1px 2px rgba(0,0,0,.04);margin-bottom:18px;gap:8px;overflow-x:auto}
.step{flex:1;min-width:120px;text-align:center;padding:10px 8px;border-radius:8px;border:1px solid #e5e7eb;font-size:12px;color:#666;position:relative}
.step .num{display:inline-block;width:22px;height:22px;border-radius:50%;background:#e5e7eb;color:#666;font-weight:600;line-height:22px;margin-bottom:6px;font-size:11px}
.step .label{display:block;font-weight:500}
.step.done{background:#dcfce7;border-color:#86efac;color:#166534}
.step.done .num{background:#16a34a;color:#fff}
.step.active{background:#dbeafe;border-color:#93c5fd;color:#1e40af}
.step.active .num{background:#1b347c;color:#fff}
.step.skip{background:#f3f4f6;border-style:dashed;color:#999}

/* ===== CARD ===== */
.p-card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 1px 2px rgba(0,0,0,.04);margin-bottom:14px}
.p-card h3{font-size:15px;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.p-card .meta{font-size:13px;color:#666;margin-bottom:12px}
.p-card .meta b{color:#1a1a1a}
.kv{display:grid;grid-template-columns:140px 1fr;gap:8px 12px;font-size:13px;margin-bottom:12px}
.kv .k{color:#888}
.kv .v{color:#1a1a1a;font-weight:500}

/* ===== STATUS BADGES ===== */
.badge{display:inline-block;padding:3px 9px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}
.badge.lunas,.badge.approved,.badge.paid,.badge.selesai{background:#dcfce7;color:#166534}
.badge.pending{background:#fef3c7;color:#92400e}
.badge.belum,.badge.none{background:#f3f4f6;color:#666}
.badge.rejected,.badge.expired,.badge.failed{background:#fee;color:#991b1b}

/* ===== BUTTONS ===== */
.btn{display:inline-block;padding:10px 18px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;text-align:center}
.btn-primary{background:#1b347c;color:#fff}.btn-primary:hover{background:#152a63}
.btn-success{background:#16a34a;color:#fff}.btn-success:hover{background:#15803d}
.btn-ghost{background:#f3f4f6;color:#333;border:1px solid #d0d7de}.btn-ghost:hover{background:#e5e7eb}
.btn-block{display:block;width:100%}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* ===== VA INFO ===== */
.va-box{background:#f8f9fb;border:1px solid #e5e7eb;border-radius:10px;padding:16px;margin-top:10px}
.va-box .va-num{font-family:'SF Mono','Monaco',monospace;font-size:20px;font-weight:600;color:#1b347c;letter-spacing:1px;background:#fff;padding:10px 14px;border-radius:6px;border:1px dashed #1b347c;display:inline-block;margin:6px 0}
.va-box .copy-btn{margin-left:8px;padding:6px 12px;background:#1b347c;color:#fff;border:none;border-radius:6px;font-size:12px;cursor:pointer}
.va-box .expire{font-size:12px;color:#92400e;margin-top:6px}

@media (max-width:600px){
  .p-wrap{padding:14px}
  .kv{grid-template-columns:1fr;gap:2px 0}
  .kv .k{font-size:11px;text-transform:uppercase;letter-spacing:.3px}
  .kv .v{margin-bottom:8px}
  .stepper{flex-wrap:nowrap}
  .step{min-width:100px}
}

.btn-sm{padding:6px 12px;font-size:12px}
.form-row{margin:12px 0}
.form-row label{display:block;font-size:12px;color:#475569;margin-bottom:4px;font-weight:600}
.form-row input{width:100%;padding:10px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px;box-sizing:border-box}
.form-row input:focus{outline:none;border-color:#1e40af}
