Your task is to implement a Stack data structure and verify its Last-In, First-Out behavior in Lean. The stack is modeled as a mathematical sequence. Specifically, you are required to implement and verify the pop operation. Pop: You must prove that the operation returns the last element of the sequence and that the resulting model sequence is the original sequence minus its last element. You must also verify the safety precondition that the stack is non-empty before a pop. In a functional setting, the function should accept a proof of non-emptiness and return both the popped value and the new stack state.
