:root{--bg-color:#0f111a;--panel-bg:#1a1d2d;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--accent:#3b82f6;--accent-hover:#2563eb;--cell-default:#2d3748;--cell-comparing:#facc15;--cell-swapping:#ef4444;--cell-writing:#f97316;--cell-shifting:#8b5cf6;--cell-selected:#0ea5e9;--cell-pivot:#d946ef;--cell-floating:#22d3ee;--cell-sorted:#10b981;--border-radius-sm:4px;--border-radius-md:8px;--border-radius-lg:12px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);flex-direction:column;min-height:100vh;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;display:flex}#root{flex-direction:column;flex:1;display:flex}button{cursor:pointer;border-radius:var(--border-radius-md);background-color:var(--accent);color:#fff;border:none;padding:8px 16px;font-weight:600;transition:background-color .2s,transform .1s}button:hover:not(:disabled){background-color:var(--accent-hover)}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.5;cursor:not-allowed}input[type=range]{accent-color:var(--accent)}select{border-radius:var(--border-radius-sm);background:var(--bg-color);color:var(--text-primary);border:1px solid var(--panel-bg);padding:8px}.control-panel{background-color:var(--panel-bg);border-radius:var(--border-radius-lg);flex-direction:column;gap:20px;margin-bottom:20px;padding:20px;display:flex}.controls-row{flex-wrap:wrap;align-items:center;gap:20px;display:flex}.control-group{flex-direction:column;gap:8px;display:flex}.control-group.algorithm-group,.control-group.input-type-group,.control-group.view-mode-group{flex-basis:100%}.control-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem}.slider-group{min-width:150px}.buttons-row{flex-wrap:wrap;gap:10px;display:flex}.buttons-row button{flex:1;min-width:100px}.algorithm-selector-btn{border-radius:var(--border-radius-md);width:100%;color:var(--text-primary);cursor:pointer;background-color:#ffffff0d;border:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding:10px 15px;font-size:.95rem;font-weight:500;transition:all .2s;display:flex}.algorithm-selector-btn:hover{border-color:var(--accent);background-color:#ffffff1a}.algorithm-selector-btn.active{border-color:var(--accent);color:var(--accent);background-color:#a855f726}.dropdown-icon{color:var(--text-secondary);font-size:.8rem;transition:transform .2s}.algorithm-selector-btn.active .dropdown-icon{color:var(--accent)}button:disabled{opacity:.5;cursor:not-allowed;transform:none}button.btn-save{background:var(--success,#10b981);color:#fff;border-color:#10b98180;box-shadow:0 0 10px #10b98166}button.btn-save:hover:not(:disabled){background:#059669;border-color:#10b981;box-shadow:0 0 15px #10b98199}button.btn-edit{background:var(--accent,#3b82f6)}.select-wrapper{width:100%;position:relative}.custom-select{border-radius:var(--border-radius-md);width:100%;color:var(--text-primary);cursor:pointer;appearance:none;background-color:#ffffff0d;border:1px solid #ffffff1a;padding:10px 35px 10px 15px;font-size:.95rem;font-weight:500;transition:all .2s;display:block}.custom-select:hover{border-color:var(--accent);background-color:#ffffff1a}.custom-select:focus{border-color:var(--accent);outline:none}.custom-select option{color:#fff;background-color:#1e293b}.select-wrapper .dropdown-icon{pointer-events:none;position:absolute;top:50%;right:15px;transform:translateY(-50%)}.radio-toggle{border-radius:var(--border-radius-md);background-color:#ffffff0d;border:1px solid #ffffff1a;width:100%;display:flex;overflow:hidden}.radio-label{text-align:center;cursor:pointer;color:var(--text-secondary);text-transform:none;letter-spacing:normal;flex:1;padding:10px 15px;font-size:.95rem;font-weight:500;transition:all .2s;position:relative}.radio-label input[type=radio]{opacity:0;width:0;height:0;position:absolute}.radio-label.active{color:var(--accent);background-color:#a855f726}.radio-label:not(.active):hover{color:var(--text-primary);background-color:#ffffff0d}.radio-label:first-child{border-right:1px solid #ffffff1a}.cell-wrapper{flex-direction:column;align-items:center;width:48px;margin:0 4px;display:flex;position:relative}.cell{border-radius:var(--border-radius-sm);background-color:var(--cell-default);justify-content:center;align-items:center;width:100%;height:48px;font-size:1.1rem;font-weight:700;transition:all .3s;display:flex;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.cell.comparing{background-color:var(--cell-comparing);color:#1a1d2d;transform:translateY(-4px)}.cell.swapping{background-color:var(--cell-swapping);transform:translateY(-8px)}.cell.shifting{background-color:var(--cell-shifting);transform:translate(4px)}.cell.selected{background-color:var(--cell-selected);transform:translateY(-4px)}.cell.pivot{background-color:var(--cell-pivot);z-index:5;border:2px solid #fff;transform:scale(1.1)}.cell.writing{background-color:var(--cell-writing);transform:scale(1.05)}.cell.sorted{background-color:var(--cell-sorted)}.cell.empty{border:2px dashed var(--text-secondary);box-shadow:none;background-color:#0000}.cell-wrapper.floating{z-index:10;position:absolute;top:-64px}.cell.floating{background-color:var(--cell-floating);box-shadow:0 10px 15px -3px #0000004d}.cell-label{color:var(--text-secondary);background-color:var(--bg-color);white-space:nowrap;border-radius:4px;padding:2px 6px;font-size:.75rem;font-weight:700;position:absolute;top:-24px}.pointers{flex-direction:column;align-items:center;gap:2px;min-height:40px;margin-top:24px;display:flex}.pointer-label{color:var(--accent);background:#ffffff1a;border-radius:4px;padding:2px 6px;font-size:.75rem}.index-label{color:var(--text-secondary);margin-bottom:4px;font-size:.75rem}.cell-input{text-align:center;width:100%;height:100%;color:inherit;font-family:inherit;font-weight:inherit;font-size:inherit;background:0 0;border:none;outline:none}.cell-input::placeholder{color:#fff3}.cell.text-sm{font-size:.85rem}.array-view-container{background-color:var(--panel-bg);border-radius:var(--border-radius-lg);scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:#8b5cf680 #ffffff0d;flex-direction:column;align-items:safe center;margin:20px 0;display:flex;overflow-x:auto}.array-view-container.single-mode{min-height:280px;padding:80px 20px 40px}.array-view-container.split-mode{gap:30px;padding:20px}.array-view-container::-webkit-scrollbar{height:8px}.array-view-container::-webkit-scrollbar-track{background:#ffffff0d;border-radius:8px;margin:0 20px}.array-view-container::-webkit-scrollbar-thumb{cursor:pointer;background:#8b5cf680;border-radius:8px}.array-view-container::-webkit-scrollbar-thumb:hover{background:#8b5cf6cc}.memory-panel{border-radius:var(--border-radius-md);background-color:#ffffff05;border:1px solid #ffffff0d;flex-direction:column;align-items:center;min-width:100%;display:flex;position:relative}.memory-panel.main-memory{min-height:280px;padding:80px 20px 40px}.memory-panel.aux-memory{padding:40px 20px 20px}.memory-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;pointer-events:none;margin:0;font-size:.85rem;position:absolute;top:12px;left:20px}.array-row{flex-direction:row;align-items:flex-start;display:flex;position:relative}.cell-column{flex-direction:column;align-items:center;display:flex;position:relative}.range-label{color:var(--text-secondary);text-transform:uppercase;margin-bottom:-10px;font-size:.9rem}.out-of-range{opacity:.3}.auxiliary-array-container{flex-direction:column;align-items:center;margin-top:20px;display:flex}.auxiliary-label{color:var(--text-secondary);margin-bottom:8px;font-size:.85rem}.range-annotation{pointer-events:none;z-index:2;justify-content:center;align-items:flex-end;height:20px;display:flex;position:absolute;top:64px}.annotation-label{white-space:nowrap;color:var(--text-secondary);background:var(--bg-color);border-radius:4px;padding:0 4px;font-size:.75rem;position:absolute;top:12px}.range-annotation.ordered-prefix{background-color:#10b9810d;border:1px dashed #10b98166;border-top:none;border-radius:0 0 8px 8px;height:58px;top:16px}.range-annotation.ordered-prefix .annotation-label{color:#10b981;top:50px}.range-annotation.active-range{border:1px solid #fff3;border-top:none;border-radius:0 0 8px 8px;height:58px;top:16px}.range-annotation.active-range .annotation-label{top:50px}.range-annotation.merge-run{border-bottom:2px solid var(--accent);height:10px;top:64px}.range-annotation.merge-run .annotation-label{color:var(--accent);top:4px}.range-annotation.gap-sequence{height:48px;top:16px}.gap-sequence-container{width:100%;height:100%;position:absolute;top:0;left:0}.gap-highlight{background-color:#8b5cf626;border-bottom:2px solid #8b5cf6;border-radius:4px;width:56px;height:100%;position:absolute;top:0}.range-annotation.gap-sequence .annotation-label{color:#8b5cf6;top:50px}.bars-view-container{background-color:var(--panel-bg);border-radius:var(--border-radius-lg);border:1px solid #ffffff0d;flex-direction:column;justify-content:flex-end;align-items:center;width:100%;min-height:400px;margin:20px 0;padding:40px;display:flex}.bars-wrapper{justify-content:center;align-items:flex-end;gap:2px;width:100%;height:300px;display:flex}.bar{background-color:var(--cell-default);border-radius:2px 2px 0 0;flex:1;min-width:2px;transition:background-color .1s,height .1s}.bar.comparing{background-color:var(--cell-comparing)}.bar.swapping{background-color:var(--cell-swapping)}.bar.shifting{background-color:var(--cell-shifting)}.bar.selected{background-color:var(--cell-selected)}.bar.pivot{background-color:var(--cell-pivot)}.bar.writing{background-color:var(--cell-writing)}.bar.sorted{background-color:var(--cell-sorted)}.bar.empty{background-color:#0000}.stats-panel{background-color:var(--panel-bg);border-radius:var(--border-radius-lg);flex-direction:column;gap:12px;margin-bottom:20px;padding:16px 20px;display:flex}.stat-item{border-bottom:1px solid #ffffff0d;flex-direction:row;justify-content:space-between;align-items:center;padding-bottom:8px;display:flex}.stat-item:last-child{border-bottom:none;padding-bottom:0}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.stat-value{color:var(--accent);font-size:1.1rem;font-weight:600}.step-message{background-color:var(--panel-bg);border-left:4px solid var(--accent);border-radius:var(--border-radius-md);color:var(--text-primary);margin-bottom:20px;padding:16px 20px;font-size:1.1rem;line-height:1.5}.pseudocode-panel{background-color:var(--panel-bg);border-radius:var(--border-radius-lg);padding:20px}.pseudocode-panel h3{color:var(--text-secondary);text-transform:uppercase;margin-bottom:12px;font-size:.9rem}.pseudocode-panel pre{background-color:var(--bg-color);border-radius:var(--border-radius-md);color:var(--text-primary);padding:16px;font-family:monospace;font-size:.9rem;line-height:1.5;overflow-x:auto}.code-line{border-radius:4px;padding:2px 4px;transition:background-color .2s,color .2s}.code-line.active{color:var(--primary-color);background-color:#ffffff26;font-weight:700}.legend-panel{background-color:var(--panel-bg);border-radius:var(--border-radius-md);margin-top:20px;padding:15px 20px}.legend-header{border-bottom:1px solid #ffffff1a;flex-direction:column;gap:4px;margin-bottom:12px;padding-bottom:8px;display:flex}.legend-panel h3{color:var(--text-primary);margin:0;font-size:1.1rem}.legend-subtitle{color:var(--text-secondary);font-size:.85rem;font-style:italic}.legend-main-grid{grid-template-columns:1fr 1fr;gap:15px;margin-bottom:16px;display:grid}.legend-column{flex-direction:column;gap:12px;display:flex}.legend-group{flex-direction:column;gap:6px;display:flex}.legend-group h5{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:.8rem}.legend-hints{border-top:1px solid #ffffff1a;padding-top:12px}.legend-hints h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:.8rem}.legend-hints-grid{grid-template-columns:1fr;gap:6px;display:grid}.legend-item{color:var(--text-primary);cursor:help;align-items:center;margin-bottom:8px;font-size:.85rem;display:flex}.legend-color{border-radius:3px;flex-shrink:0;width:14px;height:14px;margin-right:8px}.legend-color.pivot{border:1px solid #fff}.legend-annotation{flex-shrink:0;width:20px;height:10px;margin-right:8px}.legend-annotation.ordered-prefix{background-color:#10b9810d;border:1px dashed #10b98166;border-top:none;border-radius:0 0 4px 4px}.legend-annotation.active-range{border:1px solid #fff3;border-top:none;border-radius:0 0 4px 4px}.legend-annotation.merge-run{border-bottom:2px solid var(--accent)}.legend-annotation.gap-sequence{background-color:#8b5cf626;border-bottom:2px solid #8b5cf6;border-radius:2px}.legend-footer{text-align:center;border-top:1px solid #ffffff1a;margin-top:16px;padding-top:12px}.legend-toggle-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:.85rem;transition:all .2s}.legend-toggle-btn:hover{color:var(--text-primary);background:#ffffff1a;text-decoration:none}.algorithm-info-panel{background-color:var(--panel-bg);border-radius:var(--border-radius-md);color:var(--text-primary);padding:20px}.algorithm-info-panel h3{color:var(--accent);border-bottom:1px solid #ffffff1a;margin-bottom:12px;padding-bottom:8px;font-size:1.25rem}.algorithm-info-panel .description{color:var(--text-primary);margin-bottom:20px;font-size:.95rem;line-height:1.5}.complexity-grid{grid-template-columns:1fr 1fr;gap:15px;margin-bottom:20px;display:grid}.complexity-section{border-radius:var(--border-radius-sm);background-color:#0003;border:1px solid #ffffff0d;padding:12px}.complexity-section h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:.85rem}.complexity-section ul{margin:0;padding:0;list-style-type:none}.complexity-section li{justify-content:space-between;margin-bottom:4px;font-size:.9rem;display:flex}.complexity-section .label{color:var(--text-secondary)}.complexity-section .value{color:var(--text-primary);background:#ffffff1a;border-radius:3px;padding:2px 6px;font-family:monospace;font-size:.85rem;font-weight:700}.info-section{margin-bottom:20px}.info-section h4{margin-bottom:6px;font-size:.9rem}.stable-yes{color:var(--cell-sorted)}.stable-no{color:var(--cell-swapping)}.detail-text{color:var(--text-secondary);font-size:.85rem;line-height:1.4}.pros-cons-grid{grid-template-columns:1fr 1fr;gap:15px;display:grid}.pros-title{color:var(--cell-sorted)}.cons-title{color:var(--cell-swapping)}.bullet-list{color:var(--text-secondary);margin:0;padding-left:18px;font-size:.85rem;line-height:1.4}.bullet-list li{margin-bottom:6px}.notes-section{border-left:3px solid var(--accent);border-radius:0 var(--border-radius-sm) var(--border-radius-sm) 0;background-color:#3b82f61a;margin-bottom:0;padding:12px 15px}.notes-section h4{color:var(--accent)}.algorithm-selection-list{flex-direction:column;align-items:center;width:100%;padding:40px 20px;display:flex}.algorithm-selection-list h2{color:var(--text-primary);background:linear-gradient(90deg, var(--accent), #a855f7);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:30px;font-size:2rem}.algorithm-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;width:100%;max-width:1000px;display:grid}.algorithm-card{background-color:var(--panel-bg);border-radius:var(--border-radius-lg);text-align:left;cursor:pointer;border:1px solid #ffffff0d;flex-direction:column;justify-content:space-between;min-height:120px;padding:20px;transition:all .3s;display:flex;position:relative;overflow:hidden}.algorithm-card:before{content:"";background-color:#0000;width:4px;height:100%;transition:background-color .3s;position:absolute;top:0;left:0}.algorithm-card:hover{background-color:#ffffff08;border-color:#8b5cf64d;transform:translateY(-5px);box-shadow:0 10px 20px #0003}.algorithm-card:hover:before{background-color:var(--accent)}.algorithm-card.active{border-color:var(--accent);background-color:#8b5cf61a}.algorithm-card.active:before{background-color:var(--accent)}.algorithm-card-content{justify-content:space-between;align-items:flex-start;margin-bottom:15px;display:flex}.algorithm-card-content h3{color:var(--text-primary);margin:0;font-size:1.2rem}.complexity-badge{font-size:.8rem;font-family:var(--font-mono);color:var(--text-secondary);background-color:#ffffff1a;border-radius:4px;padding:4px 8px}.algorithm-card-footer{justify-content:flex-start;display:flex}.stable-badge{text-transform:uppercase;border-radius:4px;padding:4px 8px;font-size:.75rem;font-weight:600}.stable-badge.stable{color:#10b981;background-color:#10b9811a}.stable-badge.unstable{color:#ef4444;background-color:#ef44441a}.sorting-visualizer{width:100%;max-width:1700px;margin:0 auto;padding:20px}.header{text-align:center;margin-bottom:30px}.header h1{background:linear-gradient(90deg, var(--accent), #a855f7);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:2.5rem}.main-content{grid-template-columns:1fr;gap:30px;display:grid}@media (width>=992px){.main-content{grid-template-columns:350px 1fr;transition:grid-template-columns .4s cubic-bezier(.4,0,.2,1)}.main-content.selection-mode{grid-template-columns:450px 1fr}.left-column{grid-area:1/1/span 2}.right-column,.info-column{grid-column:2}}@media (width>=1400px){.main-content{grid-template-columns:320px 1fr 380px}.main-content.selection-mode{grid-template-columns:450px 1fr}.left-column{grid-area:1/1}.right-column{grid-column:2}.info-column{grid-area:1/3}}.left-column,.right-column,.info-column{flex-direction:column;min-width:0;display:flex}.fade-in-section{animation:.4s forwards fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
