: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}.connection-banner{margin-top:1rem;padding:.85rem 1rem;border-radius:.8rem;display:flex;align-items:center;gap:.85rem}.connection-banner p{margin:.2rem 0 0;font-size:.88rem}.connection-banner.connecting{background:#eef5ff;border:1px solid #b8d4f5;color:#1a4b8c}.connection-banner.unavailable{background:#fff4e5;border:1px solid #f1d3a8;color:#8a4b08}.connection-banner.unavailable button{flex-shrink:0}.connection-spinner{width:24px;height:24px;border:3px solid #b8d4f5;border-top-color:#1a6dd4;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.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.connecting-pill{background:#eef5ff;color:#1a4b8c;animation:pulse-subtle 1.5s ease-in-out infinite}@keyframes pulse-subtle{0%,to{opacity:1}50%{opacity:.6}}.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}.refresh-btn.refreshing{opacity:.7;cursor:wait}.last-refreshed{font-size:.78rem;color:var(--muted)}.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}.patients-toolbar{display:flex;gap:.75rem;align-items:center;margin-top:.9rem;flex-wrap:wrap}.patient-search-input{border:1px solid var(--border);border-radius:.6rem;padding:.52rem .75rem;font-size:.92rem;background:#fbfdff;color:var(--text);outline:none;min-width:220px}.patient-search-input:focus{border-color:#9ec3ef;box-shadow:0 0 0 3px #1249b21f}.patient-search-input.wide{flex:1}.patient-select-wrap{position:relative;width:min(100%,420px)}.patient-select-wrap .patient-search-input{width:100%}.patient-clear-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--muted);font-size:1.2rem;cursor:pointer;padding:.2rem .4rem;line-height:1}.patient-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;background:var(--surface);border:1px solid var(--border);border-radius:0 0 .6rem .6rem;box-shadow:0 6px 16px #0f172a1a;list-style:none;margin:0;padding:.3rem 0;max-height:220px;overflow-y:auto}.patient-option{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;background:transparent;border:none;color:var(--text);font-size:.9rem;cursor:pointer;text-align:left}.patient-option:hover{background:#f0f4fa}.mrn-tag{font-size:.78rem;color:var(--muted);background:var(--neutral-bg);padding:.15rem .45rem;border-radius:999px}.patient-form{margin-top:.9rem;display:grid;gap:.8rem}.patient-form.compact{margin-top:0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}.patient-form input,.patient-form textarea{border:1px solid var(--border);border-radius:.5rem;padding:.48rem .65rem;font-size:.92rem;background:#fbfdff;color:var(--text);font-family:inherit}.patient-form input:focus,.patient-form textarea:focus{border-color:#9ec3ef;box-shadow:0 0 0 3px #1249b21f;outline:none}.patient-link{color:var(--primary);font-weight:600;text-decoration:none}.patient-link:hover{text-decoration:underline}.view-btn{display:inline-flex;align-items:center;justify-content:center;padding:.3rem .65rem;font-size:.82rem;text-decoration:none;border-radius:.5rem}.patient-detail-nav{margin-top:.5rem}.back-link{display:inline-flex;align-items:center;gap:.3rem;text-decoration:none;font-size:.9rem;padding:.35rem .7rem;border-radius:.5rem}.patient-header-card{padding:1.2rem}.patient-info-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.patient-name{margin:0;font-size:1.5rem}.patient-meta{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.5rem}.patient-notes{margin:.6rem 0 0;color:var(--muted);font-size:.92rem}.patient-actions{display:flex;gap:.5rem;flex-shrink:0;align-items:flex-start}.analyze-link-btn{display:inline-flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;border:none;border-radius:.6rem;padding:.5rem .85rem;font-weight:600;font-size:.88rem;text-decoration:none;cursor:pointer}.analyze-link-btn:hover{background:var(--primary-hover)}.danger-ghost{color:var(--danger);border-color:#f3b8b3}.danger-ghost:hover:not(:disabled){background:#fde8e6}.progression-svg{width:100%;max-width:640px;height:auto;margin-top:.5rem}.analysis-timeline{display:grid;gap:.75rem;margin-top:.5rem}.timeline-card{border:1px solid var(--border);border-radius:.7rem;overflow:hidden}.timeline-card-header{display:flex;justify-content:space-between;align-items:center;padding:.6rem .85rem;background:#f8fbff;border-bottom:1px solid var(--border)}.timeline-date{font-size:.85rem;color:var(--muted);font-weight:500}.timeline-card-body{display:flex;gap:1rem;padding:.85rem;align-items:flex-start}.timeline-thumb{width:120px;height:120px;object-fit:cover;border-radius:.5rem;border:1px solid var(--border);flex-shrink:0}.timeline-details{display:grid;gap:.2rem;font-size:.9rem}.timeline-details p{margin:0}.tab-button{text-decoration:none;display:inline-flex;align-items:center}.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;z-index:100;background:var(--primary);color:#fff;padding:.6rem 1.2rem;border-radius:0 0 .5rem;font-weight:600;text-decoration:none}.skip-link:focus{left:0;top:0;width:auto;height:auto}.clinical-disclaimer{margin-top:1rem;padding:.85rem 1rem;border-radius:.8rem;background:#fef9ed;border:1px solid #f0d99e;color:#6b4f12;font-size:.9rem}.clinical-disclaimer strong{font-size:.95rem;display:block;margin-bottom:.3rem}.clinical-disclaimer>p{margin:0}.disclaimer-details{margin-top:.5rem}.disclaimer-details summary{cursor:pointer;font-weight:600;font-size:.85rem;color:#8a6516}.disclaimer-body{margin-top:.4rem;font-size:.84rem;line-height:1.55}.disclaimer-body p{margin:.35rem 0}.field-label{font-weight:600}@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%}.form-row{grid-template-columns:1fr}.patient-info-row{flex-direction:column}}@media (prefers-color-scheme: dark){:root{--bg: #0f172a;--surface: #1e293b;--text: #e2e8f0;--muted: #94a3b8;--border: #334155;--primary: #60a5fa;--primary-hover: #3b82f6;--ok-bg: #064e3b;--ok-text: #6ee7b7;--warn-bg: #451a03;--warn-text: #fbbf24;--neutral-bg: #1e293b;--neutral-text: #cbd5e1;--danger: #f87171;--slider-track: #334155;--slider-fill: #60a5fa;--slider-thumb: #1e293b;--slider-thumb-border: #60a5fa}.tabs{background:#1e293b;border-color:#334155}.tab-button{border-color:#334155;color:#cbd5e1}.tab-button.active{background:#1e3a5f;color:#93c5fd}.tab-button:hover:not(:disabled){background:#1e3a5f}.connection-banner.connecting{background:#172554;border-color:#1e40af;color:#93c5fd}.connection-banner.unavailable{background:#451a03;border-color:#92400e;color:#fbbf24}.connection-spinner{border-color:#1e40af;border-top-color:#60a5fa}.pill.connecting-pill{background:#172554;color:#93c5fd}.file-upload{background:#1e293b;border-color:#334155}.file-upload:hover{background:#253346;border-color:#475569}.file-upload.selected{background:#1e3a5f;border-color:#1d4ed8}.file-upload-button{background:#334155;border-color:#475569;color:#e2e8f0}.file-upload-button:hover{background:#475569;border-color:#64748b}.disclosure summary{background:#1e293b;color:#cbd5e1}.disclosure[open] summary{border-bottom-color:#334155}.history-table thead th{background:#1e293b;color:#94a3b8}.patient-search-input{background:#1e293b;color:#e2e8f0;border-color:#334155}.patient-search-input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa26}.patient-dropdown{background:#1e293b;border-color:#334155;box-shadow:0 6px 16px #0006}.patient-option:hover{background:#334155}.patient-form input,.patient-form textarea{background:#1e293b;color:#e2e8f0;border-color:#334155}.patient-form input:focus,.patient-form textarea:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa26}.mode-pill{background:#1e293b;border-color:#334155;color:#cbd5e1}.mode-pill:not(.active):hover:not(:disabled),.mode-pill:not(.active):focus-visible{background:#1e3a5f;color:#93c5fd;border-color:#2563eb}.mode-pill.active,.mode-pill.active:hover:not(:disabled),.mode-pill.active:focus-visible{background:#1e3a5f;color:#93c5fd;border-color:#2563eb}.ghost{border-color:#334155;color:#cbd5e1}.ghost:hover:not(:disabled){background:#253346}.attention-warning{background:#451a03;border-color:#92400e;color:#fbbf24}.metric-value{color:#93c5fd}.feedback-btn{border-color:#334155;color:#94a3b8}.feedback-btn:hover:not(:disabled){background:#334155}.feedback-btn.active-correct{background:#064e3b;border-color:#059669;color:#6ee7b7}.feedback-btn.active-incorrect{background:#450a0a;border-color:#b91c1c;color:#fca5a5}.timeline-card{border-color:#334155}.timeline-card-header{background:#1e293b;border-bottom-color:#334155}.timeline-thumb{border-color:#334155}.danger-ghost{color:#f87171;border-color:#7f1d1d}.danger-ghost:hover:not(:disabled){background:#450a0a}.clinical-disclaimer{background:#451a03;border-color:#92400e;color:#fde68a}.disclaimer-details summary{color:#fbbf24}.meter{background:#334155}.mrn-tag{background:#334155;color:#94a3b8}.preview{border-color:#334155}.analyze-link-btn{background:#2563eb;color:#fff}.analyze-link-btn:hover{background:#1d4ed8}button{background:#2563eb}button:hover:not(:disabled){background:#1d4ed8}.patient-link{color:#60a5fa}}@media (prefers-reduced-motion: reduce){.connection-spinner,.pill.connecting-pill{animation:none}*,*:before,*:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
