.blockly-div[data-v-fe032373]{width:100%;height:100%}.serial-terminal[data-v-16132d2d]{color:#d4d4d4;background:#1e1e1e;flex-direction:column;height:100%;font-family:Consolas,Monaco,Courier New,monospace;font-size:12px;display:flex}.terminal-header[data-v-16132d2d]{background-color:#2d2d30;border-bottom:1px solid #333;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 15px;display:flex}.terminal-header h3[data-v-16132d2d]{color:#d4d4d4;margin:0;font-size:14px}.terminal-controls[data-v-16132d2d]{align-items:center;gap:8px;display:flex}.status-dot[data-v-16132d2d]{border-radius:50%;width:8px;height:8px}.status-dot.connected[data-v-16132d2d]{background:#4caf50;box-shadow:0 0 4px #4caf50}.status-dot.disconnected[data-v-16132d2d]{background:#666}.status-text[data-v-16132d2d]{color:#999;font-size:11px}.clear-btn[data-v-16132d2d]{cursor:pointer;color:#d4d4d4;background-color:#333;border:none;border-radius:3px;align-items:center;gap:4px;padding:4px 8px;font-size:12px;transition:all .2s;display:flex}.clear-btn[data-v-16132d2d]:hover{background-color:#444}.clear-btn:hover svg[data-v-16132d2d]{stroke:#e74c3c}.terminal-body[data-v-16132d2d]{-webkit-user-select:text;user-select:text;background-color:#1e1e1e;flex:1;padding:10px;line-height:1.4;overflow-y:auto}.terminal-line[data-v-16132d2d]{white-space:pre-wrap;word-break:break-all;background-color:#1a1a1a;border-left:3px solid #333;border-radius:3px;margin-bottom:4px;padding:4px 8px}.terminal-placeholder[data-v-16132d2d]{color:#666;text-align:center;padding:20px;font-style:italic}.terminal-body[data-v-16132d2d]::-webkit-scrollbar{width:6px}.terminal-body[data-v-16132d2d]::-webkit-scrollbar-track{background:#2d2d30}.terminal-body[data-v-16132d2d]::-webkit-scrollbar-thumb{background:#5a5a5c;border-radius:3px}.terminal-body[data-v-16132d2d]::-webkit-scrollbar-thumb:hover{background:#6e6e70}.settings-overlay[data-v-65032282]{z-index:9999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.settings-dialog[data-v-65032282]{background:#fff;border-radius:12px;width:420px;max-width:90vw;animation:.2s dialog-in-65032282;overflow:hidden;box-shadow:0 20px 60px #00000040}@keyframes dialog-in-65032282{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.settings-header[data-v-65032282]{background:#f9fafb;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.settings-header h2[data-v-65032282]{color:#1f2937;margin:0;font-size:16px;font-weight:600}.close-btn[data-v-65032282]{cursor:pointer;color:#9ca3af;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.close-btn[data-v-65032282]:hover{color:#374151;background:#f3f4f6}.settings-body[data-v-65032282]{flex-direction:column;gap:24px;padding:20px;display:flex}.setting-group[data-v-65032282]{flex-direction:column;gap:8px;display:flex}.setting-label[data-v-65032282]{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.setting-options[data-v-65032282]{flex-wrap:wrap;gap:8px;display:flex}.option-btn[data-v-65032282]{color:#374151;cursor:pointer;background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.option-btn[data-v-65032282]:hover{background:#f5f7ff;border-color:#a5b4fc}.option-btn.active[data-v-65032282]{color:#4338ca;background:#eef2ff;border-color:#6366f1;font-weight:600}.option-btn.active svg[data-v-65032282]{stroke:#4338ca}.settings-footer[data-v-65032282]{border-top:1px solid #e5e7eb;justify-content:flex-end;padding:16px 20px;display:flex}.confirm-btn[data-v-65032282]{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:8px;padding:8px 28px;font-size:14px;font-weight:600;transition:all .2s}.confirm-btn[data-v-65032282]:hover{background:#4f46e5}.confirm-btn[data-v-65032282]:active{transform:scale(.97)}*{box-sizing:border-box;margin:0;padding:0}html,body{width:100vw;height:100vh;margin:0;padding:0;overflow:hidden}#app{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#2c3e50;flex-direction:column;width:100vw;height:100vh;margin:0;padding:0;font-family:Avenir,Helvetica,Arial,sans-serif;display:flex;overflow:hidden}#toolbar{background-color:#1b173d;flex-shrink:0;justify-content:space-between;align-items:center;height:50px;padding:0 15px;display:flex;box-shadow:0 2px 4px #0000001a}.toolbar-left{align-items:center;gap:12px;display:flex}.app-logo{color:#fff;letter-spacing:.5px;font-size:18px;font-weight:700}.firmware-version{color:#ffffffb3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#ffffff1a;border:1px solid #ffffff0d;border-radius:4px;padding:3px 8px;font-family:Courier New,monospace;font-size:11px;transition:all .3s}.firmware-version:hover{color:#ffffffe6;background-color:#ffffff26}.toolbar-right{align-items:center;gap:6px;display:flex}.toolbar-center{gap:4px;margin-right:10px;display:flex}.toolbar-btn{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap;background:linear-gradient(135deg,#4f46e5 0%,#7c3aed 100%);border:1px solid #ffffff1a;border-radius:6px;align-items:center;gap:4px;padding:8px 12px;font-size:14px;font-weight:500;transition:all .3s;display:flex;position:relative;overflow:hidden}.toolbar-btn:before{content:"";opacity:0;background:#ffffff0d;border-radius:6px;transition:opacity .3s;position:absolute;inset:0}.toolbar-btn:hover:before{opacity:1}.toolbar-btn:hover{border-color:#fff3;transform:translateY(-2px);box-shadow:0 8px 25px #4f46e566}.toolbar-btn:active{transition:transform .1s;transform:translateY(0)}.toolbar-btn:disabled{cursor:not-allowed;box-shadow:none;opacity:.6;background:linear-gradient(135deg,#374151 0%,#4b5563 100%);border:1px solid #ffffff0d;transform:none}.btn-icon{flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:color .2s;display:flex}.connect-btn{background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%)}.connect-btn.connected{background:linear-gradient(135deg,#059669 0%,#0d9488 100%)}.connect-btn:hover{box-shadow:0 8px 25px #6366f166}.new-btn{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.new-btn:hover{background:linear-gradient(135deg,#5a67d8 0%,#6b46c1 100%);box-shadow:0 8px 25px #667eea66}.open-btn{background:linear-gradient(135deg,#4f46e5 0%,#7c3aed 100%)}.open-btn:hover{background:linear-gradient(135deg,#4338ca 0%,#6d28d9 100%);box-shadow:0 8px 25px #4f46e566}.save-btn{background:linear-gradient(135deg,#059669 0%,#0d9488 100%)}.save-btn:hover{background:linear-gradient(135deg,#047857 0%,#0f766e 100%);box-shadow:0 8px 25px #05966966}.run-btn{background:linear-gradient(135deg,#dc2626 0%,#ea580c 100%)}.run-btn:hover:not(:disabled){background:linear-gradient(135deg,#b91c1c 0%,#c2410c 100%);box-shadow:0 8px 25px #dc262666}.run-btn:disabled{background:linear-gradient(135deg,#374151 0%,#4b5563 100%)}.stop-btn{background:linear-gradient(135deg,#e11d48 0%,#f97316 100%)}.stop-btn:hover{background:linear-gradient(135deg,#be185d 0%,#ea580c 100%);box-shadow:0 8px 25px #e11d4866}.reset-btn{background:linear-gradient(135deg,#d97706 0%,#ea580c 100%)}.reset-btn:hover:not(:disabled){background:linear-gradient(135deg,#b45309 0%,#c2410c 100%);box-shadow:0 8px 25px #d9770666}.reset-btn:disabled{background:linear-gradient(135deg,#374151 0%,#4b5563 100%)}.main-content{flex:1;width:100%;height:calc(100vh - 50px);display:flex;position:relative;overflow:hidden}#blockly-wrapper{flex:1;min-width:0;position:relative;overflow:hidden}#blockly-wrapper.with-code-panel{flex:0 0 60%;width:60%}.settings-fab{z-index:100;color:#6b7280;cursor:pointer;background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex;position:absolute;bottom:16px;left:16px;box-shadow:0 2px 8px #00000026}.settings-fab:hover{color:#374151;background:#f3f4f6;transform:rotate(30deg);box-shadow:0 4px 12px #0003}.settings-fab:active{transform:rotate(30deg)scale(.95)}#code-panel{background-color:#0f0f0f;border-left:1px solid #333;flex-direction:column;width:40%;display:flex}.code-section{border-bottom:1px solid #333;flex-direction:column;flex:0 0 50%;min-height:0;display:flex;overflow:hidden}.code-header{background-color:#1a1a1a;border-bottom:1px solid #333;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 15px;display:flex}.code-header h3{color:#d4d4d4;margin:0;font-size:14px}.copy-btn{color:#ccc;cursor:pointer;background:#3c3c3c;border:1px solid #3e3e42;border-radius:4px;justify-content:center;align-items:center;padding:6px;font-size:12px;transition:all .2s;display:flex}.copy-btn:hover{background-color:#464647;border-color:#5a5a5c}.copy-btn:hover svg{stroke:#64b5f6}.ace-editor-wrapper{background-color:#1e1e1e;border:none;flex:1;min-height:0}.ace-editor-wrapper .ace_content{background-color:#1e1e1e!important}.ace-editor-wrapper .ace_gutter{color:#858585!important;background-color:#1e1e1e!important}.ace-editor-wrapper .ace_scroller{background-color:#1e1e1e!important}.log-section{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.log-section .serial-terminal{border-top:none}.blocklyToolboxDiv{box-shadow:2px 0 12px #0000000f;background:#fff!important;border-right:1px solid #e8e8e8!important;width:150px!important;padding:8px!important;overflow:hidden auto!important}.blocklyToolboxContents{padding:0!important}.blocklyTreeRow{background:0 0!important;border-left:none!important;height:auto!important;margin:0!important;padding:0!important;line-height:normal!important}.blocklyTreeIcon:not(.toolbox-icon){display:none!important}.toolbox-row{cursor:pointer!important;border-left:none!important;border-radius:8px!important;flex-direction:row!important;align-items:center!important;height:48px!important;min-height:auto!important;margin:0 4px 4px!important;padding:8px!important;transition:all .2s!important;display:flex!important}.toolbox-row:hover{background:var(--cat-color,#f3f4f6)!important}.toolbox-row.blocklyTreeSelected{background:var(--cat-color,#eef2ff)!important}.toolbox-row .blocklyTreeRowContentContainer{flex-direction:row!important;align-items:center!important;gap:10px!important;width:100%!important;display:flex!important}.toolbox-icon{box-shadow:0 2px 6px #00000026;border-radius:8px!important;flex-shrink:0!important;justify-content:center!important;align-items:center!important;width:32px!important;min-width:32px!important;height:32px!important;display:flex!important;position:relative!important}.toolbox-icon:after{font-size:16px;line-height:1}.icon-puppy:after{content:"🐶";font-size:17px}.icon-display:after{content:"🖥";font-size:17px}.icon-laser:after{content:"💥";font-size:16px}.icon-system:after{content:"⚙️";font-size:16px}.icon-statements:after{content:"❕";font-size:16px}.icon-values:after{content:"✖";color:#f3f4f6;font-size:14px}.icon-logic:after{content:"⇆";color:#f3f4f6;font-size:18px}.icon-loops:after{content:"↻";color:#f3f4f6;font-size:20px}.icon-variables:after{content:"≡";color:#f3f4f6;font-size:22px}.toolbox-label{color:#6b7280!important;letter-spacing:.3px!important;white-space:nowrap!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif!important;font-size:14px!important;font-weight:500!important;line-height:1.2!important}.toolbox-row:hover .toolbox-label{color:#fff!important}.toolbox-row.blocklyTreeSelected .toolbox-label{color:#fff!important;font-weight:600!important}.blocklyTreeSeparator{background:#e5e7eb!important;border:none!important;height:1px!important;margin:8px 12px!important;padding:0!important}.blocklyFlyoutBackground{fill:#191923e0!important;fill-opacity:1!important}.blocklyFlyout{min-width:300px!important}.blocklyFlyout .blocklyFlyoutLabel text{fill:#ffffff8c!important;letter-spacing:1px!important;text-transform:uppercase!important;font-size:13px!important;font-weight:500!important}.blocklyFlyout .flyout-header text{fill:#fff!important;letter-spacing:1.5px!important;text-transform:none!important;font-size:20px!important;font-weight:700!important}.blocklyFlyoutScrollbar .blocklyScrollbarHandle{rx:3;ry:3;fill:#fff3!important}.blocklyToolboxDiv::-webkit-scrollbar{width:4px}.blocklyToolboxDiv::-webkit-scrollbar-track{background:0 0}.blocklyToolboxDiv::-webkit-scrollbar-thumb{background:#ddd;border-radius:2px}.blocklyDiv .blocklyTrash{visibility:visible!important;display:block!important}
