
#include <bits/stdc++.h>
using namespace std;
#define ll long long
const ll UM = 1, MOD = 1e9 + 7;
ll dp[65][3];
int main() {
  ll n;
  cin >> n;
  dp[63][0] = 1;
  dp[63][1] = 0;
  dp[63][2] = 0;
  for (ll i = 62; i >= 0; i--) {
    ll bit_N = (n & (UM << i));
    if (bit_N == 0LL) {
      dp[i][0] = dp[i + 1][0] + dp[i + 1][1];
      dp[i][1] = dp[i + 1][1];
      dp[i][2] = 3LL * dp[i + 1][2] + dp[i + 1][1];
    } else {
      dp[i][0] = dp[i + 1][0];
      dp[i][1] = dp[i + 1][1] + dp[i + 1][0];
      dp[i][2] = 3LL * dp[i + 1][2] + 2LL * dp[i + 1][1];
    }
    for (int j = 0; j < 3; j++)
      dp[i][j] = dp[i][j] % MOD;
  }
  ll ans = (dp[0][0] + dp[0][1] + dp[0][2]) % MOD;
  cout << ans << endl;
}