:root{
    --bg:#f5f7fb;
    --card:#ffffff;
    --text:#172033;
    --muted:#6b7280;
    --line:#e5e7eb;
    --primary:#2563eb;
    --primary-dark:#1d4ed8;
    --danger:#dc2626;
    --success:#16a34a;
    --warning:#d97706;
    --info:#0891b2;
    --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Arial,Helvetica,sans-serif;font-size:15px;line-height:1.45}
a{color:inherit;text-decoration:none}
.topbar{position:sticky;top:0;z-index:20;background:#fff;border-bottom:1px solid var(--line);height:58px;display:flex;align-items:center;justify-content:space-between;padding:0 14px}
.brand a{font-weight:800;letter-spacing:.2px;display:block;font-size:17px}.brand small{display:block;color:var(--muted);font-size:11px;margin-top:-2px}
.nav-toggle{border:0;background:#eef2ff;color:#1e40af;border-radius:10px;padding:9px 12px;font-size:19px}
.nav{position:fixed;top:58px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);padding:8px 12px;display:none;z-index:19;box-shadow:0 8px 18px rgba(15,23,42,.08)}
.nav-open .nav{display:block}.nav a{display:block;padding:11px 10px;border-radius:10px;color:#263244}.nav a:hover{background:#f1f5f9}.nav .danger{color:var(--danger)}
.container{max-width:1120px;margin:0 auto;padding:14px}.page-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin:8px 0 14px}.page-title h1{font-size:22px;margin:0}.page-title p{margin:3px 0 0;color:var(--muted)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 8px 22px rgba(15,23,42,.04);padding:14px;margin-bottom:14px}.card h2{font-size:17px;margin:0 0 10px}.card h3{font-size:15px;margin:0 0 10px;color:#374151}
.grid{display:grid;grid-template-columns:1fr;gap:12px}.grid-2{display:grid;grid-template-columns:1fr;gap:12px}.stat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px}.stat b{display:block;font-size:26px;line-height:1.1;margin-bottom:4px}.stat span{color:var(--muted);font-size:13px}
.form-group{margin-bottom:12px}.form-group label{display:block;font-weight:700;margin-bottom:6px;font-size:13px;color:#374151}input[type=text],input[type=password],input[type=date],select,textarea{width:100%;border:1px solid #d1d5db;background:#fff;border-radius:12px;padding:12px 12px;font-size:16px;outline:none}textarea{min-height:86px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.form-inline{display:flex;gap:8px}.form-inline input{flex:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:0;border-radius:12px;padding:12px 14px;background:#e5e7eb;color:#111827;font-weight:700;cursor:pointer;min-height:44px;text-align:center}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-danger{background:var(--danger);color:#fff}.btn-success{background:var(--success);color:#fff}.btn-outline{background:#fff;border:1px solid #d1d5db;color:#111827}.btn-block{display:flex;width:100%}.btn-sm{padding:8px 10px;min-height:36px;font-size:13px;border-radius:9px}
.action-row{display:grid;grid-template-columns:1fr;gap:10px;margin-top:12px}.alert{border-radius:12px;padding:11px 12px;margin-bottom:12px;border:1px solid}.alert-success{background:#ecfdf5;color:#166534;border-color:#bbf7d0}.alert-danger{background:#fef2f2;color:#991b1b;border-color:#fecaca}.alert-warning{background:#fffbeb;color:#92400e;border-color:#fde68a}.alert-info{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}
.detail-list{display:grid;grid-template-columns:1fr;gap:8px}.detail-item{border:1px solid var(--line);border-radius:12px;padding:10px;background:#fafafa}.detail-item span{display:block;color:var(--muted);font-size:12px;margin-bottom:3px}.detail-item b{font-size:14px;word-break:break-word}.old-new{display:grid;grid-template-columns:1fr;gap:12px}
.badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:700}.badge-success{background:#dcfce7;color:#166534}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fee2e2;color:#991b1b}.badge-info{background:#cffafe;color:#155e75}.badge-muted{background:#f3f4f6;color:#4b5563}
.table-wrap{overflow:auto;background:#fff;border:1px solid var(--line);border-radius:14px}.table{width:100%;border-collapse:collapse;min-width:820px}.table th,.table td{padding:10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}.table th{background:#f8fafc;color:#374151;font-size:12px;text-transform:uppercase;letter-spacing:.03em}.table tr:last-child td{border-bottom:0}.muted{color:var(--muted)}.small{font-size:12px}.nowrap{white-space:nowrap}.login-wrap{max-width:420px;margin:45px auto}.login-logo{text-align:center;margin-bottom:16px}.login-logo h1{margin:0;font-size:25px}.login-logo p{margin:5px 0 0;color:var(--muted)}
.radio-card{display:grid;grid-template-columns:1fr;gap:8px}.radio-card label{display:flex;align-items:center;gap:9px;border:1px solid var(--line);background:#fff;border-radius:12px;padding:12px;font-weight:700}.radio-card input{width:18px;height:18px}.hide{display:none!important}.footer-actions{position:sticky;bottom:0;background:linear-gradient(180deg,rgba(245,247,251,.2),var(--bg));padding:10px 0 0;margin-top:10px}
@media(min-width:760px){.nav-toggle{display:none}.nav{display:flex;position:sticky;top:58px;box-shadow:none;gap:4px;overflow:auto}.nav a{display:inline-block}.container{padding:20px}.grid{grid-template-columns:repeat(4,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}.action-row{grid-template-columns:repeat(2,1fr)}.old-new{grid-template-columns:1fr 1fr}.detail-list{grid-template-columns:repeat(2,1fr)}}
.scan-actions{display:grid;grid-template-columns:1fr;gap:8px}
.scan-panel{margin-top:12px;border:1px dashed #cbd5e1;border-radius:14px;padding:10px;background:#f8fafc}
.barcode-reader{width:100%;max-width:540px;margin:0 auto;overflow:hidden;border-radius:12px;background:#111827;min-height:170px}
.barcode-reader video{border-radius:12px}.scan-panel:before{content:"Area scan barcode batang";display:block;text-align:center;font-size:12px;color:#64748b;margin-bottom:8px;font-weight:700}
@media(min-width:760px){.scan-actions{grid-template-columns:1fr 1fr 1fr}}
.barcode-stage{position:relative;width:100%;max-width:680px;margin:0 auto;min-height:230px;background:#111827;border-radius:14px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.barcode-video{width:100%;height:270px;object-fit:cover;background:#111827;display:block}
.barcode-reader-fallback{position:absolute;inset:0;width:100%;height:100%;z-index:1;opacity:0;pointer-events:none;background:#111827}
.barcode-reader-fallback video{width:100%!important;height:100%!important;object-fit:cover!important}
.barcode-reader-fallback div{border:0!important}
.scan-panel.scanner-fallback .barcode-reader-fallback{opacity:1;pointer-events:auto}
.scan-panel.scanner-fallback .barcode-video{display:none}
.scan-panel.scanner-native .barcode-reader-fallback{opacity:0;pointer-events:none}
.scan-panel.scanner-native .barcode-video{display:block}
.barcode-guide{position:absolute;z-index:3;left:5%;right:5%;top:50%;height:34%;transform:translateY(-50%);border:2px solid rgba(255,255,255,.92);border-radius:12px;box-shadow:0 0 0 999px rgba(0,0,0,.22);pointer-events:none}
.barcode-guide span{position:absolute;left:0;right:0;top:50%;height:2px;background:rgba(22,163,74,.95);box-shadow:0 0 12px rgba(22,163,74,.75)}
.photo-preview{display:block;max-width:220px;max-height:220px;border-radius:12px;border:1px solid var(--line);margin-top:10px;object-fit:cover;background:#f3f4f6}
input[type=file]{width:100%;border:1px dashed #cbd5e1;background:#f8fafc;border-radius:12px;padding:12px;font-size:14px}
button[disabled],.btn[disabled]{opacity:.65;cursor:not-allowed}
@media(max-width:520px){.barcode-video{height:240px}.barcode-stage{min-height:210px}.barcode-guide{left:4%;right:4%;height:30%}}
