*{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}.toolbar-actions{margin-left:auto;flex-wrap:wrap}.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;transform:translateY(-1px);box-shadow:0 2px 8px #0000004d}.toolbar-btn:active{transform:translateY(0);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}#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-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{background:#1a1a1a;border:1px solid #4a4a4a;color:#fff;padding:10px;border-radius:5px;font-size:14px}.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}#shader-errors-container{position:fixed;bottom:330px;right:20px;width:400px;max-height:200px;overflow-y:auto;z-index:1001;display:flex;flex-direction:column;gap:8px}.shader-error-item{background:#2a2a2a;border:2px solid;border-radius:6px;padding:10px 12px;display:flex;align-items:flex-start;gap:10px;box-shadow:0 2px 8px #0000004d;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.shader-error-item.error{border-color:#e24a4a;background:#e24a4a1a}.shader-error-item.warning{border-color:#f39c12;background:#f39c121a}.shader-error-icon{font-size:16px;font-weight:700;flex-shrink:0;margin-top:2px}.shader-error-item.error .shader-error-icon{color:#e24a4a}.shader-error-item.warning .shader-error-icon{color:#f39c12}.shader-error-message{flex:1;color:#fff;font-size:12px;font-family:Courier New,monospace;line-height:1.4;word-break:break-word}.shader-error-close{background:none;border:none;color:#888;font-size:18px;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:3px;flex-shrink:0;transition:all .2s}.shader-error-close:hover{background:#ffffff1a;color:#fff}#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:#0000004d;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:8px 12px;display:flex;gap:12px;flex-wrap:wrap;align-items:center;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}#preview-controls.preview-controls-hidden{transform:translateY(-100%);opacity:0;pointer-events:none}#preview-controls.preview-controls-visible{transform:translateY(0);opacity:1}.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-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}.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}.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}
