Your task is to implement the Pop Max operation for a binary max-heap (the maximum value is stored at the root), which removes and returns the root element (the maximum value) of the heap, and verify its correctness in Dafny. To maintain the complete binary tree structure, the value at the last position of the sequence is moved to the root, and the heap size is decremented. Because this "promoted" value likely violates the heap property at the root, you must perform a "bubble-down" (or sift-down) process, iteratively swapping the node with its largest child until the max-heap invariant is restored throughout the tree. Specifically, you must prove the following: (1) Functional Correctness of Maximum: The value returned by the operation must be mathematically proven to be the maximum value in the original heap. This is verified by showing that the returned value is greater than or equal to every element contained in the heap's original multiset view. (2) Multiset Consistency: The resulting multiset of values in the heap must be identical to the original multiset minus exactly one instance of the returned maximum value. (3) Structural Integrity: After the bubble-down process, the heap property must be restored: for every index $i$ with children at $2i + 1$ and $2i + 2$, the value at $i$ must be greater than or equal to both children. This requires careful reasoning about the choice of the "larger child" during each swap to ensure the parent becomes a valid head for both subtrees.