*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100dvh;overflow:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#fff;color:#1a1a1a;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased}#root{display:flex;flex-direction:column}header{display:flex;align-items:center;gap:12px;padding:0 20px;height:48px;background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0}header h1{font-size:.9rem;color:#111827;font-weight:600;letter-spacing:-.01em}main{flex:1;display:grid;grid-template-columns:240px 1fr 280px;min-height:0;overflow:hidden}#slide-panel{padding:16px 12px;background:#fafafa;border-right:1px solid #e5e7eb;overflow-y:auto}#slide-panel h2{font-size:.7rem;margin-bottom:10px;color:#9ca3af;text-transform:uppercase;letter-spacing:.06em;font-weight:600;padding:0 6px}#slide-list{list-style:none}#slide-list li{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;cursor:pointer;font-size:.8rem;color:#374151;margin-bottom:4px;transition:background .12s ease}#slide-list li:hover{background:#f0f0f0}#slide-list li.active{background:#2563eb;color:#fff;font-weight:600}.slide-thumb{width:48px;height:48px;border-radius:6px;object-fit:cover;background:#e5e7eb;flex-shrink:0}.slide-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#progress-section{position:absolute;bottom:0;left:0;right:0;padding:8px 16px;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10}.progress-bar{height:4px;background:#e5e7eb;border-radius:999px;overflow:hidden;margin-bottom:6px}#progress-fill{height:100%;width:0%;background:linear-gradient(90deg,#2563eb,#3b82f6);transition:width .3s ease;border-radius:999px}#progress-msg{font-size:.75rem;color:#9ca3af}#viewer-container{position:relative;background:#f3f4f6;overflow:hidden;min-height:0}#osd-viewer{width:100%;height:100%}#cell-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}#viewer-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.placeholder-content{text-align:center;max-width:400px;padding:40px}.placeholder-content h2{font-size:1.5rem;font-weight:700;color:#1a1a1a;margin-bottom:12px}.placeholder-desc{font-size:.95rem;color:#374151;line-height:1.5;margin-bottom:16px}.placeholder-formats{font-size:.8rem;color:#6b7280;margin-bottom:8px}.placeholder-formats code{font-size:.75rem;background:#e5e7eb;padding:2px 6px;border-radius:3px}#stats-panel{padding:20px 16px;background:#fafafa;border-left:1px solid #e5e7eb;overflow-y:auto}#stats-panel h2{font-size:.7rem;margin-bottom:8px;color:#9ca3af;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.diagnosis-section{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.cancer-count{font-size:1.8rem;font-weight:700;color:#16a34a;margin-bottom:6px;letter-spacing:-.02em;line-height:1.2}.cancer-count span{font-size:.8rem;color:#9ca3af;font-weight:400;letter-spacing:0}.diagnosis-ratio{font-size:.78rem;color:#374151;margin-bottom:4px}.diagnosis-ratio strong{color:#16a34a}.diagnosis-confidence{font-size:.75rem;color:#6b7280}.diagnosis-confidence strong{color:#374151}.celltypes-section{margin-bottom:12px}.celltypes-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px;border:1px solid #e5e7eb;border-radius:6px;background:#fff;cursor:pointer;font-size:.78rem;color:#374151;font-weight:500}.celltypes-toggle:hover{background:#f9fafb}.celltypes-list{padding-top:6px}.legend-item{display:flex;align-items:center;gap:6px;padding:5px 6px;border:none;background:none;border-radius:4px;cursor:pointer;font-size:.75rem;color:#374151;text-align:left;width:100%;transition:opacity .15s}.legend-item:hover{background:#f0f0f0}.legend-dimmed{opacity:.35}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.legend-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.legend-count{color:#9ca3af;font-variant-numeric:tabular-nums;flex-shrink:0}.legend-visibility{flex-shrink:0;font-size:.6rem;color:#9ca3af;width:12px;text-align:center}.legend-dimmed .legend-visibility{color:#d1d5db}.confidence-section{margin-top:16px}.confidence-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:6px 8px;border:1px solid #e5e7eb;border-radius:6px;background:#fff;cursor:pointer;font-size:.72rem;color:#6b7280}.confidence-toggle:hover{background:#f9fafb}.chevron{font-size:.7rem}.confidence-warnings{padding:8px 0 0}.confidence-warn-row{display:flex;justify-content:space-between;padding:3px 8px;font-size:.72rem}.warn-conf{color:#d97706;font-variant-numeric:tabular-nums}#viewer-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#f3f4f6;z-index:5}.loading-spinner{width:32px;height:32px;border:3px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}#zoom-indicator{position:absolute;bottom:12px;left:12px;background:#0009;color:#fff;font-size:.72rem;font-weight:600;padding:3px 8px;border-radius:4px;pointer-events:none;z-index:4;font-variant-numeric:tabular-nums}#capped-hint{position:absolute;bottom:12px;left:50%;transform:translate(-50%);background:#0009;color:#fff;font-size:.8rem;padding:6px 14px;border-radius:6px;pointer-events:none;z-index:4}.cell-tooltip{position:absolute;display:flex;align-items:center;gap:6px;background:#000c;color:#fff;font-size:.72rem;padding:4px 10px;border-radius:4px;pointer-events:none;z-index:6;white-space:nowrap}.tooltip-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.tooltip-conf{color:#aaa;font-variant-numeric:tabular-nums}.upload-zone{margin-top:12px;border:2px dashed #d1d5db;border-radius:8px;padding:16px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}.upload-zone:hover{border-color:#9ca3af;background:#f0f0f0}.upload-zone.drag-over{border-color:#2563eb;background:#eff6ff}.upload-label{font-size:.75rem;color:#6b7280}.upload-error{font-size:.72rem;color:#dc2626;margin-top:6px;padding:0 4px}.confidence-body{padding:8px 0 0}.confidence-slider-row{display:flex;align-items:center;gap:8px;padding:0 8px 6px;font-size:.72rem;color:#6b7280}.confidence-slider-row label{flex-shrink:0}.confidence-slider-row input[type=range]{flex:1;height:4px;accent-color:#d97706}.conf-value{font-variant-numeric:tabular-nums;width:32px;text-align:right;flex-shrink:0}.confidence-ok{font-size:.72rem;color:#6b7280;padding:4px 8px}#error-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100dvh;gap:12px;font-family:Inter,sans-serif}#error-fallback h2{font-size:1.2rem;color:#1a1a1a}#error-fallback p{font-size:.85rem;color:#6b7280;max-width:400px;text-align:center}#error-fallback button{padding:8px 20px;border:1px solid #e5e7eb;border-radius:6px;background:#fff;cursor:pointer;font-size:.85rem}#error-fallback button:hover{background:#f9fafb}.hidden{display:none!important}.doc-page{min-height:100dvh;background:#fff;color:#1a1a1a;overflow-y:auto}.doc-nav{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:12px;padding:0 24px;height:48px;background:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid #e5e7eb}.doc-nav a{font-size:.82rem;color:#2563eb;text-decoration:none;font-weight:500}.doc-nav a:hover{text-decoration:underline}.doc-nav span{font-size:.82rem;color:#9ca3af}.doc-hero{padding:72px 24px 48px;text-align:center;background:linear-gradient(180deg,#eff6ff,#fff)}.doc-hero h1{font-size:2.4rem;font-weight:800;letter-spacing:-.03em;color:#111827;margin-bottom:12px}.doc-hero p{font-size:1.05rem;color:#4b5563;max-width:560px;margin:0 auto 20px;line-height:1.6}.doc-hero-links{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.doc-hero-links a{font-size:.82rem;padding:6px 14px;border-radius:6px;border:1px solid #d1d5db;color:#374151;text-decoration:none;font-weight:500;transition:background .12s}.doc-hero-links a:hover{background:#f3f4f6}.doc-body{position:relative}.doc-sidebar{position:fixed;top:48px;left:0;width:224px;height:calc(100dvh - 48px);z-index:5;display:flex;align-items:flex-start;pointer-events:none}.doc-sidebar-nav{pointer-events:auto;margin-top:32px;margin-left:16px;padding:14px 0;display:flex;flex-direction:column;gap:0;background:#ffffffe0;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid rgba(0,0,0,.06);border-radius:12px;box-shadow:0 1px 2px #0000000a,0 4px 16px #00000008;width:100%}.doc-sidebar-title{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:#b0b5bd;font-weight:600;padding:2px 14px 8px}.doc-sidebar-link{display:flex;align-items:baseline;gap:6px;padding:5px 14px;font-size:.73rem;color:#8b919a;text-decoration:none;line-height:1.4;transition:color .15s,background .15s;border-left:2px solid transparent;margin:0 2px;border-radius:0 4px 4px 0}.doc-sidebar-link:hover{color:#4b5563;background:#00000006}.doc-sidebar-link.active{color:#2563eb;background:#2563eb0f;border-left-color:#2563eb;font-weight:500}.doc-sidebar-num{font-size:.62rem;font-weight:600;color:#d1d5db;min-width:11px;flex-shrink:0}.doc-sidebar-link.active .doc-sidebar-num{color:#93b4f4}.doc-content{max-width:860px;margin:0 auto;padding:0 24px 80px}@media(max-width:1200px){.doc-sidebar{display:none}}.doc-section{margin-bottom:56px}.doc-section h2{font-size:1.35rem;font-weight:700;color:#111827;margin-bottom:12px;letter-spacing:-.02em}.doc-section h3{font-size:1rem;font-weight:600;color:#374151;margin-bottom:8px}.doc-section p{font-size:.92rem;color:#4b5563;line-height:1.7;margin-bottom:12px}.diagram-wrapper{overflow-x:auto;margin:20px 0;padding:24px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px}.diagram-wrapper svg{display:block;margin:0 auto;max-width:100%;height:auto}.celltype-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-top:16px}.celltype-card{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;background:#f9fafb;border:1px solid #e5e7eb;font-size:.82rem;color:#374151;font-weight:500}.celltype-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.category-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:#9ca3af;font-weight:600;margin-top:20px;margin-bottom:8px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-top:16px}.stat-card{padding:20px;border-radius:10px;background:#f9fafb;border:1px solid #e5e7eb}.stat-value{font-size:1.6rem;font-weight:700;color:#2563eb;letter-spacing:-.02em}.stat-label{font-size:.78rem;color:#6b7280;margin-top:4px;line-height:1.4}.comparison-table{width:100%;border-collapse:collapse;margin-top:16px;font-size:.85rem}.comparison-table th,.comparison-table td{padding:10px 14px;text-align:left;border-bottom:1px solid #e5e7eb}.comparison-table th{background:#f9fafb;font-weight:600;color:#374151;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}.comparison-table td{color:#4b5563;line-height:1.5}.comparison-table tr:last-child td{border-bottom:none}.callout{padding:12px 16px;background:#eff6ff;border-left:3px solid #2563eb;border-radius:0 8px 8px 0;font-size:.85rem;color:#1e40af;margin:16px 0;font-weight:500}.callout-list{list-style:none;padding:0;margin:16px 0}.callout-list li{padding:10px 16px;background:#f9fafb;border-left:3px solid #d1d5db;border-radius:0 8px 8px 0;font-size:.85rem;color:#4b5563;line-height:1.6;margin-bottom:8px}.doc-footer{max-width:860px;margin:0 auto;padding:24px 24px 48px;border-top:1px solid #e5e7eb;display:flex;gap:16px;flex-wrap:wrap}.doc-footer a{font-size:.82rem;color:#2563eb;text-decoration:none}.doc-footer a:hover{text-decoration:underline}
