*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #000;--bg-soft: radial-gradient(circle at center, #020617, #000);--glass: rgba(255, 255, 255, .08);--glass-strong: rgba(255, 255, 255, .14);--glass-border: rgba(255, 255, 255, .18);--glass-hover: rgba(255, 255, 255, .22);--text: rgba(255, 255, 255, .9);--text-dim: rgba(255, 255, 255, .5);--radius: .75rem;--blur: 10px;--mono: "JetBrains Mono", monospace;--ui: system-ui, -apple-system, sans-serif}html,body{width:100%;height:100%;overflow:hidden;background:var(--bg-soft);color:var(--text);font-family:var(--ui)}#app{height:100%;display:flex;flex-direction:column;overflow:hidden}#app:has(.home){overflow-y:auto}#navbar{display:flex;align-items:center;height:48px;padding:0 20px;background:#0009;-webkit-backdrop-filter:blur(var(--blur));backdrop-filter:blur(var(--blur));border-bottom:1px solid var(--glass-border);z-index:50;flex-shrink:0}.nav-logo{font-weight:700;font-size:1rem;color:var(--text);text-decoration:none;margin-right:32px}.nav-logo em{font-style:normal;opacity:.5}.nav-links{display:flex;gap:4px}.nav-link{padding:6px 14px;border-radius:6px;font-size:.75rem;font-family:var(--mono);letter-spacing:.06em;color:var(--text-dim);text-decoration:none;transition:all .15s}.nav-link:hover{color:var(--text);background:var(--glass)}.nav-link.active{color:var(--text);background:var(--glass-strong)}.home{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 48px);padding:2rem;text-align:center}.home-hero{max-width:600px;margin-bottom:4rem}.home-title{font-size:3.5rem;font-weight:800;letter-spacing:-.02em;margin-bottom:1rem}.home-title em{font-style:normal;opacity:.45}.home-tagline{font-size:1.1rem;color:var(--text-dim);line-height:1.6;margin-bottom:2rem}.home-actions{display:flex;gap:12px;justify-content:center}.home-btn{padding:12px 28px;border-radius:var(--radius);font-size:.8rem;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;text-decoration:none;cursor:pointer;transition:all .2s;border:1px solid var(--glass-border)}.home-btn-primary{background:#ffffff1f;color:var(--text)}.home-btn-primary:hover{background:#fff3;transform:translateY(-2px)}.home-btn-secondary{background:transparent;color:var(--text-dim)}.home-btn-secondary:hover{color:var(--text);background:var(--glass);transform:translateY(-2px)}.home-features{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:800px;width:100%}.home-feature{padding:24px;border-radius:var(--radius);background:var(--glass);border:1px solid var(--glass-border);text-align:left}.home-feature-icon{font-size:1.4rem;opacity:.6;display:block;margin-bottom:10px}.home-feature h3{font-size:.85rem;font-weight:600;margin-bottom:8px}.home-feature p{font-size:.75rem;color:var(--text-dim);line-height:1.55}.editor{display:flex;height:calc(100vh - 48px);overflow:hidden}#hierarchy{width:240px;min-width:240px;background:#0006;border-right:1px solid var(--glass-border);display:flex;flex-direction:column;overflow:hidden}.hierarchy-actions{padding:10px;border-bottom:1px solid var(--glass-border)}#inspector{width:320px;min-width:320px;background:#0006;border-left:1px solid var(--glass-border);display:flex;flex-direction:column;overflow:hidden}#inspectorContent{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) transparent}#inspectorContent::-webkit-scrollbar{width:6px}#inspectorContent::-webkit-scrollbar-track{background:transparent}#inspectorContent::-webkit-scrollbar-thumb{background-color:#ffffff4d;border-radius:3px}.inspector-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-dim);font-size:.75rem;font-style:italic}.panel-header{padding:12px 14px;border-bottom:1px solid var(--glass-border);display:flex;align-items:center;gap:10px}.panel-title{font-size:.7rem;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim)}.panel-footer{padding:8px 12px;border-top:1px solid var(--glass-border);display:flex;justify-content:space-between;font-size:.6rem;color:var(--text-dim)}.demo-content{display:flex;height:100vh;width:100vw;overflow:hidden}#viewport{flex:1;position:relative;overflow:hidden;background:#000}#glCanvas{width:100%;height:100%;display:block}#overlay-label{position:absolute;top:12px;left:14px;font-size:.6rem;font-family:var(--mono);color:var(--text-dim);pointer-events:none;z-index:5}.add-row,.hierarchy-actions{padding:10px;border-bottom:1px solid var(--glass-border)}.add-btn{width:100%;display:flex;justify-content:center;align-items:center;gap:8px;padding:10px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);color:var(--text);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .2s}.add-btn-secondary{margin-top:6px}.add-btn:hover{background:var(--glass-hover);transform:translateY(-2px)}.btn-pair{display:flex;gap:6px;margin-top:6px}.add-btn-half{flex:1;margin-top:0}.layer-name-input{flex:1;background:transparent;border:none;border-bottom:1px solid transparent;color:var(--text);font-size:.7rem;font-family:var(--ui);outline:none}.layer-name-input:focus{border-bottom-color:var(--glass-border)}.value-input{font-family:var(--mono);font-size:.65rem;color:#fff;background:#ffffff14;border:1px solid rgba(255,255,255,.25);border-radius:3px;width:52px;padding:1px 4px;text-align:right;outline:none;appearance:none;-webkit-appearance:none;-moz-appearance:textfield}.value-input::-webkit-outer-spin-button,.value-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.value-input:focus{border-color:#fff9;background:#ffffff1f}.slider{width:100%;height:2px;background:var(--glass-border);-webkit-appearance:none;-moz-appearance:none;appearance:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:#fff;cursor:pointer}p.disabled{opacity:.3;pointer-events:none}.toggle{position:relative;width:32px;height:18px}.toggle-row{display:flex;align-items:center;justify-content:space-between;overflow:hidden}.toggle input{position:absolute;opacity:0;width:0;height:0}.toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:9px;background:var(--glass-border)}.toggle-thumb{position:absolute;top:3px;left:3px;width:12px;height:12px;border-radius:50%;background:#fff;transition:transform .2s}.toggle input:checked~.toggle-track .toggle-thumb{transform:translate(14px)}.chip-group{display:flex;gap:6px;flex-wrap:wrap}.chip{font-size:.65rem;padding:4px 8px;background:#ffffff0f;border:1px solid var(--glass-border);border-radius:.5rem;color:var(--text-dim);cursor:pointer;transition:all .2s}.chip:hover{background:var(--glass-hover);color:#fff}.chip.active{background:#fff3;color:#fff}#tooltip{position:fixed;z-index:999;width:220px;padding:10px 12px;background:#080812f7;border:1px solid rgba(255,255,255,.18);border-radius:.6rem;box-shadow:0 12px 36px #0009;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .15s,transform .15s}#tooltip.visible{opacity:1;transform:translateY(0)}.tooltip-title{font-size:.65rem;font-weight:600;color:#fff;margin-bottom:5px;text-transform:uppercase;letter-spacing:.07em}.tooltip-body{font-size:.62rem;color:#ffffff8c;line-height:1.55}.tooltip-body .opt{display:inline-block;margin-top:5px;padding:1px 5px;border-radius:3px;background:#ffffff12;border:1px solid rgba(255,255,255,.12);color:#ffffffbf;font-family:var(--mono);font-size:.58rem;margin-right:3px;margin-bottom:2px}.info-btn{width:14px;height:14px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:transparent;color:#fff6;font-size:.55rem;font-family:var(--mono);line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;padding:0;margin-left:4px}.info-btn:hover{border-color:#ffffffb3;color:#fff;background:#ffffff14}#layerList{flex:1;overflow-y:auto;padding:4px 0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) transparent}#layerList::-webkit-scrollbar{width:6px}#layerList::-webkit-scrollbar-track{background:transparent}#layerList::-webkit-scrollbar-thumb{background-color:#ffffff4d;border-radius:3px}#layerList::-webkit-scrollbar-thumb:hover{background-color:#ffffff80}.hierarchy-item{border-bottom:1px solid rgba(255,255,255,.06)}.hierarchy-item.hierarchy-item-hidden{opacity:.35}.hierarchy-row{display:flex;align-items:center;gap:6px;padding:6px 10px;cursor:pointer;transition:background .12s;font-size:.72rem}.hierarchy-row:hover{background:var(--glass)}.hierarchy-item.selected .hierarchy-row{background:var(--glass-strong)}.layer-swatch{width:18px;height:10px;border-radius:2px;border:1px solid var(--glass-border);flex-shrink:0}.layer-badge{font-family:var(--mono);font-size:.55rem;opacity:.45;flex-shrink:0}.layer-remove,.layer-vis{background:none;border:none;cursor:pointer;color:var(--text-dim);font-size:.65rem;padding:2px;flex-shrink:0}.layer-remove:hover{color:#ff6b6b}.layer-vis.active{color:#fff}.layer-toggle{display:none}.inspector-body{padding:4px 0}.inspector-name-input{width:100%;box-sizing:border-box}.group{padding:10px 12px}.group-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin-bottom:6px;display:flex;justify-content:space-between}.value-display{font-family:var(--mono);font-size:.65rem;color:#fff}.group.disabled{opacity:.3;pointer-events:none}.palette-stops{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:6px}.palette-stop input[type=color]{width:26px;height:20px;border-radius:4px;border:1px solid var(--glass-border);background:none}.palette-stop-remove{background:none;border:none;color:var(--text-dim);cursor:pointer}.palette-stop-remove:hover{color:#ff6b6b}.palette-add{font-size:.65rem;padding:2px 6px;background:transparent;border:1px dashed var(--glass-border);border-radius:4px;color:var(--text-dim);cursor:pointer}.palette-add:hover{color:#fff;border-color:#fff}.palette-preview{height:6px;border-radius:3px;border:1px solid var(--glass-border)}.dir-row{display:flex;align-items:center;gap:12px}.dial{width:44px;height:44px;border-radius:50%;border:1px solid var(--glass-border);background:#ffffff0d;cursor:grab;position:relative}.dial:active{cursor:grabbing}.dial-needle{position:absolute;top:50%;left:50%;width:16px;height:2px;background:#fff;transform-origin:left center}.dir-values{font-size:.65rem;color:var(--text-dim)}.accent{color:#fff;font-family:var(--mono)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100}.modal-backdrop.hidden{display:none}.modal-panel{width:min(900px,92vw);height:min(620px,85vh);background:#0a0a14f2;border:1px solid var(--glass-border);border-radius:1.25rem;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 30px 80px #0009}.modal-header{padding:14px 18px;border-bottom:1px solid var(--glass-border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim)}.modal-close{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:.9rem}.modal-close:hover{color:#fff}#nodeCanvas{flex:1;display:block;cursor:default}.modal-hint{padding:8px 18px;font-size:.6rem;color:var(--text-dim);border-top:1px solid var(--glass-border);letter-spacing:.05em}.layer-drag-handle{cursor:grab;color:#fff3;font-size:.7rem;padding:0 2px;line-height:1;-webkit-user-select:none;user-select:none;flex-shrink:0;transition:color .15s}.layer-drag-handle:hover{color:#fff9}.layer-drag-handle:active{cursor:grabbing}.hierarchy-item.drag-over-top{border-top:2px solid rgba(255,255,255,.5)}.hierarchy-item.drag-over-bottom{border-bottom:2px solid rgba(255,255,255,.5)}.hierarchy-item.dragging{opacity:.35;pointer-events:none}#viewport-toolbar{position:absolute;bottom:16px;right:16px;display:flex;gap:6px;z-index:10;opacity:0;transition:opacity .25s}#viewport:hover #viewport-toolbar{opacity:1}.toolbar-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--glass-border);border-radius:8px;color:var(--text);font-size:.85rem;cursor:pointer;transition:all .2s}.toolbar-btn:hover{background:#ffffff26;transform:translateY(-2px)}.toolbar-btn-active{background:#ffffff1f;color:#fff}.modal-panel-sm{width:min(560px,90vw);height:auto;max-height:min(520px,80vh)}.config-modal-body{padding:16px 18px;display:flex;flex-direction:column;gap:12px}#configTextarea{width:100%;height:260px;background:#00000080;border:1px solid var(--glass-border);border-radius:8px;color:var(--text);font-family:var(--mono);font-size:.7rem;line-height:1.5;padding:12px;resize:vertical;outline:none;transition:border-color .2s}#configTextarea:focus{border-color:#ffffff59}#configTextarea::placeholder{color:var(--text-dim)}.config-actions{display:flex;gap:8px}.config-action-btn{flex:1;padding:10px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);color:var(--text);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .2s}.config-action-btn:hover{background:var(--glass-hover);transform:translateY(-1px)}.config-action-primary{background:#64c8ff1f;border-color:#64c8ff40}.config-action-primary:hover{background:#64c8ff33}.config-status{font-size:.65rem;font-family:var(--mono);letter-spacing:.04em;min-height:1.2em}.config-status-ok{color:#64ffa0e6}.config-status-err{color:#ff6464e6}.modal-panel-md{width:min(680px,92vw);height:auto;max-height:min(560px,85vh)}.preset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;padding:16px 18px;overflow-y:auto;flex:1;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) transparent}.preset-card{background:#ffffff0a;border:1px solid var(--glass-border);border-radius:10px;overflow:hidden;cursor:pointer;transition:all .25s;text-align:left;color:var(--text);padding:0}.preset-card:hover{background:#ffffff14;transform:translateY(-3px);box-shadow:0 8px 24px #0006;border-color:#ffffff4d}.preset-swatch{width:100%;height:60px;border-radius:0}.preset-info{padding:10px;display:flex;flex-direction:column;gap:3px}.preset-name{font-size:.75rem;font-weight:600;letter-spacing:.04em}.preset-desc{font-size:.6rem;color:var(--text-dim);line-height:1.3}.preset-layers{font-size:.55rem;font-family:var(--mono);color:var(--text-dim);opacity:.7;margin-top:2px}
