Your task is to implement Insertion Sort and verify its correctness in Dafny. The algorithm builds the final sorted array one item at a time. It iterates through the input elements and, for each one, inserts it into its correct position among the previously sorted elements. You must prove: (1) Sortedness: The resulting vector is sorted. (2) Permutation: The resulting vector is a permutation of the input. The key verification challenge is the prefix invariant: at index $i$ of the outer loop, the subarray 0..i is sorted and is a permutation of the first $i$ elements of the original array. The inner loop shifts elements to make room for the current value.