#include using namespace std; typedef long long int ll; const int N=1e6+10; vector f(N,1), inf(N,1); ll mod=1e9+7; ll inv_mod(ll a, ll b){ ll x=0, y=1, r, q, ta=a; while(b){ r=a%b; q=a/b; a=b; b=r; r=x; x=y; y=r-q*y; } x+=ta; return x%ta; } int main(){ for(int i=1; i>str; n = str.length(); vector> a(n+1,vector(26,0)); vector cnt(26,0); for(int i=0; i>q; while(q--){ int l,r; cin>>l>>r; vector tmp(26,0); for(int i=0; i<26; i++) tmp[i]=a[r][i]-a[l-1][i]; int ln=0, p=0; for(int i=0; i<26; i++){ ln+=(tmp[i]>>1); p+=(tmp[i]&1); } ll ans=f[ln]; for(int i=0; i<26; i++){ ans=ans*inf[tmp[i]>>1]%mod; } if(p) ans=ans*p%mod; cout<