mod= 10 **9 +7
#import resource
#resource.setrlimit(resource.RLIMIT_STACK, [0x100000000, resource.RLIM_INFINITY])
import threading
threading .stack_size ( 2 **28 )
import sys
sys .setrecursionlimit ( 10 **7 )
#fact=[1]
#for i in range(1,1000001):
# fact.append((fact[-1]*i)%mod)
#ifact=[0]*1000001
#ifact[1000000]=pow(fact[1000000],mod-2,mod)
#for i in range(1000000,0,-1):
# ifact[i-1]=(i*ifact[i])%mod
from sys import stdin, stdout
import bisect
from bisect import bisect_left as bl #c++ lowerbound bl(array,element)
from bisect import bisect_right as br #c++ upperbound
import itertools
import collections
import math
import heapq
from random import randint as rn
#from Queue import Queue as Q
def modinv( n, p) :
return pow ( n, p-2 , p)
def ncr( n, r, p) : #for using this uncomment the lines calculating fact and ifact
t= ( ( fact[ n] ) *( ( ifact[ r] *ifact[ n-r] ) %p) ) %p
return t
def ain( ) : #takes array as input
return list ( map ( int , sin( ) .split ( ) ) )
def sin( ) :
return input ( ) .strip ( )
def GCD( x, y) :
while ( y) :
x, y = y, x % y
return x
class node:
def __init__ ( self , s, l, p) :
self .child = { }
self .se = s
self .le = l
self .parent = p
self .val = 0
"""*******************************************************"""
def main( ) :
def sufarr( s) :
n= len ( s)
o= [ 0 ] *n
o[ 0 ] = n-1
f= [ 0 ] *26
f[ 0 ] = 1
for i in range ( n-1 ) :
f[ ord ( s[ i] ) -65 ] += 1
for i in range ( 1 , 26 ) :
f[ i] += f[ i-1 ]
for i in range ( n-2 , -1 , -1 ) :
f[ ord ( s[ i] ) -65 ] -= 1
o[ f[ ord ( s[ i] ) -65 ] ] = i
c= [ 0 ] *n
for i in range ( 1 , n) :
if ( s[ o[ i] ] == s[ o[ i-1 ] ] ) :
c[ o[ i] ] = c[ o[ i-1 ] ]
else :
c[ o[ i] ] = c[ o[ i-1 ] ] +1
l= 1
while ( l< n) :
f= [ 0 ] *n
for i in range ( n) :
f[ c[ i] ] += 1
for i in range ( 1 , n) :
f[ i] += f[ i-1 ]
od= [ 0 ] *n
for i in range ( n-1 , -1 , -1 ) :
pt= ( o[ i] -l) %n
f[ c[ pt] ] -= 1
od[ f[ c[ pt] ] ] = pt
cd = [ 0 ] *n
for i in range ( 1 , n) :
x1= c[ od[ i] ]
y1= c[ ( od[ i] +l) %n]
x2= c[ od[ i-1 ] ]
y2= c[ ( od[ i-1 ] +l) %n]
if ( x1== x2 and y1== y2) :
cd [ od[ i] ] = cd [ od[ i-1 ] ]
else :
cd [ od[ i] ] = cd [ od[ i-1 ] ] +1
o= od[ ::]
c= cd [ ::]
l*= 2
return o
def LCP( o) :
n= len ( o)
poso= [ 0 ] *n
for i in range ( n) :
poso[ o[ i] ] = i
lc= 0
lcp= [ 0 ] *( n-1 )
s= o[ 0 ]
for i in range ( n) :
oi= poso[ s]
if ( oi == n-1 ) :
lc= 0
s= ( s+1 ) %n
continue
ns= o[ oi+1 ]
lc= lcpcal( s, ns, lc-1 )
lcp[ oi] = lc
s= ( s+1 ) %n
return lcp
def lcpcal( i, j, k) :
l= max ( 0 , k)
while ( i+l < len ( st) ) and ( j+l < len ( st) ) :
if ( st[ i+l] == st[ j+l] ) :
l+= 1
else :
break
return l
def suftree( ) :
a= node( -1 , 0 , -1 )
b= node( o[ 0 ] , 1 , a)
a.child [ st[ o[ 0 ] ] ] = b
t= a
a= b
r= 1
for i in range ( 1 , n) :
x= lcp[ i-1 ]
y= o[ i]
while ( r> x) :
r-= a.le
a= a.parent
if ( r== x) :
b= node( y+x, n-( y+x) , a)
a.child [ st[ y+x] ] = b
a= b
else :
q= x-r
k= a.child [ st[ y+r] ]
w1= node( k.se , q, a)
w2= node( y+x, n-( x+y) , w1)
k.se = w1.se +q
k.le -= q
k.parent = w1
w1.child [ st[ k.se ] ] = k
w1.child [ st[ w2.se ] ] = w2
del a.child [ st[ y+r] ]
a.child [ st[ w1.se ] ] = w1
a= w2
r= n-y
return t
def dfs( x) :
if ( len ( x.child ) == 0 ) :
x.val = x.le -1
else :
x.val = x.le
for i in x.child :
x.val += dfs( x.child [ i] )
return x.val
st= list ( sin( ) )
st.append ( "$" )
x= int ( sin( ) )
q1= list ( map ( str , sin( ) .split ( ) ) )
q2= list ( map ( int , sin( ) .split ( ) ) )
n= len ( st)
o= sufarr( st)
lcp= LCP( o)
t= suftree( )
dfs( t)
f= [ ]
for i in range ( x) :
b= t
k= q2[ i]
s= q1[ i]
j= 0
t2= 0
while ( b.val > k and j< len ( s) ) :
if ( ( b.val -b.le +1 ) <= k) :
j+= b.val -k+1
break
else :
j+= b.le
if ( j>= len ( s) ) :
t2= 1
break
b= b.child [ s[ j] ]
if ( b.val <= k) :
j+= 1
break
if ( j<= len ( s) and t2== 0 ) :
print j,
else :
print "-1" ,
######## Python 2 and 3 footer by Pajenegod and c1729
py2 = round ( 0.5 )
if py2:
from future_builtins import ascii, filter , hex , map , oct , zip
range = xrange
import os , sys
from io import IOBase, BytesIO
BUFSIZE = 8192
class FastIO( BytesIO) :
newlines = 0
def __init__ ( self , file ) :
self ._file = file
self ._fd = file .fileno ( )
self .writable = "x" in file .mode or "w" in file .mode
self .write = super ( FastIO, self ) .write if self .writable else None
def _fill( self ) :
s = os .read ( self ._fd, max ( os .fstat ( self ._fd) .st_size , BUFSIZE) )
self .seek ( ( self .tell ( ) , self .seek ( 0 , 2 ) , super ( FastIO, self ) .write ( s) ) [ 0 ] )
return s
def read( self ) :
while self ._fill( ) : pass
return super ( FastIO, self ) .read ( )
def readline ( self ) :
while self .newlines == 0 :
s = self ._fill( ) ; self .newlines = s.count ( b"\n " ) + ( not s)
self .newlines -= 1
return super ( FastIO, self ) .readline ( )
def flush( self ) :
if self .writable :
os .write ( self ._fd, self .getvalue ( ) )
self .truncate ( 0 ) , self .seek ( 0 )
class IOWrapper( IOBase) :
def __init__ ( self , file ) :
self .buffer = FastIO( file )
self .flush = self .buffer .flush
self .writable = self .buffer .writable
if py2:
self .write = self .buffer .write
self .read = self .buffer .read
self .readline = self .buffer .readline
else :
self .write = lambda s:self .buffer .write ( s.encode ( 'ascii' ) )
self .read = lambda :self .buffer .read ( ) .decode ( 'ascii' )
self .readline = lambda :self .buffer .readline ( ) .decode ( 'ascii' )
sys .stdin , sys .stdout = IOWrapper( sys .stdin ) , IOWrapper( sys .stdout )
input = lambda : sys .stdin .readline ( ) .rstrip ( '\r \n ' )
#if __name__ == '__main__':
# main()
threading .Thread ( target= main) .start ( )
mod=10**9+7
#import resource
#resource.setrlimit(resource.RLIMIT_STACK, [0x100000000, resource.RLIM_INFINITY])
import threading
threading.stack_size(2**28)
import sys
sys.setrecursionlimit(10**7)
#fact=[1]
#for i in range(1,1000001):
#    fact.append((fact[-1]*i)%mod)
#ifact=[0]*1000001
#ifact[1000000]=pow(fact[1000000],mod-2,mod)
#for i in range(1000000,0,-1):
#    ifact[i-1]=(i*ifact[i])%mod
from sys import stdin, stdout
import bisect
from bisect import bisect_left as bl              #c++ lowerbound bl(array,element)
from bisect import bisect_right as br             #c++ upperbound
import itertools
import collections
import math
import heapq
from random import randint as rn
#from Queue import Queue as Q
def modinv(n,p):
    return pow(n,p-2,p)
