Simplify DAG construction: recursive memoized get_node
Replace topological sort + linear scan with a recursive function
that builds nodes on demand and memoizes by (pkg, universe).
Deps are resolved by recursion — no sorting needed.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>