*{box-sizing:border-box;margin:0}html,body{height:100%;overflow:hidden}body{font-family:ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:#f8fafc;color:#1e293b;display:flex;align-items:center;justify-content:center}.container{width:100%;max-width:960px;height:100vh;display:flex;flex-direction:column;padding:2px 16px 4px}#viz{width:100%;flex:1 1 auto;min-height:0;display:block}.controls{display:flex;align-items:center;justify-content:center;gap:14px;flex-shrink:0;padding:0;margin:-2px 0 0}.controls button{border:1px solid #d1d5db;border-radius:999px;background:#fff;color:#334155;width:30px;height:30px;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background 120ms,border-color 120ms}.controls button:hover:not(:disabled){background:#f1f5f9;border-color:#94a3b8}.controls button:disabled{opacity:.35;cursor:default}.step-dots{display:flex;gap:10px}.dot{width:10px;height:10px;border-radius:50%;background:#cbd5e1;transition:background 200ms,transform 200ms;cursor:pointer}.dot.active{background:#0f766e;transform:scale(1.3)}.description{text-align:center;flex-shrink:0;padding:0;margin-top:-2px}.step-title{font-size:18px;font-weight:700;color:#0f172a;margin-bottom:2px}.step-text{font-size:15px;line-height:1.5;color:#475569;max-width:720px;margin:0 auto}.matrix-label{font-size:15px;fill:#475569}.matrix-label.actor{text-anchor:end}.matrix-label.topic{text-anchor:middle;font-weight:600}.cell-count{font-size:15px;text-anchor:middle;dominant-baseline:central;fill:#fff;pointer-events:none;font-weight:600}.axis-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;fill:#94a3b8}.topic-node-label{font-size:15px;font-weight:700;text-anchor:middle;paint-order:stroke;stroke:rgba(248,250,252,.92);stroke-width:4px;stroke-linejoin:round;pointer-events:none}