def ncr(n,r,p):                        #for using this uncomment the lines calculating fact and ifact
    t=((fact[n])*((ifact[r]*ifact[n-r])%p))%p
    return t
def ain():                           #takes array as input
    return list(map(int,sin().split()))
def sin():
    return input().strip()
def GCD(x,y):
    while(y):
        x, y = y, x % y
    return x
class node:
    def __init__(self,s,l,p):
        self.child={}
        self.se=s
        self.le=l
        self.parent=p
        self.val=0
"""*******************************************************"""
def main():
    def sufarr(s):
        n=len(s)
        o=[0]*n
        o[0]=n-1
        f=[0]*26
        f[0]=1
        for i in range(n-1):
            f[ord(s[i])-65]+=1
        for i in range(1,26):
            f[i]+=f[i-1]
        for i in range(n-2,-1,-1):
            f[ord(s[i])-65]-=1
            o[f[ord(s[i])-65]]=i
        c=[0]*n
        for i in range(1,n):
            if(s[o[i]]==s[o[i-1]]):
                c[o[i]]=c[o[i-1]]
            else:
                c[o[i]]=c[o[i-1]]+1
        l=1
        while(l<n):
            f=[0]*n
            for i in range(n):
                f[c[i]]+=1
            for i in range(1,n):
                f[i]+=f[i-1]
            od=[0]*n
            for i in range(n-1,-1,-1):
                pt=(o[i]-l)%n
                f[c[pt]]-=1
                od[f[c[pt]]]=pt
            cd=[0]*n
            for i in range(1,n):
                x1=c[od[i]]
                y1=c[(od[i]+l)%n]
                x2=c[od[i-1]]
                y2=c[(od[i-1]+l)%n]
                if(x1==x2 and y1==y2):
                    cd[od[i]]=cd[od[i-1]]
                else:
                    cd[od[i]]=cd[od[i-1]]+1
            o=od[::]
            c=cd[::]
            l*=2
        return o
    def LCP(o):
        n=len(o)
        poso=[0]*n
        for i in range(n):
            poso[o[i]]=i
        lc=0
        lcp=[0]*(n-1)
        s=o[0]
        for i in range(n):
            oi=poso[s]
            if(oi == n-1):
                lc=0
                s=(s+1)%n
                continue
            ns=o[oi+1]
            lc=lcpcal(s,ns,lc-1)
            lcp[oi]=lc
            s=(s+1)%n
        return lcp
    def lcpcal(i,j,k):
        l=max(0,k)
        while (i+l < len(st)) and (j+l < len(st)) :
            if(st[i+l]==st[j+l]):
                l+=1
            else:
                break
        return l
    def suftree():
        a=node(-1,0,-1)
        b=node(o[0],1,a)
        a.child[st[o[0]]]=b
        t=a
        a=b
        r=1
        for i in range(1,n):
            x=lcp[i-1]
            y=o[i]
            while(r>x):
                r-=a.le
                a=a.parent
            if(r==x):
                b=node(y+x,n-(y+x),a)
                a.child[st[y+x]]=b
                a=b
            else:
                q=x-r
                k=a.child[st[y+r]]
                w1=node(k.se,q,a)
                w2=node(y+x,n-(x+y),w1)
                k.se=w1.se+q
                k.le-=q
                k.parent=w1
                w1.child[st[k.se]]=k
                w1.child[st[w2.se]]=w2
                del a.child[st[y+r]]
                a.child[st[w1.se]]=w1
                a=w2
            r=n-y
        return t
    def dfs(x):
        if(len(x.child)==0):
            x.val=x.le-1
        else:
            x.val=x.le
        for i in x.child:
            x.val+=dfs(x.child[i])
        return x.val
    st=list(sin())
    st.append("$")
    x=int(sin())
    q1=list(map(str,sin().split()))
    q2=list(map(int,sin().split()))
    n=len(st)
    o=sufarr(st)
    lcp=LCP(o)
    t=suftree()
    dfs(t)
    f=[]
    for i in range(x):
        b=t
        k=q2[i]
        s=q1[i]
        j=0
        t2=0
        while(b.val>k and j<len(s)):
            if((b.val-b.le+1)<=k):
                j+=b.val-k+1
                break
            else:
                j+=b.le
            if(j>=len(s)):
                t2=1
                break
            b=b.child[s[j]]
            if(b.val<=k):
                j+=1
                break
        if(j<=len(s) and t2==0):
            print j,
        else:
            print "-1",
