*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#1a1a1a;color:#e0e0e0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{background-color:#1a1a1a;color:#e0e0e0;flex-direction:column;height:100vh}.App,.main-content{display:flex;overflow:hidden}.main-content{flex:1 1;flex-direction:column;margin:0 auto;max-width:1400px;min-height:0;padding:10px 20px;width:100%}.title{flex-shrink:0;flex-wrap:wrap;font-size:20px;font-weight:600;gap:12px;justify-content:center;margin-bottom:10px;text-align:center;text-shadow:0 2px 4px #7a7aff4d}.title,.title-link{align-items:center;color:#7a7aff;display:flex}.title-link{gap:8px;text-decoration:none;transition:all .2s}.title-link:hover{color:#9a9aff;transform:translateY(-1px)}.problem-number{background:linear-gradient(135deg,#7a7aff,#9a9aff);border-radius:6px;box-shadow:0 2px 6px #7a7aff4d;color:#1a1a1a;font-size:14px;font-weight:700;padding:2px 8px}.title-badges{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.difficulty-badge{align-items:center;animation:badge-appear .5s ease;border:2px solid;border-radius:16px;box-shadow:0 2px 8px #0000004d;display:inline-flex;font-size:12px;font-weight:700;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}@keyframes badge-appear{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.difficulty-badge.easy{background:linear-gradient(135deg,#4caf50,#66bb6a);border-color:#81c784;box-shadow:0 2px 8px #4caf5066;color:#1a1a1a}.difficulty-badge.medium{background:linear-gradient(135deg,#ff9800,#ffa726);border-color:#ffb74d;box-shadow:0 2px 8px #ff980066;color:#1a1a1a}.difficulty-badge.hard{background:linear-gradient(135deg,#f44336,#ef5350);border-color:#e57373;box-shadow:0 2px 8px #f4433666;color:#fff}.topic-tag{align-items:center;background-color:#3a3a3a;border:1px solid #4a4a4a;border-radius:12px;color:#b0b0b0;display:inline-flex;font-size:11px;font-weight:600;padding:3px 10px;transition:all .2s}.topic-tag:hover{background-color:#4a4a4a;border-color:#5a5a5a;color:#d0d0d0;transform:translateY(-1px)}.control-panel{margin-bottom:15px;padding:15px 20px}.control-panel,.input-section{background-color:#2a2a2a;border-radius:8px;flex-shrink:0}.input-section{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px;padding:10px 15px}.interval-input{background-color:#3a3a3a;border:2px solid #4a4a4a;border-radius:6px;color:#e0e0e0;flex:1 1;font-size:14px;min-width:300px;padding:8px 12px;transition:border-color .2s}.interval-input:focus{border-color:#7a7aff;outline:none}.interval-input::placeholder{color:grey}.apply-button{background-color:#7a7aff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 20px;transition:all .2s}.apply-button:hover{background-color:#9a9aff;box-shadow:0 4px 8px #7a7aff4d;transform:translateY(-2px)}.apply-button:active{transform:translateY(0)}.controls-section{display:flex;flex-direction:column;gap:12px}.speed-control{align-items:center;display:flex;gap:15px}.speed-control label{color:#b0b0b0;font-size:15px;min-width:100px}.speed-control input[type=range]{appearance:none;-webkit-appearance:none;background:#3a3a3a;border-radius:3px;flex:1 1;height:6px;max-width:300px;outline:none}.speed-control input[type=range]::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;background:#7a7aff;border-radius:50%;cursor:pointer;height:18px;-webkit-transition:all .2s;transition:all .2s;width:18px}.speed-control input[type=range]::-webkit-slider-thumb:hover{background:#9a9aff;transform:scale(1.1)}.speed-control input[type=range]::-moz-range-thumb{background:#7a7aff;border:none;border-radius:50%;cursor:pointer;height:18px;-moz-transition:all .2s;transition:all .2s;width:18px}.speed-control input[type=range]::-moz-range-thumb:hover{background:#9a9aff;transform:scale(1.1)}.example-buttons{display:flex;flex-wrap:wrap;gap:10px}.example-buttons button{background-color:#3a3a3a;border:2px solid #4a4a4a;border-radius:6px;color:#e0e0e0;cursor:pointer;font-size:13px;padding:6px 12px;transition:all .2s}.example-buttons button:hover{background-color:#4a4a4a;border-color:#6a6a6a;transform:translateY(-2px)}.example-buttons button:active{transform:translateY(0)}.example-buttons button.random-button{border-color:#9c27b0}.example-buttons button.random-button:hover{background-color:#4a3a4a;border-color:#ba68c8}@media (max-width:768px){.main-content{padding:20px 15px}.title{font-size:24px;margin-bottom:30px}.control-panel{padding:20px}.input-section{flex-direction:column}.interval-input{min-width:100%}.apply-button{width:100%}.speed-control{align-items:flex-start;flex-direction:column}.speed-control input[type=range]{max-width:100%;width:100%}.example-buttons button{flex-basis:calc(50% - 5px);flex-grow:1;flex-shrink:1;min-width:calc(50% - 5px)}}.visualization-container{background-color:#2a2a2a;border-radius:8px;display:flex;flex:1 1;flex-direction:column;min-height:0;overflow-y:auto;padding:10px 15px}.algorithm-hint{background:linear-gradient(135deg,#2a3a4a,#2a3a3a);border-left:4px solid #7a7aff;border-radius:6px;color:#d0d0d0;font-size:12px;line-height:1.4;margin-bottom:8px;padding:6px 12px}.algorithm-hint strong{color:#7a7aff;margin-right:6px}.legend{background-color:#353535;border-radius:6px;display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-bottom:8px;padding:6px 12px}.legend-item{align-items:center;color:silver;display:flex;font-size:11px;gap:6px}.legend-box{border:2px solid;border-radius:3px;height:16px;width:24px}.legend-normal{background-color:#3a3a3a;border-color:#4a4a4a}.legend-highlight{background-color:#4a3a2a;border-color:#ffa726}.legend-processing{background-color:#3a3a2a;border-color:gold;box-shadow:0 0 8px #ffd7004d}.legend-merged{background-color:#2a3a2a;border-color:#66bb6a}.intervals-section{margin-bottom:10px}.section-title{align-items:baseline;color:#b0b0b0;display:flex;font-size:14px;font-weight:500;gap:6px;margin-bottom:8px}.section-subtitle{color:grey;font-size:12px;font-weight:400}.intervals-display{align-items:flex-start;display:flex;flex-wrap:wrap;gap:10px}.interval-box{background-color:#3a3a3a;border:2px solid #4a4a4a;border-radius:6px;min-width:70px;padding:28px 12px 8px;position:relative;text-align:center;transition:all .3s ease}.interval-box.highlighted{animation:pulse .5s ease-in-out;background-color:#4a3a2a;border-color:#ffa726}.interval-box.current{background-color:#3a3a4a;border-color:#7a7aff;transform:scale(1.05)}.interval-box.merged{background-color:#2a3a2a;border-color:#66bb6a}.color-indicator{animation:color-pulse 2s ease-in-out infinite;border-radius:50%;box-shadow:0 0 6px currentColor;height:8px;left:4px;position:absolute;top:4px;width:8px}@keyframes color-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}.interval-box.processing{animation:glow 1.5s ease-in-out infinite;background-color:#3a3a2a;border-color:gold;box-shadow:0 0 10px #ffd7004d}@keyframes glow{0%,to{box-shadow:0 0 10px #ffd7004d}50%{box-shadow:0 0 20px #ffd70099}}.processing-label{background-color:#3a3a2a;border-radius:3px;color:gold;font-size:11px;font-weight:600;padding:2px 6px;top:-20px;white-space:nowrap}.arrow-indicator,.processing-label{left:50%;position:absolute;transform:translateX(-50%)}.arrow-indicator{align-items:center;animation:bounce 1s ease-in-out infinite;display:flex;flex-direction:column;gap:2px;top:-30px}.arrow-icon{filter:drop-shadow(0 2px 4px rgba(255,167,38,.5));font-size:20px}.arrow-label{background-color:#3a3a3a;border:1px solid #ffa726;border-radius:3px;color:#ffa726;font-size:10px;font-weight:600;padding:2px 6px;white-space:nowrap}@keyframes bounce{0%,to{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-5px)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.interval-content{align-items:center;color:#e0e0e0;display:flex;font-size:16px;font-weight:600;gap:3px;justify-content:center}.interval-bracket{color:#b0b0b0;font-size:18px}.interval-value{color:#fff;min-width:24px}.interval-separator{color:#b0b0b0;margin:0 2px}.interval-index{bottom:-20px;color:grey;font-size:12px;left:50%;position:absolute;transform:translateX(-50%)}.merged-section{border-top:1px solid #404040;padding-top:15px;position:relative}.merge-source-indicator{align-items:center;animation:indicator-pulse 2s ease-in-out infinite;background:linear-gradient(135deg,#66bb6a,#81c784);border-radius:12px;box-shadow:0 2px 6px #66bb6a66;color:#1a1a1a;display:flex;font-size:10px;font-weight:700;gap:4px;padding:3px 8px;position:absolute;right:5px;top:-22px}.merge-icon{font-size:12px}.merge-count{letter-spacing:.3px}@keyframes indicator-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.source-intervals-tooltip{background-color:#3a3a3a;border:1px solid #66bb6a;border-radius:6px;bottom:-32px;box-shadow:0 4px 12px #00000080;color:silver;font-size:11px;left:50%;opacity:0;padding:6px 10px;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .3s,transform .3s;white-space:nowrap;z-index:100}.interval-box.merged:hover .source-intervals-tooltip{opacity:1;transform:translateX(-50%) translateY(-5px)}.source-interval{color:#7a7aff;font-weight:600}.merge-arrow{transition:all .3s ease}.merge-arrow:hover{stroke-width:3;opacity:1!important}.merge-arrow.processing{filter:drop-shadow(0 0 4px rgba(255,215,0,.6))}.number-line-section{background:linear-gradient(135deg,#252525,#2a2a2a);border:1px solid #3a3a3a;border-radius:8px;flex-shrink:1;margin-bottom:10px;margin-top:10px;min-height:0;padding:10px}.number-line-container{align-items:stretch;display:flex;gap:20px}.number-line-wrapper{background-color:#2a2a2a;border-radius:6px;box-shadow:inset 0 2px 4px #0000004d;flex:1 1;padding:10px}.number-line{height:auto;min-height:110px;padding:0 10px 20px;position:relative}.separator-line{align-items:center;background:linear-gradient(90deg,#0000 0,#66bb6a 10%,#66bb6a 50%,#66bb6a 90%,#0000);display:flex;height:1px;justify-content:center;left:0;position:absolute;right:0}.separator-label{background-color:#2a2a2a;border:1px solid #66bb6a;border-radius:12px;box-shadow:0 2px 6px #66bb6a4d;color:#66bb6a;font-size:11px;font-weight:600;padding:2px 12px}.baseline{background:linear-gradient(90deg,#0000 0,#505050 5%,#606060 50%,#505050 95%,#0000);height:2px;left:0;position:absolute;right:0;top:15px}.number-line-tick{position:absolute;top:0;transform:translateX(-50%)}.tick-mark{background-color:#606060;box-shadow:0 1px 2px #0000004d;height:12px;margin:0 auto;width:2px}.tick-label{color:#909090;font-size:11px;font-weight:500;margin-top:4px;text-align:center;text-shadow:0 1px 2px #00000080}.number-line-interval{height:18px;position:absolute;transition:all .4s cubic-bezier(.4,0,.2,1);z-index:1}.number-line-interval .interval-bar{background-color:#7a7aff;border:2px solid #7a7aff80;border-radius:9px;height:100%;opacity:.75;overflow:visible;position:relative;transition:all .4s ease;width:100%}.interval-endpoints{display:flex;font-size:10px;font-weight:600;justify-content:space-between;opacity:0;position:absolute;top:-18px;transition:opacity .3s;width:100%}.number-line-interval.active .interval-endpoints,.number-line-interval.processing .interval-endpoints,.number-line-interval:hover .interval-endpoints{opacity:1}.endpoint{background-color:#2a2a2a;border:1px solid;border-radius:3px;color:inherit;padding:2px 5px;white-space:nowrap}.endpoint.start{transform:translateX(-50%)}.endpoint.end{transform:translateX(50%)}.number-line-interval.original .interval-bar{background-color:#7a7aff;border-color:#6a6aee}.number-line-interval.original .interval-endpoints{color:#7a7aff}.number-line-interval.active{z-index:3}.number-line-interval.active .interval-bar{background-color:#ffa726;border-color:#ff9800;box-shadow:0 0 15px #ffa72699,0 4px 8px #0000004d;opacity:.95;transform:scaleY(1.2)}.number-line-interval.active .interval-endpoints{color:#ffa726}.number-line-interval.merged{z-index:2}.number-line-interval.merged .interval-bar{background-color:#66bb6a;border-color:#5cb860;box-shadow:0 2px 6px #66bb6a66;opacity:.85}.number-line-interval.merged .interval-endpoints{color:#66bb6a}.number-line-interval.processing{z-index:4}.number-line-interval.processing .interval-bar{animation:pulse-glow 1.5s ease-in-out infinite;background-color:gold;border-color:#ffed4e;box-shadow:0 0 20px #ffd700cc,0 4px 12px #0000004d;opacity:.95}.number-line-interval.processing .interval-endpoints{color:gold}@keyframes pulse-glow{0%,to{box-shadow:0 0 15px #ffd70099,0 4px 12px #0000004d;transform:scaleY(1)}50%{box-shadow:0 0 25px #ffd700e6,0 6px 16px #0006;transform:scaleY(1.15)}}.interval-pulse{animation:pulse-ring 2s ease-out infinite;border:2px solid #ffa726;border-radius:11px;bottom:-4px;left:-4px;position:absolute;right:-4px;top:-4px}.interval-pulse.processing-pulse{border-color:gold}@keyframes pulse-ring{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.3)}}.processing-badge{animation:badge-bounce 2s ease-in-out infinite;background:linear-gradient(135deg,gold,#ffed4e);border-radius:4px;box-shadow:0 2px 6px #ffd70066;color:#2a2a2a;font-size:10px;font-weight:700;left:50%;padding:3px 8px;position:absolute;top:-25px;transform:translateX(-50%);white-space:nowrap}@keyframes badge-bounce{0%,to{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-3px)}}.connection-lines{left:0;pointer-events:none;position:absolute;right:0;width:100%}.connection-line{stroke:#66bb6a;stroke-width:1.5;opacity:.4;transition:opacity .3s}.connection-line:hover{opacity:.8}.number-line-labels{display:flex;flex-direction:column;gap:20px;justify-content:space-around;min-width:90px}.label-row{align-items:center;background-color:#2a2a2a;box-shadow:0 2px 4px #0003;color:silver;display:flex;font-size:13px;font-weight:500;gap:8px;padding:10px 12px}.label-indicator,.label-row{border:2px solid;border-radius:6px}.label-indicator{height:12px;width:24px}.label-row.original-label{border-color:#7a7aff}.label-row.original-label .label-indicator{background-color:#7a7aff;border-color:#6a6aee}.label-row.merged-label{border-color:#66bb6a}.label-row.merged-label .label-indicator{background-color:#66bb6a;border-color:#5cb860}.status-display{align-items:flex-start;background-color:#353535;border-left:4px solid #7a7aff;border-radius:6px;display:flex;flex-shrink:0;gap:10px;margin-top:10px;padding:8px 12px;transition:all .3s ease}.status-display.initial{background:linear-gradient(135deg,#2a2a3a,#353535);border-left-color:#9c27b0}.status-display.sort{background:linear-gradient(135deg,#2a3a4a,#353535);border-left-color:#2196f3}.status-display.compare_overlap{background:linear-gradient(135deg,#3a3a2a,#353535);border-left-color:#ffa726}.status-display.merge{border-left-color:#66bb6a}.status-display.complete,.status-display.merge{background:linear-gradient(135deg,#2a3a2a,#353535)}.status-display.complete{border-left-color:#4caf50}.status-icon{animation:icon-pop .5s ease;flex-shrink:0;font-size:20px}@keyframes icon-pop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.status-content{flex:1 1}.status-type{color:#7a7aff;font-size:13px;font-weight:600;margin-bottom:4px}.status-message{color:#d0d0d0;font-size:12px;line-height:1.4}@media (max-width:768px){.visualization-container{padding:20px}.intervals-display{gap:10px}.interval-box{min-width:80px;padding:10px 15px}.interval-content{font-size:16px}}.controls-container{background-color:#2a2a2a;border-radius:8px;display:flex;flex-direction:column;flex-shrink:0;gap:10px;padding:10px 15px}.control-buttons{flex-wrap:wrap;gap:10px;margin-bottom:15px}.control-button,.control-buttons{display:flex;justify-content:center}.control-button{align-items:center;background-color:#3a3a3a;border:2px solid #4a4a4a;border-radius:6px;color:#e0e0e0;cursor:pointer;font-size:13px;font-weight:500;gap:5px;min-width:110px;padding:6px 12px;transition:all .2s}.control-button:hover:not(:disabled){background-color:#4a4a4a;border-color:#6a6a6a;transform:translateY(-2px)}.control-button:active:not(:disabled){transform:translateY(0)}.control-button:disabled{cursor:not-allowed;opacity:.4}.control-button.reset-button{border-color:#f44336}.control-button.reset-button:hover:not(:disabled){background-color:#4a3a3a;border-color:#ff5744}.control-button.play-button{border-color:#66bb6a;min-width:150px}.control-button.play-button:hover:not(:disabled){background-color:#3a4a3a;border-color:#77cc7a}.button-icon{font-size:16px}.button-text{font-size:13px}.button-shortcut{color:#909090;font-size:11px}.progress-info{display:flex;justify-content:space-between;margin-bottom:10px;padding:0 5px}.info-item{color:#b0b0b0;font-size:13px;font-weight:500}.progress-bar{background-color:#3a3a3a;border-radius:2px;height:4px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#7a7aff,#66bb6a);height:100%;transition:width .3s ease}@media (max-width:768px){.controls-container{padding:20px}.control-buttons{gap:10px}.control-button{font-size:14px;min-width:120px;padding:10px 15px}.button-text{font-size:14px}.button-shortcut{display:none}.progress-info{flex-direction:column;gap:8px;text-align:center}}.header{align-items:center;background-color:#2a2a2a;border-bottom:1px solid #3a3a3a;display:flex;flex-shrink:0;justify-content:space-between;padding:8px 20px}.header-left,.header-right{align-items:center;display:flex;gap:15px}.nav-link{align-items:center;border-radius:4px;color:#e0e0e0;display:flex;font-size:14px;gap:6px;padding:6px 12px;text-decoration:none;transition:background-color .2s}.language-select,.nav-link:hover{background-color:#3a3a3a}.language-select{border:1px solid #505050;border-radius:4px;color:#e0e0e0;cursor:pointer;font-size:14px;padding:6px 12px;transition:border-color .2s}.language-select:hover{border-color:#6a6a6a}.language-select:focus{border-color:#7a7aff;outline:none}.speech-toggle{align-items:center;background-color:#3a3a3a;border:1px solid #505050;border-radius:4px;color:#909090;cursor:pointer;display:flex;font-size:14px;gap:6px;padding:6px 12px;transition:all .2s}.speech-toggle:hover{background-color:#4a4a4a;border-color:#6a6a6a}.speech-toggle.enabled{background-color:#2a3a2a;border-color:#66bb6a;color:#66bb6a}.speech-toggle.enabled:hover{background-color:#3a4a3a;border-color:#77cc7a}.speech-label{font-size:13px}.github-icon{align-items:center;color:#e0e0e0;display:flex;transition:color .2s}.github-icon:hover{color:#7a7aff}
/*# sourceMappingURL=main.42aede85.css.map*/