#include using namespace std; #define SIZE 100005 #define ll long long #define rep(i,n) for(int i=0;i T extgcd(T a, T b, T& x, T& y) { for (T u = y = 1, v = x = 0; a;) { T q = b / a; swap(x -= q * u, u); swap(y -= q * v, v); swap(b -= q * a, a); } return b; } template T mod_inv(T a, T m) { T x, y; extgcd(a, m, x, y); return (m + x % m) % m; } ll mod_pow(ll a, ll n, ll mod) { ll ret = 1; ll p = a % mod; while (n) { if (n & 1) ret = ret * p % mod; p = p * p % mod; n >>= 1; } return ret; } ll garner(vectorb, vectorm, ll mod){ b.emplace_back(0); m.emplace_back(mod); vector coffs(b.size(), 1); vector constants(b.size(), 0); for(int i=0;i(coffs[i], m[i]) % m[i]; if (v < 0) v += m[i]; for (int j = i + 1; j < b.size(); j++) { (constants[j] += coffs[j] * v) %= m[j]; (coffs[j] *= m[i]) %= m[j]; } } return constants[b.size() - 1]; } ll gcd(ll a, ll b){ if(a &b, vector &m, ll MOD) { for (int i = 0; i < b.size(); i++) { for (int j = 0; j < i; j++) { ll g = gcd(m[i], m[j]); if ((b[i] - b[j]) % g != 0) return -1; m[i] /= g, m[j] /= g; ll gi = gcd(m[i], g), gj = g / gi; do { g = gcd(gi, gj); gi *= g, gj /= g; } while (g != 1); m[i] *= gi, m[j] *= gj; b[i] %= m[i], b[j] %= m[j]; } } ll res = 1; for (int i = 0; i < b.size(); i++) (res *= m[i]) %= MOD; return res; } /////// vectorB,M; int n; int main(){ cin >> n; rep(i,n){ ll a,b; cin >> a >> b; B.pb(a); M.pb(b); } ll ret = preGarner(B,M,1000000007LL); rep(i,n) if(B[i] > 0) goto nxt; cout << ret << endl; return 0; nxt:; if(ret == -1) cout << "-1" << endl; else{ cout << garner(B,M,1000000007LL) << endl; } }