:root{color-scheme:dark;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;--bg: #0a0a0a;--bg-card: #111114;--bg-elevated: #18181c;--border: rgba(255, 255, 255, .08);--border-active: rgba(255, 255, 255, .2);--text: #fafafa;--text-dim: rgba(255, 255, 255, .55);--text-muted: rgba(255, 255, 255, .35);--accent: #6366f1;--accent-glow: rgba(99, 102, 241, .15);--green: #22c55e;--red: #ef4444;--yellow: #eab308;--orange: #f97316;--cyan: #06b6d4;--radius: .75rem;--radius-sm: .5rem}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100vh;background:var(--bg);color:var(--text)}.app{min-height:100vh;display:flex;flex-direction:column}.header{border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(99,102,241,.06) 0%,transparent 100%);padding:2.5rem 1.5rem 2rem}.header-inner{max-width:960px;margin:0 auto}.tag-row{display:flex;gap:.5rem;margin-bottom:1rem}.tag{display:inline-block;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--text-dim);border:1px solid var(--border);padding:.25rem .5rem;border-radius:.25rem}.tag.accent{color:var(--accent);border-color:#6366f14d;background:var(--accent-glow)}.header h1{margin:0 0 .25rem;font-size:2.25rem;font-weight:700;letter-spacing:-.03em}.highlight{background:linear-gradient(135deg,var(--accent),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{margin:0 0 .5rem;font-size:1.1rem;color:var(--text-dim)}.authors{margin:0 0 1rem;font-size:.85rem;color:var(--text-muted)}.abstract{margin:0;font-size:.95rem;color:var(--text-dim);max-width:48rem;line-height:1.6}.abstract strong{color:var(--green)}.main{flex:1;max-width:960px;width:100%;margin:0 auto;padding:2rem 1.5rem;display:flex;flex-direction:column;gap:2rem}.controls-section{display:flex;flex-direction:column;gap:1.5rem}.problem-selector h3{margin:0 0 .75rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim)}.problem-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}.problem-btn{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text);cursor:pointer;transition:all .15s;font-family:inherit;font-size:.85rem;text-align:left}.problem-btn:hover{border-color:var(--border-active);background:var(--bg-elevated)}.problem-btn.selected{border-color:var(--accent);background:var(--accent-glow)}.problem-name{font-weight:600}.problem-meta{display:flex;gap:.5rem;font-size:.75rem}.problem-diff{color:var(--yellow);font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.problem-cat{color:var(--text-muted)}.control-buttons{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.round-display{font-size:.95rem;color:var(--text-dim);padding:.5rem 1rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card)}.round-display strong{color:var(--accent)}.btn{padding:.6rem 1.25rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s;border:1px solid transparent}.btn:disabled{opacity:.35;cursor:not-allowed}.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.primary:hover:not(:disabled){background:#5558e6}.btn.secondary{background:transparent;color:var(--accent);border-color:var(--accent)}.btn.secondary:hover:not(:disabled){background:var(--accent-glow)}.btn.ghost{background:transparent;color:var(--text-dim);border-color:var(--border)}.btn.ghost:hover:not(:disabled){color:var(--text);border-color:var(--border-active)}.phase-desc{padding:1rem 1.25rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card)}.phase-name{display:inline-block;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.7rem;letter-spacing:.15em;color:var(--accent);margin-bottom:.5rem}.phase-desc p{margin:0;font-size:.9rem;color:var(--text-dim)}.pipeline{display:flex;align-items:center;justify-content:center;gap:.25rem;flex-wrap:wrap}.pipeline-step-wrapper{display:flex;align-items:center;gap:.25rem}.pipeline-step{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);min-width:80px;transition:all .3s}.pipeline-step.active{border-color:var(--accent);background:var(--accent-glow);box-shadow:0 0 20px #6366f133}.pipeline-step.done{border-color:var(--green);background:#22c55e14}.step-icon{font-size:1.25rem}.step-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}.pipeline-arrow{color:var(--text-muted);font-size:1.25rem}.matchup-section{display:flex;flex-direction:column;gap:.75rem}.matchup-panel{border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;background:var(--bg-card)}.matchup-title{margin:0 0 .5rem;font-size:1.1rem}.matchup-hint{margin:0 0 1rem;font-size:.85rem;color:var(--text-dim)}.matchup-row{display:flex;gap:1rem;align-items:stretch}.matchup-card{flex:1;padding:1.25rem;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated);cursor:pointer;transition:all .2s}.matchup-card:hover,.matchup-card.hover{border-color:var(--accent);background:var(--accent-glow);transform:translateY(-2px);box-shadow:0 8px 24px #6366f126}.matchup-label{font-weight:600;font-size:.9rem;margin-bottom:.5rem;display:flex;justify-content:space-between;align-items:center}.matchup-prob{font-size:.75rem;color:var(--cyan);font-weight:400}.matchup-trace{margin:0;font-size:.85rem;color:var(--text-dim);line-height:1.5}.vs-badge{display:flex;align-items:center;font-weight:700;font-size:.9rem;color:var(--text-muted);letter-spacing:.1em}.matchup-progress{text-align:center;font-size:.8rem;color:var(--text-muted)}.candidates-section h2{margin:0 0 1rem;font-size:1.1rem}.candidates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.candidate-card{padding:1rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);transition:all .2s}.candidate-card.highlight{border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow)}.candidate-card.eliminated{opacity:.4;border-color:#ef444433}.candidate-card.mutated{border-color:#22c55e4d}.candidate-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.candidate-id{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem;font-weight:700;color:var(--accent)}.candidate-score{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.8rem;color:var(--text-dim);margin-left:auto}.badge{font-size:.65rem;padding:.15rem .4rem;border-radius:.25rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.mutated-badge{background:#22c55e26;color:var(--green);border:1px solid rgba(34,197,94,.3)}.dead-badge{background:#ef44441a;color:var(--red);border:1px solid rgba(239,68,68,.2)}.candidate-trace{margin:0;font-size:.85rem;color:var(--text-dim)}.candidate-critique{margin:.5rem 0 0;font-size:.8rem;padding:.5rem .75rem;background:#eab3080f;border-left:2px solid var(--yellow);border-radius:0 .25rem .25rem 0;color:var(--text-dim)}.critique-label{font-weight:600;color:var(--yellow);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}.bt-section{border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;background:var(--bg-card)}.bt-chart h3{margin:0 0 1rem;font-size:1rem}.bt-bars{display:flex;flex-direction:column;gap:.5rem}.bt-bar-row{display:flex;align-items:center;gap:.75rem}.bt-bar-label{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.8rem;color:var(--text-dim);width:2.5rem;text-align:right}.bt-bar-track{flex:1;height:24px;background:var(--bg);border-radius:.25rem;overflow:hidden}.bt-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--cyan));border-radius:.25rem;transition:width .6s ease}.bt-bar-value{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.75rem;color:var(--cyan);width:3.5rem}.elo-section{border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;background:var(--bg-card)}.elo-chart h3{margin:0 0 1rem;font-size:1rem}.elo-graph{display:flex;gap:.5rem;height:200px}.elo-y-axis{display:flex;flex-direction:column;justify-content:space-between;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.7rem;color:var(--text-muted);padding:.25rem 0;min-width:3rem}.elo-bars-container{flex:1;display:flex;align-items:flex-end;gap:.5rem}.elo-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;height:100%}.elo-bar-wrapper{flex:1;width:100%;display:flex;align-items:flex-end}.elo-bar{width:100%;background:linear-gradient(180deg,var(--green),var(--accent));border-radius:.25rem .25rem 0 0;min-height:4px;transition:height .6s ease}.elo-bar-label{font-size:.65rem;color:var(--text-muted)}.elo-bar-val{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.65rem;color:var(--green)}.elo-legend{display:flex;justify-content:space-between;margin-top:.75rem;font-size:.75rem;color:var(--text-muted)}.elo-base{color:var(--text-muted)}.elo-final{color:var(--green)}.algo-section h2{margin:0 0 1.25rem;font-size:1.25rem}.algo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.algo-card{padding:1.25rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);transition:border-color .2s}.algo-card:hover{border-color:var(--border-active)}.algo-num{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:2rem;font-weight:700;color:#6366f133;line-height:1;margin-bottom:.5rem}.algo-card h3{margin:0 0 .5rem;font-size:1rem}.algo-card p{margin:0;font-size:.85rem;color:var(--text-dim);line-height:1.6}.cf-section h2{margin:0 0 .5rem;font-size:1.25rem}.cf-desc{margin:0 0 1.25rem;font-size:.9rem;color:var(--text-dim);max-width:48rem}.cf-table{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.cf-row{display:grid;grid-template-columns:1fr 1fr 100px;padding:.75rem 1.25rem;border-bottom:1px solid var(--border);font-size:.85rem}.cf-row:last-child{border-bottom:none}.cf-header{background:var(--bg-elevated);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}.cf-name{font-weight:600}.cf-cat{color:var(--text-dim)}.cf-diff{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:600;text-align:right}.footer{border-top:1px solid var(--border);padding:1.5rem;text-align:center;font-size:.8rem;color:var(--text-muted)}.footer a{color:var(--accent);text-decoration:none}.footer a:hover{text-decoration:underline}@media(max-width:640px){.header h1{font-size:1.5rem}.matchup-row{flex-direction:column}.vs-badge{justify-content:center}.candidates-grid,.algo-grid,.problem-list{grid-template-columns:1fr}.pipeline{gap:.15rem}.pipeline-step{padding:.5rem;min-width:56px}.step-label{font-size:.6rem}.pipeline-arrow{font-size:.9rem}}
