@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*{box-sizing:border-box;margin:0;padding:0}:root{--stemtracer-primary:#ff7a7a;--stemtracer-primary-hover:#ff6161;--stemtracer-dark:#0d3b31;--stemtracer-dark-hover:#1a4d42;--stemtracer-border:#e0e0e0;--stemtracer-bg:#f8f9fa}html,body,#root{height:100%;overflow:hidden}body{background:var(--stemtracer-bg);color:#1a1a1a;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.btn{cursor:pointer;border:none;border-radius:6px;width:100%;margin-bottom:8px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:all .2s}.btn-primary{background:var(--stemtracer-primary);color:#fff}.btn-primary:hover{background:var(--stemtracer-primary-hover)}.btn-secondary{color:#374151;background:#f3f4f6}.btn-secondary:hover{background:#e5e7eb}.tbtn{cursor:pointer;white-space:nowrap;color:#374151;background:#fff;border:1px solid #e5e7eb;border-radius:6px;align-items:center;gap:4px;padding:5px 10px;font-family:inherit;font-size:11.5px;font-weight:500;line-height:1;transition:all .15s;display:inline-flex}.tbtn:hover{background:#f9fafb;border-color:#d1d5db}.tbtn.tbtn-primary{color:#fff;background:#ff7a7a;border-color:#ff7a7a}.tbtn.tbtn-primary:hover{background:#ff6161;border-color:#ff6161}.tbtn.tbtn-green{color:#fff;background:#0d3b31;border-color:#0d3b31}.tbtn.tbtn-green:hover{background:#1a4d42;border-color:#1a4d42}.form-group{margin-bottom:14px}.form-label{color:#374151;margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-control{border:1px solid #d1d5db;border-radius:6px;width:100%;padding:9px 12px;font-family:inherit;font-size:14px}.section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:20px;padding:20px}.stats-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;display:grid}.stat-card{background:#f9fafb;border-radius:6px;padding:12px}.stat-label{color:#6b7280;margin-bottom:4px;font-size:11px}.stat-value{color:#111827;font-size:18px;font-weight:600}.info{color:#1e40af;background:#dbeafe;border-left:4px solid #3b82f6;border-radius:6px;margin-bottom:16px;padding:12px 16px;font-size:13px}.warning{color:#92400e;background:#fef3c7;border-left:4px solid #f59e0b;border-radius:6px;margin-bottom:16px;padding:12px 16px;font-size:13px}.upload-zone{text-align:center;cursor:pointer;background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;padding:32px 20px;transition:all .2s}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--stemtracer-primary);background:#fff0f0}.file-list{margin-top:12px;list-style:none}.file-item{background:#f9fafb;border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:6px;padding:10px 12px;font-size:13px;display:flex}.file-item .remove-btn{color:#ef4444;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:16px}.scrollable-field{resize:vertical;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;min-height:80px;padding:8px;overflow-y:auto}.nav-pill{color:#2d3748;cursor:pointer;text-align:left;background:#f0f2f5;border:none;border-radius:10px;justify-content:space-between;align-items:center;width:100%;margin-bottom:6px;padding:11px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s;display:flex}.nav-pill:hover{background:#e4e7ec}.nav-pill.active{color:#fff!important;background:#c0544f!important}.nav-pill-left{align-items:center;gap:9px;display:flex}.nav-sub-group{margin-left:16px}.graph-container{background:#fff;border:1px solid #e5e7eb;border-radius:8px;min-width:0;margin-bottom:20px;padding:20px;position:relative}.chart-wrapper{width:100%;height:0;padding-bottom:75%;position:relative}.chart-wrapper canvas{position:absolute;top:0;left:0;width:100%!important;height:100%!important}.plate-container{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:20px;padding:20px;position:relative}.plate-grid{background:#e5e7eb;border-radius:8px;gap:3px;padding:8px;display:inline-grid}.well{cursor:pointer;border:1px solid #0000000d;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;width:70px;height:70px;font-size:10px;transition:all .2s;display:flex}.well:hover{z-index:10;transform:scale(1.05);box-shadow:0 4px 12px #00000026}.well-label{opacity:.7;margin-bottom:2px;font-size:9px;font-weight:600}.well-gene{margin-bottom:3px;font-size:10px;font-weight:600}.well-value{font-size:11px;font-weight:700}.row-label,.col-label{color:#6b7280;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.gene-item{cursor:pointer;border-radius:4px;align-items:center;gap:8px;margin:4px 0;padding:6px 12px;font-size:12px;transition:all .2s;display:flex}.gene-item:hover{background:#f3f4f6}.gene-item.selected{color:var(--stemtracer-primary);background:#eef2ff;font-weight:500}.sample-checkbox-item{cursor:pointer;border-radius:4px;align-items:center;gap:8px;margin:4px 0;padding:6px 8px;font-size:13px;transition:all .2s;display:flex}.sample-checkbox-item:hover{background:#f3f4f6}.gene-order-item,.unified-sample-item{cursor:move;-webkit-user-select:none;user-select:none;background:#fff;border:1px solid #e5e7eb;border-radius:4px;align-items:center;gap:8px;margin:4px 0;padding:8px 12px;transition:all .2s;display:flex}.unified-sample-item{cursor:default}.unified-sample-item.checked{cursor:move;background:#f0fdf4;border-color:#86efac}.gene-order-item:hover,.unified-sample-item.checked:hover{background:#f3f4f6;border-color:#d1d5db}.gene-order-item.dragging,.unified-sample-item.dragging{opacity:.5}.download-btn{cursor:pointer;z-index:5;background:#fff;border:1px solid #e5e7eb;border-radius:6px;align-items:center;gap:4px;padding:6px 12px;font-size:11px;font-weight:500;transition:all .2s;display:flex;position:absolute;top:10px;right:10px}.download-btn:hover{border-color:var(--stemtracer-primary);color:var(--stemtracer-primary);background:#f3f4f6}.filter-summary{z-index:1000;background:#fff;border-bottom:1px solid #e5e7eb;margin:0 -24px 16px;padding:10px 16px;font-size:13px;position:sticky;top:0;box-shadow:0 4px 6px -1px #0000001a}.toolbar-strip{scrollbar-width:none;flex-wrap:nowrap;align-items:center;gap:8px;display:flex;overflow-x:auto}.toolbar-strip::-webkit-scrollbar{display:none}.toolbar-divider{background:#e5e7eb;flex-shrink:0;width:1px;height:28px}.toolbar-label{color:#6b7280;white-space:nowrap;flex-shrink:0;font-size:11px;font-weight:600}.filter-tag{color:var(--stemtracer-primary);background:#eef2ff;border-radius:12px;margin:4px 4px 4px 0;padding:4px 10px;font-size:12px;font-weight:500;display:inline-block}.svm-btn{cursor:pointer;text-align:left;background:#f9fafb;border:1px solid #e5e7eb;border-radius:7px;align-items:center;gap:10px;width:100%;margin-bottom:2px;padding:9px 10px;font-family:inherit;transition:background .12s,border-color .12s;display:flex}.svm-btn:hover{background:#eff6ff;border-color:#6366f1}.svm-icon{flex-shrink:0;font-size:16px}.svm-label{color:#1e293b;flex:1;font-size:13px;font-weight:600}.svm-sub{color:#6b7280;text-overflow:ellipsis;white-space:nowrap;max-width:240px;margin-top:1px;font-size:11px;display:block;overflow:hidden}@media (width<=768px){html,body,#root{height:auto;overflow:auto}.stats-grid{grid-template-columns:1fr!important}.section{padding:12px!important}.btn,button{min-height:44px}.form-control,input,select,textarea{min-height:44px;padding:10px 12px!important;font-size:16px!important}}
