#include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<cstring>
using namespace std;
int n,m,r,c,cnt,cntx,ans;
struct sdt
{
int st,to,nxt;
}e[50005];
char p[205][205];
int num[205][205],head[50005],res[50005];
bool vis[50005];
void add(int x,int y)
{
e[++cntx].st=x;
e[cntx].to=y;
e[cntx].nxt=head[x];
head[x]=cntx;
}
bool dfs(int x)
{
for(int i=head[x];i;i=e[i].nxt)
{
if(!vis[e[i].to])
{
vis[e[i].to]=1;
if(!res[e[i].to] || dfs(res[e[i].to]))
{
res[e[i].to]=x;
return 1;
}
}
}
return 0;
}
int main()
{
scanf("%d%d%d%d",&n,&m,&r,&c);
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
cin>>p[i][j];
if(p[i][j]==‘.‘)num[i][j]=++cnt;
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
if(!num[i][j])continue;
if(i+r<=n && j+c<=m && num[i+r][j+c])
add(num[i][j],num[i+r][j+c]+cnt);
if(i+r<=n && j-c>0 && num[i+r][j-c])
add(num[i][j],num[i+r][j-c]+cnt);
if(i+c<=n && j+r<=m && num[i+c][j+r])
add(num[i][j],num[i+c][j+r]+cnt);
if(i+c<=n && j-r>0 && num[i+c][j-r])
add(num[i][j],num[i+c][j-r]+cnt);
}
}
for(int i=1;i<=cnt;i++)
{
memset(vis,0,sizeof(vis));
if(dfs(i))ans++;
}
printf("%d\n",cnt-ans);
return 0;
}