.header-toolbar{background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);box-shadow:0 4px 20px #00000059;justify-content:space-between;overflow:visible;padding:.8rem 2rem;position:relative;z-index:100}.brand,.header-toolbar{align-items:center;display:flex}.brand{gap:1rem}.logo{height:50px;object-fit:contain;width:50px}.company-name{font-size:1.8rem;letter-spacing:.5px}.company-name span{color:var(--accent)}.toolbar-icons{gap:1.5rem}.icon-wrapper,.toolbar-icons{align-items:center;display:flex}.icon-wrapper{color:var(--text-muted);cursor:pointer;font-size:1.5rem;justify-content:center;position:relative;transition:transform .2s ease}.icon-wrapper:hover{color:var(--text-primary);transform:translateY(-3px)}.icon-wrapper[role=button]{color:var(--text-muted)}.icon-wrapper[role=button]:hover{color:var(--text-primary);transform:translateY(-3px)}.tooltip{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:5px;bottom:-2.5rem;color:var(--text-primary);font-size:.75rem;font-weight:600;left:50%;opacity:0;padding:.25rem .6rem;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .2s ease,transform .2s ease;white-space:nowrap;z-index:200}.icon-wrapper:hover .tooltip{opacity:1;transform:translateX(-50%) translateY(-5px)}@media (max-width:768px){.header-toolbar{padding:.5rem 1rem}.company-name{font-size:1.4rem}.logo{height:auto!important;width:1200px!important}.icon-wrapper{font-size:1.2rem}}.dialog-overlay{align-items:center;background:#0000008f;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.dialog-box{animation:slideIn .3s ease;background:var(--bg-base);border:1px solid var(--border-subtle);border-radius:8px;box-shadow:0 8px 32px #0009;max-width:400px;padding:2rem;width:90%}.new-project-dialog-box{max-width:760px;padding:2.5rem}@keyframes slideIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.dialog-title{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.dialog-message{color:var(--text-muted);font-size:.95rem;line-height:1.5;margin:0 0 1.5rem}.dialog-buttons{display:flex;gap:.75rem;justify-content:flex-end}.new-project-dialog-buttons{flex-wrap:wrap;justify-content:center}.btn-cancel,.btn-create-without-save,.btn-reload,.btn-save-create{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;padding:.5rem 1rem;text-transform:none;transition:all .2s ease}.btn-create-without-save,.btn-save-create,.new-project-dialog-buttons .btn-cancel{font-size:1rem;min-height:52px;min-width:190px;padding:.9rem 1.25rem}.btn-cancel{background:var(--bg-elevated);border:1px solid var(--border-subtle);color:var(--text-primary)}.btn-cancel:hover{background:var(--bg-surface-2);border-color:var(--border-strong)}.btn-reload{background:var(--accent);border:1px solid var(--accent);color:#fff}.btn-reload:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-reload:active{background:var(--accent-hover);transform:scale(.98)}.btn-save-create{background:linear-gradient(135deg,var(--accent-gradient-start) 0,var(--accent-gradient-end) 100%);border:1px solid var(--accent);box-shadow:0 10px 24px var(--accent-shadow);color:#fff}.btn-save-create:hover{background:linear-gradient(135deg,var(--accent) 0,var(--accent-hover) 100%);border-color:var(--accent-hover)}.btn-create-without-save{background:linear-gradient(135deg,#d65b4d,#c84235);border:1px solid #df7d72;color:#fff}.btn-create-without-save:hover{background:linear-gradient(135deg,#e06b5d,#d54f43);border-color:#e4948c}.btn-create-without-save:active,.btn-save-create:active,.new-project-dialog-buttons .btn-cancel:active{transform:scale(.98)}.save-status-toast{animation:toastSlideIn .25s ease;background:linear-gradient(135deg,var(--accent-gradient-start) 0,var(--accent-gradient-end) 100%);border:1px solid var(--accent);border-radius:10px;box-shadow:0 14px 36px var(--accent-shadow);color:#fff;font-size:1rem;font-weight:700;letter-spacing:.01em;min-width:280px;padding:.95rem 1.4rem;position:fixed;right:28px;text-align:center;text-shadow:0 1px 1px #0830182e;top:110px;z-index:10000}@keyframes toastSlideIn{0%{opacity:0;transform:translateX(18px)}to{opacity:1;transform:translateX(0)}}.navbar-container{--block-panel-rail-offset:192px;--block-panel-top-offset:180px;border-bottom:1px solid var(--border-subtle);z-index:95}.navbar,.navbar-container{background:var(--bg-surface);position:relative;width:100%}.navbar{align-items:stretch;box-shadow:none;box-sizing:border-box;display:flex;flex-direction:column;gap:6px;padding:6px 16px 8px;z-index:90}.navbar-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.navbar-copy{display:flex;flex-direction:column;gap:0}.navbar-kicker{color:var(--text-primary);font-size:14px;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.navbar-groups{grid-gap:10px;align-items:stretch;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.block-library{align-items:center;display:flex;gap:10px}.block-library-rail{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);flex-shrink:0;gap:6px;min-width:64px;padding:6px}.block-library-rail,.rail-item{display:flex;flex-direction:column}.rail-item{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:10px;font-weight:500;gap:4px;justify-content:center;letter-spacing:.02em;min-width:56px;padding:8px 10px;transition:background .15s ease,color .15s ease,border-color .15s ease}.rail-item:hover{background:var(--bg-surface-2);color:var(--text-primary)}.rail-item.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.rail-item:focus-visible{outline:2px solid var(--accent-ring);outline-offset:2px}.rail-icon{align-items:center;display:flex;justify-content:center}.rail-label{font-size:10px;letter-spacing:.02em;line-height:1;white-space:nowrap}.block-library-body{display:flex;flex:1 1;flex-direction:column;justify-content:center;min-width:0}.chip-toolbar{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;gap:8px}.group-selector{align-items:center;display:inline-flex;flex-shrink:0;position:relative}.group-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:12px;font-weight:500;letter-spacing:0;min-width:110px;outline:none;padding:4px 24px 4px 10px;transition:border-color .15s ease,box-shadow .15s ease}.group-select:hover{border-color:var(--border-strong)}.group-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.group-select-chevron{color:var(--text-muted);pointer-events:none;position:absolute;right:10px;top:50%;transform:translateY(-50%)}.chip-row{align-items:center;display:flex;flex:1 1;flex-wrap:wrap;gap:4px;min-width:0}.chip-add{align-items:center;background:#0000;border:1px dashed var(--border-strong);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:inline-flex;font-family:inherit;justify-content:center;padding:4px 8px;transition:background .15s ease,border-color .15s ease,color .15s ease}.chip-add:hover:not(:disabled){background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.chip-add:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.block-library{flex-direction:column;gap:10px}.block-library-rail{align-self:stretch;flex-direction:row;min-width:0;overflow-x:auto}.rail-item{flex-direction:row;gap:8px;padding:6px 12px}.group-select,.group-selector{width:100%}}.navbar-empty-state,.popup-empty-state{border:1px dashed var(--border-subtle);border-radius:var(--radius-md);color:var(--text-muted);text-align:center}.navbar-empty-state{background:var(--bg-elevated);grid-column:1/-1;padding:14px 16px}.popup-empty-state{background:#161b22a6;font-size:12px;line-height:1.45;padding:12px 14px}.nav-group{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:none;display:flex;flex-direction:column;height:100%;padding:12px}.nav-group-label{color:var(--text-muted);font-size:10px;font-weight:500;letter-spacing:.08em;margin-bottom:10px;padding-left:2px;text-align:center;text-transform:uppercase}.nav-container{align-content:center;display:flex;flex:1 1;flex-wrap:wrap;gap:6px}.nav-container,.nav-item{align-items:center;justify-content:center}.nav-item{background:var(--bg-surface);border:1px solid #0000;border-left-width:2px;border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;display:inline-flex;font-family:inherit;font-size:11px;font-weight:500;letter-spacing:0;min-width:0;padding:4px 10px;position:relative;text-align:center;transition:background .15s ease,border-color .15s ease,color .15s ease;white-space:nowrap}.nav-item:hover{background:var(--accent-soft);border-left-color:var(--accent);box-shadow:none;color:var(--accent);transform:none}.nav-item.active{background:var(--accent);border-color:var(--accent);box-shadow:none;color:#fff;position:relative;transform:none;z-index:2}.nav-item:focus-visible{border-color:#0000;outline:2px solid var(--accent-ring);outline-offset:2px}.navbar::-webkit-scrollbar{height:6px}.navbar::-webkit-scrollbar-track{background:#0000}.navbar::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.search-bar{flex:1 1 240px;margin-left:auto;max-width:280px;min-width:200px}.search-bar-inner{color:#e6edf3b8}.navbar .search-input{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-family:inherit;font-size:12px;padding:5px 30px 5px 10px;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.navbar .search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring);outline:none}.search-icon{height:14px;right:8px;width:14px}.left-side-popup{backdrop-filter:none;-webkit-backdrop-filter:none;background:#080c128c;border:1px solid #a9b3c624;border-left:none;border-radius:0 16px 0 0;bottom:0;box-shadow:8px 0 28px #0000002e;display:flex;flex-direction:column;left:var(--block-panel-rail-offset);max-width:520px;opacity:0;overflow:hidden;pointer-events:none;position:fixed;top:var(--block-panel-top-offset);transform:translateX(-12px);transition:opacity .18s ease,transform .22s cubic-bezier(.4,0,.2,1),visibility 0s linear .22s;visibility:hidden;width:min(480px,calc(100vw - var(--block-panel-rail-offset) - 108px));z-index:94}.left-side-popup.active{opacity:1;pointer-events:auto;transform:translateX(0);transition-delay:0s;visibility:visible}.popup-header{align-items:center;background:#0a0e14b8;border-bottom:1px solid #a9b3c61f;display:flex;flex-shrink:0;font-weight:500;gap:12px;justify-content:space-between;padding:14px 16px}.popup-header,.popup-header h3{color:var(--text-primary);font-size:14px}.popup-header h3{font-weight:600;letter-spacing:0;line-height:1.3;margin:0;text-shadow:0 1px 2px #00000073}.popup-close{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:22px;height:30px;justify-content:center;padding:0;transition:background .15s ease,color .15s ease;width:30px}.popup-close:hover{background:#ffffff14;color:var(--text-primary)}.popup-content{background:#0000;flex:1 1 auto;min-height:0;overflow-x:hidden;overflow-y:auto;padding:14px 16px 20px;position:relative}.nav-option-wrapper{display:flex;flex-direction:column;gap:0}.popup-palette{background:#080c1261;border:1px solid #a9b3c61a;border-radius:var(--radius-md);box-shadow:none;box-sizing:border-box;display:flex;flex-direction:column;gap:10px;margin-top:8px;max-width:none;min-width:0;overflow:visible;padding:12px;width:100%;z-index:1}.popup-palette h4{color:var(--text-primary);font-size:13px;font-weight:500;margin:0 0 4px}.palette-header{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:.4rem;width:100%}.palette-close{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;height:28px;justify-content:center;min-width:28px;transition:background .15s ease,color .15s ease}.palette-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.popup-palette h5{color:var(--text-muted);font-size:11px;font-weight:600;letter-spacing:.04em;line-height:1.4;margin:6px 0 4px;text-shadow:0 1px 2px #0006;text-transform:uppercase}.popup-block-grid{grid-gap:.65rem;display:grid;gap:.65rem;grid-template-columns:max-content;justify-content:start}.palette-block-btn{background:#0000;border:none;color:inherit;cursor:grab;padding:0;text-align:left;transition:none}.block-preview-wrapper{width:max-content}.palette-block-btn.block-chip{background:#0000;border:none;box-shadow:none;cursor:grab;padding:0;position:relative;transition:transform .16s ease}.palette-block-btn.block-chip:hover{transform:translateY(-4px)}.palette-block-btn.block-chip:active .block-preview .blocklySvg,.palette-block-btn.block-chip:hover .block-preview .blocklySvg{filter:drop-shadow(0 0 2px #f5c636) drop-shadow(0 0 0 #f5c636)}.palette-block-btn.block-chip:active .block-preview .blocklyPath,.palette-block-btn.block-chip:hover .block-preview .blocklyPath{stroke:#f5c636;stroke-width:2px}.drag-handle{background:#0000;inset:0;position:absolute;z-index:10}.palette-block-btn.block-chip:active{cursor:grabbing}.palette-block-btn.block-chip:after,.palette-block-btn.block-chip:before{display:none}.palette-block-btn.block-chip[data-block-type=button_a_pressed],.palette-block-btn.block-chip[data-block-type=button_a_pressed_state],.palette-block-btn.block-chip[data-block-type=button_ab_pressed],.palette-block-btn.block-chip[data-block-type=event_loop],.palette-block-btn.block-chip[data-block-type=init_button_pin]{background:#0000;border-color:#0000}.palette-block-btn.block-chip.block-chip--output{box-shadow:none;clip-path:none;padding:0}.palette-block-btn.block-chip[data-block-type=button_a_pressed]:after,.palette-block-btn.block-chip[data-block-type=button_a_pressed]:before,.palette-block-btn.block-chip[data-block-type=button_a_pressed_state]:after,.palette-block-btn.block-chip[data-block-type=button_a_pressed_state]:before,.palette-block-btn.block-chip[data-block-type=button_ab_pressed]:after,.palette-block-btn.block-chip[data-block-type=button_ab_pressed]:before,.palette-block-btn.block-chip[data-block-type=event_loop]:after,.palette-block-btn.block-chip[data-block-type=event_loop]:before,.palette-block-btn.block-chip[data-block-type=init_button_pin]:after,.palette-block-btn.block-chip[data-block-type=init_button_pin]:before{background:#0000;border-color:#0000}.palette-block-btn.block-chip[data-block-type=speaker_play],.palette-block-btn.block-chip[data-block-type=speaker_set_volume],.palette-block-btn.block-chip[data-block-type=speaker_stop]{background:linear-gradient(135deg,#e4e1ff,#cfcaff);border-color:#a49bff}.palette-block-btn.block-chip[data-block-type=speaker_play]:before,.palette-block-btn.block-chip[data-block-type=speaker_set_volume]:before,.palette-block-btn.block-chip[data-block-type=speaker_stop]:before{background:#cfcaff;border-color:#a49bff}.palette-block-btn.block-chip[data-block-type=speaker_play]:after,.palette-block-btn.block-chip[data-block-type=speaker_set_volume]:after,.palette-block-btn.block-chip[data-block-type=speaker_stop]:after{background:#a49bff;border-color:#8c7bff}.palette-block-btn.block-chip[data-block-type=rgb_blink],.palette-block-btn.block-chip[data-block-type=rgb_set_color]{background:linear-gradient(135deg,#d0f6ff,#a8ebff);border-color:#6fd6f5}.palette-block-btn.block-chip[data-block-type=rgb_blink]:before,.palette-block-btn.block-chip[data-block-type=rgb_set_color]:before{background:#a8ebff;border-color:#6fd6f5}.palette-block-btn.block-chip[data-block-type=rgb_blink]:after,.palette-block-btn.block-chip[data-block-type=rgb_set_color]:after{background:#6fd6f5;border-color:#36b6db}.palette-block-btn.block-chip[data-block-type=power_off],.palette-block-btn.block-chip[data-block-type=power_on]{background:linear-gradient(135deg,#ffd8c0,#ffb999);border-color:#ff9266}.palette-block-btn.block-chip[data-block-type=power_off]:before,.palette-block-btn.block-chip[data-block-type=power_on]:before{background:#ffb999;border-color:#ff9266}.palette-block-btn.block-chip[data-block-type=power_off]:after,.palette-block-btn.block-chip[data-block-type=power_on]:after{background:#ff9266;border-color:#f06c3c}.palette-block-btn:not(.block-chip):hover{background:var(--accent-soft);border-color:var(--accent);transform:none}.curved-buttons-container{display:flex;flex-direction:column;gap:10px}.curved-button{background:#161b22b8;border:1px solid #a9b3c624;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:13px;font-weight:500;line-height:1.35;overflow:hidden;padding:11px 14px;position:relative;text-align:left;text-shadow:0 1px 2px #00000059;transition:background .15s ease,border-color .15s ease,color .15s ease;width:100%}.curved-button:hover{background:#1e2430d1;border-color:#4f87f873;box-shadow:none}.curved-button.selected{background:#3b82f633;border-color:var(--accent);color:var(--text-primary)}.curved-button:before{display:none}@media (max-width:1024px){.navbar{padding:.95rem 1rem 1rem}.navbar-container{--block-panel-rail-offset:172px}.left-side-popup{width:min(460px,calc(100vw - var(--block-panel-rail-offset) - 108px))}.navbar-groups{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.nav-item{font-size:.76rem}.search-bar{max-width:none;min-width:220px}}@media (max-width:900px){.navbar-container{--block-panel-rail-offset:148px}}@media (max-width:768px){.navbar-toolbar{align-items:stretch}.navbar-groups{grid-template-columns:1fr}.nav-group{padding:.8rem}.search-bar{margin-left:0;max-width:none;width:100%}.left-side-popup{width:min(380px,calc(100vw - var(--block-panel-rail-offset) - 88px))}}@media (max-width:480px){.navbar{gap:.85rem;padding:.85rem .75rem .95rem}.navbar-title{font-size:.88rem}.nav-container{gap:.45rem}.nav-item{font-size:.74rem;padding:.54rem .78rem}.left-side-popup{width:min(300px,calc(100vw - var(--block-panel-rail-offset) - 72px))}.popup-content,.popup-header{padding:1rem}.curved-button{font-size:.9rem;padding:.8rem 1rem}}.var-dialog-overlay{align-items:center;background:#0000008c;display:flex;inset:0;justify-content:center;position:fixed;z-index:10000}.var-dialog{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;max-width:480px;min-width:380px;padding:2rem 2.5rem;text-align:center}.var-dialog-title{color:#333;font-size:1.25rem;font-weight:700;margin:0 0 1.2rem}.var-dialog-message{color:#333;font-size:1rem;font-weight:600;margin:0 0 1.2rem}.var-dialog-input{border:2px solid #c0cfdf;border-radius:6px;box-sizing:border-box;font-size:1rem;margin-bottom:1.2rem;outline:none;padding:.7rem 1rem;transition:border-color .2s;width:100%}.var-dialog-input:focus{border-color:#6ba3d6}.var-dialog-buttons{display:flex;gap:.75rem;justify-content:center}.var-dialog-cancel,.var-dialog-ok{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;padding:.55rem 1.8rem;transition:opacity .2s}.var-dialog-ok{background:#6ba3d6;color:#fff}.var-dialog-ok:hover{opacity:.85}.var-dialog-cancel{background:#bbb;color:#fff}.var-dialog-cancel:hover{opacity:.85}.variable-palette{display:flex;flex-direction:column;gap:8px}.create-variable-btn{background:#161b22b8;border:1px solid #a9b3c624;border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:12px;font-weight:500;padding:7px 12px;transition:background .15s ease,border-color .15s ease}.create-variable-btn:hover{background:#1e2430d1;border-color:var(--accent);color:var(--accent)}.output-screen,.output-screen *{box-sizing:border-box}.output-screen{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:none;margin:0;overflow:hidden;padding:0}.output-screen--with-toast{position:relative}.output-header{align-items:center;background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);color:var(--text-primary);display:flex;flex-shrink:0;font-weight:500;justify-content:space-between;padding:12px 16px}.output-content{display:flex;flex:1 1;flex-direction:column;gap:12px;min-height:400px;overflow:visible;padding:14px 16px}.circular-display{min-height:200px}.output-preview{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);margin-top:.5rem;max-width:80%;padding:.5rem}.output-preview-text{color:var(--success);font-family:Fira Code,JetBrains Mono,Consolas,monospace;font-size:12px}.output-console{background:var(--bg-base);flex:1 1;overflow:hidden}.device-monitor,.output-console{border:1px solid var(--border-subtle);border-radius:var(--radius-md);display:flex;flex-direction:column}.device-monitor{background:var(--bg-surface-2);color:var(--text-primary);gap:10px;padding:12px 14px}.device-monitor-header{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between}.device-monitor-title-group{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.device-monitor-title{color:var(--text-primary);font-size:13px;font-weight:500}.device-monitor-pill{border-radius:var(--radius-sm);font-size:11px;font-weight:500;letter-spacing:0;padding:3px 10px}.device-monitor-pill.online{background:var(--success-soft);border:1px solid #10b98152;color:var(--success)}.device-monitor-pill.offline{background:#ef44441f;border:1px solid #ef444447;color:var(--danger)}.device-monitor-meta{color:var(--text-muted);font-size:11px}.device-monitor-events{display:flex;flex-direction:column;gap:8px}.device-monitor-event{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:8px 12px}.device-monitor-event-topline{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:4px}.device-monitor-event-kind{color:var(--accent);font-size:10px;font-weight:500;letter-spacing:.04em;text-transform:uppercase}.device-monitor-event-time{color:var(--text-faint);font-size:10px}.device-monitor-empty,.device-monitor-event-message{color:var(--text-primary);font-size:12px;line-height:1.5}.device-monitor-empty{color:var(--text-muted)}.console-header{align-items:center;background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;padding:8px 14px}.console-header,.console-title{color:var(--text-primary);font-weight:500}.console-title{font-size:12px;letter-spacing:0}.console-toggle{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);display:flex;gap:4px;padding:3px}.console-toggle button{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:11px;font-weight:500;padding:4px 12px;transition:background .15s ease,color .15s ease}.console-toggle button:hover{color:var(--text-primary)}.console-toggle button.active{background:var(--accent);color:#fff}.console-content{background:var(--bg-base);color:var(--text-primary);flex:1 1;font-family:Fira Code,JetBrains Mono,Courier New,monospace;font-size:12px;line-height:1.6;overflow-y:auto;padding:12px 14px;white-space:pre-wrap}.console-content pre{word-wrap:break-word;margin:0;white-space:pre-wrap}.console-line{margin-bottom:1px;white-space:pre-wrap;word-break:break-all}.console-line-error{color:var(--danger)}.console-line-warning{color:var(--warning)}.console-line-success{color:var(--success)}.console-line-info{color:var(--text-muted);font-style:italic;padding-left:12px}.console-line-normal{border:none;color:var(--text-primary)}.loading{align-items:center;color:var(--accent);display:flex;font-size:12px;gap:8px}.spinner{animation:spin .8s linear infinite;border:2px solid var(--accent);border-radius:50%;border-top:2px solid #0000;flex-shrink:0;height:14px;width:14px}@keyframes spin{to{transform:rotate(1turn)}}.console-placeholder{color:var(--text-faint);font-style:italic}.placeholder-line{margin-bottom:.4rem}.model-display-wrapper{display:flex;flex-direction:row;flex-shrink:0;gap:0;height:400px;margin:0;overflow:visible;padding:0;position:relative;width:100%}.screen-settings-slot{height:0;pointer-events:none;position:absolute;right:0;top:0;width:0;z-index:5000}.screen-settings-slot .screen-settings-modal{pointer-events:auto}.model-display{flex:1 1;height:100%;margin:0;min-width:0;padding:0;position:relative}.model-display,.model-overlay{align-items:center;display:flex;justify-content:center}.model-overlay{color:#fff;flex-direction:column;height:260px;left:0;pointer-events:none;position:absolute;top:0;width:260px}.model-text{font-weight:700;letter-spacing:2px}.model-status{font-size:14px;margin-top:6px;opacity:.8}.view-toggle{border-bottom:1px solid var(--border-subtle);display:flex;flex-shrink:0;gap:4px;margin-bottom:10px}.view-toggle button{background:#0000;border:none;border-bottom:2px solid #0000;color:var(--text-muted);cursor:pointer;font-size:13px;font-weight:500;margin-bottom:-1px;padding:8px 14px;transition:color .15s ease,border-color .15s ease}.view-toggle button:hover{color:var(--text-primary)}.view-toggle button.active{border-bottom-color:var(--accent);color:var(--accent)}.terminal-content{background:var(--bg-base);padding:0}.terminal-body{background:var(--bg-base);color:var(--text-primary);font-family:Fira Code,JetBrains Mono,Courier New,monospace;font-size:12px;line-height:1.7;min-height:100px;overflow-y:auto;padding:12px 14px}.terminal-line{align-items:baseline;display:flex;flex-wrap:wrap;gap:4px;margin-bottom:1px}.terminal-prompt{color:var(--success);flex-shrink:0;-webkit-user-select:none;user-select:none}.terminal-cmd{color:var(--text-primary)}.terminal-muted{color:var(--text-faint);font-style:italic}.terminal-indent{color:var(--text-muted);font-style:italic;padding-left:16px}.terminal-info-line{align-items:center;color:var(--accent);display:flex;gap:8px;margin:4px 0}.terminal-output-block{margin:4px 0 8px;padding-left:4px}.terminal-out-error{color:var(--danger);white-space:pre-wrap;word-break:break-all}.terminal-out-warning{color:var(--warning);white-space:pre-wrap}.terminal-out-success{color:var(--success);white-space:pre-wrap}.terminal-out-info{color:var(--text-muted);white-space:pre-wrap}.terminal-out-normal{color:var(--text-primary);white-space:pre-wrap}.spinner-term{animation:spin .8s linear infinite;border:2px solid var(--accent);border-radius:50%;border-top:2px solid #0000;display:inline-block;flex-shrink:0;height:10px;width:10px}.terminal-cursor{animation:blink 1s step-end infinite;background:var(--success);display:inline-block;height:13px;margin-left:4px;vertical-align:middle;width:8px}.terminal-cursor-line{margin-top:4px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.monaco-editor,.monaco-editor .inputarea.ime-input,.monaco-editor .overflow-guard,.monaco-editor-background{background-color:var(--bg-base)!important}.react-flow__controls{background:var(--bg-surface)!important;border:1px solid var(--border-subtle);border-radius:var(--radius-md)!important;box-shadow:none;overflow:hidden}.react-flow__controls-button{background:#0000!important;border-bottom:1px solid var(--border-subtle)!important;color:var(--text-muted)!important;transition:background .15s ease,color .15s ease}.react-flow__controls-button:last-child{border-bottom:none!important}.react-flow__controls-button:hover{background:var(--accent-soft)!important;color:var(--accent)!important}.react-flow__controls-button svg{fill:currentColor!important}.component-sidebar-wrapper{display:flex;flex-shrink:0;gap:0!important;height:100%;margin:0!important;max-width:70px;min-width:70px;padding:0!important;position:relative;width:70px}.bottom-section{display:flex;flex-direction:column;gap:.5rem;position:relative;width:100%}.component-sidebar{align-items:center;justify-content:flex-start;margin:0;width:100%}.component-sidebar-item{font-weight:500;margin:0;opacity:1;padding:8px 4px;text-align:center;visibility:visible;width:70px}.component-sidebar-item:hover{transform:none}.component-icon{margin-bottom:6px}.component-icon svg{height:20px;width:20px}.component-name{max-width:100%;text-overflow:ellipsis}.property-inspector{background:#0000;color:#f8fafc;display:flex;flex-direction:column;flex-shrink:0;font-family:Montserrat,system-ui,-apple-system,sans-serif;font-size:12px;max-width:300px;min-width:220px;overflow:hidden;width:260px}.property-inspector__header{align-items:flex-start;background:#1f2430fa;border-bottom:1px solid #ffffff14;display:flex;gap:10px;justify-content:space-between;padding:10px 12px}.property-inspector__header-text{flex:1 1;min-width:0}.property-inspector__title{color:#f8fafc;font-size:13px;font-weight:700;letter-spacing:.02em;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.property-inspector__type-badge{background:#ffffff0a;border:1px solid #ffffff14;border-radius:999px;color:var(--text-muted);display:inline-block;font-size:10px;font-weight:600;letter-spacing:.06em;margin-top:4px;padding:2px 8px;text-transform:uppercase}.property-inspector__close{align-items:center;background:#0000;border:none;border-radius:8px;color:#cbd5e1;cursor:pointer;display:flex;flex-shrink:0;font-size:20px;height:30px;justify-content:center;line-height:1;margin:-4px -6px 0 0;transition:color .15s ease,background .15s ease;width:30px}.property-inspector__close:hover{background:#ffffff14;color:#f8fafc}.property-inspector__body{flex:1 1;min-height:0;overflow:visible;padding:8px 12px 12px}.property-inspector__row{grid-gap:6px 10px;align-items:center;border-bottom:1px solid #ffffff14;display:grid;gap:6px 10px;grid-template-columns:84px minmax(0,1fr);padding:5px 0}.property-inspector__row:last-child{border-bottom:none}.property-inspector__row--color .property-inspector__label{padding-top:0}.property-inspector__row--visible{align-items:center}.property-inspector__row--visible .property-inspector__label{padding-top:0}.property-inspector__label{color:#e2e8f0d1;font-size:12px;font-weight:500;padding-top:0;text-align:right}.property-inspector__control{min-width:0}.property-inspector__input,.property-inspector__select{background:#ffffff0a;border:1px solid #ffffff1f;border-radius:8px;color:#f8fafc;font-family:inherit;font-size:12px;height:28px;outline:none;padding:6px 10px;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.property-inspector__input:focus,.property-inspector__select:focus{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-ring)}.property-inspector__input--error,.property-inspector__row--error .property-inspector__input{border-color:var(--danger)}.property-inspector__field-error{color:var(--danger);font-size:10px;line-height:1.35;margin:6px 0 0}.property-inspector__select{appearance:auto;cursor:pointer}.property-inspector__color-stack{align-items:center;display:flex;flex-direction:row;gap:8px}.property-inspector__color-swatch-btn{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:10px;box-sizing:border-box;cursor:pointer;height:30px;padding:0;transition:border-color .15s ease,box-shadow .15s ease;width:34px}.property-inspector__color-swatch-btn:hover{border-color:#38bdf8cc;box-shadow:0 0 0 1px #38bdf82e}.property-inspector__visible-cell{align-items:center;display:flex;gap:10px;padding-top:0}.property-inspector__checkbox{accent-color:#38bdf8;cursor:pointer;height:16px;width:16px}.property-inspector__visible-hint{color:#e2e8f0b8;cursor:pointer;font-size:10px;-webkit-user-select:none;user-select:none}.property-inspector__row--actions{border-bottom:none;padding-top:10px}.property-inspector__btn-delete{align-items:center;background:#8b1a1a;border:1px solid #8b1a1a80;border-radius:12px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:12px;font-weight:700;gap:6px;justify-content:center;letter-spacing:.02em;padding:8px 12px;transition:background .15s ease,border-color .15s ease,transform .15s ease;width:100%}.property-inspector__btn-delete:focus,.property-inspector__btn-delete:hover{background:#a02828;border-color:#ffffff52}.property-inspector__btn-delete:active{transform:scale(.98)}.property-inspector__btn-icon{align-items:center;display:inline-flex;font-size:14px;justify-content:center}.property-inspector__delete-warning{color:#f87171f2;font-size:11px;margin-top:8px}.output-screen-toast{background:#ff5252;border:none;border-radius:0;box-shadow:none;color:#fff;font-family:Montserrat,system-ui,-apple-system,sans-serif;font-size:14px;font-weight:500;line-height:1.35;padding:12px 20px;pointer-events:none;position:absolute;right:16px;top:52px;z-index:300}.react-flow{direction:ltr}.react-flow__container{height:100%;left:0;position:absolute;top:0;width:100%}.react-flow__pane{cursor:grab;z-index:1}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:grabbing}.react-flow__viewport{pointer-events:none;transform-origin:0 0;z-index:2}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{overflow:visible;pointer-events:none}.react-flow__connection-path,.react-flow__edge-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{cursor:pointer;pointer-events:visibleStroke}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{box-sizing:border-box;cursor:grab;pointer-events:all;position:absolute;transform-origin:0 0;-webkit-user-select:none;user-select:none}.react-flow__node.dragging{cursor:grabbing}.react-flow__nodesselection{pointer-events:none;transform-origin:left top;z-index:3}.react-flow__nodesselection-rect{cursor:grab;pointer-events:all;position:absolute}.react-flow__handle{background:#1a192b;border:1px solid #fff;border-radius:100%;height:6px;min-height:5px;min-width:5px;pointer-events:none;position:absolute;width:6px}.react-flow__handle.connectionindicator{cursor:crosshair;pointer-events:all}.react-flow__handle-bottom{bottom:-4px;left:50%;top:auto;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{left:-4px;top:50%;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{margin:15px;position:absolute;z-index:5}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translateX(-50%)}.react-flow__attribution{background:#ffffff80;font-size:10px;margin:0;padding:2px 3px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{height:100%;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none;width:100%}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-group,.react-flow__node-input,.react-flow__node-output{background-color:#fff;border:1px solid #1a192b;border-radius:3px;color:#222;font-size:12px;padding:10px;text-align:center;width:150px}.react-flow__node-default.selectable:hover,.react-flow__node-group.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted #0059dccc}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{align-items:center;background:#fefefe;border:none;border-bottom:1px solid #eee;box-sizing:initial;cursor:pointer;display:flex;height:16px;justify-content:center;padding:5px;-webkit-user-select:none;user-select:none;width:16px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{max-height:12px;max-width:12px;width:100%}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.bottom,.react-flow__resize-control.top{cursor:ns-resize}.react-flow__resize-control.bottom.right,.react-flow__resize-control.top.left{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{background-color:#3367d9;border:1px solid #fff;border-radius:1px;height:4px;transform:translate(-50%,-50%);width:4px}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.bottom.left,.react-flow__resize-control.handle.top.left{left:0}.react-flow__resize-control.handle.bottom.right,.react-flow__resize-control.handle.top.right{left:100%}.react-flow__resize-control.line{border:0 solid #3367d9}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{height:100%;top:0;transform:translate(-50%);width:1px}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.bottom,.react-flow__resize-control.line.top{height:1px;left:0;transform:translateY(-50%);width:100%}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.device-preview-wrapper{align-items:center;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:none;box-sizing:border-box;display:flex;flex-direction:column;justify-content:center;max-width:600px;min-height:320px;padding:12px 20px;position:relative;width:100%}.device-screen{border:1px solid var(--border-strong);border-radius:50%;box-shadow:0 0 0 1px var(--border-subtle),inset 0 0 40px #0006;cursor:crosshair;height:340px;margin:10px;overflow:hidden;pointer-events:auto;position:relative;transition:border-color .2s,box-shadow .2s;-webkit-user-select:none;user-select:none;width:340px}.device-screen__bg{border-radius:50%;inset:0;pointer-events:none;position:absolute;z-index:0}.device-screen>.empty-state,.device-screen>.guide-line,.device-screen>.placed-component{z-index:1}.device-screen.out-of-range{border-color:var(--danger);box-shadow:0 0 0 1px #ef444466,inset 0 0 40px #0006}.guide-line{background:var(--warning);opacity:.65;pointer-events:none;position:absolute;transition:opacity .1s;z-index:10}.guide-line.v{height:100%;top:0;width:1px}.guide-line.h{height:1px;left:0;width:100%}.guide-line.center{background:var(--accent);border-radius:50%;box-shadow:0 0 6px var(--accent);height:2px;opacity:1;width:2px}.placed-component{align-items:center;border:1px solid var(--border-strong);border-radius:var(--radius-sm);box-sizing:border-box;cursor:grab;display:flex;font-size:10px;font-weight:500;justify-content:center;overflow:hidden;pointer-events:auto;position:absolute;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;-webkit-user-select:none;user-select:none;z-index:100}.placed-component .widget-fill{box-sizing:border-box;height:100%;min-height:0;min-width:0;width:100%}.placed-component:active{cursor:grabbing}.placed-component{background:var(--bg-elevated);box-shadow:none;color:var(--text-primary)}.placed-component:hover{background:var(--bg-surface-2);border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-ring);z-index:101}.placed-component.dragging{border-color:var(--warning);box-shadow:0 0 0 1px #f59e0b73;opacity:.85;z-index:200}.placed-component.selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-ring);z-index:102}.device-screen .placed-component{font-family:Montserrat,system-ui,-apple-system,sans-serif}.selection-frame{border:1px dashed var(--accent);border-radius:var(--radius-sm);inset:-4px;pointer-events:none;position:absolute;z-index:5}.resize-handle{background:var(--bg-elevated);border:1px solid var(--accent);border-radius:2px;box-sizing:border-box;height:9px;pointer-events:auto;position:absolute;width:9px;z-index:160}.resize-handle-nw{cursor:nwse-resize;left:-5px;top:-5px}.resize-handle-ne{cursor:nesw-resize;right:-5px;top:-5px}.resize-handle-sw{bottom:-5px;cursor:nesw-resize;left:-5px}.resize-handle-se{bottom:-5px;cursor:nwse-resize;right:-5px}.inline-text-edit{background:var(--bg-base);border:1px solid var(--accent);border-radius:3px;box-sizing:border-box;color:var(--text-primary);font-family:Montserrat,system-ui,-apple-system,sans-serif;font-weight:500;margin:0 auto;max-width:100%;min-width:32px;outline:none;padding:4px 6px;text-align:center;width:calc(100% - 6px)}.placed-component.label,.placed-component.label-plus{background:#0000;border:none;box-shadow:none;box-sizing:border-box;font-weight:500;letter-spacing:.02em;padding:0}.placed-component.label .widget-text,.placed-component.label-plus .widget-text{align-items:center;box-sizing:border-box;display:flex;height:100%;justify-content:center;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap;width:100%}.placed-component.label-plus:hover,.placed-component.label:hover{background:#ffffff0f;border:1px dashed var(--border-subtle)}.placed-component.button{background:#0000;border:none;box-shadow:none;box-sizing:border-box;font-weight:600;letter-spacing:.02em;padding:0}.placed-component.button .widget-text{align-items:center;background:#f8fafcf0;border:2px solid var(--accent);border-radius:999px;box-shadow:0 1px 2px #0000001f;box-sizing:border-box;color:#0f172a;display:flex;height:100%;justify-content:center;overflow:hidden;padding:0 8px;text-align:center;text-overflow:ellipsis;white-space:nowrap;width:100%}.placed-component.line{background:#0000;border:none;box-sizing:border-box;padding:0}.placed-component.line .line-render{align-items:center;box-sizing:border-box;display:flex;height:100%;justify-content:center;width:100%}.placed-component.line .line-stroke{background:var(--accent);border-radius:1px;box-sizing:border-box;flex-shrink:0}.placed-component.switch{align-items:stretch;background:#0000;border:none;box-shadow:none;justify-content:stretch;padding:2px}.placed-component.switch .switch-render{background:var(--border-strong);background:var(--widget-bg,var(--border-strong));border:1px solid var(--border-subtle);border-radius:999px;box-sizing:border-box;height:100%;min-height:0;position:relative;width:100%}.placed-component.switch .switch-render--themed{background:var(--border-strong);background:var(--widget-bg,var(--border-strong));border-color:var(--widget-color,var(--border-subtle))}.placed-component.switch .switch-render:after{aspect-ratio:1;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:50%;box-shadow:none;content:"";height:calc(100% - 4px);left:2px;max-width:46%;position:absolute;top:50%;transform:translateY(-50%);width:auto}.placed-component.switch .switch-render--themed:after{background:var(--widget-color);border:none}.placed-component.ui-slider{align-items:center;background:#0000!important;border:none!important;border-radius:0;box-shadow:none!important;justify-content:stretch;min-height:18px;overflow:visible!important;padding:0}.placed-component.ui-slider.dragging,.placed-component.ui-slider.selected,.placed-component.ui-slider:hover{background:#0000!important;border:none!important;box-shadow:none!important}.placed-component.ui-slider:after,.placed-component.ui-slider:before{content:none!important;display:none!important}.placed-component.ui-slider .slider-widget-host{align-self:center;flex:0 0 auto;width:100%}.placed-component.bar{background:#0000;border:none;box-sizing:border-box;padding:0}.placed-component.bar .bar-render{align-items:center;box-sizing:border-box;display:flex;height:100%;width:100%}.placed-component.bar .bar-track{background:var(--border-strong);background:var(--widget-bg,var(--border-strong));border:1px solid var(--border-subtle);border-radius:4px;box-sizing:border-box;height:100%;overflow:hidden;position:relative;width:100%}.placed-component.bar .bar-fill{background:var(--accent);background:var(--widget-color,var(--accent));border-radius:4px;box-sizing:border-box;height:100%;left:0;position:absolute;top:0;width:40%}.placed-component.bar .bar-render--themed .bar-track{border-color:var(--widget-color,var(--border-subtle))}.placed-component.checkbox{align-items:stretch;background:#0000;border:none;box-shadow:none;flex-direction:row;font-size:10px;font-weight:500;gap:4px;height:100%;justify-content:flex-start;padding:2px 4px;width:100%}.placed-component.checkbox .checkbox-box{aspect-ratio:1;background:#fff;border:2px solid var(--accent);border-radius:3px;box-sizing:border-box;display:block;flex-shrink:0;height:100%;margin-top:0;max-width:45%;width:auto}.placed-component.checkbox .checkbox-label{align-items:center;display:flex;flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.placed-component.checkbox.checkbox--themed .checkbox-box{border-color:var(--widget-color)}.placed-component.checkbox.checkbox--checked .checkbox-box{background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath fill='%233b82f6' d='M4.5 9.2 1.8 6.5l1-1 1.7 1.7 4.7-4.7 1 1z'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:70% 70%;border-color:var(--widget-color,var(--accent))}.placed-component.image,.placed-component.image-plus{align-items:stretch;background:#0000;border:none;border-radius:8px;box-shadow:none;justify-content:stretch;overflow:hidden;padding:0}.placed-component.image .image-render,.placed-component.image-plus .image-render{align-items:center;background:#0000;border:1px solid var(--accent-ring);border-radius:8px;box-sizing:border-box;display:flex;height:100%;justify-content:center;min-height:0;padding:2px;position:relative;width:100%}.placed-component.image .image-render__photo,.placed-component.image-plus .image-render__photo{border-radius:8px;display:block;height:100%;object-fit:cover;width:100%}.placed-component.image .image-render__svg,.placed-component.image-plus .image-render__svg{display:block;height:100%;max-height:100%;max-width:100%;width:100%}.placed-component.image .image-render__panel,.placed-component.image-plus .image-render__panel{fill:#a8bdd4}.placed-component.image .image-render__sun,.placed-component.image-plus .image-render__sun{fill:#eef4fc}.placed-component.image .image-render__hill--back,.placed-component.image-plus .image-render__hill--back{fill:#6b849a}.placed-component.image .image-render__hill--front,.placed-component.image-plus .image-render__hill--front{fill:#8aa3ba}.coord-tooltip{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);box-shadow:none;color:var(--accent);font-family:Fira Code,JetBrains Mono,monospace;font-size:11px;left:-130px;padding:5px 10px;pointer-events:none;position:absolute;top:-20px;white-space:nowrap;z-index:300}.floating-property-card{background:#12161ef5;border:1px solid #2a2d3a;border-radius:8px;box-shadow:0 16px 40px #00000047;color:#f8fafc;display:flex;flex-direction:column;font-family:Montserrat,system-ui,-apple-system,sans-serif;max-height:calc(100vh - 16px);max-width:calc(100vw - 16px);overflow:hidden;position:fixed;width:280px;z-index:400}.floating-property-card__header{align-items:center;background:#1f2430fa;border-bottom:1px solid #ffffff14;display:flex;gap:8px;justify-content:space-between;padding:10px 12px}.floating-property-card__title{font-size:13px;font-weight:700;letter-spacing:.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.floating-property-card__actions{align-items:center;display:flex;gap:6px}.floating-property-card__close,.floating-property-card__drag-handle{background:#0000;border:none;border-radius:6px;color:#cbd5e1;cursor:pointer;padding:4px 6px}.floating-property-card__close:hover,.floating-property-card__drag-handle:hover{background:#ffffff0f;color:#f8fafc}.floating-property-card__drag-handle:active{cursor:grabbing}.floating-property-card__body{flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;padding:10px 12px 12px}.color-field-row__swatch{border:1px solid #2a2d3a;border-radius:5px;box-sizing:border-box;cursor:pointer;flex-shrink:0;height:26px;padding:0;width:26px}.color-field-row__swatch--open{outline:2px solid #3b82f6;outline-offset:1px}.color-field-row__popover{background:#12161efa;border:1px solid #2a2d3a;border-radius:8px;box-shadow:0 16px 40px #00000052;box-sizing:border-box;max-width:calc(100vw - 16px);overflow:hidden;padding:10px 12px;position:fixed;width:252px;z-index:5100}.color-field-row__popover:before{display:none}.floating-property-card:before{border-style:solid;content:"";height:0;position:absolute;width:0}.floating-property-card--right:before{border-color:#0000 var(--bg-elevated) #0000 #0000;border-width:8px 10px 8px 0;left:-10px;top:calc(50% - 8px)}.floating-property-card--left:before{border-color:#0000 #0000 #0000 var(--bg-elevated);border-width:8px 0 8px 10px;right:-10px;top:calc(50% - 8px)}.floating-property-card--top:before{border-color:var(--bg-elevated) #0000 #0000 #0000;border-width:10px 8px 0;bottom:-10px;left:calc(50% - 8px)}.floating-property-card--bottom:before{border-color:#0000 #0000 var(--bg-elevated) #0000;border-width:0 8px 10px;left:calc(50% - 8px);top:-10px}.floating-property-card--bottom-right:before,.floating-property-card--top-right:before{border-color:#0000 #0000 var(--bg-elevated) #0000;border-width:8px 8px 0;left:16px}.coord-tooltip .warning{color:var(--danger);font-weight:600;margin-left:6px}.empty-state{color:var(--text-muted);left:50%;pointer-events:none;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:1}.empty-state p{font-size:13px;font-weight:500;margin-top:10px}.empty-state small{color:var(--text-faint);display:block;font-size:11px;margin-top:6px;opacity:.85}.empty-state svg{opacity:.55}.screen-info{background:var(--accent-soft);border:1px solid var(--accent-ring);border-radius:var(--radius-sm);color:var(--accent);font-family:Fira Code,JetBrains Mono,monospace;font-size:11px;letter-spacing:0;margin-top:10px;padding:4px 12px;text-align:center}@media (max-width:768px){.device-preview-wrapper{min-height:280px;padding:8px 12px}.device-screen{height:280px;width:280px}.coord-tooltip{font-size:10px;left:-10px;padding:4px 8px;top:-35px}}.device-screen:before{background:#8b949e66;border-radius:50%;content:"";height:2px;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:2px;z-index:2}.flat-color-picker{background:#0000;box-sizing:border-box;font-family:Montserrat,system-ui,-apple-system,sans-serif;padding:0;width:100%}.flat-color-picker__preview{background:#0d1117;border:1px solid #2a2d3a;padding:8px}.flat-color-picker__preview,.flat-color-picker__sv{border-radius:5px;box-sizing:border-box;overflow:hidden}.flat-color-picker__sv{border:1px solid #2a2d3a;cursor:crosshair;height:140px;position:relative;touch-action:none;width:100%}.flat-color-picker__sv-white{background:linear-gradient(90deg,#fff,#0000);inset:0;pointer-events:none;position:absolute}.flat-color-picker__sv-black{background:linear-gradient(0deg,#000,#0000);inset:0;pointer-events:none;position:absolute}.flat-color-picker__sv-cursor{border:2px solid #fff;border-radius:50%;box-shadow:0 0 0 1px #0006;height:12px;pointer-events:none;position:absolute;transform:translate(-50%,-50%);width:12px}.flat-color-picker__hue{background:linear-gradient(90deg,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red);border:1px solid #2a2d3a;border-radius:999px;box-sizing:border-box;cursor:pointer;height:12px;margin-bottom:0;margin-top:8px;position:relative;touch-action:none;width:100%}.flat-color-picker__hue-cursor{background:#fff;border:2px solid #fff;border-radius:50%;box-shadow:0 0 0 1px #0006;height:14px;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:14px}.flat-color-picker__row{align-items:center;display:flex;gap:8px;margin-bottom:0;margin-top:8px}.flat-color-picker__hex{background:#1e2330;border:1px solid #2a2d3a;border-radius:5px;box-sizing:border-box;color:#f8fafc;flex:1 1;font-family:ui-monospace,monospace;font-size:12px;height:26px;padding:0 8px}.flat-color-picker__ok{background:#3b82f6;border:none;border-radius:5px;box-shadow:none;color:#fff;cursor:pointer;flex-shrink:0;font-family:Montserrat,system-ui,-apple-system,sans-serif;font-size:12px;font-weight:700;height:26px;letter-spacing:.03em;min-width:52px;padding:0 14px}.flat-color-picker__ok:hover{background:#2563eb}.alp-slider{--alp-slider-active:#00bcd4;--alp-slider-inactive:#9e9e9e;--alp-slider-track-h:5px;--alp-slider-thumb:16px;align-items:center;box-sizing:border-box;display:flex;height:var(--alp-slider-thumb);position:relative;touch-action:none;-webkit-user-select:none;user-select:none;width:100%}.alp-slider__track{background:var(--alp-slider-inactive);border:none;border-radius:999px;box-shadow:none;height:var(--alp-slider-track-h);left:0;overflow:hidden;position:absolute;right:0;top:50%;transform:translateY(-50%)}.alp-slider__fill{background:var(--alp-slider-active);border-radius:999px 0 0 999px;height:100%;pointer-events:none}.alp-slider__thumb{background:var(--alp-slider-active);border:none;border-radius:50%;box-shadow:none;cursor:grab;height:var(--alp-slider-thumb);margin-left:0;position:absolute;top:50%;transform:translate(-50%,-50%);width:var(--alp-slider-thumb);z-index:2}.alp-slider__thumb:active{cursor:grabbing}.alp-slider--disabled{opacity:.55;pointer-events:none}.screen-settings-backdrop{background:#0000;inset:0;pointer-events:auto;position:fixed;z-index:5000}.screen-settings-backdrop--panel{position:absolute}.screen-settings-modal{background:#12161ef5;border:1px solid #2a2d3a;border-radius:8px;box-shadow:0 16px 40px #00000047;box-sizing:border-box;color:#f8fafc;display:flex;flex-direction:column;font-family:Montserrat,system-ui,-apple-system,sans-serif;max-height:calc(100vh - 16px);max-width:calc(100vw - 16px);overflow:hidden;pointer-events:auto;position:fixed;width:280px;z-index:5001}.screen-settings-modal--panel{max-height:calc(100% - 8px);max-width:100%;position:absolute;right:0}.screen-settings-modal__header{align-items:center;background:#1f2430fa;border-bottom:1px solid #ffffff14;display:flex;gap:8px;justify-content:space-between;padding:10px 12px}.screen-settings-modal__title{color:#f8fafc;font-size:13px;font-weight:700;letter-spacing:.02em}.screen-settings-modal__close{align-items:center;background:#0000;border:none;border-radius:6px;color:#cbd5e1;cursor:pointer;display:flex;font-size:18px;justify-content:center;line-height:1;padding:4px 6px}.screen-settings-modal__close:hover{background:#ffffff0f;color:#f8fafc}.screen-settings-modal__body{flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;padding:10px 12px 12px}.screen-settings-modal__field{align-items:center;display:flex;gap:8px;margin-bottom:6px}.screen-settings-modal__label{color:#94a3b8;flex-shrink:0;font-size:11px;line-height:1.2;white-space:nowrap}.screen-settings-modal__swatch{border:1px solid #2a2d3a;border-radius:5px;box-sizing:border-box;display:block;flex-shrink:0;height:26px;width:26px}.screen-settings-modal__picker-wrap{box-sizing:border-box;margin-top:4px;width:100%}.block-editor{background:radial-gradient(circle at 20% 20%,#00ffaa0d,#0000 45%),radial-gradient(circle at 80% 10%,#00aaff0d,#0000 35%),#0b0d10;border:1px solid #ffffff0d;border-radius:12px;box-shadow:0 14px 35px #00000059;display:flex;flex-direction:column;gap:.75rem;height:100%;min-height:0;padding:.75rem}.blockly-toolbar{background:#ffffff08;border:1px solid #ffffff0f;border-radius:8px;color:#d8e7ff;font-size:.9rem;padding:.65rem .9rem}.blockly-wrapper{background:linear-gradient(180deg,#0c1116,#0a0f14);border:1px solid #00ff9626;border-radius:10px;height:calc(100% - 3rem);overflow:hidden;position:relative}.blockly-workspace{height:100%;width:100%}.blockly-workspace .blocklySvg{background-color:#0c1116!important}.blocklySvg{background-color:initial!important}.blocklyBlockDragSurface,.blocklyBlockDragSurface>svg,.blocklyWsDragSurface,.blocklyWsDragSurface>svg{background:#0000!important;background-color:initial!important}.blocklyBlockDragSurface>svg>g>rect,.blocklyBlockDragSurface>svg>rect{fill:#0000!important}.blocklyBlockDragSurface>svg>g{filter:none!important}.blocklyPathDark{display:none!important}.blocklyDragging{filter:none!important}.blocklyDraggable.blocklyDragging>.blocklyPath,.blocklyDraggable.blocklySelected>.blocklyPath{stroke:#f5c636!important;stroke-width:2.5px!important}.blocklyDraggable:not(.blocklyInsertionMarker)>.blocklyPathLight{stroke:#0000}.blocklyDraggable.blocklySelected>.blocklyPathLight{stroke:#f5c636!important;stroke-width:1.5px!important;stroke-opacity:1!important}.blocklyIconGroup.blocklyCommentIcon .blocklyIconPath{fill:none!important}.blocklyIconGroup.blocklyCommentIcon>svg{height:18px!important;width:18px!important}.blocklyCommentBubble,.blocklyCommentDiv,.blocklyCommentTextarea{background:#fff9c4!important;border:1px solid #f1c40f!important;border-radius:6px!important;color:#222!important}.blocklyTreeLabel{color:#e6f3ff!important}.blocklyFlyoutBackground{fill:#0f1721!important;fill-opacity:.95!important}.blocklyFlyoutLabelText{fill:#e6f3ff!important}.blocklyTrashcanFlyout{display:none!important}.blocklyTrash{cursor:pointer}.blocklyTrash image{pointer-events:visiblePainted}.blocklyScrollbarHorizontal,.blocklyScrollbarVertical{opacity:.55}@media (max-width:1100px){.blockly-workspace{height:480px}.blockly-wrapper{min-height:480px}}.block-editor .dialog-buttons .btn-cancel,.block-editor .dialog-buttons .btn-delete{align-items:center;display:inline-flex;gap:.45rem}.block-editor .btn-delete{background:#da3633;border:1px solid #f85149;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.5rem 1rem;transition:all .2s ease}.block-editor .btn-delete:hover{background:#f85149;border-color:#ff7b72}.block-editor .btn-delete:active{background:#da3633;transform:scale(.98)}.block-editor-dialog-overlay{pointer-events:auto}.coding-interface{gap:0;margin:0!important;padding:0!important;width:100%}.coding-interface,.editor-container{box-sizing:border-box;display:flex;height:100%;min-height:0;overflow:hidden}.editor-container{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:none;flex:1 1 auto;flex-direction:column;min-width:0}.output-screen{border-bottom-right-radius:0!important;border-right:none!important;border-top-right-radius:0!important;height:100%;width:100%}.output-screen,.output-wrapper{margin-right:0!important;padding-right:0!important}.output-wrapper{box-sizing:border-box;flex:1 1 auto}.editor-header{align-items:center;background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;flex-shrink:0;justify-content:space-between;min-height:60px;padding:12px 16px}.editor-header,.editor-title{color:var(--text-primary);font-weight:500}.editor-title{font-size:14px;letter-spacing:0}.device-controls,.editor-controls{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.device-controls{max-width:min(100%,760px)}.device-target-toggle{align-items:center;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);display:inline-flex;gap:2px;padding:3px}.device-target-btn{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:500;letter-spacing:0;min-width:64px;padding:6px 12px;transition:background .15s ease,color .15s ease}.device-target-btn:hover{color:var(--text-primary)}.device-target-btn.active{background:var(--accent);color:#fff}.device-select{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:12px;min-width:160px;padding:7px 12px;transition:border-color .15s ease}.device-select:focus,.device-select:hover{border-color:var(--accent);outline:none}.device-baud-select{min-width:110px}.device-status-pill{border-radius:var(--radius-sm);font-size:11px;font-weight:500;letter-spacing:0;padding:5px 10px}.device-status-pill.connected{background:var(--success-soft);border:1px solid #10b98152;color:var(--success)}.device-status-pill.idle{background:var(--accent-soft);border:1px solid var(--accent-ring);color:var(--accent)}.device-message{color:var(--text-muted);font-size:11px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mode-toggle{align-items:center;display:flex;gap:8px;margin-right:4px}.mode-toggle-label{color:var(--text-muted);font-size:11px;font-weight:500;letter-spacing:0;text-transform:uppercase}.mode-toggle-options{align-items:center;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:none;display:inline-flex;gap:2px;padding:3px}.mode-toggle-btn{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:500;letter-spacing:0;min-width:72px;padding:6px 14px;transition:background .15s ease,color .15s ease}.mode-toggle-btn:hover{color:var(--text-primary)}.mode-toggle-btn.active{background:var(--accent);box-shadow:none;color:#fff}.mode-toggle-btn:focus-visible{outline:2px solid var(--accent-ring);outline-offset:2px}.control-btn{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:12px;font-weight:500;letter-spacing:.4px;min-width:80px;padding:7px 16px;text-transform:uppercase;transition:background .15s ease,border-color .15s ease,color .15s ease}.control-btn:hover{border-color:var(--border-strong)}.control-btn.build-send{background:#206bb6;background:hsl(var(--theme-hue,210) 70% 42%);color:#fff}.control-btn.build-send:hover:not(:disabled){background:#1c5c9c;background:hsl(var(--theme-hue,210) 70% 36%)}.control-btn.build-send:disabled{cursor:not-allowed;opacity:.45}.control-btn.run{background:var(--success)!important;border:1px solid var(--success)!important;color:#fff}.control-btn.run:hover{background:var(--success-hover)!important;border-color:var(--success-hover)!important}.control-btn.clear{background:#0000!important;border:1px solid var(--border-subtle)!important;color:var(--danger)}.control-btn.clear:hover{background:#ef444414!important;border-color:var(--danger)!important}.control-btn.save{background:#0000!important;border:1px solid var(--border-subtle)!important;color:var(--accent)}.control-btn.save:hover{background:var(--accent-soft)!important;border-color:var(--accent)!important}.control-btn.connect{background:var(--accent)!important;border:1px solid var(--accent)!important;color:#fff}.control-btn.connect:hover{background:var(--accent-hover)!important;border-color:var(--accent-hover)!important}.control-btn.neutral{background:#0000!important;border:1px solid var(--border-subtle)!important;color:var(--text-muted)}.control-btn.neutral:hover{border-color:var(--accent)!important;color:var(--text-primary)}.output-wrapper{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:none;display:flex;flex-direction:column;height:100%;min-height:0;min-width:0;overflow:hidden;position:relative}.output-screen{display:flex;flex:1 1;flex-direction:column;min-height:0}.block-editor-area{flex:1 1 auto;height:100%;min-height:0;overflow:hidden}.monaco-editor-container{box-sizing:border-box;flex:1 1;height:100%;min-height:0;position:relative;width:100%}.code-editor{background:#1c1b2c;border:none;color:#f0f0f0;flex:1 1;font-family:Courier New,monospace;font-size:14px;line-height:1.5;outline:none;padding:1rem;resize:none}.resizer{background:var(--bg-base);cursor:col-resize;flex-shrink:0;position:relative;transition:background .15s ease;width:6px;z-index:5}.resizer:hover{background:var(--accent-soft)}.resizer:after{background:var(--border-subtle);content:"";height:100%;left:50%;opacity:1;position:absolute;top:0;transform:translateX(-50%);transition:background .15s ease;width:1px}.resizer:hover:after{background:var(--accent)}body.is-pane-resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}body.is-pane-resizing .resizer{background:var(--accent-soft);transition:none}body.is-pane-resizing .resizer:after{background:var(--accent)}.circular-display{align-items:center;background:radial-gradient(circle,var(--bg-base) 0,var(--bg-surface) 100%);border:1px solid var(--border-subtle);border-radius:50%;display:flex;flex:1 1;justify-content:center;overflow:hidden;position:relative}.circular-display:before{animation:rotate 4s linear infinite;background:conic-gradient(#0000,var(--accent),#0000 30%);content:"";height:200%;left:-50%;opacity:.4;position:absolute;top:-50%;width:200%}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.circular-inner{align-items:center;background:var(--bg-surface);border-radius:50%;display:flex;flex-direction:column;gap:.5rem;height:90%;justify-content:center;position:relative;width:90%;z-index:2}.circular-text{color:var(--text-primary);font-size:1.4rem;font-weight:600}.circular-status{color:var(--text-muted);font-size:12px}.console-line{margin-bottom:.25rem}@media (max-width:1024px){.coding-interface{flex-direction:column;gap:1rem}}@media (max-width:768px){.coding-interface{flex-direction:column}.editor-controls{flex-wrap:wrap;justify-content:center}.control-btn{font-size:.78rem;min-width:70px;padding:6px 12px}.mode-toggle{justify-content:center;margin-bottom:8px;order:-1;width:100%}.mode-toggle-label{display:none}.mode-toggle-options{width:min(100%,320px)}.mode-toggle-btn{flex:1 1;min-width:0}}.coding-interface>div{margin:0;padding:0}.component-sidebar{background:var(--bg-surface);border-left:1px solid var(--border-subtle);box-shadow:none;box-sizing:border-box;display:flex;flex-direction:column;height:100%;max-width:100px;min-width:100px;overflow-x:hidden;overflow-y:auto;padding:10px 6px;position:relative;width:100px;z-index:10}.component-sidebar-container{align-items:center;display:flex;flex:1 1;flex-direction:column;flex-wrap:nowrap;gap:6px;width:100%}.component-sidebar-item{align-items:center;background:#0000;border:1px solid #0000;border-radius:14px;box-sizing:border-box;color:var(--text-primary);cursor:pointer;display:flex;flex-direction:column;gap:4px;height:64px;justify-content:center;min-width:84px;padding:6px 4px;transition:background .15s ease,color .15s ease;width:84px}.component-sidebar-item:hover{background:var(--bg-elevated)}.component-sidebar-item.active{background:var(--accent-soft);box-shadow:none;color:var(--accent)}.component-sidebar-item.disabled{cursor:not-allowed;filter:grayscale(100%);opacity:.35}.component-sidebar-item.disabled:hover{background:#0000}.component-icon{align-items:center;color:inherit;display:flex;flex-shrink:0;justify-content:center;opacity:.95}.component-icon svg{filter:none;height:18px;width:18px}.component-name{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:inherit;font-size:9px;font-weight:500;letter-spacing:.02em;line-height:1.1;overflow:visible;text-align:center;text-overflow:clip;text-rendering:optimizeLegibility;text-shadow:none;white-space:nowrap;width:100%}.component-sidebar::-webkit-scrollbar{width:4px}.component-sidebar::-webkit-scrollbar-track{background:#0000}.component-sidebar::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:2px}.component-sidebar::-webkit-scrollbar-thumb:hover{background:var(--accent)}@media (max-width:768px){.component-sidebar{max-width:85px;min-width:85px;padding:8px 4px;width:85px}.component-sidebar-item{gap:4px;height:60px;min-width:72px;padding:6px 2px;width:72px}.component-name{font-size:9px}.component-icon svg{height:16px;width:16px}}.bl-rail{align-self:stretch;border-right:1px solid #2a3140;border-right:1px solid var(--border-subtle,#2a3140);flex:0 0 auto;height:100%;min-width:192px;position:relative;width:192px;z-index:60}.bl-rail,.bl-rail-inner{background:#161b22;background:var(--bg-surface,#161b22);display:flex;flex-direction:column}.bl-rail-inner{flex:1 1 auto;gap:14px;overflow-y:auto;padding:16px 12px 20px}.search-bar-inner{position:relative;width:100%}.bl-rail-search-icon{color:#8b949e;color:var(--text-muted,#8b949e);opacity:.85;pointer-events:none;position:absolute;right:14px;top:50%;transform:translateY(-50%);z-index:1}.bl-rail .search-input{padding:12px 38px 12px 14px;width:100%}.bl-rail-row{display:flex;flex-direction:column;gap:10px;overflow:visible;position:relative}.bl-rail-item{border:1px solid #0000;border-radius:18px;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:12px;padding:18px 14px;transition:background .15s ease,color .15s ease,border-color .15s ease,box-shadow .15s ease;width:100%}.bl-rail-item,.bl-rail-item .bl-rail-icon{align-items:center;background:#0000;color:#9aa6b2;color:var(--text-secondary,#9aa6b2);justify-content:center}.bl-rail-item .bl-rail-icon{border:1px solid #0000;border-radius:16px;display:inline-flex;height:56px;width:56px}.bl-rail-label{color:inherit;font-size:15px;font-weight:600;letter-spacing:0;line-height:1.2;text-align:center}.bl-rail-item:hover{background:#94a3b80d;border-color:#94a3b859;box-shadow:inset 0 0 0 1px #94a3b814;color:#e6edf3;color:var(--text-primary,#e6edf3)}.bl-rail-item:hover .bl-rail-icon{background:#94a3b814;border-color:#94a3b838;color:#e6edf3;color:var(--text-primary,#e6edf3)}.bl-rail-item.is-expanded,.bl-rail-item:focus-visible{background:#1e2432;background:var(--bg-elevated,#1e2432);border-color:#2a3140;border-color:var(--border-subtle,#2a3140);color:#e6edf3;color:var(--text-primary,#e6edf3);outline:none}.bl-rail-item.is-expanded .bl-rail-icon,.bl-rail-item:focus-visible .bl-rail-icon{background:#3b82f61a;border-color:#3b82f64d;color:#3b82f6;color:var(--accent,#3b82f6)}.bl-rail-item.has-active{color:#e6edf3;color:var(--text-primary,#e6edf3)}.bl-rail-item.has-active .bl-rail-icon{background:#3b82f61f;border-color:#3b82f666;color:#3b82f6;color:var(--accent,#3b82f6)}.bl-rail-panel{grid-gap:8px;animation:bl-rail-panel-fade .12s ease-out;border-left:1px solid #2a3140;border-left:1px solid var(--border-subtle,#2a3140);display:grid;gap:8px;grid-template-columns:1fr;margin-left:10px;max-width:none;min-width:0;padding:2px 0 6px 14px;width:100%}@keyframes bl-rail-panel-fade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.bl-rail-chip{background:#1e2432;background:var(--bg-elevated,#1e2432);border:1px solid #0000;border-radius:12px;color:#9aa6b2;color:var(--text-secondary,#9aa6b2);cursor:pointer;font-family:inherit;font-size:12px;font-weight:500;letter-spacing:.02em;line-height:1.25;padding:11px 12px;text-align:left;transition:background .15s ease,color .15s ease,border-color .15s ease;white-space:normal;width:100%}.bl-rail-chip:hover{background:#3b82f61f;border-color:#3b82f64d;color:#e6edf3;color:var(--text-primary,#e6edf3)}.bl-rail-chip.active{background:#3b82f62e;border-color:#3b82f6;border-color:var(--accent,#3b82f6);color:#3b82f6;color:var(--accent,#3b82f6)}@media (max-width:1200px){.bl-rail{min-width:172px;width:172px}.bl-rail-item{padding:16px 12px}}@media (max-width:900px){.bl-rail{min-width:148px;width:148px}.bl-rail .search-input{padding-right:34px}.bl-rail-search-icon{right:12px}.bl-rail-item{border-radius:16px;gap:10px;padding:14px 10px}.bl-rail-item .bl-rail-icon{border-radius:14px;height:48px;width:48px}.bl-rail-label{font-size:13px}.bl-rail-panel{margin-left:8px;padding-left:10px}.bl-rail-chip{font-size:11px;padding:10px}}.device-popup-overlay{align-items:center;background:#05080eb8;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:2147483647}.device-popup{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:0 24px 80px #0000006b;color:var(--text-primary);padding:28px;width:min(760px,calc(100% - 40px))}.device-popup-heading{margin-bottom:20px}.device-popup h2{color:var(--text-primary);font-size:28px;font-weight:700;letter-spacing:-.03em;margin:0}.device-popup-heading p{color:var(--text-muted);font-size:14px;line-height:1.5;margin:8px 0 0}.device-row{margin:16px 0}.device-row label{color:var(--text-muted);display:block;font-size:11px;font-weight:500;letter-spacing:.04em;margin-bottom:8px;text-transform:uppercase}.device-settings-tabs{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);display:inline-flex;gap:4px;margin:6px 0 4px;padding:4px}.device-settings-tab{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:13px;font-weight:600;padding:10px 16px;transition:background .15s ease,color .15s ease}.device-settings-tab.active{background:#fff;color:#0d1117}.device-settings-tab--connect{background:var(--success);color:#fff}.device-settings-tab--connect.active,.device-settings-tab--connect:hover{background:var(--success-hover);color:#fff}.device-settings-tab--connect.active{box-shadow:0 0 0 2px #10b98159}.device-nexus-connect-row{display:flex;justify-content:flex-end;margin-top:16px}.device-btn--connect{background:var(--success);border:1px solid var(--success);color:#fff;min-width:140px}.device-btn--connect:hover:not(:disabled){background:var(--success-hover);border-color:var(--success-hover)}.device-settings-panel{background:linear-gradient(180deg,#ffffff05,#fff0);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-top:14px;padding:18px}.device-row input,.device-row select{appearance:none;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:13px;padding:9px 12px;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.device-row input:focus,.device-row select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring);outline:none}.device-row--split{grid-gap:16px;align-items:end;display:grid;gap:16px;grid-template-columns:minmax(0,1fr) auto}.device-popup-inline-actions{align-items:center;display:flex;gap:10px}.device-status-row{align-items:center;color:var(--text-muted);display:flex;font-size:13px;gap:12px;justify-content:space-between;margin-top:4px}.status-chip{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:11px;font-weight:500;padding:5px 12px}.status-chip.connected{background:var(--success-soft);border-color:#10b98152;color:var(--success)}.status-chip.disconnected{background:#ef44441f;border-color:#ef444447;color:var(--danger)}.status-chip.idle{background:var(--accent-soft);border-color:var(--accent-ring);color:var(--accent)}.device-support-text{color:var(--text-muted);font-size:12px;line-height:1.5;margin-top:12px}.device-platform-toggle{display:inline-flex;flex-wrap:wrap;gap:6px}.device-platform-btn{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;font-size:13px;font-weight:600;min-width:108px;padding:10px 14px;transition:border-color .15s ease,background .15s ease,color .15s ease}.device-platform-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--text-primary)}.device-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:28px}.device-btn{border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;letter-spacing:.04em;min-width:112px;padding:10px 18px;text-transform:uppercase;transition:background .15s ease,border-color .15s ease,color .15s ease}.device-btn:disabled{cursor:not-allowed;opacity:.58}.device-btn--primary{background:var(--accent);border-color:var(--accent);color:#fff}.device-btn--primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.device-btn--danger{background:#ef44441f;border-color:#ef444452;color:var(--danger)}.device-btn--danger:hover:not(:disabled){background:#ef44442e;border-color:#ef444470}.device-btn--ghost{background:#0000;color:var(--text-muted)}.device-btn--ghost:hover:not(:disabled){background:var(--bg-elevated);color:var(--text-primary)}@media (max-width:720px){.device-popup{padding:22px;width:min(100%,calc(100% - 24px))}.device-popup h2{font-size:22px}.device-row--split{grid-template-columns:1fr}.device-actions,.device-platform-toggle,.device-popup-inline-actions{width:100%}.device-actions,.device-popup-inline-actions{align-items:stretch;flex-direction:column}.device-btn,.device-platform-btn{width:100%}}.empty-text-indicator{align-items:center;color:#aaa;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:16px;font-weight:500;justify-content:center;line-height:1;margin-left:6px;margin-right:2px;transition:color .15s ease;-webkit-user-select:none;user-select:none}.empty-text-indicator:hover{color:#fff}:root{--theme-hue:220;--app-zoom:0.75;--bg-base:#0d1117;--bg-surface:#161b22;--bg-surface-2:#1c2128;--bg-elevated:#1e2432;--border-subtle:#2a3140;--border-strong:#30363d;--text-primary:#e6edf3;--text-muted:#8b949e;--text-faint:#6e7681;--text-secondary:#9aa6b2;--accent:#3b82f6;--accent-hover:#2563eb;--accent-soft:#3b82f624;--accent-ring:#3b82f652;--accent-contrast:#0d1117;--accent-gradient-start:#60a5fa;--accent-gradient-end:#2563eb;--accent-shadow:#2563eb47;--success:#10b981;--success-hover:#059669;--success-soft:#10b98124;--danger:#ef4444;--warning:#f59e0b;--radius-sm:6px;--radius-md:8px;--radius-lg:12px}html{background:#0d1117;background:var(--bg-base);height:100%;overflow:hidden}*{box-sizing:border-box;margin:0;padding:0}body{zoom:.75;zoom:var(--app-zoom);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0d1117;background:var(--bg-base);color:#e6edf3;color:var(--text-primary);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:13px;height:133.33333vh;height:calc(100vh/var(--app-zoom));overflow:hidden;width:133.33333vw;width:calc(100vw/var(--app-zoom))}#root,.App,.glass{height:100%;overflow:hidden;width:100%}.App,.glass{display:flex;flex-direction:column}.layout{flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.header,.layout{display:flex;width:100%}.header{background:#161b22;background:var(--bg-surface);border-bottom:1px solid #2a3140;border-bottom:1px solid var(--border-subtle);box-shadow:none;flex-direction:column;gap:12px;padding:14px 24px;position:relative;z-index:100}.header-top{align-items:center;display:flex;justify-content:space-between;width:100%}.company-name{color:#e6edf3;color:var(--text-primary);font-size:2rem;font-weight:600;letter-spacing:0;white-space:nowrap}.header-bottom{align-items:center;display:flex;justify-content:flex-end;padding-right:2rem;width:100%}.search-bar{max-width:400px;width:100%}.search-input{border:1px solid #2a3140;border:1px solid var(--border-subtle);border-radius:8px;border-radius:var(--radius-md);box-shadow:none;color:#e6edf3;color:var(--text-primary);font-family:inherit;font-size:13px;outline:none;padding:8px 12px 8px 36px;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.search-input,.search-input:focus{background:#1e2432;background:var(--bg-elevated)}.search-input:focus{border-color:#3b82f6;border-color:var(--accent);box-shadow:0 0 0 3px #3b82f652;box-shadow:0 0 0 3px var(--accent-ring)}.search-input::placeholder{color:#6e7681;color:var(--text-faint)}.search-wrapper{position:relative;width:100%}.search-icon{color:#8b949e;color:var(--text-muted);opacity:.7;pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.main-content{display:flex;flex:1 1;min-height:0;overflow-x:hidden;transition:all .3s ease;width:100%}.main-content.sidebar-open{margin-left:0;width:100%}.coding-area{background:#0d1117;background:var(--bg-base);display:flex;flex:1 1;flex-direction:column;min-height:0;min-width:0;padding:14px;width:100%}.bottom-controls{align-items:center;bottom:20px;display:flex;gap:1rem;margin-left:0;z-index:40}.python-switch-container{align-items:center;background:#1e2432;background:var(--bg-elevated);border:1px solid #2a3140;border:1px solid var(--border-subtle);border-radius:8px;border-radius:var(--radius-md);display:flex;gap:10px;padding:8px 14px}.switch-label{color:#8b949e;color:var(--text-muted);font-size:12px;font-weight:500;letter-spacing:0}.python-switch{display:inline-block;height:24px;position:relative;width:44px}.python-switch input{height:0;opacity:0;width:0}.python-switch .slider{background:#1c2128;background:var(--bg-surface-2);border:1px solid #2a3140;border:1px solid var(--border-subtle);border-radius:999px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.2s ease}.python-switch .slider:before{background:#8b949e;background:var(--text-muted);border-radius:50%;bottom:2px;box-shadow:none;content:"";height:18px;left:2px;position:absolute;transition:.2s ease;width:18px}.python-switch input:checked+.slider{background:#3b82f6;background:var(--accent);border-color:#3b82f6;border-color:var(--accent)}.python-switch input:checked+.slider:before{background:#fff;transform:translateX(20px)}.control-btn-download{background:#3b82f6;background:var(--accent);border:1px solid #3b82f6;border:1px solid var(--accent);border-radius:8px;border-radius:var(--radius-md);box-shadow:none;color:#fff;cursor:pointer;font-family:inherit;font-size:12px;font-weight:500;letter-spacing:.4px;padding:8px 16px;text-transform:uppercase;transition:background .15s ease,border-color .15s ease}.control-btn-download:hover{background:#2563eb;background:var(--accent-hover);border-color:#2563eb;border-color:var(--accent-hover);box-shadow:none;transform:none}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0d1117;background:var(--bg-base)}::-webkit-scrollbar-thumb{background:#30363d;background:var(--border-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#3b82f6;background:var(--accent)}@media (max-width:1200px){.company-name{font-size:2rem}.component-sidebar{width:220px}}@media (max-width:1024px){.header{padding:1rem}.company-name{font-size:1.8rem}.component-sidebar{width:200px}.component-sidebar-item{padding:.8rem}}@media (max-width:768px){.header{gap:.8rem;padding:.8rem}.company-name{font-size:1.6rem}.search-input{font-size:.9rem;padding:.6rem .8rem}.main-content{flex-direction:column}.component-sidebar{border-bottom:1px solid #2a3140;border-bottom:1px solid var(--border-subtle);border-right:none;height:auto;width:100%}.component-sidebar-container{flex-direction:row;overflow-x:auto;padding-bottom:.5rem}.component-sidebar-item{flex-direction:column;min-width:120px;text-align:center}.bottom-controls{align-items:flex-start;bottom:10px;flex-direction:column;left:10px}}@media (max-width:480px){.header{padding:.6rem}.company-name{font-size:1.4rem}.search-bar{max-width:200px}.component-sidebar-item{min-width:100px;padding:.6rem}.component-name{font-size:.9rem}.python-switch-container{padding:.6rem 1rem}}
/*# sourceMappingURL=main.5320162a.css.map*/