:root{--bg: #3e3830;--bg-card: #4d4840;--bg-dark: #2e2a23;--surface: #5a554d;--surface-hover: #676259;--border: #706b62;--border-active: #7db891;--text: #f2ede4;--text-dim: #b8b0a0;--text-muted: #a8a298;--accent: #7db891;--accent-light: #9dd1ac;--accent-glow: rgba(125, 184, 145, .18);--green: #6ab87e;--green-glow: rgba(106, 184, 126, .15);--red: #ef4444;--red-glow: rgba(239, 68, 68, .15);--yellow: #eab308;--yellow-glow: rgba(234, 179, 8, .15);--orange: #f97316;--radius: 12px;--radius-sm: 8px;--radius-xs: 4px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;height:100vh;display:flex;flex-direction:column;overflow:hidden}.topbar{height:52px;background:var(--bg-dark);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0}.topbar-left{display:flex;align-items:center;gap:12px}.topbar-brand{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px;color:var(--text);text-decoration:none}.topbar-brand svg{width:20px;height:20px;color:var(--accent-light)}.topbar-sep{width:1px;height:24px;background:var(--border)}.topbar-status{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-dim)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--red)}.status-dot.connected{background:var(--green)}.status-dot.connecting{background:var(--yellow);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.topbar-right{display:flex;align-items:center;gap:10px}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-xs);font-weight:600;font-size:12px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.btn:hover{border-color:var(--accent);color:var(--accent-light)}.btn:active{transform:scale(.97)}.btn svg{width:14px;height:14px}.btn-primary{background:var(--accent);border-color:var(--accent);color:#0f172a}.btn-primary:hover{background:var(--accent-light);border-color:var(--accent-light);color:#000}.btn-danger{border-color:var(--red);color:var(--red)}.btn-danger:hover{background:var(--red-glow)}.btn-success{border-color:var(--green);color:var(--green)}.btn-success:hover{background:var(--green-glow)}.btn-sm{padding:4px 10px;font-size:11px}.btn-icon{padding:7px;border:none;background:transparent;color:var(--text-dim)}.btn-icon:hover{color:var(--text);background:var(--surface)}.user-avatar{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);cursor:pointer}.user-menu-btn{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--surface);color:var(--text-dim);cursor:pointer;font-size:12px;font-family:inherit}.user-menu-btn:hover{border-color:var(--accent)}.tabs{display:flex;background:var(--bg-dark);border-bottom:1px solid var(--border);padding:0 16px;flex-shrink:0}.tab{padding:10px 20px;font-size:13px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:6px}.tab:hover{color:var(--text)}.tab.active{color:var(--accent-light);border-bottom-color:var(--accent)}.tab svg{width:16px;height:16px}.main{flex:1;overflow-y:auto;overflow-x:hidden}.tab-content{display:none;padding:24px;min-height:100%}.tab-content.active{display:block}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-header h3{font-weight:700}.card-body{padding:20px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.connection-bar{display:flex;align-items:center;gap:12px;padding:14px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px}.connection-info{flex:1}.connection-info h4{font-size:13px;font-weight:600}.connection-info p{font-size:12px;color:var(--text-dim)}.wiring-diagram{position:relative;background:var(--bg-dark);border-radius:var(--radius);padding:32px;min-height:400px}.wiring-diagram svg{width:100%;height:auto}.component-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.component-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px}.component-item .pin{padding:2px 8px;background:var(--accent-glow);border:1px solid var(--accent);border-radius:var(--radius-xs);font-family:SF Mono,monospace;font-size:11px;color:var(--accent-light);font-weight:600}.component-item .label{font-weight:600}.component-item .desc{color:var(--text-dim);font-size:12px}.profile-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.profile-btn{padding:14px 8px;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-sm);text-align:center;cursor:pointer;transition:all .15s;font-family:inherit;color:var(--text)}.profile-btn:hover{border-color:var(--accent)}.profile-btn.active{border-color:var(--accent);background:var(--accent-glow)}.profile-btn .num{font-size:22px;font-weight:800;color:var(--accent-light)}.profile-btn .name{font-size:12px;font-weight:600;display:block;margin-top:4px}.profile-btn .detail{font-size:10px;color:var(--text-dim);display:block;margin-top:2px}.profile-btn.level-1:hover{border-color:#10b981}.profile-btn.level-1.active{border-color:#10b981;background:#10b98126!important}.profile-btn.level-1 .num{color:#10b981}.profile-btn.level-2:hover{border-color:#6ab87e}.profile-btn.level-2.active{border-color:#6ab87e;background:#6ab87e26!important}.profile-btn.level-2 .num{color:#6ab87e}.profile-btn.level-3:hover{border-color:#eab308}.profile-btn.level-3.active{border-color:#eab308;background:#eab30826!important}.profile-btn.level-3 .num{color:#eab308}.profile-btn.level-4:hover{border-color:#f97316}.profile-btn.level-4.active{border-color:#f97316;background:#f9731626!important}.profile-btn.level-4 .num{color:#f97316}.profile-btn.level-5:hover{border-color:#ef4444}.profile-btn.level-5.active{border-color:#ef4444;background:#ef444426!important}.profile-btn.level-5 .num{color:#ef4444}.slider-group{margin-bottom:20px}.slider-label{display:flex;justify-content:space-between;margin-bottom:6px;font-size:12px;font-weight:600}.slider-label span:last-child{font-family:SF Mono,monospace;color:var(--accent-light)}input[type=range]{width:100%;height:6px;-webkit-appearance:none;background:var(--text-dim);border-radius:3px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--accent-light)}.remap-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}.remap-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm)}.remap-item .remap-label{font-size:12px;font-weight:600}.remap-item select{padding:4px 8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-size:11px;font-family:inherit}.sensor-btns{display:flex;flex-wrap:wrap;gap:8px}.sensor-btn{padding:10px 16px;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-dim);cursor:pointer;font-size:12px;font-weight:600;font-family:inherit;transition:all .15s;display:flex;align-items:center;gap:6px}.sensor-btn:hover{border-color:var(--accent);color:var(--accent-light);border-style:solid}.sensor-btn svg{width:14px;height:14px}.added-sensors{margin-top:12px}.added-sensor{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px}.added-sensor .sensor-info{display:flex;align-items:center;gap:10px}.added-sensor .sensor-type{padding:2px 8px;background:var(--accent-glow);border-radius:var(--radius-xs);font-size:10px;font-weight:700;color:var(--accent-light);text-transform:uppercase}.added-sensor .sensor-pin{font-size:12px;font-weight:600}.remove-sensor{background:none;border:none;color:var(--text);cursor:pointer;padding:4px;font-size:16px}.remove-sensor:hover{color:var(--red)}.sketch-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:200;background:#000000b3;display:none;align-items:center;justify-content:center;padding:32px}.sketch-modal.open{display:flex}.sketch-modal-content{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:800px;max-height:80vh;display:flex;flex-direction:column}.sketch-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.sketch-modal-header h3{font-size:14px}.sketch-modal-body{flex:1;overflow:auto;padding:0}.sketch-code{font-family:SF Mono,Fira Code,monospace;font-size:12px;line-height:1.6;padding:20px;color:var(--text-dim);white-space:pre;-moz-tab-size:2;tab-size:2}.driver-popover{background:var(--bg-card)!important;color:var(--text)!important;border:1px solid var(--border)!important;border-radius:var(--radius)!important;font-family:inherit!important;box-shadow:0 10px 40px #0009!important;padding:30px!important;max-width:450px!important}.driver-popover-title{font-size:20px!important;font-weight:800!important;color:var(--text)!important;margin-bottom:12px!important}.driver-popover-description{color:var(--text-dim)!important;font-size:16px!important;line-height:1.6!important}.driver-popover-close-btn{color:var(--text-dim)!important;transition:color .15s!important}.driver-popover-close-btn:hover{color:var(--text)!important}.driver-popover-footer{margin-top:20px!important}.driver-popover-progress-text{color:var(--text-dim)!important;font-size:12px!important;font-weight:600!important}.driver-popover-prev-btn,.driver-popover-next-btn{padding:7px 14px!important;border-radius:var(--radius-xs)!important;font-weight:600!important;font-size:12px!important;border:1px solid var(--border)!important;background:var(--surface)!important;color:var(--text)!important;cursor:pointer!important;transition:all .15s!important;text-shadow:none!important}.driver-popover-prev-btn:hover{border-color:var(--accent)!important;color:var(--accent-light)!important;background:var(--surface-hover)!important}.driver-popover-next-btn{background:var(--accent)!important;border-color:var(--accent)!important;color:#2e2a23!important}.driver-popover-next-btn:hover{background:var(--accent-light)!important;border-color:var(--accent-light)!important;color:#000!important}.driver-popover-arrow-side-left .driver-popover-arrow{border-left-color:var(--bg-card)!important}.driver-popover-arrow-side-right .driver-popover-arrow{border-right-color:var(--bg-card)!important}.driver-popover-arrow-side-top .driver-popover-arrow{border-top-color:var(--bg-card)!important}.driver-popover-arrow-side-bottom .driver-popover-arrow{border-bottom-color:var(--bg-card)!important}.snake-container{position:relative;background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.snake-container canvas{display:block;width:100%;cursor:none}.snake-overlay{position:absolute;top:12px;left:12px;display:flex;gap:12px}.snake-score{padding:4px 12px;background:#0a0a0fcc;border:1px solid var(--border);border-radius:var(--radius-xs);font-size:12px;font-weight:700;color:var(--accent-light)}.controller-map{background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius);padding:24px;position:relative}.controller-visual{max-width:600px;margin:0 auto;position:relative}.ctrl-body{background:var(--surface);border:2px solid var(--border);border-radius:40px;padding:24px 32px;position:relative}.ctrl-shoulders{display:flex;justify-content:space-between;margin-bottom:8px}.ctrl-shoulder-group{display:flex;gap:8px}.ctrl-btn{padding:6px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:11px;font-weight:700;color:var(--text-dim);text-align:center;transition:all .1s;min-width:40px}.ctrl-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 12px var(--accent-glow)}.ctrl-dpad{position:relative;width:90px;height:90px}.ctrl-dpad-label{position:absolute;top:-16px;left:0;font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.dpad-up,.dpad-down,.dpad-left,.dpad-right,.dpad-center{position:absolute;width:28px;height:28px;background:var(--bg-card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-dim);transition:all .1s}.dpad-up{top:0;left:31px;border-radius:6px 6px 0 0}.dpad-down{bottom:0;left:31px;border-radius:0 0 6px 6px}.dpad-left{top:31px;left:0;border-radius:6px 0 0 6px}.dpad-right{top:31px;right:0;border-radius:0 6px 6px 0}.dpad-center{top:31px;left:31px}.ctrl-center{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 0}.ctrl-face{position:relative;width:90px;height:90px}.ctrl-face-label{position:absolute;top:-16px;right:0;font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.face-y,.face-a,.face-x,.face-b{position:absolute;width:32px;height:32px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text-dim);transition:all .1s}.face-y{top:0;left:29px}.face-a{bottom:0;left:29px}.face-x{top:29px;left:0}.face-b{top:29px;right:0}.ctrl-sticks{display:flex;justify-content:center;gap:60px;padding:12px 0}.ctrl-stick{width:60px;height:60px;border-radius:50%;background:var(--bg-card);border:2px solid var(--border);position:relative;display:flex;align-items:center;justify-content:center}.ctrl-stick-dot{width:16px;height:16px;border-radius:50%;background:var(--text-muted);transition:all .05s}.ctrl-stick-label{position:absolute;bottom:-18px;font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;white-space:nowrap}.ctrl-pads{display:flex;justify-content:space-between;margin-top:12px}.ctrl-pad{width:45%;height:48px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;transition:all .1s}.ctrl-main{display:flex;align-items:flex-start;justify-content:space-between;padding:8px 0}.dpad-up.active,.dpad-down.active,.dpad-left.active,.dpad-right.active,.face-y.active,.face-a.active,.face-x.active,.face-b.active,.ctrl-pad.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 12px var(--accent-glow)}.serial-monitor{background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.serial-monitor-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border)}.serial-monitor-header h4{font-size:12px;font-weight:700}.serial-output{height:200px;overflow-y:auto;padding:12px 16px;font-family:SF Mono,Fira Code,monospace;font-size:11px;line-height:1.7;color:var(--green)}.serial-output .line-error{color:var(--red)}.serial-output .line-info{color:var(--accent-light)}.serial-input-row{display:flex;border-top:1px solid var(--border)}.serial-input{flex:1;padding:10px 16px;background:var(--surface);border:none;color:var(--text);font-family:SF Mono,Fira Code,monospace;font-size:12px;outline:none}.serial-input::placeholder{color:var(--text-muted)}.serial-send{padding:10px 16px;background:var(--accent);border:none;color:var(--bg);font-weight:700;font-size:12px;cursor:pointer;font-family:inherit}.serial-send:hover{background:var(--accent-light)}.joystick-mockup{background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius);padding:24px;text-align:center}.mockup-visual{position:relative;width:200px;height:200px;margin:0 auto 16px}.mockup-base{width:200px;height:200px;border-radius:50%;border:3px solid var(--border);position:relative;display:flex;align-items:center;justify-content:center}.mockup-deadzone{border-radius:50%;border:1.5px dashed var(--text-dim);position:absolute;transition:width .2s cubic-bezier(.34,1.56,.64,1),height .2s cubic-bezier(.34,1.56,.64,1);pointer-events:none}.mockup-cursor{width:12px;height:12px;border-radius:50%;background:var(--accent);position:absolute;transition:all .05s;box-shadow:0 0 8px var(--accent-glow)}.mockup-crosshair-h{position:absolute;width:100%;height:1px;background:var(--border);top:50%}.mockup-crosshair-v{position:absolute;height:100%;width:1px;background:var(--border);left:50%}.mockup-label{font-size:11px;color:var(--text-dim);font-weight:600}.mockup-values{display:flex;justify-content:center;gap:24px;margin-top:8px}.mockup-val{font-family:SF Mono,monospace;font-size:12px;color:var(--accent-light)}.auth-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:300;background:#000000bf;display:none;align-items:center;justify-content:center;padding:32px}.auth-modal.open{display:flex}.auth-modal-content{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:40px;width:100%;max-width:400px;text-align:center}.auth-modal-content h2{font-size:22px;margin-bottom:8px}.auth-modal-content p{color:var(--text-dim);font-size:14px;margin-bottom:24px}.auth-google-btn{width:100%;padding:12px;background:#fff;border:1px solid #ddd;border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:#333;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;font-family:inherit;margin-bottom:12px}.auth-google-btn:hover{background:#f5f5f5}.auth-google-btn img{width:18px;height:18px}.auth-divider{color:var(--text-muted);font-size:12px;margin:16px 0}.auth-input{width:100%;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;margin-bottom:10px;outline:none;font-family:inherit}.auth-input:focus{border-color:var(--accent)}.auth-submit{width:100%;padding:12px;background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit}.auth-submit:hover{background:var(--accent-light)}.auth-toggle{margin-top:16px;font-size:13px;color:var(--text-dim)}.auth-toggle a{color:var(--accent-light);cursor:pointer}.auth-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-dim);font-size:24px;cursor:pointer}.save-indicator{font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:4px}.save-indicator.saving{color:var(--yellow)}.save-indicator.saved{color:var(--green)}.board-select{padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-size:12px;font-family:inherit}.toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;color:var(--text);box-shadow:0 8px 32px #0006;z-index:400;transform:translateY(100px);opacity:0;transition:all .3s}.toast.show{transform:translateY(0);opacity:1}.toast.success{border-color:var(--green)}.toast.error{border-color:var(--red)}@media (max-width: 768px){.grid-2,.grid-3{grid-template-columns:1fr}.profile-grid{grid-template-columns:repeat(3,1fr)}.ctrl-body,.tab-content{padding:16px}}.sensor-toolbox{display:flex;flex-wrap:wrap;gap:12px;background:var(--bg-dark);padding:16px;border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:24px}.toolbox-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:grab;width:100px;transition:all .2s;-webkit-user-select:none;user-select:none}.toolbox-item:hover{border-color:var(--accent);background:var(--surface-hover);transform:translateY(-2px)}.toolbox-item:active{cursor:grabbing}.toolbox-item svg{width:24px;height:24px;color:var(--accent-light)}.toolbox-item span{font-size:11px;font-weight:600;text-align:center;color:var(--text-dim)}.jack-slots{display:grid;grid-template-columns:1fr 1fr;gap:16px}.jack-slot{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:140px;background:var(--bg-dark);border:2px dashed var(--border);border-radius:var(--radius);transition:all .2s;position:relative}.jack-slot.drag-over{border-color:var(--accent);background:var(--accent-glow)}.jack-slot-label{position:absolute;top:12px;left:12px;font-size:10px;font-weight:800;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em}.jack-slot-pin{position:absolute;top:12px;right:12px;font-size:10px;font-weight:700;color:var(--accent);background:var(--accent-glow);padding:2px 6px;border-radius:4px}.jack-empty-state{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted)}.jack-empty-state svg{width:32px;height:32px;opacity:.3}.jack-empty-state span{font-size:12px}.jack-occupied-state{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;padding:20px}.jack-occupied-state .sensor-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--accent-glow);border-radius:50%;color:var(--accent-light)}.jack-occupied-state .sensor-icon svg{width:24px;height:24px}.jack-occupied-state .sensor-name{font-size:14px;font-weight:700;color:var(--text)}.jack-remove-btn{margin-top:8px;font-size:11px;color:var(--red);background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.jack-remove-btn:hover{background:var(--red-glow)}
