:root{--primary-blue:#3b82f6;--primary-blue-light:#60a5fa;--primary-blue-dark:#1d4ed8;--gradient-primary:linear-gradient(135deg,#667eea,#764ba2);--gradient-success:linear-gradient(135deg,#4facfe,#00f2fe);--gradient-danger:linear-gradient(135deg,#fa709a,#fee140);--gradient-card:linear-gradient(145deg,#fff,#f8fafc);--gradient-dark:linear-gradient(135deg,#2d3748,#1a202c);--glass-bg:#ffffff40;--glass-border:#ffffff2e;--glass-shadow:0 8px 32px 0 #1f26875e;--shadow-soft:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-medium:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-large:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--shadow-glow:0 0 20px #6366f14d;--font-primary:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--transition-fast:0.15s ease-out;--transition-normal:0.3s ease-out;--transition-slow:0.5s ease-out}*{box-sizing:border-box}body{background:linear-gradient(135deg,#667eea,#764ba2);color:#1f2937;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-primary);line-height:1.6;margin:0;min-height:100vh;overflow-x:hidden;padding:1.5rem;padding:var(--space-lg)}body:before{animation:float 20s ease-in-out infinite;background:radial-gradient(circle at 20% 80%,#7877c64d 0,#0000 50%),radial-gradient(circle at 80% 20%,#ff77c64d 0,#0000 50%),radial-gradient(circle at 40% 40%,#78dbff4d 0,#0000 50%);content:"";height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:-1}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}33%{transform:translateY(-10px) rotate(1deg)}66%{transform:translateY(5px) rotate(-1deg)}}.app{animation:slideIn .8s ease-out;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#ffffff40;background:var(--glass-bg);border:1px solid #ffffff2e;border:1px solid var(--glass-border);border-radius:1.5rem;border-radius:var(--radius-2xl);box-shadow:0 8px 32px 0 #1f26875e;box-shadow:var(--glass-shadow);margin:0 auto;max-width:1400px;overflow:hidden;padding:3rem;padding:var(--space-2xl);position:relative}.app:before{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#fffc,#0000);content:"";height:1px;left:0;position:absolute;right:0;top:0}@keyframes slideIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.controls{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff40;background:var(--glass-bg);border:1px solid #ffffff2e;border:1px solid var(--glass-border);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-medium);display:flex;flex-wrap:wrap;gap:1.5rem;gap:var(--space-lg);margin-bottom:2rem;margin-bottom:var(--space-xl);overflow:hidden;padding:2rem;padding:var(--space-xl);position:relative}.controls:before{animation:controlsShine 3s ease-in-out infinite;background:linear-gradient(45deg,#0000,#ffffff1a,#0000);content:"";height:200%;left:-50%;position:absolute;top:-50%;transform:rotate(45deg);width:200%}@keyframes controlsShine{0%,to{transform:translateX(-100%) translateY(-100%) rotate(45deg)}50%{transform:translateX(100%) translateY(100%) rotate(45deg)}}button{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);border:none;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-soft);color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;letter-spacing:.5px;overflow:hidden;padding:.5rem 1.5rem;padding:var(--space-sm) var(--space-lg);position:relative;text-transform:uppercase;transition:all .3s ease-out;transition:all var(--transition-normal)}button:before{background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .3s ease-out;transition:left var(--transition-normal);width:100%}button:hover:before{left:100%}button:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-large);transform:translateY(-2px)}button:active{transform:translateY(0)}button.start{background:linear-gradient(135deg,#4facfe,#00f2fe);background:var(--gradient-success)}button.pause{background:linear-gradient(135deg,#ffd89b,#19547b)}button.resume{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary)}button.reset{background:linear-gradient(135deg,#fa709a,#fee140);background:var(--gradient-danger)}button:disabled{background:linear-gradient(135deg,#e2e8f0,#cbd5e0);box-shadow:none;color:#64748b;cursor:not-allowed;transform:none}button:disabled:before{display:none}input,select{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff40;background:var(--glass-bg);border:2px solid #fff3;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-soft);color:#1f2937;font-size:.875rem;font-weight:500;padding:.5rem 1rem;padding:var(--space-sm) var(--space-md);transition:all .3s ease-out;transition:all var(--transition-normal)}input:focus,select:focus{border-color:#6366f199;box-shadow:0 0 0 3px #6366f11a;outline:none}input:hover,select:hover{border-color:#fff6}label{color:#374151;display:block;font-size:.875rem;font-weight:600;letter-spacing:.5px;margin-bottom:.5rem;margin-bottom:var(--space-sm);text-transform:uppercase}.visualization-container{grid-gap:2rem;grid-gap:var(--space-xl);animation:fadeInUp .8s ease-out .2s both;display:grid;gap:2rem;gap:var(--space-xl);grid-template-columns:2fr 1fr;margin:2rem 0;margin:var(--space-xl) 0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1024px){.visualization-container{grid-template-columns:1fr}}.stock-bar{align-items:center;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-soft);color:#fff;cursor:pointer;display:flex;font-weight:700;height:80px;justify-content:flex-start;min-width:200px;overflow:visible;padding:1rem 1.5rem;padding:var(--space-md) var(--space-lg);position:relative;transition:all .3s ease-out;transition:all var(--transition-normal)}.stock-bar.positive{background:linear-gradient(45deg,#22c35d,#12a146)}.stock-bar.negative{background:linear-gradient(45deg,#e05252,#e61a1a)}.stock-bar:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease-out;transition:left var(--transition-slow);width:100%;z-index:1}.stock-bar:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-large);transform:translateY(-3px) scale(1.02);z-index:10}.stock-bar:hover:before{left:100%}.stock-label{font-size:1.1rem;font-weight:800;letter-spacing:.5px;line-height:1.2;overflow:visible;position:relative;text-overflow:clip;text-shadow:2px 2px 4px #00000080;z-index:2}.stock-visualization{align-items:flex-end;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff40;background:var(--glass-bg);border:1px solid #ffffff2e;border:1px solid var(--glass-border);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-medium);display:flex;gap:.5rem;gap:var(--space-sm);height:450px;overflow:hidden;padding:2rem;padding:var(--space-xl);position:relative}.stock-visualization:before{background:linear-gradient(90deg,#0000,#ffffff80,#0000);bottom:0;content:"";height:1px;left:0;position:absolute;right:0}.stock-item{align-items:center;border-radius:.75rem .75rem 0 0;border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-soft);cursor:pointer;display:flex;flex:1 1;justify-content:center;max-width:90px;min-width:50px;overflow:hidden;position:relative;transition:all .3s ease-out;transition:all var(--transition-normal)}.stock-item.positive{background:linear-gradient(180deg,#22c35d,#12a146)}.stock-item.negative{background:linear-gradient(180deg,#e05252,#e61a1a)}.stock-item:before{background:linear-gradient(90deg,#fff9,#fff3,#fff9);content:"";height:3px;left:0;position:absolute;right:0;top:0}.stock-item:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-large);transform:translateY(-8px) scale(1.05);z-index:10}.stock-item.highlighted{background:linear-gradient(180deg,gold,orange)!important;box-shadow:0 0 20px #6366f14d;box-shadow:var(--shadow-glow);transform:translateY(-8px) scale(1.08);z-index:20}.stock-item.highlighted:before{background:linear-gradient(90deg,#fffc,#fff6,#fffc)}.stock-label{color:#fff;font-size:.875rem;font-weight:700;letter-spacing:1px;max-height:100%;overflow:hidden;padding:1rem;padding:var(--space-md);text-orientation:mixed;text-overflow:ellipsis;text-shadow:2px 2px 4px #0006;white-space:nowrap;writing-mode:vertical-rl}.metrics,.performance-metrics{animation:fadeInUp .8s ease-out .4s both;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff40;background:var(--glass-bg);border:1px solid #ffffff2e;border:1px solid var(--glass-border);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-medium);margin-top:2rem;margin-top:var(--space-xl);padding:2rem;padding:var(--space-xl)}.metrics-grid{grid-gap:1.5rem;grid-gap:var(--space-lg);display:grid;gap:1.5rem;gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:1.5rem 0;margin:var(--space-lg) 0}.metric-card{background:linear-gradient(145deg,#fff,#f8fafc);background:var(--gradient-card);border:1px solid #fff3;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-soft);overflow:hidden;padding:1.5rem;padding:var(--space-lg);position:relative;transition:all .3s ease-out;transition:all var(--transition-normal)}.metric-card:before{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);content:"";height:3px;left:0;position:absolute;right:0;top:0}.metric-card:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-large);transform:translateY(-5px) scale(1.02)}.metric-card h4{color:#6b7280;font-size:.875rem;font-weight:600;letter-spacing:1px;margin:0 0 .5rem;margin:0 0 var(--space-sm) 0;text-transform:uppercase}.metric-card p{color:#111827;font-family:JetBrains Mono,Fira Code,monospace;font-family:var(--font-mono);font-size:2rem;font-weight:800;margin:0}.stock-info-panel{animation:fadeInUp .8s ease-out .6s both;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff40;background:var(--glass-bg);border:1px solid #ffffff2e;border:1px solid var(--glass-border);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-medium);margin-top:2rem;margin-top:var(--space-xl);padding:2rem;padding:var(--space-xl)}.stock-header{align-items:center;border-bottom:2px solid #fff3;display:flex;justify-content:space-between;margin-bottom:1.5rem;margin-bottom:var(--space-lg);padding-bottom:1.5rem;padding-bottom:var(--space-lg)}.stock-header h4{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:800;margin:0}.price{border:1px solid #fff3;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-soft);font-family:JetBrains Mono,Fira Code,monospace;font-family:var(--font-mono);font-size:1.5rem;font-weight:700;padding:.5rem 1.5rem;padding:var(--space-sm) var(--space-lg)}.price.positive{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.price.negative{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.data-source-toggle{margin-bottom:1.5rem;margin-bottom:var(--space-lg)}.toggle-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff40;background:var(--glass-bg);border:2px solid #fff3;border-radius:.75rem;border-radius:var(--radius-lg);display:flex;margin-top:.5rem;margin-top:var(--space-sm);overflow:hidden}.toggle-option{background:#0000;border:none;color:#374151;cursor:pointer;flex:1 1;font-weight:600;overflow:hidden;padding:1rem 1.5rem;padding:var(--space-md) var(--space-lg);position:relative;transition:all .3s ease-out;transition:all var(--transition-normal)}.toggle-option:before{background:linear-gradient(135deg,#4facfe,#00f2fe);background:var(--gradient-success);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .3s ease-out;transition:left var(--transition-normal);width:100%;z-index:-1}.toggle-option.active{color:#fff;text-shadow:1px 1px 2px #0000004d}.toggle-option.active:before{left:0}.toggle-option:not(.active):hover{background:#ffffff1a}.view-mode-toggle{display:flex;gap:1rem;gap:var(--space-md);justify-content:center;margin-bottom:2rem;margin-bottom:var(--space-xl)}.mode-button{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff40;background:var(--glass-bg);border:2px solid #0000;border-radius:.75rem;border-radius:var(--radius-lg);color:#374151;cursor:pointer;font-weight:700;letter-spacing:.5px;overflow:hidden;padding:1rem 2rem;padding:var(--space-md) var(--space-xl);position:relative;text-transform:uppercase;transition:all .3s ease-out;transition:all var(--transition-normal)}.mode-button:before{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .3s ease-out;transition:left var(--transition-normal);width:100%;z-index:-1}.mode-button:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-medium);transform:translateY(-2px)}.mode-button.active{color:#fff;text-shadow:1px 1px 2px #0000004d}.mode-button.active:before{left:0}.race-visualizations{display:flex;gap:2rem;gap:var(--space-xl);margin:2rem 0;margin:var(--space-xl) 0}.race-column{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff40;background:var(--glass-bg);border:1px solid #ffffff2e;border:1px solid var(--glass-border);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-medium);flex:1 1;min-width:0;padding:1.5rem;padding:var(--space-lg)}.race-column h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:700;margin-bottom:1.5rem;margin-bottom:var(--space-lg)}.data-controls{align-items:center;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff40;background:var(--glass-bg);border:1px solid #ffffff2e;border:1px solid var(--glass-border);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-medium);display:flex;gap:2rem;gap:var(--space-xl);margin:2rem 0;margin:var(--space-xl) 0;padding:1.5rem;padding:var(--space-lg)}.company-count-selector{align-items:center;display:flex;gap:1rem;gap:var(--space-md)}.company-count-selector label{color:#374151;font-size:.875rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}.line-chart,.scatter-plot{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff40;background:var(--glass-bg);border:1px solid #ffffff2e;border:1px solid var(--glass-border);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-medium);display:block;margin:0 auto}.live-status{color:#10b981;font-weight:700;text-shadow:0 0 10px #10b9814d}.loading,.mock-status,.no-selection{color:#6b7280;font-weight:600}.loading,.no-selection{font-size:1.125rem;padding:3rem;padding:var(--space-2xl);text-align:center}@media (max-width:1200px){.race-visualizations{flex-direction:column}.race-column{width:100%}.controls,.data-controls{align-items:stretch;flex-direction:column}}@media (max-width:768px){body{padding:1rem;padding:var(--space-md)}.app{padding:1.5rem;padding:var(--space-lg)}.metrics-grid{grid-template-columns:1fr}.stock-header{gap:1rem;gap:var(--space-md);text-align:center}.stock-header,.view-mode-toggle{flex-direction:column}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.mode-button:focus,.toggle-option:focus,button:focus,input:focus,select:focus{outline:2px solid #3b82f6;outline-offset:2px}@media (prefers-contrast:high){:root{--glass-bg:#ffffffe6;--glass-border:#0000004d}}@media print{.app,body{background:#fff}.app{border:1px solid #000;box-shadow:none}.controls,button{display:none}}.pseudo-code-display{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff40;background:var(--glass-bg);border:1px solid #ffffff2e;border:1px solid var(--glass-border);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-medium);margin-top:1.5rem;margin-top:var(--space-lg);padding:1.5rem;padding:var(--space-lg)}.pseudo-code-display h4{color:#374151;font-size:1rem;font-weight:600;margin:0 0 1rem;margin:0 0 var(--space-md) 0}.pseudo-code{background:#0000000d;border-radius:.5rem;border-radius:var(--radius-md);font-family:JetBrains Mono,Fira Code,monospace;font-family:var(--font-mono);font-size:.9rem;line-height:1.5;margin:0;overflow-x:auto;padding:1rem;padding:var(--space-md)}.code-line{border-radius:.375rem;border-radius:var(--radius-sm);padding:.25rem .5rem;padding:var(--space-xs) var(--space-sm);transition:all .3s ease-out;transition:all var(--transition-normal)}.code-line.current-step{background:#6366f11a;color:#1d4ed8;color:var(--primary-blue-dark);font-weight:600;position:relative;transform:translateX(.5rem);transform:translateX(var(--space-sm))}.code-line.current-step:before{animation:pointStep 1s ease-in-out infinite;color:#3b82f6;color:var(--primary-blue);content:"→";left:-1rem;position:absolute}@keyframes pointStep{0%,to{transform:translateX(0)}50%{transform:translateX(3px)}}.visualization-wrapper{align-items:stretch;display:flex;gap:2rem;gap:var(--space-xl)}.visualization-wrapper.guess,.visualization-wrapper.race{display:block}.visualization-wrapper .stock-visualization{flex:2 1;min-width:0}.visualization-wrapper.single .stock-visualization{min-height:450px}.visualization-wrapper .pseudo-code-display{flex:1 1;height:-webkit-fit-content;height:fit-content;max-width:400px;min-width:300px;position:-webkit-sticky;position:sticky;top:2rem;top:var(--space-xl)}@media (max-width:1200px){.visualization-wrapper{flex-direction:column}.visualization-wrapper .pseudo-code-display{max-width:none}}.algorithm-explanation{background-color:#f8f9fa;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin:20px 0;padding:20px}.algorithm-explanation h2{border-bottom:2px solid #3498db;color:#2c3e50;margin-bottom:15px;padding-bottom:10px}.algorithm-description{color:#34495e;line-height:1.6;margin-bottom:20px}.complexity-info{background-color:#fff;border-radius:6px;margin-bottom:20px;padding:15px}.complexity-info h3{color:#2c3e50;font-size:1.1em;margin-bottom:10px}.complexity-info ul{list-style:none;padding-left:0}.complexity-info li{color:#34495e;margin:5px 0}.pseudocode{background-color:#2c3e50;border-radius:6px;overflow-x:auto;padding:20px}.pseudocode h3{color:#fff;margin-bottom:15px}.pseudocode pre{color:#ecf0f1;font-family:Consolas,Monaco,monospace;font-size:14px;line-height:1.5;margin:0;white-space:pre-wrap}.algorithm-race{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.race-controls{background:#f8f9fa;border-radius:6px;margin-bottom:20px;padding:15px}.algorithm-selectors{display:flex;gap:20px;margin-bottom:15px}.algorithm-select{flex:1 1}.algorithm-select label{color:#2c3e50;display:block;font-weight:700;margin-bottom:8px}.algorithm-select select{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:8px;width:100%}.race-buttons{display:flex;gap:10px;justify-content:center}.race-buttons button{border:none;border-radius:4px;cursor:pointer;font-weight:700;padding:10px 20px;transition:all .3s ease}.start-race{background-color:#2ecc71;color:#fff}.start-race:hover:not(:disabled){background-color:#27ae60}.stop-race{background-color:#e74c3c;color:#fff}.stop-race:hover:not(:disabled){background-color:#c0392b}.race-buttons button:disabled{cursor:not-allowed;opacity:.6}.race-visualizations{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.race-column{background:#f8f9fa;border-radius:6px;padding:15px}.race-column h3{border-bottom:2px solid #3498db;color:#2c3e50;margin-bottom:15px;padding-bottom:10px;text-align:center}@media (max-width:1024px){.race-visualizations{grid-template-columns:1fr}.algorithm-selectors{flex-direction:column}}.guess-algorithm{gap:20px}.guess-algorithm,.guess-controls{display:flex;flex-direction:column;padding:20px}.guess-controls{align-items:center;background-color:#f5f5f5;border-radius:8px;box-shadow:0 2px 4px #0000001a;gap:15px}.start-button{background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;padding:12px 24px;transition:background-color .3s}.start-button:hover{background-color:#45a049}.start-button:disabled{background-color:#ccc;cursor:not-allowed}.guess-input{display:flex;gap:10px;max-width:500px;width:100%}.guess-input input{border:2px solid #ddd;border-radius:4px;flex:1 1;font-size:16px;outline:none;padding:10px}.guess-input input:focus{border-color:#4caf50}.guess-input input:disabled{background-color:#f5f5f5;cursor:not-allowed}.submit-button{background-color:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;padding:10px 20px;transition:background-color .3s}.submit-button:hover{background-color:#1976d2}.submit-button:disabled{background-color:#ccc;cursor:not-allowed}.result{animation:fadeIn .5s ease-in;border-radius:8px;margin-top:20px;padding:20px;text-align:center}.result.correct{background-color:#e8f5e9;border:2px solid #4caf50}.result.incorrect{background-color:#ffebee;border:2px solid #f44336}.result h3{font-size:24px;margin:0 0 10px}.new-game-button{background-color:#9c27b0;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;margin-top:15px;padding:10px 20px;transition:background-color .3s}.new-game-button:hover{background-color:#7b1fa2}.visualization-container{display:flex;flex-direction:column;gap:20px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
/*# sourceMappingURL=main.fd82fd60.css.map*/