:root,[data-theme=light]{--brand: #46a2da;--brand-hover: #3590c8;--brand-light: #e8f4fc;--brand-muted: #a0cfe8;--brand-text: #ffffff;--bg-primary: #ffffff;--bg-secondary: #f6f8fa;--bg-surface: #edf0f4;--bg-hover: #dfe3ea;--bg-toolbar: #f6f8fa;--bg-tabbar: #edf0f4;--text-primary: #1a2332;--text-secondary: #4a5568;--text-muted: #8a95a5;--accent-green: #22a55b;--accent-red: #d6394c;--accent-yellow: #c99a1d;--accent-purple: #7c51d1;--accent-teal: #0f907e;--accent-orange: #d96830;--border: #d8dde5;--border-light: #e8ecf1;--shadow: rgba(26, 35, 50, .08);--shadow-lg: rgba(26, 35, 50, .14);--toolbar-height: 44px;--tabbar-height: 36px;--console-height: 180px;--graph-grid: #e8ecf1;--graph-bg: #fafbfc;--card-bg: #f6f8fa;--tab-active-bg: #ffffff;--tab-active-accent: var(--brand)}[data-theme=dark]{--brand: #4faee3;--brand-hover: #68bde8;--brand-light: #1a3a52;--brand-muted: #2d6d94;--brand-text: #0f1e2d;--bg-primary: #0f1a24;--bg-secondary: #131f2b;--bg-surface: #1a2a38;--bg-hover: #243545;--bg-toolbar: #101c27;--bg-tabbar: #131f2b;--text-primary: #d8e3ee;--text-secondary: #8da1b8;--text-muted: #506880;--accent-green: #4ade80;--accent-red: #f87171;--accent-yellow: #fbbf24;--accent-purple: #a78bfa;--accent-teal: #5eead4;--accent-orange: #fb923c;--border: #243545;--border-light: #1e3040;--shadow: rgba(0, 0, 0, .35);--shadow-lg: rgba(0, 0, 0, .5);--graph-grid: #1a2a38;--graph-bg: #0f1a24;--card-bg: #1a2a38;--tab-active-bg: #0f1a24;--tab-active-accent: var(--brand)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;overflow:hidden;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);transition:background .25s ease,color .25s ease}.toolbar{display:flex;align-items:center;height:var(--toolbar-height);background:var(--brand);border-bottom:none;padding:0 12px;gap:6px;z-index:100;-webkit-user-select:none;user-select:none;color:#fff}.toolbar-logo{display:flex;align-items:center;gap:6px;margin-right:10px;flex-shrink:0}.toolbar-logo img{height:22px;width:auto;filter:brightness(0) invert(1)}.toolbar-brand{font-size:15px;font-weight:700;color:#fff;letter-spacing:-.3px}.toolbar-project-name{display:flex;align-items:center;padding:3px 10px;border-radius:6px;cursor:pointer;min-width:100px;max-width:220px;transition:background .15s}.toolbar-project-name:hover{background:#ffffff26}.project-name-text{font-size:13px;font-weight:500;color:#ffffffd9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-name-input{font-size:13px;font-weight:500;font-family:inherit;background:var(--bg-surface);border:1px solid var(--brand);border-radius:4px;padding:2px 6px;color:var(--text-primary);width:100%;outline:none}.toolbar-group{display:flex;align-items:center;gap:2px;padding:0 6px;border-left:1px solid rgba(255,255,255,.2)}.toolbar-group:first-child{border-left:none}.btn.toolbar-file-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;font-size:12px;color:#fff!important}.btn.toolbar-file-btn:hover{color:#fff!important;background:#ffffff26}.btn.toolbar-file-btn svg{flex-shrink:0;color:#fff;stroke:#fff}.toolbar-separator{width:1px;height:22px;background:#fff3;margin:0 4px}.board-type-chip{display:flex;align-items:center;gap:5px;padding:3px 10px 3px 6px;border:1px solid rgba(255,255,255,.25);border-radius:14px;background:#ffffff14;color:#fff;font-size:12px;cursor:pointer;transition:background .15s}.board-type-chip:hover{background:#ffffff2e}.board-type-icon{font-size:14px}.board-type-label{font-weight:600;white-space:nowrap}.board-type-arrow{font-size:10px;opacity:.7;margin-left:2px}.overlay-dismiss{position:fixed;inset:0;z-index:999}.board-type-dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:280px;z-index:1000;background:var(--bg-card, #1e293b);border:1px solid var(--border, #334155);border-radius:10px;box-shadow:0 8px 24px #0006;overflow:hidden}.board-type-option{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;border:none;background:none;color:var(--text, #e2e8f0);cursor:pointer;text-align:left;font-size:13px;transition:background .12s}.board-type-option:hover{background:#46a2da26}.board-type-option.active{background:#46a2da33}.bto-icon{font-size:22px;flex-shrink:0}.bto-info{display:flex;flex-direction:column;gap:1px;flex:1}.bto-name{font-weight:600;font-size:13px}.bto-desc{font-size:11px;opacity:.6}.bto-check{color:var(--brand, #46a2da);font-weight:700}[data-theme=light] .board-type-chip{border-color:#00000026;background:#0000000f;color:#1e293b}[data-theme=light] .board-type-chip:hover{background:#0000001f}[data-theme=light] .board-type-dropdown{background:#fff;border-color:#d1d5db;box-shadow:0 8px 24px #00000026}[data-theme=light] .board-type-option{color:#1e293b}[data-theme=light] .board-type-option:hover{background:#46a2da1a}.icon-btn{width:30px;height:30px;border-radius:6px;border:none;background:transparent;color:#ffffffb3;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s ease;flex-shrink:0}.icon-btn:hover{background:#ffffff26;color:#fff}.icon-btn svg{width:16px;height:16px}.run-btn.go{color:#4dff7c}.run-btn.go:hover{background:#4dff7c2e;color:#4dff7c}.run-btn.stop{color:var(--accent-red)}.run-btn.stop:hover{background:#d6394c1f;color:var(--accent-red)}.toolbar-connection{gap:4px}.conn-btn.active{color:#4dff7c;background:#4dff7c2e}.connection-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.connection-dot.disconnected{background:var(--text-muted)}.connection-dot.connecting{background:var(--accent-yellow);animation:pulse 1s infinite}.connection-dot.connected{background:#4dff7c}.connection-dot.error{background:var(--accent-red)}.connection-label{font-size:11px;font-weight:600;color:#fffc}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.usb-dropdown-wrapper{position:relative}.usb-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:240px;background:var(--bg-primary);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 30px var(--shadow-lg);z-index:999;overflow:hidden}.usb-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.usb-dropdown-title{font-size:12px;font-weight:700;color:var(--text-primary)}.usb-dropdown-close{background:none;border:none;font-size:16px;color:var(--text-muted);cursor:pointer;padding:0 2px;line-height:1}.usb-dropdown-close:hover{color:var(--text-primary)}.usb-dropdown-status{padding:10px 12px}.usb-status-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:11px}.usb-status-label{color:var(--text-muted);font-weight:500}.usb-status-value{font-weight:600;color:var(--text-primary)}.usb-status-value.connected{color:var(--accent-green)}.usb-status-value.checking{color:var(--accent-yellow)}.usb-status-value.not-installed{color:var(--accent-red)}.usb-status-value.outdated{color:var(--accent-orange)}.usb-status-value.up-to-date{color:var(--accent-green)}.usb-status-value.unknown{color:var(--text-muted)}.usb-dropdown-actions{padding:0 12px 10px}.usb-action-btn{width:100%;padding:7px 10px;font-size:11px;font-weight:600;border-radius:6px;cursor:pointer;border:none;font-family:inherit}.usb-action-btn.install{background:var(--brand);color:#fff}.usb-action-btn.install:hover{background:var(--brand-hover)}.usb-action-btn.update{background:var(--accent-orange);color:#fff}.usb-action-btn.update:hover{opacity:.9}.usb-action-btn.check{background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border)}.usb-action-btn.check:hover{border-color:var(--brand);color:var(--brand)}.usb-action-btn:disabled{opacity:.6;cursor:not-allowed}.usb-firmware-ok{font-size:11px;color:var(--accent-green);font-weight:500;text-align:center;padding:4px 0}.usb-action-spinner{width:18px;height:18px;margin:4px auto;border:2px solid var(--border);border-top:2px solid var(--brand);border-radius:50%;animation:spin .8s linear infinite}.usb-disconnect-btn{width:calc(100% - 24px);margin:0 12px 10px;padding:6px;font-size:11px;font-weight:500;border-radius:6px;background:none;border:1px solid var(--border);color:var(--accent-red);cursor:pointer;font-family:inherit}.usb-disconnect-btn:hover{background:#d6394c14;border-color:var(--accent-red)}.usb-install-steps{text-align:center}.usb-install-title{font-size:12px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.usb-install-instructions{text-align:left;font-size:11px;color:var(--text-secondary);margin:0 0 8px 16px;padding:0;line-height:1.8}.usb-install-instructions strong{color:var(--text-primary)}.usb-install-hint{font-size:10px;color:var(--text-muted);margin-bottom:8px;font-style:italic}.usb-flash-progress{width:calc(100% - 24px);height:8px;margin:8px auto;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.usb-flash-progress-bar{height:100%;background:var(--brand);border-radius:4px;transition:width .3s ease}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.toolbar-panel-toggles{display:flex;align-items:center;gap:2px;padding:0 4px}.panel-toggle{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;padding:3px 7px;border:none;border-radius:5px;background:transparent;color:#fff9;cursor:pointer;transition:all .12s}.panel-toggle:hover{background:#ffffff26;color:#fff}.panel-toggle.active{background:#ffffff40;color:#fff}.panel-toggle-icon{width:15px;height:15px;display:flex}.panel-toggle-icon svg{width:15px;height:15px}.panel-toggle-label{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;line-height:1}.theme-toggle-btn svg{width:16px;height:16px}.mode-tabs{display:flex;gap:0}.mode-tab{padding:4px 14px;font-size:12px;font-weight:600;border:none;background:transparent;color:#fff9;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;font-family:inherit}.mode-tab:hover{color:#fff}.mode-tab.active{color:#fff;border-bottom-color:#fff}.mode-tab.disabled,.mode-tab:disabled{opacity:.3;cursor:not-allowed;color:var(--text-muted);border-bottom-color:transparent}.btn{display:flex;align-items:center;gap:6px;padding:5px 12px;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease;font-family:inherit}.btn-primary{background:var(--brand);color:var(--brand-text)}.btn-primary:hover{background:var(--brand-hover)}.btn-danger{background:var(--accent-red);color:#fff}.btn-danger:hover{filter:brightness(1.1)}.btn-secondary{background:var(--bg-surface);color:var(--text-primary)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-surface);color:var(--text-primary)}.btn-active{background:var(--brand);color:var(--brand-text)}.btn:disabled{opacity:.5;cursor:not-allowed}.tab-bar{display:flex;align-items:stretch;height:var(--tabbar-height);background:var(--bg-tabbar);border-bottom:1px solid var(--border);padding:0;-webkit-user-select:none;user-select:none;overflow:hidden}.tab-bar-tabs{display:flex;align-items:stretch;overflow-x:auto;flex:1;min-width:0}.tab-bar-tabs::-webkit-scrollbar{height:0}.tab-item{display:flex;align-items:center;gap:5px;padding:0 14px;height:100%;font-size:12px;font-weight:500;color:var(--text-muted);cursor:pointer;border-right:1px solid var(--border-light);white-space:nowrap;position:relative;transition:all .12s;min-width:0}.tab-item:hover{background:var(--bg-hover);color:var(--text-primary)}.tab-item.active{background:var(--brand-light);color:var(--text-primary);font-weight:600}.tab-item.function{font-style:italic}.tab-item.function.active{background:#f0e8ff;color:#5b21b6}[data-theme=dark] .tab-item.function.active{background:#2a1a42;color:#c4b5fd}.tab-item.library.active{background:#e6f7f5;color:#0f766e}[data-theme=dark] .tab-item.library.active{background:#0f2e2c;color:#5eead4}.tab-item.highlighted{outline:2px solid var(--accent-purple);outline-offset:-2px;background:#7c51d114}[data-theme=dark] .tab-item.highlighted{background:#a78bfa1a}.tab-item[draggable]{cursor:grab}.tab-item[draggable]:active{cursor:grabbing}.tab-item.dragging{opacity:.4}.tab-item.drag-over-tab{box-shadow:inset 2px 0 0 var(--brand)}.tab-type-icon{width:14px;height:14px;flex-shrink:0;opacity:.7}.tab-item.active .tab-type-icon{opacity:1}.fn-icon{color:var(--accent-purple);opacity:1}.lib-icon{color:var(--accent-teal);opacity:1}.config-icon{color:var(--text-muted);opacity:.8}.tab-item.config-tab.active .config-icon{color:#d97706;opacity:1}.tab-bar-right{display:flex;align-items:stretch;margin-left:auto;border-left:1px solid var(--border);flex-shrink:0}.tab-item.config-tab{font-size:11px;font-weight:500;padding:0 12px;gap:4px;border-right:none;color:var(--text-muted)}.tab-item.config-tab:hover{background:#d9770614;color:#d97706}.tab-item.config-tab.active{background:#d977061f;color:#d97706;font-weight:600}[data-theme=dark] .tab-item.config-tab:hover{background:#fbbf2414;color:#fbbf24}[data-theme=dark] .tab-item.config-tab.active{background:#fbbf241f;color:#fbbf24}[data-theme=dark] .config-icon{color:var(--text-muted)}[data-theme=dark] .tab-item.config-tab.active .config-icon{color:#fbbf24}.tab-name{overflow:hidden;text-overflow:ellipsis;max-width:120px}.tab-rename-input{font-size:12px;font-weight:500;font-family:inherit;background:var(--bg-surface);border:1px solid var(--brand);border-radius:3px;padding:1px 4px;color:var(--text-primary);width:100px;outline:none}.tab-close{width:16px;height:16px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:3px;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .12s;flex-shrink:0;margin-left:2px}.tab-item:hover .tab-close{opacity:.7}.tab-close:hover{background:var(--accent-red);color:#fff;opacity:1!important}.tab-close svg{width:10px;height:10px}.tab-add-inline{display:flex;align-items:center;padding:0 8px;position:relative;flex-shrink:0}.tab-add-btn{width:26px;height:26px;border:1px dashed var(--border);background:transparent;color:var(--text-muted);cursor:pointer;border-radius:5px;display:flex;align-items:center;justify-content:center;transition:all .15s}.tab-add-btn:hover{background:var(--brand-light);border-color:var(--brand);color:var(--brand)}.tab-add-btn svg{width:12px;height:12px}.tab-tooltip{position:fixed;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:10px 14px;min-width:200px;z-index:9999;box-shadow:0 8px 24px var(--shadow-lg);font-style:normal;pointer-events:none}.tab-tooltip-header{font-size:13px;font-weight:700;color:var(--accent-purple);font-family:JetBrains Mono,monospace;margin-bottom:4px}.tab-tooltip-desc{font-size:11px;color:var(--text-secondary);margin-bottom:6px;line-height:1.4}.tab-tooltip-params{font-size:12px;font-family:JetBrains Mono,monospace;color:var(--text-primary);margin-bottom:4px}.tab-tooltip-param{padding:1px 0}.param-name{color:var(--brand)}.param-type{color:var(--accent-teal)}.param-default{color:var(--text-muted)}.param-empty{color:var(--text-muted);font-style:italic;font-family:inherit}.tab-tooltip-return{font-size:11px;color:var(--text-secondary);border-top:1px solid var(--border);padding-top:4px;margin-top:2px}.new-tab-menu{background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;padding:4px;min-width:210px;box-shadow:0 8px 24px var(--shadow-lg)}.new-tab-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;border-radius:6px;background:transparent;color:var(--text-primary);cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;transition:background .12s;text-align:left}.new-tab-option:hover{background:var(--brand-light)}.new-tab-option svg{width:16px;height:16px;flex-shrink:0}.new-tab-option-label{flex-shrink:0}.new-tab-option-desc{font-size:11px;color:var(--text-muted);font-weight:400;margin-left:auto}.new-tab-divider{height:1px;background:var(--border);margin:4px 8px}.library-option:hover{background:#0f907e1a}[data-theme=dark] .library-option:hover{background:#5eead414}.library-picker-dialog{background:var(--bg-primary);border:1px solid var(--border);border-radius:14px;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px var(--shadow-lg);overflow:hidden}.library-picker-header{padding:20px 24px 12px;border-bottom:1px solid var(--border)}.library-picker-header h2{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.library-picker-header p{font-size:13px;color:var(--text-secondary);margin:0 0 12px;line-height:1.4}.library-search{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;background:var(--bg-secondary);color:var(--text-primary);outline:none;transition:border-color .15s;box-sizing:border-box}.library-search::placeholder{color:var(--text-muted)}.library-search:focus{border-color:var(--brand)}.library-cat-tabs{display:flex;gap:4px;margin-top:12px;flex-wrap:wrap}.library-cat-tab{padding:4px 10px;border:none;border-radius:6px;font-size:12px;font-weight:500;font-family:inherit;background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;transition:all .12s;white-space:nowrap}.library-cat-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.library-cat-tab.active{background:var(--brand);color:var(--brand-text)}.library-picker-grid{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:6px}.library-card{display:flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid var(--border-light);border-radius:10px;background:var(--bg-secondary);cursor:pointer;transition:all .12s;text-align:left;font-family:inherit;color:var(--text-primary)}.library-card:hover{border-color:var(--brand);background:var(--brand-light);box-shadow:0 2px 8px var(--shadow)}.library-card-icon{font-size:22px;flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-surface);border-radius:8px}.library-card:hover .library-card-icon{background:var(--bg-primary)}.library-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.library-card-name{font-size:13px;font-weight:600;color:var(--text-primary)}.library-card-desc{font-size:11px;color:var(--text-muted);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-card-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px;background:var(--accent-teal);color:#fff;white-space:nowrap;flex-shrink:0;letter-spacing:.3px}.library-section-heading{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);padding:12px 4px 4px;border-top:1px solid var(--border-light);margin-top:4px}.library-section-heading:first-child{border-top:none;margin-top:0;padding-top:0}.cloud-data-heading{color:#34a853}.library-card-cloud{border-color:#34a85340}.library-card-cloud:hover{border-color:#34a853;background:#34a85314}.library-picker-empty{padding:32px 16px;text-align:center;color:var(--text-muted);font-size:13px}.library-picker-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.library-picker-hint{font-size:11px;color:var(--text-muted);font-style:italic}.ide-container{display:flex;flex-direction:column;height:calc(100% - var(--toolbar-height) - var(--tabbar-height))}.editor-area{display:flex;flex:1;min-height:0}.empty-editor-area{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px}.panel{position:relative;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:5px 12px;background:var(--bg-secondary);border-bottom:1px solid var(--border);font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.blockly-panel{flex:1;min-width:250px}.blockly-container{width:100%;height:100%}.code-panel{flex:1;min-width:200px;display:flex;flex-direction:column}.code-editor-wrapper{flex:1;overflow:auto}.cm-editor{height:100%}.cm-editor .cm-scroller{font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:13px;line-height:1.6}[data-theme=light] .cm-editor{background:#fff}[data-theme=light] .cm-editor .cm-gutters{background:var(--bg-secondary)!important;border-right:1px solid var(--border)!important;color:var(--text-muted)!important}[data-theme=light] .cm-editor .cm-activeLineGutter,[data-theme=light] .cm-editor .cm-activeLine{background:var(--brand-light)!important}[data-theme=light] .cm-editor .cm-content{color:var(--text-primary)}.resize-handle{width:5px;cursor:col-resize;background:var(--border);transition:background .15s;flex-shrink:0;position:relative;z-index:5}.resize-handle:after{content:"";position:absolute;inset:0 -3px}.resize-handle:hover,.resize-handle.dragging{background:var(--brand)}.resize-handle-h{height:5px;width:100%;cursor:row-resize;background:var(--border);transition:background .15s;flex-shrink:0;position:relative;z-index:5}.resize-handle-h:after{content:"";position:absolute;inset:-3px 0}.resize-handle-h:hover,.resize-handle-h.dragging{background:var(--brand)}.console-panel{height:var(--console-height);border-top:1px solid var(--border);display:flex;flex-direction:column;background:var(--bg-secondary)}.console-messages{flex:1;overflow-y:auto;padding:6px 12px;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:12px;line-height:1.6}.console-msg{display:flex;gap:8px;padding:1px 0}.console-msg-time{color:var(--text-muted);white-space:nowrap;-webkit-user-select:none;user-select:none}.console-msg.info .console-msg-text{color:var(--text-primary)}.console-msg.error .console-msg-text{color:var(--accent-red)}.console-msg.output .console-msg-text{color:var(--accent-green)}.console-msg.system .console-msg-text{color:var(--brand)}.board-panel{width:260px;background:var(--brand);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0}.board-panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;font-size:11px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px}.board-card{position:relative;padding:10px 12px;margin:0 8px 6px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border);cursor:pointer;transition:border-color .15s}.board-card:hover{border-color:var(--brand)}.bc-header{padding-left:10px;margin-bottom:4px}.bc-title-row{display:flex;align-items:center;gap:6px}.bc-name{line-height:1.4;flex:1;min-width:0}.bc-remove-btn{position:absolute;top:4px;right:4px;padding:0 4px!important;font-size:12px;line-height:1;color:var(--text-muted)!important;opacity:.4;z-index:1}.bc-remove-btn:hover{opacity:1;color:var(--accent-red)!important}.board-led-display{display:flex;gap:3px;flex-shrink:0}.board-led{width:10px;height:10px;border-radius:50%;border:1.5px solid var(--border)}.board-led.on{border-color:transparent;background:currentColor}.board-led.off{background:var(--bg-surface)}.board-led.single-led{width:12px;height:12px}.bc-info{font-size:11px;color:var(--text-muted);margin-top:2px;padding-left:13px}.board-panel-empty{padding:24px 16px;display:flex;flex-direction:column;align-items:center;text-align:center}.board-panel-actions{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px}.board-action-btn{width:100%;max-width:200px;font-size:11px;padding:6px 12px;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;cursor:pointer;transition:background .15s;text-align:center}.board-action-btn:hover{background:#ffffff4d}.board-action-btn:disabled{opacity:.4;cursor:not-allowed}.board-action-sim{background:#ffffff1a;color:#fffc;border-color:#fff3}.board-action-group{background:#ffffff14;color:#ffffffe6;border-color:#ffffff40;margin-top:4px}.bc-device-list{margin-top:6px;padding-left:13px}.bc-device-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-secondary);padding:2px 0}.bc-device-item-icon{font-size:11px;flex-shrink:0;width:16px;text-align:center}.bc-device-item-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bc-device-item-port{font-size:10px;font-weight:600;color:var(--text-muted);background:var(--bg-surface);padding:1px 5px;border-radius:3px;flex-shrink:0}.bc-device-item-badge{font-size:9px;font-weight:700;color:var(--accent-orange);background:#d968301a;padding:1px 4px;border-radius:3px;flex-shrink:0}.bc-device-list-empty{font-size:11px;color:var(--text-muted);font-style:italic;padding:4px 0 0 13px;opacity:.7}@keyframes led-blink{0%,49%{opacity:1}50%,to{opacity:.15}}.board-led.led-blink{animation:led-blink 1s step-end infinite}.board-card-ghosted{opacity:.4;border-style:dashed!important}.board-card-ghosted:hover{opacity:.6}.bc-wifi-badge{display:inline-flex;align-items:center;margin-left:6px;color:#4285f4;vertical-align:middle;animation:wifi-pulse 2s ease-in-out infinite}@keyframes wifi-pulse{0%,to{opacity:1}50%{opacity:.6}}.bc-hidden-badge{display:inline-block;font-size:9px;font-weight:700;color:var(--accent-orange);background:#d9683026;padding:1px 5px;border-radius:3px;margin-left:6px;text-transform:uppercase;letter-spacing:.3px}.bc-visibility-btn{background:none;border:none;padding:2px;cursor:pointer;color:var(--text-secondary);flex-shrink:0;display:flex;align-items:center;opacity:.7;transition:opacity .15s,color .15s;border-radius:4px}.bc-visibility-btn:hover{opacity:1;color:var(--brand);background:rgba(var(--brand-rgb, 59, 130, 246),.1)}.bc-visibility-btn.hidden-board{opacity:.4;color:var(--text-muted)}.bc-visibility-btn.hidden-board:hover{opacity:.8;color:var(--accent-orange)}.bc-type-selector{position:relative;flex-shrink:0;margin-left:auto}.bc-type-btn{display:flex;align-items:center;gap:2px;background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;padding:2px 6px;cursor:pointer;font-size:14px;color:var(--text-secondary);transition:border-color .15s}.bc-type-btn:hover{border-color:var(--brand)}.bc-type-caret{font-size:9px;color:var(--text-muted)}.bc-type-dropdown{position:absolute;top:100%;right:0;z-index:100;margin-top:4px;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px var(--shadow-lg);min-width:160px;padding:4px;overflow:hidden}.bc-type-option{display:flex;align-items:center;gap:8px;width:100%;background:none;border:none;padding:8px 12px;cursor:pointer;font-size:13px;color:var(--text-primary);border-radius:6px;transition:background .1s}.bc-type-option:hover{background:var(--bg-surface)}.bc-type-option.active{background:rgba(var(--brand-rgb, 59, 130, 246),.15);color:var(--brand);font-weight:600}.bcd-gpio-name-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding:0 4px}.bcd-gpio-pins{flex-wrap:wrap!important;max-height:120px;overflow-y:auto}.bcd-gpio-pins .bcd-port-btn{min-width:38px;font-size:11px}.bcd-gpio-pins .bcd-port-btn.used{opacity:.3;text-decoration:line-through;cursor:not-allowed}.bcd-gpio-direction-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:8px}.bcd-gpio-direction-grid .bcd-direction-btn{padding:8px;font-size:12px}.overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.dialog{background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;padding:24px;max-width:480px;width:90%;box-shadow:0 20px 60px var(--shadow-lg)}.dialog h2{font-size:18px;margin-bottom:16px;color:var(--text-primary)}.dialog p{font-size:14px;color:var(--text-secondary);margin-bottom:16px;line-height:1.5}.color-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:20px}.color-swatch{width:100%;aspect-ratio:1;border-radius:8px;border:3px solid transparent;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5)}.color-swatch:hover{transform:scale(1.05)}.color-swatch.selected{border-color:#fff;transform:scale(1.1)}.confirm-detail-list{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:12px;margin-bottom:16px;font-size:13px;color:var(--text-secondary)}.confirm-section{margin-bottom:6px;line-height:1.5}.confirm-section:last-child{margin-bottom:0}.confirm-label{font-weight:600;color:var(--text-primary);margin-right:6px}.confirm-actions{display:flex;gap:8px;justify-content:flex-end}.btn-danger{background:var(--accent-red);color:#fff;border:none;padding:6px 16px;border-radius:6px;font-weight:600;cursor:pointer;font-size:13px}.btn-danger:hover{opacity:.9}.simulator-panel{flex:1;min-width:280px;background:var(--bg-primary);display:flex;flex-direction:column}.simulator-canvas-wrapper{flex:1;display:flex;align-items:center;justify-content:center;padding:8px}.simulator-canvas-wrapper canvas{border-radius:8px;background:#f8f9fa}[data-theme=dark] .simulator-canvas-wrapper canvas{background:#101820}[data-theme=light] .simulator-canvas-wrapper canvas{border:1px solid var(--border)}.dashboard-panel{display:flex;flex-direction:column;background:var(--bg-primary);border-top:1px solid var(--border);overflow:hidden;height:100%}.dashboard-content{display:flex;flex:1;min-height:0;overflow:hidden}.widget-palette{width:180px;border-right:1px solid var(--border);background:var(--bg-secondary);overflow-y:auto;overflow-x:hidden;flex-shrink:0;padding:8px 0;max-height:100%}.widget-palette-title{font-size:11px;font-weight:700;color:var(--text-primary);padding:4px 12px 8px;text-transform:uppercase;letter-spacing:.5px}.widget-palette-section{margin-bottom:8px}.widget-palette-section-label{font-size:9px;font-weight:600;color:var(--text-muted);padding:4px 12px 2px;text-transform:uppercase;letter-spacing:.5px}.widget-palette-item{display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:grab;transition:background .1s;border-left:3px solid transparent}.widget-palette-item:hover{background:var(--bg-hover);border-left-color:var(--brand)}.widget-palette-item:active{cursor:grabbing;opacity:.7}.widget-palette-icon{font-size:18px;flex-shrink:0}.widget-palette-item-info{display:flex;flex-direction:column;min-width:0}.widget-palette-item-name{font-size:11px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-palette-item-desc{font-size:9px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-viewport{flex:1;overflow:hidden;position:relative;min-width:0;cursor:grab;background:var(--bg-secondary)}.dashboard-viewport:active{cursor:grabbing}.dashboard-grid{display:grid;padding:8px;position:relative;min-width:0;width:fit-content}.bg-picker-wrap{position:relative}.bg-picker-trigger{display:flex;align-items:center;gap:4px;background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;padding:2px 8px 2px 4px;cursor:pointer;font-size:10px;font-weight:600;color:var(--text-secondary);font-family:inherit;transition:border-color .15s}.bg-picker-trigger:hover{border-color:var(--brand)}.bg-picker-swatch{display:inline-block;width:14px;height:14px;border-radius:3px;border:1px solid rgba(255,255,255,.15);flex-shrink:0}.bg-picker-label{letter-spacing:.5px}.bg-picker-popover{position:absolute;top:100%;right:0;margin-top:4px;z-index:200;width:280px;background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 30px #00000040;padding:10px}.bg-picker-title{font-size:11px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.bg-picker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:8px}.bg-picker-option{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:2px solid transparent;border-radius:8px;padding:4px;cursor:pointer;transition:border-color .15s,background .15s}.bg-picker-option:hover{background:var(--bg-hover)}.bg-picker-option.active{border-color:var(--brand);background:var(--bg-hover)}.bg-picker-option-swatch{width:40px;height:28px;border-radius:5px;border:1px solid rgba(255,255,255,.25);box-shadow:inset 0 0 0 1px #0003,0 1px 3px #0000004d}[data-theme=light] .bg-picker-option-swatch{border:1px solid rgba(0,0,0,.2);box-shadow:inset 0 0 0 1px #0000000d,0 1px 3px #0000001f}.bg-picker-option-label{font-size:8px;font-weight:600;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:56px;text-align:center}.bg-picker-custom{display:flex;align-items:center;gap:8px;padding-top:6px;border-top:1px solid var(--border)}.bg-picker-color-input{width:36px;height:28px;border:none;border-radius:5px;cursor:pointer;padding:0;background:none}.bg-picker-color-input::-webkit-color-swatch-wrapper{padding:0}.bg-picker-color-input::-webkit-color-swatch{border:1px solid var(--border);border-radius:5px}.dashboard-grid-cell{border-radius:4px;border:1px dashed var(--border);opacity:.3;pointer-events:none}.dashboard-grid-cell.drag-hover{background:var(--brand);opacity:.15;border-color:var(--brand);border-style:solid}.dash-zoom-controls{display:flex;align-items:center;gap:1px;background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;overflow:hidden}.dash-zoom-btn{background:none;border:none;color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;padding:2px 7px;transition:all .1s;font-family:inherit}.dash-zoom-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.dash-zoom-level{background:none;border:none;color:var(--text-muted);font-size:10px;font-weight:600;cursor:pointer;padding:2px 4px;font-family:JetBrains Mono,monospace;min-width:38px;text-align:center}.dash-zoom-level:hover{color:var(--brand)}.dash-label-nav{display:flex;gap:6px;padding:4px 10px;border-bottom:1px solid var(--border);background:var(--bg-secondary);overflow-x:auto;flex-shrink:0}.dash-label-nav::-webkit-scrollbar{height:3px}.dash-label-nav::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.dash-label-nav-btn{border:1px solid var(--border);cursor:pointer;font-size:11px;font-weight:600;padding:3px 12px;white-space:nowrap;transition:all .15s;font-family:inherit}.dash-label-nav-btn:hover{border-color:var(--brand);box-shadow:0 1px 6px #46a2da33;transform:translateY(-1px)}.widget-card{position:relative;background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;z-index:1;transition:box-shadow .15s,border-color .15s}.widget-card.label-live{background:transparent;border:none;box-shadow:none;overflow:visible}.widget-card.edit-mode{border-style:dashed}.widget-card.edit-mode:hover{border-color:var(--brand);box-shadow:0 2px 12px #46a2da26}.widget-card.resizing{opacity:.8}.widget-card.dragging{opacity:.7;z-index:100;box-shadow:0 4px 20px #46a2da4d;border-color:var(--brand)}.widget-card.clickable{cursor:pointer}.widget-card.clickable:hover{border-color:var(--brand);box-shadow:0 1px 8px #46a2da1f}.widget-card-header{display:flex;align-items:center;gap:4px;padding:2px 4px 0;flex-shrink:0;background:var(--bg-secondary);border-bottom:1px solid var(--border);height:22px}.widget-card-drag-handle{font-size:10px;color:var(--text-muted);cursor:grab;letter-spacing:-2px;-webkit-user-select:none;user-select:none;padding:0 4px;border-radius:3px}.widget-card-drag-handle:hover{background:var(--bg-hover);color:var(--text-secondary)}.widget-card-label{font-size:9px;font-weight:600;color:var(--text-secondary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-card-gear{background:none;border:none;font-size:12px;color:var(--text-muted);cursor:pointer;padding:0 2px;border-radius:4px;transition:all .1s}.widget-card-gear:hover{color:var(--brand);background:var(--bg-hover)}.widget-card-mini-gear{position:absolute;top:3px;right:3px;background:var(--bg-surface);border:1px solid var(--border);font-size:11px;color:var(--text-muted);cursor:pointer;padding:1px 4px;border-radius:5px;opacity:0;transition:opacity .15s,color .15s;z-index:2}.widget-card:hover .widget-card-mini-gear{opacity:.8}.widget-card-mini-gear:hover{color:var(--brand);opacity:1!important}.widget-card-binding{font-size:7px;color:var(--text-muted);opacity:.7}.widget-card-content{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:4px}.widget-card-live-label{position:absolute;bottom:2px;left:0;right:0;text-align:center;font-size:8px;font-weight:600;color:var(--text-muted);pointer-events:none;text-transform:uppercase;letter-spacing:.5px}.widget-resize-handle{position:absolute;bottom:0;right:0;width:16px;height:16px;cursor:nwse-resize;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .1s}.widget-card.edit-mode:hover .widget-resize-handle{opacity:1}.wsp-dialog{width:380px;max-height:80vh;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;box-shadow:0 20px 60px var(--shadow-lg);overflow:hidden}.wsp-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--brand);color:#fff}.wsp-dialog-title{font-size:15px;font-weight:700}.wsp-dialog-body{padding:16px;overflow-y:auto;max-height:60vh;display:flex;flex-direction:column;gap:2px}.wsp-field{display:flex;flex-direction:column;gap:3px;margin-bottom:8px}.wsp-field-label{font-size:9px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.wsp-input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:5px;padding:6px 10px;font-size:12px;color:var(--text-primary);font-family:inherit;outline:none;transition:border-color .15s}.wsp-input:focus{border-color:var(--brand)}.wsp-select{background:var(--bg-secondary);border:1px solid var(--border);border-radius:5px;padding:6px 8px;font-size:12px;color:var(--text-primary);font-family:inherit;outline:none;cursor:pointer}.wsp-select:focus{border-color:var(--brand)}.wsp-btn{background:var(--brand);color:#fff;border:none;border-radius:5px;padding:4px 10px;font-size:11px;cursor:pointer;font-family:inherit;font-weight:600;white-space:nowrap}.wsp-btn:hover{opacity:.9}.wsp-delete{background:none;border:1px solid var(--accent-red);color:var(--accent-red);border-radius:6px;padding:6px 12px;font-size:11px;cursor:pointer;font-family:inherit;font-weight:600;transition:all .15s}.wsp-delete:hover{background:var(--accent-red);color:#fff}.wsp-section-divider{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-top:1px solid var(--border);padding-top:8px;margin-top:4px}.widget-value-display{display:flex;flex-direction:column;align-items:center;justify-content:center}.widget-value-number{font-family:JetBrains Mono,monospace;font-weight:700;color:var(--text-primary);line-height:1.1}.widget-value-unit{font-size:10px;color:var(--text-muted);margin-top:2px}.widget-graph-canvas{border-radius:6px;display:block}.widget-toggle{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer}.widget-toggle-label{font-size:9px;font-weight:600;color:var(--text-muted);text-transform:uppercase}.widget-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;-webkit-user-select:none;user-select:none}.widget-button-face{border:3px solid var(--brand);cursor:pointer;transition:all .1s;box-shadow:0 3px 8px #00000026}.widget-button-face:hover{opacity:.9}.widget-button-face.pressed{transform:scale(.93);box-shadow:0 1px 3px #0003}.widget-button-label{font-size:9px;font-weight:600;color:var(--text-muted);text-transform:uppercase}.widget-joystick-svg{cursor:crosshair;-webkit-user-select:none;user-select:none}.widget-slider-svg{cursor:pointer;-webkit-user-select:none;user-select:none}.widget-label-display{display:flex;align-items:center;font-weight:700;padding:4px 8px;line-height:1.2;word-break:break-word;overflow:hidden;font-family:Inter,sans-serif}.widget-direction-svg{-webkit-user-select:none;user-select:none}.dashboard-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;pointer-events:auto}.dashboard-empty-text{font-size:13px;color:var(--text-muted);text-align:center}::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.blocklyToolboxDiv{background:var(--bg-secondary)!important}.blocklyFlyout{background:var(--bg-surface)!important}.blocklyMainBackground{fill:var(--bg-primary)!important}[data-theme=light] .blocklyToolboxDiv{background:var(--bg-secondary)!important}[data-theme=light] .blocklyFlyout{background:var(--bg-surface)!important}[data-theme=light] .blocklyMainBackground{fill:#fff!important}[data-theme=light] .blocklyTreeRow:not(.blocklyTreeSelected):hover{background-color:var(--brand-light)!important}.fe-dialog{background:var(--bg-primary);border-radius:14px;width:520px;max-width:92vw;max-height:85vh;overflow-y:auto;box-shadow:0 16px 48px var(--shadow-lg),0 0 0 1px var(--border);display:flex;flex-direction:column}.fe-header{padding:20px 24px 12px;border-bottom:1px solid var(--border-light)}.fe-header h2{font-size:17px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.fe-header p{font-size:12px;color:var(--text-muted);margin:0}.fe-section{padding:12px 24px;border-bottom:1px solid var(--border-light)}.fe-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.fe-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.03em}.fe-section-header .fe-label{margin-bottom:0}.fe-hint{font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-muted);font-size:11px}.fe-input{width:100%;padding:7px 10px;border-radius:7px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:13px;font-family:Inter,sans-serif;outline:none;transition:border-color .15s;box-sizing:border-box}.fe-input:focus{border-color:var(--brand)}.fe-name-input{font-family:JetBrains Mono,Fira Code,monospace;font-weight:600;font-size:15px}.fe-select{padding:7px 10px;border-radius:7px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:13px;cursor:pointer;outline:none}.fe-select:focus{border-color:var(--brand)}.fe-empty{font-size:12px;color:var(--text-muted);padding:8px 0;font-style:italic}.fe-add-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;border:1px dashed var(--border);border-radius:6px;background:transparent;color:var(--brand);font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.fe-add-btn:hover{background:var(--brand-light);border-color:var(--brand-muted)}.fe-icon{width:14px;height:14px;display:block;flex-shrink:0}.fe-param-row{display:flex;align-items:center;gap:6px;border-left:3px solid var(--brand);padding:5px 0 5px 10px;margin-bottom:4px;border-radius:0 6px 6px 0;background:var(--bg-secondary)}.fe-param-row.global{border-left-color:var(--accent-orange)}.fe-param-name{width:130px;padding:5px 8px;border:1px solid var(--border-light);border-radius:5px;background:var(--bg-primary);color:var(--text-primary);font-family:JetBrains Mono,Fira Code,monospace;font-size:12px;outline:none}.fe-param-name:focus{border-color:var(--brand)}.fe-param-name-select{width:130px;cursor:pointer;font-family:JetBrains Mono,Fira Code,monospace;font-size:11px}.fe-param-type{width:100px;padding:5px 6px;border:1px solid var(--border-light);border-radius:5px;background:var(--bg-primary);color:var(--text-primary);font-size:12px;cursor:pointer;outline:none}.fe-param-default{flex:1;min-width:60px;padding:5px 8px;border:1px solid var(--border-light);border-radius:5px;background:var(--bg-primary);color:var(--text-secondary);font-size:12px;outline:none}.fe-param-default:focus{border-color:var(--brand)}.fe-param-actions{display:flex;gap:2px;flex-shrink:0}.fe-icon-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:4px;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s}.fe-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.fe-icon-btn:disabled{opacity:.3;cursor:not-allowed}.fe-icon-btn-danger:hover{background:#d6394c1f;color:var(--accent-red)}.fe-preview{padding:12px 24px;border-bottom:1px solid var(--border-light)}.fe-preview-code{display:block;padding:10px 14px;border-radius:8px;background:var(--bg-surface);color:var(--accent-purple);font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;font-weight:500;white-space:pre-wrap;word-break:break-all}.fe-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 24px}.btn{padding:7px 16px;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:background .15s,box-shadow .15s}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border)}.btn-secondary:hover{background:var(--bg-hover)}.btn-primary{background:var(--brand);color:#fff}.board-config-dialog{width:440px;max-height:80vh;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;box-shadow:0 20px 60px var(--shadow-lg);overflow:hidden}.bcd-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--brand);color:#fff}.bcd-header-title{font-size:15px;font-weight:700}.bcd-close-btn{width:28px;height:28px;border:none;border-radius:6px;background:#ffffff26;color:#fff;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .15s;padding:0}.bcd-close-btn:hover{background:#ffffff40}.bcd-body{padding:16px;overflow-y:auto;max-height:60vh;display:flex;flex-direction:column;gap:6px}.bcd-empty{padding:24px;text-align:center;color:var(--text-muted);font-size:12px;font-style:italic}.bcd-device-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border-light);border-radius:8px;background:var(--bg-secondary);cursor:pointer;transition:all .15s;font-family:inherit;text-align:left;width:100%;color:var(--text-primary)}.bcd-device-row:hover{border-color:var(--brand);background:var(--brand-light)}.bcd-device-icon{font-size:20px;flex-shrink:0}.bcd-device-name{flex:1;font-size:13px;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bcd-device-port{font-size:11px;font-weight:700;padding:2px 8px;background:var(--brand);color:#fff;border-radius:4px}.bcd-device-badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.bcd-device-badge.rev{background:#fde68a;color:#92400e}.bcd-device-badge.lib{background:var(--brand-light);color:var(--brand)}.bcd-device-chevron{font-size:18px;color:var(--text-muted);font-weight:300}.bcd-inline-remove{background:none;border:none;color:var(--accent-red);cursor:pointer;font-size:16px;padding:0 4px;opacity:0;transition:opacity .15s}.bcd-device-row:hover .bcd-inline-remove{opacity:1}.bcd-add-device-btn{display:flex;align-items:center;gap:10px;padding:12px 14px;border:2px dashed var(--border);border-radius:8px;background:transparent;color:var(--brand);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;width:100%;text-align:left;font-family:inherit}.bcd-add-device-btn:hover{border-color:var(--brand);background:var(--brand-light)}.bcd-add-lib-btn{border-style:dotted}.bcd-add-icon{font-size:20px}.bcd-remove-board-btn{display:block;width:100%;margin-top:16px;padding:8px;background:none;border:1px solid var(--accent-red);border-radius:6px;color:var(--accent-red);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;opacity:.7}.bcd-remove-board-btn:hover{opacity:1;background:#d6394c14}.bcd-remove-confirm{margin-top:16px;padding:12px;background:#d6394c0d;border:1px solid var(--accent-red);border-radius:8px}.bcd-remove-confirm-title{font-size:13px;font-weight:700;color:var(--accent-red);margin-bottom:4px}.bcd-remove-confirm-text{font-size:12px;color:var(--text-secondary);margin-bottom:8px}.bcd-remove-confirm-item{font-size:11px;color:var(--text-secondary);padding:2px 0}.bcd-remove-confirm-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:10px}.bcd-device-picker{display:flex;flex-direction:column;gap:12px}.bcd-picker-title{font-size:15px;font-weight:600;color:var(--brand);text-align:center;padding:4px 0}.bcd-picker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.bcd-picker-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:14px 6px;border:2px solid var(--brand);border-radius:10px;background:var(--bg-secondary);cursor:pointer;transition:all .15s;font-family:inherit;color:var(--brand)}.bcd-picker-tile:hover{background:var(--brand);color:#fff;transform:scale(1.04)}.bcd-tile-icon{font-size:28px}.bcd-tile-label{font-size:10px;font-weight:700;text-transform:uppercase;text-align:center;line-height:1.2}.bcd-port-grid{display:flex;flex-direction:column;gap:12px;align-items:center}.bcd-port-label{font-size:15px;font-weight:600;color:var(--brand);text-align:center}.bcd-port-buttons{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.bcd-port-btn{width:52px;height:52px;border:2px solid var(--brand);border-radius:10px;background:var(--brand);color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:all .15s;font-family:inherit}.bcd-port-btn:hover{transform:scale(1.06);box-shadow:0 4px 12px #46a2da4d}.bcd-port-btn.selected{background:var(--brand);box-shadow:0 0 0 3px #46a2da66;transform:scale(1.08)}.bcd-detail-actions{display:flex;align-items:center;gap:8px;padding-top:12px;border-top:1px solid var(--border-light);margin-top:4px}.bcd-detail-actions .btn:first-child{margin-right:auto}.bcd-done-btn{padding:6px 20px!important;border-radius:20px!important;font-weight:700!important}.bcd-motor-detail,.bcd-sensor-detail{display:flex;flex-direction:column;gap:12px}.bcd-detail-header{display:flex;align-items:center;gap:10px;padding-bottom:8px;border-bottom:1px solid var(--border-light)}.bcd-device-icon-lg{font-size:28px}.bcd-port-badge{font-size:12px;font-weight:700;padding:3px 10px;background:var(--brand);color:#fff;border-radius:6px;margin-left:auto}.bcd-direction-section{text-align:center}.bcd-direction-label{font-size:13px;font-weight:600;color:var(--brand);margin-bottom:10px}.bcd-direction-options{display:flex;gap:12px;justify-content:center;margin-bottom:12px}.bcd-direction-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 20px;border:2px solid var(--border);border-radius:10px;background:var(--bg-secondary);cursor:pointer;transition:all .15s;font-family:inherit;color:var(--text-secondary);min-width:120px}.bcd-direction-btn.active{border-color:var(--brand);background:var(--brand-light);color:var(--brand)}.bcd-direction-btn:hover{border-color:var(--brand)}.bcd-dir-arrow{font-size:24px}.bcd-dir-icon{font-size:20px;font-weight:700}.bcd-dir-text{font-size:11px;font-weight:600;text-transform:lowercase}.bcd-toggle-row{display:flex;align-items:center;justify-content:center;gap:10px;font-size:12px}.bcd-toggle{width:44px;height:24px;border-radius:12px;background:var(--bg-surface);border:2px solid var(--border);position:relative;cursor:pointer;transition:all .2s;padding:0}.bcd-toggle.on{background:var(--brand);border-color:var(--brand)}.bcd-toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:left .2s}.bcd-toggle.on .bcd-toggle-thumb{left:22px}.bcd-lib-picker-view{display:flex;flex-direction:column;gap:10px}.bcd-lib-picker-list{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.bcd-lib-tile{min-height:80px}.bcd-lib-section-heading{grid-column:1 / -1;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#34a853;padding:8px 4px 2px;border-top:1px solid var(--border-light);margin-top:4px}.bcd-lib-cloud{border-color:#34a85340}.bm-dialog{background:var(--bg-primary);border-radius:14px;width:680px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 16px 48px var(--shadow-lg),0 0 0 1px var(--border);display:flex;flex-direction:column}.bm-title{text-align:center;font-size:18px;font-weight:700;color:var(--text-primary);padding:18px 24px 10px;margin:0}.bm-workspace{margin:0 20px;padding:30px 20px;background:var(--bg-primary);border:2px dashed var(--border);border-radius:10px;min-height:120px;display:flex;align-items:center;justify-content:center}.bm-block-preview{display:flex;justify-content:center}.bm-block-shape{display:flex;flex-direction:column;align-items:flex-start;cursor:pointer}.bm-notch-top,.bm-notch-bottom{width:30px;height:6px;background:#7c51d1;border-radius:0 0 4px 4px;margin-left:16px}.bm-notch-bottom{border-radius:4px 4px 0 0;margin-top:-1px}.bm-notch-top{margin-bottom:-1px}.bm-block-body{display:flex;align-items:center;gap:0;background:#7c51d1;border-radius:8px;padding:6px 10px;min-height:36px;flex-wrap:wrap;row-gap:4px}.bm-block-name{font-size:13px;font-weight:700;color:#fff;padding:3px 8px;cursor:text;-webkit-user-select:none;user-select:none;white-space:nowrap}.bm-inline-edit{background:#ffffff4d;border:1px solid rgba(255,255,255,.5);border-radius:4px;color:#fff;font-size:12px;font-weight:600;padding:2px 6px;outline:none;min-width:60px;font-family:inherit}.bm-part-input .bm-inline-edit,.bm-part-boolean .bm-inline-edit{color:#333;background:#0000000f;border-color:#00000026}.bm-name-edit{font-size:13px;font-weight:700}.bm-part{display:flex;align-items:center;gap:2px;margin-left:2px;cursor:grab;position:relative;transition:transform .15s}.bm-part.drag-over{transform:translate(4px)}.bm-part:active{cursor:grabbing}.bm-part-input{background:#fff;border-radius:12px;padding:3px 10px;border:2px solid #6a42b5}.bm-part-input .bm-part-label{color:#333;font-size:12px;font-weight:500;cursor:text}.bm-part-boolean{background:#fff;padding:3px 14px;clip-path:polygon(12% 0%,88% 0%,100% 50%,88% 100%,12% 100%,0% 50%);min-width:80px;text-align:center}.bm-part-boolean .bm-part-label{color:#333;font-size:12px;font-weight:500;cursor:text}.bm-part.bm-part-label>.bm-part-label{color:#fff;font-size:12px;font-weight:600;cursor:text;padding:3px 4px}.bm-part-remove{position:absolute;top:-8px;right:-6px;width:16px;height:16px;border-radius:50%;border:none;background:var(--accent-red);color:#fff;font-size:11px;line-height:1;cursor:pointer;display:none;align-items:center;justify-content:center;padding:0}.bm-part:hover .bm-part-remove{display:flex}.bm-palette{display:flex;justify-content:center;gap:20px;padding:20px;border-top:1px solid var(--border-light);margin-top:16px}.bm-palette-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 24px;border:2px solid var(--border);border-radius:10px;background:var(--bg-primary);cursor:pointer;transition:border-color .15s,box-shadow .15s;min-width:100px}.bm-palette-item:hover{border-color:var(--brand-muted);box-shadow:0 2px 8px var(--shadow)}.bm-palette-svg{width:36px;height:36px}.bm-palette-text-icon{width:36px;height:36px;background:#7c51d1;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:700}.bm-palette-label{font-size:13px;font-weight:600;color:var(--text-primary)}.bm-palette-sublabel{font-size:11px;color:var(--text-muted);margin-top:-4px}.bm-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 24px;border-top:1px solid var(--border-light)}