######## Python 2 and 3 footer by Pajenegod and c1729
py2 = round(0.5)
if py2:
    from future_builtins import ascii, filter, hex, map, oct, zip
    range = xrange

import os, sys
from io import IOBase, BytesIO

BUFSIZE = 8192
class FastIO(BytesIO):
    newlines = 0
    def __init__(self, file):
        self._file = file
        self._fd = file.fileno()
        self.writable = "x" in file.mode or "w" in file.mode
        self.write = super(FastIO, self).write if self.writable else None

    def _fill(self):
        s = os.read(self._fd, max(os.fstat(self._fd).st_size, BUFSIZE))
        self.seek((self.tell(), self.seek(0,2), super(FastIO, self).write(s))[0])
        return s
    def read(self):
        while self._fill(): pass
        return super(FastIO,self).read()

    def readline(self):
        while self.newlines == 0:
            s = self._fill(); self.newlines = s.count(b"\n") + (not s)
        self.newlines -= 1
        return super(FastIO, self).readline()

    def flush(self):
        if self.writable:
            os.write(self._fd, self.getvalue())
            self.truncate(0), self.seek(0)

class IOWrapper(IOBase):
    def __init__(self, file):
        self.buffer = FastIO(file)
        self.flush = self.buffer.flush
        self.writable = self.buffer.writable
        if py2:
            self.write = self.buffer.write
            self.read = self.buffer.read
            self.readline = self.buffer.readline
        else:
            self.write = lambda s:self.buffer.write(s.encode('ascii'))
            self.read = lambda:self.buffer.read().decode('ascii')
            self.readline = lambda:self.buffer.readline().decode('ascii')

sys.stdin, sys.stdout = IOWrapper(sys.stdin), IOWrapper(sys.stdout)
input = lambda: sys.stdin.readline().rstrip('\r\n')

#if __name__ == '__main__':
#   main()
threading.Thread(target=main).start()
