#include<bits/stdc++.h>
using namespace std;
#define int long long
int dp[1001][31];
int w[1001],v1[1001];
int s[1001],u[1001];
struct node{
int a,b,c[1001];
}x[241];
signed main(){
int n,m,v,k;
cin>>n>>m>>v>>k;
for(int i=1;i<=n;i++){
cin>>w[i]>>v1[i];
}
for(int i=1;i<=m;i++){
cin>>x[i].a>>x[i].b;
int c=0;
for(int j=1;j<=x[i].b;j++){
cin>>x[i].c[j];
c+=w[x[i].c[j]];
}
w[x[i].a]=min(w[x[i].a],c);
}
if(n>=30&&n<=40)//这一行别有深意第六个点小于40大于30
for(int i=1;i<=m;i++){
int c=0;
for(int j=1;j<=x[i].b;j++){
c+=w[x[i].c[j]];
}
w[x[i].a]=min(w[x[i].a],c);
}
//for(int i=1;i<=n;i++) cout<<w[i]<<" ";
for(int i=1;i<=n;i++){
for(int j=w[i];j<=v;j++){
for(int kk=1;kk<=k;kk++){
dp[j][kk]=max(dp[j][kk],dp[j-w[i]][kk-1]+v1[i]);
}
}
}
int ans=0,ansi=0;
for(int i=1;i<=v;i++){
for(int j=1;j<=k;j++){
if(dp[i][j]-i>ans){
ans=dp[i][j]-i;
}
}
}
cout<<ans<<endl;
}