:root{font-family:Inter,Hiragino Sans,Hiragino Kaku Gothic ProN,Yu Gothic,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#182026;background:#f5f7f8;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--line: #d9e1e7;--panel: #ffffff;--ink: #182026;--muted: #64748b;--blue: #2563eb;--blue-weak: #dbeafe;--teal: #0f766e;--teal-strong: #0b5f59;--amber: #f59e0b;--danger: #b42318;--surface: #f8fafc}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0}button,textarea,select,input{font:inherit}button{border:0}.jsl-app{display:grid;grid-template-rows:64px 1fr;width:100%;height:100%;overflow:hidden;background:var(--surface)}.app-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 16px;border-bottom:1px solid var(--line);background:#ffffffeb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.brand,.topbar-actions,.button-row,.section-title,.camera-metrics,.capture-row{display:flex;align-items:center}.brand{gap:11px;min-width:0}.brand-mark{display:grid;width:36px;height:36px;place-items:center;border-radius:8px;background:#102033;color:#f8c14a;font-weight:800}.brand h1,.section-title h2,.panel-heading h2,.brand p,.eyebrow{margin:0}.brand h1{font-size:16px;line-height:1.15;letter-spacing:0}.brand p{color:var(--muted);font-size:12px;line-height:1.25}.topbar-actions{gap:8px}.privacy-pill,.candidate-chip{display:inline-flex;align-items:center;gap:6px;min-height:30px;border:1px solid #cde1d4;border-radius:999px;padding:0 10px;background:#f2fbf5;color:#17663a;font-size:12px;white-space:nowrap}.recognition-workspace{display:grid;grid-template-columns:minmax(0,1fr) 390px;min-height:0}.camera-surface{display:grid;grid-template-rows:minmax(0,1fr) 42px;min-width:0;min-height:0;background:#0f172a}.camera-stage{position:relative;min-width:0;min-height:0;overflow:hidden}.camera-video,.camera-overlay{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;transform:scaleX(-1)}.camera-video{background:#111827}.camera-overlay{pointer-events:none}.camera-empty{position:absolute;inset:0;display:grid;place-items:center;align-content:center;gap:10px;color:#cbd5e1;background:linear-gradient(135deg,#111827,#1f2937);font-size:14px}.camera-metrics{gap:14px;min-width:0;padding:0 14px;border-top:1px solid rgba(255,255,255,.1);color:#dbeafe;font-size:12px}.camera-metrics span{display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.metric-dot{width:9px;height:9px;border-radius:999px;background:#64748b}.metric-dot.running{background:#10b981}.metric-dot.loading{background:var(--amber)}.metric-dot.error{background:#ef4444}.control-panel{display:flex;flex-direction:column;gap:12px;min-width:0;min-height:0;padding:12px;overflow:auto;border-left:1px solid var(--line);background:#eef3f6}.settings-panel,.result-panel,.collect-panel{display:flex;flex-direction:column;gap:12px;border:1px solid var(--line);border-radius:8px;padding:13px;background:var(--panel)}.section-title{justify-content:space-between;gap:8px;min-height:24px}.section-title h2{flex:1;color:#23323f;font-size:14px;letter-spacing:0}.section-title span{color:var(--muted);font-size:12px}.field-row,.range-field,.text-output{display:grid;gap:7px;color:#334155;font-size:12px}.field-row select,.text-output textarea{width:100%;min-width:0;border:1px solid var(--line);border-radius:7px;background:#fff;color:var(--ink);outline:none}.field-row select{height:36px;padding:0 9px}.range-field input{width:100%;accent-color:var(--teal)}.segmented-control{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;border:1px solid var(--line);border-radius:8px;padding:4px;background:#f8fafc}.segmented-control button,.label-button{min-width:0;border-radius:6px;background:transparent;color:#334155;cursor:pointer}.segmented-control button{height:30px;font-size:12px}.segmented-control button.selected,.label-button.selected{background:var(--blue);color:#fff}.status-line{min-height:32px;margin:0;border:1px solid #cbd8e6;border-radius:7px;padding:8px 9px;background:#f6f9fc;color:#24415f;font-size:12px;line-height:1.25}.status-line.error{border-color:#f4c7c1;background:#fff7f4;color:#8a241a}.panel-heading{display:flex;align-items:center;justify-content:space-between;gap:12px}.eyebrow{color:var(--muted);font-size:12px;line-height:1.2}.panel-heading h2{color:#111827;font-size:32px;line-height:1.1;letter-spacing:0}.confidence-ring{display:flex;align-items:baseline;justify-content:center;width:66px;height:66px;border:6px solid var(--blue-weak);border-top-color:var(--blue);border-radius:50%;color:var(--blue);font-weight:800}.confidence-ring small{margin-left:1px;font-size:11px}.candidate-list{display:flex;flex-wrap:wrap;gap:7px}.candidate-chip{border-color:#dbeafe;background:#f8fbff;color:#1d4ed8}.candidate-chip small{color:var(--muted)}.text-output textarea{height:112px;resize:vertical;padding:9px 10px;line-height:1.55;font-size:14px}.button-row{gap:8px;flex-wrap:wrap}.primary-button,.secondary-button,.danger-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:36px;border-radius:7px;cursor:pointer;white-space:nowrap}.primary-button,.secondary-button,.danger-button{padding:0 12px}.icon-button{width:36px;border:1px solid var(--line);background:#fff;color:var(--ink)}.primary-button{background:var(--teal);color:#fff}.primary-button:hover{background:var(--teal-strong)}.secondary-button{border:1px solid var(--line);background:#fff;color:var(--ink)}.secondary-button:hover,.icon-button:hover{background:#edf3f5}.danger-button{background:var(--danger);color:#fff}.primary-button:disabled,.secondary-button:disabled,.danger-button:disabled,.icon-button:disabled{cursor:not-allowed;opacity:.52}.full{flex:1 1 auto}.label-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}.label-groups{display:grid;gap:10px;max-height:330px;overflow:auto;padding-right:2px}.label-group{display:grid;gap:5px}.label-group>span{color:var(--muted);font-size:11px;line-height:1.2}.label-grid.compact{grid-template-columns:minmax(104px,1fr)}.label-button{display:grid;min-height:46px;place-items:center;gap:1px;border:1px solid var(--line);background:#f8fafc}.label-button span{max-width:100%;overflow:hidden;text-overflow:ellipsis;color:inherit;font-size:16px;font-weight:700;line-height:1.05;white-space:nowrap}.label-button small{color:inherit;font-size:10px;line-height:1;opacity:.68}.capture-row{gap:10px}.progress-track{flex:1;height:10px;overflow:hidden;border-radius:999px;background:#e2e8f0}.progress-track span{display:block;height:100%;border-radius:inherit;background:var(--amber);transition:width 80ms linear}.sample-summary{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}.sample-summary span{display:grid;place-items:center;gap:2px;min-height:48px;border:1px solid var(--line);border-radius:7px;background:#fbfdff;color:var(--muted);font-size:12px}.sample-summary strong{color:var(--ink);font-size:16px}.unsupported-strip{display:flex;flex-wrap:wrap;gap:6px;align-items:center;border:1px solid #f3d49a;border-radius:7px;padding:8px;background:#fffaf0}.unsupported-strip span,.unsupported-strip small{font-size:11px;line-height:1}.unsupported-strip span{color:#92400e;font-weight:700}.unsupported-strip small{border-radius:999px;padding:5px 7px;background:#fffbeb;color:#78350f}.storage-note{margin:0;color:var(--muted);font-size:12px;line-height:1.35}.share-note{min-height:26px;margin:0;border:1px solid #d7e7ea;border-radius:7px;padding:7px 8px;background:#f7fbfc;color:#28525a;font-size:12px;line-height:1.35}.sample-manager{display:grid;gap:7px;border:1px solid var(--line);border-radius:7px;padding:8px;background:#fbfdff}.sample-manager-title,.sample-row,.sample-row>div{display:flex;align-items:center}.sample-manager-title{justify-content:space-between;gap:8px}.sample-manager-title span{color:#23323f;font-size:12px;font-weight:700}.sample-manager-title small{color:var(--muted);font-size:11px}.sample-list{display:grid;gap:5px;max-height:150px;overflow:auto}.sample-list p{margin:0;color:var(--muted);font-size:12px;line-height:1.35}.sample-row{justify-content:space-between;gap:8px;min-height:42px;border:1px solid #e2e8f0;border-radius:7px;padding:5px 5px 5px 9px;background:#fff}.sample-row>div{flex-wrap:wrap;gap:6px;min-width:0}.sample-row strong{color:var(--ink);font-size:12px;line-height:1.2}.sample-row small{color:var(--muted);font-size:11px;line-height:1.2}.danger-icon{flex:0 0 32px;width:32px;height:32px;color:var(--danger)}.danger-icon:hover{background:#fff1f0}.collect-panel .button-row .secondary-button{flex:1 1 76px}.file-input{display:none}@media(max-width:980px){.jsl-app{grid-template-rows:auto 1fr}.app-topbar{align-items:stretch;flex-direction:column;padding:10px}.topbar-actions{flex-wrap:wrap}.recognition-workspace{grid-template-columns:1fr;grid-template-rows:minmax(320px,52vh) auto;overflow:auto}.control-panel{border-left:0;border-top:1px solid var(--line)}}
