:root{--bg:#f0ede8;--bg-panel:#e8e4de;--bg-card:#faf8f5;--border:#d6d0c8;--border-soft:#e0dbd4;--text:#3d3730;--text-muted:#7a7168;--text-code:#1e293b;--col-default:#1e293b;--col-highlight:#f59e0b;--col-compare:#3b82f6;--col-swap:#f97316;--col-balanced:#22c55e;--col-unbalanced:#ef4444;--col-red-node:#dc2626;--col-black-node:#1e293b;--edge:#94a3b8;--accent:#5b4fcf;--accent-soft:#5b4fcf1a;--font-ui:"Plus Jakarta Sans", system-ui, sans-serif;--font-display:"Fraunces", Georgia, serif;--font-code:"DM Mono", "Fira Code", monospace;font-family:var(--font-ui);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-size:14px;line-height:1.5}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{height:100vh;margin:0;overflow:hidden}#app{flex-direction:column;height:100vh;display:flex;overflow:hidden}#header{background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;height:52px;padding:0 20px;display:flex}.header-left{align-items:center;gap:10px;display:flex}.logo-mark{color:var(--accent);font-size:20px;line-height:1}.site-title{font-family:var(--font-display);color:var(--text-code);letter-spacing:-.3px;font-size:18px;font-weight:400}.site-sub{color:var(--text-muted);border-left:1px solid var(--border);margin-left:2px;padding-left:10px;font-size:12px}.header-right{align-items:center;gap:16px;display:flex}.speed-control{align-items:center;gap:8px;display:flex}.speed-label{color:var(--text-muted);font-size:12px;font-weight:500}.speed-buttons{background:var(--bg-panel);border:1px solid var(--border);border-radius:6px;gap:2px;padding:2px;display:flex}.speed-btn{font-family:var(--font-code);color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:500;transition:all .15s}.speed-btn:hover{color:var(--text);background:var(--border-soft)}.speed-btn.active{background:var(--bg-card);color:var(--accent);box-shadow:0 1px 3px #0000001a}#tab-bar{background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0;gap:0;padding:0 20px;display:flex}.tab{font-family:var(--font-ui);color:var(--text-muted);cursor:pointer;letter-spacing:.1px;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 16px;font-size:13px;font-weight:500;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}#main-layout{flex:1;grid-template-columns:220px 1fr 200px;min-height:0;display:grid;overflow:hidden}#left-panel,#right-panel{background:var(--bg-card);border-right:1px solid var(--border);flex-direction:column;gap:0;display:flex;overflow-y:auto}#right-panel{border-right:none;border-left:1px solid var(--border)}.panel-section{border-bottom:1px solid var(--border-soft);padding:14px}.panel-title{font-family:var(--font-display);letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px;font-size:11px;font-weight:400}.controls-group{flex-direction:column;gap:8px;display:flex}.value-input{width:100%;font-family:var(--font-code);background:var(--bg);border:1px solid var(--border);color:var(--text-code);border-radius:6px;outline:none;padding:7px 10px;font-size:13px;transition:border-color .15s}.value-input:focus{border-color:var(--accent)}.value-input::placeholder{color:var(--text-muted);font-size:12px}.value-input.small{flex:1;padding:5px 8px;font-size:12px}.op-buttons{grid-template-columns:1fr 1fr 1fr;gap:4px;display:grid}.op-btn{font-family:var(--font-ui);border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:5px;padding:6px 4px;font-size:12px;font-weight:500;transition:all .15s}.op-btn:hover{background:var(--bg-panel);border-color:var(--text-muted)}.op-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.op-btn.primary:hover{background:#4a3fb5;border-color:#4a3fb5}.op-btn.danger{background:var(--bg);color:var(--col-unbalanced);border-color:var(--col-unbalanced)}.op-btn.danger:hover{background:#fef2f2}.op-btn:disabled{opacity:.45;cursor:not-allowed}.group-label{color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;margin-bottom:4px;font-size:11px;font-weight:600;display:block}.traversal-group{flex-direction:column;gap:4px;margin-top:4px;display:flex}.traversal-buttons{grid-template-columns:1fr 1fr;gap:3px;display:grid}.trav-btn{font-family:var(--font-ui);border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;border-radius:4px;padding:5px 6px;font-size:11px;font-weight:500;transition:all .15s}.trav-btn:hover{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.heap-type-toggle{gap:12px;display:flex}.toggle-label{color:var(--text-muted);cursor:pointer;align-items:center;gap:4px;font-size:12px;display:flex}.autocomplete-section{flex-direction:column;gap:4px;margin-top:4px;display:flex}.autocomplete-results{flex-wrap:wrap;gap:3px;max-height:80px;display:flex;overflow-y:auto}.autocomplete-tag{font-family:var(--font-code);background:var(--accent-soft);color:var(--accent);cursor:pointer;border:1px solid #5b4fcf33;border-radius:3px;padding:2px 6px;font-size:11px}.autocomplete-tag:hover{background:var(--accent);color:#fff}.btree-order{flex-direction:column;gap:4px;margin-top:4px;display:flex}.order-buttons{gap:3px;display:flex}.order-btn{font-family:var(--font-code);border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:4px;padding:4px 10px;font-size:12px;font-weight:500;transition:all .15s}.order-btn:hover{background:var(--bg-panel)}.order-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.range-inputs{align-items:center;gap:4px;display:flex}.batch-section{border-top:1px solid var(--border-soft);flex-direction:column;gap:6px;margin-top:8px;padding-top:8px;display:flex}.batch-input{width:100%;font-family:var(--font-code);background:var(--bg);border:1px solid var(--border);color:var(--text-code);resize:none;border-radius:5px;outline:none;padding:6px 8px;font-size:12px;line-height:1.4}.batch-input:focus{border-color:var(--accent)}.action-row{border-top:1px solid var(--border-soft);grid-template-columns:1fr 1fr;gap:4px;margin-top:8px;padding-top:8px;display:grid}.action-btn{font-family:var(--font-ui);border:1px solid var(--border);background:var(--bg-panel);color:var(--text);cursor:pointer;border-radius:5px;padding:6px 4px;font-size:12px;font-weight:500;transition:all .15s}.action-btn:hover{background:var(--border)}.action-btn.danger{color:var(--col-unbalanced)}.action-btn.danger:hover{border-color:var(--col-unbalanced);background:#fef2f2}.property-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.prop-item{background:var(--bg);border:1px solid var(--border-soft);border-radius:5px;flex-direction:column;gap:1px;padding:6px 8px;display:flex}.prop-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600}.prop-value{font-family:var(--font-code);color:var(--text-code);font-size:14px;font-weight:500}#canvas-area{background:var(--bg);flex-direction:column;display:flex;position:relative;overflow:hidden}#canvas-wrapper{flex:1;position:relative;overflow:hidden}#tree-canvas{width:100%;height:100%;display:block}.canvas-message{background:var(--text-code);color:#fff;font-family:var(--font-ui);pointer-events:none;opacity:1;white-space:nowrap;border-radius:20px;padding:8px 16px;font-size:13px;font-weight:500;transition:opacity .3s;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.canvas-message.hidden{opacity:0}.heap-array-view{border-top:1px solid var(--border);background:var(--bg-card);flex-shrink:0;align-items:center;gap:10px;height:56px;padding:10px 16px;display:flex;overflow-x:auto}.sorted-array-view{border-top:1px solid var(--border);background:var(--bg-card);flex-shrink:0;align-items:center;gap:10px;height:48px;padding:8px 16px;display:flex;overflow-x:auto}.array-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;font-size:11px;font-weight:600}.heap-array-cells,.sorted-array-cells{align-items:center;gap:3px;display:flex}.array-cell{font-family:var(--font-code);background:var(--bg);border:1px solid var(--border);min-width:32px;height:32px;color:var(--text-code);border-radius:4px;justify-content:center;align-items:center;font-size:12px;font-weight:500;transition:all .2s;display:flex;position:relative}.array-cell .cell-idx{color:var(--text-muted);font-size:9px;position:absolute;top:-14px;left:50%;transform:translate(-50%)}.array-cell.highlight{background:var(--col-highlight);color:#fff;border-color:var(--col-highlight)}.array-cell.compare{background:var(--col-compare);color:#fff;border-color:var(--col-compare)}.array-cell.swap{background:var(--col-swap);color:#fff;border-color:var(--col-swap)}.sorted-cell{font-family:var(--font-code);background:var(--bg);border:1px solid var(--border);color:var(--text-code);border-radius:4px;padding:3px 8px;font-size:12px;transition:background .2s}.sorted-cell.highlight{background:var(--col-highlight);color:#fff}.op-log{flex-direction:column;gap:3px;max-height:260px;list-style:none;display:flex;overflow-y:auto}.op-log-item{color:var(--text-muted);border-left:3px solid var(--border);background:var(--bg);font-size:12px;font-family:var(--font-code);border-radius:4px;padding:4px 6px;animation:.2s ease-out logSlide}.op-log-item.insert{border-color:var(--col-balanced)}.op-log-item.delete{border-color:var(--col-unbalanced)}.op-log-item.search{border-color:var(--col-compare)}.op-log-item.found{border-color:var(--col-highlight);color:var(--col-highlight)}.op-log-item.rotate{border-color:var(--col-swap)}.op-log-item.recolor{border-color:var(--col-red-node)}@keyframes logSlide{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}.legend-items{flex-direction:column;gap:5px;display:flex}.legend-item{color:var(--text-muted);align-items:center;gap:7px;font-size:12px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.legend-dot.default{background:var(--col-default)}.legend-dot.highlight{background:var(--col-highlight)}.legend-dot.compare{background:var(--col-compare)}.legend-dot.swap{background:var(--col-swap)}.legend-dot.balanced{background:var(--col-balanced)}.legend-dot.unbalanced{background:var(--col-unbalanced)}.hidden{display:none!important}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}
