Your task is to implement the Search operation for a Ternary Search Tree (TST) and verify its correctness in Dafny. A TST is a hybrid data structure that combines the time efficiency of Tries with the space efficiency of Binary Search Trees. Unlike a standard Trie, which wastes memory by using a large array for every possible child (e.g., 256 slots per node), a TST node stores just one character (val) and three pointers: left, right, and mid. The left and right children form a BST for "sibling" characters at the current position, while the mid child acts as a Trie link to the next character in the sequence. The search logic must respect this three-way branching: (1) Horizontal Traversal (BST Logic): If the current character in the key is less than the node's val, recurse to left. If it is greater than, recurse to right. In both cases, do not consume the character from the key. (2) Vertical Traversal (Trie Logic): If the current character is equal to the node's val, the character is matched. Consume it and recurse to mid with the remaining key. Specifically, you must prove: (1) Functional Correctness: The function returns true if and only if the key exists in the tree's abstract view. (2) Traversal Invariant: The implementation correctly navigates the BST structure for mismatches and the Trie structure for matches.