*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --blue:#185FA5; --blue-lt:#E6F1FB; --green:#3B6D11; --green-lt:#EAF3DE;
  --amber:#BA7517; --amber-lt:#FAEEDA; --red:#A32D2D; --red-lt:#FCEBEB;
  --gray-lt:#F1EFE8; --text:#1a1a18; --muted:#666; --bg:#f4f3ef;
  --surface:#ffffff; --border:rgba(0,0,0,0.11); --radius:12px; --radius-s:8px;
}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:15px;overscroll-behavior:none;-webkit-tap-highlight-color:transparent}
#app{max-width:480px;margin:0 auto;padding-bottom:100px}

.header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}
.logo{width:36px;height:36px;background:var(--blue);border-radius:var(--radius-s);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.header-text{flex:1;min-width:0}
.header-text h1{font-size:14px;font-weight:600}
.header-text p{font-size:11px;color:var(--muted)}
.header-badge{background:var(--blue);color:#fff;border-radius:20px;padding:3px 10px;text-align:center;flex-shrink:0;transition:transform .2s}
.header-badge span{font-size:16px;font-weight:700;display:block;line-height:1.1}
.header-badge small{font-size:10px;opacity:.8}
.header-badge.badge-pulse{animation:badgePulse .5s ease}
@keyframes badgePulse{0%{transform:scale(1)}40%{transform:scale(1.45);background:var(--green)}100%{transform:scale(1)}}

.scanner-section{padding:12px 16px 0}
.scanner-wrap{position:relative;width:100%;aspect-ratio:1/1;background:#111;border-radius:var(--radius);overflow:hidden}
#video{width:100%;height:100%;object-fit:cover;display:block}

.viewfinder{position:absolute;inset:0;pointer-events:none}
.viewfinder::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.4);clip-path:polygon(0% 0%,100% 0%,100% 100%,0% 100%,0% 0%,18% 18%,18% 82%,82% 82%,82% 18%,18% 18%)}
.vf-corner{position:absolute;width:24px;height:24px;border-color:#fff;border-style:solid}
.vf-corner.tl{top:calc(18% - 1px);left:calc(18% - 1px);border-width:3px 0 0 3px;border-radius:4px 0 0 0}
.vf-corner.tr{top:calc(18% - 1px);right:calc(18% - 1px);border-width:3px 3px 0 0;border-radius:0 4px 0 0}
.vf-corner.bl{bottom:calc(18% - 1px);left:calc(18% - 1px);border-width:0 0 3px 3px;border-radius:0 0 0 4px}
.vf-corner.br{bottom:calc(18% - 1px);right:calc(18% - 1px);border-width:0 3px 3px 0;border-radius:0 0 4px 0}
.scan-line{position:absolute;left:19%;right:19%;height:2px;background:linear-gradient(90deg,transparent,#4af 40%,#4af 60%,transparent);animation:scanline 1.8s ease-in-out infinite}
@keyframes scanline{0%,100%{top:20%;opacity:.3}50%{top:78%;opacity:1}}
.scanner-hint{position:absolute;bottom:12px;left:0;right:0;text-align:center;color:rgba(255,255,255,.75);font-size:12px;pointer-events:none}

.success-flash{position:absolute;inset:0;background:rgba(59,109,17,.5);display:flex;align-items:center;justify-content:center;animation:fadeIn .25s ease}
.success-icon{width:64px;height:64px;background:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

.status-bar{display:flex;align-items:center;gap:8px;margin-top:10px;padding:9px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-s);font-size:13px}
.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:#ccc}
.status-dot.scanning{background:var(--blue);animation:pulse 1.4s ease-in-out infinite}
.status-dot.detected{background:var(--green)}
.status-dot.fetching{background:var(--amber);animation:pulse 1s ease-in-out infinite}
.status-dot.error{background:var(--red)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}

.action-row{display:flex;gap:8px;padding:10px 16px}
.btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 12px;border-radius:var(--radius-s);font-size:13px;font-weight:500;border:none;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap}
.btn:active{transform:scale(.97)}
.btn:disabled{opacity:.38;cursor:not-allowed}
.btn-primary{background:var(--blue);color:#fff}
.btn-success{background:var(--green);color:#fff}
.btn-outline{background:var(--surface);color:var(--text);border:1px solid var(--border);flex:none;padding:11px 14px}
.btn-sm{flex:none;padding:8px 14px;font-size:12px}

.progress-panel{margin:0 16px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.progress-header{display:flex;justify-content:space-between;font-size:13px;font-weight:600;margin-bottom:10px}
.progress-track{background:var(--gray-lt);border-radius:20px;height:8px;overflow:hidden;margin-bottom:6px}
.progress-fill{height:100%;border-radius:20px;background:var(--blue);transition:width .5s ease}
.progress-meta{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:12px}
.prog-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.pstat{background:var(--gray-lt);border-radius:var(--radius-s);padding:8px;text-align:center}
.pstat-n{font-size:20px;font-weight:600}
.pstat-n.green{color:var(--green)}
.pstat-n.amber{color:var(--amber)}
.pstat-l{font-size:11px;color:var(--muted)}

.section-title{display:flex;justify-content:space-between;align-items:center;padding:0 16px;margin-bottom:8px;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.clear-btn{background:none;border:none;font-size:12px;color:var(--red);cursor:pointer;padding:2px 6px;border-radius:4px}
.clear-btn:hover{background:var(--red-lt)}
#docList{display:flex;flex-direction:column;gap:8px;padding:0 16px}

.doc-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.doc-card-head{display:flex;align-items:center;justify-content:space-between;padding:10px 13px;border-bottom:1px solid var(--border)}
.doc-idx{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.doc-head-right{display:flex;align-items:center;gap:6px}
.badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;padding:2px 8px;border-radius:20px}
.badge-done{background:var(--green-lt);color:var(--green)}
.badge-fetch{background:var(--amber-lt);color:var(--amber)}
.badge-error{background:var(--red-lt);color:var(--red)}
.del-btn{width:24px;height:24px;border:none;background:none;cursor:pointer;color:var(--muted);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:15px}
.del-btn:hover{background:var(--red-lt);color:var(--red)}

.doc-card-body{padding:11px 13px}
.doc-faktur-no{font-size:14px;font-weight:700;color:var(--blue);margin-bottom:8px}
.doc-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:8px}
.doc-field .lbl{font-size:10px;color:var(--muted);margin-bottom:1px}
.doc-field .val{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.doc-amounts{display:flex;gap:12px;padding:8px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:8px}
.doc-amount .lbl{font-size:10px;color:var(--muted)}
.doc-amount .val{font-size:13px;font-weight:600}
.doc-amount .val.dpp{color:var(--blue)}
.doc-amount .val.ppn{color:var(--green)}
.doc-items-title{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.doc-item-row{display:flex;justify-content:space-between;align-items:baseline;padding:3px 0;border-bottom:1px solid var(--gray-lt);font-size:12px;gap:8px}
.doc-item-row:last-child{border-bottom:none}
.doc-item-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.doc-item-meta{flex-shrink:0;color:var(--muted);font-size:11px;text-align:right}
.doc-loading{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);padding:4px 0}
.doc-url{margin-top:8px;font-size:10px;color:#bbb;word-break:break-all;padding:5px 7px;background:var(--gray-lt);border-radius:5px}

.spinner{width:13px;height:13px;border:2px solid var(--amber-lt);border-top-color:var(--amber);border-radius:50%;animation:spin .65s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}

.empty-state{text-align:center;padding:40px 20px;color:var(--muted)}
.empty-icon{width:64px;height:64px;margin:0 auto 14px;background:var(--gray-lt);border-radius:50%;display:flex;align-items:center;justify-content:center}
.empty-state p{font-size:14px;line-height:1.65}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#1a1a18;color:#fff;padding:10px 18px;border-radius:20px;font-size:13px;z-index:100;white-space:nowrap;animation:toastIn .2s ease}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(8px)}}

.install-banner{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:12px 16px;display:flex;align-items:center;gap:12px;z-index:50}
.install-banner>div{flex:1}
.install-banner strong{font-size:14px;display:block}
.install-banner p{font-size:12px;color:var(--muted)}
.install-close{background:none;border:none;cursor:pointer;font-size:18px;color:var(--muted);padding:4px}

/* Duplicate modal */
.dup-modal{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease}
.dup-modal-box{background:var(--surface);border-radius:var(--radius);padding:28px 24px;max-width:280px;width:90%;text-align:center}
.dup-icon{width:56px;height:56px;background:var(--amber-lt);color:var(--amber);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.dup-title{font-size:16px;font-weight:600;margin-bottom:8px}
.dup-msg{font-size:13px;color:var(--muted);margin-bottom:20px;line-height:1.5}
.dup-btn{background:var(--blue);color:#fff;border:none;border-radius:var(--radius-s);padding:10px 32px;font-size:14px;font-weight:500;cursor:pointer}