:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:block;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}body{margin:0;padding:0;background:linear-gradient(135deg,#1e1e2f,#3a3a5e);color:#eee;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;min-height:100vh}.dashboard{max-width:1400px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;padding:20px;box-sizing:border-box}.serial-warning{background:#ff5252e6;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);color:#fff;padding:10px;text-align:center;font-size:.9em;font-weight:700;margin-bottom:20px;border-radius:8px;box-shadow:0 4px 12px #0000004d;align-self:center;width:100%;max-width:600px}.header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:15px 30px;background:#ffffff08;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;border:1px solid rgba(255,255,255,.05);margin-bottom:30px;gap:15px;position:relative;z-index:10}.logo-section{display:flex;align-items:center;gap:15px}.app-logo{height:40px;width:auto;filter:drop-shadow(0 0 8px rgba(76,175,80,.3))}.header h1{margin:0;font-size:1.5em;font-weight:700;letter-spacing:-.5px;color:#fff;white-space:nowrap}body:before{content:"";position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:60vh;height:60vh;background-image:url(/assets/logo-source-BPTtdmR9.png);background-size:contain;background-repeat:no-repeat;background-position:center;opacity:.03;pointer-events:none;z-index:-1;filter:grayscale(100%)}.status-badges{display:flex;gap:10px;flex-wrap:wrap}.badge{background:#ffffff0d;padding:6px 12px;border-radius:6px;color:#aaa;font-size:.75em;font-weight:600;letter-spacing:.5px;border:1px solid rgba(255,255,255,.05);transition:all .3s ease;white-space:nowrap}.badge.connected{background:#00e6761a;color:#00e676;border-color:#00e67633;box-shadow:0 0 10px #00e6761a}.main-view{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:30px;padding-bottom:60px;padding-top:20px}.dashboard-row{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:20px;width:100%}.speedometer-container{flex:0 0 auto;width:320px;max-width:90vw;aspect-ratio:1;display:flex;justify-content:center;align-items:center}.gauge-section{display:flex;flex-direction:column;align-items:center;flex:1;min-width:300px}.controls{margin-top:40px;display:grid;grid-template-columns:repeat(3,1fr);gap:15px;width:100%;max-width:450px}@media(max-width:768px){.controls{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.header{flex-direction:column;align-items:flex-start}.main-view{gap:30px}}button{background:linear-gradient(180deg,#4caf50,#388e3c);color:#fff;border:none;padding:14px 20px;border-radius:12px;font-size:.9em;font-weight:600;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:1px;box-shadow:0 4px #2e7d32,0 5px 10px #0003;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.2}button:active{transform:translateY(2px);box-shadow:0 2px #2e7d32,0 2px 5px #0003}button.secondary{background:#ffffff0d;box-shadow:none;border:1px solid rgba(255,255,255,.1);color:#ccc}button.secondary:hover{background:#ffffff1a;color:#fff;border-color:#fff3}.telemetry-panel{background:#14141499!important;-webkit-backdrop-filter:blur(12px)!important;backdrop-filter:blur(12px)!important;border:1px solid rgba(255,255,255,.08)!important;box-shadow:0 8px 32px #0006!important;border-radius:20px!important;height:100%;width:100%}.footer{text-align:center;color:#666;font-size:.8em;padding:20px;margin-top:auto}.telemetry-panel{display:flex;flex-direction:column;gap:15px;background:#1a1a1a;padding:15px;border-radius:12px}.telemetry-gauges{display:flex;gap:15px;align-items:flex-end;justify-content:center;border-bottom:1px solid #333;padding-bottom:15px}.gauge-container{display:flex;flex-direction:column;align-items:center;gap:5px}.gauge-container.wide{flex:1;align-items:stretch;justify-content:center}.bar-gauge{width:30px;height:120px;background:#222;border-radius:15px;position:relative;overflow:hidden;border:2px solid #444}.bar-fill{position:absolute;bottom:0;width:100%;transition:height .05s linear}.bar-fill.throttle{background:linear-gradient(to top,#4caf50,#8bc34a)}.bar-fill.brake{background:linear-gradient(to top,#f44336,#e91e63)}.horiz-bar-gauge{height:20px;background:#222;border-radius:10px;position:relative;border:2px solid #444;overflow:hidden;margin-top:5px}.center-mark{position:absolute;left:50%;top:0;bottom:0;width:2px;background:#666;transform:translate(-50%);z-index:2}.horiz-fill{position:absolute;height:100%;background:#2196f3;transition:width .05s linear,transform .05s linear}.launch-status{display:flex;justify-content:space-between;align-items:center;background:#222;padding:10px;border-radius:5px;font-weight:700}.status-badge.state-0{color:#666}.status-badge.state-1{color:#ffeb3b;animation:pulse 1s infinite}.status-badge.state-2{color:#f44336}@keyframes pulse{0%{opacity:.5}50%{opacity:1}to{opacity:.5}}.pwm-display{background:#111;padding:10px;border-radius:8px;font-family:monospace}.pwm-display h4{margin:0 0 10px;color:#666;font-size:.8em;text-transform:uppercase}.pwm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:5px}.pwm-item{display:flex;justify-content:space-between;font-size:.9em;color:#888}.pwm-item .val{color:var(--accent)}.settings-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;display:flex;justify-content:center;align-items:center;padding:20px;box-sizing:border-box}.settings-panel{background:#1e1e28f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);width:100%;max-width:600px;height:auto;max-height:90vh;border-radius:20px;border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000080;animation:panelSlideUp .3s ease-out}@keyframes panelSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.settings-header{padding:20px 25px;border-bottom:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.settings-header h2{margin:0;color:#fff;font-size:1.25em;font-weight:700;letter-spacing:.5px}.close-btn{background:#ffffff1a;border:none;color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5em;cursor:pointer;line-height:1;padding:0;transition:background .2s}.close-btn:hover{background:#fff3}.settings-content{flex:1;overflow-y:auto;padding:25px}.settings-section{margin-bottom:35px}.settings-section h3{margin:0 0 20px;font-size:.85em;color:#888;text-transform:uppercase;letter-spacing:1px;font-weight:700}.control-group{margin-bottom:25px}.control-group label{display:block;margin-bottom:12px;font-size:.95em;color:#ddd;font-weight:500}input[type=range]{width:100%;accent-color:#4CAF50;height:6px;background:#ffffff1a;border-radius:3px;outline:none}.mode-toggle{display:flex;gap:8px;background:#0003;padding:4px;border-radius:12px}.mode-toggle button{flex:1;background:transparent;color:#888;border:none;padding:12px;font-size:.9em;border-radius:8px;box-shadow:none;text-transform:none;font-weight:500}.mode-toggle button.active{background:#ffffff1a;color:#fff;box-shadow:0 2px 4px #0000001a;font-weight:600}.gears-header{display:grid;grid-template-columns:40px 1fr 1fr 40px;gap:10px;margin-bottom:10px;padding:0 10px;font-size:.8em;color:#666;font-weight:600}.gear-row{display:grid;grid-template-columns:40px 1fr 1fr 40px;gap:10px;align-items:center;background:#ffffff08;margin-bottom:8px;padding:10px;border-radius:8px}.gear-row strong{color:#888}.gear-row input{width:100%;background:#0000004d;border:1px solid rgba(255,255,255,.1);padding:8px;border-radius:6px;color:#fff;font-family:inherit;box-sizing:border-box}.remove-btn{width:30px;height:30px;padding:0;background:#f443361a;color:#f44336;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.2em;box-shadow:none}.add-btn{width:100%;margin-top:15px;background:#ffffff0d;border:1px dashed rgba(255,255,255,.2);box-shadow:none;color:#aaa}.add-btn:hover{background:#ffffff1a;color:#fff}.settings-footer{padding:20px 25px;border-top:1px solid rgba(255,255,255,.05);text-align:right;flex-shrink:0;background:#0003;border-bottom-left-radius:20px;border-bottom-right-radius:20px}.save-btn{width:100%;padding:16px;background:#4caf50;font-size:1em;font-weight:600;letter-spacing:.5px;box-shadow:0 4px 15px #4caf504d}.save-btn:hover{background:#43a047;transform:translateY(-1px);box-shadow:0 6px 20px #4caf5066}.secondary-btn{width:100%;padding:12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.1);color:#fff;font-size:.9em;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s}.secondary-btn:hover{background:#fff3;transform:translateY(-1px)}.mapping-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px}@media(max-width:480px){.mapping-grid{grid-template-columns:1fr}}.speedometer-container{position:relative;width:320px;height:320px;background:radial-gradient(circle at center,#2e2e3e,#1e1e2f 70%);border-radius:50%;box-shadow:0 10px 30px #00000080,inset 0 0 50px #0003,0 0 0 4px #ffffff0d;display:flex;justify-content:center;align-items:center;overflow:hidden}.input-bar-vertical{position:absolute;width:12px;height:160px;background:#00000080;border-radius:6px;overflow:hidden;bottom:80px;border:1px solid rgba(255,255,255,.1);z-index:10;display:flex;align-items:flex-end}.brake-bar{left:45px;bottom:60px;height:140px}.throttle-bar{right:45px;bottom:60px;height:140px}.input-bar-horizontal{position:absolute;width:140px;height:8px;background:#00000080;border-radius:4px;top:40px;left:50%;transform:translate(-50%);overflow:hidden;border:1px solid rgba(255,255,255,.1);z-index:10}.input-fill{width:100%;transition:height .05s linear,width .05s linear,left .05s linear}.brake-fill{background:linear-gradient(to top,#d32f2f,#f44336);box-shadow:0 0 10px #f4433666}.throttle-fill{background:linear-gradient(to top,#388e3c,#4caf50);box-shadow:0 0 10px #4caf5066}.steering-fill{position:absolute;height:100%;top:0;background:#2196f3;box-shadow:0 0 8px #2196f380}.steering-center-mark{position:absolute;left:50%;top:0;height:100%;width:2px;background:#fff6;transform:translate(-50%);z-index:20}.speedometer-svg{width:100%;height:100%;position:absolute;top:0;left:0}.center-readout{position:absolute;top:60%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:2}.readout-value{font-family:Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:3.5em;font-weight:800;color:#fff;line-height:1;text-shadow:0 0 10px rgba(255,255,255,.2)}.readout-unit{font-size:.7em;color:#666;letter-spacing:2px;margin-top:5px}.gear-indicator{margin-top:15px;font-size:.9em;color:#888;background:#111;padding:4px 12px;border-radius:12px;border:1px solid #333;display:inline-block}.current-gear{color:#4caf50;font-weight:700;font-size:1.2em;margin-left:4px}.launch-btn{position:absolute;bottom:40px;left:50%;transform:translate(-50%);background:#333;color:#888;border:1px solid #444;border-radius:20px;padding:5px 20px;font-size:.75em;font-weight:700;cursor:pointer;transition:all .2s ease;z-index:10;width:auto;min-width:80px}.launch-btn:hover{background:#444;color:#fff}.launch-btn.armed{background:#ff9800;color:#000;border-color:#ff9800;box-shadow:0 0 15px #ff980066;animation:pulse 1s infinite}.launch-btn.firing{background:#00e676;color:#000;border-color:#00e676;box-shadow:0 0 20px #00e67699}@keyframes pulse{0%{transform:translate(-50%) scale(1);opacity:1}50%{transform:translate(-50%) scale(1.05);opacity:.8}to{transform:translate(-50%) scale(1);opacity:1}}.wizard-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:2000}.wizard-card{background:linear-gradient(145deg,#1e1e24,#121212);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:40px;width:500px;text-align:center;box-shadow:0 20px 50px #00000080;color:#fff}.wizard-card h2{margin-top:0;font-size:1.8em;color:#4caf50}.wizard-card p{color:#aaa;line-height:1.5;margin-bottom:30px}.wizard-input-display{height:60px;background:#0000004d;border-radius:10px;display:flex;justify-content:center;align-items:center;margin-bottom:30px;border:2px dashed #333}.input-active{color:#00e676;font-weight:700;font-size:1.2em;animation:popIn .3s ease}.input-waiting{color:#555;font-style:italic}.wizard-actions{display:flex;justify-content:center;gap:20px;margin-bottom:30px}.step-dots{display:flex;justify-content:center;gap:10px}.dot{width:10px;height:10px;border-radius:50%;background:#333;transition:all .3s ease}.dot.active{background:#4caf50;transform:scale(1.3)}.dot.done{background:#2e7d32}@keyframes popIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.version-badge-container{position:fixed;bottom:20px;right:20px;z-index:900;cursor:pointer;display:flex;flex-direction:column;align-items:center}.version-badge{background:#ffffff1a;color:#888;padding:6px 12px;border-radius:20px;font-size:.8em;font-weight:600;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);transition:all .3s;border:1px solid rgba(255,255,255,.05)}.version-badge:hover{background:#fff3;color:#fff;transform:scale(1.05)}.version-badge.pulse{box-shadow:0 0 #4caf50b3;animation:badgePulse 2s infinite;color:#4caf50;background:#4caf501a;border-color:#4caf504d}.attention-arrow{display:flex;flex-direction:column;align-items:center;color:#4caf50;font-weight:700;font-size:1.2em;animation:arrowBounce 1.5s infinite;margin-bottom:5px}.attention-arrow span{font-size:.6em;text-transform:uppercase;background:#4caf50;color:#000;padding:2px 6px;border-radius:4px;margin-bottom:-2px}@keyframes arrowBounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@keyframes badgePulse{0%{transform:scale(.95);box-shadow:0 0 #4caf50b3}70%{transform:scale(1);box-shadow:0 0 0 10px #4caf5000}to{transform:scale(.95);box-shadow:0 0 #4caf5000}}.patch-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:2000;display:flex;justify-content:center;align-items:center;padding:20px;box-sizing:border-box;animation:fadeIn .3s}.patch-modal{background:linear-gradient(135deg,#1e1e28f2,#14141efa);width:100%;max-width:500px;max-height:80vh;border-radius:16px;border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;animation:popUp .3s cubic-bezier(.175,.885,.32,1.275)}.patch-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center}.patch-header h2{margin:0;font-size:1.2em;color:#fff}.patch-content{padding:20px;overflow-y:auto;flex:1}.patch-version{margin-bottom:25px}.patch-version h3{color:#4caf50;margin-top:0;margin-bottom:10px;font-size:1em;border-bottom:1px dashed rgba(76,175,80,.3);padding-bottom:5px}.patch-version.old h3{color:#888;border-color:#ffffff1a}.patch-version ul{margin:0;padding-left:20px;color:#ccc;font-size:.9em;line-height:1.5}.patch-version li{margin-bottom:6px}.patch-footer{padding:20px;text-align:right;border-top:1px solid rgba(255,255,255,.05)}@keyframes popUp{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.about-section{text-align:center;margin-bottom:25px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1)}.developer-credit{font-size:1.1em;color:#fff;margin:5px 0}.license-info{font-size:.8em;color:#888;margin:0 0 15px}.about-links{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.social-link{background:#ffffff14;color:#ddd;text-decoration:none;padding:8px 12px;border-radius:8px;font-size:.85em;transition:all .2s;border:1px solid rgba(255,255,255,.05)}.social-link:hover{background:#ffffff26;color:#fff;transform:translateY(-2px)}
