*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #080c14;--surface: #0f1520;--card: #141c2b;--card2: #1a2235;--border: #1e2d42;--border2: #253348;--text: #e2e8f0;--text-2: #94a3b8;--text-3: #4a5568;--accent: #63cab7;--accent-b: #4a9eff;--accent-am: #fbbf24;--radius: 12px;--radius-sm: 7px;font-family:Inter,system-ui,-apple-system,sans-serif;color-scheme:dark}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased}.dropzone-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(99,202,183,.08) 0%,transparent 70%),radial-gradient(ellipse 60% 40% at 80% 80%,rgba(74,158,255,.05) 0%,transparent 60%),var(--bg)}.dropzone-hero{display:flex;flex-direction:column;align-items:center;gap:20px;padding:40px 24px;max-width:520px;width:100%;position:relative}.hero-glow{position:absolute;top:-60px;width:300px;height:300px;background:radial-gradient(circle,rgba(99,202,183,.12) 0%,transparent 70%);pointer-events:none;z-index:0}.hero-icon{width:80px;height:80px;position:relative;z-index:1}.hero-title{font-size:28px;font-weight:700;letter-spacing:-.5px;background:linear-gradient(135deg,#e2e8f0,#63cab7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;z-index:1}.hero-sub{color:var(--text-2);font-size:13px;text-align:center;position:relative;z-index:1}.dropzone{width:100%;border:1.5px dashed var(--border2);border-radius:var(--radius);padding:40px 24px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;background:var(--card);transition:border-color .2s,background .2s,transform .15s;position:relative;z-index:1}.dropzone:hover,.dropzone.dragging{border-color:var(--accent);background:#63cab70a;transform:scale(1.01)}.dz-icon{width:40px;height:40px;color:var(--accent);opacity:.8}.dz-main{font-size:16px;font-weight:600;color:var(--text)}.dz-sub{font-size:12px;color:var(--text-3);letter-spacing:.02em}.format-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;position:relative;z-index:1}.format-chip{font-size:11px;padding:4px 10px;border-radius:99px;border:1px solid color-mix(in srgb,var(--chip-color) 40%,transparent);color:var(--chip-color);background:color-mix(in srgb,var(--chip-color) 8%,transparent);letter-spacing:.02em}.app{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(ellipse 100% 40% at 50% 0%,rgba(99,202,183,.04) 0%,transparent 60%),var(--bg)}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:52px;border-bottom:1px solid var(--border);background:#080c14e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:10px}.app-logo{display:flex;align-items:center}.logo-icon{width:22px;height:22px;color:var(--accent)}.app-name{font-size:15px;font-weight:600;color:var(--text);letter-spacing:-.2px}.btn-load{font-size:12px;font-weight:500;padding:6px 14px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--card2);color:var(--text-2);cursor:pointer;transition:border-color .15s,color .15s,background .15s;font-family:inherit}.btn-load:hover{border-color:var(--accent);color:var(--accent);background:#63cab70f}.loading-bar{height:2px;background:var(--border);overflow:hidden}.loading-inner{height:100%;width:40%;background:linear-gradient(90deg,var(--accent),var(--accent-b));animation:slide 1.2s ease-in-out infinite}@keyframes slide{0%{transform:translate(-100%)}to{transform:translate(350%)}}.error-banner{display:flex;align-items:flex-start;gap:12px;margin:16px 24px 0;padding:14px 18px;border-radius:var(--radius);background:#ef444414;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.err-icon{width:18px;height:18px;flex-shrink:0;margin-top:1px}.err-msg{font-family:JetBrains Mono,monospace;font-size:12.5px;white-space:pre-wrap;flex:1}.btn-retry{font-size:12px;padding:4px 12px;border-radius:6px;border:1px solid rgba(239,68,68,.4);background:transparent;color:#fca5a5;cursor:pointer;font-family:inherit;flex-shrink:0}.meta-bar{display:flex;flex-wrap:wrap;gap:7px;padding:12px 24px;border-bottom:1px solid var(--border);background:var(--surface)}.meta-badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;padding:3px 10px;border-radius:99px;border:1px solid var(--border2);color:var(--text-2);background:var(--card);letter-spacing:.01em;white-space:nowrap}.badge-name{font-weight:600;color:var(--text);border-color:var(--border2);max-width:280px;overflow:hidden;text-overflow:ellipsis}.badge-icon{font-size:12px}.main-layout{display:grid;grid-template-columns:auto 1fr;gap:16px;padding:16px 24px 24px;flex:1;align-items:start;overflow:auto}@media (max-width: 1100px){.main-layout{grid-template-columns:1fr}}.panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.panel-header{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);background:#ffffff04}.panel-title{font-size:13px;font-weight:600;color:var(--text);letter-spacing:-.1px;flex-shrink:0}.time-display{font-size:12px;font-family:JetBrains Mono,monospace;color:var(--accent);margin-left:auto}.btn-clear{font-size:11px;padding:3px 10px;border-radius:6px;border:1px solid rgba(99,202,183,.3);background:#63cab70f;color:var(--accent);cursor:pointer;font-family:inherit;margin-left:auto}.btn-clear:hover{background:#63cab71f}.panel-hint{font-size:11px;color:var(--text-3);margin-left:auto}.heatmap-container{padding:16px;display:flex;flex-direction:column;align-items:center;gap:12px;overflow-x:auto}.plate-svg{display:block}.plate-label{fill:#4a5568;font-family:JetBrains Mono,monospace;font-weight:500}.color-bar{display:flex;align-items:center;gap:10px;width:100%;max-width:340px}.cb-swatch{flex:1;height:10px;border-radius:99px;border:1px solid rgba(255,255,255,.06)}.cb-label{font-size:10.5px;font-family:JetBrains Mono,monospace;color:var(--text-3);white-space:nowrap;min-width:36px}.cb-label:last-child{text-align:right}.well-tooltip{pointer-events:none;z-index:999;background:var(--card2);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:8px 12px;font-size:12px;box-shadow:0 8px 24px #0006;min-width:90px}.tt-pos{font-family:JetBrains Mono,monospace;color:var(--accent);font-weight:600;font-size:13px}.tt-name{color:var(--text-2);margin-top:2px}.tt-val{color:var(--text);margin-top:4px;font-family:JetBrains Mono,monospace;font-size:13px}.time-slider-wrap{display:flex;align-items:center;gap:10px;width:100%;padding:4px 16px 8px}.slider-label{font-size:10.5px;font-family:JetBrains Mono,monospace;color:var(--text-3);white-space:nowrap;min-width:38px}.slider-label:last-child{text-align:right}.time-slider{flex:1;-webkit-appearance:none;height:4px;border-radius:99px;background:var(--border2);outline:none;cursor:pointer}.time-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);cursor:pointer;transition:transform .1s}.time-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.stats-bar{display:flex;border-top:1px solid var(--border);width:100%}.stat-cell{flex:1;padding:8px 6px;text-align:center;border-right:1px solid var(--border)}.stat-cell:last-child{border-right:none}.stat-label{font-size:9.5px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}.stat-val{font-size:12px;font-family:JetBrains Mono,monospace;color:var(--text);font-weight:500}.chart-container{padding:12px 8px 8px}.chart-note{font-size:11px;color:var(--text-3);text-align:center;padding:8px}.endpoint-table-wrap{max-height:380px;overflow-y:auto;padding:8px 0;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.endpoint-table{width:100%;border-collapse:collapse;font-size:12.5px}.endpoint-table th{position:sticky;top:0;background:var(--card);padding:7px 16px;text-align:left;font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border)}.endpoint-table td{padding:6px 16px;border-bottom:1px solid rgba(255,255,255,.03);color:var(--text-2)}.endpoint-table tr:hover td{background:#ffffff06}.cell-mono{font-family:JetBrains Mono,monospace;font-size:11.5px;color:var(--accent)!important}.cell-val{font-family:JetBrains Mono,monospace;color:var(--text)!important;font-weight:500}.no-data{padding:24px;color:var(--text-3);text-align:center;font-size:13px}.well-legend{border-top:1px solid var(--border);padding:12px 16px}.legend-title{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px}.legend-grid{display:flex;flex-wrap:wrap;gap:6px;max-height:120px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.legend-item{display:flex;align-items:center;gap:6px;padding:3px 8px;border-radius:6px;cursor:pointer;border:1px solid transparent;transition:border-color .15s,background .15s}.legend-item:hover{background:#ffffff0a}.legend-item.selected{border-color:#63cab766;background:#63cab70f}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.legend-pos{font-family:JetBrains Mono,monospace;font-size:10.5px;color:var(--text-3)}.legend-name{font-size:11px;color:var(--text-2);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}.header-right{display:flex;align-items:center;gap:8px}.btn-label{font-size:12px;font-weight:500;padding:6px 14px;border-radius:var(--radius-sm);border:1px solid rgba(99,202,183,.35);background:#63cab70f;color:var(--accent);cursor:pointer;transition:background .15s,border-color .15s;font-family:inherit}.btn-label:hover{background:#63cab71f;border-color:var(--accent)}.btn-export-hdr{font-size:12px;font-weight:500;padding:6px 14px;border-radius:var(--radius-sm);border:1px solid rgba(74,158,255,.35);background:#4a9eff0f;color:var(--accent-b);cursor:pointer;transition:background .15s,border-color .15s;font-family:inherit}.btn-export-hdr:hover{background:#4a9eff1f;border-color:var(--accent-b)}.panel-samples{min-width:260px;max-width:340px}.sample-list{max-height:420px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.sample-row{display:flex;align-items:center;gap:10px;padding:7px 16px;border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;transition:background .12s}.sample-row:hover{background:#ffffff08}.sample-row.sample-selected{background:#63cab712;border-color:#63cab71f}.sample-id{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--accent);min-width:28px}.sample-name{font-size:12px;color:var(--text-2);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sample-val{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--text);font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal-panel{background:var(--card);border:1px solid var(--border2);border-radius:var(--radius);display:flex;flex-direction:column;max-height:90vh;box-shadow:0 24px 64px #0009;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-title{font-size:14px;font-weight:600;color:var(--text);letter-spacing:-.2px}.modal-close{width:26px;height:26px;border-radius:6px;border:none;background:transparent;color:var(--text-3);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s}.modal-close:hover{background:#ffffff12;color:var(--text)}.modal-footer{display:flex;align-items:center;gap:10px;padding:12px 18px;border-top:1px solid var(--border);flex-shrink:0}.footer-note{font-size:11px;color:var(--text-3);flex:1;font-style:italic}.btn-cancel{font-size:12px;padding:7px 16px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:transparent;color:var(--text-2);cursor:pointer;font-family:inherit;transition:border-color .12s,color .12s}.btn-cancel:hover{border-color:var(--text-3);color:var(--text)}.btn-save{font-size:12px;font-weight:500;padding:7px 18px;border-radius:var(--radius-sm);border:1px solid rgba(99,202,183,.4);background:#63cab71a;color:var(--accent);cursor:pointer;font-family:inherit;transition:background .12s,border-color .12s}.btn-save:hover{background:#63cab72e;border-color:var(--accent)}.btn-export{font-size:12px;font-weight:500;padding:7px 18px;border-radius:var(--radius-sm);border:1px solid rgba(74,158,255,.4);background:#4a9eff1a;color:var(--accent-b);cursor:pointer;font-family:inherit;transition:background .12s,border-color .12s}.btn-export:hover{background:#4a9eff2e;border-color:var(--accent-b)}.labeler-panel{width:480px}.labeler-toolbar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);background:#ffffff04;flex-shrink:0;flex-wrap:wrap}.toolbar-filter{width:100px;font-size:12px;padding:5px 10px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--surface);color:var(--text);font-family:inherit;outline:none}.toolbar-filter:focus{border-color:var(--accent)}.toolbar-divider{width:1px;height:20px;background:var(--border);flex-shrink:0}.toolbar-btn{font-size:11px;padding:5px 10px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:transparent;color:var(--text-2);cursor:pointer;font-family:inherit;white-space:nowrap}.toolbar-btn:hover{border-color:var(--text-3);color:var(--text)}.bulk-input{flex:1;min-width:100px;font-size:12px;padding:5px 10px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--surface);color:var(--text);font-family:inherit;outline:none}.bulk-input:focus{border-color:var(--accent)}.btn-assign{font-size:11px;font-weight:500;padding:5px 12px;border-radius:var(--radius-sm);border:1px solid rgba(99,202,183,.35);background:#63cab714;color:var(--accent);cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .12s}.btn-assign:disabled{opacity:.4;cursor:default}.btn-assign:not(:disabled):hover{background:#63cab726}.labeler-list{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.labeler-list-header{display:flex;align-items:center;padding:6px 16px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:1}.lh-id{font-size:10px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;width:50px}.lh-name{font-size:10px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em}.labeler-row{display:flex;align-items:center;gap:10px;padding:5px 16px;border-bottom:1px solid rgba(255,255,255,.025);cursor:pointer;transition:background .1s}.labeler-row:hover{background:#ffffff08}.labeler-row.row-selected{background:#63cab712}.row-id{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--accent);width:40px;flex-shrink:0}.row-input{flex:1;font-size:12px;padding:4px 8px;border-radius:5px;border:1px solid transparent;background:transparent;color:var(--text);font-family:inherit;outline:none;transition:border-color .12s,background .12s}.row-input:focus{border-color:var(--border2);background:var(--surface)}.labeler-empty{padding:20px;color:var(--text-3);text-align:center;font-size:12px}.export-panel{width:560px}.export-options{display:flex;flex-direction:column;gap:14px;padding:16px 18px;border-bottom:1px solid var(--border);flex-shrink:0}.opt-group{display:flex;align-items:center;gap:12px}.opt-label{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;width:80px;flex-shrink:0}.opt-row{display:flex;gap:6px}.opt-btn{font-size:11.5px;padding:5px 12px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:transparent;color:var(--text-2);cursor:pointer;font-family:inherit;transition:border-color .12s,color .12s,background .12s}.opt-btn:hover{border-color:var(--text-3);color:var(--text)}.opt-btn.active{border-color:#4a9eff80;background:#4a9eff1a;color:var(--accent-b)}.opt-tag{font-size:12px;color:var(--text-2);padding:4px 10px;border-radius:var(--radius-sm);background:var(--card2);border:1px solid var(--border)}.export-preview{flex:1;overflow:hidden;display:flex;flex-direction:column;padding:14px 18px;gap:8px;min-height:0}.preview-label{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;flex-shrink:0}.preview-scroll{overflow:auto;flex:1;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.preview-table{border-collapse:collapse;font-size:11.5px;width:100%}.preview-table td{padding:5px 10px;border-bottom:1px solid rgba(255,255,255,.04);border-right:1px solid rgba(255,255,255,.04);white-space:nowrap;color:var(--text-2);font-family:JetBrains Mono,monospace}.preview-head-row td{font-weight:600;color:var(--text);background:#ffffff05;border-bottom-color:var(--border)}.preview-empty{color:var(--text-3);font-size:10px}.preview-more{color:var(--accent-b);font-size:10.5px;font-style:italic}.section-panel{margin:24px 0 0;border-top:1px solid var(--border);padding-top:20px}.section-panel-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.section-panel-title{font-size:15px;font-weight:600;color:var(--text);margin:0}.section-badge{font-size:11px;font-weight:500;color:var(--accent-b);background:#4a9eff1f;border:1px solid rgba(74,158,255,.2);border-radius:4px;padding:2px 7px;text-transform:capitalize}.opt-channel-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.opt-channel-tag{background:#1e2d42;border:1px solid #2d4060;border-radius:4px;padding:2px 8px;font-size:11px;color:#8fb3d4;font-family:monospace}
