:root{--primary-color: #8b5cf6;--primary-hover: #7c3aed;--primary-light: #ddd6fe;--background: #ffffff;--surface: #f8fafc;--border: #e2e8f0;--border-hover: #cbd5e1;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;color:var(--text-primary);background-color:var(--background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=dark]{--primary-color: #8b5cf6;--primary-hover: #7c3aed;--primary-light: #4c1d95;--background: #111111;--surface: #1a1a1a;--border: #333333;--border-hover: #444444;--text-primary: #f5f5f5;--text-secondary: #c0c0c0;--text-muted: #888888;--shadow: 0 1px 3px 0 rgb(0 0 0 / .4), 0 1px 2px -1px rgb(0 0 0 / .4);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .4), 0 4px 6px -4px rgb(0 0 0 / .4)}*{box-sizing:border-box}body{margin:0;padding:0;min-height:100vh;overflow:hidden}#app{width:100vw;height:100vh;display:flex;flex-direction:column;overflow:hidden}.main-container{flex:1;display:flex;overflow:hidden;background:var(--surface);min-height:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.navbar{background:var(--background);border-bottom:1px solid var(--border);height:40px;display:flex;align-items:center;padding:0 12px;-webkit-user-select:none;user-select:none;box-shadow:var(--shadow);z-index:1000}.navbar-brand{display:flex;align-items:center;margin-right:24px}.navbar-logo{height:24px;width:auto;transition:transform .2s ease}.navbar-logo:hover{transform:scale(1.05)}.navbar-logo-container{height:24px;width:auto;transition:transform .2s ease;display:flex;align-items:center}.navbar-logo-container:hover{transform:scale(1.05)}.navbar-logo-container svg{height:24px;width:auto}.navbar-menu{list-style:none;margin:0;padding:0;display:flex;align-items:center}.navbar-item{position:relative}.navbar-link{display:block;padding:6px 10px;color:var(--text-secondary);text-decoration:none;font-size:13px;border-radius:50px;transition:color .2s ease;position:relative;overflow:hidden}.navbar-link:after{content:"";position:absolute;bottom:2px;left:50%;width:0;height:1px;background:var(--text-primary);transition:all .25s ease;transform:translate(-50%)}.navbar-link:hover{color:var(--text-primary)}.navbar-link:hover:after{width:calc(100% - 20px)}.navbar-link:active{color:var(--text-primary);transform:translateY(1px)}.dropdown{position:absolute;top:100%;left:0;background:var(--background);border:1px solid var(--border);border-radius:6px;box-shadow:0 8px 25px #00000026;z-index:1000;min-width:180px;opacity:0;visibility:hidden;transform:translateY(-10px) scale(.95);transition:opacity .2s ease,visibility .2s ease,transform .2s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4px 0}.navbar-item:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.dropdown a{display:block;padding:8px 16px;color:var(--text-secondary);text-decoration:none;font-size:12px;transition:all .15s cubic-bezier(.4,0,.2,1);position:relative;border-radius:0;letter-spacing:0}.dropdown a:before{content:"";position:absolute;left:4px;top:50%;width:0;height:20px;background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));border-radius:0 2px 2px 0;transform:translateY(-50%);transition:width .2s cubic-bezier(.4,0,.2,1)}.dropdown a:hover{color:var(--text-primary);padding-left:20px;letter-spacing:.3px;background:linear-gradient(90deg,rgba(139,92,246,.08) 0%,transparent 100%)}.dropdown a:hover:before{width:3px}.dropdown a:active{transform:scale(.98)}.load-layout-preset-trigger{display:flex!important;justify-content:space-between;align-items:center;position:relative;padding:8px 16px;color:var(--text-secondary);text-decoration:none;font-size:12px;transition:all .15s cubic-bezier(.4,0,.2,1);border-radius:0;letter-spacing:0;cursor:pointer}.load-layout-preset-trigger:before{content:"";position:absolute;left:4px;top:50%;width:0;height:20px;background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));border-radius:0 2px 2px 0;transform:translateY(-50%);transition:width .2s cubic-bezier(.4,0,.2,1)}.load-layout-preset-trigger:hover{color:var(--text-primary);padding-left:20px;letter-spacing:.3px;background:linear-gradient(90deg,rgba(139,92,246,.08) 0%,transparent 100%)}.load-layout-preset-trigger:hover:before{width:3px}.submenu-arrow{font-size:10px;color:var(--text-muted);transition:transform .2s ease}.load-layout-preset-trigger:hover .submenu-arrow{transform:rotate(90deg)}.submenu{position:absolute;top:0;left:100%;background:var(--background);border:1px solid var(--border);border-radius:6px;box-shadow:0 8px 25px #00000026;min-width:200px;opacity:0;visibility:hidden;transform:translate(-10px) scale(.95);transition:opacity .2s ease,visibility .2s ease,transform .2s ease;z-index:1001;margin-left:4px}.load-layout-preset-trigger:hover .submenu,.submenu:hover{opacity:1;visibility:visible;transform:translate(0) scale(1)}.submenu-content{padding:4px 0}.submenu-item{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .15s ease}.submenu-item:hover{background:var(--surface);color:var(--text-primary)}.submenu-item.submenu-placeholder{color:var(--text-muted);font-style:italic;cursor:default}.submenu-item.submenu-placeholder:hover{background:none;color:var(--text-muted)}.preset-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preset-delete{width:16px;height:16px;border:none;background:transparent;color:var(--text-muted);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;cursor:pointer;transition:all .15s ease;margin-left:8px;opacity:0}.submenu-item:hover .preset-delete{opacity:1}.preset-delete:hover{background:var(--border);color:var(--text-primary)}.dropdown-separator{height:1px;background:var(--border);margin:4px 8px;opacity:.5}.dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dialog{background:var(--background);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-lg);width:90%;max-width:400px;overflow:hidden;animation:dialogSlideIn .2s ease}@keyframes dialogSlideIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.dialog-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--surface)}.dialog-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.dialog-close{width:24px;height:24px;border:none;background:transparent;color:var(--text-muted);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;transition:all .15s ease}.dialog-close:hover{background:var(--border);color:var(--text-primary)}.dialog-body{padding:20px}.dialog-body label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:var(--text-primary)}.dialog-body input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:4px;font-size:14px;background:var(--background);color:var(--text-primary);transition:border-color .2s ease}.dialog-body input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-light)}.dialog-hint{margin-top:8px;font-size:12px;color:var(--text-muted)}.dialog-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid var(--border);background:var(--surface)}.dialog-button{padding:8px 16px;border:1px solid var(--border);border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.dialog-button-secondary{background:var(--background);color:var(--text-secondary)}.dialog-button-secondary:hover{background:var(--surface);color:var(--text-primary)}.dialog-button-primary{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.dialog-button-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.dialog-button-primary:disabled{opacity:.5;cursor:not-allowed}.theme-toggle{margin-left:auto;padding:4px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:50%;font-size:16px;transition:all .1s ease;display:flex;align-items:center;justify-content:center;width:28px;height:28px}.theme-toggle:hover{background-color:var(--border);color:var(--text-primary)}.theme-toggle:active{background-color:var(--border-hover)}.tab-bar{background:var(--surface);border-bottom:1px solid var(--border);height:36px;display:flex;align-items:center;padding:0 12px;-webkit-user-select:none;user-select:none;overflow-x:auto;overflow-y:hidden;box-shadow:inset 0 -1px 0 var(--border)}.tab-bar::-webkit-scrollbar{height:2px}.tab-bar::-webkit-scrollbar-track{background:transparent}.tab-bar::-webkit-scrollbar-thumb{background:var(--border);border-radius:1px}.tabs-container{display:flex;align-items:center;gap:2px;min-width:0}.tab{display:flex;align-items:center;padding:6px 12px;background:transparent;border:none;border-radius:6px 6px 0 0;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);position:relative;min-width:120px;max-width:200px;justify-content:space-between;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-bottom:2px solid transparent}.tab:hover{background:var(--background);color:var(--text-primary)}.tab.active{background:var(--background);color:var(--text-primary);border-bottom-color:var(--primary-color);box-shadow:0 -1px 0 var(--border),1px 0 0 var(--border),-1px 0 0 var(--border)}.tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:var(--background);z-index:1}.tab-title{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;margin-right:8px}.tab-close{display:flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:transparent;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;transition:all .15s ease;flex-shrink:0;opacity:.6}.tab-close:hover{background:var(--border);color:var(--text-primary);opacity:1}.tab:hover .tab-close{opacity:1}.tab-close:active{transform:scale(.9)}.new-tab-button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:transparent;border:none;color:var(--text-muted);font-size:14px;cursor:pointer;transition:all .15s ease;margin-left:4px;flex-shrink:0}.new-tab-button:hover{background:var(--border);color:var(--text-primary)}.new-tab-button:active{transform:scale(.95)}.tab.dragging{opacity:.5;transform:rotate(5deg)}.tab.drag-over{border-left:2px solid var(--primary-color)}.tab-context-menu{position:absolute;background:var(--background);border:1px solid var(--border);border-radius:6px;box-shadow:var(--shadow-lg);z-index:1001;min-width:150px;padding:4px 0;opacity:0;visibility:hidden;transform:scale(.95);transition:all .15s ease}.tab-context-menu.visible{opacity:1;visibility:visible;transform:scale(1)}.tab-context-menu-item{display:block;width:100%;padding:8px 16px;background:none;border:none;color:var(--text-secondary);font-size:12px;text-align:left;cursor:pointer;transition:all .15s ease}.tab-context-menu-item:hover{background:var(--surface);color:var(--text-primary)}.tab-context-menu-item:disabled{color:var(--text-muted);cursor:not-allowed}.tab-context-menu-item:disabled:hover{background:none}@keyframes tabSlideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes tabSlideOut{0%{opacity:1;transform:translate(0);max-width:200px}to{opacity:0;transform:translate(-20px);max-width:0}}.tab.slide-in{animation:tabSlideIn .2s ease-out}.tab.slide-out{animation:tabSlideOut .2s ease-out}.window-container{flex:1;display:flex;flex-direction:column;position:relative;height:100%;min-height:0}.window{background:var(--background);border:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow);position:relative;flex:1;height:100%;min-height:0}.window-header{background:var(--surface);border-bottom:1px solid var(--border);padding:8px 12px;display:flex;align-items:center;justify-content:space-between;height:36px;-webkit-user-select:none;user-select:none;flex-shrink:0}.window-title-container{flex:1;min-width:0}.custom-dropdown{position:relative;display:inline-block}.custom-dropdown-trigger{background:transparent;border:none;color:var(--text-primary);font-size:13px;font-weight:500;font-family:inherit;padding:2px 20px 2px 4px;border-radius:3px;cursor:pointer;outline:none;min-width:0;max-width:100%;transition:color .12s ease,background-color .12s ease;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='m6 9 6 6 6-6'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 4px center;background-size:12px}.custom-dropdown-trigger:hover{color:var(--text-primary);background-color:#8080800d;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231e293b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='m6 9 6 6 6-6'/%3e%3c/svg%3e")}.custom-dropdown-trigger:focus{color:var(--text-primary);background-color:#80808014;outline:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231e293b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='m6 9 6 6 6-6'/%3e%3c/svg%3e")}[data-theme=dark] .custom-dropdown-trigger{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c0c0c0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='m6 9 6 6 6-6'/%3e%3c/svg%3e")}[data-theme=dark] .custom-dropdown-trigger:hover,[data-theme=dark] .custom-dropdown-trigger:focus{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f5f5f5' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='m6 9 6 6 6-6'/%3e%3c/svg%3e")}.custom-dropdown-menu{position:absolute;top:100%;left:0;background:var(--background);border:1px solid var(--border);border-radius:6px;box-shadow:0 8px 25px #00000026;z-index:1000;min-width:180px;opacity:0;visibility:hidden;transform:translateY(-10px) scale(.95);transition:opacity .2s ease,visibility .2s ease,transform .2s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4px 0}.custom-dropdown.open .custom-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.custom-dropdown-item{display:block;padding:8px 16px;color:var(--text-secondary);text-decoration:none;font-size:12px;transition:all .15s cubic-bezier(.4,0,.2,1);position:relative;border-radius:0;letter-spacing:0}.custom-dropdown-item:before{content:"";position:absolute;left:4px;top:50%;width:0;height:20px;background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));border-radius:0 2px 2px 0;transform:translateY(-50%);transition:width .2s cubic-bezier(.4,0,.2,1)}.custom-dropdown-item:hover{color:var(--text-primary);padding-left:20px;letter-spacing:.3px;background:linear-gradient(90deg,rgba(139,92,246,.08) 0%,transparent 100%)}.custom-dropdown-item:hover:before{width:3px}.custom-dropdown-item:active{transform:scale(.98)}.custom-dropdown-item.selected{color:var(--text-primary);font-weight:500;background:linear-gradient(90deg,rgba(139,92,246,.12) 0%,transparent 100%)}.window-controls{display:flex;gap:4px}.window-control{width:18px;height:18px;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;transition:background-color .08s ease}.window-control:hover{background-color:var(--border)}.window-control.close{background-color:transparent;color:var(--text-muted);font-size:14px}.window-control.close:hover{background-color:var(--border);color:var(--text-primary)}.split-buttons{position:absolute;pointer-events:none;inset:0}.split-button{position:absolute;width:16px;height:16px;background:var(--text-secondary);border:1px solid var(--background);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:11px;font-weight:400;color:var(--background);transition:all .12s ease;pointer-events:all;opacity:0;transform:scale(.8);z-index:100}.split-button:hover{background:var(--text-primary);color:var(--background);opacity:1;transform:scale(1)}.split-button.top{top:8px;left:50%;transform:translate(-50%) scale(.8)}.split-button.top:hover{transform:translate(-50%) scale(1)}.split-button.right{right:8px;top:50%;transform:translateY(-50%) scale(.8)}.split-button.right:hover{transform:translateY(-50%) scale(1)}.split-button.bottom{bottom:8px;left:50%;transform:translate(-50%) scale(.8)}.split-button.bottom:hover{transform:translate(-50%) scale(1)}.split-button.left{left:8px;top:50%;transform:translateY(-50%) scale(.8)}.split-button.left:hover{transform:translateY(-50%) scale(1)}.split-button:before{content:"";position:absolute;inset:-40px;pointer-events:all}.split-button.top:hover,.split-button.right:hover,.split-button.bottom:hover,.split-button.left:hover{opacity:1}.window-content{flex:1;padding:16px;overflow:auto;background:var(--background);min-height:0;position:relative}.window-content:has(.graph-creator-container){padding:0}.split-container{display:flex;flex:1;position:relative;height:100%;min-height:0}.split-horizontal{flex-direction:row}.split-vertical{flex-direction:column}.split-pane{flex:1;display:flex;flex-direction:column;min-width:200px;min-height:0;height:100%;overflow:hidden}.resizer{background:var(--border);transition:background-color .15s ease;z-index:10;flex-shrink:0;flex-grow:0}.resizer:hover{background:var(--border-hover)}.resizer-horizontal{width:4px!important;min-width:4px!important;max-width:4px!important;cursor:col-resize;flex-basis:4px!important}.resizer-vertical{height:4px!important;min-height:4px!important;max-height:4px!important;cursor:row-resize;flex-basis:4px!important}.resizer.resizing{background:var(--text-secondary)}.window:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-light)}.welcome-content,.graph-creator-content,.algorithm-visualizer-content,.data-manager-content,.settings-content{padding:24px;height:100%;overflow-y:auto}.welcome-content h2,.graph-creator-content h2,.algorithm-visualizer-content h2,.data-manager-content h2,.settings-content h2{margin:0 0 16px;color:var(--text-primary);font-size:20px;font-weight:600}.welcome-content h3,.graph-creator-content h3,.algorithm-visualizer-content h3,.data-manager-content h3,.settings-content h3{margin:20px 0 12px;color:var(--text-primary);font-size:16px;font-weight:500}.welcome-content p,.graph-creator-content p,.algorithm-visualizer-content p,.data-manager-content p,.settings-content p{margin:0 0 12px;color:var(--text-secondary);line-height:1.5}.welcome-content ul,.graph-creator-content ul,.algorithm-visualizer-content ul,.data-manager-content ul,.settings-content ul{margin:0 0 16px;padding-left:20px;color:var(--text-secondary)}.welcome-content li,.graph-creator-content li,.algorithm-visualizer-content li,.data-manager-content li,.settings-content li{margin:6px 0;line-height:1.4}.welcome-content strong,.graph-creator-content strong,.algorithm-visualizer-content strong,.data-manager-content strong,.settings-content strong{color:var(--text-primary)}.welcome-content em,.graph-creator-content em,.algorithm-visualizer-content em,.data-manager-content em,.settings-content em{color:var(--text-muted);font-style:italic}.placeholder-area{background:var(--surface);border-radius:6px;padding:20px;margin-top:16px;border:1px solid var(--border)}.placeholder-area h3{margin:0 0 12px;text-align:center;color:var(--text-secondary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);height:100%;padding:32px;text-align:center}.empty-state h3{margin:0 0 8px;font-size:18px;font-weight:500;color:var(--text-secondary)}.empty-state p{margin:0;font-size:14px}.graph-creator-container{position:relative;height:100%;width:100%;overflow:hidden}.graph-canvas-area{position:absolute;inset:0;width:100%;height:100%;overflow:hidden}.canvas-overlay{position:absolute;inset:0;pointer-events:none;z-index:10}.canvas-controls{position:absolute;top:12px;right:12px;display:flex;gap:8px;pointer-events:auto}.canvas-control-btn{width:32px;height:32px;border:1px solid var(--border);background:var(--background);border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--text-secondary);box-shadow:var(--shadow)}.canvas-control-btn:hover{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.graph-stats{position:absolute;bottom:12px;left:12px;display:flex;gap:16px;pointer-events:auto}.stat-item{background:var(--background);border:1px solid var(--border);border-radius:6px;padding:8px 12px;box-shadow:var(--shadow);font-size:12px}.stat-label{color:var(--text-secondary);margin-right:4px}.stat-value{color:var(--primary-color);font-weight:600}.graph-controls-panel-left{position:absolute;top:0;left:0;bottom:0;width:280px;background:var(--background);border-right:1px solid var(--border);display:flex;flex-direction:column;transition:transform .3s ease;z-index:20;box-shadow:var(--shadow)}.graph-controls-panel-left.collapsed{transform:translate(-100%)}.controls-header{padding:10px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--surface)}.controls-header h3{margin:0;font-size:13px;font-weight:600;color:var(--text-primary)}.panel-toggle{width:20px;height:20px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.panel-toggle:hover{background:var(--primary-light);color:var(--primary-color)}.panel-toggle svg{transition:transform .3s ease;width:14px;height:14px}.graph-controls-panel-left.collapsed .panel-toggle svg{transform:rotate(180deg)}.sidebar-toggle-persistent{position:absolute;top:16px;left:16px;width:40px;height:40px;background:var(--background);border:1px solid var(--border);border-radius:8px;display:none;align-items:center;justify-content:center;cursor:pointer;z-index:15;box-shadow:var(--shadow);transition:all .2s ease;color:var(--text-secondary)}.sidebar-toggle-persistent:hover{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.graph-controls-panel-left.collapsed~.sidebar-toggle-persistent{display:flex}.controls-content{flex:1;padding:12px;overflow-y:auto;overflow-x:hidden}.control-section{margin-bottom:12px}.control-section:last-child{margin-bottom:0}.control-group{margin-bottom:8px}.control-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;font-size:12px;color:var(--text-primary)}.control-value{color:var(--primary-color);font-weight:600;font-size:11px}.slider-container{position:relative;height:16px;margin-bottom:6px}.control-slider{-webkit-appearance:none;appearance:none;width:100%;height:3px;border-radius:2px;background:var(--border);outline:none;cursor:pointer;position:relative;z-index:2}.control-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:2px solid var(--background);box-shadow:0 1px 2px #0003;transition:all .2s ease}.control-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 2px 4px #0000004d}.control-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:2px solid var(--background);box-shadow:0 1px 2px #0003}.control-input{width:100%;padding:4px 8px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text-primary);font-size:12px;font-family:inherit;transition:all .2s ease;margin-top:4px;height:26px;box-sizing:border-box}.control-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 1px var(--primary-light)}.control-input:hover{border-color:var(--primary-color)}.toggle-group{display:flex;gap:4px;margin-bottom:8px}.toggle-btn{flex:1;padding:6px 10px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);border-radius:4px;font-size:11px;cursor:pointer;transition:all .2s ease;height:28px;display:flex;align-items:center;justify-content:center}.toggle-btn:hover{border-color:var(--primary-color);color:var(--text-primary)}.toggle-btn.active{background:var(--surface);border-color:var(--primary-color);color:var(--text-primary);box-shadow:0 0 0 1px var(--primary-color)}.weight-controls{margin-top:8px;padding:8px;background:var(--surface);border:1px solid var(--border);border-radius:4px;transition:all .3s ease}.weight-inputs{display:flex;gap:8px}.weight-input-group{flex:1}.weight-label{display:block;margin-bottom:3px;font-size:11px;color:var(--text-secondary);font-weight:500}.weight-input{width:100%;padding:4px 6px;border:1px solid var(--border);border-radius:4px;background:var(--background);color:var(--text-primary);font-size:11px;font-family:inherit;transition:all .2s ease;height:24px;box-sizing:border-box}.weight-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 1px var(--primary-light)}.weight-input:hover{border-color:var(--primary-color)}.action-buttons{display:flex;gap:6px;margin-top:8px}.primary-btn{flex:1;padding:8px 12px;background:var(--primary-color);color:#fff;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;height:32px}.primary-btn:hover{background:var(--primary-hover)}.secondary-btn{flex:1;padding:8px 12px;background:var(--surface);color:var(--text-secondary);border:1px solid var(--border);border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s ease;height:32px}.secondary-btn:hover{background:var(--background);border-color:var(--primary-color);color:var(--text-primary)}.property-buttons{display:flex;flex-direction:column;gap:6px}.property-btn{display:flex;align-items:center;padding:8px 10px;border:1px solid var(--border);background:var(--surface);border-radius:4px;cursor:pointer;transition:all .2s ease;text-align:left;font-size:12px;height:32px}.property-btn:hover{border-color:var(--primary-color);background:var(--primary-light)}.property-btn.active{border-color:var(--primary-color);background:var(--primary-light);box-shadow:0 0 0 1px var(--primary-color)}.property-icon{font-size:16px;margin-right:12px;min-width:20px}.property-info{flex:1}.property-name{display:block;font-size:13px;font-weight:500;color:var(--text-primary);line-height:1.2}.property-desc{display:block;font-size:11px;color:var(--text-muted);line-height:1.2;margin-top:2px}.advanced-settings{border-top:1px solid var(--border);padding-top:12px;margin-top:12px}.advanced-section{margin-bottom:12px}.advanced-section:last-child{margin-bottom:0}.section-header{margin-bottom:8px}.section-title{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.advanced-options{display:flex;flex-direction:column;gap:6px}.option-controls{margin-top:6px;padding:8px;background:var(--surface);border:1px solid var(--border);border-radius:4px;transition:all .3s ease}.flex{display:flex}.flex-1{flex:1}.flex-col{flex-direction:column}.h-full{height:100%}.w-full{width:100%}@media (max-width: 768px){.navbar{padding:0 8px}.navbar-brand{margin-right:16px}.window{margin:4px}.split-pane{min-width:150px;min-height:120px}}@media (max-width: 768px){.graph-controls-panel-left{position:absolute;top:0;left:0;bottom:0;z-index:100;box-shadow:var(--shadow-lg)}.canvas-controls{flex-direction:column}.graph-stats{flex-direction:column;gap:8px}}
