.blockly-div[data-v-977e43b1]{width:100%;height:100%}.serial-terminal[data-v-ecd42430]{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-ecd42430]{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-ecd42430]{color:#d4d4d4;margin:0;font-size:14px}.terminal-controls[data-v-ecd42430]{align-items:center;gap:8px;display:flex}.status-dot[data-v-ecd42430]{border-radius:50%;width:8px;height:8px}.status-dot.connected[data-v-ecd42430]{background:#4caf50;box-shadow:0 0 4px #4caf50}.status-dot.disconnected[data-v-ecd42430]{background:#666}.status-text[data-v-ecd42430]{color:#999;font-size:11px}.clear-btn[data-v-ecd42430]{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-ecd42430]:hover{background-color:#444}.clear-btn:hover svg[data-v-ecd42430]{stroke:#e74c3c}.terminal-body[data-v-ecd42430]{-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-ecd42430]{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-ecd42430]{color:#666;text-align:center;padding:20px;font-style:italic}.terminal-body[data-v-ecd42430]::-webkit-scrollbar{width:6px}.terminal-body[data-v-ecd42430]::-webkit-scrollbar-track{background:#2d2d30}.terminal-body[data-v-ecd42430]::-webkit-scrollbar-thumb{background:#5a5a5c;border-radius:3px}.terminal-body[data-v-ecd42430]::-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)}.flash-overlay[data-v-41048468]{z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.flash-dialog[data-v-41048468]{background:#1a1a2e;border:1px solid #2196f34d;border-radius:16px;flex-direction:column;width:90%;max-width:520px;max-height:85vh;animation:.25s ease-out flash-dialog-in-41048468;display:flex;overflow:hidden;box-shadow:0 20px 60px #00000080,0 0 30px #2196f31a}@keyframes flash-dialog-in-41048468{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.flash-header[data-v-41048468]{background:linear-gradient(135deg,#1565c0,#0d47a1);border-bottom:1px solid #2196f34d;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.flash-title-row[data-v-41048468]{color:#fff;align-items:center;gap:8px;font-size:16px;font-weight:600;display:flex}.flash-close-btn[data-v-41048468]{color:#ffffffb3;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:18px;transition:all .2s}.flash-close-btn[data-v-41048468]:hover:not(:disabled){color:#fff;background:#ffffff1a}.flash-close-btn[data-v-41048468]:disabled{opacity:.3;cursor:not-allowed}.flash-body[data-v-41048468]{padding:20px;overflow-y:auto}.flash-info-card[data-v-41048468]{background:#2196f314;border:1px solid #2196f333;border-radius:12px;align-items:center;gap:15px;margin-bottom:16px;padding:16px;display:flex}.flash-info-icon[data-v-41048468]{font-size:36px}.flash-info-title[data-v-41048468]{color:#64b5f6;margin:0 0 4px;font-size:16px;font-weight:600}.flash-info-desc[data-v-41048468]{color:#9e9e9e;margin:0;font-size:13px;line-height:1.5}.flash-warning[data-v-41048468]{color:#ffb74d;background:#ff98001a;border:1px solid #ff980040;border-radius:8px;align-items:center;gap:8px;margin-bottom:20px;padding:10px 14px;font-size:13px;display:flex}.warning-icon[data-v-41048468]{font-size:16px}.flash-start-btn[data-v-41048468]{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2196f3,#1565c0);border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:16px;font-weight:600;transition:all .2s;display:flex}.flash-start-btn[data-v-41048468]:hover{background:linear-gradient(135deg,#42a5f5,#1e88e5);transform:translateY(-1px);box-shadow:0 4px 20px #2196f366}.flash-progress-area[data-v-41048468]{margin-bottom:16px}.flash-progress-bar-container[data-v-41048468]{background:#ffffff1a;border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden}.flash-progress-bar[data-v-41048468]{background:linear-gradient(90deg,#2196f3,#42a5f5);border-radius:4px;height:100%;transition:width .3s}.flash-progress-text[data-v-41048468]{color:#90caf9;text-align:center;font-size:14px}.flash-result[data-v-41048468]{text-align:center;padding:20px 0}.flash-result .result-icon[data-v-41048468]{border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 16px;font-size:30px;font-weight:700;display:flex}.flash-result.success .result-icon[data-v-41048468]{color:#4caf50;background:#4caf5026;border:2px solid #4caf50}.flash-result.error .result-icon[data-v-41048468]{color:#f44336;background:#f4433626;border:2px solid #f44336}.flash-result .result-text[data-v-41048468]{color:#ccc;margin:0 0 20px;font-size:15px}.flash-done-btn[data-v-41048468],.flash-retry-btn[data-v-41048468]{cursor:pointer;color:#fff;border:none;border-radius:8px;padding:10px 32px;font-size:14px;font-weight:600}.flash-done-btn[data-v-41048468]{background:linear-gradient(135deg,#4caf50,#388e3c)}.flash-done-btn[data-v-41048468]:hover{background:linear-gradient(135deg,#66bb6a,#43a047)}.flash-retry-btn[data-v-41048468]{background:linear-gradient(135deg,#2196f3,#1565c0)}.flash-retry-btn[data-v-41048468]:hover{background:linear-gradient(135deg,#42a5f5,#1e88e5)}.flash-log[data-v-41048468]{border:1px solid #ffffff1a;border-radius:8px;margin-top:16px;overflow:hidden}.flash-log-header[data-v-41048468]{color:#999;text-transform:uppercase;letter-spacing:.5px;background:#ffffff0d;padding:8px 12px;font-size:12px;font-weight:600}.flash-log-body[data-v-41048468]{background:#0000004d;max-height:160px;padding:8px 12px;font-family:Courier New,monospace;font-size:12px;overflow-y:auto}.flash-log-line[data-v-41048468]{color:#999;margin:2px 0;line-height:1.5}.flash-log-line.info[data-v-41048468]{color:#64b5f6}.flash-log-line.success[data-v-41048468]{color:#81c784}.flash-log-line.error[data-v-41048468]{color:#ef5350}.flash-log-body[data-v-41048468]::-webkit-scrollbar{width:4px}.flash-log-body[data-v-41048468]::-webkit-scrollbar-track{background:0 0}.flash-log-body[data-v-41048468]::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}*{box-sizing:border-box;margin:0;padding:0}html,body{background:#1b173d;width:100vw;height:100vh;margin:0;padding:0;overflow:hidden}#app{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#2c3e50;width:100vw;height:100vh;padding:0;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);flex-direction:column;margin: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.ble.connected{background:linear-gradient(135deg,#2563eb 0%,#7c3aed 100%)}.connect-btn:hover{box-shadow:0 8px 25px #6366f166}.connect-wrapper{position:relative}.connect-dropdown{z-index:1000;background:#1e1b3a;border:1px solid #ffffff26;border-radius:8px;min-width:160px;animation:.15s dropdownIn;position:absolute;top:calc(100% + 6px);left:0;overflow:hidden;box-shadow:0 8px 30px #0006}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.connect-option{color:#e2e8f0;cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:10px 16px;font-size:14px;transition:background .15s;display:flex}.connect-option:hover{background:#6366f140}.connect-option+.connect-option{border-top:1px solid #ffffff14}.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%)}.flash-fw-btn{background:linear-gradient(135deg,#2196f3 0%,#1565c0 100%)}.flash-fw-btn:hover{background:linear-gradient(135deg,#42a5f5 0%,#1e88e5 100%);box-shadow:0 8px 25px #2196f366}.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{width:32px!important;min-width:32px!important;height:32px!important;box-shadow:none!important;background-color:#0000!important;border:none!important;border-radius:50%!important;flex-shrink:0!important;justify-content:center!important;align-items:center!important;display:flex!important;position:relative!important;overflow:hidden!important}.blocklyToolboxDiv .blocklyTreeIcon{background-color:#0000!important}.toolbox-icon:after{font-size:16px;line-height:1}.icon-puppy:after{content:""}.icon-puppy{background-image:url(../icons/cat-puppy.png)!important;background-position:50%!important;background-repeat:no-repeat!important;background-size:28px 28px!important}.icon-actions:after{content:""}.icon-actions{background-image:url(../icons/cat-actions.png)!important;background-position:50%!important;background-repeat:no-repeat!important;background-size:28px 28px!important}.icon-display:after{content:""}.icon-display{background-image:url(../icons/cat-display.png)!important;background-position:50%!important;background-repeat:no-repeat!important;background-size:28px 28px!important}.icon-laser:after{content:""}.icon-laser{background-image:url(../icons/cat-laser.png)!important;background-position:50%!important;background-repeat:no-repeat!important;background-size:28px 28px!important}.icon-audio:after{content:""}.icon-audio{background-image:url(../icons/cat-audio.png)!important;background-position:50%!important;background-repeat:no-repeat!important;background-size:28px 28px!important}.icon-camera:after{content:""}.icon-camera{background-image:url(../icons/cat-camera.png)!important;background-position:50%!important;background-repeat:no-repeat!important;background-size:28px 28px!important}.icon-sensors:after{content:""}.icon-sensors{background-image:url(../icons/cat-sensors.png)!important;background-position:50%!important;background-repeat:no-repeat!important;background-size:28px 28px!important}.icon-button:after{content:""}.icon-button{background-image:url(../icons/cat-button.png)!important;background-position:50%!important;background-repeat:no-repeat!important;background-size:28px 28px!important}.icon-system:after{content:""}.icon-system{background-image:url(../icons/cat-system.png)!important;background-position:50%!important;background-repeat:no-repeat!important;background-size:28px 28px!important}.icon-control:after{content:""}.icon-control{background-image:url(../icons/cat-control.png)!important;background-position:50%!important;background-repeat:no-repeat!important;background-size:28px 28px!important}.icon-operators:after{content:""}.icon-operators{background-image:url(../icons/cat-operators.png)!important;background-position:50%!important;background-repeat:no-repeat!important;background-size:28px 28px!important}.icon-data:after{content:""}.icon-data{background-image:url(../icons/cat-data.png)!important;background-position:50%!important;background-repeat:no-repeat!important;background-size:28px 28px!important}.icon-variables:after{content:""}.icon-variables{background-image:url(../icons/cat-variables.png)!important;background-position:50%!important;background-repeat:no-repeat!important;background-size:28px 28px!important}.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}#toolbar-mobile{z-index:100;background:#1b173d;flex-shrink:0;justify-content:space-between;align-items:center;height:36px;padding:0 8px;display:flex}.mobile-menu-btn{color:#fff;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:20px;line-height:1}.mobile-center{gap:6px;display:flex}.mobile-right{align-items:center;gap:6px;display:flex}.mobile-btn{color:#fff;cursor:pointer;border:none;border-radius:4px;align-items:center;gap:4px;padding:4px 12px;font-size:14px;font-weight:600;display:flex}.mobile-btn.run{background:linear-gradient(135deg,#dc2626,#ea580c)}.mobile-btn.run:disabled{opacity:.6;cursor:not-allowed;background:#4b5563}.mobile-btn.stop{background:linear-gradient(135deg,#e11d48,#f97316)}.mobile-btn.stop:disabled{opacity:.6;cursor:not-allowed;background:#4b5563}.mobile-btn.connect{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.mobile-btn.connect.connected{background:linear-gradient(135deg,#059669,#0d9488)}.mobile-btn.code{background:linear-gradient(135deg,#4f46e5,#7c3aed);font-family:monospace}.drawer-overlay{z-index:1500;background:#00000080;position:fixed;inset:0}.menu-drawer{background:#1e1b3a;flex-direction:column;width:220px;height:100%;padding:12px 0;display:flex;position:absolute;top:0;left:0;overflow-y:auto;box-shadow:4px 0 20px #0006}.drawer-title{color:#fff;border-bottom:1px solid #ffffff1a;margin-bottom:4px;padding:8px 16px 16px;font-size:16px;font-weight:700}.drawer-item{color:#e2e8f0;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:10px 16px;font-size:14px;transition:background .15s;display:flex}.drawer-item:hover{background:#6366f140}.drawer-item:disabled{opacity:.4;cursor:not-allowed}.drawer-divider{background:#ffffff1a;height:1px;margin:4px 12px}.toolbox-drawer{background:#1e1b3a;border-radius:16px 16px 0 0;max-height:55vh;padding:8px 12px 16px;position:absolute;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0006}.drawer-handle{background:#ffffff4d;border-radius:2px;width:40px;height:4px;margin:0 auto 12px}.toolbox-grid{flex-wrap:wrap;gap:8px;max-height:calc(55vh - 40px);padding-bottom:8px;display:flex;overflow-y:auto}.toolbox-cat-btn{color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;transition:transform .15s,box-shadow .15s}.toolbox-cat-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #0000004d}.code-overlay{z-index:2000;background:#0f0f0f;flex-direction:column;display:flex;position:fixed;inset:0}.code-overlay-header{background:#1a1a1a;border-bottom:1px solid #333;flex-shrink:0;justify-content:space-between;align-items:center;height:36px;padding:0 12px;display:flex}.overlay-back-btn{color:#7c9aff;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:14px}.overlay-copy-btn{cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:16px}.code-overlay-body{flex-direction:column;flex:1;min-height:0;display:flex}.code-overlay-editor{border-bottom:1px solid #333;flex:1;min-height:0}.code-overlay-terminal{flex:1;min-height:0;overflow:hidden}.fab{z-index:200;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;transition:transform .2s;display:flex;position:absolute;box-shadow:0 2px 10px #0000004d}.fab:hover{transform:scale(1.1)}.fab-toolbox{color:#fff;background:#4f46e5;bottom:12px;left:12px}.drawer-left-enter-active,.drawer-left-leave-active{transition:opacity .25s}.drawer-left-enter-active .menu-drawer,.drawer-left-leave-active .menu-drawer{transition:transform .25s}.drawer-left-enter-from,.drawer-left-leave-to{opacity:0}.drawer-left-enter-from .menu-drawer,.drawer-left-leave-to .menu-drawer{transform:translate(-100%)}.drawer-up-enter-active,.drawer-up-leave-active{transition:opacity .25s}.drawer-up-enter-active .toolbox-drawer,.drawer-up-leave-active .toolbox-drawer{transition:transform .25s}.drawer-up-enter-from,.drawer-up-leave-to{opacity:0}.drawer-up-enter-from .toolbox-drawer,.drawer-up-leave-to .toolbox-drawer{transform:translateY(100%)}.slide-up-enter-active,.slide-up-leave-active{transition:transform .25s}.slide-up-enter-from,.slide-up-leave-to{transform:translateY(100%)}@media (height<=500px){.blocklyToolboxDiv{display:none!important}.main-content{height:calc(100vh - 36px)}#blockly-wrapper{flex:1!important;width:100%!important}}
