*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0a;--surface:#111;--border:#1e1e1e;--accent:#e8e8e8;--muted:#444;--text:#f0f0f0;--subtext:#888;--green:#4ade80;--radius:12px}body{background:var(--bg);color:var(--text);flex-direction:column;align-items:center;min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;display:flex}header{flex-direction:column;align-items:center;gap:24px;width:100%;max-width:480px;padding:32px 20px 0;display:flex}.wordmark{letter-spacing:-.5px;color:var(--text);align-items:center;gap:10px;font-size:22px;font-weight:700;display:flex}.wordmark img{width:28px;height:28px;display:block}.wordmark span{color:var(--subtext)}.tabs{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);gap:4px;width:100%;padding:4px;display:flex}.tab-btn{color:var(--subtext);cursor:pointer;letter-spacing:.01em;background:0 0;border:none;border-radius:9px;flex:1;padding:10px;font-size:14px;font-weight:500;transition:all .18s}.tab-btn.active{background:var(--accent);color:#0a0a0a}main{flex:1;width:100%;max-width:480px;padding:20px}.panel{display:none}.panel.active{flex-direction:column;gap:16px;display:flex}.camera-wrap{aspect-ratio:1;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);width:100%;position:relative;overflow:hidden}#video{object-fit:cover;width:100%;height:100%;display:block}#scan-canvas{display:none}.scan-overlay{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.scan-frame{aspect-ratio:1;width:56%;position:relative}.scan-frame:before,.scan-frame:after,.scan-frame>span:before,.scan-frame>span:after{content:"";border-color:var(--text);border-style:solid;border-width:0;width:20px;height:20px;position:absolute}.scan-frame:before{border-top-width:2px;border-left-width:2px;border-radius:3px 0 0;top:0;left:0}.scan-frame:after{border-top-width:2px;border-right-width:2px;border-radius:0 3px 0 0;top:0;right:0}.scan-frame>span:before{border-bottom-width:2px;border-left-width:2px;border-radius:0 0 0 3px;bottom:0;left:0}.scan-frame>span:after{border-bottom-width:2px;border-right-width:2px;border-radius:0 0 3px;bottom:0;right:0}.scan-line{background:linear-gradient(90deg, transparent, var(--green), transparent);height:1.5px;animation:2s ease-in-out infinite sweep;position:absolute;top:0;left:0;right:0}@keyframes sweep{0%{opacity:0;top:0%}10%{opacity:1}90%{opacity:1}to{opacity:0;top:100%}}.cam-idle{flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex;position:absolute;inset:0}.cam-idle svg{opacity:.3}.cam-idle p{color:var(--subtext);font-size:13px}.result-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:6px;min-height:72px;padding:16px;display:flex}.result-label{text-transform:uppercase;letter-spacing:.08em;color:var(--subtext);font-size:11px}.result-value{color:var(--text);word-break:break-all;font-size:15px;line-height:1.5}.result-value.empty{color:var(--muted);font-size:14px}.result-actions{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;transition:opacity .15s;display:inline-flex}.btn:hover{opacity:.85}.btn-primary{background:var(--accent);color:#0a0a0a;border-radius:var(--radius);justify-content:center;width:100%;padding:13px;font-size:14px}.btn-ghost{background:var(--surface);color:var(--subtext);border:1px solid var(--border)}.btn-ghost:hover{color:var(--text)}.badge-success{color:var(--green);background:#4ade8014;border-radius:99px;align-items:center;gap:5px;width:fit-content;padding:3px 8px;font-size:11px;display:inline-flex}.badge-success:before{content:"";background:var(--green);border-radius:50%;width:6px;height:6px;display:block}.file-drop-zone{background:var(--surface);border:1.5px dashed var(--border);border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:40px 20px;transition:border-color .15s,background .15s;display:flex}.file-drop-zone:hover,.file-drop-zone.drag-over{background:#161616;border-color:#444}.file-drop-zone svg{opacity:.35}.file-drop-zone p{color:var(--subtext);text-align:center;font-size:14px}.link-like{color:var(--text);text-underline-offset:2px;text-decoration:underline}.file-info{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:6px;padding:14px 16px;display:flex}.file-info-row{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.file-info-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:260px;font-size:14px;overflow:hidden}.file-info-size{color:var(--subtext);flex-shrink:0;font-size:12px}.chunk-info{color:var(--subtext);font-size:12px}.compress-progress-wrap{background:var(--border);border-radius:99px;height:3px;margin-top:2px;overflow:hidden}.compress-progress-bar{background:var(--text);height:100%;width:var(--progress,0%);border-radius:99px;transition:width 80ms linear}.compress-progress-bar.finishing{transition:width .5s cubic-bezier(.22,1,.36,1)}.discard-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:13px;line-height:1;transition:color .15s}.discard-btn:hover{color:var(--text)}.btn-primary:disabled{opacity:.35;cursor:not-allowed}.qr-overlay{background:var(--bg);z-index:10000;flex-direction:column;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.qr-overlay.visible{display:flex}#qr-canvas{image-rendering:pixelated;flex-shrink:0;display:block}.cam-preview-wrap{cursor:pointer;border-radius:8px;flex-shrink:0;position:relative;overflow:hidden}.cam-preview-mask{background:var(--surface);color:var(--subtext);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-size:12px;display:none;position:absolute;inset:0}.cam-preview-wrap.hidden video{visibility:hidden}.cam-preview-wrap.hidden .cam-preview-mask{display:flex}.qr-overlay-footer{background:linear-gradient(to top, var(--bg) 65%, transparent);flex-direction:column;gap:12px;padding:16px 24px 28px;display:flex;position:fixed;bottom:0;left:0;right:0}.qr-overlay-info{flex-direction:row;justify-content:space-between;align-items:baseline;display:flex}.qr-overlay-label-group{flex-direction:column;gap:2px;min-width:0;display:flex}.qr-overlay-label{text-transform:uppercase;letter-spacing:.1em;color:var(--subtext);font-size:10px}.qr-overlay-filename{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.qr-overlay-frame{color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-1px;flex-shrink:0;font-size:26px;font-weight:700}.cam-preview{background:var(--surface);width:100%;height:auto;display:block}.qr-progress-wrap{background:var(--border);border-radius:99px;height:3px;overflow:hidden}.qr-progress-bar{background:var(--text);height:100%;width:var(--progress,0%);border-radius:99px;transition:width .2s linear}.qr-info-sub{color:var(--subtext);font-variant-numeric:tabular-nums;min-height:16px;font-size:12px}.qr-stop-btn{border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text);cursor:pointer;border:1px solid var(--border);padding:13px;font-size:15px;font-weight:500;transition:background .15s}.qr-stop-btn:hover{background:#1a1a1a}@media (orientation:landscape){.qr-overlay{flex-direction:row;justify-content:flex-start;align-items:stretch}.qr-overlay-footer{background:0 0;flex-direction:column;flex:1;justify-content:center;gap:20px;padding:32px 28px;position:static}.qr-overlay-info{flex-direction:column;align-items:flex-start;gap:4px}.qr-overlay-filename{font-size:16px}.qr-overlay-frame{letter-spacing:-1.5px;font-size:36px}.qr-progress-wrap{height:4px}}.ack-progress-bar{background:var(--green)!important}.toast{background:var(--text);color:var(--bg);opacity:0;pointer-events:none;white-space:nowrap;z-index:100;border-radius:99px;padding:10px 18px;font-size:13px;font-weight:500;transition:opacity .2s,transform .2s;position:fixed;bottom:24px;left:50%;transform:translate(-50%)translateY(12px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}
