#include <algorithm>
#include <deque>
#include <map>
#include <math.h>
#include <queue>
#include <set>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <string>
#include <vector>
using namespace std;
const long long mod = 1000000007;
const long long inf = mod * mod;
char str[1100][1100];
int main() {
  int a;
  scanf("%d", &a);
  for (int i = 0; i < a; i++)
    scanf("%s", str[i]);
  bool ok = false;
  for (int i = 0; i < a; i++)
    for (int j = 0; j < a; j++)
      if (str[i][j] == '#')
        ok = true;
  if (!ok) {
    printf("-1\n");
    return 0;
  }
  int ad = 0;
  int ret = 114514;
  for (int i = 0; i < a; i++) {
    bool dd = false;
    for (int j = 0; j < a; j++)
      if (str[j][i] == '.')
        dd = true;
    if (dd)
      ad++;
  }
  for (int i = 0; i < a; i++) {
    bool OK = false;
    for (int j = 0; j < a; j++)
      if (str[j][i] == '#')
        OK = true;
    int cnt = 0;
    for (int j = 0; j < a; j++) {
      if (str[i][j] == '.')
        cnt++;
    }
    if (!OK)
      cnt++;
    ret = min(ret, cnt);
  }
  printf("%d\n", ret + ad);
}