#### Registered Users Only

Please login to utilize this feature.

Do note that this website only supports submissions in C++.

### Title

### Problem Statement

We have a board with an `H × W` grid.
Each square in the grid is painted in black or white. The square at the `i`-th row from the top and `j`-th column from the left is black if the `j`-th character in `S _{i}` is

`#`

, and white if that character is `.`

.Snuke can perform the following operation on the grid any number of times:

- Select a row or column in the grid, and invert the color of all the squares in that row or column (that is, black squares become white and vice versa).

Then, Snuke draws a rectangle along grid lines. Here, all the squares contained in the rectangle must be painted in black.

Find the maximum possible area of Snuke's rectangle when the operation is performed optimally.

### Constraints

`2 ≤ H ≤ 2000``2 ≤ W ≤ 2000``|S`_{i}| = W`S`consists of_{i}`#`

and`.`

.

### Input

Input is given from Standard Input in the following format:

HWS_{1}S_{2}:S_{H}

### Output

Print the maximum possible area of Snuke's rectangle.

### Sample Input 1

3 3 ..# ##. .#.

### Sample Output 1

6

If the first row from the top and the third column from the left are inverted, a `2 × 3` rectangle can be drawn, as shown below:

### Sample Input 2

4 4 .... .... .... ....

### Sample Output 2

16

### Sample Input 3

10 8 ##...#.# ##...#.# ..###.#. #.##.#.# .#..#.#. ..##.#.# ##.#.#.. ...#.#.. ###.#.## ###..###

### Sample Output 3

27

### Tags

### Subtasks and Limits

Subtask | Score | #TC | Time | Memory | Scoring |
---|---|---|---|---|---|

1 | 100 | 37 | 1s | 256MB | Minimum |

2 | 0 | 3 | 1s | 256MB | Minimum |

### Judge Compile Command

g++-7 ans.cpp -o fliprect -Wall -static -O2 -lm -m64 -s -w -std=gnu++17 -fmax-errors=512