Your task is to implement the Zig-Zag operation (Left-Right Rotation) in a binary search tree and verify its correctness in Lean. A Zig-Zag is performed when node X lies between parent P and grandparent G (X is right child of P, P is left child of G). Prove: (1) Set Preservation: The tree's view is unchanged. (2) BST Invariant Preservation. (3) Structural Correctness: X becomes the new root, P becomes the left child of X, and G becomes the right child of X.
