:root{--bg:#09090b;--bg-glow-a:#3b9eff12;--bg-glow-b:#f472b60d;--surface:#111116;--surface2:#18181f;--surface3:#1f1f28;--border:#2a2a34;--border-soft:#22222b;--text:#eceae4;--muted:#7a7884;--bfs:#3b9eff;--greedy:#a78bfa;--louvain:#2dd4a0;--knn:#f472b6;--sans:"Syne", system-ui, sans-serif;--mono:"Space Mono", ui-monospace, monospace;--shell:980px}*,:before,:after{box-sizing:border-box}body{background:radial-gradient(ellipse 80% 50% at 50% -10%, var(--bg-glow-a), transparent 55%), radial-gradient(ellipse 60% 40% at 100% 100%, var(--bg-glow-b), transparent 50%), var(--bg);min-height:100vh;color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;margin:0}#root{width:100%}.page{justify-content:center;padding:1.5rem 1rem 2.5rem;display:flex}.shell{width:100%;max-width:var(--shell);flex-direction:column;gap:1rem;display:flex}.top{padding-bottom:.25rem}.brand .eyebrow{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0 0 .35rem;font-size:.62rem}.brand h1{letter-spacing:-.03em;margin:0;font-size:clamp(1.55rem,4vw,2rem);font-weight:800;line-height:1.05}.brand h1 span{color:var(--knn)}.lede{color:#a8a6ae;max-width:52ch;margin:.55rem 0 0;font-size:.88rem;line-height:1.55}.section-label{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.45rem;font-size:.58rem;display:block}.scenario-row{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.85rem}.scenario-cards{grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem;display:grid}.scenario-card{border:1px solid var(--border-soft);background:var(--surface2);color:var(--text);text-align:left;cursor:pointer;border-radius:8px;flex-direction:column;align-items:flex-start;gap:.3rem;padding:.75rem .8rem;transition:border-color .15s,background .15s,transform .15s;display:flex}.scenario-card:hover:not(:disabled){border-color:var(--border);background:var(--surface3)}.scenario-card.active{border-color:var(--bfs);background:#3b9eff14;box-shadow:inset 0 0 0 1px #3b9eff26}.scenario-card strong{font-size:.82rem;font-weight:700}.scenario-card span{color:#a8a6ae;font-size:.72rem;line-height:1.4}.scenario-card em{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-size:.58rem;font-style:normal}.toolbar{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;align-items:flex-end;gap:.75rem 1rem;padding:.85rem;display:flex}.toolbar-group{flex-direction:column;gap:.35rem;display:flex}.toolbar-group.playback{flex-direction:row;align-items:center;gap:.35rem;padding-top:1rem}.mode-tabs{flex-wrap:wrap;gap:.3rem;display:flex}.btn{font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;border:1px solid var(--border);background:var(--surface2);color:var(--text);cursor:pointer;border-radius:6px;padding:.48rem .72rem;font-size:.64rem;transition:background .15s,border-color .15s,color .15s}.btn:hover:not(:disabled){background:var(--surface3);border-color:#3a3a46}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.primary{color:var(--bfs);background:#3b9eff1a;border-color:#3b9eff73}.btn.active{background:var(--surface3)}.speed-group{display:flex}.speed-group .btn{border-right-width:0;border-radius:0}.speed-group .btn:first-child{border-radius:6px 0 0 6px}.speed-group .btn:last-child{border-right-width:1px;border-radius:0 6px 6px 0}.toggle{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);cursor:pointer;align-items:center;gap:.45rem;margin-left:auto;padding-top:1rem;font-size:.62rem;display:flex}.toggle input{accent-color:var(--bfs)}.stats{grid-template-columns:repeat(5,minmax(0,1fr));gap:.55rem;display:grid}.stats article{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.7rem .8rem}.stats span{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:.25rem;font-size:.56rem;display:block}.stats strong{white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;display:block;overflow:hidden}.workspace{grid-template-columns:minmax(0,1fr) 280px;align-items:start;gap:.75rem;display:grid}.graph-panel{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}.graph-panel-head{border-bottom:1px solid var(--border-soft);font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);justify-content:space-between;align-items:center;gap:.75rem;padding:.65rem .85rem;font-size:.62rem;display:flex}.graph-panel-meta{color:#5f5d68}.graph-shell{background:radial-gradient(circle at 50% 40%, #3b9eff0a, transparent 55%), linear-gradient(#ffffff06 1px, transparent 1px), linear-gradient(90deg, #ffffff06 1px, transparent 1px), var(--surface2);background-size:auto,22px 22px,22px 22px,auto;height:420px}.sidebar{flex-direction:column;gap:.65rem;display:flex}.panel{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.85rem}.panel-header{justify-content:space-between;align-items:center;gap:.6rem;margin-bottom:.45rem;display:flex}.panel-title{align-items:center;gap:.45rem;font-size:.88rem;font-weight:700;display:flex}.dot{border-radius:50%;width:7px;height:7px}.status-pill{font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;border:1px solid var(--border);color:var(--muted);border-radius:999px;padding:.18rem .45rem;font-size:.56rem}.status-pill.running{border-color:var(--bfs);color:var(--bfs)}.status-pill.done{border-color:var(--louvain);color:var(--louvain)}.status-pill.ready{border-color:var(--greedy);color:var(--greedy)}.panel-subtitle{font-family:var(--mono);color:var(--muted);margin:0 0 .65rem;font-size:.6rem}.status-text{color:#b8b6bf;margin:0 0 .65rem;font-size:.8rem;line-height:1.5}.result-block{background:var(--surface2);border:1px solid var(--border-soft);border-radius:6px;margin-bottom:.65rem;padding:.6rem .7rem}.result-label{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem;font-size:.56rem;display:block}.path-line{color:#fde68a;margin:0;font-size:.74rem;line-height:1.45}.vote-result{margin:0;font-size:.88rem;font-weight:700}.vote-result.danger{color:#ff6b81}.vote-result.safe{color:#4ade80}.note{color:var(--muted);border-top:1px solid var(--border-soft);padding-top:.65rem;font-size:.74rem;line-height:1.5}.note strong{color:var(--text)}.panel h2{margin:0 0 .65rem;font-size:.88rem}.muted{color:var(--muted);font-size:.8rem}.details{gap:.45rem;margin:0;display:grid}.details div{border-bottom:1px solid var(--border-soft);justify-content:space-between;gap:.6rem;padding-bottom:.4rem;display:flex}.details dt{font-family:var(--mono);color:var(--muted);text-transform:uppercase;font-size:.58rem}.details dd{margin:0;font-size:.78rem;font-weight:600}.details .danger{color:#ff6b81}.details .safe{color:#4ade80}.details .warning{color:#fb923c}.ds-view{flex-direction:column;gap:.65rem;display:flex}.ds-title{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;font-size:.64rem;font-weight:700}.ds-label{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem;font-size:.56rem;display:block}.ds-list{flex-direction:column;gap:.3rem;margin:0;padding:0;list-style:none;display:flex}.ds-list li{flex-wrap:wrap;align-items:center;gap:.45rem;font-size:.74rem;display:flex}.ds-chip{font-family:var(--mono);border:1px solid var(--border);background:var(--surface2);border-radius:4px;padding:.18rem .4rem;font-size:.64rem}.ds-chip.next,.ds-chip.current{border-color:var(--bfs);color:var(--bfs)}.ds-pri{color:var(--muted)}.ds-hint,.ds-empty{font-family:var(--mono);color:var(--muted);font-size:.6rem}.lesson-hint{color:var(--muted);border-top:1px solid var(--border-soft);margin:0;padding-top:.45rem;font-size:.74rem;line-height:1.45}footer{font-family:var(--mono);color:var(--muted);letter-spacing:.04em;padding-top:.5rem;font-size:.6rem}@media (width<=920px){.scenario-cards,.workspace{grid-template-columns:1fr}.stats{grid-template-columns:repeat(2,minmax(0,1fr))}.toggle{margin-left:0;padding-top:0}}
