Your task is to implement the modify operation for a Range Maximum Segment Tree using a functional (immutable) approach and verify its correctness in Verus. The modify operation updates the value at a specific index $idx$ to $v$ by creating a new version of the tree (path copying) rather than mutating memory in place. The operation proceeds from the root: (1) Base Case: If the current node is a leaf representing $idx$, return a new leaf node containing the new value $v$. (2) Recursive Step: Identify which child contains $idx$, recursively call modify on that child to get a new subtree, and reuse the pointer to the other unchanged child. Create and return a new internal node linking to these children, updating its val to be the maximum of the new children. Specifically, you must prove the following: (1) Functional Correctness: In the returned tree, the value at $idx$ is exactly $v$. (2) Frame Preservation: For all other indices $k \neq idx$, the value in the new tree is identical to the value in the old tree. (3) Invariant Preservation: The new tree maintains the is_segment_tree invariant, ensuring the structural and max-value properties remain valid after the update.