Your task is to implement the Binary Search algorithm (specifically the lower_bound variant) and verify its correctness in Dafny. You are given a sorted sequence of integers and a target value. The algorithm must find the first index $k$ such that $s[k] \ge target$ in $O(\log N)$ time logic (using a shrinking window). In the incomplete code, the specification is_sorted is provided. You must implement the standard binary search loop (while low < high) and prove that the returned index is the correct boundary. This requires a two-sided invariant: (1) Left Side: All elements to the left of the current window (0..low) are strictly less than the target. (2) Right Side: All elements to the right of the current window (high..|s|) are greater than or equal to the target.