:root{--bg: #07070f;--panel: #0c0c18;--panel2: #10101e;--panel3: #161628;--panel4: #1c1c30;--border: #1a1a2e;--border2: #252540;--border3: #303050;--text: #dde4f0;--text2: #8892a4;--text3: #4a5268;--text4: #2e3548;--accent: #5b4ff5;--accent2: #7c72ff;--accent3: #a09bff;--green: #0fb87a;--green2: #1de9a0;--red: #f04058;--red2: #ff6080;--orange: #f57c20;--cyan: #20c8e8;--cyan2: #50dff5;--yellow: #f5b820;--purple: #9060f0;--font-ui: "DM Sans", "Segoe UI", system-ui, sans-serif;--font-head: "Space Grotesk", "DM Sans", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--r-xs: 3px;--r-sm: 5px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--ease: cubic-bezier(.2, 0, 0, 1);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--topbar-h: 46px;--palette-w: 220px;--props-w: 280px;--screens-h: 36px;--transition: .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-ui);font-size:12px;overflow:hidden;-webkit-font-smoothing:antialiased}input,select,textarea,button{font-family:inherit;font-size:11px;color:var(--text)}input[type=number],input[type=text]{background:var(--panel2);border:1px solid var(--border);color:var(--text);padding:4px 7px;border-radius:var(--r-sm);outline:none;width:100%;transition:border-color .15s var(--ease)}input[type=number]:focus,input[type=text]:focus,textarea:focus,select:focus{border-color:var(--accent2);box-shadow:0 0 0 2px #5b4ff526;outline:none}select{background:var(--panel2);border:1px solid var(--border);padding:4px 24px 4px 7px;border-radius:var(--r-sm);outline:none;cursor:pointer;width:100%;transition:border-color .15s var(--ease);appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%234a5268' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}#app{display:flex;flex-direction:column;height:100vh;width:100vw}.editor-main{display:flex;flex:1;overflow:hidden}.editor-center{flex:1;display:flex;flex-direction:column;min-width:0}.canvas-container{flex:1;position:relative;overflow:hidden;background:var(--bg)}.canvas-container canvas{display:block;width:100%;height:100%}.editor-topbar{height:var(--topbar-h);background:linear-gradient(180deg,#0e0e1c,#0c0c18);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:2px;padding:0 10px;flex-shrink:0;overflow-x:auto;white-space:nowrap;z-index:10}.editor-topbar::-webkit-scrollbar{display:none}.canvas-toolbar{display:flex;align-items:center;padding:4px 10px;background:#0c0c14b3;border-bottom:1px solid var(--border);flex-shrink:0}.canvas-search-wrap{display:flex;align-items:center;gap:6px;flex:1;max-width:320px;padding:0 8px}.canvas-search-icon{color:var(--text2);flex-shrink:0}.canvas-search-wrap input{flex:1;background:var(--panel2);border:1px solid var(--border);color:var(--text);padding:5px 10px;border-radius:var(--r-sm);font-size:12px;outline:none}.canvas-search-wrap input:focus{border-color:var(--accent2);box-shadow:0 0 0 2px #5b4ff526}.preview-modal{position:fixed;inset:0;z-index:9999;background:#000000d9;display:flex;flex-direction:column;align-items:center;justify-content:center}.preview-modal-header{display:flex;align-items:center;justify-content:space-between;width:90vw;max-width:1200px;padding:12px 0;color:var(--text);font-weight:600;font-size:14px}.preview-modal-close{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:var(--text);padding:6px 16px;border-radius:6px;cursor:pointer;font-size:13px;transition:background .15s}.preview-modal-close:hover{background:#fff3}.preview-modal-body{background:var(--bg);border:2px solid var(--border);border-radius:8px;padding:16px;overflow:auto;max-width:90vw;max-height:80vh}.preview-modal-body canvas{display:block}.topbar-brand{display:flex;align-items:center;gap:7px;margin-right:4px;flex-shrink:0}.brand-icon{color:var(--accent2);display:flex;align-items:center}.brand-text{font-family:var(--font-head);font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.3px;line-height:1}.brand-text span{color:var(--accent2)}.brand-version{font-family:var(--font-mono);font-size:9px;color:var(--accent);background:#5b4ff526;border:1px solid rgba(91,79,245,.25);padding:1px 5px;border-radius:3px;line-height:1.4}.topbar-divider{width:1px;height:18px;background:var(--border2);margin:0 5px;flex-shrink:0}.topbar-group{display:flex;align-items:center;gap:2px;flex-shrink:0}.tb-btn{display:inline-flex;align-items:center;gap:5px;background:transparent;border:1px solid transparent;color:var(--text2);padding:5px 9px;border-radius:var(--r-sm);cursor:pointer;font-size:11px;font-family:var(--font-ui);font-weight:500;white-space:nowrap;transition:all .13s var(--ease);flex-shrink:0;line-height:1}.tb-btn:hover{background:var(--panel3);border-color:var(--border2);color:var(--text)}.tb-btn svg{opacity:.7;flex-shrink:0}.tb-btn:hover svg{opacity:1}.tb-btn.tb-disabled{opacity:.3;pointer-events:none}.tb-toggle.active-btn,.tb-btn.active-btn,.tb-btn.tb-active{background:#5b4ff52e;border-color:#5b4ff566;color:var(--accent3)}.tb-btn.tb-accent-cyan{color:var(--cyan);border-color:#20c8e833}.tb-btn.tb-accent-cyan:hover{background:#20c8e81a;border-color:#20c8e866}.tb-btn.tb-accent-green{color:var(--green);border-color:#0fb87a33}.tb-btn.tb-accent-green:hover{background:#0fb87a1a;border-color:#0fb87a66}.tb-btn.tb-wifi{color:var(--cyan);border-color:#20c8e840}.tb-btn.tb-wifi:hover{background:#20c8e81a;border-color:#20c8e880}.tb-btn.tb-export{color:var(--accent2);background:#5b4ff51f;border-color:#5b4ff559;font-weight:600}.tb-btn.tb-export:hover{background:#5b4ff538;border-color:#5b4ff599;color:#fff}.tb-btn.tb-icon{padding:5px 7px}.tb-btn.tb-new-project{color:var(--green, #0fb87a);border-color:#0fb87a40;font-weight:600}.tb-btn.tb-new-project:hover{background:#0fb87a1a;border-color:#0fb87a80;color:var(--green2, #1de9a0)}.tb-size-group{display:flex;align-items:center;gap:4px;flex-shrink:0}.tb-label{font-size:10px;color:var(--text3);font-family:var(--font-mono)}.tb-size-group input{width:54px;background:var(--panel2);border:1px solid var(--border);color:var(--text);padding:4px 6px;border-radius:var(--r-sm);font-family:var(--font-mono);font-size:11px;text-align:center}.tb-input-wrap{display:flex;align-items:center;background:var(--panel2);border:1px solid var(--border);border-radius:var(--r-sm);padding:0 6px 0 2px;gap:2px}.tb-input-wrap input{width:36px;background:transparent;border:none;text-align:center;font-family:var(--font-mono);padding:4px 2px}.tb-input-unit{font-size:9px;color:var(--text3);font-family:var(--font-mono)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:2px;flex-shrink:0}#lcd-badge{font-family:var(--font-mono);font-size:10px;background:#20c8e814;border:1px solid rgba(32,200,232,.2);color:var(--cyan);padding:3px 8px;border-radius:var(--r-xs);white-space:nowrap;flex-shrink:0}.tb-zoom-group{display:flex;align-items:center;gap:1px;background:var(--panel2);border:1px solid var(--border);border-radius:var(--r-md);padding:1px}.tb-zoom-group .tb-btn{border:none;border-radius:var(--r-sm);padding:4px 6px}.tb-zoom-group .tb-btn:hover{background:var(--panel3);border-color:transparent}.tb-zoom-label{font-size:11px;font-family:var(--font-mono);color:var(--accent3);min-width:42px;text-align:center;padding:3px 4px;user-select:none;cursor:default}.tb-sep{width:1px;height:18px;background:var(--border2);margin:0 4px}.widget-palette{width:var(--palette-w);background:linear-gradient(180deg,#0e0e1f,#09091a);border-right:1px solid rgba(91,79,245,.15);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.wp-search{padding:8px 8px 6px;border-bottom:1px solid rgba(91,79,245,.12);flex-shrink:0}.wp-search input{width:100%;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:7px 10px;color:#cbd5e1;font-size:11px;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit;box-sizing:border-box}.wp-search input:focus{border-color:#5b4ff573;box-shadow:0 0 0 2px #5b4ff51f}.wp-search input::placeholder{color:#4b5563}.wp-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 0 8px;scrollbar-width:thin;scrollbar-color:rgba(91,79,245,.25) transparent}.wp-list::-webkit-scrollbar{width:4px}.wp-list::-webkit-scrollbar-track{background:transparent}.wp-list::-webkit-scrollbar-thumb{background:#5b4ff54d;border-radius:4px}.wp-list::-webkit-scrollbar-thumb:hover{background:#5b4ff58c}.wp-category{margin-bottom:2px}.wp-cat-header{display:flex;align-items:center;gap:8px;padding:7px 10px;margin:3px 6px 1px;border-radius:7px;border:1px solid transparent;position:sticky;top:3px;z-index:3;background:transparent;color:#94a3b8;cursor:pointer;user-select:none;transition:background-color .15s,border-color .15s,transform .12s,box-shadow .15s}.wp-cat-header:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:2px;height:60%;border-radius:2px;background:var(--cat-color, #818cf8);box-shadow:0 0 6px var(--cat-color, #818cf8);transition:transform .15s}.wp-cat-header:hover{background-color:#ffffff0d;border-color:#ffffff0f;transform:translate(2px);box-shadow:0 2px 12px #0000004d,-2px 0 color-mix(in srgb,var(--cat-color, #818cf8) 55%,transparent)}.wp-cat-header:hover:before{transform:translateY(-50%) scaleY(1)}.wp-cat-icon{font-size:13px;line-height:1;flex-shrink:0;filter:drop-shadow(0 0 4px color-mix(in srgb,var(--cat-color, #818cf8) 70%,transparent));transition:filter .15s,transform .15s}.wp-cat-header:hover .wp-cat-icon{filter:drop-shadow(0 0 8px color-mix(in srgb,var(--cat-color, #818cf8) 95%,white));transform:scale(1.18)}.wp-cat-label{flex:1;font-size:10px;font-weight:800;letter-spacing:1.3px;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:linear-gradient(110deg,color-mix(in srgb,var(--cat-color, #818cf8) 70%,#94a3b8) 0%,color-mix(in srgb,var(--cat-color, #818cf8) 95%,white) 50%,var(--cat-color, #818cf8) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.wp-cat-count{font-size:9px;background:color-mix(in srgb,var(--cat-color, #818cf8) 12%,transparent);border:1px solid color-mix(in srgb,var(--cat-color, #818cf8) 28%,transparent);color:var(--cat-color, #818cf8);padding:1px 5px;border-radius:4px;font-weight:600;margin-left:auto}.wp-cat-arrow{font-size:11px;color:#475569;opacity:.7;transition:transform .22s cubic-bezier(.34,1.56,.64,1),opacity .15s,color .15s;flex-shrink:0}.wp-cat-header:hover .wp-cat-arrow{color:var(--cat-color, #818cf8);opacity:1}.wp-collapsed .wp-cat-arrow{transform:rotate(-90deg)}.wp-collapsed .wp-grid{display:none}.wp-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px;padding:4px 8px 6px}.wp-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 4px 7px;border:1px solid rgba(255,255,255,.06);border-radius:8px;cursor:grab;background:#ffffff08;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);transition:border-color .15s,background .15s,transform .12s,box-shadow .15s;text-align:center;user-select:none;position:relative}.wp-item:hover{border-color:color-mix(in srgb,var(--item-color, #818cf8) 45%,transparent);background:color-mix(in srgb,var(--item-color, #818cf8) 9%,rgba(10,10,22,.8));transform:translateY(-2px) scale(1.03);box-shadow:0 4px 16px #00000073,0 0 0 1px color-mix(in srgb,var(--item-color, #818cf8) 20%,transparent) inset,0 0 12px color-mix(in srgb,var(--item-color, #818cf8) 15%,transparent)}.wp-item:active,.wp-item.wp-dragging{border-color:var(--item-color, #818cf8);background:color-mix(in srgb,var(--item-color, #818cf8) 16%,rgba(10,10,22,.9));cursor:grabbing;transform:scale(.96);box-shadow:0 2px 8px #0009}.wp-item-icon{font-size:18px;line-height:1;display:block;filter:drop-shadow(0 0 3px color-mix(in srgb,var(--item-color, #818cf8) 50%,transparent));transition:filter .15s,transform .15s}.wp-item:hover .wp-item-icon{filter:drop-shadow(0 0 7px color-mix(in srgb,var(--item-color, #818cf8) 85%,white));transform:scale(1.12)}.wp-item-icon svg{width:18px;height:18px}.wp-item-name{font-size:9px;color:#64748b;text-align:center;line-height:1.2;word-break:break-word;transition:color .12s}.wp-item:hover .wp-item-name{color:#94a3b8}.wp-empty{padding:20px;text-align:center;color:#4b5563;font-size:12px}.props-panel{width:var(--props-w);background:var(--panel);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0}.props-panel::-webkit-scrollbar{width:3px}.props-panel::-webkit-scrollbar-track{background:transparent}.props-panel::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.pp-header{display:flex;align-items:center;gap:10px;padding:12px;border-bottom:1px solid var(--border)}.pp-delete-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#f0405826;border:1px solid rgba(240,64,88,.3);border-radius:var(--r-md);color:var(--red);font-size:14px;cursor:pointer;transition:all var(--transition);flex-shrink:0}.pp-delete-btn:hover{background:#f040584d;border-color:var(--red);transform:scale(1.1)}.pp-widget-badge{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#5b4ff51f;border-radius:var(--r-md);color:var(--accent2)}.pp-widget-badge svg{width:18px;height:18px}.pp-title{font-weight:600;font-size:13px;color:var(--text)}.pp-subtitle{font-size:10px;font-family:var(--font-mono);color:var(--text3);margin-top:1px}.pp-section{border-bottom:1px solid var(--border)}.pp-section-title{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;user-select:none}.pp-section-title:hover{color:var(--text)}.pp-section-toggle{font-size:13px;color:var(--text2, #8888aa);opacity:.8;transition:transform var(--transition),color .15s;margin-left:auto;line-height:1}.pp-section-title:hover .pp-section-toggle{color:var(--accent, #8b7ff5);opacity:1}.pp-collapsed .pp-section-toggle{transform:rotate(-90deg)}.pp-collapsed .pp-row{display:none}.pp-row{display:flex;align-items:center;justify-content:space-between;padding:4px 12px;gap:8px;min-height:30px}.pp-row label{font-size:11px;color:var(--text3);min-width:70px;flex-shrink:0}.pp-row input[type=number],.pp-row input[type=text],.pp-row select{flex:1;min-width:0;background:var(--panel2);border:1px solid var(--border);border-radius:var(--r-sm);padding:4px 8px;color:var(--text);font-size:12px;font-family:var(--font-mono);outline:none;transition:border-color var(--transition)}.pp-row input:focus,.pp-row select:focus,.pp-row textarea:focus{border-color:var(--accent2);box-shadow:0 0 0 2px #5b4ff526}.pp-row textarea{flex:1;min-width:0;background:var(--panel2);border:1px solid var(--border);border-radius:var(--r-sm);padding:4px 8px;color:var(--text);font-size:11px;font-family:var(--font-mono);resize:vertical;outline:none}.pp-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.pp-color-wrap{display:flex;align-items:center;gap:6px;flex:1}.pp-color-wrap input[type=color]{width:28px;height:28px;border:1px solid var(--border);border-radius:var(--r-sm);padding:1px;cursor:pointer;background:transparent}.pp-color-hex{font-size:10px;font-family:var(--font-mono);color:var(--text3)}.pp-range-wrap{display:flex;align-items:center;gap:6px;flex:1}.pp-range-wrap input[type=range]{flex:1;height:4px;accent-color:var(--accent)}.pp-range-val{font-size:10px;font-family:var(--font-mono);color:var(--text3);min-width:28px;text-align:right}.pp-empty{padding:40px 20px;text-align:center;color:var(--text3);font-size:12px}.pp-upload-btn{width:100%;padding:8px 12px;background:#5b4ff51f;border:1px dashed rgba(91,79,245,.4);border-radius:var(--r-md);color:var(--accent2);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s var(--ease);text-align:center}.pp-upload-btn:hover{background:#5b4ff538;border-color:var(--accent2);color:#fff}.pp-bg-panel{margin-top:4px}.screens-bar{height:var(--screens-h);background:var(--panel);border-top:1px solid var(--border);flex-shrink:0}.sb-tabs{display:flex;align-items:center;height:100%;padding:0 4px;gap:2px;overflow-x:auto}.sb-tab{display:flex;align-items:center;gap:6px;padding:0 12px;height:28px;border-radius:var(--r-sm);font-size:11px;color:var(--text3);cursor:pointer;transition:all var(--transition);white-space:nowrap;user-select:none}.sb-tab:hover{background:var(--panel3);color:var(--text2)}.sb-tab.sb-active{background:#5b4ff51f;color:var(--accent2);font-weight:500}.sb-tab-del{font-size:12px;opacity:0;cursor:pointer;padding:0 2px;transition:opacity var(--transition)}.sb-tab:hover .sb-tab-del{opacity:.6}.sb-tab-del:hover{opacity:1!important;color:var(--red)}.sb-add{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);color:var(--text3);cursor:pointer;font-size:16px;transition:all var(--transition)}.sb-add:hover{background:var(--panel3);color:var(--accent2)}.sb-rename-input{background:var(--panel2);border:1px solid var(--accent);border-radius:var(--r-sm);color:var(--text);font-size:11px;padding:2px 6px;width:80px;outline:none}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--border3)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}::selection{background:#5b4ff54d}.flash-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.flash-modal{background:var(--panel2);border:1px solid var(--border2);border-radius:12px;width:650px;max-width:90vw;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #00000080;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.flash-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--panel)}.flash-header-left{display:flex;align-items:center;gap:10px}.flash-header h2{font-size:15px;font-weight:600;color:var(--text);margin:0}.flash-close{background:none;border:none;color:var(--text3);font-size:16px;cursor:pointer;padding:4px 8px;border-radius:var(--r-sm)}.flash-close:hover{background:var(--panel3);color:var(--text)}.flash-body{padding:20px;overflow-y:auto;flex:1}.flash-step-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;color:var(--accent3);margin-bottom:14px}.flash-search-row{display:flex;gap:8px;margin-bottom:14px}.flash-input{flex:1;background:var(--panel);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);padding:8px 12px;font-size:13px;font-family:var(--font-sans)}.flash-input:focus{outline:none;border-color:var(--accent)}.flash-select{background:var(--panel);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);padding:8px 10px;font-size:13px;cursor:pointer}.flash-panel-list{display:flex;flex-direction:column;gap:6px;max-height:340px;overflow-y:auto;margin-bottom:16px}.flash-panel-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 14px;cursor:pointer;transition:all .15s ease}.flash-panel-card:hover{border-color:var(--border3);background:var(--panel3)}.flash-panel-card.selected{border-color:var(--accent);background:#5b4ff514;box-shadow:0 0 0 1px var(--accent)}.flash-panel-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.flash-panel-name{font-weight:600;font-size:13px;color:var(--text)}.flash-panel-size{font-size:11px;color:var(--text3)}.flash-panel-meta{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:6px}.flash-tag{font-size:10px;padding:2px 7px;border-radius:999px;background:var(--panel2);border:1px solid var(--border);color:var(--text2)}.flash-tag-touch{border-color:#22d3ee4d;color:var(--cyan)}.flash-panel-desc{font-size:11px;color:var(--text3);line-height:1.4}.flash-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:14px}.flash-btn{padding:9px 18px;border-radius:var(--r-md);font-size:13px;font-weight:600;cursor:pointer;border:1px solid var(--border);transition:all .15s ease;font-family:var(--font-sans)}.flash-btn:disabled{opacity:.4;cursor:not-allowed}.flash-btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.flash-btn-primary:hover:not(:disabled){background:var(--accent2)}.flash-btn-secondary{background:var(--panel);color:var(--text2)}.flash-btn-secondary:hover{background:var(--panel3)}.flash-info-box{background:var(--panel);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 14px;margin-bottom:16px}.flash-info-title{font-weight:600;font-size:14px;color:var(--text);margin-bottom:4px}.flash-info-detail{font-size:12px;color:var(--text3)}.flash-instructions{margin-bottom:16px}.flash-instructions p{font-size:13px;color:var(--text2);line-height:2;padding-left:8px}.flash-instructions b{color:var(--accent3)}.flash-progress-container{margin-bottom:14px}.flash-progress-bar{height:8px;background:var(--panel);border-radius:4px;overflow:hidden;margin-bottom:6px}.flash-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--cyan));border-radius:4px;transition:width .3s ease}.flash-progress-text{font-size:12px;color:var(--text3);text-align:center}.flash-log{background:var(--panel);border:1px solid var(--border);border-radius:var(--r-sm);max-height:160px;overflow-y:auto;padding:8px 10px;font-family:var(--font-mono);font-size:11px}.flash-log-line{padding:2px 0;color:var(--text3)}.flash-log-ok{color:var(--green)}.flash-log-error{color:var(--red)}.flash-step-done,.flash-step-error{text-align:center;padding:30px 20px}.flash-done-icon,.flash-error-icon{font-size:48px;margin-bottom:12px}.flash-step-done h3{font-size:18px;color:var(--green);margin-bottom:8px}.flash-done-text,.flash-error-text{font-size:13px;color:var(--text2);line-height:1.8}.tb-usb-mirror{border-color:#22d3ee59!important;color:var(--cyan)!important}.tb-usb-mirror.active-btn{background:#22d3ee26!important;border-color:var(--cyan)!important;animation:mirrorPulse 2s ease-in-out infinite}@keyframes mirrorPulse{0%,to{box-shadow:0 0 #22d3ee00}50%{box-shadow:0 0 8px 2px #22d3ee4d}}.symbol-picker-popup{width:340px;max-height:380px;background:var(--panel2);border:1px solid var(--border2);border-radius:12px;box-shadow:0 12px 40px #0009;z-index:10000;overflow:hidden;display:flex;flex-direction:column}.sp-header{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border)}.sp-title{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap}.sp-search{flex:1;background:var(--panel);border:1px solid var(--border2);border-radius:6px;padding:4px 8px;color:var(--text);font-size:12px;outline:none}.sp-search:focus{border-color:var(--accent)}.sp-close{background:none;border:none;color:var(--text3);cursor:pointer;font-size:14px;padding:2px 6px;border-radius:4px}.sp-close:hover{background:#ffffff1a;color:var(--text)}.sp-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;padding:8px;overflow-y:auto;max-height:300px}.sp-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;border-radius:8px;background:transparent;border:1px solid transparent;cursor:pointer;transition:all .15s}.sp-item:hover{background:#5b4ff526;border-color:#5b4ff54d}.sp-char{font-size:20px;line-height:1;font-family:FontAwesome,"Font Awesome 4",serif;display:block;min-width:24px;text-align:center}.sp-name{font-size:8px;color:var(--text3);text-align:center;line-height:1.2}body.preview-mode .editor-topbar,body.preview-mode #widget-palette,body.preview-mode #props-panel,body.preview-mode #screens-bar{display:none!important}body.preview-mode .editor-main{height:100vh}body.preview-mode .editor-center{width:100%}body.preview-mode .canvas-container{background:#000}.pp-layer-btns{display:flex;gap:4px;margin-top:4px}.pp-layer-btn{flex:1;padding:4px;border-radius:6px;background:var(--panel3);border:1px solid var(--border2);color:var(--text2);cursor:pointer;font-size:11px;text-align:center;transition:all .15s}.pp-layer-btn:hover{background:var(--panel4);border-color:var(--accent);color:var(--text)}.align-toolbar{display:flex;gap:2px;padding:4px;background:var(--panel2);border-radius:8px;border:1px solid var(--border)}.align-btn{width:28px;height:26px;border-radius:5px;background:transparent;border:none;color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.align-btn:hover{background:#5b4ff526;color:var(--accent)}.align-btn svg{width:14px;height:14px}.pp-events-section{margin-top:4px;border-top:1px solid rgba(234,179,8,.15)}.pp-events-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#eab3080a;border-bottom:1px solid rgba(234,179,8,.1)}.pp-events-title{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#eab308}.pp-events-icon{flex-shrink:0}.pp-events-count{background:#eab30826;color:#eab308;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}.pp-events-add{background:#eab3081a;border:1px solid rgba(234,179,8,.25);color:#eab308;font-size:11px;font-weight:600;padding:3px 10px;border-radius:4px;cursor:pointer;transition:all .15s}.pp-events-add:hover{background:#eab30833;border-color:#eab30866}.pp-events-cards{display:flex;flex-direction:column;gap:4px;padding:6px 8px}.pp-event-card{background:#eab30808;border:1px solid rgba(234,179,8,.1);border-radius:6px;padding:6px 8px;transition:border-color .15s}.pp-event-card:hover{border-color:#eab30840}.pp-event-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.pp-event-num{font-size:10px;font-weight:700;color:#eab308;background:#eab3081a;padding:1px 6px;border-radius:3px}.pp-event-delete{background:none;border:none;color:var(--text2);font-size:11px;cursor:pointer;padding:2px 4px;border-radius:3px;transition:all .15s}.pp-event-delete:hover{color:#ef4444;background:#ef44441a}.pp-event-mode-toggle{font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;cursor:pointer;user-select:none;transition:all .18s ease;letter-spacing:.2px;flex:1;text-align:center;margin:0 6px}.pp-event-mode-sequential{background:#22c55e1f;border:1px solid rgba(34,197,94,.35);color:#22c55e}.pp-event-mode-sequential:hover{background:#22c55e38;border-color:#22c55e8c}.pp-event-mode-parallel{background:#94a3b81a;border:1px solid rgba(148,163,184,.25);color:var(--text3)}.pp-event-mode-parallel:hover{background:#94a3b82e;border-color:#94a3b866;color:var(--text2)}.pp-event-row{display:flex;align-items:center;gap:6px;margin-bottom:4px}.pp-event-row label{font-size:11px;color:var(--text2);min-width:60px;flex-shrink:0}.pp-event-input{flex:1;background:var(--panel2);border:1px solid var(--border);color:var(--text);padding:4px 8px;border-radius:4px;font-size:11px;outline:none;min-width:0}.pp-event-input:focus{border-color:#eab30866;box-shadow:0 0 0 2px #eab30814}.pp-event-anim-row{gap:4px}.pp-event-delay{display:flex;align-items:center;gap:2px;flex-shrink:0}.pp-event-delay input{width:52px;background:var(--panel2);border:1px solid var(--border);color:var(--text);padding:4px;border-radius:4px;font-size:11px;text-align:right;outline:none}.pp-event-delay input:focus{border-color:#eab30866}.pp-event-delay-label{font-size:10px;color:var(--text2)}.pp-event-cond-input{font-family:var(--font-mono);font-size:11px}.pp-event-action-panel{display:flex;flex-direction:column;gap:0;margin-top:6px;padding:0 0 4px;border-top:1px solid rgba(234,179,8,.15)}.af-field{display:flex;flex-direction:column;gap:0}.af-row{display:flex;align-items:center;gap:6px;padding:4px 8px;min-height:28px}.af-loading{font-size:10px;align-items:center;gap:6px;padding:4px 8px;min-height:28px}.af-label{font-size:10.5px;color:var(--text3);min-width:88px;max-width:88px;flex-shrink:0;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.af-input{flex:1;min-width:0;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:5px;color:var(--text);font-size:11px;font-family:var(--font-sans);padding:3px 7px;outline:none;transition:border-color .15s,box-shadow .15s;height:24px}.af-input:focus{border-color:#8b7ff58c;box-shadow:0 0 0 2px #8b7ff51f}select.af-input{cursor:pointer;appearance:auto}select.af-input optgroup{font-size:10px;font-weight:700;color:var(--text3);background:var(--panel);font-style:normal;letter-spacing:.4px}select.af-input option{font-size:11px;background:var(--panel2);color:var(--text)}.af-hint{font-size:9.5px;color:#64748b;padding:1px 8px 4px 102px;line-height:1.4;font-style:italic}.af-title{font-size:10.5px;font-weight:700;color:var(--text3);padding:8px 8px 3px;letter-spacing:.4px;text-transform:uppercase;font-family:var(--font-sans)}.af-divider{height:1px;background:#ffffff0f;margin:4px 8px}.af-info{font-size:10.5px;line-height:1.55;padding:5px 10px;margin:2px 8px 4px;border-radius:6px;border:1px solid rgba(255,255,255,.07);background:#ffffff0a;color:var(--text3)}.af-checkbox-row{display:flex;align-items:center;gap:8px;padding:5px 8px;cursor:pointer;border-radius:5px;transition:background .12s}.af-checkbox-row:hover{background:#ffffff0a}.af-checkbox{width:14px;height:14px;flex-shrink:0;accent-color:#4ade80;cursor:pointer;margin:0}.af-checkbox-label{font-size:11px;color:var(--text2);cursor:pointer;line-height:1.3;user-select:none}.af-color-row{display:flex;align-items:center;gap:6px;padding:4px 8px;min-height:28px}.af-color-inner{display:flex;align-items:center;gap:6px;flex:1}.af-color-swatch{width:36px;height:24px;border-radius:5px;border:1px solid rgba(255,255,255,.15);padding:1px;cursor:pointer;background:transparent;flex-shrink:0}.af-color-hex{font-size:11px;font-family:var(--font-mono);color:var(--text3)}.af-gpio-wrap{padding:4px 8px 6px;display:flex;flex-direction:column;gap:4px}.af-gpio-label{font-size:10.5px;color:var(--text3);font-weight:600;letter-spacing:.2px}.af-multi-gpio-label{color:#f59e0b}.af-badge{font-size:10px;font-weight:600;padding:2px 10px;border-radius:4px;margin:0 8px 4px;display:inline-block;width:fit-content}.af-badge-high{background:#22c55e26;border:1px solid rgba(34,197,94,.35);color:#4ade80}.af-badge-low{background:#ef444426;border:1px solid rgba(239,68,68,.35);color:#f87171}.af-loading{font-size:10px;color:#64748b;padding:6px 8px;font-style:italic}.af-empty{font-size:10.5px;color:#64748b;padding:8px;text-align:center}.af-error{font-size:10.5px;color:#f87171;padding:6px 8px;background:#ef444414;border-radius:4px;margin:4px 8px}.pp-event-row select optgroup{font-size:10px;font-weight:700;color:var(--text3);background:var(--panel);font-style:normal}.wf-overlay{position:fixed;inset:0;background:#0000008c;backdrop-filter:blur(3px);z-index:9000;display:flex;align-items:stretch;justify-content:flex-end}.wf-modal{width:100vw;height:100vh;background:#0b0b18;border-left:none;display:flex;flex-direction:column;overflow:hidden;box-shadow:none;transform:translate(100%);transition:transform .26s cubic-bezier(.4,0,.2,1)}.wf-modal.wf-modal-open{transform:translate(0)}.wf-modal.wf-modal-closing{transform:translate(100%)}.wf-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:#0a0a16;border-bottom:1px solid rgba(91,79,245,.2);flex-shrink:0}.wf-header-left{display:flex;align-items:center;gap:10px}.wf-header-icon{font-size:18px}.wf-header-title{font-size:15px;font-weight:700;color:#e2e8f0;letter-spacing:.4px}.wf-header-screen{font-size:12px;color:#8b7ff5;font-weight:500}.wf-header-right{display:flex;align-items:center;gap:6px}.wf-header-sep{width:1px;height:20px;background:#ffffff1a;margin:0 2px}.wf-zoom-label{font-size:12px;color:#64748b;min-width:40px;text-align:center}.wf-btn{padding:5px 12px;border-radius:6px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#cbd5e1;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.wf-btn:hover{background:#ffffff1a;color:#fff;border-color:#fff3}.wf-btn-save{background:#5b4ff533;border-color:#5b4ff566;color:#a78bfa}.wf-btn-save:hover{background:#5b4ff559}.wf-btn-validate{background:#22c55e1a;border-color:#22c55e4d;color:#4ade80}.wf-btn-validate:hover{background:#22c55e33}.wf-btn-close{background:#ef44441a;border-color:#ef444440;color:#f87171;font-size:14px}.wf-btn-close:hover{background:#ef444433}.wf-palette{width:230px;min-width:230px;background:linear-gradient(180deg,#0e0e1f,#09091a);border-right:1px solid rgba(91,79,245,.15);overflow-y:auto;display:flex;flex-direction:column;flex-shrink:0;scrollbar-width:thin;scrollbar-color:rgba(91,79,245,.25) transparent}.wf-palette::-webkit-scrollbar{width:4px}.wf-palette::-webkit-scrollbar-track{background:transparent}.wf-palette::-webkit-scrollbar-thumb{background:#5b4ff54d;border-radius:4px}.wf-palette::-webkit-scrollbar-thumb:hover{background:#5b4ff58c}.wf-palette-header{display:flex;align-items:center;gap:8px;padding:14px 14px 10px;font-size:9px;font-weight:800;color:#5b4ff5;letter-spacing:2px;text-transform:uppercase;border-bottom:1px solid rgba(91,79,245,.12);background:linear-gradient(135deg,rgba(91,79,245,.06) 0%,transparent 100%);flex-shrink:0}.wf-palette-header:before{content:"⚡";font-size:13px;filter:drop-shadow(0 0 6px rgba(91,79,245,.8))}.wf-palette-section{display:flex;flex-direction:column;gap:1px}.wf-palette-section-title{display:flex;align-items:center;gap:9px;padding:7px 12px 7px 10px;margin:3px 7px 1px;border-radius:7px;border:1px solid transparent;position:sticky;top:3px;z-index:2;background:transparent;color:#94a3b8;font-size:10px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;user-select:none;transition:background-color .15s,border-color .15s,transform .12s,box-shadow .15s}.wf-palette-section-title:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:2px;height:60%;border-radius:2px;background:#a78bfa;box-shadow:0 0 6px #a78bfa;transition:transform .15s}.wf-palette-section-title.wf-section-collapsible{cursor:pointer}.wf-palette-section-title.wf-section-collapsible:hover{background-color:#ffffff0e;border-color:#ffffff12;transform:translate(2px);box-shadow:0 2px 12px #0000004d,-2px 0 #a78bfa80;background-image:linear-gradient(110deg,#c4b5fd,#f0ecff 45%,#ddd6fe)}.wf-palette-section-title.wf-section-collapsible:hover:before{transform:translateY(-50%) scaleY(1)}.wf-palette-section-icon{font-size:15px;line-height:1;flex-shrink:0;filter:drop-shadow(0 0 5px rgba(139,92,246,.7));transition:filter .15s,transform .15s}.wf-palette-section-title:hover .wf-palette-section-icon{filter:drop-shadow(0 0 9px rgba(196,181,253,1));transform:scale(1.15)}.wf-palette-section-label{flex:1;font-size:10px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:linear-gradient(110deg,#818cf8,#c4b5fd,#a78bfa);-webkit-background-clip:text;background-clip:text;color:transparent;transition:background .15s}.wf-palette-section-title:hover .wf-palette-section-label{background:linear-gradient(110deg,#a5b4fc,#f0ecff,#c4b5fd);-webkit-background-clip:text;background-clip:text}.wf-section-chevron{margin-left:auto;font-size:8px;opacity:.5;transition:transform .22s cubic-bezier(.34,1.56,.64,1),opacity .15s;flex-shrink:0;color:#a78bfa}.wf-palette-section-title:hover .wf-section-chevron{opacity:.85}.wf-palette-item{display:flex;align-items:center;gap:9px;padding:6px 12px 6px 10px;cursor:grab;border-radius:7px;margin:1px 7px;transition:background .15s,transform .12s,box-shadow .15s;user-select:none;position:relative;border:1px solid transparent}.wf-palette-item:hover{background:#ffffff0e;border-color:#ffffff14;box-shadow:inset 0 0 0 1px #ffffff0f,-2px 0 #5b4ff580}.wf-palette-item:active{cursor:grabbing;transform:scale(.97)}.wf-palette-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:2px;height:60%;border-radius:2px;background:var(--pi-color, #5b4ff5);transition:transform .15s}.wf-palette-item:hover:before{transform:translateY(-50%) scaleY(1)}.wf-palette-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px currentColor}.wf-palette-item-label{font-size:12px;font-weight:700;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .12s}.wf-palette-item:hover .wf-palette-item-label{color:#fff}.wf-palette-group{display:flex;align-items:center;gap:9px;padding:6px 12px 6px 10px;margin:1px 7px;border-radius:7px;border:1px solid transparent;font-size:11px;font-weight:500;letter-spacing:.2px;color:#78869a;cursor:pointer;user-select:none;position:relative;transition:background .15s,transform .12s,box-shadow .15s,color .15s}.wf-palette-group:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:2px;height:60%;border-radius:2px;background:var(--gc, #60a5fa);box-shadow:0 0 6px var(--gc, #60a5fa);transition:transform .15s}.wf-palette-group:hover{background:#ffffff0e;border-color:#ffffff0f;transform:translate(2px);box-shadow:0 2px 12px #0000004d,-2px 0 color-mix(in srgb,var(--gc, #60a5fa) 60%,transparent);color:#e2e8f0}.wf-palette-group:hover:before{transform:translateY(-50%) scaleY(1)}.wf-palette-group-open{color:#94a3b8}.wf-palette-group-open:before{transform:translateY(-50%) scaleY(1)}.wf-palette-group-icon{font-size:15px;line-height:1;flex-shrink:0;filter:drop-shadow(0 0 4px color-mix(in srgb,var(--gc, #60a5fa) 70%,transparent));transition:filter .15s,transform .15s}.wf-palette-group:hover .wf-palette-group-icon{filter:drop-shadow(0 0 7px color-mix(in srgb,var(--gc, #60a5fa) 90%,white));transform:scale(1.12)}.wf-palette-group-chevron{margin-left:auto;font-size:8px;opacity:.55;transition:transform .22s cubic-bezier(.34,1.56,.64,1),opacity .15s;flex-shrink:0}.wf-palette-group-open .wf-palette-group-chevron{transform:rotate(90deg);opacity:.85}.wf-palette-group:hover .wf-palette-group-chevron{opacity:.8}.wf-palette-group-label{font-size:11px;font-weight:500;color:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .12s;flex:1}.wf-palette-group-items{display:none;flex-direction:column;gap:0;padding:0;margin:0}.wf-palette-group-items .wf-palette-item{--pi-color: var(--gc, #60a5fa)}.wf-palette-group-items .wf-palette-item:hover{box-shadow:0 2px 12px #0000004d,-2px 0 color-mix(in srgb,var(--gc, #60a5fa) 60%,transparent)}.wf-palette-item-icon{font-size:15px;line-height:1;flex-shrink:0;filter:drop-shadow(0 0 4px color-mix(in srgb,var(--pi-color, #5b4ff5) 60%,transparent));transition:filter .15s,transform .15s}.wf-palette-item:hover .wf-palette-item-icon{filter:drop-shadow(0 0 7px color-mix(in srgb,var(--pi-color, #5b4ff5) 85%,white));transform:scale(1.12)}.wf-template-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .15s,border-color .15s,transform .12s;border-radius:8px;margin:2px 7px;border:1px solid transparent;position:relative;overflow:hidden}.wf-template-item:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#5b4ff500,#5b4ff500);transition:background .2s;border-radius:inherit}.wf-template-item:hover{background:#5b4ff514;border-color:#5b4ff533;transform:translate(2px);box-shadow:0 2px 12px #0000004d,-2px 0 #5b4ff599}.wf-template-icon{font-size:20px;flex-shrink:0;filter:drop-shadow(0 0 4px rgba(91,79,245,.4));transition:filter .2s,transform .2s}.wf-template-item:hover .wf-template-icon{filter:drop-shadow(0 0 8px rgba(91,79,245,.7));transform:scale(1.1)}.wf-template-label{font-size:11px;font-weight:700;color:#cbd5e1;transition:color .12s}.wf-template-item:hover .wf-template-label{color:#e2e8f0}.wf-template-desc{font-size:9px;color:#374151;margin-top:2px;line-height:1.4}.wf-main{display:flex;flex:1;overflow:hidden}.wf-canvas-wrap{flex:1;overflow:hidden;position:relative;background:#07070f;background-image:radial-gradient(circle at 1px 1px,rgba(91,79,245,.12) 1px,transparent 0);background-size:24px 24px;cursor:default}.wf-canvas{position:absolute;top:0;left:0;width:4000px;height:4000px;transform-origin:0 0}.wf-wire-svg{position:absolute;inset:0;pointer-events:none;overflow:visible;z-index:5}@keyframes wf-wire-flow{0%{stroke-dashoffset:24}to{stroke-dashoffset:0}}.wf-minimap{position:absolute;bottom:16px;right:16px;background:#080816eb;border:1px solid rgba(91,79,245,.22);border-radius:10px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 4px 24px #0000008c,0 0 0 1px #5b4ff514 inset;z-index:50;overflow:hidden;transition:box-shadow .2s,border-color .2s;user-select:none}.wf-minimap:hover{border-color:#5b4ff566;box-shadow:0 6px 32px #000000a6,0 0 0 1px #5b4ff526 inset,0 0 20px #5b4ff514}.wf-minimap-header{display:flex;align-items:center;justify-content:space-between;padding:5px 8px 4px;background:linear-gradient(135deg,rgba(91,79,245,.1) 0%,transparent 100%);border-bottom:1px solid rgba(91,79,245,.1)}.wf-minimap-title{font-size:9px;font-weight:700;color:#6d60f5;letter-spacing:.5px;display:flex;align-items:center;gap:4px}.wf-minimap-toggle{background:#5b4ff526;border:1px solid rgba(91,79,245,.25);color:#8b7ff5;font-size:12px;font-weight:700;line-height:1;width:18px;height:18px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;padding:0}.wf-minimap-toggle:hover{background:#5b4ff559;color:#c4b5fd}.wf-minimap-canvas{display:block;cursor:crosshair;transition:opacity .15s}.wf-minimap-canvas:hover{opacity:.9}.wf-minimap-collapsed .wf-minimap-header{border-bottom:none}.wf-minimap-collapsed{border-color:#5b4ff526}@keyframes wf-node-appear{0%{opacity:0;transform:scale(.8) translateY(-14px);filter:blur(4px)}to{opacity:1;transform:scale(1) translateY(0);filter:blur(0)}}@keyframes wf-node-glow{0%,to{box-shadow:0 0 0 2px color-mix(in srgb,var(--nc,#5b4ff5) 45%,transparent),0 8px 32px #000000b3}50%{box-shadow:0 0 0 4px color-mix(in srgb,var(--nc,#5b4ff5) 22%,transparent),0 14px 50px #000000d9,0 0 30px color-mix(in srgb,var(--nc,#5b4ff5) 14%,transparent)}}.wf-node{position:absolute;min-width:205px;max-width:285px;background:linear-gradient(158deg,#16162e,#0d0d1e);border:1.5px solid color-mix(in srgb,var(--nc,#5b4ff5) 22%,transparent);border-radius:12px;overflow:hidden;box-shadow:0 6px 28px #000000a6,0 1px #ffffff0b inset;transition:border-color .2s,box-shadow .2s,transform .18s,filter .18s;z-index:10;user-select:none;animation:wf-node-appear .26s cubic-bezier(.34,1.56,.64,1) both}.wf-node:hover{border-color:color-mix(in srgb,var(--nc,#5b4ff5) 52%,transparent);transform:translateY(-2px) scale(1.006);box-shadow:0 12px 38px #000000bf,0 0 0 1px color-mix(in srgb,var(--nc,#5b4ff5) 28%,transparent)}.wf-node-selected{border-color:color-mix(in srgb,var(--nc,#5b4ff5) 68%,transparent)!important;animation:wf-node-glow 2.2s ease-in-out infinite!important;transform:translateY(-1px)!important}.wf-node-error{border-color:#ef4444a6!important}.wf-node-warning{border-color:#eab3088c!important}.wf-node-dragging{z-index:100;opacity:.93;transform:scale(1.035) translateY(-5px)!important;animation:none!important;filter:drop-shadow(0 20px 40px rgba(0,0,0,.9))}.wf-node-accent{height:3px;background:linear-gradient(90deg,var(--nc,#5b4ff5) 0%,color-mix(in srgb,var(--nc,#5b4ff5) 28%,transparent) 100%);flex-shrink:0}.wf-node-head{display:flex;align-items:center;gap:8px;padding:9px 10px;cursor:grab;border-bottom:1px solid color-mix(in srgb,var(--nc,#5b4ff5) 14%,transparent)}.wf-node-head:active{cursor:grabbing}.wf-node-icon{font-size:15px;line-height:1;flex-shrink:0;filter:drop-shadow(0 0 6px color-mix(in srgb,var(--nc,#5b4ff5) 70%,transparent))}.wf-node-label{flex:1;font-size:12px;font-weight:700;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.3px;text-shadow:0 1px 4px rgba(0,0,0,.5)}.wf-node-head-right{display:flex;align-items:center;gap:5px;flex-shrink:0}.wf-node-type-chip{font-size:8px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:color-mix(in srgb,var(--nc,#5b4ff5) 90%,white);background:color-mix(in srgb,var(--nc,#5b4ff5) 13%,transparent);padding:2px 6px;border-radius:8px;border:1px solid color-mix(in srgb,var(--nc,#5b4ff5) 28%,transparent);white-space:nowrap;opacity:.88}.wf-node-del{background:none;border:none;color:#fff3;font-size:14px;cursor:pointer;padding:0;width:19px;height:19px;border-radius:5px;display:flex;align-items:center;justify-content:center;line-height:1;transition:color .12s,background .12s;flex-shrink:0}.wf-node-del:hover{color:#f87171;background:#ef444426}.wf-node-body{padding:7px 8px 9px;display:flex;flex-direction:column;gap:5px}.wf-ports{display:flex;flex-direction:column;gap:2px;padding:4px 0 3px;border-top:1px solid rgba(255,255,255,.045)}.wf-ports-in{padding-left:0}.wf-ports-out{padding-right:0}.wf-port{display:flex;align-items:center;gap:7px;padding:3px 8px}.wf-ports-out .wf-port{justify-content:flex-end}.wf-port-dot{width:13px;height:13px;border-radius:50%;border:2.5px solid;cursor:crosshair;transition:transform .15s,filter .15s,opacity .15s,box-shadow .15s;flex-shrink:0;background:#0006}.wf-port-dot:hover{transform:scale(1.5);filter:drop-shadow(0 0 6px currentColor)}.wf-port-compatible{transform:scale(1.35)!important;box-shadow:0 0 0 3px #4ade8059,0 0 12px #4ade8099!important;border-color:#4ade80!important;background:#4ade8040!important;animation:wf-port-pulse .9s ease-in-out infinite}.wf-port-incompatible{opacity:.25!important;filter:none!important;border-color:#ef4444!important;cursor:not-allowed!important;transform:scale(.85)!important}.wf-port-shake{animation:wf-port-shake .4s ease!important;border-color:#ef4444!important;box-shadow:0 0 0 4px #ef444466!important}@keyframes wf-port-pulse{0%,to{box-shadow:0 0 0 3px #4ade8059,0 0 12px #4ade8099}50%{box-shadow:0 0 0 5px #4ade8080,0 0 20px #4ade80cc}}@keyframes wf-port-shake{0%{transform:translate(0) scale(1.2)}20%{transform:translate(-5px) scale(1.2)}40%{transform:translate(5px) scale(1.2)}60%{transform:translate(-4px) scale(1.2)}80%{transform:translate(4px) scale(1.2)}to{transform:translate(0) scale(1)}}@keyframes wf-toast-in{0%{opacity:0;transform:translateY(6px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.wf-port-label{font-size:9.5px;color:#475569;white-space:nowrap;font-weight:500;transition:color .12s}.wf-port:hover .wf-port-label{color:#94a3b8}.wf-field{display:flex;align-items:center;gap:5px}.wf-field-label{font-size:9.5px;color:#475569;min-width:65px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.wf-input,.wf-select{flex:1;min-width:0;background:#00000061;border:1px solid rgba(255,255,255,.08);border-radius:5px;color:#cbd5e1;font-size:10.5px;padding:3px 6px;height:23px;outline:none;font-family:inherit;transition:border-color .15s,box-shadow .15s}.wf-input:focus,.wf-select:focus{border-color:color-mix(in srgb,var(--nc,#5b4ff5) 60%,transparent);box-shadow:0 0 0 2px color-mix(in srgb,var(--nc,#5b4ff5) 12%,transparent)}.wf-select{cursor:pointer;background:#090916;color:#cbd5e1;color-scheme:dark}.wf-select option{background:#0f1022;color:#e2e8f0}.wf-select optgroup{background:#0a0a18;color:#475569;font-size:9.5px;font-weight:700;font-style:normal}.wf-checkbox{accent-color:#4ade80;width:13px;height:13px}.wf-color{width:32px;height:22px;border-radius:4px;border:1px solid rgba(255,255,255,.15);padding:1px;cursor:pointer;background:transparent}.wf-schema-form{display:flex;flex-direction:column;gap:4px;margin-top:3px;padding-top:5px;border-top:1px solid rgba(255,255,255,.05)}.wf-field-complex{font-size:9.5px;color:#334155;font-style:italic;padding:2px 0}.wf-comment-text{width:100%;background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:6px;color:#94a3b8;font-size:10.5px;padding:5px 7px;resize:vertical;font-family:inherit;outline:none;min-height:48px;transition:border-color .15s,color .15s}.wf-comment-text:focus{border-color:#64748b59;color:#cbd5e1}.wf-field-hint{font-size:9px;color:#f59e0b;padding:2px 0 0;font-style:italic}.wf-statusbar{display:flex;align-items:center;gap:14px;padding:5px 16px;background:linear-gradient(90deg,#06060f,#08081a);border-top:1px solid rgba(91,79,245,.12);font-size:11px;flex-shrink:0;box-shadow:0 -4px 20px #0000004d}.wf-status-item{color:#374151;font-size:10.5px}.wf-status-item b{color:#6b7280;font-weight:700}.wf-status-hint{margin-left:auto;font-size:9.5px;color:#1e2533;font-style:italic}.wf-validate-popup{position:absolute;bottom:50px;right:24px;background:#11111f;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:12px 14px;min-width:280px;max-width:400px;box-shadow:0 10px 40px #0009;z-index:1000;display:flex;flex-direction:column;gap:5px}.wf-validate-row{font-size:11px;line-height:1.5}.wf-validate-error{color:#f87171}.wf-validate-warning{color:#fbbf24}.wf-validate-info{color:#60a5fa}@keyframes wf-back-pulse{0%,to{box-shadow:0 0 #fb923c80,0 2px 12px #fb923c4d}50%{box-shadow:0 0 0 5px #fb923c00,0 2px 16px #fb923c99}}.wf-btn-back{background:linear-gradient(135deg,#ea580cd9,#ef4444bf)!important;border:1.5px solid rgba(251,146,60,.8)!important;color:#fff!important;font-weight:800!important;font-size:13px!important;padding:7px 18px!important;border-radius:8px!important;letter-spacing:.3px!important;animation:wf-back-pulse 2.4s ease-in-out infinite!important;text-shadow:0 1px 4px rgba(0,0,0,.4)!important;transition:transform .15s,filter .15s!important}.wf-btn-back:hover{background:linear-gradient(135deg,#ea580c,#ef4444)!important;color:#fff!important;filter:brightness(1.15)!important;transform:scale(1.04)!important;animation:none!important;box-shadow:0 0 18px #fb923cb3!important}.wf-palette-widget{gap:9px;align-items:center;padding:6px 12px 6px 10px}.wf-palette-widget-icon{font-size:17px;line-height:1;flex-shrink:0;filter:drop-shadow(0 0 4px rgba(91,79,245,.35));transition:filter .15s,transform .15s}.wf-palette-item:hover .wf-palette-widget-icon{filter:drop-shadow(0 0 7px rgba(91,79,245,.7));transform:scale(1.1)}.wf-palette-widget-type{font-size:8.5px;color:#374151;margin-top:2px;font-weight:600;letter-spacing:.3px}.wf-palette-widget-screen{font-size:7.5px;color:#4b5563;margin-top:1px;font-weight:500;opacity:.7}.wf-editor-peek,.wf-peek-label{display:none!important}.wf-editor-peek:hover .wf-peek-label{color:#a78bfae6}.wf-widget-badge{display:inline-flex;align-items:center;justify-content:center;background:#5b4ff540;color:#8b7ff5;font-size:8.5px;font-weight:800;border-radius:10px;padding:1px 7px;margin-left:5px;vertical-align:middle;border:1px solid rgba(91,79,245,.3);transition:background .2s}.wf-palette-empty{font-size:10px;color:#1f2937;font-style:italic;padding:8px 14px 10px;text-align:center;border:1px dashed rgba(255,255,255,.05);border-radius:6px;margin:4px 8px}.wf-widget-section{border-bottom:1px solid rgba(91,79,245,.1);margin-bottom:2px;padding-bottom:4px}.wf-status-autosave{font-size:9.5px;color:#15803d;font-weight:600;opacity:.75}.wf-frame{position:absolute;border:1.5px solid color-mix(in srgb,var(--fc,#5b4ff5) 38%,transparent);border-radius:12px;background:color-mix(in srgb,var(--fc,#5b4ff5) 5%,rgba(7,7,18,.55));backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);box-shadow:0 0 0 1px color-mix(in srgb,var(--fc,#5b4ff5) 8%,transparent) inset;z-index:1;transition:border-color .2s,box-shadow .2s}.wf-frame:hover{border-color:color-mix(in srgb,var(--fc,#5b4ff5) 55%,transparent);box-shadow:0 0 0 1px color-mix(in srgb,var(--fc,#5b4ff5) 12%,transparent) inset,0 0 20px color-mix(in srgb,var(--fc,#5b4ff5) 10%,transparent)}.wf-frame-header{display:flex;align-items:center;gap:6px;padding:5px 8px 4px;border-radius:10px 10px 0 0;background:color-mix(in srgb,var(--fc,#5b4ff5) 12%,rgba(0,0,0,.35));cursor:grab;border-bottom:1px solid color-mix(in srgb,var(--fc,#5b4ff5) 20%,transparent);user-select:none}.wf-frame-header:active{cursor:grabbing}.wf-frame-title{flex:1;font-size:11px;font-weight:700;color:color-mix(in srgb,var(--fc,#5b4ff5) 80%,#fff);letter-spacing:.4px;cursor:grab;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wf-frame-input{flex:1;background:transparent;border:none;border-bottom:1.5px solid var(--fc,#5b4ff5);color:color-mix(in srgb,var(--fc,#5b4ff5) 80%,#fff);font-size:11px;font-weight:700;outline:none;padding:1px 0;width:100%}.wf-frame-del{background:#ef44441f;border:1px solid rgba(239,68,68,.2);color:#ef44448c;font-size:13px;width:18px;height:18px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;padding:0;transition:background .15s,color .15s,border-color .15s;flex-shrink:0}.wf-frame-del:hover{background:#ef444440;color:#ef4444;border-color:#ef444473}.wf-frame-swatch{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.25);cursor:pointer;flex-shrink:0;transition:border-color .15s,transform .15s;padding:0}.wf-frame-swatch:hover{border-color:#fff9;transform:scale(1.2)}.wf-frame-colorpicker{position:absolute;top:28px;left:6px;background:#0a0a18f5;border:1px solid rgba(91,79,245,.3);border-radius:10px;padding:8px;display:grid;grid-template-columns:repeat(4,20px);gap:6px;z-index:9999;box-shadow:0 8px 32px #000000b3,0 0 0 1px #5b4ff51a inset;backdrop-filter:blur(10px)}.wf-frame-color-dot{width:20px;height:20px;border-radius:50%;border:2px solid rgba(255,255,255,.1);cursor:pointer;transition:transform .12s,border-color .12s;padding:0}.wf-frame-color-dot:hover{transform:scale(1.25);border-color:#ffffff80}.wf-frame-color-dot-active{border-color:#fff!important;box-shadow:0 0 0 2px #ffffff4d;transform:scale(1.15)}.wf-frame-resizer{position:absolute;bottom:0;right:0;width:20px;height:20px;cursor:se-resize;border-radius:0 0 10px;background:linear-gradient(135deg,transparent 50%,color-mix(in srgb,var(--fc,#5b4ff5) 35%,transparent) 50%);transition:background .15s}.wf-frame-resizer:hover{background:linear-gradient(135deg,transparent 50%,color-mix(in srgb,var(--fc,#5b4ff5) 60%,transparent) 50%)}.wf-frame-preview{position:absolute;border:2px dashed rgba(139,127,245,.75);border-radius:8px;background:#5b4ff50f;pointer-events:none;z-index:9000;animation:wf-frame-preview-pulse 1s ease-in-out infinite}@keyframes wf-frame-preview-pulse{0%,to{border-color:#8b7ff5bf}50%{border-color:#a78bfa}}.wf-btn-active{background:#5b4ff547!important;border-color:#8b7ff599!important;color:#c4b5fd!important;box-shadow:0 0 12px #5b4ff547!important}.wf-input{background:#ffffff0d;border:1px solid rgba(91,79,245,.25);border-radius:5px;color:#cbd5e1;font-size:11px;padding:3px 6px;width:100%;box-sizing:border-box;outline:none;transition:border-color .15s}.wf-input:focus{border-color:#5b4ff58c}.wf-section-collapsible{cursor:pointer;user-select:none;display:flex!important;align-items:center;justify-content:space-between;border-radius:6px;transition:background .15s}.wf-section-collapsible:hover{background:#5b4ff51a!important}.wf-section-chevron{font-size:16px;color:#b4aaffd9;transition:transform .2s ease,color .15s;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px;background:#5b4ff526;margin-left:6px;line-height:1}.wf-section-collapsible:hover .wf-section-chevron{color:#c4b5fd;background:#5b4ff547}.wf-chevron-collapsed{transform:rotate(-90deg)}.wf-palette-search-wrap{padding:8px 10px 2px;position:sticky;top:38px;background:#0c0c1a;z-index:2}.wf-palette-search{width:100%;box-sizing:border-box;background:#ffffff0d;border:1px solid rgba(91,79,245,.2);border-radius:7px;color:#cbd5e1;font-size:11px;padding:5px 10px;outline:none;transition:border-color .15s,background .15s,box-shadow .15s;font-family:inherit}.wf-palette-search::placeholder{color:#94a3b873}.wf-palette-search:focus{border-color:#5b4ff580;background:#5b4ff512;box-shadow:0 0 0 2px #5b4ff51f}.wf-btn-undo,.wf-btn-redo{font-size:11px;min-width:52px;padding:4px 8px}.wf-btn-undo:disabled,.wf-btn-redo:disabled{opacity:.3;cursor:not-allowed;pointer-events:none}
