.tree-visualizer{display:flex;flex-direction:column;height:100%;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);overflow:hidden}.visualizer-controls{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.visualizer-controls button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:1.25rem;transition:all .2s ease}.visualizer-controls button:hover{background:var(--accent-cyan);border-color:var(--accent-cyan);color:var(--bg-primary)}.zoom-level{min-width:50px;text-align:center;font-family:var(--font-mono);font-size:.8rem;color:var(--text-secondary)}.reset-btn,.fit-btn{width:auto!important;padding:0 .75rem!important;font-size:.85rem!important;margin-left:.25rem}.tree-info{margin-left:auto;display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-muted);font-family:var(--font-mono)}.tree-canvas-container{flex:1;overflow:hidden;cursor:grab;position:relative;background:var(--bg-primary)}.tree-canvas-container:active{cursor:grabbing}.tree-canvas-container canvas{display:block}.node-tooltip{position:absolute;transform:translate(-50%);background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:.75rem;min-width:180px;box-shadow:0 10px 30px #00000080;z-index:100;pointer-events:none;animation:tooltip-appear .2s ease}@keyframes tooltip-appear{0%{opacity:0;transform:translate(-50%) translateY(-5px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.tooltip-header{font-weight:600;font-size:.9rem;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.tooltip-content{display:flex;flex-direction:column;gap:.35rem}.tooltip-row{display:flex;justify-content:space-between;font-size:.8rem}.tooltip-row span:first-child{color:var(--text-secondary)}.tooltip-row span:last-child{font-family:var(--font-mono);color:var(--text-primary)}.tooltip-keys{display:flex;flex-direction:column;gap:.25rem;margin-top:.25rem;padding-top:.5rem;border-top:1px solid var(--border-color);font-size:.75rem}.tooltip-keys span:first-child{color:var(--text-muted)}.key-range{font-family:var(--font-mono);color:var(--accent-cyan)}.tooltip-divider{height:1px;background:var(--border-color);margin:.35rem 0}.tooltip-distribution{display:flex;flex-direction:column;gap:.25rem;margin-top:.25rem}.dist-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;font-family:var(--font-mono)}.dist-color{width:10px;height:10px;border-radius:2px;flex-shrink:0}.visualizer-legend{display:flex;align-items:center;gap:1.5rem;padding:.75rem 1rem;background:var(--bg-tertiary);border-top:1px solid var(--border-color)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-secondary)}.legend-dot{width:12px;height:12px;border-radius:3px}.legend-dot.internal{background:#00d9ff4d;border:2px solid var(--accent-cyan)}.legend-dot.leaf{background:linear-gradient(135deg,#e2363680,#36e26780,#9b36e280);border:2px solid var(--accent-green)}.legend-hint{margin-left:auto;font-size:.75rem;color:var(--text-muted);font-style:italic}.distribution-chart{display:flex;flex-direction:column;height:100%;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);overflow:hidden}.chart-controls{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);flex-wrap:wrap}.view-mode-selector{display:flex;gap:.25rem;background:var(--bg-card);padding:.25rem;border-radius:8px}.view-mode-selector button{padding:.5rem 1rem;border-radius:6px;font-size:.85rem;color:var(--text-secondary);transition:all .2s ease}.view-mode-selector button:hover{color:var(--text-primary)}.view-mode-selector button.active{background:var(--accent-cyan);color:var(--bg-primary);font-weight:500}.node-filter{display:flex;align-items:center;gap:.5rem}.node-filter label{font-size:.85rem;color:var(--text-secondary)}.node-filter select{min-width:150px}.chart-content{flex:1;padding:1.5rem;overflow:auto}.empty-chart{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-style:italic}.timeline-view{display:flex;flex-direction:column;height:100%}.timeline-chart{flex:1;display:flex;align-items:flex-end;gap:2px;padding:1rem 0;min-height:300px}.timeline-bar-container{flex:1;height:100%;display:flex;align-items:flex-end}.timeline-bar{width:100%;display:flex;flex-direction:column-reverse;border-radius:2px 2px 0 0;overflow:hidden;min-height:2px;transition:height .3s ease}.bar-segment{width:100%;transition:height .3s ease}.timeline-axis{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.75rem;color:var(--text-muted);border-top:1px solid var(--border-color)}.heatmap-view{display:flex;flex-direction:column;gap:1rem}.heatmap-header{display:flex;justify-content:space-between;font-size:.9rem;color:var(--text-secondary)}.heatmap-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:3px;background:var(--bg-tertiary);padding:.5rem;border-radius:8px}.heatmap-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:4px;cursor:pointer;transition:all .2s ease;position:relative}.heatmap-cell:hover{transform:scale(1.1);z-index:1;box-shadow:0 0 10px #0000004d}.cell-count{font-family:var(--font-mono);font-size:.65rem;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.heatmap-legend{padding-top:1rem}.legend-scale{display:flex;align-items:center;gap:.75rem;font-size:.75rem;color:var(--text-muted)}.gradient-bar{flex:1;height:8px;border-radius:4px;background:linear-gradient(to right,#269dd933,#269dd9)}.histogram-view{display:flex;flex-direction:column;gap:1.5rem}.histogram-chart{display:flex;align-items:flex-end;gap:.75rem;min-height:300px;padding:1rem 0}.histogram-bar-container{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;max-width:80px}.bar-value{font-family:var(--font-mono);font-size:.7rem;color:var(--text-secondary);margin-bottom:.5rem}.histogram-bar{width:100%;border-radius:4px 4px 0 0;transition:all .3s ease;position:relative}.histogram-bar:hover{filter:brightness(1.2)}.histogram-bar.above-avg:after{content:"▲";position:absolute;top:-16px;left:50%;transform:translate(-50%);font-size:.6rem;color:var(--accent-green)}.bar-label{margin-top:.5rem;font-size:.75rem;color:var(--text-muted);text-align:center;white-space:nowrap}.histogram-stats{display:flex;justify-content:center;gap:2rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px}.histogram-stats .stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.histogram-stats .stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.histogram-stats .stat-value{font-family:var(--font-mono);font-size:1.1rem;font-weight:600;color:var(--accent-cyan)}.control-panel{background:var(--bg-card);border-radius:12px;border:1px solid var(--border-color);padding:1.25rem}.panel-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.panel-icon{font-size:1.25rem}.panel-header h2{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.id-type-selector{display:flex;gap:.5rem}.id-type-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:8px;transition:all .2s ease}.id-type-btn:hover:not(:disabled){border-color:var(--accent-cyan)}.id-type-btn.active{background:#00d9ff1a;border-color:var(--accent-cyan)}.id-type-btn:disabled{opacity:.5;cursor:not-allowed}.id-type-icon{font-size:1.5rem}.id-type-name{font-size:.85rem;font-weight:600;color:var(--text-primary)}.id-type-bits{font-size:.7rem;font-family:var(--font-mono);color:var(--text-muted)}.id-type-btn.active .id-type-name{color:var(--accent-cyan)}.control-group{margin-bottom:1.25rem}.control-label{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.label-text{font-size:.875rem;font-weight:500;color:var(--text-primary)}.label-hint{font-size:.75rem;color:var(--text-muted);font-family:var(--font-mono)}.input-with-controls{display:flex;gap:0}.input-with-controls input{flex:1;text-align:center;border-radius:0;border-left:none;border-right:none}.stepper-btn{width:40px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);font-size:1.25rem;font-weight:500;transition:all .2s ease}.stepper-btn:first-child{border-radius:8px 0 0 8px}.stepper-btn:last-child{border-radius:0 8px 8px 0}.stepper-btn:hover:not(:disabled){background:var(--accent-cyan);border-color:var(--accent-cyan);color:var(--bg-primary)}.stepper-btn:disabled{opacity:.5;cursor:not-allowed}.control-range{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.control-range input[type=range]{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;background:var(--bg-tertiary);border-radius:3px;border:none;padding:0}.control-range input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:var(--accent-cyan);border-radius:50%;cursor:pointer;box-shadow:0 0 10px #00d9ff80;transition:transform .2s ease}.control-range input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}.control-range input[type=range]::-moz-range-thumb{width:16px;height:16px;background:var(--accent-cyan);border-radius:50%;cursor:pointer;border:none;box-shadow:0 0 10px #00d9ff80}.range-value{min-width:50px;text-align:right;font-family:var(--font-mono);font-size:.8rem;color:var(--accent-cyan)}.total-preview{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#00d9ff0d;border:1px solid rgba(0,217,255,.2);border-radius:8px;margin-bottom:1.25rem}.preview-label{font-size:.875rem;color:var(--text-secondary)}.preview-value{font-family:var(--font-mono);font-size:1rem;font-weight:600;color:var(--accent-cyan)}.button-group{display:flex;flex-direction:column;gap:.5rem}.generate-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem 1.5rem;background:var(--gradient-glow);border-radius:8px;font-size:1rem;font-weight:600;color:var(--bg-primary);transition:all .3s ease;box-shadow:0 4px 15px #00d9ff4d}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #00d9ff66}.generate-btn:active:not(:disabled){transform:translateY(0)}.generate-btn:disabled{opacity:.7;cursor:not-allowed}.btn-icon{font-size:1.1rem}.spinner{width:18px;height:18px;border:2px solid rgba(0,0,0,.2);border-top-color:var(--bg-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.clear-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem 1.25rem;background:transparent;border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;font-weight:500;color:var(--text-secondary);transition:all .2s ease}.clear-btn:hover{border-color:var(--accent-magenta);color:var(--accent-magenta);background:#ff00801a}.progress-container{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--bg-tertiary);border-radius:8px;margin-bottom:1rem}.progress-text{font-size:.75rem;color:var(--text-secondary);font-family:var(--font-mono)}.progress-bar{height:6px;background:var(--bg-secondary);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--gradient-glow);border-radius:3px;transition:width .2s ease}.progress-percent{font-size:.8rem;font-family:var(--font-mono);color:var(--accent-cyan);text-align:right}.stats-panel{background:var(--bg-card);border-radius:12px;border:1px solid var(--border-color);padding:1.25rem}.stats-panel .panel-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.stats-panel .panel-icon{font-size:1.25rem}.stats-panel .panel-header h2{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.generation-time{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#00ff9f1a;border:1px solid rgba(0,255,159,.3);border-radius:8px;margin-bottom:1rem}.time-icon{font-size:1rem}.time-label{font-size:.8rem;color:var(--text-secondary)}.time-value{margin-left:auto;font-family:var(--font-mono);font-size:.9rem;font-weight:600;color:var(--accent-green)}.id-type-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#00d9ff1a;border:1px solid rgba(0,217,255,.3);border-radius:6px;margin-bottom:1rem}.badge-icon{font-size:1rem}.badge-text{font-size:.8rem;font-family:var(--font-mono);color:var(--accent-cyan)}.stats-section{margin-bottom:1.25rem}.stats-section:last-child{margin-bottom:0}.section-title{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-item{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:var(--bg-tertiary);border-radius:8px;text-align:center}.stat-value{font-family:var(--font-mono);font-size:1.5rem;font-weight:600;color:var(--accent-cyan);line-height:1}.stat-label{font-size:.7rem;color:var(--text-muted);margin-top:.25rem;text-transform:uppercase;letter-spacing:.03em}.stats-list{display:flex;flex-direction:column;gap:.5rem}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px dashed var(--border-color)}.stat-row:last-child{border-bottom:none}.stat-key{font-size:.8rem;color:var(--text-secondary)}.stat-val{font-family:var(--font-mono);font-size:.875rem;color:var(--text-primary)}.stat-val.highlight{color:var(--accent-cyan);font-weight:600}.node-distribution{display:flex;flex-direction:column;gap:.5rem}.node-bar-container{display:flex;flex-direction:column;gap:.25rem}.node-bar-label{display:flex;justify-content:space-between;align-items:center}.node-id{font-size:.75rem;font-family:var(--font-mono);color:var(--text-secondary)}.node-count{font-size:.75rem;font-family:var(--font-mono);color:var(--text-muted)}.node-bar-track{height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.node-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}.more-nodes{font-size:.75rem;color:var(--text-muted);text-align:center;padding-top:.5rem;font-style:italic}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{position:relative;padding:2rem 3rem;background:var(--gradient-card);border-bottom:1px solid var(--border-color);overflow:hidden}.header-content{position:relative;z-index:1}.header-decoration{position:absolute;top:0;right:0;width:400px;height:100%;background:linear-gradient(135deg,transparent 0%,rgba(0,217,255,.05) 50%,rgba(189,0,255,.05) 100%);clip-path:polygon(30% 0,100% 0,100% 100%,0% 100%)}.logo{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.logo-icon{font-size:2.5rem;animation:float 3s ease-in-out infinite}.logo h1{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.02em}.logo h1 .highlight{background:var(--gradient-glow);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:var(--text-secondary);font-size:1rem;margin:0;font-family:var(--font-mono)}.app-main{flex:1;display:flex;gap:0}.sidebar{width:320px;min-width:320px;background:var(--bg-secondary);border-right:1px solid var(--border-color);padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto;max-height:calc(100vh - 120px)}.content{flex:1;display:flex;flex-direction:column;background:var(--bg-primary);overflow:hidden}.tab-bar{display:flex;gap:.5rem;padding:1rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.tab-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:8px;font-size:.9rem;font-weight:500;color:var(--text-secondary);background:transparent;transition:all .2s ease}.tab-button:hover{color:var(--text-primary);background:var(--bg-tertiary)}.tab-button.active{color:var(--accent-cyan);background:#00d9ff1a;box-shadow:inset 0 0 0 1px #00d9ff4d}.tab-icon{font-size:1.1rem}.visualization-container{flex:1;overflow:auto;padding:1.5rem}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem;color:var(--text-secondary)}.empty-state-icon{font-size:5rem;margin-bottom:1.5rem;opacity:.5;animation:float 4s ease-in-out infinite}.empty-state h2{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.empty-state p{font-size:1rem;max-width:400px;margin-bottom:2rem;line-height:1.6}.empty-state strong{color:var(--accent-cyan)}.empty-state-hint{display:flex;flex-direction:column;gap:.75rem;text-align:left}.hint-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--bg-card);border-radius:8px;border:1px solid var(--border-color);font-size:.9rem}.hint-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--gradient-glow);border-radius:50%;font-weight:600;font-size:.8rem;color:var(--bg-primary)}@media (max-width: 1024px){.app-main{flex-direction:column}.sidebar{width:100%;min-width:100%;max-height:none;border-right:none;border-bottom:1px solid var(--border-color)}}:root{--bg-primary: #0a0e14;--bg-secondary: #0d1117;--bg-tertiary: #161b22;--bg-card: #1a1f2e;--border-color: #30363d;--border-glow: #00d9ff;--accent-cyan: #00d9ff;--accent-magenta: #ff0080;--accent-yellow: #ffcc00;--accent-green: #00ff9f;--accent-purple: #bd00ff;--accent-orange: #ff6b35;--text-primary: #e6edf3;--text-secondary: #8b949e;--text-muted: #484f58;--gradient-glow: linear-gradient(135deg, #00d9ff 0%, #bd00ff 50%, #ff0080 100%);--gradient-card: linear-gradient(145deg, rgba(26, 31, 46, .9) 0%, rgba(13, 17, 23, .95) 100%);--shadow-glow-cyan: 0 0 20px rgba(0, 217, 255, .3);--shadow-glow-magenta: 0 0 20px rgba(255, 0, 128, .3);--font-display: "Outfit", sans-serif;--font-mono: "JetBrains Mono", monospace}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow-x:hidden}body{font-family:var(--font-display);background:var(--bg-primary);color:var(--text-primary);line-height:1.6}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(0,217,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,217,255,.03) 1px,transparent 1px);background-size:50px 50px;pointer-events:none;z-index:-1}#root{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent-cyan)}::selection{background:#00d9ff4d;color:var(--text-primary)}:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}button{font-family:var(--font-display);cursor:pointer;border:none;background:none}input,select{font-family:var(--font-mono);background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);padding:.75rem 1rem;border-radius:8px;font-size:.9rem;transition:all .2s ease}input:hover,select:hover{border-color:var(--accent-cyan)}input:focus,select:focus{outline:none;border-color:var(--accent-cyan);box-shadow:var(--shadow-glow-cyan)}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.5}}@keyframes scan-line{0%{transform:translateY(-100%)}to{transform:translateY(100vh)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}
