:root{font-family:system-ui,sans-serif;color:#e8eaed;background:#12141a}*{box-sizing:border-box}html{height:100%;overflow:hidden}@supports (height:100dvh){html{height:100dvh;max-height:100dvh}}body{margin:0}.home-app,body{height:100%;max-height:100%;overflow:hidden}.home-app{min-height:0;display:flex;flex-direction:column;background:#12141a}.home-app__header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.65rem 1rem .65rem 1.25rem;border-bottom:1px solid #2a3142;background:#161920}.home-app__title{margin:0;font-size:1.15rem;font-weight:600;color:#e8eaed;letter-spacing:.02em}.home-app__body,.home-app__cameras{flex:1 1;display:flex;min-height:0;align-items:stretch}.home-app__cameras{width:100%;overflow:hidden;flex-direction:row;flex-wrap:nowrap;justify-content:center;gap:.75rem;padding:.65rem .85rem .85rem;box-sizing:border-box}.home-app__cameras--empty{flex-direction:column;justify-content:center;align-items:center}.home-app__header-actions{display:flex;align-items:center;gap:.45rem;flex-shrink:0}.home-app__saves-link{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .55rem;border:1px solid #30363d;border-radius:999px;background:#1a1d26;color:#8b949e;text-decoration:none;font-size:.72rem;font-family:inherit;cursor:pointer;white-space:nowrap}.home-app__saves-link__icon{flex-shrink:0}.home-app__cameras--layout-single{align-items:stretch;padding:.5rem .65rem .65rem;gap:.65rem;min-height:0}.home-app__cameras-single-stage{flex:1 1;min-width:0;min-height:0;display:flex}.home-app__cameras--layout-single .camera-tile{flex:1 1 auto;max-width:none;width:100%}.home-app__camera-picker{flex:0 0 13rem;max-width:42vw;min-height:0;display:flex;flex-direction:column;background:#161920;border:1px solid #2a3142;border-radius:10px;overflow:hidden}.home-app__camera-picker__title{margin:0;padding:.5rem .65rem;font-size:.72rem;font-weight:600;color:#8b949e;border-bottom:1px solid #2a3142;flex-shrink:0}.home-app__camera-picker__list{list-style:none;margin:0;padding:.35rem;overflow-y:auto;flex:1 1;min-height:0}.home-app__camera-picker__list li{margin:0}.home-app__camera-picker__list button{width:100%;text-align:left;padding:.45rem .55rem;margin-bottom:.25rem;border-radius:8px;border:1px solid #2a3142;background:#0d1117;color:#e8eaed;font-size:.8rem;cursor:pointer}.home-app__camera-picker__list button.is-active,.home-app__camera-picker__list button:hover{border-color:#388bfd;background:#21262d;color:#79c0ff}.view-layout-toggle{display:inline-flex;border:1px solid #30363d;border-radius:999px;overflow:hidden;background:#1a1d26}.view-layout-toggle__btn{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .55rem;border:none;background:transparent;color:#8b949e;cursor:pointer;font-size:.72rem}.view-layout-toggle__btn.is-active{background:#21262d;color:#79c0ff}.view-layout-toggle__btn+.view-layout-toggle__btn{border-left:1px solid #30363d}@media (max-width:720px){.home-app__cameras--layout-single{flex-direction:column;overflow-y:auto;align-items:stretch}.home-app__cameras-single-stage{flex:1 1 auto;min-height:min(56vh,480px)}.home-app__camera-picker{flex:0 0 auto;max-width:none;max-height:38vh}.home-app__cameras--layout-multi:not(.home-app__cameras--empty){flex-direction:column;flex-wrap:nowrap;align-items:stretch;justify-content:flex-start;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.home-app__cameras--layout-multi:not(.home-app__cameras--empty) .camera-tile{flex:0 0 auto;width:100%;max-width:none}.home-app__cameras--layout-multi:not(.home-app__cameras--empty) .camera-tile__body{aspect-ratio:1/1;flex:0 0 auto;width:100%}.home-app__cameras--layout-multi:not(.home-app__cameras--empty) .camera-tile__body[data-preview-view=crop169]{aspect-ratio:16/9}.home-app__cameras--layout-multi:not(.home-app__cameras--empty) .camera-tile__body[data-preview-view=crop169] .camera-rail__flat-frame--crop169{flex:1 1;min-height:0;height:100%}.home-app__cameras--layout-multi:not(.home-app__cameras--empty) .camera-tile__body[data-preview-view=crop169] .camera-rail__crop169-inner{width:100%;height:100%;aspect-ratio:unset;max-width:none;max-height:none;margin-inline:0}}@media (max-width:520px){.home-app__saves-link__hint,.view-layout-toggle__hint{display:none}.home-app__saves-link,.view-layout-toggle__btn{padding:.35rem .45rem}}.camera-wall__empty{text-align:center;padding:2rem 1.5rem;max-width:28rem}.camera-wall__empty-title{margin:0;font-size:1.15rem;font-weight:600;color:#8b949e;letter-spacing:.02em}.camera-wall__empty-sub{margin:.75rem 0 0;font-size:.85rem;line-height:1.45;color:#6e7681}.camera-tile{min-width:0;max-width:50%;background:#0d1117;border:1px solid #2a3142;border-radius:10px;overflow:hidden}.camera-tile,.camera-tile__inner{flex:1 1;display:flex;flex-direction:column;min-height:0}.camera-tile__inner{padding:.65rem .75rem .75rem}.camera-tile__header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.45rem .75rem;border-bottom:1px solid #2a3142;background:#161920}.camera-tile__body{flex:1 1;min-height:0;position:relative;overflow:hidden;background:#0d1117;display:flex;flex-direction:column;container-type:size}.camera-tile__info-overlay{position:absolute;top:8px;right:8px;max-width:260px;max-height:55%;overflow-y:auto;background:rgba(13,17,23,.93);border:1px solid #2a3142;border-radius:8px;padding:.6rem .7rem;z-index:10;font-size:.78rem}.camera-rail__latency-hud{position:absolute;top:8px;left:8px;bottom:auto;z-index:9;min-width:11rem;padding:.35rem .5rem;border-radius:6px;background:rgba(13,17,23,.88);border:1px solid #30363d;font-size:.65rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.35;color:#8b949e;pointer-events:none}.camera-rail__latency-hud__row{display:flex;justify-content:space-between;gap:.75rem}.camera-rail__latency-hud__label{color:#6e7681}.camera-rail__latency-hud__val{color:#79c0ff;font-weight:600}.camera-rail__latency-hud__warn{margin-top:.25rem;padding-top:.2rem;border-top:1px solid #3d3420;color:#d4a72c;font-weight:600}.camera-rail__gps-stack{position:absolute;left:8px;bottom:8px;z-index:9;display:flex;flex-direction:column;gap:6px;align-items:flex-start;pointer-events:none}.camera-rail__gps-stack .camera-rail__gps-map-panel{pointer-events:auto}.camera-rail__gps-map-panel{width:160px;height:160px;border-radius:8px;overflow:hidden;border:1px solid #2a3142;background:#161b22;box-shadow:0 2px 8px rgba(0,0,0,.35)}.camera-rail__mapbox-mini-inner{width:100%;height:100%}.camera-rail__gps-map-panel .mapboxgl-ctrl-bottom-right{bottom:2px;right:2px;transform:scale(.75);transform-origin:bottom right}.camera-rail__gps-nofix{height:100%;padding:8px;text-align:center;font-size:.72rem;line-height:1.35}.camera-rail__gps-map-btn,.camera-rail__gps-nofix{display:flex;align-items:center;justify-content:center;color:#8b949e}.camera-rail__gps-map-btn{width:34px;height:34px;padding:0;border-radius:8px;border:1px solid #30363d;background:rgba(13,17,23,.88);cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.35);pointer-events:auto}.camera-rail__gps-map-btn:hover{color:#c9d1d9;border-color:#388bfd}.camera-rail__gps-map-btn.is-active{border-color:#388bfd;color:#58a6ff}.camera-tile__sliders-overlay{position:absolute;bottom:0;left:0;right:0;background:rgba(13,17,23,.93);border-top:1px solid #2a3142;padding:.4rem .6rem .5rem;z-index:10;display:flex;flex-direction:column;gap:.3rem}.camera-tile__footer{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.35rem .6rem;border-top:1px solid #2a3142;background:#161920}.camera-tile__footer--inactive{justify-content:center;border-top-color:#21262d;background:#12141a}.camera-tile__footer-modes{display:flex;gap:.35rem}.camera-tile__footer-modes button{padding:.2rem .6rem;font-size:.75rem;border-radius:6px;border:1px solid #444c5c;background:#1a1d26;color:#8b949e;cursor:pointer}.camera-tile__footer-modes button.is-active{border-color:#388bfd;color:#79c0ff;background:#21262d}.camera-tile__footer-actions{display:flex;gap:.35rem}.camera-tile__footer-actions button{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;border:1px solid #444c5c;background:#1a1d26;color:#8b949e;cursor:pointer}.camera-tile__footer-actions button.is-active,.camera-tile__footer-actions button:hover{border-color:#388bfd;color:#79c0ff;background:#21262d}.relay-ws-indicator{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .55rem;border-radius:999px;border:1px solid #30363d;background:#1a1d26;color:#8b949e;cursor:default;line-height:0}.relay-ws-indicator:focus-visible{outline:2px solid #388bfd;outline-offset:2px}.relay-ws-indicator__dot{width:8px;height:8px;border-radius:50%;background:currentColor;opacity:.9}.relay-ws-indicator--ok{color:#7ee787;border-color:#238636}.relay-ws-indicator--ok .relay-ws-indicator__dot{background:#3fb950;box-shadow:0 0 8px rgba(63,185,80,.45)}.relay-ws-indicator--wait{color:#d2a8ff;border-color:#6e40c9}.relay-ws-indicator--bad{color:#ff7b72;border-color:#da3633}.relay-ws-indicator--bad .relay-ws-indicator__dot{background:#f85149}@keyframes relay-spin{to{transform:rotate(1turn)}}.relay-ws-indicator__arc--spin{animation:relay-spin .9s linear infinite;transform-origin:12px 12px}.camera-rail__toolbar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;flex-shrink:0;margin-bottom:.5rem}.camera-rail__title-block{display:flex;align-items:baseline;gap:.35rem;margin-right:auto}.camera-rail__title{font-size:.95rem;font-weight:600;color:#e8eaed}.camera-rail__id{font-size:.72rem;color:#6e7681;font-family:ui-monospace,monospace}.camera-rail__badges{display:flex;flex-wrap:wrap;gap:.35rem}.camera-rail__pill{font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;padding:.2rem .4rem;border-radius:4px;border:1px solid #30363d;color:#8b949e}.camera-rail__pill.is-ok{color:#7ee787;border-color:#238636;background:rgba(35,134,54,.12)}.camera-rail__pill.is-warn{color:#d2a8ff;border-color:#6e40c9}.camera-rail__pill.is-bad{color:#ff7b72;border-color:#da3633}.camera-rail__rec{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.2rem .5rem;border-radius:4px;border:1px solid #8b3a3a;background:linear-gradient(180deg,#3d2a2a,#2a2020);color:#e89a9a;cursor:pointer;flex-shrink:0;line-height:1.2}.camera-rail__rec:hover{border-color:#b34a4a;color:#ffc9c9;background:linear-gradient(180deg,#4a3232,#322525)}.camera-rail__rec--on{border-color:#ff3333;background:linear-gradient(180deg,#d42020,#8b0505);color:#fff;box-shadow:0 0 14px rgba(255,50,50,.55);animation:camera-rail-rec-pulse 1.2s ease-in-out infinite}.camera-rail__rec:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;animation:none}.camera-rail__squeeper{display:flex;align-items:center;gap:.25rem;flex-shrink:0}.camera-rail__squeeper__select{font-size:.65rem;font-weight:600;padding:.15rem .35rem;border-radius:4px;border:1px solid #30363d;background:#161b22;color:#e6edf3;max-width:4.2rem;cursor:pointer}.camera-rail__squeeper__select:disabled{opacity:.45;cursor:not-allowed}.camera-rail__squeeper__apply{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.2rem .45rem;border-radius:4px;border:1px solid #238636;background:linear-gradient(180deg,#1c3a25,#122718);color:#a6f7c1;cursor:pointer;line-height:1.2;flex-shrink:0}.camera-rail__squeeper__apply:hover:not(:disabled){border-color:#3fb950;color:#cffcdf}.camera-rail__squeeper__apply:disabled{opacity:.45;cursor:not-allowed}@keyframes camera-rail-rec-pulse{0%,to{box-shadow:0 0 10px rgba(255,50,50,.4)}50%{box-shadow:0 0 22px rgba(255,50,50,.75)}}.rec-modal-backdrop{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.62);display:flex;align-items:center;justify-content:center;padding:1rem}.rec-modal{width:100%;max-width:22rem;background:#161920;border:1px solid #2a3142;border-radius:12px;padding:1.15rem 1.25rem;box-shadow:0 16px 48px rgba(0,0,0,.45)}.rec-modal__title{margin:0 0 .5rem;font-size:1.05rem;font-weight:600;color:#e8eaed}.rec-modal__text{margin:0 0 1rem;font-size:.84rem;line-height:1.45;color:#8b949e}.rec-modal__actions{display:flex;gap:.5rem;justify-content:flex-end;flex-wrap:wrap}.rec-modal__btn{padding:.45rem .85rem;border-radius:8px;font-size:.82rem;cursor:pointer;border:1px solid #30363d}.rec-modal__btn--secondary{background:#21262d;color:#e8eaed}.rec-modal__btn--secondary:hover{border-color:#484f58}.rec-modal__btn--primary{background:linear-gradient(180deg,#9b2c2c,#6e1515);border-color:#c44;color:#fff;font-weight:600}.rec-modal__btn--primary:hover{border-color:#e05555;filter:brightness(1.08)}.camera-rail__info-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border-radius:8px;border:1px solid #444c5c;background:#21262d;color:#8b949e;cursor:pointer}.camera-rail__info-btn.is-open,.camera-rail__info-btn:hover{color:#79c0ff;border-color:#388bfd}.camera-rail__details{margin-bottom:.5rem;padding:.5rem .65rem;border-radius:8px;background:#161b22;border:1px solid #30363d;max-height:40vh;overflow:auto}.camera-rail__status-line{margin:0 0 .35rem;font-size:.82rem}.camera-rail__dl{margin:.35rem 0 0;display:grid;grid-gap:.45rem;gap:.45rem;font-size:.8rem}.camera-rail__dl div{display:grid;grid-template-columns:minmax(5.5rem,8.5rem) 1fr;grid-gap:.5rem;gap:.5rem}.camera-rail__dl dt{margin:0;color:#8b949e}.camera-rail__dl dd{margin:0;color:#e8eaed}.camera-rail__name-input{width:100%;max-width:16rem;box-sizing:border-box;padding:.2rem .45rem;font-size:inherit;font-family:inherit;color:#e8eaed;background:#0d1117;border:1px solid #30363d;border-radius:6px}.camera-rail__name-input:focus{outline:none;border-color:#58a6ff}.camera-rail__muted{margin:.25rem 0 0;font-size:.78rem;color:#6e7681}.camera-rail__pre{margin:.5rem 0 0;font-size:.72rem;line-height:1.4;color:#7ee787;white-space:pre-wrap;font-family:ui-monospace,monospace}.camera-rail__video{flex:1 1;min-height:0;display:flex;flex-direction:column;border-radius:8px;overflow:hidden;border:1px solid #2a3142;background:#0d1117}.camera-rail__mode-toggle{flex-shrink:0;display:flex;gap:.35rem;padding:.35rem .5rem;border-bottom:1px solid #2a3142;background:#161920}.camera-rail__mode-toggle button{padding:.25rem .65rem;font-size:.75rem;border-radius:6px;border:1px solid #444c5c;background:#1a1d26;color:#8b949e;cursor:pointer}.camera-rail__mode-toggle button.is-active{border-color:#388bfd;color:#79c0ff;background:#21262d}.camera-rail__video .equirect-sphere-wrap,.camera-tile__body .equirect-sphere-wrap{flex:1 1;min-height:0;width:100%;margin-top:0;border-radius:0;border:none;aspect-ratio:unset;height:auto;max-height:100%}.camera-rail__flat-frame{flex:1 1;min-height:0;width:100%;display:flex;align-items:center;justify-content:center}.camera-rail__flat-frame--crop169{align-self:stretch;width:100%;min-height:0}.camera-rail__flat-img{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.camera-rail__crop169-inner{aspect-ratio:16/9;width:100%;max-width:100%;height:auto;max-height:100%;margin-inline:auto;overflow:hidden;flex-shrink:0}@supports (container-type:size){.camera-tile__body .camera-rail__crop169-inner{width:min(100cqw,calc(100cqh * 16 / 9));max-height:100cqh}}.camera-rail__crop169-inner .camera-rail__flat-img{width:100%;height:100%;max-width:none;max-height:none;object-fit:cover;object-position:center}.camera-rail__video-placeholder{flex:1 1;min-height:clamp(8rem,22vh,18rem);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;padding:1rem;text-align:center;color:#8b949e}.camera-rail__video-placeholder-title{margin:0;font-size:.9rem;font-weight:600;color:#e8eaed}.camera-rail__video-placeholder-sub{margin:0;font-size:.78rem;line-height:1.4;color:#8b949e;max-width:28rem;word-break:break-word}.camera-rail__flat-controls{flex-shrink:0;display:flex;flex-direction:column;gap:.3rem;padding:.4rem .6rem .5rem;border-top:1px solid #2a3142}.camera-rail__ctrl-row{display:flex;align-items:center;gap:.5rem;font-size:.74rem;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.camera-rail__ctrl-label{flex-shrink:0;min-width:108px;color:#8b949e;font-family:ui-monospace,monospace;display:flex;gap:.25rem;align-items:baseline}.camera-rail__ctrl-val{color:#e8eaed;min-width:38px}.camera-rail__ctrl-live{color:#444c5c;font-size:.68rem}.camera-rail__ctrl-row input[type=range]{flex:1 1;accent-color:#388bfd;cursor:pointer}.page{min-height:100vh;display:grid;place-items:center;padding:1rem}.home-stack{display:flex;flex-direction:column;align-items:center;gap:.75rem}.home-live-preview{text-align:left}.card,.home-live-preview .label-muted{text-align:center}.card{padding:1.75rem 2rem;border-radius:12px;background:#1a1d26;border:1px solid #2a3142;max-width:22rem}.card-wide{max-width:28rem;text-align:left}.card-wide h1{text-align:center}.camera-stats{margin:.5rem 0 0;display:grid;grid-gap:.65rem;gap:.65rem}.camera-stats div{display:grid;grid-template-columns:minmax(6.5rem,9rem) 1fr;grid-gap:.5rem;gap:.5rem;align-items:baseline;font-size:.9rem}.camera-stats dt{margin:0;color:#8b949e;font-weight:500}.camera-stats dd{margin:0;color:#e8eaed}.ws-target{margin:.35rem 0 0;font-size:.7rem;color:#6e7681;word-break:break-all;text-align:center}.card h1{margin:0 0 .75rem;font-size:1.25rem;font-weight:600}.status{margin:0;font-size:1rem;line-height:1.5}.status.ok{color:#7ee787}.status.bad{color:#ff7b72}.status.wait{color:#d2a8ff}.status.muted{color:#8b949e}.preview-zoom-readout{margin:.35rem 0 0;font-size:.85rem;font-family:ui-monospace,monospace;color:#8fcbff;text-align:center}.preview-remote-control{margin:.75rem 0 0;padding:.6rem .65rem;background:#0d1117;border:1px solid #30363d;border-radius:6px}.preview-remote-hint{margin:0 0 .5rem;font-size:.72rem;line-height:1.35;text-transform:none;letter-spacing:normal}.preview-remote-hint code{font-size:.68rem;color:#79c0ff}.preview-stepper-row{display:grid;grid-template-columns:7.5rem 1fr;align-items:center;grid-gap:.5rem;gap:.5rem;margin:.45rem 0 0;font-size:.78rem;color:#c9d1d9}.preview-stepper-name{font-family:ui-monospace,monospace;color:#8b949e}.preview-stepper-buttons{display:flex;align-items:center;justify-content:flex-end;gap:.4rem}.preview-stepper-btn{min-width:2rem;height:2rem;padding:0 .5rem;font-size:1.1rem;line-height:1;font-weight:600;color:#c9d1d9;background:#21262d;border:1px solid #30363d;border-radius:6px;cursor:pointer}.preview-stepper-btn:hover:not(:disabled){background:#30363d;border-color:#58a6ff;color:#58a6ff}.preview-stepper-btn:disabled{opacity:.35;cursor:not-allowed}.preview-stepper-value{min-width:4.5rem}.preview-stepper-input,.preview-stepper-value{font-family:ui-monospace,monospace;font-size:.72rem;color:#ffa657;text-align:center}.preview-stepper-input{box-sizing:border-box;width:5.25rem;min-width:4.25rem;padding:.3rem .35rem;background:#0d1117;border:1px solid #30363d;border-radius:4px}.preview-stepper-input--wide{width:6.25rem;min-width:5.25rem}.preview-stepper-input:disabled{opacity:.35;cursor:not-allowed}.preview-stepper-input:focus{outline:none;border-color:#58a6ff}.preview-android-live{margin:.5rem 0 0;padding:.5rem .65rem;background:#161b22;border:1px solid #30363d;border-radius:6px}.preview-android-live-pre{margin:.25rem 0 0;font-size:.8rem;line-height:1.45;color:#7ee787;white-space:pre-wrap;text-align:left}.preview-android-live-copy{margin:.4rem 0 0;font-size:.75rem;line-break:anywhere}.preview-android-live-copy code{font-size:.72rem;color:#ffa657}.label-muted{margin:0 0 .25rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:#8b949e}.divider{margin:1rem 0;border:none;border-top:1px solid #2a3142}.home-demo-link{margin:1rem 0 0;text-align:center}.home-demo-link a{color:#79c0ff;font-size:.95rem}.webrtc-page .hint{margin:.75rem 0 0;font-size:.85rem;line-height:1.45;color:#8b949e}.webrtc-page .hint code{font-size:.8em;background:#0d1117;padding:.1em .35em;border-radius:4px}.webrtc-page .hint a{color:#79c0ff}.webrtc-actions{margin:1.25rem 0 0;display:flex;flex-wrap:wrap;gap:.5rem}.webrtc-actions button{padding:.5rem 1rem;border-radius:8px;border:1px solid #388bfd;background:#1f6feb;color:#fff;font-size:.9rem;cursor:pointer}.webrtc-actions button:hover{background:#388bfd}.remote-videos{margin:1rem 0 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:.75rem;gap:.75rem}.remote-videos video{width:100%;border-radius:8px;background:#0d1117;border:1px solid #2a3142}.webrtc-log{max-height:10rem;overflow:auto;padding:.65rem .75rem;font-size:.75rem;font-family:ui-monospace,monospace;line-height:1.4}.preview-frame-wrap,.webrtc-log{margin:1rem 0 0;border-radius:8px;background:#0d1117;border:1px solid #2a3142}.preview-frame-wrap{overflow:hidden;width:100%;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center}.preview-frame{display:block;width:100%;height:100%;object-fit:contain}.preview-view-toggle{margin:.75rem 0 0;display:flex;gap:.5rem;justify-content:center}.preview-view-toggle button{padding:.35rem .85rem;border-radius:8px;border:1px solid #444c5c;background:#1a1d26;color:#8b949e;font-size:.85rem;cursor:pointer}.preview-view-toggle button.toggle-active{border-color:#388bfd;color:#79c0ff;background:#21262d}.equirect-sphere-wrap{width:100%;aspect-ratio:1/1;margin-top:.75rem;border-radius:8px;overflow:hidden;background:#0d1117;border:1px solid #2a3142;display:flex;align-items:center;justify-content:center}.equirect-sphere-wrap canvas{display:block;width:100%!important;height:100%!important}.admin-app{height:100%;max-height:100%;min-height:0;display:flex;flex-direction:column;overflow:hidden;background:#0d1117;color:#e8eaed}.admin-app__header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1.25rem;border-bottom:1px solid #30363d;background:#161b22;position:-webkit-sticky;position:sticky;top:0;z-index:10}.admin-app__header-left{display:flex;flex-direction:column;gap:.2rem;min-width:0}.admin-app__brand{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#8b949e}.admin-app__subtitle{font-size:1.05rem;font-weight:600;color:#e8eaed}.admin-app__back{flex-shrink:0;padding:.45rem 1rem;border-radius:8px;border:1px solid #388bfd;background:#21262d;color:#79c0ff;font-size:.9rem;font-weight:500;text-decoration:none;white-space:nowrap}.admin-app__back:hover{background:#30363d}.admin-app__main{flex:1 1;min-height:0;overflow:auto;padding:1.25rem 1.25rem 2rem}.admin-app__main--fullbleed{padding:0;overflow:hidden;display:flex;flex-direction:column;min-height:0}.admin-card{max-width:960px;margin:0 auto;padding:1.5rem 1.75rem;border-radius:12px;background:#161b22;border:1px solid #30363d}.admin-card h1{margin:0 0 1rem;font-size:1.35rem;font-weight:600;text-align:left}.admin-table-wrap{overflow-x:auto}.saves-pagination{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;font-size:.88rem;color:#8b949e}.saves-pagination--top{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #2a3142}.saves-pagination--bottom{margin-top:1rem;padding-top:1rem;border-top:1px solid #2a3142}.saves-pagination__nav{display:flex;gap:.5rem}.saves-pagination__btn{padding:.35rem .85rem;border-radius:8px;border:1px solid #444c5c;background:#21262d;color:#e8eaed;cursor:pointer;font-size:.85rem}.saves-pagination__btn:hover:not(:disabled){background:#30363d}.saves-pagination__btn:disabled{background:#161b22;cursor:not-allowed;opacity:.5}.save-replay-page{flex:1 1;min-height:0;display:flex;flex-direction:column;width:100%;background:#0d1117}.save-replay__viewport{flex:1 1;min-height:0;width:100%;position:relative;background:#000}.save-replay__canvas-box{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#000;overflow:hidden;pointer-events:none}.save-replay__canvas-box .save-replay__canvas{pointer-events:auto}.save-replay__canvas-box>.camera-rail__gps-stack{bottom:max(14px,5vh);left:12px}.save-replay__canvas{display:block;max-width:100%;max-height:100%;width:auto;height:auto}.save-replay__overlay{position:absolute;left:0;right:0;bottom:0;max-height:min(52vh,100%);overflow-x:hidden;overflow-y:auto;padding:.75rem 1rem 1rem;background:linear-gradient(0deg,rgba(13,17,23,.97) 0,rgba(13,17,23,.88) 45%,rgba(13,17,23,.45) 78%,transparent);pointer-events:none}.save-replay__overlay a,.save-replay__overlay button,.save-replay__overlay input{pointer-events:auto}.save-replay__meta{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem;font-size:.8rem;color:#8b949e;margin-bottom:.5rem}.save-replay__link{color:#79c0ff;text-decoration:none}.save-replay__link:hover{text-decoration:underline}.save-replay__metaSep{opacity:.5}.save-replay__id{font-size:.72rem;opacity:.85;color:#c9d1d9}.save-replay__clock{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem .75rem;margin-bottom:.45rem}.save-replay__clock-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#8b949e}.save-replay__clock-value{font-size:1rem;font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:#e8eaed}.save-replay__clock-offset{font-size:.85rem;font-family:ui-monospace,monospace;color:#7ee787}.save-replay__status{margin:0 0 .4rem;font-size:.82rem;color:#d2a8ff}.save-replay__timeline-row{margin-top:.5rem;margin-bottom:0}.save-replay__timeline-hint{font-size:.75rem;color:#8b949e;margin-bottom:.2rem}.save-replay__timeline{width:100%;accent-color:#388bfd;cursor:pointer}.save-replay__controls{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem;margin-bottom:.35rem}.save-replay__controls button{padding:.4rem .9rem;border-radius:8px;border:1px solid #444c5c;background:#21262d;color:#e8eaed;font-size:.88rem;cursor:pointer}.save-replay__frames{font-size:.8rem;color:#8b949e}.save-replay__detail{margin:.35rem 0 0;font-size:.72rem;color:#6e7681}.save-replay__hint{font-size:.85rem;color:#8b949e}.home-app__remote-drive{padding:.35rem .75rem;border-radius:8px;border:1px solid #388bfd;background:#1f3a5f;color:#e8eaed;font-size:.82rem;font-weight:500;cursor:pointer}.home-app__remote-drive:hover{background:#254a7a}.remote-drive-root{position:fixed;inset:0;z-index:12000;display:flex;align-items:center;justify-content:center;padding:1rem;pointer-events:auto}.remote-drive-backdrop{position:absolute;inset:0;border:none;margin:0;padding:0;background:rgba(0,0,0,.55);cursor:pointer}.remote-drive-dialog{position:relative;z-index:1;width:min(920px,100%);max-height:min(88vh,900px);overflow:auto;background:#161920;border:1px solid #2a3142;border-radius:12px;box-shadow:0 16px 48px rgba(0,0,0,.45);padding:1rem 1.25rem 1.25rem}.remote-drive-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.remote-drive-title{margin:0;font-size:1.1rem;font-weight:600;color:#e8eaed}.remote-drive-close{border:none;background:transparent;color:#8b949e;font-size:1.5rem;line-height:1;cursor:pointer;padding:0 .25rem}.remote-drive-close:hover{color:#e8eaed}.remote-drive-hint{margin:.5rem 0 1rem;font-size:.8rem;color:#8b949e;line-height:1.45}.remote-drive-code{font-size:.75rem;background:#21262d;padding:.1rem .35rem;border-radius:4px}.remote-drive-columns{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-start}.remote-drive-controls{flex:1 1 220px;display:flex;flex-direction:column;gap:.55rem}.remote-drive-status{font-size:.78rem;color:#8b949e;line-height:1.4;margin-bottom:.25rem}.remote-drive-btn{padding:.5rem .75rem;border-radius:8px;border:1px solid #444c5c;background:#21262d;color:#e8eaed;font-size:.82rem;cursor:pointer;text-align:left}.remote-drive-btn:hover:not(:disabled){border-color:#58a6ff}.remote-drive-btn:disabled{opacity:.45;cursor:not-allowed}.remote-drive-btn--secondary{background:#1c2128}.remote-drive-btn--danger{border-color:#f8514988;color:#ffa198}.remote-drive-list-wrap{flex:2 1 320px;min-height:200px;max-height:52vh;display:flex;flex-direction:column;border:1px solid #2a3142;border-radius:8px;overflow:hidden;background:#12141a}.remote-drive-list-head{padding:.45rem .65rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#8b949e;border-bottom:1px solid #2a3142;background:#161920}.remote-drive-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1 1}.remote-drive-list-empty{padding:1rem;font-size:.8rem;color:#6e7681}.remote-drive-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem;padding:.55rem .65rem;border-bottom:1px solid #21262d}.remote-drive-row-info{display:flex;flex-direction:column;gap:.15rem;min-width:0}.remote-drive-row-name{font-size:.85rem;color:#e8eaed;word-break:break-word}.remote-drive-row-mac{font-size:.72rem;color:#6e7681;font-family:ui-monospace,monospace}.remote-drive-row-actions{display:flex;flex-wrap:wrap;gap:.35rem}.remote-drive-btn-small{padding:.3rem .5rem;font-size:.72rem;border-radius:6px;border:1px solid #444c5c;background:#21262d;color:#e8eaed;cursor:pointer}.remote-drive-btn-small:hover:not(:disabled){border-color:#58a6ff}.remote-drive-btn-small:disabled{opacity:.45;cursor:not-allowed}.remote-drive-btn-small--muted{background:#1c2128}