*{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,sans-serif;background:#1a1a1a;color:#fff;min-height:100vh}#app{padding:20px;max-width:1400px;margin:0 auto}.hidden{display:none!important}#file-select{text-align:center;padding:40px}#status{margin-top:10px;color:#888}#video-container{position:relative;background:#000}#video{width:100%;max-width:960px;max-height:540px;display:block}#overlay{display:block;background:#1a1a1a}#info-panel{display:flex;gap:30px;padding:15px;background:#2a2a2a;font-family:monospace}#info-panel>div span{color:#4a9eff}#mouse-mode{display:flex;align-items:center;gap:10px}#mouse-mode label{display:flex;align-items:center;gap:4px;cursor:pointer}#mouse-mode input[type=radio]{cursor:pointer}#recenter-interval{width:60px;padding:2px 4px;border:1px solid #555;border-radius:4px;background:#333;color:#fff;text-align:right}#recenter-interval:disabled{opacity:.4;cursor:not-allowed}#recenter-label:has(#recenter-interval:disabled){opacity:.5}#usage-hint{font-size:11px;color:#777;line-height:1.5;margin-top:12px;padding:10px 12px;background:#1a1a1a;border-radius:6px;border:1px solid #333}#usage-hint p{margin:3px 0}#usage-hint strong{color:#999}#loading-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000c;color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;z-index:100;pointer-events:none}#viewer-layout{display:flex;gap:20px}#viewer-main{flex:1;min-width:0}#side-panel{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:12px}#side-panel details{background:#2a2a2a;border-radius:6px;overflow:hidden}#side-panel summary{padding:10px 14px;background:#333;cursor:pointer;font-weight:500;font-size:13px;-webkit-user-select:none;user-select:none}#side-panel summary:hover{background:#3a3a3a}#side-panel details[open] summary{border-bottom:1px solid #444}#window-info{padding:12px 14px;font-family:monospace;font-size:12px;line-height:1.6}#window-info .title{color:#4a9eff;word-break:break-all}#window-info .coords{color:#888}#window-info .placeholder{color:#666;font-style:italic}#mcap-info{padding:12px 14px;font-family:monospace;font-size:11px;line-height:1.5;max-height:400px;overflow-y:auto}#mcap-info .placeholder{color:#666;font-style:italic}#mcap-info .section{margin-bottom:12px}#mcap-info .section-title{color:#4a9eff;font-weight:500;margin-bottom:4px}#mcap-info .topic-row{display:flex;justify-content:space-between;padding:2px 0;border-bottom:1px solid #333}#mcap-info .topic-name{color:#aaa}#mcap-info .topic-count{color:#666}#mcap-info .time-range{color:#888;margin-top:8px}@media(max-width:900px){#viewer-layout{flex-direction:column}#side-panel{width:100%;flex-direction:row;flex-wrap:wrap}#side-panel details{flex:1;min-width:200px}}.landing-bg{position:fixed;inset:0;background:linear-gradient(135deg,#0f0f23,#1a1a2e,#16213e)}.landing-overlay{position:fixed;inset:0;background:#0006}.landing-content{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 20px;text-align:center;font-family:Inter,system-ui,sans-serif;color:#fff}.landing-content h1{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.landing-link{color:#fff;text-decoration:underline;margin-bottom:2rem}.dataset-list{text-align:left;margin-bottom:2rem}.dataset-list h3{font-weight:600;margin-bottom:.5rem}.dataset-list ul{list-style:disc inside}.dataset-list a{color:#93c5fd;text-decoration:none}.dataset-list a:hover{color:#dbeafe;text-decoration:underline}.search-box{display:flex;width:100%;max-width:32rem;margin-bottom:1rem}.search-box input{flex:1;padding:.5rem 1rem;border-radius:.25rem 0 0 .25rem;background:#fff3;color:#fff;border:none;outline:none}.search-box input::placeholder{color:#d1d5db}.search-box input:focus{box-shadow:0 0 0 2px #93c5fd}.search-box button{padding:.5rem 1rem;background:#3b82f6;border-radius:0 .25rem .25rem 0}.search-box button:hover{background:#2563eb}.more-datasets{margin-top:1rem;max-width:32rem;width:100%}.more-datasets summary{cursor:pointer;color:#9ca3af}.more-datasets ul{list-style:disc inside;max-height:7rem;overflow-y:auto;word-break:break-all;text-align:left;margin-top:.5rem}.more-datasets a{color:#93c5fd}.more-datasets a:hover{color:#dbeafe;text-decoration:underline}.local-section{margin-top:2rem;width:100%;max-width:28rem}.drop-zone{border:2px dashed rgba(255,255,255,.3);border-radius:12px;padding:2rem;text-align:center;transition:all .2s;background:#ffffff08}.drop-zone:hover,.drop-zone.dragover{border-color:#93c5fd;background:#93c5fd1a}.drop-zone-icon{font-size:2.5rem;margin-bottom:.5rem}.drop-zone-text{font-size:1rem;color:#d1d5db;margin-bottom:.5rem}.drop-zone-or{color:#6b7280;font-size:.85rem;margin:.75rem 0}.drop-zone-files{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.file-btn{display:inline-block;padding:8px 16px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;cursor:pointer;font-size:.85rem;color:#d1d5db;transition:all .2s}.file-btn:hover{background:#ffffff26;border-color:#ffffff4d}.file-btn input{display:none}.file-btn.selected{background:#4a9eff33;border-color:#4a9eff;color:#93c5fd}.drop-zone-status{margin-top:1rem;font-size:.85rem;color:#9ca3af;min-height:1.2em}#file-section>ul{max-height:300px;overflow-y:auto;padding:0;margin:0;list-style:none}#file-section ul{padding-left:12px;margin:0;list-style:none}#file-section details{margin:2px 0}#file-section summary{cursor:pointer;padding:4px 8px;background:#2a2a2a;border-radius:4px;font-size:.85em;color:#9ca3af}#file-section summary:hover{background:#333}#file-section li{padding:5px 10px;margin:2px 0;background:#333;border-radius:4px;cursor:pointer;font-size:.8em;word-break:break-all}#file-section li:hover{background:#444}#file-section li.active{background:#4a9eff}#file-section li.loading:after{content:"  ⏳ Loading...";color:#fbbf24;font-weight:600}
