def f(A): a0=0 P=[0]*((1<<10)) AA=[0]*((1<<10)) for a in A: a0^=a for p,val in enumerate(P): AA[a0^p]+=val AA[a0^p]%=MOD P[a0]+=1 AA[a0]+=1 return AA import sys input = sys.stdin.readline MOD=10**9+7 N,M,K=map(int, input().split()) A=list(map(int, input().split())) B=list(map(int, input().split())) A=f(A) B=f(B) cnt=0 for a,val_a in enumerate(A): for b,val_b in enumerate(B): if a^b==K: cnt+=val_a*val_b cnt%=MOD print(cnt)