*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0a0a0f;--surface: #14141f;--surface-2: #1e1e2e;--border: #363650;--text: #e0e0e8;--text-dim: #a0a0b8;--accent: #818cf8;--accent-hover: #9299ff;--radius: 8px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;overflow-x:hidden}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.header{padding:16px 32px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.header-home-link{display:flex;align-items:center;gap:12px;cursor:pointer;text-decoration:none;color:inherit}.header-logo{width:32px;height:32px;object-fit:contain;border-radius:4px}.header h1{font-size:20px;font-weight:700;letter-spacing:-.02em}.subtitle{font-size:13px;color:var(--text-dim)}.header-right{margin-left:auto;display:flex;align-items:center;gap:12px}.lang-picker{position:relative}.lang-picker-btn{display:flex;align-items:center;gap:6px;padding:5px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .15s;white-space:nowrap}.lang-picker-btn:hover{border-color:var(--accent);color:var(--text)}.lang-picker-chevron{transition:transform .2s}.lang-picker-chevron.open{transform:rotate(180deg)}.lang-picker-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:160px;max-height:320px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0006;z-index:100;padding:4px}.lang-picker-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 10px;border:none;border-radius:4px;background:transparent;color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .1s;text-align:left}.lang-picker-option:hover{background:var(--surface-2);color:var(--text)}.lang-picker-option.active{color:var(--accent);font-weight:600}.lang-picker-native{flex:1}.app-footer{padding:12px 32px;text-align:center;font-size:12px;color:var(--text-dim);opacity:.75;border-top:1px solid var(--border);flex-shrink:0;display:flex;justify-content:center;align-items:center;gap:6px}.footer-sep{opacity:.6}.footer-link{background:none;border:none;color:inherit;font:inherit;cursor:pointer;text-decoration:underline;text-decoration-color:transparent;transition:text-decoration-color .15s;padding:0}.footer-link:hover{text-decoration-color:currentColor}.privacy-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.privacy-modal{background:var(--bg);border:1px solid var(--border);border-radius:12px;max-width:640px;width:100%;max-height:80vh;overflow-y:auto;padding:32px}.privacy-modal h2{margin:0 0 4px;font-size:20px}.privacy-date{font-size:12px;color:var(--text-dim);margin:0 0 16px}.privacy-section{margin-top:16px}.privacy-section h3{font-size:14px;margin:0 0 4px}.privacy-section p{font-size:13px;line-height:1.6;color:var(--text-dim);margin:0}.privacy-modal>p{font-size:13px;line-height:1.6;color:var(--text-dim);margin:0}.privacy-close-btn{margin-top:24px;padding:8px 24px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:13px;cursor:pointer;width:100%}.privacy-close-btn:hover{border-color:var(--accent)}.main{flex:1;display:flex;overflow:hidden}.sidebar{width:360px;min-width:360px;border-right:1px solid var(--border);padding:24px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}.content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;position:relative;overflow:auto}.control-panel{display:flex;flex-direction:column;gap:20px}.control-group{display:flex;flex-direction:column;gap:8px}.control-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);display:flex;justify-content:space-between;align-items:center}.control-value{font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}.type-buttons{display:flex;flex-direction:column;gap:4px}.type-btn{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .15s;text-align:left}.type-btn:hover{border-color:var(--accent);color:var(--text)}.type-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}.slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:var(--surface-2);outline:none;cursor:pointer}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent);border:2px solid white;cursor:pointer;transition:transform .1s}.slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.slider-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--text-dim)}.view-buttons{display:flex;gap:4px}.view-btn{flex:1;padding:8px 6px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .15s}.view-btn:hover{border-color:var(--accent);color:var(--text)}.view-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}.uploader{border:2px dashed var(--border);border-radius:var(--radius);padding:48px 32px;text-align:center;cursor:pointer;transition:all .2s;width:100%;max-width:480px}.uploader:hover{border-color:var(--accent);background:#818cf80d}.uploader-content{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-dim)}.uploader-content p{font-size:14px}.uploader-hint{font-size:12px;opacity:.8}.canvas-container{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.canvas-container canvas{max-width:100%;max-height:calc(100vh - 140px);border-radius:var(--radius);object-fit:contain}.canvas-placeholder{position:absolute;color:var(--text-dim);font-size:14px}.compare-view{position:relative;width:100%;max-width:100%;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;touch-action:none}.compare-layer{position:relative}.compare-layer canvas{max-width:100%;max-height:calc(100vh - 140px);display:block;border-radius:var(--radius)}.compare-left{position:relative}.compare-right{position:absolute;top:0;left:0;width:100%;height:100%}.compare-right canvas{width:100%;height:100%;object-fit:contain}.compare-label{position:absolute;bottom:16px;padding:4px 12px;background:#000000b3;border-radius:4px;font-size:12px;font-weight:600;pointer-events:none}.compare-left .compare-label{left:16px}.compare-right .compare-label{right:16px}.compare-slider{position:absolute;top:0;bottom:0;width:4px;transform:translate(-50%);cursor:ew-resize;z-index:10}.compare-slider-line{position:absolute;top:0;bottom:0;left:50%;width:2px;transform:translate(-50%);background:#fff;box-shadow:0 0 4px #00000080}.compare-slider-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:36px;border-radius:50%;background:#fff;color:#333;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000004d}.image-actions{display:flex;gap:8px;margin-top:16px}.action-btn{padding:6px 16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .15s}.action-btn:hover{border-color:var(--accent);color:var(--text)}.share-btn{width:100%;padding:10px;border:1px solid var(--accent);border-radius:var(--radius);background:transparent;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.share-btn:hover{background:var(--accent);color:#fff}.test-flow{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;max-width:640px;margin:0 auto;width:100%}.welcome-screen{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 24px;width:100%}.welcome-card{max-width:520px;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:40px 32px;display:flex;flex-direction:column;gap:20px}.welcome-card h2{font-size:24px;font-weight:700}.welcome-desc{color:var(--text-dim);font-size:14px;line-height:1.6}.calibration-section h3{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);margin-bottom:12px}.calibration-list{list-style:none;display:flex;flex-direction:column;gap:8px}.calibration-list li{font-size:13px;color:var(--text);padding-left:24px;position:relative}.calibration-list li:before{content:"";position:absolute;left:0;top:5px;width:12px;height:12px;border:1.5px solid var(--accent);border-radius:3px}.checkbox-label{display:flex;align-items:center;gap:10px;font-size:14px;cursor:pointer;padding:12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2)}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent)}.start-btn{width:100%;padding:14px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .15s}.start-btn:hover:not(:disabled){background:var(--accent-hover)}.start-btn:disabled{opacity:.55;cursor:not-allowed}.previous-hint{font-size:12px;color:var(--text-dim);text-align:center}.home-landing{max-width:720px;width:100%;display:flex;flex-direction:column;align-items:center;gap:24px}.home-heading{font-size:28px;font-weight:700;text-align:center}.home-subheading{font-size:14px;color:var(--text-dim);text-align:center;line-height:1.6;max-width:480px}.home-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;width:100%}.home-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:28px 24px;display:flex;flex-direction:column;gap:14px;transition:border-color .15s}.home-card:hover{border-color:var(--accent)}.home-card-icon{color:var(--accent)}.home-card-title{font-size:18px;font-weight:700}.home-card-desc{font-size:13px;color:var(--text-dim);line-height:1.6;flex:1}.home-disclaimer{font-size:11px;color:var(--text-dim);opacity:.75;line-height:1.5;font-style:italic}.instructions-list{list-style:none;display:flex;flex-direction:column;gap:14px}.instructions-list li{display:flex;align-items:flex-start;gap:12px;font-size:14px;line-height:1.6;color:var(--text)}.instructions-num{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:1px}.home-back-btn{width:100%;padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .15s}.home-back-btn:hover{border-color:var(--accent);color:var(--text)}.session-input-group{display:flex;gap:8px}.session-input{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2);color:var(--text);font-size:13px;font-family:SF Mono,Menlo,Consolas,monospace;outline:none;transition:border-color .15s}.session-input:focus{border-color:var(--accent)}.session-input::placeholder{color:var(--text-dim);opacity:.7;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif}.load-btn{padding:10px 20px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}.load-btn:hover:not(:disabled){background:var(--accent-hover)}.load-btn:disabled{opacity:.55;cursor:not-allowed}.load-error{font-size:12px;color:#ef4444;margin-top:-6px}@media(max-width:600px){.home-cards{grid-template-columns:1fr}}.trial-container{display:flex;flex-direction:column;align-items:center;gap:32px;padding:20px 0}.trial-instruction{font-size:16px;color:var(--text-dim);text-align:center;margin-bottom:-16px}.trial-hint{font-size:12px;color:var(--text-dim);opacity:.8;text-align:center}.odd-one-out-grid{display:grid;gap:16px;justify-items:center}.threshold-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;justify-items:center}.circle-btn{border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s,border-color .1s;width:80px;height:80px;outline:none}.circle-btn:hover{transform:scale(1.08);border-color:#ffffff4d}.circle-btn:active{transform:scale(.95)}.circle-btn.large{width:90px;height:90px}.cant-tell-btn{padding:10px 28px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:14px;cursor:pointer;transition:all .15s}.cant-tell-btn:hover{border-color:var(--accent);color:var(--text);background:var(--surface-2)}.trial-actions{display:flex;gap:8px;align-items:center}.modifier-btn{padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .15s}.modifier-btn:hover{border-color:var(--accent);color:var(--text)}.modifier-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}.modifier-btn.faint.active{border-color:#60a5fa;background:#60a5fa;color:#000}.faint-hint{font-size:12px;color:var(--text-dim);opacity:.85;text-align:center;margin-top:4px}.test-progress{width:100%;display:flex;flex-direction:column;gap:8px}.test-progress-header{display:flex;justify-content:space-between;font-size:13px}.test-progress-label{color:var(--text-dim);font-weight:600}.test-progress-count{color:var(--accent);font-variant-numeric:tabular-nums}.test-progress-bar{width:100%;height:4px;background:var(--surface-2);border-radius:2px;overflow:hidden}.test-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.test-results{width:100%;display:flex;justify-content:center}.results-card{max-width:680px;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:40px 32px;display:flex;flex-direction:column;gap:16px}.results-card h2{font-size:24px;font-weight:700;margin-bottom:8px}.result-item{display:flex;justify-content:space-between;align-items:center}.result-label{font-size:13px;color:var(--text-dim);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.result-value{font-size:14px;font-weight:600}.type-value{color:var(--accent)}.result-description{font-size:13px;color:var(--text-dim);line-height:1.6;padding:12px;background:var(--surface-2);border-radius:var(--radius)}.severity-bar,.severity-bar-small{width:100%;height:8px;background:var(--surface-2);border-radius:4px;position:relative;overflow:hidden}.severity-bar-small{height:4px;margin-top:4px}.severity-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,#4ade80,#facc15,#ef4444);transition:width .5s ease}.severity-marker{position:absolute;top:-4px;width:4px;height:16px;background:#fff;border-radius:2px;transform:translate(-50%);box-shadow:0 1px 3px #0006}.severity-scale{display:flex;justify-content:space-between;font-size:12px;color:var(--text-dim)}.axis-profile{display:flex;flex-direction:column;gap:10px;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.axis-profile>.result-label{margin-bottom:-4px}.axis-profile-hint{font-size:12px;color:var(--text-dim);opacity:.8}.axis-bar-row{display:flex;align-items:center;gap:10px}.axis-bar-row.primary{font-weight:600}.axis-bar-label{font-size:12px;width:120px;flex-shrink:0}.axis-bar-track{flex:1;height:8px;background:var(--surface-2);border-radius:4px;overflow:hidden}.axis-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.axis-bar-value{font-size:12px;color:var(--text-dim);width:50px;text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0}.confidence-explanation{font-size:12px;color:var(--text-dim);line-height:1.6;margin-top:-4px}.low-confidence-warning{font-size:12px;color:#facc15;padding:8px 12px;background:#facc151a;border-radius:var(--radius);border:1px solid rgba(250,204,21,.2)}.result-stats{display:flex;justify-content:space-between;font-size:12px;color:var(--text-dim);padding-top:8px;border-top:1px solid var(--border)}.continue-btn{width:100%;padding:14px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .15s;margin-top:8px}.continue-btn:hover{background:var(--accent-hover)}.result-disclaimer{font-size:12px;color:var(--text-dim);text-align:center;opacity:.8}.header-feedback{font-size:12px;color:#fbbf24;text-decoration:none;padding:5px 12px;border:1px solid rgba(251,191,36,.4);border-radius:var(--radius);background:#fbbf2414;transition:all .15s;white-space:nowrap;font-weight:500}.header-feedback:hover{border-color:#fbbf24;color:#fde68a;background:#fbbf2426}.view-results-btn{width:100%;padding:10px;border:1px solid var(--accent);border-radius:var(--radius);background:transparent;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.view-results-btn:hover{background:var(--accent);color:#fff}.detail-session-id{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.session-id-section{margin-top:16px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.session-id-row{display:flex;align-items:center;gap:8px;margin-top:6px}.session-id-code{flex:1;font-family:SF Mono,Menlo,Consolas,monospace;font-size:12px;padding:6px 10px;background:var(--bg);border:1px solid var(--border);border-radius:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;-webkit-user-select:all;user-select:all}.copy-btn{padding:6px 12px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text);font-size:12px;cursor:pointer;white-space:nowrap;transition:all .15s}.copy-btn:hover{border-color:var(--accent)}.session-id-hint{font-size:12px;color:var(--text-dim);margin-top:6px;line-height:1.4}.detected-info{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--surface-2);border-radius:var(--radius)}.detected-row{display:flex;justify-content:space-between;align-items:center;font-size:13px}.detected-key{color:var(--text-dim)}.detected-val{font-weight:600}.skip-test-btn{padding:6px 16px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .15s}.skip-test-btn:hover{border-color:var(--accent);color:var(--text)}.sidebar-actions{display:flex;gap:8px;margin-top:4px}.sidebar-actions .view-results-btn,.sidebar-actions .retest-btn{flex:1}.retest-btn{width:100%;padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .15s}.retest-btn:hover{border-color:var(--accent);color:var(--text)}.view-hint{font-size:12px;color:var(--text-dim);opacity:.8;line-height:1.4}.detected-info.compact{display:flex;flex-direction:column;gap:2px}.type-display{font-size:18px;font-weight:700}.type-hint{font-size:12px;color:var(--text-dim);opacity:.8}.detail-hint{font-size:12px;color:var(--text-dim);opacity:.8;line-height:1.4;margin:-4px 0 4px}.results-stages{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.stage-list{display:flex;flex-direction:column;gap:12px;margin-top:8px}.stage-item{display:flex;align-items:flex-start;gap:10px}.stage-dot{flex-shrink:0;width:10px;height:10px;border-radius:50%;margin-top:4px;background:var(--text-dim)}.stage-dot.done{background:var(--accent)}.stage-info{display:flex;flex-direction:column;gap:2px}.stage-name{font-size:13px;font-weight:600}.stage-detail{font-size:12px;color:var(--text-dim)}.go-back-btn{margin-top:8px;padding:8px 20px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .15s}.go-back-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.go-back-btn:disabled{opacity:.45;cursor:not-allowed}.plate-test{display:flex;flex-direction:column;align-items:center;gap:20px;padding:16px 0}.plate-instruction{font-size:16px;color:var(--text-dim);text-align:center}.plate-hint{font-size:13px;color:var(--text-dim);opacity:.8}.ishihara-image-container{display:flex;justify-content:center;align-items:center;max-width:340px;width:100%}.ishihara-image{max-width:100%;max-height:340px;border-radius:12px;border:2px solid var(--border);object-fit:contain}.ishihara-input-display{font-size:32px;font-weight:700;min-height:48px;min-width:120px;text-align:center;color:var(--text);border-bottom:2px solid var(--border);padding:4px 16px}.ishihara-placeholder{font-size:16px;font-weight:400;color:var(--text-dim);opacity:.7}.ishihara-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-width:240px;width:100%}.plate-number-btn{padding:14px 0;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:20px;font-weight:600;cursor:pointer;transition:all .15s}.plate-number-btn:hover{border-color:var(--accent);background:var(--surface-2)}.plate-number-btn:active{transform:scale(.95)}.plate-number-btn:disabled{opacity:.5;cursor:not-allowed}.ishihara-backspace{font-size:18px}.ishihara-confirm{background:var(--accent);border-color:var(--accent);font-size:14px}.ishihara-confirm:hover:not(:disabled){background:var(--accent-hover)}.plate-cant-see{margin-top:4px}.plate-stage-header{width:100%;text-align:center;padding-bottom:8px;border-bottom:1px solid var(--border);margin-bottom:8px}.plate-stage-label{font-size:14px;color:var(--text-dim);font-weight:600}.plate-stage-hint{font-size:12px;color:var(--text-dim);opacity:.85;margin-top:6px;line-height:1.5}.detected-axes{display:flex;flex-direction:column;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.detected-axis-row{display:flex;align-items:center;gap:8px;font-size:12px}.detected-axis-label{width:90px;flex-shrink:0;font-weight:600}.detected-axis-bar{flex:1;height:4px;background:var(--surface-2);border-radius:2px;overflow:hidden}.detected-axis-fill{height:100%;border-radius:2px;transition:width .3s ease}.detected-axis-val{width:30px;text-align:right;color:var(--text-dim);font-variant-numeric:tabular-nums}.detail-toggle-btn{width:100%;padding:8px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .15s;margin-top:4px}.detail-toggle-btn:hover{border-color:var(--accent);color:var(--text)}.detail-panel{display:flex;flex-direction:column;gap:12px;padding:12px;background:var(--surface-2);border-radius:var(--radius);border:1px solid var(--border)}.detail-section-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}.detail-stages{display:flex;flex-direction:column;gap:6px}.detail-stage-item{display:flex;flex-direction:column;gap:2px;padding-left:12px;border-left:2px solid var(--accent)}.detail-stage-name{font-size:12px;font-weight:600}.detail-stage-info{font-size:12px;color:var(--text-dim)}.detail-stats{display:flex;justify-content:space-between;font-size:12px;color:var(--text-dim);padding-top:8px;border-top:1px solid var(--border)}.detail-disclaimer{font-size:11px;color:var(--text-dim);opacity:.75;text-align:center}.diagnosis-section{display:flex;flex-direction:column;gap:8px;padding:16px;background:var(--surface-2);border-radius:var(--radius);border:1px solid var(--border)}.diagnosis-badge{display:inline-block;padding:4px 12px;border-radius:4px;font-size:14px;font-weight:700;align-self:flex-start}.diagnosis-badge.normal{background:#4ade8026;color:#4ade80}.diagnosis-badge.anomalous{background:#facc1526;color:#facc15}.diagnosis-badge.dichromat{background:#ef444426;color:#ef4444}.compound-badge,.ambiguous-badge{display:inline-block;padding:3px 10px;border-radius:4px;font-size:12px;font-weight:600;align-self:flex-start}.compound-badge{background:#a855f726;color:#a855f7}.ambiguous-badge{background:#eab30826;color:#ca8a04}.diagnosis-explanation{font-size:12px;color:var(--text-dim);line-height:1.6}.axis-data-section{display:flex;flex-direction:column;gap:8px;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.axis-data-table{width:100%;border-collapse:collapse;font-size:12px}.axis-data-table th{text-align:left;padding:6px 8px;font-size:12px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}.axis-data-table td{padding:8px;vertical-align:top}.axis-data-table .primary-row{background:var(--surface-2)}.mono-val{font-variant-numeric:tabular-nums;font-weight:600}.axis-sev-badge{font-weight:600;margin-right:4px}.axis-sev-pct{font-size:12px;color:var(--text-dim)}.clinical-note{font-size:12px;color:var(--text-dim);line-height:1.4}.differential-note{display:flex;flex-direction:column;gap:6px;padding:12px;background:var(--surface-2);border-radius:var(--radius);border-left:3px solid var(--accent)}.differential-note p{font-size:12px;color:var(--text);line-height:1.6}.methodology-toggle{width:100%;padding:8px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .15s}.methodology-toggle:hover{border-color:var(--accent);color:var(--text)}.methodology-section{display:flex;flex-direction:column;gap:12px;padding:12px;background:var(--surface-2);border-radius:var(--radius);border:1px solid var(--border)}.methodology-item{font-size:12px;line-height:1.6}.methodology-item strong{display:block;font-size:12px;color:var(--text);margin-bottom:4px}.methodology-item p{color:var(--text-dim);margin:0}.sidebar-axis-row{display:flex;align-items:center;gap:8px;padding:2px 0;white-space:nowrap}.sidebar-axis-row.primary{font-weight:600}.sidebar-axis-label{font-size:12px;width:48px;flex-shrink:0;font-weight:600}.sidebar-axis-track{flex:1;min-width:80px;height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden}.sidebar-axis-fill{height:100%;border-radius:3px;transition:width .3s ease}.sidebar-axis-val{font-size:12px;color:var(--text);width:32px;text-align:right;flex-shrink:0;font-family:SF Mono,Menlo,monospace}.sidebar-axis-severity{font-size:11px;color:var(--text-dim);text-align:right;flex-shrink:0;white-space:nowrap}.sidebar-axis-status{font-size:11px;color:var(--text-dim);opacity:.8;text-align:right;flex-shrink:0;white-space:nowrap}.axis-primary-badge{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:3px;font-size:10px;font-weight:600;background:var(--accent);color:#fff;vertical-align:middle;text-transform:uppercase;letter-spacing:.04em}.axis-status-dim{color:var(--text-dim);opacity:.8;font-size:12px}.axis-secondary-note{font-size:12px;color:var(--text-dim);opacity:.8;line-height:1.5;margin-top:4px}.detail-diagnosis{padding:8px 0}.diagnosis-badge-sm{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:600}.diagnosis-badge-sm.normal{background:#166534;color:#86efac}.diagnosis-badge-sm.anomalous{background:#854d0e;color:#fde047}.diagnosis-badge-sm.dichromat{background:#991b1b;color:#fca5a5}.detail-diagnosis-explain{font-size:12px;color:var(--text-dim);margin-top:6px;line-height:1.5}.detail-axis-table{display:flex;flex-direction:column;gap:2px;margin:8px 0;font-size:12px}.detail-axis-header{display:grid;grid-template-columns:1fr 70px 80px;gap:4px;color:var(--text-dim);font-size:11px;text-transform:uppercase;padding-bottom:4px;border-bottom:1px solid var(--border)}.detail-axis-row{display:grid;grid-template-columns:1fr 70px 80px;gap:4px;padding:3px 0}.detail-axis-row.primary{font-weight:600}.detail-clinical-note{font-size:12px;color:var(--text-dim);padding-left:8px;border-left:2px solid;margin:4px 0}.detail-differential{margin:8px 0}.detail-differential p{font-size:12px;color:var(--text-dim);line-height:1.5}.mono-val{font-family:SF Mono,Menlo,monospace}.correction-preview{display:flex;flex-direction:column;gap:12px;padding:16px 0;border-top:1px solid var(--border)}.correction-preview-hint{font-size:12px;color:var(--text-dim);line-height:1.5}.correction-preview-images{display:flex;gap:12px;align-items:center;justify-content:center}.correction-preview-side{display:flex;flex-direction:column;align-items:center;gap:8px}.correction-preview-canvas{max-width:200px;max-height:200px;border-radius:8px;border:1px solid var(--border)}.correction-preview-divider{width:1px;height:180px;background:var(--border);flex-shrink:0}.correction-preview-label{font-size:12px;color:var(--text-dim);font-weight:600}.correction-preview-answer{font-size:12px;color:var(--text-dim);text-align:center}.correction-preview-triple{display:flex;gap:8px;align-items:center;justify-content:center}.correction-preview-triple .correction-preview-canvas{max-width:160px;max-height:160px}.correction-preview-triple .correction-preview-divider{height:140px}.feedback-widget{margin-top:24px;padding-top:20px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:12px}.feedback-title{font-size:15px;font-weight:600;text-align:center;color:var(--text-dim)}.feedback-rating-label{font-size:13px;color:var(--text-dim);text-align:center}.feedback-stars{display:flex;justify-content:center;gap:8px}.feedback-star{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:4px;border-radius:4px;transition:all .1s}.feedback-star:hover{transform:scale(1.15)}.feedback-star.active{color:#facc15}.feedback-comment{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:13px;font-family:inherit;resize:vertical;outline:none;transition:border-color .15s}.feedback-comment:focus{border-color:var(--accent)}.feedback-comment::placeholder{color:var(--text-dim);opacity:.7}.feedback-submit-btn{padding:10px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.feedback-submit-btn:hover:not(:disabled){background:var(--accent-hover)}.feedback-submit-btn:disabled{opacity:.55;cursor:not-allowed}.feedback-thanks{font-size:14px;font-weight:600;text-align:center;padding:12px 0;color:var(--accent)}@media(max-width:768px){.main{flex-direction:column}.sidebar{width:100%;min-width:0;border-right:none;border-bottom:1px solid var(--border);max-height:40vh}}
