Your task is to implement a Topological Sort algorithm and verify its functional correctness in Dafny. You need to implement topological_sort, which takes a directed graph and returns Some(seq<int>) containing a valid topological ordering if the graph is a DAG, or None if the graph contains a cycle. There are several verification challenges: (1) Ordering Validity: If returning Some(order), you must prove that order is a permutation of all graph nodes and that for every edge $u \to v$ in the graph, $u$ appears before $v$ in the sequence. (2) Cycle Detection: If returning None, you must prove that the graph actually contains a cycle. This ensures the algorithm doesn't fail spuriously on valid DAGs. You can implement either Kahn's algorithm or use DFS.