/*
* @Author: hungeazy
* @Date: 2025-11-11 14:07:38
* @Last Modified by: hungeazy
* @Last Modified time: 2025-11-11 14:32:09
*/
#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
// #pragma GCC optimize("O3")
// #pragma GCC optimize("unroll-loops")
// #pragma GCC target("avx2,bmi,bmi2,popcnt,lzcnt")
using namespace std;
using namespace __gnu_pbds;
bool M1;
#define fast ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
#define int long long
#define ll long long
#define ull unsigned long long
#define sz(x) x.size()
#define sqr(x) (1LL * (x) * (x))
#define all(x) x.begin(), x.end()
#define fill(f,x) memset(f,x,sizeof(f))
#define FOR(i,l,r) for(int i=l;i<=r;i++)
#define FOD(i,r,l) for(int i=r;i>=l;i--)
#define debug(x) cout << #x << " = " << x << '\n'
#define ii pair<int,int>
#define iii pair<int,ii>
#define di pair<ii,ii>
#define vi vector<int>
#define vii vector<ii>
#define mii map<int,int>
#define fi first
#define se second
#define pb push_back
#define MOD 1000000007
#define __lcm(a,b) (1ll * ((a) / __gcd((a), (b))) * (b))
#define YES cout << "YES\n"
#define NO cout << "NO\n"
#define MASK(i) (1LL << (i))
#define c_bit(i) __builtin_popcountll(i)
#define BIT(x,i) ((x) & MASK(i))
#define SET_ON(x,i) ((x) | MASK(i))
#define SET_OFF(x,i) ((x) & ~MASK(i))
#define oo 1e18
#define name "ANCTEXT"
#define endl '\n'
#define memory() cerr << abs(&M2-&M1)/1024.0/1024 << " MB" << endl
#define time() cerr << endl << "-------------Time:" << 1000.0 * clock() / CLOCKS_PER_SEC << "ms." << endl
template<typename T> bool maximize(T &res, const T &val) { if (res < val){ res = val; return true; }; return false; }
template<typename T> bool minimize(T &res, const T &val) { if (res > val){ res = val; return true; }; return false; }
template <class T> using ordered_set = tree <T, null_type, less_equal <T>, rb_tree_tag,tree_order_statistics_node_update>;
const int N = (int)5e5+10;
string s;
int n,q;
pair<int,string> mem[N];
// VO20 - Bài 3
namespace hungeazy {
const int base = 256;
int pw[N],hashA[N],sorted[N],cnt=0;
int hashing(int hashVal, char h) {
return (hashVal*base%MOD+h)%MOD;
}
int getHash(int l, int r) {
return (hashA[r]-hashA[l-1]*pw[r-l+1]%MOD+sqr(MOD))%MOD;
}
struct Node {
int h,endIdx,hashVal;
Node *child[26], *par[20];
char cur;
Node() {
h = hashVal = 0;
endIdx = -1;
FOR(i,0,19) par[i] = NULL;
FOR(i,0,25) child[i] = NULL;
cur = '?';
}
} *endNode[N];
struct Trie {
Node *root;
Trie() {
root = new Node();
FOR(i,0,19) root->par[i] = root;
endNode[0] = root;
}
void insert(Node *p, int idx, string &s)
{
for (char c : s)
{
int pos = c-'a';
if (p->child[pos] == NULL)
{
p->child[pos] = new Node();
p->child[pos]->hashVal = (p->hashVal*base%MOD+c)%MOD;
p->child[pos]->h = p->h+1;
p->child[pos]->cur = c;
p->child[pos]->par[0] = p;
FOR(i,1,19)
p->child[pos]->par[i] = (p->child[pos]->par[i-1])->par[i-1];
}
p = p->child[pos];
}
if (p->endIdx == -1) p->endIdx = idx;
endNode[idx] = p;
}
void DFS(Node *u)
{
if (u->endIdx != -1) sorted[++cnt] = u->endIdx;
FOR(pos,0,25)
if (u->child[pos] != NULL)
DFS(u->child[pos]);
}
} trie;
bool check(int pos, int L, int R)
{
Node *p = endNode[pos];
int lenS = R-L+1;
if (p->h <= lenS and p->hashVal == getHash(L,L+p->h-1)) return true;
FOD(i,19,0)
{
int lenT = p->par[i]->h;
if (lenT > lenS or p->par[i]->hashVal != getHash(L,L+lenT-1))
p = p->par[i];
}
return (p->h <= lenS and p->cur < s[L+p->h-1]);
}
void solve(void)
{
int len = sz(s);
s = "#"+s;
pw[0] = 1;
FOR(i,1,len)
{
pw[i] = pw[i-1]*base%MOD;
hashA[i] = hashing(hashA[i-1],s[i]);
}
FOR(i,1,n)
{
auto [par,st] = mem[i];
trie.insert(endNode[par],i,st);
}
trie.DFS(trie.root);
while (q--)
{
int l,r;
cin >> l >> r;
int L = 1, R = cnt, ans = -1;
while (L <= R)
{
int mid = (L+R)>>1;
if (check(sorted[mid],l,r)) ans = sorted[mid], L = mid+1;
else R = mid-1;
}
cout << ans << endl;
}
}
}
bool M2;
signed main()
{
fast;
if (fopen(name".inp","r"))
{
freopen(name".inp","r",stdin);
freopen(name".out","w",stdout);
}
int subtask;
cin >> subtask >> s >> n;
FOR(i,1,n)
{
int par; string st;
cin >> par >> st;
mem[i] = {par,st};
}
cin >> q;
hungeazy::solve();
time();
memory();
return 0;
}
// ██░ ██ █ ██ ███▄ █ ▄████
//▓██░ ██▒ ██ ▓██▒ ██ ▀█ █ ██▒ ▀█▒
//▒██▀▀██░▓██ ▒██░▓██ ▀█ ██▒▒██░▄▄▄░
//░▓█ ░██ ▓▓█ ░██░▓██▒ ▐▌██▒░▓█ ██▓
//░▓█▒░██▓▒▒█████▓ ▒██░ ▓██░░▒▓███▀▒
// ▒ ░░▒░▒░▒▓▒ ▒ ▒ ░ ▒░ ▒ ▒ ░▒ ▒
// ▒ ░▒░ ░░░▒░ ░ ░ ░ ░░ ░ ▒░ ░ ░
// ░ ░░ ░ ░░░ ░ ░ ░ ░ ░ ░ ░ ░
// ░ ░ ░ ░ ░ ░
LyoKKiBAQXV0aG9yOiBodW5nZWF6eQoqIEBEYXRlOiAgIDIwMjUtMTEtMTEgMTQ6MDc6MzgKKiBATGFzdCBNb2RpZmllZCBieTogICBodW5nZWF6eQoqIEBMYXN0IE1vZGlmaWVkIHRpbWU6IDIwMjUtMTEtMTEgMTQ6MzI6MDkKKi8KI2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNpbmNsdWRlIDxleHQvcGJfZHMvYXNzb2NfY29udGFpbmVyLmhwcD4gCiNpbmNsdWRlIDxleHQvcGJfZHMvdHJlZV9wb2xpY3kuaHBwPiAKLy8gI3ByYWdtYSBHQ0Mgb3B0aW1pemUoIk8zIikgIAovLyAjcHJhZ21hIEdDQyBvcHRpbWl6ZSgidW5yb2xsLWxvb3BzIikgIAovLyAjcHJhZ21hIEdDQyB0YXJnZXQoImF2eDIsYm1pLGJtaTIscG9wY250LGx6Y250IikgIAp1c2luZyBuYW1lc3BhY2Ugc3RkOwp1c2luZyBuYW1lc3BhY2UgX19nbnVfcGJkczsgCmJvb2wgTTE7CiNkZWZpbmUgZmFzdCBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKGZhbHNlKTsgY2luLnRpZShOVUxMKTsgY291dC50aWUoTlVMTCk7CiNkZWZpbmUgaW50IGxvbmcgbG9uZwojZGVmaW5lIGxsIGxvbmcgbG9uZyAKI2RlZmluZSB1bGwgdW5zaWduZWQgbG9uZyBsb25nCiNkZWZpbmUgc3ooeCkgeC5zaXplKCkKI2RlZmluZSBzcXIoeCkgKDFMTCAqICh4KSAqICh4KSkKI2RlZmluZSBhbGwoeCkgeC5iZWdpbigpLCB4LmVuZCgpCiNkZWZpbmUgZmlsbChmLHgpIG1lbXNldChmLHgsc2l6ZW9mKGYpKQojZGVmaW5lIEZPUihpLGwscikgZm9yKGludCBpPWw7aTw9cjtpKyspCiNkZWZpbmUgRk9EKGkscixsKSBmb3IoaW50IGk9cjtpPj1sO2ktLSkKI2RlZmluZSBkZWJ1Zyh4KSBjb3V0IDw8ICN4IDw8ICIgPSAiIDw8IHggPDwgJ1xuJwojZGVmaW5lIGlpIHBhaXI8aW50LGludD4KI2RlZmluZSBpaWkgcGFpcjxpbnQsaWk+CiNkZWZpbmUgZGkgcGFpcjxpaSxpaT4KI2RlZmluZSB2aSB2ZWN0b3I8aW50PgojZGVmaW5lIHZpaSB2ZWN0b3I8aWk+CiNkZWZpbmUgbWlpIG1hcDxpbnQsaW50PgojZGVmaW5lIGZpIGZpcnN0CiNkZWZpbmUgc2Ugc2Vjb25kCiNkZWZpbmUgcGIgcHVzaF9iYWNrCiNkZWZpbmUgTU9EIDEwMDAwMDAwMDcKI2RlZmluZSBfX2xjbShhLGIpICgxbGwgKiAoKGEpIC8gX19nY2QoKGEpLCAoYikpKSAqIChiKSkKI2RlZmluZSBZRVMgY291dCA8PCAiWUVTXG4iCiNkZWZpbmUgTk8gY291dCA8PCAiTk9cbiIKI2RlZmluZSBNQVNLKGkpICgxTEwgPDwgKGkpKQojZGVmaW5lIGNfYml0KGkpIF9fYnVpbHRpbl9wb3Bjb3VudGxsKGkpCiNkZWZpbmUgQklUKHgsaSkgKCh4KSAmIE1BU0soaSkpCiNkZWZpbmUgU0VUX09OKHgsaSkgKCh4KSB8IE1BU0soaSkpCiNkZWZpbmUgU0VUX09GRih4LGkpICgoeCkgJiB+TUFTSyhpKSkKI2RlZmluZSBvbyAxZTE4CiNkZWZpbmUgbmFtZSAiQU5DVEVYVCIKI2RlZmluZSBlbmRsICdcbicKI2RlZmluZSBtZW1vcnkoKSBjZXJyIDw8IGFicygmTTItJk0xKS8xMDI0LjAvMTAyNCA8PCAiIE1CIiA8PCBlbmRsCiNkZWZpbmUgdGltZSgpIGNlcnIgPDwgZW5kbCA8PCAiLS0tLS0tLS0tLS0tLVRpbWU6IiA8PCAxMDAwLjAgKiBjbG9jaygpIC8gQ0xPQ0tTX1BFUl9TRUMgPDwgIm1zLiIgPDwgZW5kbAp0ZW1wbGF0ZTx0eXBlbmFtZSBUPiBib29sIG1heGltaXplKFQgJnJlcywgY29uc3QgVCAmdmFsKSB7IGlmIChyZXMgPCB2YWwpeyByZXMgPSB2YWw7IHJldHVybiB0cnVlOyB9OyByZXR1cm4gZmFsc2U7IH0KdGVtcGxhdGU8dHlwZW5hbWUgVD4gYm9vbCBtaW5pbWl6ZShUICZyZXMsIGNvbnN0IFQgJnZhbCkgeyBpZiAocmVzID4gdmFsKXsgcmVzID0gdmFsOyByZXR1cm4gdHJ1ZTsgfTsgcmV0dXJuIGZhbHNlOyB9CnRlbXBsYXRlIDxjbGFzcyBUPiB1c2luZyBvcmRlcmVkX3NldCA9IHRyZWUgPFQsIG51bGxfdHlwZSwgbGVzc19lcXVhbCA8VD4sIHJiX3RyZWVfdGFnLHRyZWVfb3JkZXJfc3RhdGlzdGljc19ub2RlX3VwZGF0ZT47CmNvbnN0IGludCBOID0gKGludCk1ZTUrMTA7CnN0cmluZyBzOwppbnQgbixxOwpwYWlyPGludCxzdHJpbmc+IG1lbVtOXTsKLy8gVk8yMCAtIELDoGkgMwpuYW1lc3BhY2UgaHVuZ2VhenkgewoKCWNvbnN0IGludCBiYXNlID0gMjU2OwoJaW50IHB3W05dLGhhc2hBW05dLHNvcnRlZFtOXSxjbnQ9MDsKCglpbnQgaGFzaGluZyhpbnQgaGFzaFZhbCwgY2hhciBoKSB7CgkJcmV0dXJuIChoYXNoVmFsKmJhc2UlTU9EK2gpJU1PRDsKCX0KCglpbnQgZ2V0SGFzaChpbnQgbCwgaW50IHIpIHsKCQlyZXR1cm4gKGhhc2hBW3JdLWhhc2hBW2wtMV0qcHdbci1sKzFdJU1PRCtzcXIoTU9EKSklTU9EOwoJfQoKCXN0cnVjdCBOb2RlIHsKCQlpbnQgaCxlbmRJZHgsaGFzaFZhbDsKCQlOb2RlICpjaGlsZFsyNl0sICpwYXJbMjBdOwoJCWNoYXIgY3VyOwoJCU5vZGUoKSB7CgkJCWggPSBoYXNoVmFsID0gMDsKCQkJZW5kSWR4ID0gLTE7CgkJCUZPUihpLDAsMTkpIHBhcltpXSA9IE5VTEw7CgkJCUZPUihpLDAsMjUpIGNoaWxkW2ldID0gTlVMTDsKCQkJY3VyID0gJz8nOwoJCX0KCX0gKmVuZE5vZGVbTl07CgoJc3RydWN0IFRyaWUgewoJCU5vZGUgKnJvb3Q7CgoJCVRyaWUoKSB7CgkJCXJvb3QgPSBuZXcgTm9kZSgpOwoJCQlGT1IoaSwwLDE5KSByb290LT5wYXJbaV0gPSByb290OwoJCQllbmROb2RlWzBdID0gcm9vdDsKCQl9CgoJCXZvaWQgaW5zZXJ0KE5vZGUgKnAsIGludCBpZHgsIHN0cmluZyAmcykKCQl7CgkJCWZvciAoY2hhciBjIDogcykKCQkJewoJCQkJaW50IHBvcyA9IGMtJ2EnOwoJCQkJaWYgKHAtPmNoaWxkW3Bvc10gPT0gTlVMTCkKCQkJCXsKCQkJCQlwLT5jaGlsZFtwb3NdID0gbmV3IE5vZGUoKTsKCQkJCQlwLT5jaGlsZFtwb3NdLT5oYXNoVmFsID0gKHAtPmhhc2hWYWwqYmFzZSVNT0QrYyklTU9EOwoJCQkJCXAtPmNoaWxkW3Bvc10tPmggPSBwLT5oKzE7CgkJCQkJcC0+Y2hpbGRbcG9zXS0+Y3VyID0gYzsKCQkJCQlwLT5jaGlsZFtwb3NdLT5wYXJbMF0gPSBwOwoJCQkJCUZPUihpLDEsMTkpCgkJCQkJCXAtPmNoaWxkW3Bvc10tPnBhcltpXSA9IChwLT5jaGlsZFtwb3NdLT5wYXJbaS0xXSktPnBhcltpLTFdOwoJCQkJfQoJCQkJcCA9IHAtPmNoaWxkW3Bvc107CgkJCX0KCQkJaWYgKHAtPmVuZElkeCA9PSAtMSkgcC0+ZW5kSWR4ID0gaWR4OwoJCQllbmROb2RlW2lkeF0gPSBwOwoJCX0KCgkJdm9pZCBERlMoTm9kZSAqdSkKCQl7CgkJCWlmICh1LT5lbmRJZHggIT0gLTEpIHNvcnRlZFsrK2NudF0gPSB1LT5lbmRJZHg7CgkJCUZPUihwb3MsMCwyNSkKCQkJCWlmICh1LT5jaGlsZFtwb3NdICE9IE5VTEwpCgkJCQkJREZTKHUtPmNoaWxkW3Bvc10pOyAKCQl9Cgl9IHRyaWU7CgoJYm9vbCBjaGVjayhpbnQgcG9zLCBpbnQgTCwgaW50IFIpCgl7CgkJTm9kZSAqcCA9IGVuZE5vZGVbcG9zXTsKCQlpbnQgbGVuUyA9IFItTCsxOwoJCWlmIChwLT5oIDw9IGxlblMgYW5kIHAtPmhhc2hWYWwgPT0gZ2V0SGFzaChMLEwrcC0+aC0xKSkgcmV0dXJuIHRydWU7CgkJRk9EKGksMTksMCkKCQl7CgkJCWludCBsZW5UID0gcC0+cGFyW2ldLT5oOwoJCQlpZiAobGVuVCA+IGxlblMgb3IgcC0+cGFyW2ldLT5oYXNoVmFsICE9IGdldEhhc2goTCxMK2xlblQtMSkpCgkJCQlwID0gcC0+cGFyW2ldOwoJCX0KCQlyZXR1cm4gKHAtPmggPD0gbGVuUyBhbmQgcC0+Y3VyIDwgc1tMK3AtPmgtMV0pOwoJfQoKCXZvaWQgc29sdmUodm9pZCkKCXsKCQlpbnQgbGVuID0gc3oocyk7CgkJcyA9ICIjIitzOwoJCXB3WzBdID0gMTsKCQlGT1IoaSwxLGxlbikKCQl7CgkJCXB3W2ldID0gcHdbaS0xXSpiYXNlJU1PRDsKCQkJaGFzaEFbaV0gPSBoYXNoaW5nKGhhc2hBW2ktMV0sc1tpXSk7CgkJfQoJCUZPUihpLDEsbikKCQl7CgkJCWF1dG8gW3BhcixzdF0gPSBtZW1baV07CgkJCXRyaWUuaW5zZXJ0KGVuZE5vZGVbcGFyXSxpLHN0KTsKCQl9CgkJdHJpZS5ERlModHJpZS5yb290KTsKCQl3aGlsZSAocS0tKQoJCXsKCQkJaW50IGwscjsKCQkJY2luID4+IGwgPj4gcjsKCQkJaW50IEwgPSAxLCBSID0gY250LCBhbnMgPSAtMTsKCQkJd2hpbGUgKEwgPD0gUikKCQkJewoJCQkJaW50IG1pZCA9IChMK1IpPj4xOwoJCQkJaWYgKGNoZWNrKHNvcnRlZFttaWRdLGwscikpIGFucyA9IHNvcnRlZFttaWRdLCBMID0gbWlkKzE7CgkJCQllbHNlIFIgPSBtaWQtMTsKCQkJfQoJCQljb3V0IDw8IGFucyA8PCBlbmRsOwoJCX0KCX0KCQp9Cgpib29sIE0yOwpzaWduZWQgbWFpbigpCnsKICAgIGZhc3Q7CiAgICBpZiAoZm9wZW4obmFtZSIuaW5wIiwiciIpKQogICAgewogICAgCWZyZW9wZW4obmFtZSIuaW5wIiwiciIsc3RkaW4pOwogICAgCWZyZW9wZW4obmFtZSIub3V0IiwidyIsc3Rkb3V0KTsKICAgIH0KICAgIGludCBzdWJ0YXNrOwogICAgY2luID4+IHN1YnRhc2sgPj4gcyA+PiBuOwogICAgRk9SKGksMSxuKQogICAgewogICAgCWludCBwYXI7IHN0cmluZyBzdDsKICAgIAljaW4gPj4gcGFyID4+IHN0OwogICAgCW1lbVtpXSA9IHtwYXIsc3R9OwogICAgfQogICAgY2luID4+IHE7CiAgICBodW5nZWF6eTo6c29sdmUoKTsKICAgIHRpbWUoKTsKICAgIG1lbW9yeSgpOwogICAgcmV0dXJuIDA7Cn0KLy8g4paI4paI4paRIOKWiOKWiCAg4paIICAgIOKWiOKWiCAg4paI4paI4paI4paEICAgIOKWiCAgIOKWhOKWiOKWiOKWiOKWiAovL+KWk+KWiOKWiOKWkSDilojilojilpIg4paI4paIICDilpPilojilojilpIg4paI4paIIOKWgOKWiCAgIOKWiCAg4paI4paI4paSIOKWgOKWiOKWkgovL+KWkuKWiOKWiOKWgOKWgOKWiOKWiOKWkeKWk+KWiOKWiCAg4paS4paI4paI4paR4paT4paI4paIICDiloDilogg4paI4paI4paS4paS4paI4paI4paR4paE4paE4paE4paRCi8v4paR4paT4paIIOKWkeKWiOKWiCDilpPilpPiloggIOKWkeKWiOKWiOKWkeKWk+KWiOKWiOKWkiAg4paQ4paM4paI4paI4paS4paR4paT4paIICDilojilojilpMKLy/ilpHilpPilojilpLilpHilojilojilpPilpLilpLilojilojilojilojilojilpMg4paS4paI4paI4paRICAg4paT4paI4paI4paR4paR4paS4paT4paI4paI4paI4paA4paSCi8vIOKWkiDilpHilpHilpLilpHilpLilpHilpLilpPilpIg4paSIOKWkiDilpEg4paS4paRICAg4paSIOKWkiAg4paR4paSICAg4paSCi8vIOKWkiDilpHilpLilpEg4paR4paR4paR4paS4paRIOKWkSDilpEg4paRIOKWkeKWkSAgIOKWkSDilpLilpEgIOKWkSAgIOKWkQovLyDilpEgIOKWkeKWkSDilpEg4paR4paR4paRIOKWkSDilpEgICAg4paRICAg4paRIOKWkSDilpEg4paRICAg4paRCi8vIOKWkSAg4paRICDilpEgICDilpEgICAgICAgICAgICAgIOKWkSAgICAgICDilpE=