import java.io.BufferedReader; import java.io.InputStreamReader; import java.util.ArrayList; import java.util.HashSet; import java.util.List; import java.util.Set; public class Main { public static void main(String[] args) throws Exception { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); String[] sa = br.readLine().split(" "); int n = Integer.parseInt(sa[0]); int m = Integer.parseInt(sa[1]); int k = Integer.parseInt(sa[2]); int max = 301; List> list = new ArrayList<>(max); for (int i = 0; i < max; i++) { list.add(new ArrayList<>()); } Set set = new HashSet<>(); for (int i = 0; i < m; i++) { sa = br.readLine().split(" "); int p = Integer.parseInt(sa[0]); Obj o = new Obj(); o.q = Integer.parseInt(sa[1]); o.c = Integer.parseInt(sa[2]); list.get(p).add(o); set.add(p); } br.close(); int mod = 1000000007; // x個、最後がy、複雑度z long[][][] dp = new long[n][max][k + 1]; for (int y : set) { dp[0][y][0] = 1; } for (int x = 0; x < n - 1; x++) { for (int y : set) { for (Obj next : list.get(y)) { for (int z = 0; z <= k; z++) { if (z + next.c <= k) { dp[x + 1][next.q][z + next.c] += dp[x][y][z]; dp[x + 1][next.q][z + next.c] %= mod; } } } } // for (int y = 0; y < 5; y++) { // for (int z = 0; z <= k; z++) { // System.out.print(dp[x + 1][y][z] + "\t"); // } // System.out.println(); // } // System.out.println(); } long ans = 0; for (int y = 0; y < max; y++) { ans += dp[n - 1][y][k]; } ans %= mod; System.out.println(ans); } static class Obj { int q, c; } }