@import url(https://fonts.googleapis.com/css2?family=Atkinson+Hyperlegible:ital,wght@0,400;0,700;1,400;1,700&display=swap);:root{--background-primary:#fff;--background-secondary:#f8f9fa;--background-tertiary:#e9ecef;--text-primary:#495057;--text-secondary:#6c757d;--border-color:#dee2e6;--border-light:#e0e0e0;--shadow-light:#0000000d;--shadow-medium:#0000001a;--accent-color:#007acc;--accent-hover:#0056b3;--danger-color:#dc3545;--danger-hover:#c82333}[data-theme=dark]{--background-primary:#1a1a1a;--background-secondary:#2d2d2d;--background-tertiary:#3a3a3a;--text-primary:#e0e0e0;--text-secondary:#b0b0b0;--border-color:#404040;--border-light:#555;--shadow-light:#0000004d;--shadow-medium:#00000080;--accent-color:#4dabf7;--accent-hover:#339af0;--danger-color:#ff6b7a;--danger-hover:#ff5252}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;background-color:var(--background-primary);color:#495057;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;transition:background-color .3s ease,color .3s ease}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--font-gm-primary:Arial,Helvetica,sans-serif;--font-gm-display:Georgia,"Times New Roman",serif;--font-standard-sans:Arial,Helvetica,sans-serif;--font-standard-serif:"Times New Roman",Times,serif;--font-high-legibility:Verdana,Arial,sans-serif;--font-dyslexia:"OpenDyslexic",Verdana,Arial,sans-serif;--font-low-vision:"Atkinson Hyperlegible",Verdana,Arial,sans-serif;--font-high-contrast:"Arial Black",Arial,sans-serif;--font-size-default:18px;--font-size-large:22px;--font-size-extra-large:28px;--font-size-vision-impaired:24px;--font-size-motor-impaired:20px;--line-height-default:1.5;--line-height-accessibility:1.6;--line-height-dyslexia:1.8;--letter-spacing-default:normal;--letter-spacing-dyslexia:0.05em;--letter-spacing-low-vision:0.03em}.font-gm-brand{font-family:Arial,Helvetica,sans-serif;font-family:var(--font-gm-primary)}.font-dyslexia-friendly{font-family:OpenDyslexic,Verdana,Arial,sans-serif;font-family:var(--font-dyslexia);letter-spacing:.05em;letter-spacing:var(--letter-spacing-dyslexia);line-height:1.8;line-height:var(--line-height-dyslexia)}.font-low-vision{font-family:Atkinson Hyperlegible,Verdana,Arial,sans-serif;font-family:var(--font-low-vision);font-size:24px;font-size:var(--font-size-vision-impaired);letter-spacing:.03em;letter-spacing:var(--letter-spacing-low-vision);line-height:1.6;line-height:var(--line-height-accessibility)}.font-high-contrast{font-family:Arial Black,Arial,sans-serif;font-family:var(--font-high-contrast);font-weight:900}.font-motor-accessible{font-size:20px;font-size:var(--font-size-motor-impaired)}.font-cognitive-accessible,.font-motor-accessible{font-family:Arial,Helvetica,sans-serif;font-family:var(--font-standard-sans);line-height:1.6;line-height:var(--line-height-accessibility)}.font-cognitive-accessible{font-size:22px;font-size:var(--font-size-large)}@media (max-width:768px){:root{--font-size-default:16px;--font-size-large:20px;--font-size-extra-large:24px;--font-size-vision-impaired:22px;--font-size-motor-impaired:18px}}@media (max-width:480px){:root{--font-size-default:14px;--font-size-large:18px;--font-size-extra-large:22px;--font-size-vision-impaired:20px;--font-size-motor-impaired:16px}}.font-preload{font-family:Arial,Helvetica,sans-serif,OpenDyslexic,Verdana,Atkinson Hyperlegible;font-family:var(--font-gm-primary),var(--font-dyslexia),var(--font-low-vision);height:0;position:absolute;visibility:hidden;width:0}@media print{*{font-family:Arial,Helvetica,sans-serif!important;font-family:var(--font-standard-sans)!important}}.canvas-component{box-sizing:border-box;transition:all .2s ease}.canvas-component *{pointer-events:none!important;-webkit-user-select:none!important;user-select:none!important}.canvas-component .handle{pointer-events:auto!important}.canvas-component:hover{box-shadow:0 4px 12px #0003!important}.canvas-component.selected{box-shadow:0 0 0 2px #ff6b35,0 4px 12px #ff6b354d!important}.component-icon{flex-shrink:0}.component-text{font-weight:600;line-height:1.2;text-align:center}.component-subtext{line-height:1;margin-top:2px;text-align:center}.selection-handles{bottom:-4px;left:-4px;pointer-events:none;position:absolute;right:-4px;top:-4px;z-index:1000}.handle{background:#ff6b35;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000004d;cursor:nw-resize;height:16px;pointer-events:auto!important;position:absolute;transition:transform .1s ease;width:16px;z-index:1001}.handle:hover{background:#ff4500;transform:scale(1.2)}.handle-nw{cursor:nw-resize;left:0;top:0}.handle-ne{cursor:ne-resize;right:0;top:0}.handle-sw{bottom:0;cursor:sw-resize;left:0}.handle-se{bottom:0;cursor:se-resize;right:0}.canvas-component.button{border-radius:8px}.canvas-component.slider{border-radius:12px}.canvas-component.display{background:#f8f9fa!important;border:2px solid #dee2e6!important;color:#333!important}@keyframes pulse{0%{opacity:.5}to{opacity:1}}.canvas{background:#383838;border:2px solid var(--border-color);border-radius:8px;height:600px;margin:20px;overflow:hidden;position:relative;transition:background-color .3s ease,border-color .3s ease;width:800px}.canvas-grid{background-image:radial-gradient(circle,#fffc 1px,#0000 0),radial-gradient(circle,#0000004d 1px,#0000 0);background-position:0 0,1px 1px;background-size:20px 20px,20px 20px;background-size:var(--grid-size,20px) var(--grid-size,20px),var(--grid-size,20px) var(--grid-size,20px);height:100%;left:0;opacity:.5;opacity:var(--grid-opacity,.5);pointer-events:none;position:absolute;top:0;transition:opacity .2s ease;width:100%;z-index:1}.canvas-grid.hidden{opacity:0;pointer-events:none}.canvas-empty{color:#6c757d;left:50%;pointer-events:none;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.canvas-empty h3{font-size:24px;margin:0 0 10px}.canvas-empty p{font-size:16px;margin:0}@media (max-width:768px){.canvas{height:400px;margin:10px;max-width:500px;width:100%}}.vehicle-ui{background:#000;color:#fff;color:var(--text-color,#fff);font-family:Arial,sans-serif;font-family:var(--active-font-family,Arial,sans-serif);height:100vh;left:0;margin:0;min-height:100vh;overflow:hidden;padding:0;position:fixed;top:0;width:100vw}.vehicle-ui .canvas{background-image:none!important;background-size:auto!important;border:none!important;border-radius:0!important;box-shadow:none!important;margin:0!important}.vehicle-ui-loading{align-items:center;background:#000;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #333;border-radius:50%;border-top-color:#fff;height:50px;margin-bottom:20px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.dev-profile-switcher{background:#000c;border-radius:6px;padding:10px;position:fixed;right:10px;top:10px;z-index:1000}.profile-select{background:#fff;background:var(--background-color,#fff);border:1px solid #ccc;border:1px solid var(--border-color,#ccc);border-radius:4px;color:#333;color:var(--text-color,#333);font-size:14px;padding:5px 10px}.vehicle-interface{max-width:800px;text-align:center;width:100%}.vehicle-header{margin-bottom:40px}.vehicle-title{color:#fff;color:var(--text-color,#fff);font-family:Arial,sans-serif;font-family:var(--active-font-family,Arial,sans-serif);font-size:2.5rem;font-weight:700;margin:0 0 20px}.accessibility-indicator{background:#004c97;background:var(--primary-color,#004c97);margin:0 auto}.accessibility-indicator,.config-indicator{align-items:center;border-radius:20px;color:#fff;color:var(--button-text-color,#fff);display:flex;font-size:14px;gap:8px;justify-content:center;padding:8px 16px;width:-webkit-fit-content;width:fit-content}.config-indicator{background:#28a745;background:var(--secondary-color,#28a745);margin:0 auto 0 12px}.accessibility-icon{font-size:16px}.vehicle-canvas{background:#f8f9fa;background:var(--background-color,#f8f9fa);border-radius:8px;box-shadow:0 4px 6px #0000001a;margin:20px auto;overflow:hidden}.vehicle-controls{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin:0 auto 40px;max-width:600px;padding:20px}.vehicle-control-button{align-items:center;background:#004c97;background:var(--primary-color,#004c97);border:2px solid #06c;border:2px solid var(--border-color,#06c);border-radius:12px;box-shadow:0 4px 8px #0003;color:#fff;color:var(--button-text-color,#fff);cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:8px;justify-content:center;min-height:120px;padding:16px;transition:all .3s ease}.vehicle-control-button:hover{background:#036;background:var(--primary-hover-color,#036);border-color:#06c;border-color:var(--secondary-color,#06c);box-shadow:0 6px 12px #0000004d;transform:translateY(-2px)}.vehicle-control-button:focus{outline:3px solid #4caf50;outline:3px solid var(--focus-color,#4caf50);outline-offset:2px}.vehicle-control-button:active{box-shadow:0 2px 4px #0003;transform:translateY(0)}.control-icon{font-size:2.5rem;line-height:1}.control-label{word-wrap:break-word;font-size:inherit;font-weight:500;text-align:center}.vehicle-status{background:#ffffff1a;border:1px solid #fff3;border:1px solid var(--border-color,#fff3);border-radius:8px;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-around;margin:0 auto;max-width:500px;padding:20px}.status-item{align-items:center;display:flex;flex-direction:column;gap:4px}.status-label{font-size:14px;font-weight:500;opacity:.8}.status-value{color:#fff;color:var(--text-color,#fff);font-size:18px;font-weight:700}@media (max-width:768px){.vehicle-ui{padding:10px}.vehicle-title{font-size:2rem}.vehicle-controls{gap:15px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));padding:15px}.vehicle-control-button{min-height:100px;padding:12px}.control-icon{font-size:2rem}.vehicle-status{align-items:center;flex-direction:column}}@media (max-width:480px){.vehicle-controls{grid-template-columns:repeat(2,1fr)}.vehicle-title{font-size:1.5rem}}@media (prefers-contrast:high){.vehicle-control-button{border-width:3px}.vehicle-control-button:focus{outline-width:4px}}@media (prefers-reduced-motion:reduce){.vehicle-control-button{transition:none}.vehicle-control-button:hover{transform:none}.loading-spinner{animation:none}}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.toolbar-btn.disabled{cursor:not-allowed!important;opacity:.6}.toolbar-btn.disabled,.toolbar-btn.disabled:hover{background-color:#e0e0e0!important;color:#999!important}.toolbar-btn.disabled:hover{transform:none!important}
/*# sourceMappingURL=main.0f0908a7.css.map*/