:root{font-family:Trebuchet MS,Segoe UI,sans-serif;line-height:1.4;font-weight:400;color:#102136;background:linear-gradient(170deg,#d8e6ff,#edf6ff 45%,#f3f8ff);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at 12% 20%,rgba(10,79,168,.13),transparent 25%),radial-gradient(circle at 82% 30%,rgba(0,160,150,.1),transparent 28%),linear-gradient(170deg,#d8e6ff,#edf6ff 45%,#f3f8ff)}#root{min-height:100vh}.rto-shell{width:min(1120px,96vw);margin:0 auto;padding:2rem 0 2.5rem}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:1rem}.auth-card{width:min(420px,96vw);background:#ffffffeb;border:1px solid #d5deeb;border-radius:16px;padding:1rem;box-shadow:0 14px 38px #06172a1a;display:grid;gap:.8rem}.auth-card h1{margin:0}.auth-card p{margin:0;color:#35577e}.auth-form{display:grid;gap:.7rem}.auth-form label{display:grid;gap:.3rem;font-weight:700;color:#1c3554}.auth-form input{border:1px solid #a7b9d1;background:#f7fbff;color:#102136;border-radius:8px;padding:.5rem .7rem;font-size:.95rem}.rto-shell.app-fullscreen{width:100vw;max-width:none;min-height:100vh;margin:0;padding:0;background:#02070f}.rto-header{display:flex;justify-content:space-between;gap:1rem;align-items:center;margin-bottom:1rem}.header-actions{display:flex;gap:.5rem}.rto-header h1{margin:0;font-size:clamp(1.5rem,3vw,2.2rem)}.subtitle{margin:.3rem 0 0;color:#4f5a67}.panel{background:#ffffffd9;border:1px solid #d5deeb;border-radius:18px;padding:1rem;box-shadow:0 10px 30px #06172a14}.cab-panel{display:grid;gap:1rem}.app-fullscreen .cab-panel{min-height:100vh;grid-template-rows:1fr auto auto;gap:.4rem;margin:0;border-radius:0;border:none;box-shadow:none;background:#02070f;padding:.5rem .6rem}.profile-panel{display:grid;gap:.7rem;margin-bottom:1rem}.overlay-speedometer{position:absolute;left:50%;transform:translate(-50%);bottom:calc(100% + .65rem - 50px);display:grid;justify-items:center;gap:.2rem;z-index:21}.speedometer{width:min(157px,44vw);height:auto}.speedo-outer{fill:#13253d;stroke:#2a4365;stroke-width:3}.speedo-major-tick{stroke:#13253d;stroke-width:3.5;stroke-linecap:round}.speedo-minor-tick{stroke:#496282;stroke-width:2;stroke-linecap:round}.speedo-label{font-size:10px;font-weight:700;text-anchor:middle;dominant-baseline:middle;fill:#173459}.speedo-needle{stroke:#d73131;stroke-width:5;stroke-linecap:round;filter:drop-shadow(0 0 3px rgba(215,49,49,.45))}.speedo-cap{fill:#0f2239;stroke:#4d6586;stroke-width:2}.speedo-unit{font-size:12px;letter-spacing:.16em;text-transform:uppercase;text-anchor:middle;fill:#2f4f77}.speedo-digital{min-width:132px;text-align:center;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:1rem;font-weight:700;color:#ebf2ff;background:#10263f;border:1px solid #3b5578;border-radius:8px;padding:.25rem .5rem}.profile-panel h2{margin:0;font-size:1rem;color:#1b3455}.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}.profile-card{text-align:left;display:grid;gap:.2rem;background:#f5f9ff;border:1px solid #b9c9df}.profile-thumb{width:50%;aspect-ratio:16 / 9;object-fit:cover;border-radius:8px;margin-bottom:.3rem}.profile-card.active{border-color:#0a4fa8;background:#dcebff;box-shadow:inset 0 0 0 1px #0a4fa8}.profile-card strong{color:#0e2f56}.profile-card span{font-size:.85rem;color:#35577e}.profile-source{font-size:.78rem;color:#295d95;text-decoration:underline}.dvdt-control{display:grid;gap:.35rem;padding:.35rem .2rem .1rem}.dvdt-label{font-size:.85rem;color:#1c3554;font-weight:700}.dvdt-slider{width:min(560px,100%);accent-color:#0a4fa8}.video-timeline{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.65rem;padding:.1rem .2rem .2rem}.video-time{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:.82rem;color:#214267;min-width:3.2rem}.video-seek{width:100%;accent-color:#0a4fa8}.fullscreen-video-speed{justify-self:start;font-size:.88rem;color:#d7e7ff;background:#0e1d31e6;border:1px solid #3b5270;border-radius:999px;padding:.2rem .55rem}.hide-in-fullscreen{display:block}.app-fullscreen .hide-in-fullscreen{display:none}.stream-panel{display:grid;grid-template-columns:1fr auto auto;gap:.8rem;align-items:end;margin-bottom:1rem}.stream-input-wrap{display:grid;gap:.35rem}.stream-label{font-size:.8rem;color:#4f5a67;font-weight:700}.stream-input{border:1px solid #a7b9d1;background:#f7fbff;color:#102136;border-radius:8px;padding:.5rem .7rem;font-size:.95rem}.stream-actions{display:flex;gap:.45rem}.stream-state{align-self:center;justify-self:end;padding:.35rem .6rem;border-radius:999px;font-size:.82rem;font-weight:700;border:1px solid #b7c8df;color:#1a395e;background:#e8f0fb}.stream-state.online{border-color:#9ec8aa;color:#1a5c35;background:#e3f4e8}.stream-state.offline{border-color:#d6bbc3;color:#6a2435;background:#fae8ee}.drive-stage{position:relative;border-radius:14px;border:1px solid #9fb5d4;overflow:hidden;aspect-ratio:16 / 9;background:#182435}.app-fullscreen .drive-stage{border-radius:8px;border-color:#243348}.drive-feed{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}.drive-feed-video{transform:translateY(-20%)}.fullscreen-toggle{position:absolute;right:.6rem;top:.6rem;z-index:30}.cabin-piece{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}.cabin-piece.top{clip-path:inset(0 0 99% 0)}.cabin-piece.bottom{clip-path:inset(48% 0 0 0)}.left-overlay-control,.right-overlay-control{position:absolute;bottom:calc(9% - 50px);display:flex;align-items:center;gap:.55rem}.left-overlay-control{left:calc(50% - 50px);transform:translate(-50%)}.right-overlay-control{left:calc(50% + 250px);transform:translate(-50%)}.slider-live-value{min-width:2.6rem;text-align:center;font-weight:800;font-size:1.15rem;color:#0d2b52;background:#e7eef8;border:1px solid #b3c4da;border-radius:999px;padding:.25rem .45rem}.slider-live-value.right{color:#5e1d1a;background:#faeceb;border-color:#dcb4b1}.slider-column{display:grid;justify-items:center;gap:.4rem}.slider-column.overlay .slider-title{font-size:.85rem;color:#102b4d}.slider-title{font-weight:700;color:#12253d}.scale-label{font-size:.78rem;color:#4f5a67;font-weight:700}.vertical-slider{width:52px;height:240px;margin:0;writing-mode:vertical-lr;direction:rtl;accent-color:#0a4fa8}.vertical-slider.brake{accent-color:#b0382f}.vertical-slider.overlay{width:144px;height:120px}button{border:1px solid #6e829f;background:#f4f7fb;color:#12253d;border-radius:8px;padding:.5rem .7rem;cursor:pointer}button:hover:not(:disabled){background:#e7eef7}button:disabled{opacity:.6;cursor:not-allowed}button.ghost{background:#fff9}button.mode-active{border-color:#0a4fa8;background:#dcebff;color:#0e2f56;box-shadow:inset 0 0 0 1px #0a4fa8}.error-banner{background:#ffeaea;border:1px solid #ffc6c6;color:#7b1010;padding:.7rem .9rem;border-radius:10px;margin-bottom:.9rem}.video-popup{position:absolute;top:.7rem;left:50%;transform:translate(-50%);z-index:35;max-width:min(88%,560px);background:#0e243ee6;border:1px solid #45658c;color:#eef5ff;border-radius:10px;padding:.45rem .75rem;text-align:center;font-weight:700;box-shadow:0 8px 24px #06172a47}.footer{margin-top:.9rem;color:#4f5a67}@media(max-width:760px){.overlay-speedometer{bottom:calc(100% + .3rem)}.speedometer{width:min(168px,50vw)}.speedo-digital{min-width:102px;font-size:.85rem}.header-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}.profile-grid{grid-template-columns:1fr}.stream-panel{grid-template-columns:1fr;align-items:stretch}.stream-state{justify-self:start}.vertical-slider{width:44px;height:190px}.vertical-slider.overlay{width:58px;height:105px}.left-overlay-control{left:22%;bottom:7%}.right-overlay-control{left:42%;bottom:7%}}
