:root{--bg: #f4f7fb;--surface: #ffffff;--text: #0f172a;--muted: #475569;--border: #dce5f0;--primary: #1249b2;--primary-hover: #0e3f99;--ok-bg: #e7f7ef;--ok-text: #0f6d3a;--warn-bg: #fff4e5;--warn-text: #8a4b08;--neutral-bg: #eef2f7;--neutral-text: #334155;--danger: #b42318;--slider-track: #dbe7f5;--slider-fill: #2f6fdb;--slider-thumb: #ffffff;--slider-thumb-border: #1249b2}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,-apple-system,sans-serif}#root{min-height:100vh}.page{max-width:1040px;margin:0 auto;padding:1rem 1rem 3rem}.hero h1{margin:.45rem 0 0;font-size:1.9rem;text-align:center;letter-spacing:.01em}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.brand-strip{display:flex;align-items:center;justify-content:center}.brand-wordmark{width:min(43%,420px);height:auto;object-fit:contain}.hero p{margin:.15rem 0 0;color:var(--muted);max-width:720px;text-align:center;margin-left:auto;margin-right:auto}.tabs{margin-top:1rem;display:inline-flex;border:1px solid var(--border);border-radius:.7rem;overflow:hidden;background:#f8fbff}.tab-button{border:0;border-right:1px solid var(--border);background:transparent;color:var(--neutral-text);padding:.52rem .95rem;font-weight:600}.tab-button:last-child{border-right:0}.tab-button.active{background:#eaf2ff;color:#103e8a}.tab-button:hover:not(:disabled){background:#edf4ff}.status-bar{margin-top:1rem;display:flex;flex-wrap:wrap;gap:.55rem;align-items:center}.pill{font-size:.86rem;border-radius:999px;padding:.35rem .7rem;font-weight:600}.pill.ok{background:var(--ok-bg);color:var(--ok-text)}.pill.warn{background:var(--warn-bg);color:var(--warn-text)}.pill.neutral{background:var(--neutral-bg);color:var(--neutral-text)}.panel,.card{background:var(--surface);border:1px solid var(--border);border-radius:.9rem;padding:1rem;margin-top:1rem;box-shadow:0 1px 2px #0f172a08}.panel-heading h2,.card h3{margin:0}.panel-heading p{margin:.35rem 0 0;color:var(--muted)}.controls{margin-top:.9rem;display:grid;gap:.95rem}.field{display:grid;gap:.4rem}.field span{font-weight:600}.field small{color:var(--muted)}.mode-toggle{display:inline-flex;align-items:center;flex-wrap:wrap}.mode-pill{font-size:.82rem;font-weight:600}.file-upload{display:flex;width:min(100%,620px);align-items:center;justify-content:space-between;gap:.85rem;padding:.62rem .72rem;border:1px solid var(--border);border-radius:.75rem;background:#fbfdff;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease}.file-upload:hover{border-color:#c8d8eb;background:#f8fbff}.file-upload.selected{border-color:#9ec3ef;background:#f1f7ff}.file-upload-copy{display:grid;min-width:0;gap:.15rem}.file-upload-copy strong{color:var(--neutral-text);font-size:.95rem}.file-upload-copy span{color:var(--muted);font-size:.84rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-input-hidden{position:absolute;width:1px;height:1px;margin:-1px;padding:0;border:0;overflow:hidden;clip:rect(0,0,0,0)}.file-upload-button{display:inline-flex;align-items:center;justify-content:center;border-radius:.6rem;border:1px solid #c5d6ea;background:#eef4fb;color:#1f3a63;font-weight:600;font-size:.84rem;padding:.43rem .72rem;cursor:pointer;transition:background .12s ease,border-color .12s ease;flex-shrink:0}.file-upload-button:hover{background:#e5eef9;border-color:#afc8e7}.file-input-hidden:focus-visible~.file-upload-button{box-shadow:0 0 0 4px #1249b233}.threshold-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:min(100%,340px);height:.55rem;border-radius:999px;background:linear-gradient(to right,var(--slider-fill) 0%,var(--slider-fill) var(--slider-progress, 50%),var(--slider-track) var(--slider-progress, 50%),var(--slider-track) 100%);outline:none}.threshold-slider:focus-visible{box-shadow:0 0 0 4px #1249b233}.threshold-slider::-webkit-slider-runnable-track{height:.55rem;border-radius:999px;background:transparent}.threshold-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:1.1rem;height:1.1rem;border-radius:50%;margin-top:-.275rem;background:var(--slider-thumb);border:2px solid var(--slider-thumb-border);box-shadow:0 1px 3px #0f172a33;cursor:pointer}.threshold-slider::-moz-range-track{height:.55rem;border-radius:999px;background:var(--slider-track)}.threshold-slider::-moz-range-thumb{width:1.1rem;height:1.1rem;border-radius:50%;background:var(--slider-thumb);border:2px solid var(--slider-thumb-border);box-shadow:0 1px 3px #0f172a33;cursor:pointer}.row{display:flex;gap:.7rem;flex-wrap:wrap}button{border:0;background:var(--primary);color:#fff;border-radius:.6rem;padding:.55rem .95rem;cursor:pointer;font-weight:600}button:hover:not(:disabled){background:var(--primary-hover)}button:disabled{opacity:.6;cursor:not-allowed}.mode-toggle{gap:.45rem}.mode-pill{display:inline-flex;align-items:center;justify-content:center;line-height:1;background:#f3f7fc;color:var(--neutral-text);border:1px solid var(--border);padding:.42rem .78rem;border-radius:999px;transition:background .12s ease,border-color .12s ease,color .12s ease}.mode-pill:not(.active):hover:not(:disabled),.mode-pill:not(.active):focus-visible{background:#eaf2ff;color:#103e8a;border-color:#c3d8f3}.mode-pill.active,.mode-pill.active:hover:not(:disabled),.mode-pill.active:focus-visible{background:#d7e8ff;color:#103e8a;border-color:#95bbe8;box-shadow:inset 0 0 0 1px #103e8a14}.ghost{background:transparent;color:var(--neutral-text);border:1px solid var(--border)}.ghost:hover:not(:disabled){background:#f7f9fc}.grid{margin-top:1rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.metrics-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.metrics-grid .span-2{grid-column:span 2}.metric-card{min-height:120px;display:flex;flex-direction:column;justify-content:center}.metric-value{margin:.5rem 0 0;font-size:2rem;line-height:1.1;font-weight:700;color:#114395}.metric-correct{color:var(--ok-text)}.metric-incorrect{color:var(--danger)}.metric-sub{margin:.25rem 0 0;font-size:.82rem}.preview{width:min(100%,480px);border-radius:.6rem;border:1px solid var(--border)}.prediction-line{margin:.4rem 0 0}.muted{color:var(--muted)}.meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.2rem 1rem;margin:.5rem 0 .75rem}.meta-grid p{margin:.2rem 0;color:var(--neutral-text)}.prob-list{margin-top:.7rem;display:grid;gap:.6rem}.prob-item{display:grid;gap:.32rem}.prob-meta{display:flex;justify-content:space-between;font-size:.92rem;color:var(--neutral-text)}.meter{height:.56rem;border-radius:999px;background:#e7edf5;overflow:hidden}.meter-fill{height:100%;background:linear-gradient(90deg,#0b69c7,#2aa8ff)}.error{color:var(--danger);margin:.8rem 0 0}.attention-warning{margin:.5rem 0 .35rem;padding:.6rem .72rem;border-radius:.6rem;background:#fff6ea;border:1px solid #f1d3a8;color:#8a4b08;font-size:.9rem}.inline-note{margin:.85rem 0 0}.disclosure{padding:0;overflow:hidden}.disclosure summary{list-style:none;cursor:pointer;padding:.85rem 1rem;font-weight:600;color:var(--neutral-text);background:#fbfdff}.disclosure summary::-webkit-details-marker{display:none}.disclosure summary:after{content:"+";float:right;color:#6b7f9f}.disclosure[open] summary{border-bottom:1px solid var(--border)}.disclosure[open] summary:after{content:"-"}.disclosure-body{padding:.95rem 1rem 1rem}.cam-wrapper{display:grid;gap:.8rem}.cam-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.cam-label{margin:0 0 .35rem;font-weight:600;color:var(--neutral-text)}.overlay-frame{position:relative;width:min(100%,480px)}.overlay-base,.overlay-top{display:block}.overlay-top{position:absolute;top:0;left:0}.history-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.6rem}.table-wrap{overflow-x:auto}.history-table{width:100%;border-collapse:collapse;font-size:.93rem}.history-table th,.history-table td{text-align:left;padding:.55rem .5rem;border-bottom:1px solid var(--border);white-space:nowrap}.history-table thead th{color:var(--muted);font-weight:600;background:#f8fbff}.feedback-cell{display:flex;gap:.3rem;align-items:center}.feedback-btn{display:inline-flex;align-items:center;justify-content:center;width:1.7rem;height:1.7rem;border-radius:.4rem;font-size:.85rem;padding:0;background:transparent;color:var(--muted);border:1px solid var(--border);transition:background .1s ease,color .1s ease,border-color .1s ease}.feedback-btn:hover:not(:disabled){background:#f0f4fa}.feedback-btn.active-correct{background:var(--ok-bg);color:var(--ok-text);border-color:#a6dbc2}.feedback-btn.active-incorrect{background:#fde8e6;color:var(--danger);border-color:#f3b8b3}@media (max-width: 900px){.grid,.cam-grid,.meta-grid{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.file-upload{width:100%}}
