:root{font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#000000de;background-color:#f9f9f9;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:2.2em;line-height:1.1}button{border-radius:6px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#f9f9f9;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: dark){:root{color:#ffffffde;background-color:#242424}a:hover{color:#747bff}button{background-color:#1a1a1a}}body{font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.4;color:#333;background-color:#f9f9f9;margin:0;padding:0;overflow:hidden}#root{width:100vw;height:100vh;margin:0 auto;padding:.5rem;padding-bottom:80px;text-align:center;display:flex;flex-direction:column;overflow:auto;box-sizing:border-box}.app{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}h1{font-size:1.6rem;margin:.5rem 0;color:#2c3e50}.description{font-size:.9rem;color:#666;margin:.5rem 0 1rem}.algorithm-runner{display:flex;flex-direction:column;width:100%;height:100%;padding:.5rem;background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #0000000d;box-sizing:border-box;overflow:hidden;position:relative}.visualization-container{width:100%;flex:1;margin:.3rem 0;padding:.3rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000d;overflow:hidden;display:flex;align-items:center;justify-content:center;box-sizing:border-box;min-height:300px;transition:height .3s ease}.algorithm-visualization{width:100%;height:100%;display:flex;justify-content:center;align-items:center;position:relative}.algorithm-visualization svg{width:100%;height:100%;display:block}.input-panel{width:100%;padding:.7rem;background-color:#f5f7fa;border-radius:8px;margin-bottom:.3rem;box-sizing:border-box}.input-field{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.input-field label{margin-bottom:0;font-weight:600;color:#333;white-space:nowrap}.input-field input{flex:1;padding:.5rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem;transition:border-color .3s,box-shadow .3s}.input-field input:focus{border-color:#646cff;outline:none;box-shadow:0 0 0 3px #646cff1a}.start-button{padding:.5rem 1rem;background-color:#3949ab;color:#fff;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:background-color .3s;white-space:nowrap}.start-button:hover{background-color:#303f9f}.start-button:disabled{background-color:#bdbdbd;cursor:not-allowed}.random-button{display:flex;align-items:center;justify-content:center;padding:.3rem;width:36px;height:36px;background-color:#009688;color:#fff;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .3s;font-size:20px;line-height:1}.random-button:hover{background-color:#00796b;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.random-button:disabled{background-color:#bdbdbd;cursor:not-allowed;transform:none;box-shadow:none;opacity:.7}.examples{display:flex;align-items:center;margin:.5rem 0}.examples-header{margin-right:.5rem}.examples-title{margin:0;font-size:.9rem;font-weight:500;color:#555;white-space:nowrap}.example-buttons{display:flex;flex-wrap:nowrap;gap:.5rem;overflow-x:auto;padding-bottom:4px;margin-top:4px}.example-button{padding:.3rem .6rem;background-color:#e0f2f1;color:#00695c;border:1px solid #b2dfdb;border-radius:4px;font-size:.8rem;cursor:pointer;transition:background-color .3s;white-space:nowrap;flex-shrink:0}.example-button:hover{background-color:#b2dfdb}.example-button:disabled{opacity:.7;cursor:not-allowed}.controls{display:flex;flex-direction:row;justify-content:center;align-items:center;margin:0;padding:.2rem .5rem;background-color:#f8f9fa;border-radius:0;box-sizing:border-box;box-shadow:none;border-bottom:0}.progress-container{display:flex;flex-direction:column;align-items:center;margin:0 .8rem;min-width:180px}.progress-bar{width:100%;height:6px;background-color:#e0e0e0;border-radius:3px;overflow:hidden;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,#64b5f6,#5c6bc0);border-radius:3px;transition:width .3s ease}.progress-text{font-size:.7rem;font-weight:500;color:#5c6bc0;margin-top:4px;white-space:nowrap}.control-buttons{display:flex;gap:.5rem;justify-content:center;margin-bottom:0;margin-right:.5rem}.control-button{display:flex;align-items:center;justify-content:center;width:auto;height:auto;padding:6px 10px;background-color:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:all .3s;font-size:12px;font-weight:500;color:#333;box-shadow:0 1px 2px #0000000d}.control-button svg{width:16px;height:16px;color:#333;margin-right:3px}.control-button:hover{background-color:#f1f5f9;border-color:#b0bec5;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.control-button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.reset-button{background-color:#ffebee;color:#d32f2f;border-color:#ffcdd2}.reset-button svg{color:#d32f2f}.prev-button{background-color:#e3f2fd;color:#1976d2;border-color:#bbdefb}.prev-button svg{color:#1976d2}.play-button{background-color:#e8f5e9;color:#388e3c;border-color:#c8e6c9}.play-button svg{color:#388e3c}.pause-button{background-color:#fff3e0;color:#f57c00;border-color:#ffe0b2}.pause-button svg{color:#f57c00}.next-button{background-color:#e3f2fd;color:#1976d2;border-color:#bbdefb}.next-button svg{color:#1976d2}.speed-control{display:flex;align-items:center;gap:.3rem;background-color:#f8f9fa;padding:4px 10px;border-radius:4px;border:1px solid #e0e0e0;box-shadow:0 1px 2px #0000000d;height:28px;position:relative}.speed-control label{font-size:.75rem;color:#5c6bc0;font-weight:600;margin-right:2px}.speed-control select{padding:2px 20px 2px 4px;border:none;border-radius:3px;background-color:transparent;font-size:.8rem;font-weight:500;color:#333;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235c6bc0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center}.speed-control select:focus{outline:none;background-color:#5c6bc00d}.speed-control select option{font-size:.8rem;padding:8px}.keyboard-hints{font-size:.65rem;color:#666;margin:0;background-color:#f8f9fa;padding:.1rem 0 .2rem;border-radius:0;border-bottom:1px solid #e0e0e0}@media (max-width: 768px){#root,.algorithm-runner{padding:.25rem}.examples{flex-direction:row;align-items:center}.example-buttons{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px}.controls{flex-wrap:wrap;padding:.4rem;gap:.5rem}.control-buttons{gap:.3rem;margin-right:0;justify-content:center;width:100%}.progress-container{margin:0;width:100%;min-width:120px;order:-1}.speed-control{margin-bottom:.3rem}.speed-control label,.keyboard-hints{display:none}}.fullwidth-progress-container{width:100%;position:relative;margin:0;padding:0;border-top:1px solid #e0e0e0;border-bottom:0;background-color:#f8f9fa}.fullwidth-progress-bar{width:100%;height:6px;background-color:#f0f0f0;overflow:hidden;position:relative}.fullwidth-progress-fill{height:100%;background:linear-gradient(90deg,#4fc3f7,#5c6bc0);transition:width .3s ease}.fullwidth-progress-text{font-size:.75rem;font-weight:500;color:#5c6bc0;text-align:center;padding:1px 0 0;margin:0}@media (max-width: 768px){.fullwidth-progress-container{margin-bottom:.1rem}.fullwidth-progress-bar{height:6px}}.bottom-controls-container{position:fixed;bottom:0;left:0;right:0;background-color:#f8f9fa;z-index:100;box-shadow:0 -1px 4px #0000001a}.custom-speed-control{position:relative;min-width:72px}.speed-display{display:flex;align-items:center;gap:4px;background:linear-gradient(to bottom,#f8f9fa,#f1f3f5);border:1px solid #dbe1e8;border-radius:20px;padding:4px 8px;font-size:.8rem;font-weight:500;color:#4a5568;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000d;white-space:nowrap;height:28px;box-sizing:border-box}.speed-display:hover{background:linear-gradient(to bottom,#f1f3f5,#e9ecef);border-color:#cbd2d9}.speed-icon{display:flex;align-items:center;color:#5c6bc0}.current-speed{color:#4a5568;font-weight:600}.dropdown-arrow{display:flex;align-items:center;color:#5c6bc0;margin-left:2px}.speed-dropdown{position:absolute;bottom:100%;left:0;margin-bottom:4px;background-color:#fff;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:1000;overflow:hidden;width:100%;min-width:80px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.speed-option{display:block;width:100%;padding:8px 12px;text-align:center;background-color:transparent;border:none;font-size:.8rem;color:#4a5568;cursor:pointer;transition:background-color .2s}.speed-option:hover{background-color:#f1f5f9}.speed-option.active{background-color:#e3f2fd;color:#1976d2;font-weight:600}@media (max-width: 768px){.custom-speed-control{min-width:56px}.speed-display{padding:4px 6px}.speed-icon{display:none}}.input-error{border-color:#f44336!important;background-color:#fff8f8}.input-error:focus{box-shadow:0 0 0 3px #f443361a!important}.error-message{color:#f44336;font-size:.8rem;margin-top:.3rem;text-align:left;animation:fadeIn .3s ease;font-weight:500}
