#include <bits/stdc++.h>
using namespace std;
using ll = long long;
static const ll MOD = 1e9 + 7;
int main() {
  cin.tie(0);
  ios::sync_with_stdio(false);
  ll n;
  cin >> n;
  vector<vector<ll>> dp(65, vector<ll>(3, 0));
  dp[64][0] = 1;
  for (ll i = 63; i >= 0; i--) {
    if (n & (1LL << i)) {
      dp[i][0] += dp[i + 1][0];
      dp[i][1] += dp[i + 1][0] + dp[i + 1][1];
      dp[i][2] += 2 * dp[i + 1][1] + 3 * dp[i + 1][2];
    } else {
      dp[i][0] += dp[i + 1][0] + dp[i + 1][1];
      dp[i][1] += dp[i + 1][1];
      dp[i][2] += dp[i + 1][1] + 3 * dp[i + 1][2];
    }
    dp[i][0] %= MOD;
    dp[i][1] %= MOD;
    dp[i][2] %= MOD;
  }
  cout << (dp[0][0] + dp[0][1] + dp[0][2]) % MOD << '\n';
}