n,d,k=map(int,input().split()) mod=10**9+7 No=2 while No<=k: No*=2 tree=[0]*(2*No) #kをxにする def update(k,x): k+=No-1 tree[k]=x while k>0: k=(k-1)//2 tree[k]=(tree[k*2+1]+tree[k*2+2])%mod #lからrまでの和(l,r含む) def query(l,r): L=l+No-1 R=r+No-1 s=0 while L<=R: if R&1: s+=tree[R] s%=mod R-=2 else: R-=1 if L&1: L-=1 else: s+=tree[L] s%=mod L>>=1;R>>=1 return s%mod update(0,1) for j in range(n): for i in range(k,-1,-1): update(i,query(max(i-d,0),i-1)) print(tree[k+No-1])