*{box-sizing:border-box}:root{font-family:Courier New,monospace;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#1a1a1a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}.cylinder-track{display:flex;flex-direction:column;gap:1rem;height:100%}.cylinder-track__header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.cylinder-track__header h3{margin:0;font-size:1rem}.cylinder-track__header p{margin:.2rem 0 0;color:#bbb;font-size:.85rem}.cylinder-track__stats{text-align:right;display:flex;flex-direction:column;gap:.1rem}.stat-label{font-size:.8rem;color:#aaa;text-transform:uppercase}.stat-value{font-size:1.4rem;font-weight:700;color:#fff}.stat-subtle{font-size:.85rem;color:#bbb}.cylinder-track__axis{display:flex;justify-content:space-between;font-size:.85rem;color:#888}.cylinder-track__bar{position:relative;height:32px;border-radius:999px;background:linear-gradient(90deg,#2d2d2d,#111);border:1px solid rgba(255,255,255,.08);overflow:hidden}.cylinder-track__fill{position:absolute;top:0;bottom:0;left:0;background:linear-gradient(90deg,#39a8ff4d,#1c78d499)}.cylinder-track__indicator{position:absolute;top:-6px;width:12px;height:44px;border-radius:999px;background:linear-gradient(135deg,#39a8ff,#1c78d4);box-shadow:0 0 10px #39a8ff99;transform:translate(-50%);transition:left .2s ease}.telemetry-panel{display:flex;flex-direction:column;gap:.75rem;padding:1rem}.telemetry-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #444}.telemetry-item:last-child{border-bottom:none}.telemetry-label{color:#aaa;font-size:.875rem}.telemetry-value{color:#fff;font-weight:500;font-size:.875rem}.live-graph-recharts{display:flex;flex-direction:column;height:100%;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:#171717;overflow:hidden}.graph-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.05);background:#ffffff03}.graph-title{display:flex;flex-direction:column;gap:.25rem}.graph-title h3{margin:0;font-size:1rem;font-weight:600;color:#fff;letter-spacing:.5px}.graph-subtitle{font-size:.75rem;color:#888;font-weight:400}.graph-controls{display:flex;gap:.75rem}.graph-controls button{padding:.45rem 1rem;font-size:.85rem;background:#242424;border:1px solid rgba(255,255,255,.1);color:#f0f0f0;cursor:pointer;border-radius:6px;font-family:inherit;font-weight:500;transition:background .2s ease,color .2s ease}.graph-controls button:hover:not(:disabled){background:#2e2e2e}.graph-controls button:disabled{opacity:.6;cursor:not-allowed}.graph-controls button.capturing{background:linear-gradient(135deg,#d32f2f,#b71c1c);border-color:#ff5252;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.graph-content{flex:1;min-height:0;padding:.75rem 1.1rem 1.1rem}.graph-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#666;text-align:center;padding:2rem}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.graph-empty p{margin:.5rem 0;font-size:.875rem}.empty-hint{color:#555;font-size:.75rem;font-style:italic}.control-panel{display:flex;flex-direction:column;gap:1rem;padding:1rem}.control-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.control-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;border:1px solid #555;border-radius:4px;background:#2a2a2a}.control-label{color:#ccc;font-size:.875rem;margin-bottom:.5rem}.control-item button{padding:.5rem 1rem;font-size:.875rem;background:#3a3a3a;border:1px solid #555;color:#fff;cursor:pointer;border-radius:4px}.control-item button:hover{background:#4a4a4a;border-color:#666}.control-select{padding:.5rem;font-size:.875rem;background:#3a3a3a;border:1px solid #555;color:#fff;border-radius:4px;cursor:pointer}.control-select:hover{background:#4a4a4a;border-color:#666}.control-select:focus{outline:none;border-color:#666}.control-input-group{display:flex;gap:.5rem;align-items:center}.control-slider{flex:1;height:6px;background:#3a3a3a;border-radius:3px;outline:none;-webkit-appearance:none}.control-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:#4a9eff;border-radius:50%;cursor:pointer}.control-slider::-moz-range-thumb{width:16px;height:16px;background:#4a9eff;border-radius:50%;cursor:pointer;border:none}.control-value{min-width:3rem;text-align:right;color:#fff;font-weight:600}.control-input{flex:1;padding:.5rem;font-size:.875rem;background:#3a3a3a;border:1px solid #555;color:#fff;border-radius:4px;min-width:0}.control-input:focus{outline:none;border-color:#666}.log-viewer{display:flex;flex-direction:column;height:100%;border:1px solid #555;border-radius:4px;background:#1a1a1a;overflow:hidden}.log-viewer-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid #555;background:#2a2a2a}.log-viewer-header h3{margin:0;font-size:.875rem;font-weight:400;color:#ccc}.log-controls{display:flex;gap:1rem;align-items:center}.log-count{font-size:.75rem;color:#888}.log-clear-button{padding:.25rem .75rem;font-size:.75rem;background:#3a3a3a;border:1px solid #555;color:#fff;cursor:pointer;border-radius:4px;font-family:inherit}.log-clear-button:hover{background:#4a4a4a;border-color:#666}.log-viewer-content{flex:1;overflow-y:auto;padding:.5rem;font-family:Courier New,monospace;font-size:.75rem;line-height:1.4}.log-viewer-content::-webkit-scrollbar{width:8px}.log-viewer-content::-webkit-scrollbar-track{background:#1a1a1a}.log-viewer-content::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.log-viewer-content::-webkit-scrollbar-thumb:hover{background:#555}.log-empty{color:#666;text-align:center;padding:2rem;font-style:italic}.log-entry{display:flex;gap:.5rem;padding:.25rem .5rem;border-radius:2px;margin-bottom:1px}.log-entry:hover{background:#ffffff0d}.log-timestamp{color:#666;min-width:80px}.log-level{font-weight:600;min-width:60px}.log-message{color:#ccc;flex:1;word-break:break-word}.log-level-debug .log-level{color:#888}.log-level-info .log-level{color:#4caf50}.log-level-warning .log-level{color:#ff9800}.log-level-error .log-level{color:#f44336}.log-level-debug{background:#8888880d}.log-level-info{background:#4caf500d}.log-level-warning{background:#ff98001a}.log-level-error{background:#f443361a}.joystick-visualization{padding:1rem;background:#1a1a1a;border-radius:8px;border:1px solid #333}.joystick-header{margin-bottom:1rem}.joystick-header h3{margin:0 0 .5rem;font-size:1rem;color:#fff}.joystick-stats{display:flex;gap:1rem;flex-wrap:wrap;font-size:.85rem}.stat-item{color:#aaa}.stat-item strong{color:#fff;font-weight:600}.stat-item.deadzone-active,.stat-item.deadzone-active strong{color:orange}.joystick-container{margin:1.5rem 0}.joystick-track{position:relative;height:60px;background:#2a2a2a;border-radius:8px;border:2px solid #444;overflow:hidden}.deadzone-indicator{position:absolute;top:0;height:100%;background:#ffa50033;border-left:1px solid rgba(255,165,0,.5);border-right:1px solid rgba(255,165,0,.5);pointer-events:none}.center-line{position:absolute;left:50%;top:0;bottom:0;width:2px;background:#666;transform:translate(-50%);pointer-events:none}.position-indicator{position:absolute;top:50%;width:12px;height:12px;background:#4a9eff;border:2px solid #fff;border-radius:50%;transform:translate(-50%,-50%);transition:left .1s ease-out;pointer-events:none;box-shadow:0 0 8px #4a9eff80}.position-indicator.in-deadzone{background:orange;box-shadow:0 0 8px #ffa50080}.joystick-label{position:absolute;top:-20px;font-size:.75rem;color:#888;transform:translate(-50%)}.joystick-label.left{left:0}.joystick-label.center{left:50%}.joystick-label.right{right:0;transform:translate(50%)}.joystick-calibration-info{display:flex;gap:1rem;flex-wrap:wrap;padding-top:.5rem;border-top:1px solid #333;font-size:.85rem}.calib-item{color:#aaa}.calib-item span{margin-right:.25rem}.calib-item strong{color:#fff;font-weight:600}.settings-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.settings-window{background-color:#1e1e1e;border:1px solid #444;border-radius:8px;width:90%;max-width:800px;max-height:90vh;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:20px;box-shadow:0 10px 25px #00000080;color:#e0e0e0}.settings-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #444;padding-bottom:10px}.settings-header h2{margin:0;font-size:1.5rem}.close-button{background:none;border:none;color:#aaa;font-size:1.5rem;cursor:pointer}.close-button:hover{color:#fff}.settings-section{background-color:#2d2d2d;padding:15px;border-radius:4px}.settings-section h3{margin-top:0;margin-bottom:15px;font-size:1.1rem;border-bottom:1px solid #444;padding-bottom:5px}.input-group{display:flex;gap:20px;flex-wrap:wrap}.input-field{display:flex;flex-direction:column;gap:5px}.input-field label{font-size:.85rem;color:#aaa}.input-field input{background-color:#1a1a1a;border:1px solid #444;color:#fff;padding:5px 8px;border-radius:4px;width:120px}.input-field select{background-color:#1a1a1a;border:1px solid #444;color:#fff;padding:5px 8px;border-radius:4px}.map-editor{display:flex;flex-direction:column;gap:10px}.map-row{display:flex;align-items:center;gap:10px;background-color:#252525;padding:5px;border-radius:4px}.map-row-index{width:20px;text-align:center;color:#777;font-size:.8rem}.remove-button,.add-button{padding:4px 8px;border-radius:4px;cursor:pointer;font-size:.8rem;border:1px solid #555}.remove-button{background-color:#4a2020;color:#faa}.remove-button:hover{background-color:#6a2020}.add-button{background-color:#204a20;color:#afa;margin-top:10px;align-self:flex-start}.add-button:hover{background-color:#306a30}.add-button:disabled,.remove-button:disabled{opacity:.5;cursor:not-allowed;background-color:#333;color:#555}.test-button{background-color:#345;color:#adf;padding:4px 8px;border:1px solid #445566;border-radius:4px;cursor:pointer;font-size:.8rem;margin-left:auto}.test-button:hover{background-color:#456}.settings-footer{display:flex;justify-content:space-between;align-items:center;padding-top:15px;border-top:1px solid #444;margin-top:10px}.settings-status{display:flex;gap:15px;align-items:center}.settings-changed{color:orange;font-size:.9rem}.settings-disconnected{color:#f44336;font-size:.9rem}.settings-info{color:#bbb;font-size:.85rem}.settings-actions{display:flex;gap:10px}.settings-save-button{background-color:#4caf50;color:#fff;padding:8px 20px;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:600}.settings-save-button:hover:not(:disabled){background-color:#5cbf60}.settings-save-button:disabled{background-color:#555;color:#888;cursor:not-allowed}.settings-cancel-button{background-color:#555;color:#fff;padding:8px 20px;border:1px solid #666;border-radius:4px;cursor:pointer;font-size:.9rem}.settings-cancel-button:hover{background-color:#666}.calibration-section{display:flex;flex-direction:column;gap:.75rem}.calibration-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.calibration-progress{flex:1;display:flex;align-items:center;gap:.5rem}.calibration-progress-bar{flex:1;height:8px;border-radius:4px;background:#ffffff1a;overflow:hidden}.calibration-progress-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,#4caf50,#8bc34a);transition:width .2s ease}.calibration-progress-text{font-size:.85rem;color:#fff;min-width:3rem;text-align:right}.calibration-message{margin:0;color:#bbb;font-size:.9rem}.calibration-message.calibration-success{color:#4caf50;font-weight:600}.calibration-message.calibration-failed{color:#f44336;font-weight:600}.calibration-values{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.calibration-value{display:flex;flex-direction:column;padding:.75rem;border:1px solid #444;border-radius:4px;background:#0003;text-align:center}.calibration-value span{color:#aaa;font-size:.8rem}.calibration-value strong{color:#fff;font-size:1.1rem;margin-top:.25rem}.app{min-height:100vh;background:linear-gradient(135deg,#0a0a0a,#1a1a1a);color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;display:flex;flex-direction:column}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #333;background:linear-gradient(135deg,#2a2a2a,#1f1f1f);box-shadow:0 2px 10px #00000080}.app-header h1{margin:0;font-size:1.75rem;font-weight:700;color:#fff;letter-spacing:1px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.connection-controls{display:flex;gap:1rem;align-items:center}.connection-status{color:#4caf50;font-size:.875rem;font-weight:500}.webhid-warning{color:#ff9800;font-size:.75rem;padding:.25rem .5rem;background:#ff98001a;border-radius:4px}.connect-button:disabled{opacity:.5;cursor:not-allowed}.debug-button{padding:.5rem 1rem;font-size:.75rem;background:#3a3a3a;border:1px solid #555;color:#fff;cursor:pointer;border-radius:4px;font-family:inherit;opacity:.7}.debug-button:hover{background:#4a4a4a;border-color:#666;opacity:1}.connect-button,.disconnect-button{padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;background:linear-gradient(135deg,#4caf50,#45a049);border:none;color:#fff;cursor:pointer;border-radius:8px;font-family:inherit;transition:all .3s ease;box-shadow:0 4px 6px #4caf504d}.connect-button:hover{background:linear-gradient(135deg,#5cbd5f,#4caf50);transform:translateY(-2px);box-shadow:0 6px 12px #4caf5066}.disconnect-button{background:linear-gradient(135deg,#f44336,#d32f2f);box-shadow:0 4px 6px #f443364d}.disconnect-button:hover{background:linear-gradient(135deg,#ff5252,#f44336);transform:translateY(-2px);box-shadow:0 6px 12px #f4433666}.app-main{flex:1;padding:1.25rem clamp(1rem,3vw,2.5rem);padding-bottom:12rem;display:flex;flex-direction:column;gap:1.25rem}.top-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}.visualization-panel,.telemetry-panel-wrapper,.joystick-panel{border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#1f1f1f;padding:1.25rem;box-shadow:0 10px 30px #00000059}.visualization-panel h2,.telemetry-panel-wrapper h2{margin:0 0 1.5rem;font-size:1.125rem;font-weight:600;color:#fafafa;letter-spacing:.4px}.middle-section{width:100%;height:420px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#1f1f1f;padding:1.25rem;box-shadow:0 10px 30px #00000059;display:flex;flex-direction:column}.bottom-section{width:100%;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#1f1f1f;padding:1.25rem;box-shadow:0 10px 30px #00000059}.logs-section{width:100%;min-height:220px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#1f1f1f;padding:1.25rem;box-shadow:0 10px 30px #00000059}.app-footer{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 2rem;border-top:2px solid #333;background:#0f0f0ff2;box-shadow:0 -8px 24px #0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200}.app-footer__status{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.status-dot{width:10px;height:10px;border-radius:50%;box-shadow:0 0 6px #fff6}.status-dot--connected{background:#4caf50}.status-dot--disconnected{background:#f44336}.app-footer__status-text{font-size:.85rem;color:#ccc}.app-footer__status-text--pending{color:#ffb74d}.app-footer__status-text--error{color:#f44336}.app-footer__status-text--success{color:#81c784}.app-footer__actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;justify-content:flex-end}.app-footer button{padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;background:linear-gradient(135deg,#3a3a3a,#2a2a2a);border:1px solid #555;color:#fff;cursor:pointer;border-radius:8px;font-family:inherit;transition:all .3s ease;box-shadow:0 2px 4px #0003}.app-footer button:hover{background:linear-gradient(135deg,#4a4a4a,#3a3a3a);border-color:#666;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.app-footer__save{background:linear-gradient(135deg,#4caf50,#43a047);border-color:#66bb6a;color:#fff;box-shadow:0 4px 10px #4caf5066}.app-footer__save:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.telemetry-loader{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;margin-bottom:1rem;border:1px solid #555;border-radius:8px;background:#0f0f0fd9;box-shadow:0 4px 10px #0006}.telemetry-loader__spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.15);border-top-color:#4caf50;border-radius:50%;animation:telemetry-spin 1s linear infinite}.telemetry-loader__title{margin:0;font-weight:600;letter-spacing:.5px}.telemetry-loader__subtitle{margin:.15rem 0 0;color:#bbb;font-size:.85rem}@keyframes telemetry-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
