*{margin:0;padding:0;box-sizing:border-box}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:#1a1a1a;border-radius:6px}::-webkit-scrollbar-thumb{background:#4a4a4a;border-radius:6px;border:2px solid #1a1a1a}::-webkit-scrollbar-thumb:hover{background:#5a5a5a}::-webkit-scrollbar-thumb:active{background:#6a6a6a}::-webkit-scrollbar-corner{background:#1a1a1a}*{scrollbar-width:thin;scrollbar-color:#4a4a4a #1a1a1a}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow:hidden;background:#1a1a1a;color:#fff}#app{width:100vw;height:100vh;display:flex;flex-direction:column}#main-content{flex:1;display:flex;position:relative;overflow:hidden}#toolbar{background:linear-gradient(135deg,#2a2a2a,#242424);padding:12px 20px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 8px #0006;border-bottom:1px solid #3a3a3a}.toolbar-section{display:flex;align-items:center;gap:8px;justify-content:flex-end}.toolbar-branding{display:flex;align-items:center;gap:12px}.toolbar-logo{height:32px;width:auto;filter:brightness(0) invert(1)}.toolbar-branding h1{font-size:18px;font-weight:600;margin-right:20px;color:#fff;letter-spacing:.3px}.language-select{background:#4a4a4a66;color:#fff;border:1px solid #4a4a4a;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s ease;outline:none}.language-select:hover{background:#4a4a4a99;border-color:#6a6a6a}.language-select:focus{border-color:#6ab0ff;box-shadow:0 0 0 2px #6ab0ff33}.language-select option{background:#2d2d2d;color:#fff}.toolbar-actions{margin-left:auto;flex-wrap:wrap}.toolbar-menus{display:flex;gap:2px;margin-left:0}.toolbar-menu{position:relative}.toolbar-menu-btn{background:transparent;border:1px solid transparent;color:#ccc;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:all .15s ease;white-space:nowrap}.toolbar-menu-btn:hover,.toolbar-menu.open .toolbar-menu-btn{background:#ffffff1a;color:#fff}.debug-menu-btn{color:#ff9500!important;border:1px dashed rgba(255,149,0,.4)!important}.debug-menu-btn:hover,.toolbar-menu.open .debug-menu-btn{background:#ff950026!important;color:#ffb340!important;border-color:#ff950099!important}.toolbar-dropdown{position:absolute;top:100%;left:0;min-width:220px;background:#2a2a2a;border:1px solid #4a4a4a;border-radius:6px;box-shadow:0 8px 24px #00000080;padding:4px;z-index:10002;opacity:0;visibility:hidden;transform:translateY(-4px);transition:all .15s ease}.toolbar-menu.open .toolbar-dropdown{opacity:1;visibility:visible;transform:translateY(4px)}.dropdown-item{display:flex;align-items:center;justify-content:space-between;width:100%;background:transparent;border:none;color:#ddd;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:13px;text-align:left;transition:all .1s ease}.dropdown-item:hover:not(:disabled){background:#6ab0ff26;color:#fff}.dropdown-item:disabled{color:#666;cursor:not-allowed}.dropdown-item-label{flex:1}.dropdown-item-shortcut{font-size:11px;color:#888;margin-left:16px;font-family:SF Mono,Consolas,monospace}.dropdown-item:disabled .dropdown-item-shortcut{color:#555}.dropdown-separator{height:1px;background:#4a4a4a;margin:4px 8px}.dropdown-item-warning{color:#ffb74d}.dropdown-item-warning:hover:not(:disabled){background:#ff980033;color:#ffc947}.dropdown-item-discord{color:#7289da}.discord-icon{width:16px;height:16px;margin-right:8px;flex-shrink:0}.dropdown-item-discord:hover:not(:disabled){background:#7289da33;color:#7792f3}.dropdown-item-donate{color:#fff;font-family:Nunito,Quicksand,Comic Neue,sans-serif;font-weight:700}.dropdown-item-donate .dropdown-item-label{color:#fff}.donate-heart-icon{width:16px;height:16px;margin-right:8px;flex-shrink:0;color:#d90429}.dropdown-item-donate:hover:not(:disabled){background:#d9042940;color:#fff}.donate-tiny-heart{position:fixed;background-color:#d90429;box-shadow:0 0 30px 2px #ef233c99;animation:donate-heart-float var(--duration) ease-in-out forwards,donate-heart-fade var(--duration) ease-in-out forwards,donate-heart-bounce var(--duration) ease-out forwards,donate-heart-sway 1.3s ease-in-out infinite;animation-delay:0s,0s,0s,var(--sway-delay, 0s);z-index:999999;pointer-events:none}.donate-tiny-heart:before,.donate-tiny-heart:after{content:"";position:absolute;border-radius:50%;top:0;left:0;width:100%;height:100%;background-color:#d90429}.donate-tiny-heart:before{transform:translate(-50%)}.donate-tiny-heart:after{transform:translateY(-50%)}@keyframes donate-heart-float{0%{translate:0 0}to{translate:0 var(--float-height, -50px)}}@keyframes donate-heart-fade{0%{opacity:0}10%,70%{opacity:1}to{opacity:0}}@keyframes donate-heart-bounce{0%{scale:0}12%{scale:1.3}20%{scale:.9}50%,60%{scale:1}to{scale:0}}@keyframes donate-heart-sway{0%,to{transform:translate(2px) rotate(40deg)}50%{transform:translate(-2px) rotate(50deg)}}.toolbar-dropdown-help{min-width:280px;padding:0;overflow:hidden}.help-search-container{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#1a1a1a;border-bottom:1px solid #3a3a3a}.help-search-icon{width:16px;height:16px;fill:#888;flex-shrink:0}.help-search-input{flex:1;background:transparent;border:none;color:#fff;font-size:13px;outline:none}.help-search-input::placeholder{color:#666}.help-search-results{max-height:300px;overflow-y:auto;display:none}.help-search-results.visible{display:block;border-bottom:1px solid #3a3a3a}.help-search-result{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .1s ease}.help-search-result:hover{background:#6ab0ff26}.help-search-result-menu{font-size:10px;color:#888;background:#333;padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.5px}.help-search-result-label{flex:1;color:#ddd;font-size:13px}.help-search-result-shortcut{font-size:11px;color:#666;font-family:SF Mono,Consolas,monospace}.help-menu-items{padding:4px}.toolbar-standalone{margin-left:auto;padding-left:8px;border-left:1px solid #4a4a4a}.toolbar-separator{width:1px;height:28px;background:#4a4a4a;margin:0 4px}.toolbar-btn{background:#4a4a4a66;background:transparent;color:#fff;border:1px solid #4a4a4a;border:1px solid transparent;padding:8px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s ease;white-space:nowrap;display:flex;align-items:center;gap:8px;position:relative;overflow:hidden}.toolbar-btn:disabled{opacity:.5}.toolbar-btn svg{width:18px;height:18px;fill:currentColor;flex-shrink:0}.toolbar-btn span{line-height:1}.toolbar-btn:hover{background:#5a5a5a99;border-color:#5a5a5a;box-shadow:0 2px 8px #0000004d}.toolbar-btn:active{box-shadow:0 1px 3px #0000004d}.toolbar-btn-primary{background:linear-gradient(135deg,#4a90e2,#357abd);border-color:#357abd;color:#fff}.toolbar-btn-primary:hover{background:linear-gradient(135deg,#5aa0f2,#4585c7);border-color:#4585c7;box-shadow:0 2px 12px #4a90e266}.toolbar-btn-secondary{background:#ff980026;border-color:#ff9800;color:#ffb74d}.toolbar-btn-secondary:hover{background:#ff980040;border-color:#ffa726;color:#ffc947;box-shadow:0 2px 12px #ff98004d}.toolbar-btn-icon{padding:8px;min-width:auto}.toolbar-btn-icon span{display:none}.export-btn-group{display:flex;position:relative}.export-btn-main{border-top-right-radius:0;border-bottom-right-radius:0;border-right:none}.export-btn-arrow{border-top-left-radius:0;border-bottom-left-radius:0;padding:8px 6px;min-width:auto;border-left:1px solid rgba(255,255,255,.2)}.export-btn-arrow svg{width:12px;height:12px}.export-dropdown{position:absolute;top:100%;right:0;min-width:220px;background:linear-gradient(135deg,#4a90e2,#357abd);border:1px solid #357abd;border-radius:6px;box-shadow:0 8px 24px #357abd66;padding:4px;z-index:10002;opacity:0;visibility:hidden;transform:translateY(-4px);transition:all .15s ease;margin-top:4px}.export-dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}.export-dropdown .dropdown-item{flex-direction:column;align-items:flex-start;gap:2px;color:#fff}.export-dropdown .dropdown-item:hover:not(:disabled){background:#fff3}.export-dropdown .dropdown-item-desc{font-size:11px;color:#ffffffb3;font-weight:400}.export-dropdown .dropdown-item:hover .dropdown-item-desc{color:#ffffffe6}#clearBtn{background:#e74c3c}#clearBtn:hover{background:#c0392b}#canvas-container{flex:1;position:relative;overflow:hidden;background:#1a1a1a;transition:margin-right .3s ease}#sidebar{width:300px;background:#2a2a2a;border-left:2px solid #4a4a4a;display:none;flex-direction:column;overflow:hidden}#sidebar.open{display:flex}#sidebar-header{background:#333;padding:15px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid #4a4a4a}#sidebar-header h2{font-size:16px;margin:0;color:#fff}#closeSidebarBtn{background:transparent!important;color:#aaa!important;border:none!important;font-size:24px;padding:0!important;width:30px;height:30px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:3px;transform:none!important;box-shadow:none!important}#closeSidebarBtn:hover{background:#4a4a4a!important;color:#fff!important;transform:none!important;box-shadow:none!important}#sidebar-content{flex:1;overflow-y:auto;padding:15px}#no-output-msg{color:#888;text-align:center;padding:20px;font-style:italic}#dependency-list{display:none}#dependency-list.visible{display:block}.dependency-group{margin-bottom:20px}.dependency-group-header{font-size:12px;color:#888;text-transform:uppercase;margin-bottom:8px;font-weight:700}.dependency-node{background:#1a1a1a;border-left:3px solid;padding:10px 12px;margin-bottom:6px;border-radius:3px;cursor:pointer;transition:background .2s}.dependency-node:hover{background:#252525}.dependency-node-title{font-weight:700;font-size:13px;margin-bottom:3px}.dependency-node-type{font-size:11px;color:#888}#canvas{width:100%;height:100%;display:block;cursor:default}#minimap-container{position:absolute;top:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:1000}#minimap{width:200px;height:150px;background:#2a2a2ae6;border:2px solid #4a4a4a;border-radius:8px;box-shadow:0 4px 20px #00000080;cursor:pointer}#minimap-controls{display:flex;gap:4px;align-items:center;background:#2a2a2ae6;border:2px solid #4a4a4a;border-radius:8px;padding:6px;box-shadow:0 4px 20px #00000080}.minimap-control-btn{background:#4a4a4a80;border:1px solid #5a5a5a;color:#fff;padding:4px;border-radius:4px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;width:24px;height:24px;position:relative}.minimap-control-btn svg{width:16px;height:16px;fill:currentColor}.minimap-control-btn:hover{background:#6a6a6ab3;border-color:#7a7a7a}.minimap-control-btn:active{background:#5a5a5acc;transform:scale(.95)}.minimap-control-btn:before{content:attr(title);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#1e1e1ef2;color:#fff;padding:6px 10px;border-radius:4px;font-size:12px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;z-index:10000;box-shadow:0 2px 8px #00000080;border:1px solid #4a4a4a}.minimap-control-btn:after{content:"";position:absolute;bottom:calc(100% + 2px);left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1e1e1ef2;opacity:0;pointer-events:none;transition:opacity .2s;z-index:10000}.minimap-control-btn:hover:before,.minimap-control-btn:hover:after{opacity:1}.zoom-level-display{background:#4a4a4a80;border:1px solid #5a5a5a;color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;font-family:Courier New,monospace;min-width:40px;text-align:center;-webkit-user-select:none;user-select:none;position:relative}.zoom-level-display:before{content:attr(title);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#1e1e1ef2;color:#fff;padding:6px 10px;border-radius:4px;font-size:12px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;z-index:10000;box-shadow:0 2px 8px #00000080;border:1px solid #4a4a4a}.zoom-level-display:after{content:"";position:absolute;bottom:calc(100% + 2px);left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1e1e1ef2;opacity:0;pointer-events:none;transition:opacity .2s;z-index:10000}.zoom-level-display:hover:before,.zoom-level-display:hover:after{opacity:1}:root{--node-bg: #2d2d2d;--node-border: #4a4a4a;--node-header: #3a3a3a;--port-color: #4a90e2;--wire-color: #4a90e2}#portValueInput{position:fixed;background:#1a1a1a;color:#fff;border:2px solid #4a90e2;padding:0;font-size:11px;font-family:monospace;border-radius:3px;outline:none;text-align:center;z-index:10000;display:none;visibility:hidden;opacity:0;pointer-events:none;transition:none;box-sizing:border-box}#portValueInput:focus{border-color:#6ab0ff;box-shadow:0 0 5px #4a90e280}.search-menu{position:fixed;background:#2a2a2a;border:2px solid #4a4a4a;border-radius:8px;box-shadow:0 4px 20px #00000080;display:none;flex-direction:column;width:300px;max-height:400px;z-index:10001;overflow:hidden}.search-menu.visible{display:flex}#searchInput{background:#1a1a1a;color:#fff;border:none;border-bottom:2px solid #4a4a4a;padding:8px 12px;font-size:14px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;outline:none}#searchInput:focus{border-bottom-color:#4a90e2}.search-results{flex:1;overflow-y:auto;padding:2px}.search-result-item{padding:4px 6px;cursor:pointer;border-radius:4px;margin-bottom:2px;transition:background .15s;display:flex;align-items:center;gap:10px;outline:none}.search-result-item:hover,.search-result-item:focus{background:#3a3a3a}.search-result-item.search-selected{background:#4f4f4f;color:#fff}.search-result-item.search-selected:hover{background:#5f5f5f}.search-result-color{width:12px;height:12px;border-radius:2px;flex-shrink:0}.search-result-name{flex:1;font-size:13px;color:#fff}.search-result-type{font-size:11px;color:#888}.search-results::-webkit-scrollbar{width:8px}.search-results::-webkit-scrollbar-track{background:#1a1a1a}.search-results::-webkit-scrollbar-thumb{background:#4a4a4a;border-radius:4px}.search-results::-webkit-scrollbar-thumb:hover{background:#5a5a5a}.search-category-header{padding:8px 10px;font-size:11px;font-weight:700;text-transform:uppercase;color:#888;background:#222;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative;margin-top:4px;border-radius:3px;transition:background .15s}.search-category-header:first-child{margin-top:0}.search-category-header:hover{background:#2a2a2a;color:#aaa}.search-category-header:before{content:"▼";display:inline-block;margin-right:6px;font-size:8px;transition:transform .2s;transform:rotate(-90deg)}.search-category-header.expanded:before{transform:rotate(0)}.search-category-content{max-height:1000px;overflow:hidden;transition:max-height .3s ease,opacity .2s ease;opacity:1}.search-category-content.collapsed{max-height:0;opacity:0}#uniform-sidebar{width:320px;background:#2a2a2a;border-right:2px solid #4a4a4a;display:flex;flex-direction:column;overflow-y:auto}.sidebar-section-header{background:#333;padding:8px 12px;border-bottom:2px solid #4a4a4a;position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.sidebar-section-header:hover{background:#3a3a3a}.sidebar-section-header h2{font-size:15px;margin:0;color:#fff;flex:1}.collapse-btn{background:transparent!important;border:none!important;color:#888!important;font-size:12px;padding:4px 8px!important;cursor:pointer;transition:transform .2s,color .2s;min-width:auto;box-shadow:none!important}.collapse-btn:hover{background:transparent!important;color:#fff!important;transform:translateY(0)!important;box-shadow:none!important}.collapsible-section.collapsed .collapse-btn{transform:rotate(-90deg)}.sidebar-section-content{padding:12px;max-height:2000px;overflow:hidden;transition:max-height .3s ease,padding .3s ease}.collapsible-section.collapsed .sidebar-section-content{max-height:0;padding-top:0;padding-bottom:0}#shader-settings-section{border-bottom:2px solid #4a4a4a}.settings-form{display:flex;flex-direction:column;gap:4px}.settings-form label{display:flex;flex-direction:row;align-items:center;gap:8px;font-size:13px;color:#aaa}.settings-form label>span{font-weight:500;color:#ccc;min-width:50px;flex-shrink:0}.settings-form label:has(textarea){flex-direction:column;align-items:stretch;gap:4px}.settings-form label:has(textarea)>span{min-width:auto}.settings-form input[type=text],.settings-form input[type=url],.settings-form input[type=number],.settings-form select,.settings-form textarea{background:#1a1a1a;border:1px solid #4a4a4a;color:#fff;padding:6px 4px;border-radius:4px;font-size:13px;font-family:inherit;transition:border-color .2s;flex:2;height:32px}.settings-form input:focus,.settings-form select:focus,.settings-form textarea:focus{outline:none;border-color:#4a90e2}.settings-form textarea{resize:vertical;min-height:60px}.checkbox-label{flex-direction:row!important;align-items:center;gap:8px!important;cursor:pointer}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#4a90e2;margin:2px 0 1px}.checkbox-label span{color:#ccc;-webkit-user-select:none;user-select:none}.extend-box-inputs{display:flex;gap:8px;width:100%}.extend-box-inputs input{flex:1;min-width:0;width:0}#uniform-sidebar-header{background:#333;padding:15px 20px;border-bottom:2px solid #4a4a4a}#uniform-sidebar-header h2{font-size:16px;margin:0;color:#fff}#uniform-sidebar-content{flex:1;overflow-y:auto;padding:15px}.add-uniform-btn{width:100%;background:transparent;color:#4a90e2;border:1px solid #4a90e2;padding:10px;border-radius:5px;cursor:pointer;font-size:14px;margin-bottom:10px;transition:background .2s}.add-uniform-btn:hover{background:#4a91e21f}#uniform-list{display:flex;flex-direction:column;gap:10px}.uniform-item{background:#333;border:1px solid #4a4a4a;border-radius:5px;padding:8px;display:flex;flex-direction:column;gap:6px;transition:border-color .2s;position:relative}.uniform-item:hover{border-color:#4a90e2}.uniform-item.dragging{opacity:.5}.uniform-item-header{display:flex;align-items:center;gap:8px}.uniform-drag-handle{color:#666;font-size:14px;cursor:grab;padding:2px;-webkit-user-select:none;user-select:none;line-height:1;transition:color .2s}.uniform-drag-handle:hover{color:#4a90e2}.uniform-drag-handle:active{cursor:grabbing}.uniform-item-name{font-weight:700;color:#4a90e2;font-size:14px}.uniform-item-name-input{background:transparent;border:none;color:#4a90e2;font-weight:700;font-size:13px;font-family:inherit;padding:1px 3px;border-radius:3px;transition:background .2s;min-width:80px;flex:1}.uniform-item-name-input:hover{background:#4a90e21a}.uniform-item-name-input:focus{outline:none;background:#4a90e233}.uniform-item-type{font-size:12px;color:#888}.uniform-item-controls{display:flex;gap:8px;align-items:center}.uniform-delete-btn{background:#e24a4a;color:#fff;border:none;padding:4px 8px;border-radius:3px;cursor:pointer;font-size:12px;transition:background .2s}.uniform-delete-btn:hover{background:#c23a3a}.uniform-value-control{display:flex;flex-direction:column;gap:4px}.uniform-value-control label{font-size:12px;color:#aaa}.uniform-value-control input[type=number],.uniform-value-control input[type=range]{width:100%;background:#1a1a1a;border:1px solid #4a4a4a;color:#fff;padding:6px;border-radius:3px;font-size:12px}.uniform-value-control input[type=color]{width:100%;height:40px;background:#1a1a1a;border:1px solid #4a4a4a;border-radius:3px;cursor:pointer}.uniform-percent-display{display:flex;align-items:center;gap:8px}.uniform-percent-display input[type=range]{flex:1}.uniform-percent-display span{min-width:45px;text-align:right;font-size:12px;color:#4a90e2}.uniform-float-display{display:flex;align-items:center;gap:8px}.uniform-float-display input[type=range]{flex:1}.uniform-float-display input[type=number]{width:60px;text-align:center}.uniform-name-container{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.uniform-info-line{display:flex;align-items:center;gap:4px;font-size:10px;color:#888;flex-wrap:wrap}.uniform-variable-name,.uniform-item-type-inline{color:#888;font-size:10px}.uniform-description-input{background:transparent;border:none;color:#aaa;font-size:10px;font-family:inherit;padding:0;min-width:60px;flex:1}.uniform-description-input:focus{outline:none;color:#ccc}.uniform-add-desc-btn{background:transparent;border:1px solid #4a4a4a;color:#888;padding:1px 4px;border-radius:2px;cursor:pointer;font-size:9px;transition:all .2s}.uniform-add-desc-btn:hover{border-color:#4a90e2;color:#4a90e2}.uniform-float-compact{display:flex;flex-direction:column;gap:4px}.uniform-input-row{display:flex;align-items:center;gap:6px}.uniform-number-input-compact{flex:1;background:#1a1a1a;border:1px solid #4a4a4a;color:#fff;padding:4px 6px;border-radius:3px;font-size:12px}.checkbox-label-compact{display:flex;align-items:center;gap:3px;cursor:pointer;font-size:11px;color:#888;-webkit-user-select:none;user-select:none}.checkbox-label-compact input[type=checkbox]{margin:0;cursor:pointer}.checkbox-label-compact span{color:#888}.uniform-percent-display-compact{display:flex;align-items:center;gap:6px}.uniform-percent-display-compact input[type=range]{flex:1;height:4px}.percent-text-compact{min-width:35px;text-align:right;font-size:11px;color:#4a90e2}.uniform-value-control input[type=color]{width:100%;height:32px;background:#1a1a1a;border:1px solid #4a4a4a;border-radius:3px;cursor:pointer;padding:2px}.uniform-modal{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000b3;z-index:10000;justify-content:center;align-items:center}.uniform-modal.visible{display:flex}.uniform-modal-content{background:#2a2a2a;border:2px solid #4a4a4a;border-radius:8px;padding:25px;min-width:350px;display:flex;flex-direction:column;gap:15px}.uniform-modal-content h3{margin:0;font-size:18px;color:#fff}.uniform-modal-content label{display:flex;flex-direction:column;gap:6px;font-size:14px;color:#aaa}.uniform-modal-content input,.uniform-modal-content select,.uniform-modal-content textarea{background:#1a1a1a;border:1px solid #4a4a4a;color:#fff;padding:10px;border-radius:5px;font-size:14px;font-family:inherit}.color-input-wrapper{display:flex;gap:10px;align-items:center;pointer-events:all}.color-input-label{pointer-events:all}.color-input-wrapper input[type=color]{width:60px;height:40px;padding:2px;cursor:pointer;border:2px solid #4a4a4a}.color-input-wrapper input[type=text]{flex:1;font-family:Courier New,monospace;text-transform:uppercase}.uniform-modal-buttons{display:flex;gap:10px;justify-content:flex-end;margin-top:10px}.uniform-modal-buttons button{padding:10px 20px;border-radius:5px;border:none;cursor:pointer;font-size:14px;transition:background .2s}#uniformModalCancel{background:#4a4a4a;color:#fff}#uniformModalCancel:hover{background:#5a5a5a}#uniformModalAdd{background:#4a90e2;color:#fff}#uniformModalAdd:hover{background:#357abd}.custom-node-modal{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000b3;z-index:10000;justify-content:center;align-items:center;overflow-y:auto}.custom-node-modal.visible{display:flex}.custom-node-modal-content{background:#2a2a2a;border:2px solid #4a4a4a;border-radius:8px;padding:25px;min-width:900px;max-width:1200px;max-height:90vh;overflow-y:auto;margin:20px}.custom-node-modal-content h3{margin:0 0 20px;font-size:20px;color:#fff}.custom-node-modal-content h4{margin:0 0 10px;font-size:14px;color:#4a90e2;font-weight:700}.custom-node-form{display:flex;flex-direction:column;gap:6px}.custom-node-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#aaa}.custom-node-form input,.custom-node-form select,.custom-node-form textarea{background:#1a1a1a;border:1px solid #4a4a4a;color:#fff;padding:8px;border-radius:5px;font-size:13px;font-family:Courier New,monospace}.custom-node-form input[type=color]{width:100%;height:32px;background:#1a1a1a;border:1px solid #4a4a4a;border-radius:3px;cursor:pointer;padding:2px}.custom-node-form textarea{resize:vertical;min-height:60px}.custom-node-section{border:1px solid #3a3a3a;border-radius:5px;padding:15px;background:#252525}.custom-nodes-list{display:flex;flex-direction:column;gap:10px}.custom-node-header{display:flex;flex-direction:row;gap:15px;padding:20px;background:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px}.custom-node-header-row{display:flex;gap:5px;align-items:center;flex-direction:row;flex:3}.custom-node-header-row:first-child{padding-bottom:15px;border-bottom:1px solid #2a2a2a;flex-direction:column;flex:1}.custom-node-header-row>label{display:flex;align-items:center}.custom-node-header-row>label>span{font-size:12px;font-weight:500;color:#888;text-transform:uppercase;letter-spacing:.5px}.custom-node-header-row .name-label{flex:1;align-items:start;width:100%}.custom-node-header-row .name-label>input[type=text]{flex:1;min-width:0;font-size:14px;padding:10px 12px}.custom-node-header-row .color-label{flex:0 0 auto;align-items:start;width:100%}.custom-node-header-row .color-label>input[type=color]{width:100%;height:38px;cursor:pointer;border-radius:6px;padding:3px}.custom-node-header-row .checkbox-label{flex:0 0 auto;width:100%;flex-direction:row!important;align-items:center;gap:5px;padding:8px;border-radius:6px;cursor:pointer;transition:background .2s}.custom-node-header-row .checkbox-label:hover{background:#2a2a2a}.custom-node-header-row .checkbox-label input[type=checkbox]{width:16px;height:16px;margin:0;cursor:pointer;accent-color:#4a90e2}.custom-node-header-row .checkbox-label>span{font-size:12px;font-weight:500;color:#aaa;text-transform:lowercase}.custom-node-ports-section{display:flex;gap:5px;width:100%}.custom-node-ports-column{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.custom-node-ports-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.custom-node-ports-column h4{margin:0;font-size:14px;color:#4a90e2;font-weight:700}.add-port-btn-small{width:24px;height:24px;min-width:24px;background:#4a90e2;border:none;color:#fff;border-radius:4px;cursor:pointer;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0;transition:all .2s;line-height:1}.add-port-btn-small:hover{background:#5ba3ff;transform:scale(1.1)}.add-port-btn-small:active{transform:scale(.95)}.custom-node-ports-list{display:flex;flex-direction:column;gap:0px;min-height:130px;max-height:130px;overflow-y:auto;overflow-x:hidden;padding-right:5px;background:#1a1a1a;flex:1;width:100%}.custom-node-ports-list::-webkit-scrollbar{width:8px}.custom-node-ports-list::-webkit-scrollbar-track{background:#1a1a1a;border-radius:4px}.custom-node-ports-list::-webkit-scrollbar-thumb{background:#4a4a4a;border-radius:4px}.custom-node-ports-list::-webkit-scrollbar-thumb:hover{background:#5a5a5a}.custom-node-code-section{display:flex;flex-direction:column;gap:0;border:1px solid #3a3a3a;border-radius:5px;overflow:hidden;background:#1a1a1a}.custom-node-code-header{display:flex;justify-content:space-between;align-items:center;padding:10px 15px;background:#1a1a1a;border-bottom:1px solid #3a3a3a}.code-type-tabs,.shader-lang-tabs{display:flex;gap:5px}.code-tab,.shader-tab{background:#2a2a2a;border:1px solid #3a3a3a;color:#aaa;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s}.code-tab:hover,.shader-tab:hover{background:#3a3a3a;color:#fff}.code-tab.active,.shader-tab.active{background:#4a90e2;color:#fff;border-color:#4a90e2}.shader-tab.disabled{opacity:.4;cursor:not-allowed}.shader-tab.disabled:hover{background:#2a2a2a;color:#aaa}.custom-node-code-editor{padding:0;background:#0d0d0d;flex:1;display:flex;flex-direction:column;min-height:400px;max-height:500px;overflow:hidden}.custom-node-code-editor>div{flex:1;overflow:auto}.custom-node-code-editor .cm-editor{height:100%;font-size:13px;font-family:Consolas,Monaco,Courier New,monospace}.custom-node-code-editor .cm-scroller{overflow:auto;min-height:100%}.custom-node-code-editor .cm-content{min-height:100%}.custom-node-code-editor .cm-gutters{background:#0a0a0a;border-right:1px solid #2a2a2a}.custom-node-code-editor .cm-lineNumbers{color:#555}.custom-node-code-editor .cm-activeLineGutter{background:#1a1a1a}.custom-node-code-editor .cm-activeLine{background:#ffffff08}.custom-node-code-editor .cm-content{padding:8px 0}.custom-node-code-editor .cm-line{padding:0 8px}.custom-port-item{display:flex;gap:4px;align-items:center;padding:2px;border-radius:4px}.custom-port-item input{flex:1;min-width:0;width:0}.custom-port-item select{width:120px}.custom-port-item button{background:#e24a4a;color:#fff;border:none;padding:6px 10px;border-radius:3px;cursor:pointer;font-size:12px}.custom-port-item button:hover{background:#c93a3a}.add-port-btn{background:#4a4a4a;color:#fff;border:none;padding:8px 15px;border-radius:5px;cursor:pointer;font-size:13px;width:100%;transition:background .2s}.add-port-btn:hover{background:#5a5a5a}.custom-node-modal-buttons{display:flex;gap:10px;justify-content:flex-end;margin-top:10px;padding-top:15px;border-top:1px solid #3a3a3a}.custom-node-modal-buttons button{padding:10px 20px;border-radius:5px;border:none;cursor:pointer;font-size:14px;transition:background .2s}.primary-btn{background:#4a90e2;color:#fff}.primary-btn:hover{background:#357abd}.secondary-btn{background:#4a4a4a;color:#fff}.secondary-btn:hover{background:#5a5a5a}.custom-node-drag-handle{transition:opacity .2s}.custom-node-drag-handle:hover{opacity:.8}.custom-node-drag-handle:active{cursor:grabbing!important}#openPreviewBtn{position:fixed;bottom:20px;right:20px;width:48px;height:48px;background:#4a90e2;border:none;padding:0;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000080;z-index:1000;transition:all .2s}#openPreviewBtn:hover{background:#5ba3ff;transform:scale(1.05);box-shadow:0 6px 16px #0009}#openPreviewBtn svg{width:24px;height:24px;fill:currentColor}#preview-window{position:fixed;bottom:20px;right:20px;width:400px;height:300px;background:#2a2a2a;border:2px solid #4a4a4a;border-radius:8px;overflow:hidden;z-index:1000;display:flex;flex-direction:column;box-shadow:0 4px 12px #00000080;resize:both;min-width:200px;min-height:150px}#preview-content{flex:1;position:relative;overflow:hidden}#preview-header{background:#1a1a1a;padding:8px 12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #4a4a4a;cursor:move;-webkit-user-select:none;user-select:none}#preview-header span{color:#fff;font-size:13px;font-weight:700}.preview-header-buttons{display:flex;gap:4px}#reloadPreviewBtn{background:none;border:none;color:#fff;cursor:pointer;padding:4px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:background .2s}#reloadPreviewBtn:hover{background:#4a90e2}#reloadPreviewBtn svg{width:20px;height:20px;fill:currentColor}#closePreviewBtn{background:none;border:none;color:#fff;cursor:pointer;padding:4px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:background .2s}#closePreviewBtn:hover{background:#e24a4a}#closePreviewBtn svg{width:20px;height:20px;fill:currentColor}#screenshotPreviewBtn{background:none;border:none;color:#fff;cursor:pointer;padding:4px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:background .2s}#screenshotPreviewBtn:hover{background:#4a90e2}#screenshotPreviewBtn svg{width:20px;height:20px;fill:currentColor}#preview-controls{position:absolute;top:0;left:0;right:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:0;display:flex;flex-direction:column;z-index:10;border-bottom:1px solid rgba(74,74,74,.5);box-shadow:0 2px 8px #0000004d;transition:transform .3s ease,opacity .3s ease;transform-origin:top;height:calc(100% - 28px)}#preview-controls.preview-controls-hidden{transform:translateY(-100%);opacity:0;pointer-events:none}#preview-controls.preview-controls-visible{transform:translateY(0);opacity:1}.preview-tabs{display:flex;gap:0;background:#0006;border-bottom:1px solid rgba(74,74,74,.5);flex-shrink:0}.preview-tab{background:transparent;border:none;color:#aaa;padding:8px 16px;cursor:pointer;font-size:12px;font-weight:500;border-bottom:2px solid transparent;transition:all .2s}.preview-tab:hover{color:#fff;background:#ffffff0d}.preview-tab.active{color:#4a90e2;border-bottom-color:#4a90e2;background:#4a90e21a}.preview-tab-content{display:none;padding:10px 12px;gap:10px;flex-wrap:wrap;align-items:center;max-height:100%;overflow-y:auto}.preview-tab-content.active{display:flex}.preview-tab-content[data-tab=script].active{display:flex;flex-direction:column;padding:12px}.script-tab-container{display:flex;flex-direction:column;width:100%;height:100%;gap:8px}.script-tab-header{display:flex;flex-direction:column;gap:4px}.script-tab-header label{color:#fff;font-size:13px;font-weight:500}.script-tab-hint{color:#888;font-size:11px;line-height:1.4}.script-tab-hint code{background:#4a9eff26;color:#4a9eff;padding:1px 5px;border-radius:3px;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:10px}.script-editor{width:100%;flex:1;min-height:200px;background:#0d0d0d;border:1px solid #3a3a3a;border-radius:6px;color:#e8e8e8;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:12px;line-height:1.5;padding:12px;resize:none;outline:none;-moz-tab-size:2;tab-size:2}.script-editor:focus{border-color:#4a9eff;box-shadow:0 0 0 2px #4a9eff26}.script-editor::placeholder{color:#555}.preview-control-group{display:flex;align-items:center;gap:6px}.preview-control-group label{color:#fff;font-size:12px;white-space:nowrap;text-shadow:0 0 4px rgba(0,0,0,1);display:flex;align-items:center;gap:4px}.preview-control-group select{background:#0007;border:1px solid #4a4a4a;color:#fff;text-shadow:0 0 4px rgba(0,0,0,1);padding:4px 8px;border-radius:4px;font-size:12px;cursor:pointer;outline:none}.preview-control-group select:hover{border-color:#6a6a6a}.preview-control-group select:focus{border-color:#4a9eff}.preview-control-group input[type=checkbox]{cursor:pointer;width:14px;height:14px}.preview-slider-group{width:100%}.preview-slider-container{display:flex;align-items:center;gap:8px;flex:1}.preview-slider-container input[type=range]{flex:1;height:4px;background:#333;border-radius:2px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.preview-slider-container input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;background:#4a90e2;border-radius:50%;cursor:pointer;transition:background .2s}.preview-slider-container input[type=range]::-webkit-slider-thumb:hover{background:#5ba3ff}.preview-slider-container input[type=range]::-moz-range-thumb{width:12px;height:12px;background:#4a90e2;border-radius:50%;border:none;cursor:pointer}.preview-slider-container span{min-width:35px;text-align:right;font-size:11px;color:#4a90e2;font-family:Courier New,monospace}.editable-slider-value{cursor:pointer;padding:2px 4px;border-radius:3px;transition:background .2s}.editable-slider-value:hover{background:#4a90e233}.editable-slider-value.editing{background:#1a1a1a;outline:1px solid #4a90e2}.slider-value-input{width:45px;background:#1a1a1a;border:1px solid #4a90e2;border-radius:3px;color:#4a90e2;font-size:11px;font-family:Courier New,monospace;text-align:right;padding:2px 4px;outline:none;-moz-appearance:textfield}.slider-value-input::-webkit-outer-spin-button,.slider-value-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.slider-value-input::selection{background:#ffffff4d;color:#fff}.preview-texture-group{width:100%}.texture-preview-container{display:flex;align-items:center;gap:2px}.texture-preview{width:40px;height:40px;background:#000;border:1px solid #4a4a4a;border-radius:4px;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.texture-preview span{font-size:9px;color:#666;text-align:center;padding:2px}.texture-preview img{width:100%;height:100%;object-fit:cover}.texture-btn{background:none;border:1px solid transparent;color:#fff;padding:4px;border-radius:4px;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.texture-btn svg{width:22px;height:22px;fill:currentColor;pointer-events:none}.texture-btn svg *{pointer-events:none}.texture-btn:hover{border-color:#6a6a6a;background:#3a3a3acc}.texture-clear-btn{background:none;border:1px solid transparent;color:#e24a4a;font-size:20px;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:all .2s}.texture-clear-btn svg{width:16px;height:16px;fill:currentColor;pointer-events:none}.texture-clear-btn svg *{pointer-events:none}.texture-clear-btn:hover{background:#e24a4a33;border-color:#e24a4a}.reset-preview-btn{background:#6d00004e;border:1px solid #e24a4a;color:#ff4343;padding:4px 8px;border-radius:4px;font-size:12px;text-shadow:0 0 4px rgba(0,0,0,1);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;width:100%;margin-top:4px}.reset-preview-btn:hover{background:#e24a4a40;border-color:#ff5a5a;color:#ff5a5a}#togglePreviewSettingsBtn{background:none;border:none;color:#fff;cursor:pointer;padding:4px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:all .2s}#togglePreviewSettingsBtn:hover{background:#ffffff1a}#togglePreviewSettingsBtn.active{background:#4a90e2;color:#fff}#togglePreviewSettingsBtn.active:hover{background:#5ba3ff}#togglePreviewSettingsBtn svg{width:20px;height:20px;fill:currentColor}#preview-iframe{position:absolute;top:0;left:0;border:none;width:100%;height:100%;background:#000}#viewCodeModal{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000b3;z-index:10000;justify-content:center;align-items:center}.view-code-modal{background:#2a2a2a;border:2px solid #4a4a4a;border-radius:8px;width:90%;max-width:1200px;height:80vh;display:flex;flex-direction:column;overflow:hidden}.view-code-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #4a4a4a}.view-code-modal .modal-header h2{margin:0;font-size:18px;color:#fff}.view-code-modal .modal-close{background:transparent;border:none;color:#aaa;font-size:24px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.view-code-modal .modal-close:hover{background:#4a4a4a;color:#fff}.view-code-modal .modal-body{flex:1;display:flex;flex-direction:column;overflow:hidden}.code-tabs{display:flex;gap:0;background:#1a1a1a;border-bottom:1px solid #4a4a4a}.code-tab{background:transparent;border:none;color:#aaa;padding:12px 24px;cursor:pointer;font-size:14px;border-bottom:2px solid transparent;transition:all .2s;position:relative}.code-tab:hover{color:#fff;background:#2a2a2a}.code-tab.active{color:#4a90e2;background:#2a2a2a;border-bottom-color:#4a90e2}.code-panels{flex:1;position:relative;overflow:hidden;background:#1e1e1e}.code-panel{display:none;height:100%;overflow:hidden}.code-panel.active{display:flex;flex-direction:column}.code-panel .cm-editor{height:100%;font-size:13px;font-family:Consolas,Monaco,Courier New,monospace}.code-panel .cm-scroller{overflow:auto;min-height:100%}.code-panel .cm-content{min-height:100%}.code-panel .cm-gutters{background:#0a0a0a;border-right:1px solid #2a2a2a}.code-panel .cm-lineNumbers{color:#555}.code-panel .cm-activeLineGutter{background:#1a1a1a}.code-panel .cm-activeLine{background:#ffffff08}.code-panel .cm-line{padding:0 8px}.view-code-modal .modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:15px 25px;border-top:1px solid #4a4a4a;background:#2a2a2a}.view-code-modal .modal-footer button{padding:10px 20px;border-radius:5px;border:none;cursor:pointer;font-size:14px;transition:background .2s}#copyCodeBtn{background:#4a4a4a;color:#fff}#copyCodeBtn:hover{background:#5a5a5a}#viewCodeModalOk{background:#4a90e2;color:#fff}#viewCodeModalOk:hover{background:#357abd}#openFilesModal{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000c;z-index:10000;justify-content:center;align-items:center}.open-files-modal{background:#2a2a2a;border:2px solid #4a4a4a;border-radius:8px;width:90%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;overflow:auto}.open-files-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #4a4a4a}.open-files-modal .modal-header h2{margin:0;font-size:18px;color:#fff}.open-files-modal .modal-close{background:transparent;border:none;color:#aaa;font-size:24px;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.open-files-modal .modal-close:hover{background:#4a4a4a;color:#fff}.modal-tabs{display:flex;gap:0;background:#1a1a1a;border-bottom:1px solid #4a4a4a}.modal-tab{background:transparent;border:none;color:#aaa;padding:12px 24px;cursor:pointer;font-size:14px;border-bottom:2px solid transparent;transition:all .2s;position:relative}.modal-tab:hover{color:#fff;background:#2a2a2a}.modal-tab.active{color:#4a90e2;background:#2a2a2a;border-bottom-color:#4a90e2}.open-files-modal .modal-body{flex:1;overflow-y:auto;padding:20px;min-height:560px;position:relative}@media (max-height: 890px){.open-files-modal .modal-body{min-height:280px}}.open-files-modal .modal-body:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-100%,-50%);width:560px;height:560px;background-image:url(/construct-shader-graph/favicon.svg);background-size:contain;background-repeat:no-repeat;background-position:center;pointer-events:none;z-index:0;opacity:.03;filter:brightness(0) invert(1)}.modal-tab-content{display:none;position:relative;z-index:1}.modal-tab-content.active{display:block}.examples-grid,.recent-files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px;position:relative;z-index:1}.recent-files-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:500px;color:#888;text-align:center;position:relative;z-index:1}.recent-files-empty p{margin:0;font-size:16px}.example-card,.recent-file-card{background:#1a1a1a;border:2px solid #3a3a3a;border-radius:8px;overflow:hidden;cursor:pointer;transition:all .2s;position:relative}.example-card:hover,.recent-file-card:hover{border-color:#6ab0ff;transform:translateY(-2px);box-shadow:0 4px 12px #6ab0ff33}.example-preview,.recent-file-preview{width:100%;height:150px;background:#2a2a2a;display:flex;align-items:center;justify-content:center;overflow:hidden}.example-preview img,.recent-file-preview img{width:100%;height:100%;object-fit:cover}.example-preview-placeholder,.recent-file-preview-placeholder{width:64px;height:64px;opacity:.3}.example-info,.recent-file-info{padding:15px}.example-name,.recent-file-name{font-size:16px;font-weight:600;color:#fff;margin:0 0 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.example-description,.recent-file-date{font-size:12px;color:#888;margin:0;line-height:1.4}.recent-file-remove{position:absolute;top:8px;right:8px;background:#e24a4ae6;border:none;color:#fff;width:28px;height:28px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s;z-index:10}.recent-file-card:hover .recent-file-remove{opacity:1}.recent-file-remove:hover{background:#e24a4a;transform:scale(1.1)}.recent-file-remove svg{width:16px;height:16px;fill:currentColor}.open-files-modal .modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:15px 25px;border-top:1px solid #4a4a4a;background:#2a2a2a}.open-files-modal .modal-footer button{padding:10px 20px;border-radius:5px;border:none;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;display:flex;align-items:center;gap:8px}.open-files-modal .modal-footer button svg{flex-shrink:0}#openFilesNewBtn,#openFilesOpenBtn{background:#4a90e2;color:#fff}#openFilesNewBtn:hover,#openFilesOpenBtn:hover{background:#357abd}#openFilesModalCancel{background:#4a4a4a;color:#fff}#openFilesModalCancel:hover{background:#5a5a5a}#clearRecentFilesBtn{background:transparent;border:none;color:#888;padding:0;font-size:13px;text-decoration:underline;cursor:pointer;transition:color .2s}#clearRecentFilesBtn:hover{color:#e24a4a}#notification-container{position:fixed;bottom:20px;left:340px;z-index:10000;display:flex;flex-direction:column-reverse;gap:10px;pointer-events:none;max-width:380px}.notification{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:#2d2d2d;border-radius:8px;box-shadow:0 4px 20px #0006,0 0 0 1px #ffffff0d;pointer-events:auto;animation:notificationSlideIn .3s cubic-bezier(.34,1.56,.64,1);min-width:280px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.notification.exiting{animation:notificationSlideOut .25s ease-in forwards}@keyframes notificationSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes notificationSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.notification-icon{width:22px;height:22px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:50%;margin-top:1px}.notification.success .notification-icon{background:#4caf5033;color:#4caf50}.notification.error .notification-icon{background:#f4433633;color:#f44336}.notification.warning .notification-icon{background:#ff980033;color:#ff9800}.notification.info .notification-icon{background:#4a90e233;color:#4a90e2}.notification-content{flex:1;min-width:0}.notification-title{font-size:13px;font-weight:600;color:#fff;margin-bottom:2px}.notification-message{font-size:12px;color:#a0a0a0;line-height:1.4;word-break:break-word}.notification-close{background:none;border:none;color:#666;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:4px;flex-shrink:0;transition:all .15s;margin-left:4px}.notification-close:hover{background:#ffffff1a;color:#fff}.notification-close svg{width:14px;height:14px}.notification-progress{position:absolute;bottom:0;left:0;height:3px;background:currentColor;opacity:.4;border-radius:0 0 8px 8px;animation:notificationProgress linear forwards}.notification.success .notification-progress{background:#4caf50}.notification.error .notification-progress{background:#f44336}.notification.warning .notification-progress{background:#ff9800}.notification.info .notification-progress{background:#4a90e2}@keyframes notificationProgress{0%{width:100%}to{width:0%}}#preview-console{position:absolute;bottom:0;left:0;right:0;background:#1a1a1a;border-top:1px solid #3a3a3a;display:flex;flex-direction:column;z-index:10;transition:height .2s ease}#preview-console.preview-console-collapsed{height:28px}#preview-console.preview-console-expanded{height:160px}#preview-console-header{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;background:#242424;cursor:pointer;-webkit-user-select:none;user-select:none;min-height:28px;box-sizing:border-box}#preview-console-header:hover{background:#2a2a2a}.preview-console-title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:500;color:#999}.preview-console-title svg{opacity:.7}.preview-console-badge{background:#e24a4a;color:#fff;font-size:10px;font-weight:600;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}.preview-console-badge.hidden{display:none}.preview-console-badge.warning-only{background:#f39c12}.preview-console-actions{display:flex;align-items:center;gap:2px}.preview-console-actions button{background:none;border:none;color:#888;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .15s}.preview-console-actions button:hover{background:#ffffff1a;color:#fff}#toggleConsoleBtn svg{transition:transform .2s ease}#preview-console.preview-console-expanded #toggleConsoleBtn svg{transform:rotate(180deg)}#preview-console-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:0;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,Consolas,monospace;font-size:11px;line-height:1.5}#preview-console.preview-console-collapsed #preview-console-content{display:none}.console-entry{display:flex;align-items:flex-start;gap:8px;padding:4px 10px;border-bottom:1px solid #2a2a2a}.console-entry:last-child{border-bottom:none}.console-entry.log{color:#ccc}.console-entry.info{color:#7ec8e3;background:#7ec8e30d}.console-entry.warning{color:#f5a623;background:#f5a62314}.console-entry.error{color:#ff6b6b;background:#ff6b6b14}.console-entry-icon{width:14px;height:14px;flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:2px;opacity:.8}.console-entry-message{flex:1;word-break:break-word;white-space:pre-wrap}.console-entry-time{color:#666;font-size:10px;flex-shrink:0;margin-top:2px}.console-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#555;font-size:11px;font-style:italic}#manualModal{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000c;z-index:10000;justify-content:center;align-items:center}.manual-modal{background:#2a2a2a;border:2px solid #4a4a4a;border-radius:8px;max-width:1100px;width:90vw;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.manual-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #4a4a4a;flex-shrink:0}.manual-modal .modal-header h2{margin:0;font-size:18px;color:#fff}.manual-modal .modal-close{background:transparent;border:none;color:#aaa;font-size:24px;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.manual-modal .modal-close:hover{background:#4a4a4a;color:#fff}.manual-modal .modal-footer{display:flex;gap:10px;justify-content:space-between;align-items:center;padding:15px 25px;border-top:1px solid #4a4a4a;background:#2a2a2a;flex-shrink:0}.manual-node-count{color:#888;font-size:13px}.manual-modal .modal-footer button{padding:10px 20px;border-radius:5px;border:none;cursor:pointer;font-size:14px;background:#4a90e2;color:#fff;transition:background .2s}.manual-modal .modal-footer button:hover{background:#357abd}.manual-modal .modal-body{padding:0;flex:1;overflow:hidden}.manual-layout{display:flex;flex:1;min-height:400px;overflow:hidden}.manual-sidebar{width:280px;min-width:280px;background:#1a1a1a;border-right:1px solid #3a3a3a;display:flex;flex-direction:column;overflow:hidden}.manual-search-container{padding:12px;border-bottom:1px solid #3a3a3a;background:#222}.manual-search-input{width:100%;padding:10px 12px;background:#1a1a1a;border:1px solid #3a3a3a;border-radius:6px;color:#fff;font-size:13px;outline:none;transition:border-color .2s,box-shadow .2s}.manual-search-input:focus{border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e226}.manual-search-input::placeholder{color:#666}.manual-categories{flex:1;overflow-y:auto;padding:8px 0}.manual-category{margin-bottom:2px}.manual-category-header{display:flex;align-items:center;gap:6px;padding:10px 14px;color:#bbb;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.manual-category-header:hover{background:#ffffff0d;color:#fff}.manual-category-arrow{width:16px;height:16px;transition:transform .2s;opacity:.6}.manual-category.collapsed .manual-category-arrow{transform:rotate(-90deg)}.manual-category-count{margin-left:auto;background:#333;color:#888;font-size:10px;font-weight:500;padding:2px 6px;border-radius:10px;min-width:20px;text-align:center}.manual-category-nodes{overflow:hidden;transition:max-height .25s ease}.manual-category.collapsed .manual-category-nodes{display:none}.manual-node-item{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:8px 14px 8px 36px;color:#aaa;font-size:13px;cursor:pointer;transition:all .15s;border-left:3px solid transparent;margin-left:12px}.manual-node-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manual-icon{flex-shrink:0;opacity:.5;transition:opacity .15s}.manual-node-item:hover .manual-icon{opacity:.8}.manual-node-item.active .manual-icon{opacity:1;color:#4a90e2}.manual-node-item:hover{background:#4a90e21a;color:#fff}.manual-node-item.active{background:#4a90e233;color:#4a90e2;border-left-color:#4a90e2!important}.manual-content{flex:1;overflow-y:auto;padding:24px 32px;background:#222}.manual-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#555;text-align:center}.manual-placeholder svg{opacity:.3;margin-bottom:20px}.manual-placeholder h3{color:#888;font-size:18px;font-weight:500;margin:0 0 8px}.manual-placeholder p{color:#666;font-size:14px;margin:0}.manual-entry{max-width:700px}.manual-entry-header{display:flex;align-items:center;gap:16px;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid #3a3a3a;border-left:4px solid #4a90e2;padding-left:16px;margin-left:-16px}.manual-entry-header h2{margin:0;font-size:26px;font-weight:600;color:#fff}.manual-entry-category{background:#333;color:#aaa;font-size:11px;font-weight:500;padding:4px 10px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.manual-section{margin-bottom:28px}.manual-section h3{color:#4a90e2;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin:0 0 14px;padding-bottom:8px;border-bottom:1px solid #333}.manual-section p{color:#bbb;font-size:14px;line-height:1.7;margin:0}.manual-no-items{color:#666;font-style:italic}.manual-ports-table{width:100%;border-collapse:collapse;font-size:13px}.manual-ports-table th,.manual-ports-table td{text-align:left;padding:10px 14px;border-bottom:1px solid #333}.manual-ports-table th{color:#888;font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.5px;background:#1a1a1a}.manual-ports-table td{color:#ccc}.manual-ports-table code{color:#fff;font-family:SF Mono,Monaco,Consolas,monospace;font-size:13px}.manual-type-badge{display:inline-block;background:linear-gradient(135deg,#333,#2a2a2a);color:#7ec8e3;font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px;padding:3px 8px;border-radius:4px;border:1px solid #3a3a3a}.manual-operations{display:flex;flex-wrap:wrap;gap:8px}.manual-operation-item{display:flex;align-items:center;gap:8px;background:#1a1a1a;border:1px solid #3a3a3a;border-radius:6px;padding:8px 12px;transition:all .15s}.manual-operation-item.has-description{flex-direction:column;align-items:flex-start;gap:4px;flex:1 1 calc(50% - 4px);min-width:200px}.manual-operation-item:hover{border-color:#4a90e2;background:#4a90e21a}.manual-operation-label{color:#fff;font-size:13px;font-weight:500}.manual-operation-description{color:#888;font-size:12px;line-height:1.4}.manual-operation-value{color:#7ec8e3;font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px;background:#333;padding:2px 6px;border-radius:3px}.manual-tags{display:flex;flex-wrap:wrap;gap:6px}.manual-tag{background:#333;color:#aaa;font-size:12px;padding:4px 10px;border-radius:12px;transition:all .15s}.manual-tag:hover{background:#444;color:#fff}.manual-custom-content{background:#1a1a1a;border:1px solid #3a3a3a;border-radius:8px;padding:20px}.manual-custom-content h3{margin-top:0;border-bottom:none;padding-bottom:0}.manual-custom-content h4{color:#ddd;font-size:15px;font-weight:600;margin:20px 0 10px}.manual-custom-content h4:first-child{margin-top:0}.manual-custom-content p{margin:0 0 12px}.manual-custom-content ul,.manual-custom-content ol{color:#bbb;margin:0 0 12px;padding-left:24px}.manual-custom-content li{margin-bottom:6px;line-height:1.6}.manual-custom-content code{background:#333;color:#7ec8e3;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;padding:2px 6px;border-radius:3px}.manual-custom-content pre{background:#111;border:1px solid #333;border-radius:6px;padding:14px;overflow-x:auto;margin:12px 0}.manual-custom-content pre code{background:transparent;padding:0;font-size:12px;line-height:1.5}.manual-custom-content .tip{background:#4a90e21a;border-left:3px solid #4a90e2;padding:12px 16px;border-radius:0 6px 6px 0;margin:16px 0}.manual-custom-content .tip strong{color:#4a90e2}.manual-custom-content .warning{background:#f5a6231a;border-left:3px solid #f5a623;padding:12px 16px;border-radius:0 6px 6px 0;margin:16px 0}.manual-custom-content .warning strong{color:#f5a623}.manual-error{color:#ff6b6b;text-align:center;padding:40px}
