*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html,body{color:#f0f0fa;background:#0c0c14;min-height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px}:root{--accent:#6366f1;--green:#838e8a;--red:#f43f5e;--amber:#f59e0b;--surface:#15151f;--surface2:#1d1d2a;--border:#2a2a3c;--muted:#6b6b8a}#root{min-height:100vh}.header{background:var(--surface);border-bottom:1px solid var(--border);z-index:20;justify-content:space-between;align-items:center;padding:16px 18px;display:flex;position:sticky;top:0}.logo-row{align-items:center;gap:10px;display:flex}.logo{background:var(--accent);border-radius:9px;place-items:center;width:32px;height:32px;font-size:10px;font-weight:700;display:grid}.app-title{font-size:16px;font-weight:700}.hdr-right{align-items:center;gap:8px;display:flex}.badge{background:var(--surface2);border:1px solid var(--border);color:var(--muted);border-radius:99px;padding:4px 11px;font-size:12px;font-weight:600}.screen{flex-direction:column;min-height:calc(100vh - 65px);display:none}.screen.active{display:flex}.setup-wrap{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:18px;padding:28px 24px;display:flex}.login-form{flex-direction:column;gap:12px;width:100%;max-width:460px;display:flex}.setup-title{text-align:center;letter-spacing:-.4px;font-size:22px;font-weight:700}.setup-sub{color:var(--muted);text-align:center;max-width:360px;font-size:13px;line-height:1.6}.api-input-wrap{width:100%;max-width:460px;position:relative}.api-input{background:var(--surface);border:1px solid var(--border);color:#f0f0fa;-webkit-appearance:none;letter-spacing:.5px;border-radius:12px;outline:none;width:100%;padding:14px 72px 14px 16px;font-family:ui-monospace,SF Mono,monospace;font-size:14px}.api-input:focus{border-color:var(--accent)}.api-input::placeholder{color:var(--muted);letter-spacing:0;font-family:-apple-system,sans-serif}.eye-btn{cursor:pointer;color:var(--muted);background:0 0;border:none;padding:4px;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.save-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:13px;width:100%;max-width:460px;padding:16px;font-size:15px;font-weight:700;transition:opacity .15s}.save-btn:active{opacity:.85}.api-err{color:#fb7185;text-align:center;font-size:12px}.scan-wrap{flex-direction:column;flex:1;gap:14px;width:100%;max-width:900px;margin:0 auto;padding:16px;display:flex}.shoot-btn{border:2px dashed var(--border);cursor:pointer;background:var(--surface);-webkit-appearance:none;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:10px;width:100%;min-height:150px;padding:0;transition:border-color .15s,background .15s;display:flex}.shoot-btn:active{background:var(--surface2);border-color:var(--accent)}.shoot-icon{background:var(--accent);border-radius:15px;place-items:center;width:52px;height:52px;font-size:12px;font-weight:700;display:grid}.shoot-label{color:#f0f0fa;font-size:16px;font-weight:700}.shoot-sub{color:var(--muted);font-size:12px}input[type=file]{opacity:0;width:1px;height:1px;position:absolute;left:-9999px}.gal-btn{border:1px solid var(--border);background:var(--surface2);width:100%;color:var(--muted);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;gap:8px;margin-top:10px;padding:13px;font-size:13px;font-weight:600;display:flex}.processing{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:12px;padding:24px 20px;display:none}.processing.show{display:flex}.proc-thumb{object-fit:contain;background:#000;border-radius:10px;width:100%;max-height:180px;display:block}.proc-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.proc-text{color:#a5b4fc;font-size:14px;font-weight:600}.proc-sub{color:var(--muted);font-size:12px}.result-flash{border-radius:14px;flex-direction:column;gap:10px;padding:16px;display:none}.result-flash.show{display:flex}.result-flash.ok{background:#10b9811a;border:1px solid #10b9814d}.result-flash.err{background:#f43f5e1a;border:1px solid #f43f5e4d}.result-flash.warn{background:#f59e0b1a;border:1px solid #f59e0b4d}.rf-head{align-items:center;gap:8px;margin-bottom:2px;font-size:13px;font-weight:700;display:flex}.rf-head.ok{color:#34d399}.rf-head.err{color:#fb7185}.rf-head.warn{color:#fbbf24}.rf-fields{flex-direction:column;gap:8px;display:flex}.rf-row{flex-direction:column;gap:2px;display:flex}.rf-lbl{letter-spacing:1px;color:var(--muted);text-transform:uppercase;font-size:9px;font-weight:700}.rf-val{color:#f0f0fa;word-break:break-all;font-family:ui-monospace,SF Mono,monospace;font-size:14px}.rf-src{color:var(--muted);margin-top:1px;font-size:10px}.rf-err-msg{color:#fb7185;font-size:13px;line-height:1.5}.section-hd{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.section-title{letter-spacing:1px;color:var(--muted);text-transform:uppercase;font-size:11px;font-weight:700}.tools{gap:8px;display:flex}.tool-btn{background:var(--surface2);border:1px solid var(--border);color:#f0f0fa;cursor:pointer;border-radius:8px;padding:6px 11px;font-size:11px;font-weight:700}.tool-btn.danger{color:var(--red);border-color:#f43f5e4d}.empty-box{text-align:center;color:var(--muted);border:1px dashed var(--border);border-radius:13px;padding:28px 16px;font-size:13px;line-height:1.7}.model-groups{gap:12px;display:grid}.model-card{border:1px solid var(--border);background:var(--surface);border-radius:13px;overflow:hidden}.model-card-head{color:#f0f0fa;letter-spacing:.4px;background:#1a1d2b;padding:10px 14px;font-size:12px;font-weight:700}.serial-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;padding:12px;display:grid}.serial-pill{border:1px solid var(--border);color:#d8dbef;background:#ffffff08;border-radius:9px;padding:7px 10px;font-size:12px;line-height:1.2}
