Your task is to implement the Delete operation for a Ternary Search Tree (TST) and verify its correctness in Verus. A TST uses a hybrid structure where left and right children store neighbors (BST) and the mid child stores the suffix (Trie). This structure complicates deletion because removing a node might require re-linking its BST siblings or pruning its Trie descendants. Crucially, this implementation must perform "Eager Pruning" (Garbage Collection). In a TST, a node is considered "useless" and must be removed if it is not an end-point (!is_end) AND it has no children at all (left, mid, and right are all None). A standard Trie deletion often just unmarks the is_end flag, but valid TST implementation must physically remove dead nodes to prevent memory leaks. The deletion logic proceeds as follows: (1) Traverse to the target node using the TST search logic. (2) Unmark the is_end flag. (3) On the return path of the recursion, check if the current node has become "useless." If so, return None to the parent to prune it. Specifically, you must prove: (1) Set Update: The abstract view of the resulting tree corresponds to the set difference of the original view and the key. (2) Structural Correctness (Pruning): The result must satisfy opt_well_formed, formally asserting that no "useless" nodes exist. This proves that your implementation correctly cleaned up the specific path used by the deleted key without breaking the structure for shared prefixes or siblings.