:root{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#e6edf3;background:#0d1117}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top,#1f2937,#0d1117 40%);color:#e6edf3}.app-shell{min-height:100vh}header{border-bottom:1px solid #273244;position:sticky;top:0;background:#0d1117e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10}nav{max-width:1200px;margin:0 auto;padding:1rem;display:flex;gap:.75rem}nav a{color:#9fb3c8;text-decoration:none;padding:.5rem .85rem;border-radius:8px}nav a.active,nav a:hover{color:#fff;background:#1d4ed8}main{max-width:1200px;margin:0 auto;padding:1.25rem}h1,h2{margin-top:0}.subtitle{color:#9fb3c8;margin-top:-.4rem;margin-bottom:1.25rem}.landing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.landing-card{text-decoration:none;color:inherit;background:#111826;border:1px solid #273244;border-radius:12px;padding:1rem}.landing-card:hover{border-color:#3b82f6}.control-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.75rem;align-items:end;background:#111826;border:1px solid #273244;border-radius:12px;padding:1rem}label{display:flex;flex-direction:column;gap:.4rem}label span{color:#9fb3c8;font-size:.85rem}input,select,button{background:#0b1220;color:#fff;border:1px solid #334155;border-radius:8px;padding:.55rem .65rem}button{background:#2563eb;border:none;cursor:pointer;font-weight:600}button:disabled{opacity:.6;cursor:wait}.panel{margin-top:1rem;background:#111826;border:1px solid #273244;border-radius:12px;padding:1rem}.metric-grid{margin-top:1rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.metric-card{background:#111826;border:1px solid #273244;border-radius:10px;padding:.8rem;display:flex;flex-direction:column;gap:.2rem}.metric-card span{color:#9fb3c8;font-size:.82rem}.metric-card strong{font-size:1.1rem}.matrix{display:inline-grid;gap:.35rem}.matrix-row{display:flex;gap:.35rem}.matrix-row span{min-width:2.2rem;text-align:center;background:#0b1220;border:1px solid #334155;border-radius:6px;padding:.2rem}.tree-wrapper{margin-top:.9rem;overflow:auto;border:1px solid #273244;border-radius:10px}.tree-svg{width:100%;min-width:850px;height:520px;background:#0b1220}.tree-edge{stroke:#64748b;stroke-width:2}.tree-node.internal{fill:#1d4ed8}.tree-node.leaf{fill:#059669}.tree-label{fill:#fff;font-size:11px}.tree-label.small{fill:#bfdbfe;font-size:10px}.tree-label.node-id{fill:#94a3b8;font-size:10px}.muted{color:#9fb3c8}.error{margin-top:.8rem;color:#fca5a5}
