#include using namespace std; #define rep(i, n) for (int i = 0; i < n; ++i) typedef long long ll; #define MOD 1000000007 template void add(T &a, T b) { a = (a + b) % MOD; } ll solve(string S) { ll dp[10005][2][3][8][2] = {}; dp[0][0][0][0][0] = 1; int len = S.size(); rep(i, len) rep(j, 2) rep(k, 3) rep(l, 8) rep(m, 2) { int x = j ? 9 : S[i] - '0'; rep(d, x + 1) { add(dp[i + 1][j || d < x][(k + d) % 3][(10 * l + d) % 8][m || d == 3], dp[i][j][k][l][m]); } } ll ans = 0; rep(j, 2) rep(k, 3) rep(l, 8) rep(m, 2) { if (l == 0) continue; if (k == 0 || m) add(ans, dp[len][j][k][l][m]); } return ans; } int main() { string A, B; cin >> A >> B; int a = A[A.size() - 1] - '0'; A = A.substr(0, A.size() - 1); A += ('0' + a - 1); ll ans = solve(B) - solve(A) + MOD; ans %= MOD; cout << ans << endl; return 0; }