*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;background:#000}.root{position:relative;width:100%;height:100%;overflow:hidden;font-family:SF Mono,Menlo,Consolas,monospace}.camera-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:brightness(.85) contrast(1.1)}.vignette{position:absolute;inset:0;z-index:2;pointer-events:none;background:radial-gradient(ellipse at center,transparent 50%,rgba(0,0,0,.6) 100%)}.impact-flash{position:absolute;inset:0;z-index:4;pointer-events:none;border-radius:0}.hud-top{position:absolute;top:0;left:0;right:0;z-index:5;display:flex;align-items:flex-start;padding:12px;background:none}.hud-corner-tl,.hud-corner-tr{width:16px;height:16px;flex-shrink:0}.hud-corner-tl{border-left:2px solid rgba(255,255,255,.3);border-top:2px solid rgba(255,255,255,.3)}.hud-corner-tr{border-right:2px solid rgba(255,255,255,.3);border-top:2px solid rgba(255,255,255,.3)}.hud-title-row{flex:1;display:flex;align-items:center;justify-content:space-between;padding:0 10px}.hud-title{color:#ffffffd9;font-size:15px;font-weight:700;letter-spacing:.25em;text-shadow:0 0 12px rgba(255,255,255,.2)}.hud-rec{display:flex;align-items:center;gap:6px;color:#f44;font-size:12px;font-weight:600;letter-spacing:.15em;text-shadow:0 0 8px rgba(255,50,50,.5)}.hud-rec-dot{width:8px;height:8px;border-radius:50%;background:#f44;box-shadow:0 0 6px #f44;animation:pulse-dot 1s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.hud-stats{position:absolute;top:4px;left:4px;right:4px;z-index:5;display:flex;flex-wrap:nowrap;gap:2px}.hud-stat{display:flex;flex-direction:column;align-items:center;flex:1;min-width:0;padding:4px 0;background:#00000080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.08)}.hud-stat:first-child{border-radius:6px 0 0 6px}.hud-stat:last-child{border-radius:0 6px 6px 0}.hud-stat-label{font-size:8px;font-weight:600;letter-spacing:.15em;color:#ffffff59}.hud-stat-value{font-size:16px;font-weight:700;color:#ffffffe6;text-shadow:0 0 8px rgba(255,255,255,.15);font-variant-numeric:tabular-nums;white-space:nowrap}.hud-stat-unit{font-size:9px;font-weight:500;color:#fff6;margin-left:2px}.main-view{position:absolute;inset:0 0 232px;z-index:2;overflow:hidden;display:flex;align-items:stretch;justify-content:stretch;background:#000}.main-view>*:not(.view-dots){width:100%;height:100%;margin:0}.main-view>.pressure-map{height:auto}.camera-full{position:absolute!important;inset:0!important;width:100%!important;height:100%!important;margin:0!important;z-index:0}.camera-full .camera-video{width:100%;height:100%;object-fit:cover}.camera-pip{position:absolute!important;top:100px!important;right:12px!important;width:120px!important;height:90px!important;margin:0!important;border-radius:8px;overflow:hidden;border:2px solid rgba(255,255,255,.15);z-index:5;cursor:pointer;box-shadow:0 2px 8px #00000080}.camera-pip .camera-video{width:100%;height:100%;object-fit:cover}.camera-flip-btn{position:absolute;top:56px;left:4px;width:36px;height:36px;border-radius:6px;border:1.5px solid rgba(255,255,255,.4);background:#0009;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;pointer-events:auto;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.view-dots{position:absolute;bottom:12px;left:0;right:0;padding:16px 0;display:flex;justify-content:center;gap:8px;pointer-events:auto;z-index:10}.view-dot{width:12px;height:12px;border-radius:50%;background:#fff6;border:1.5px solid rgba(0,0,0,.3);box-shadow:0 0 4px #00000080;cursor:pointer;transition:background .2s}.view-dot-active{background:#fff}.view-dot-disabled{background:#ffffff14;cursor:default}.view-fill{width:100%;height:100%;object-fit:cover}.camera-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#000}.spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.15);border-top-color:#fff9;border-radius:50%;animation:spin .8s linear infinite}.camera-video{width:100%;height:100%;object-fit:cover;display:block;background:#000}.camera-toggle-btn{width:12px;height:12px;border:none;border-radius:50%;cursor:pointer;z-index:5;padding:0}.camera-toggle-on{background:#00c864cc;box-shadow:0 0 4px #00c86466}.camera-toggle-off{background:#ff3c3c99;box-shadow:0 0 4px #ff3c3c4d}video.camera-video::-webkit-media-controls,video.camera-video::-webkit-media-controls-enclosure,video.camera-video::-webkit-media-controls-panel,video.camera-video::-webkit-media-controls-overlay-enclosure,video.camera-video::-webkit-media-controls-overlay-play-button,video.camera-video::-webkit-media-controls-start-playback-button,video.camera-video::-webkit-media-controls-play-button,video.camera-video::-webkit-media-controls-fullscreen-button,video.camera-video::-internal-media-controls-overlay-cast-button{display:none!important;opacity:0!important;visibility:hidden!important;pointer-events:none!important;width:0!important;height:0!important;-webkit-appearance:none!important;appearance:none!important}video.camera-video{-webkit-appearance:none;appearance:none}.wireframe-wrap{position:relative;width:100%;height:100%}.wireframe-canvas,.pressure-canvas{width:100%;height:100%;display:block}.pressure-placeholder{width:100%;height:100%}.wireframe-reset{position:absolute;bottom:4px;right:4px;z-index:20;width:44px;height:44px;border:none;border-radius:4px;background:#0009;color:#fff9;font-size:20px;line-height:44px;pointer-events:auto;text-align:center;cursor:pointer;padding:0;transition:all .15s}.wireframe-reset:hover{background:#000000b3;color:#ffffffd9}.main-view .wireframe-reset{width:54px;height:54px;font-size:26px;line-height:54px;bottom:50%;right:50%;transform:translate(50%,50%);z-index:20;pointer-events:auto;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.overlay{position:absolute;inset:0;z-index:8;display:flex;flex-direction:column;pointer-events:none}.overlay>*{pointer-events:auto}.overlay-center{display:flex;flex-direction:row;align-items:center;justify-content:center;padding:0;gap:0}.control-bar{display:flex;gap:2px;align-items:center;width:100%}.ctrl-btn{display:flex;align-items:center;justify-content:center;gap:6px;flex:1;height:36px;padding:0 6px;border:1.5px solid rgba(255,255,255,.25);border-radius:0;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fffc;font-family:SF Mono,Menlo,Consolas,monospace;font-size:9px;font-weight:600;letter-spacing:.08em;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.ctrl-btn:active{transform:scale(.95)}.ctrl-run:hover{border-color:#00dc6480}.ctrl-run.active{border-color:#00dc64cc}.ctrl-run-icon{width:14px;height:14px;transition:all .2s}.ctrl-run-icon.play{width:0;height:0;border-left:10px solid rgba(0,220,100,.9);border-top:7px solid transparent;border-bottom:7px solid transparent;border-right:none}.ctrl-run-icon.stop{width:12px;height:12px;border-radius:2px;background:#ff503ce6;border:none}.ctrl-stream:hover{border-color:#00c8ff80}.ctrl-stream.active{border-color:#00dc64cc}.ctrl-stream-icon{width:12px;height:10px;display:flex;flex-direction:column;justify-content:space-between}.ctrl-stream-icon:before,.ctrl-stream-icon:after{content:"";display:block;height:2px;background:#00c8ffb3;border-radius:1px}.ctrl-stream-icon:before{box-shadow:0 4px #00c8ffb3}.ctrl-stream-icon.streaming:before,.ctrl-stream-icon.streaming:after{background:#00dc64e6}.ctrl-stream-icon.streaming:before{box-shadow:0 4px #00dc64e6}.ctrl-video:hover{border-color:#ff505080}.ctrl-video.active{border-color:#00dc64cc}.ctrl-btn.disabled{opacity:.3;pointer-events:none}.ctrl-ble.connecting{border-color:#0096ff66}.ctrl-ble-spinner{width:12px;height:12px;border:2px solid rgba(0,150,255,.3);border-top-color:#0096ffe6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ctrl-ble:hover{border-color:#0096ff80}.ctrl-ble.active{border-color:#00dc64cc}.ctrl-ble-icon{width:10px;height:14px;border:1.5px solid rgba(0,150,255,.6);border-radius:3px 3px 0 0;position:relative}.ctrl-ble-icon:after{content:"";position:absolute;bottom:-4px;left:50%;transform:translate(-50%);width:6px;height:3px;border-bottom:1.5px solid rgba(0,150,255,.6);border-left:1.5px solid rgba(0,150,255,.6);border-right:1.5px solid rgba(0,150,255,.6);border-radius:0 0 2px 2px}.ctrl-ble-icon.connected{border-color:#00c8ffe6}.ctrl-ble-icon.connected:after{border-color:#00c8ffe6}.ctrl-runs:hover{border-color:#ffffff80}.ctrl-runs-icon{width:12px;height:10px;border:1.5px solid rgba(255,255,255,.6);border-radius:2px;position:relative}.ctrl-runs-icon:after{content:"";position:absolute;top:2px;left:2px;right:2px;height:1px;background:#ffffff80;box-shadow:0 3px #ffffff80}.ctrl-video-icon{width:12px;height:12px;border-radius:50%;border:2px solid rgba(255,80,80,.7);background:transparent;transition:all .2s}.ctrl-video.active .ctrl-video-icon{background:#ff5050e6;box-shadow:0 0 6px #ff505080}.hud-status{display:flex;align-items:center;gap:12px}.hud-connection-badge{font-size:10px;font-weight:700;letter-spacing:.1em;padding:1px 6px;border:1px solid currentColor;border-radius:3px;opacity:.8}.hud-device-btn{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border:1px solid rgba(255,255,255,.15);border-radius:3px;background:#ffffff0d;color:#ffffff80;font-family:SF Mono,Menlo,Consolas,monospace;font-size:9px;cursor:pointer;max-width:160px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.hud-device-btn:hover{border-color:#ffffff4d;color:#ffffffb3}.hud-device-btn-x{color:#ff505099;font-size:10px}.hud-support-btn{width:22px;height:22px;border-radius:50%;border:1.5px solid rgba(68,170,255,.4);background:#44aaff1a;color:#4afc;font-size:13px;font-weight:700;font-family:SF Mono,Menlo,Consolas,monospace;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.hud-support-btn:hover{border-color:#44aaffb3;background:#4af3}.hud-run-badge{color:#00dc64e6;font-size:12px;font-weight:600;letter-spacing:.12em;text-shadow:0 0 8px rgba(0,220,100,.3)}.native-scrub{padding:4px 8px;background:#0009}.native-scrub input{width:100%;height:20px}.native-scrub-label{font-family:SF Mono,Menlo,Consolas,monospace;font-size:9px;text-align:center;padding:2px 0}.chart-row{display:flex;width:100%;gap:0;height:192px}.chart-panel{flex:1;min-width:0;padding:0;height:100%;transition:flex .25s ease-out}.runs-overlay{position:fixed;inset:0;z-index:100;background:#000000d9;display:flex;align-items:center;justify-content:center}.runs-panel{width:90%;max-width:500px;max-height:80vh;background:#111;border:1px solid rgba(255,255,255,.1);border-radius:8px;display:flex;flex-direction:column;overflow:hidden}.runs-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.08);font-size:12px;font-weight:600;letter-spacing:.1em;color:#ffffffb3}.runs-header button{background:none;border:1px solid rgba(255,255,255,.2);color:#fff9;padding:4px 12px;border-radius:4px;font-size:10px;font-weight:600;letter-spacing:.1em;cursor:pointer}.runs-empty{padding:32px;text-align:center;color:#ffffff4d;font-size:12px}.runs-list{overflow-y:auto;flex:1}.run-item{border-bottom:1px solid rgba(255,255,255,.05)}.run-row{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;cursor:pointer}.run-row:hover{background:#ffffff08}.run-id{font-size:11px;color:#fff9;font-family:monospace}.run-delete{background:none;border:1px solid rgba(255,60,60,.3);color:#ff3c3c99;padding:2px 8px;border-radius:3px;font-size:9px;font-weight:600;cursor:pointer}.run-files{padding:4px 16px 12px 24px}.run-file{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:11px;color:#ffffff80;font-family:monospace}.run-file-size{color:#ffffff40;font-size:10px}.run-file button{background:none;border:1px solid rgba(255,255,255,.15);color:#ffffff80;padding:1px 6px;border-radius:3px;font-size:9px;cursor:pointer}.run-video-player{width:100%;max-height:200px;margin-top:8px;border-radius:4px;background:#000}.saved-path{color:#ffffff80;font-size:10px;text-align:center;max-width:90%;word-break:break-all}
