:root{--bg: #f6f7fb;--bg-grad: radial-gradient(1200px 600px at 80% -10%, #eef0ff 0%, transparent 60%), radial-gradient(900px 500px at -10% 0%, #f3ecff 0%, transparent 55%);--surface: #ffffff;--surface-2: #fbfbfd;--border: #e7e8ee;--border-strong: #d7d9e3;--text: #14172a;--muted: #6b7185;--muted-2: #9aa0b2;--accent: #5b5bd6;--accent-2: #8b5cf6;--accent-soft: #eef0fc;--green: #15a05a;--green-soft: #e7f6ee;--red: #dc2b3d;--red-soft: #fcebed;--amber: #c97a12;--amber-soft: #fdf2e1;--radius: 16px;--radius-sm: 10px;--shadow-sm: 0 1px 2px rgba(20, 23, 42, .04), 0 1px 3px rgba(20, 23, 42, .06);--shadow-md: 0 10px 30px -12px rgba(20, 23, 42, .18);--mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);background:var(--bg);background-image:var(--bg-grad);background-attachment:fixed;-webkit-font-smoothing:antialiased}code{font-family:var(--mono);font-size:.85em;background:var(--accent-soft);color:#4646b8;padding:1px 6px;border-radius:6px}.mono{font-family:var(--mono)}.muted{color:var(--muted)}.app{min-height:100%;display:flex;flex-direction:column}.container{width:100%;max-width:1080px;margin:0 auto;padding:0 24px}.header{position:sticky;top:0;z-index:20;background:#ffffffc7;-webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:66px}.brand{display:flex;align-items:center;gap:12px}.logo{filter:drop-shadow(0 4px 10px rgba(99,102,241,.35))}.brand-text{display:flex;flex-direction:column;line-height:1.1}.brand-name{font-weight:800;font-size:18px;letter-spacing:-.01em}.brand-sub{font-size:12.5px;color:var(--muted);font-weight:500}.status{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--muted)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--muted-2)}.status-ok{color:#0f7a44;border-color:#cdeedd;background:var(--green-soft)}.status-ok .status-dot{background:var(--green);box-shadow:0 0 0 3px #15a05a2e}.status-warn{color:var(--amber);border-color:#f3e2c4;background:var(--amber-soft)}.status-warn .status-dot{background:var(--amber)}.tool,.tabs{margin-top:26px}.tabs{display:flex;gap:6px;padding:5px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-sm);overflow-x:auto}.tab{flex:1 0 auto;border:none;background:transparent;color:var(--muted);font:inherit;font-weight:600;font-size:14px;padding:10px 16px;border-radius:10px;cursor:pointer;white-space:nowrap;transition:all .15s ease}.tab:hover{color:var(--text);background:var(--surface-2)}.tab.is-active{color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 6px 16px -6px #5b5bd699}.tool-head h2{margin:0 0 4px;font-size:22px;letter-spacing:-.02em}.tool-head p{margin:0 0 18px;color:var(--muted);font-size:14.5px}.tool-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}@media (max-width: 860px){.tool-grid{grid-template-columns:1fr}}.panel,.result{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.panel{padding:20px;display:flex;flex-direction:column;gap:16px}.panel-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width: 520px){.panel-row{grid-template-columns:1fr}}.panel-note{margin:0;font-size:12.5px;color:var(--muted);line-height:1.5}.dz-wrap{display:flex;flex-direction:column;gap:8px}.dz-label{font-size:13px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}.dz-optional{font-size:11px;font-weight:600;color:var(--muted-2);background:var(--surface-2);border:1px solid var(--border);padding:1px 7px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}.dropzone{position:relative;display:block;border:1.5px dashed var(--border-strong);border-radius:var(--radius-sm);background:var(--surface-2);min-height:168px;cursor:pointer;transition:border-color .15s,background .15s;overflow:hidden}.dropzone:hover{border-color:var(--accent)}.dropzone.is-drag{border-color:var(--accent);background:var(--accent-soft)}.dropzone.has-file{border-style:solid;border-color:var(--border)}.dz-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);padding:16px;text-align:center}.dz-cta{font-size:13.5px;font-weight:500}.dz-hint{font-size:11.5px;color:var(--muted-2)}.dz-preview{display:block;width:100%;height:168px;object-fit:contain;background:#0e1020}.dz-filename{position:absolute;left:0;right:0;bottom:0;font-size:11.5px;color:#fff;background:linear-gradient(transparent,#000000b3);padding:14px 10px 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dz-clear{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:50%;border:none;background:#0f10209e;color:#fff;cursor:pointer;font-size:12px;line-height:1;z-index:2}.dz-clear:hover{background:var(--red)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:none;border-radius:11px;padding:12px 18px;font:inherit;font-weight:650;font-size:14.5px;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-2));cursor:pointer;box-shadow:0 8px 20px -8px #5b5bd6b3;transition:transform .08s ease,box-shadow .15s,filter .15s}.btn-primary:hover:not(:disabled){filter:brightness(1.05)}.btn-primary:active:not(:disabled){transform:translateY(1px)}.btn-primary:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.result{min-height:280px;display:flex;flex-direction:column}.result-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.result-title{font-weight:650;font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.result-meta{display:flex;align-items:center;gap:10px}.latency{font-family:var(--mono);font-size:12px;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);padding:2px 8px;border-radius:6px}.toggle{border:1px solid var(--border);background:var(--surface);color:var(--muted);font:inherit;font-size:12px;font-weight:600;padding:4px 10px;border-radius:7px;cursor:pointer}.toggle:hover{color:var(--text);border-color:var(--border-strong)}.result-body{flex:1;padding:18px;overflow:auto}.result-placeholder{height:100%;min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--muted);font-size:14px}.result-summary{font-size:14px;color:var(--muted);margin-bottom:14px}.result-summary strong{color:var(--text);font-size:16px}.alert{display:flex;flex-direction:column;gap:4px;background:var(--red-soft);border:1px solid #f4c9ce;color:#a11423;padding:14px 16px;border-radius:var(--radius-sm);font-size:13.5px}.alert strong{font-size:13px;text-transform:uppercase;letter-spacing:.04em}.json{position:relative}.json pre{margin:0;font-family:var(--mono);font-size:12.5px;line-height:1.6;color:#2b2f45;background:#0e1020;color:#d6d9f0;padding:16px;border-radius:var(--radius-sm);overflow:auto}.json-copy{position:absolute;top:10px;right:10px;border:1px solid rgba(255,255,255,.16);background:#ffffff14;color:#cfd3ee;font:inherit;font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:7px;cursor:pointer}.json-copy:hover{background:#ffffff29}.ocr-table{width:100%;border-collapse:collapse;font-size:13.5px}.ocr-table td{padding:9px 10px;border-bottom:1px solid var(--border);vertical-align:top}.ocr-table tr:last-child td{border-bottom:none}.ocr-key{width:38%;color:var(--muted);font-weight:500}.ocr-val{color:var(--text);font-weight:500;word-break:break-word}.ocr-table.nested{border:1px solid var(--border);border-radius:8px;margin-top:4px}.ocr-img{max-width:160px;max-height:110px;border-radius:8px;border:1px solid var(--border);background:#0e1020}.liveness-result,.match-result{display:flex;flex-direction:column;gap:16px}.bbox{position:relative;border-radius:var(--radius-sm);overflow:hidden;background:#0e1020;line-height:0}.bbox img{width:100%;display:block}.bbox-rect{position:absolute;border:2.5px solid var(--green);border-radius:4px;box-shadow:0 0 0 9999px #0000000a}.bbox-rect.tone-bad{border-color:var(--red)}.bbox-tag{position:absolute;top:-22px;left:-2px;font-family:var(--mono);font-size:11px;font-weight:600;color:#fff;background:var(--green);padding:1px 6px;border-radius:5px;line-height:1.5}.bbox-rect.tone-bad .bbox-tag{background:var(--red)}.face-card{border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;background:var(--surface-2)}.face-card-head{display:flex;align-items:center;justify-content:space-between;font-weight:600;font-size:14px;margin-bottom:12px}.metric{display:flex;flex-direction:column;gap:7px}.metric-row{display:flex;justify-content:space-between;font-size:13px;color:var(--muted)}.metric-row .mono{color:var(--text)}.model-scores{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.chip{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:11.5px;border:1px solid var(--border);background:var(--surface);border-radius:7px;padding:3px 8px}.chip-k{color:var(--muted-2)}.chip-v{color:var(--text);font-weight:500}.scorebar{height:9px;border-radius:999px;background:#edeef4;overflow:hidden}.scorebar-fill{height:100%;border-radius:999px;transition:width .4s cubic-bezier(.2,.7,.2,1)}.tone-ok{background:linear-gradient(90deg,#1bb568,var(--green))}.tone-bad{background:linear-gradient(90deg,#f0566a,var(--red))}.tone-warn{background:linear-gradient(90deg,#e8a24a,var(--amber))}.match-verdict{display:flex;flex-direction:column;align-items:center;gap:12px;padding:26px;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border)}.match-verdict.is-match{background:var(--green-soft);border-color:#cdeedd}.match-verdict.no-match{background:var(--red-soft);border-color:#f4c9ce}.match-score{font-size:44px;font-weight:800;letter-spacing:-.03em}.pill{display:inline-flex;align-items:center;font-size:11.5px;font-weight:700;letter-spacing:.05em;padding:4px 11px;border-radius:999px}.pill-ok{color:#0f7a44;background:var(--green-soft);border:1px solid #cdeedd}.pill-bad{color:#a11423;background:var(--red-soft);border:1px solid #f4c9ce}.pill-warn{color:var(--amber);background:var(--amber-soft);border:1px solid #f3e2c4}.pill-neutral{color:var(--muted);background:var(--surface-2);border:1px solid var(--border)}.spinner{display:inline-block;border:2.5px solid rgba(120,120,160,.25);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.btn-primary .spinner{border-color:#fff6;border-top-color:#fff}@keyframes spin{to{transform:rotate(360deg)}}.footer{margin-top:48px;padding:22px 0;border-top:1px solid var(--border)}.footer .container{display:flex;justify-content:space-between;font-size:13px;color:var(--muted)}
