#include using namespace std; int main() { int N, M, K; cin>> N >> M >> K; vector> LR(M); vector> dp(3001, vector(3001, -1)); for (int i = 0; i < M; i++) { int a, b; cin >> a >> b; LR[i] = make_pair(a, b); } sort(LR.begin(), LR.end()); for (int i = 0; i < M; i++) dp[K][i] = (N <= LR[i].second) ? 1 : 0; auto solve = [&](auto f, int k, int m) { if (dp[k][m] >= 0) return dp[k][m]; long long r = 0LL; for (int i = 0; i < upper_bound(LR.begin(), LR.end(), make_pair(LR[m].second, 0)) - LR.begin(); i++) if (min(LR[m].second, LR[i].second) >= max(LR[m].first, LR[i].first)) r = (r + f(f, k + 1, i) * (min(LR[m].second, LR[i].second) - max(LR[m].first, LR[i].first) + 1) % 1000000007) % 1000000007; dp[k][m] = r; return r; }; long long r = 0; for (int i = 0; i < M; i++) if (1 >= LR[i].first) r = (r + solve(solve, 1, i)) % 1000000007; cout << r << endl; return 0; }