:root{
  --bg:#0a0c0f;--sf:#111318;--s2:#181c23;--s3:#252d3a;
  --bd:#252d3a;--ac:#c8ff3e;--a2:#3effc8;--a3:#ff7e3e;
  --tx:#e8ecf0;--dm:#6b7480;--md:#9aa3ad;
  --mild:#3effc8;--mod:#ffd93e;--sev:#ff4e3e;--r:14px;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
body{background:var(--bg);color:var(--tx);font-family:'DM Sans',sans-serif;font-size:15px;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body::before{content:'';position:fixed;inset:0;background-image:linear-gradient(rgba(200,255,62,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(200,255,62,.03) 1px,transparent 1px);background-size:48px 48px;pointer-events:none;z-index:0}
.wrap{position:relative;z-index:1;max-width:980px;margin:0 auto;padding:0 20px 80px}
header{display:flex;align-items:center;justify-content:space-between;padding:24px 0 28px;border-bottom:1px solid var(--bd);margin-bottom:36px}
.logo{display:flex;align-items:center;gap:12px}
.logo-icon{width:38px;height:38px;background:var(--ac);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px}
.logo-text{font-family:'Syne',sans-serif;font-weight:800;font-size:19px;letter-spacing:-.5px}
.logo-text span{color:var(--ac)}
.hdr-r{display:flex;align-items:center;gap:10px}
.badge{background:var(--s2);border:1px solid var(--bd);border-radius:20px;padding:5px 12px;font-size:11px;color:var(--dm);letter-spacing:.5px;text-transform:uppercase}
.mdot-wrap{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--dm)}
.mdot{width:7px;height:7px;border-radius:50%;background:var(--bd);transition:background .4s}
.mdot.loading{background:var(--mod);animation:pulse 1s ease infinite}
.mdot.ready{background:var(--mild)}
.mdot.err{background:var(--sev)}
.hero{margin-bottom:36px}
.hero h1{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(24px,5vw,44px);line-height:1.1;letter-spacing:-1.5px;margin-bottom:12px}
.hero h1 .hl{color:var(--ac)}
.hero p{color:var(--md);font-size:15px;font-weight:300;max-width:520px;line-height:1.65}
.steps{display:flex;margin-bottom:32px;background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);padding:4px}
.step{flex:1;display:flex;align-items:center;gap:9px;padding:11px 14px;border-radius:10px;transition:all .3s}
.step.active{background:var(--s2);border:1px solid var(--bd)}
.sn{width:24px;height:24px;border-radius:50%;background:var(--bd);display:flex;align-items:center;justify-content:center;font-size:10px;font-family:'Syne',sans-serif;font-weight:700;color:var(--dm);flex-shrink:0;transition:all .3s}
.step.active .sn{background:var(--ac);color:#000}
.step.done .sn{background:var(--a2);color:#000}
.sl{font-size:12px;font-weight:500;color:var(--dm);transition:all .3s}
.step.active .sl{color:var(--tx)}
.step.done .sl{color:var(--md)}
.panel{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);overflow:hidden;display:none}
.panel.visible{display:block;animation:fadeUp .35s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.ph{padding:18px 22px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:12px}
.ph .ico{width:30px;height:30px;background:var(--s2);border:1px solid var(--bd);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px}
.pt{font-family:'Syne',sans-serif;font-weight:700;font-size:15px;letter-spacing:-.3px}
.ps{font-size:12px;color:var(--dm);margin-top:2px}
.pb{padding:22px}

.cam-area{position:relative;background:var(--s2);border:2px dashed var(--bd);border-radius:12px;overflow:hidden;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;transition:border-color .3s}
.cam-area.live{border-color:var(--ac);border-style:solid}
.cam-area.captured{border-color:var(--a2);border-style:solid}
.cam-area.bad{border-color:var(--sev);border-style:solid}
#vid,#prev{width:100%;height:100%;object-fit:cover;display:none}
#vid.show,#prev.show{display:block}
.cam-ph{text-align:center;padding:36px 20px;pointer-events:none}
.cam-ph .big{font-size:44px;margin-bottom:14px;display:block}
.cam-ph p{color:var(--md);font-size:14px;margin-bottom:6px}
.cam-ph small{color:var(--dm);font-size:12px}

.q-badge{position:absolute;bottom:10px;left:10px;z-index:10;background:rgba(0,0,0,.7);border-radius:8px;padding:5px 9px;font-size:11px;display:none;align-items:center;gap:5px}
.q-badge.show{display:flex}
.qdot{width:6px;height:6px;border-radius:50%}
.guide{position:absolute;inset:0;pointer-events:none;display:none;z-index:5}
.guide.show{display:block}
.g-rect{position:absolute;top:50%;left:50%;width:60%;aspect-ratio:3/4;transform:translate(-50%,-50%);border:2px solid rgba(200,255,62,.5);border-radius:12px}
.g-rect::after{content:'Posisikan area kulit di sini';position:absolute;bottom:-24px;left:50%;transform:translateX(-50%);font-size:10px;color:rgba(200,255,62,.7);white-space:nowrap;font-family:'DM Sans',sans-serif}
.corner{position:absolute;width:18px;height:18px;border-color:var(--ac);border-style:solid}
.corner.tl{top:10px;left:10px;border-width:2px 0 0 2px}
.corner.tr{top:10px;right:10px;border-width:2px 2px 0 0}
.corner.bl{bottom:10px;left:10px;border-width:0 0 2px 2px}
.corner.br{bottom:10px;right:10px;border-width:0 2px 2px 0}
.scan-l{position:absolute;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--ac),transparent);animation:scanMove 2.5s linear infinite;box-shadow:0 0 10px var(--ac);display:none}
.scan-l.show{display:block}
@keyframes scanMove{0%{top:0;opacity:0}10%{opacity:1}90%{opacity:1}100%{top:100%;opacity:0}}
.cam-info{display:none;margin-top:8px;padding:8px 12px;background:var(--s2);border:1px solid var(--bd);border-radius:9px;font-size:12px;color:var(--dm)}
.controls{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:13px 18px;border-radius:10px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none;outline:none;user-select:none}
.btn:disabled{opacity:.38;cursor:not-allowed;transform:none!important}
.btn:active:not(:disabled){transform:scale(.97)}
.btn-p{background:var(--ac);color:#000}
.btn-p:hover:not(:disabled){background:#d4ff5a;transform:translateY(-1px);box-shadow:0 8px 24px rgba(200,255,62,.25)}
.btn-s{background:var(--s2);color:var(--tx);border:1px solid var(--bd)}
.btn-s:hover:not(:disabled){background:var(--bd);transform:translateY(-1px)}
.btn-a2{background:var(--a2);color:#000}
.btn-a2:hover:not(:disabled){background:#5cffe0;transform:translateY(-1px);box-shadow:0 8px 24px rgba(62,255,200,.25)}
.btn-full{grid-column:1/-1}
.bsel{margin-top:18px}
.bsel>label{display:block;font-size:11px;font-weight:500;color:var(--dm);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px}
.chips{display:flex;gap:7px;flex-wrap:wrap}
.chip{padding:7px 13px;border-radius:20px;background:var(--s2);border:1px solid var(--bd);color:var(--md);font-size:13px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:5px}
.chip:hover{border-color:var(--ac);color:var(--tx)}
.chip.sel{background:rgba(200,255,62,.1);border-color:var(--ac);color:var(--ac)}

#ld-panel{padding:56px 22px;text-align:center}
.sp-wrap{margin-bottom:26px;display:inline-block;position:relative}
.sp{width:60px;height:60px;border-radius:50%;border:3px solid var(--bd);border-top-color:var(--ac);animation:spin 1s linear infinite}
.sp-in{position:absolute;top:8px;left:8px;right:8px;bottom:8px;border-radius:50%;border:2px solid var(--bd);border-bottom-color:var(--a2);animation:spin .7s linear infinite reverse}
@keyframes spin{to{transform:rotate(360deg)}}
.ld-t{font-family:'Syne',sans-serif;font-weight:700;font-size:19px;margin-bottom:7px}
.ld-s{color:var(--dm);font-size:13px;margin-bottom:22px;min-height:20px}
.pg-w{background:var(--s2);border-radius:4px;height:4px;max-width:300px;margin:0 auto;overflow:hidden}
.pg{height:100%;background:linear-gradient(90deg,var(--ac),var(--a2));border-radius:4px;transition:width .5s ease;width:0%}
.ld-steps{margin-top:18px;display:flex;flex-direction:column;gap:7px;max-width:300px;margin-left:auto;margin-right:auto}
.lst{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--dm);text-align:left}
.lst .dot{width:6px;height:6px;border-radius:50%;background:var(--bd);flex-shrink:0;transition:all .3s}
.lst.done .dot{background:var(--ac)}
.lst.active .dot{background:var(--ac);box-shadow:0 0 8px var(--ac);animation:pulse 1s ease infinite}
.rg{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:22px}
.rc{background:var(--s2);border:1px solid var(--bd);border-radius:12px;padding:18px;position:relative;overflow:hidden}
.rc::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.rc.mild::before{background:var(--mild)}.rc.moderate::before{background:var(--mod)}.rc.severe::before{background:var(--sev)}.rc.info::before{background:var(--ac)}
.rl{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:1px;color:var(--dm);margin-bottom:7px}
.rv{font-family:'Syne',sans-serif;font-weight:800;font-size:26px;letter-spacing:-1px;line-height:1}
.rv.mild{color:var(--mild)}.rv.moderate{color:var(--mod)}.rv.severe{color:var(--sev)}.rv.info{color:var(--ac)}
.rd{font-size:12px;color:var(--dm);margin-top:5px;line-height:1.5}
.sv-sec{background:var(--s2);border:1px solid var(--bd);border-radius:12px;padding:18px;margin-bottom:22px}
.sv-l{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.8px;color:var(--dm);margin-bottom:13px}
.sv-bw{height:10px;background:var(--bd);border-radius:10px;overflow:hidden;margin-bottom:8px}
.sv-b{height:100%;border-radius:10px;transition:width 1.3s cubic-bezier(.16,1,.3,1);width:0%}
.sv-tk{display:flex;justify-content:space-between;font-size:10px;color:var(--dm)}
.vs-sec{margin-bottom:22px}
.vs-l{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.8px;color:var(--dm);margin-bottom:11px}
.cv-w{border-radius:12px;overflow:hidden;background:var(--s2);border:1px solid var(--bd)}
#vc{width:100%;display:block}
.leg{display:flex;gap:14px;margin-top:9px;flex-wrap:wrap}
.leg-i{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--md)}
.leg-d{width:9px;height:9px;border-radius:3px}
.rc-sec{background:var(--s2);border:1px solid var(--bd);border-radius:12px;overflow:hidden;margin-bottom:22px}
.rc-h{padding:15px 18px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:9px;font-family:'Syne',sans-serif;font-weight:700;font-size:15px}
.ri{padding:13px 18px;display:flex;gap:13px;align-items:flex-start;border-bottom:1px solid var(--bd);animation:fadeUp .4s ease forwards;opacity:0}
.ri:last-child{border-bottom:none}
.ri-ico{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;margin-top:1px}
.ri-ico.g{background:rgba(62,255,200,.12)}.ri-ico.y{background:rgba(255,217,62,.12)}.ri-ico.o{background:rgba(255,126,62,.12)}.ri-ico.b{background:rgba(62,150,255,.12)}
.ri-tx h4{font-size:14px;font-weight:500;margin-bottom:3px}
.ri-tx p{font-size:12px;color:var(--dm);line-height:1.6}
.disc{padding:14px 18px;background:rgba(255,126,62,.06);border:1px solid rgba(255,126,62,.2);border-radius:10px;font-size:12px;color:var(--dm);line-height:1.6;display:flex;gap:9px;align-items:flex-start;margin-bottom:18px}
.disc .wi{flex-shrink:0;font-size:14px;margin-top:1px}
.act-r{display:grid;grid-template-columns:1fr 1fr;gap:10px}
#ep{padding:48px 22px;text-align:center}
.e-ico{font-size:44px;margin-bottom:16px;display:block}
.e-t{font-family:'Syne',sans-serif;font-weight:700;font-size:18px;margin-bottom:8px;color:var(--sev)}
.e-m{color:var(--dm);font-size:13px;line-height:1.6;max-width:380px;margin:0 auto 24px}
.toast{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom,0px));left:50%;transform:translateX(-50%) translateY(80px);background:var(--s2);border:1px solid var(--bd);border-radius:10px;padding:11px 18px;font-size:13px;z-index:9999;transition:transform .3s cubic-bezier(.16,1,.3,1);white-space:nowrap;box-shadow:0 8px 32px rgba(0,0,0,.5)}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.ok{border-color:rgba(62,255,200,.35)}.toast.warn{border-color:rgba(255,217,62,.35)}.toast.fail{border-color:rgba(255,78,62,.35)}
@media(max-width:600px){.rg{grid-template-columns:1fr}.controls{grid-template-columns:1fr}.act-r{grid-template-columns:1fr}.steps{display:none}header{padding:16px 0 20px}.hero{margin-bottom:24px}.badge{display:none}}
@media(max-width:380px){.hero h1{font-size:22px}.pb{padding:16px}}