#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int N=3e5+5,M=3e5+5,INF=1e9;
inline int read(){
char c=getchar();int x=0,f=1;
while(c<‘0‘||c>‘9‘){if(c==‘-‘)f=-1; c=getchar();}
while(c>=‘0‘&&c<=‘9‘){x=x*10+c-‘0‘; c=getchar();}
return x*f;
}
int _=10000;
int n,m,k;
struct String{
int p,l;
}a[N];
int cat[N];
int s[M],ns;
int c[N],t1[N],t2[N];
struct SuffixArray{
int n,m;
int sa[N],rnk[N],height[N];
inline bool cmp(int *r,int a,int b,int j){
return a+j<=n&&b+j<=n&&r[a]==r[b]&&r[a+j]==r[b+j];
}
void getSA(){
m=_;
int *r=t1,*k=t2;
for(int i=0;i<=m;i++) c[i]=0;
for(int i=1;i<=n;i++) c[r[i]=s[i]]++;
for(int i=1;i<=m;i++) c[i]+=c[i-1];
for(int i=n;i>=1;i--) sa[c[r[i]]--]=i;
for(int j=1;j<=n;j<<=1){
int p=0;
for(int i=n-j+1;i<=n;i++) k[++p]=i;
for(int i=1;i<=n;i++) if(sa[i]>j) k[++p]=sa[i]-j;
for(int i=0;i<=m;i++) c[i]=0;
for(int i=1;i<=n;i++) c[r[k[i]]]++;
for(int i=1;i<=m;i++) c[i]+=c[i-1];
for(int i=n;i>=1;i--) sa[c[r[k[i]]]--]=k[i];
swap(r,k);p=0;r[sa[1]]=++p;
for(int i=2;i<=n;i++) r[sa[i]]=cmp(k,sa[i],sa[i-1],j)?p:++p;
if(p>=n) break;m=p;
}
}
void getHeight(){
for(int i=1;i<=n;i++) rnk[sa[i]]=i;
int k=0;
for(int i=1;i<=n;i++){
if(k) k--;
if(rnk[i]==1) continue;
int j=sa[rnk[i]-1];
while(i+k<=n&&j+k<=n&&s[i+k]==s[j+k]) k++;
height[rnk[i]]=k;
}
}
void test(){
puts("test");
for(int i=1;i<=n;i++) printf("%d ",rnk[i]);puts("");
for(int i=1;i<=n;i++) printf("%d ",height[i]);puts("");
puts("end");
}
}t;
int a2[N];
int vis[20005];
void solve(){
t.n=ns;
t.getSA();
t.getHeight();
for(int i=1;i<=m;i++){
int a1=0;
int p=t.rnk[a[i].p],len=a[i].l;//printf("hi %d %d %d %d %d\n",i,a[i].p,a[i].l,p,t.height[p]);
for(int j=p;j>1&&t.height[j]>=len;j--){
int q=t.sa[j-1];
if(cat[q]&&vis[cat[q]]!=i) a1++,a2[cat[q]]++,vis[cat[q]]=i;
}
for(int j=p+1;j<=ns&&t.height[j]>=len;j++){
int q=t.sa[j];
if(cat[q]&&vis[cat[q]]!=i) a1++,a2[cat[q]]++,vis[cat[q]]=i;
}
//memset(vis,0,sizeof(vis));
printf("%d\n",a1);
}
for(int i=1;i<=n;i++){printf("%d",a2[i]);if(i!=n) putchar(‘ ‘);}
}
int main(){
freopen("in","r",stdin);
n=read();m=read();
for(int i=1;i<=n;i++){
k=read();
while(k--) s[++ns]=read(),cat[ns]=i;
s[++ns]=++_;
k=read();
while(k--) s[++ns]=read(),cat[ns]=i;
s[++ns]=++_;
}
for(int i=1;i<=m;i++){
a[i].p=ns+1;
a[i].l=k=read();
while(k--) s[++ns]=read();
if(i!=m) s[++ns]=++_;
}
solve();
}