// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

contract ArbitParagon {
&nbsp;&nbsp;&nbsp; address public owner;
&nbsp;&nbsp;&nbsp; address public companyWallet;
&nbsp;&nbsp;&nbsp; 
&nbsp;&nbsp;&nbsp; uint256 public referralCommission = 5; // 5% referral commission
&nbsp;&nbsp;&nbsp; uint256 public binaryCommission = 10; // 10% binary commission
&nbsp;&nbsp;&nbsp; uint256 public monthlyProfit = 6; // 6% monthly profit
&nbsp;&nbsp;&nbsp; uint256 public withdrawalFee = 3; // 3% withdrawal fee
&nbsp;&nbsp;&nbsp; uint256 public maxBinaryDaily = 10000 * 10**18; // $10000 max binary daily commission
&nbsp;&nbsp;&nbsp; uint256 public goldenRewardVolume = 300000 * 10**18; // $300,000 for Golden Reward

&nbsp;&nbsp;&nbsp; struct User {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; address wallet;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uint256 totalDeposit;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uint256 totalWithdraw;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uint256 leftVolume;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uint256 rightVolume;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uint256 referralCommissionEarned;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uint256 binaryCommissionEarned;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uint256 goldenRewardEarned;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uint256 nextMonthlyWithdraw;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uint256 nextCommissionWithdraw;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uint256 lastBinaryResetTime;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uint256 totalBinaryWithdrawn;
&nbsp;&nbsp;&nbsp; }

&nbsp;&nbsp;&nbsp; mapping(address =&gt; User) public users;
&nbsp;&nbsp;&nbsp; mapping(address =&gt; address) public referrals; // Wallet -&gt; referrer
&nbsp;&nbsp;&nbsp; mapping(address =&gt; bool) public activeUsers;

&nbsp;&nbsp;&nbsp; event Deposit(address indexed user, uint256 amount);
&nbsp;&nbsp;&nbsp; event Withdraw(address indexed user, uint256 amount, string category);
&nbsp;&nbsp;&nbsp; event GoldenRewardEarned(address indexed user, uint256 reward);

&nbsp;&nbsp;&nbsp; modifier onlyOwner() {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; require(msg.sender == owner, &quot;Only owner can perform this action&quot;);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; _;
&nbsp;&nbsp;&nbsp; }

&nbsp;&nbsp;&nbsp; constructor(address _companyWallet) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; owner = msg.sender;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; companyWallet = _companyWallet;
&nbsp;&nbsp;&nbsp; }

&nbsp;&nbsp;&nbsp; // Function to activate user with referral
&nbsp;&nbsp;&nbsp; function activateUser(address referrer) external payable {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; require(!activeUsers[msg.sender], &quot;User already active&quot;);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; require(msg.value &gt;= 150 * 10**18, &quot;Minimum activation fee is $150&quot;);

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; activeUsers[msg.sender] = true;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; referrals[msg.sender] = referrer;

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; // Add volumes for binary tree
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; if (users[referrer].leftVolume == 0) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; users[referrer].leftVolume += msg.value;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; } else {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; users[referrer].rightVolume += msg.value;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; emit Deposit(msg.sender, msg.value);
&nbsp;&nbsp;&nbsp; }

&nbsp;&nbsp;&nbsp; // Function to deposit funds for investment
&nbsp;&nbsp;&nbsp; function deposit() external payable {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; require(activeUsers[msg.sender], &quot;User is not active&quot;);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; require(msg.value &gt;= 100 * 10**18, &quot;Minimum deposit is $100&quot;);

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uint256 commission = (msg.value * referralCommission) / 100;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; address referrer = referrals[msg.sender];

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; users[referrer].referralCommissionEarned += commission;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; users[msg.sender].totalDeposit += (msg.value - commission);

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; emit Deposit(msg.sender, msg.value);
&nbsp;&nbsp;&nbsp; }

&nbsp;&nbsp;&nbsp; // Function to withdraw funds
&nbsp;&nbsp;&nbsp; function withdraw(string memory category, uint256 amount) external {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; require(activeUsers[msg.sender], &quot;User is not active&quot;);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; require(amount &gt; 0, &quot;Withdraw amount must be greater than zero&quot;);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uint256 fee = (amount * withdrawalFee) / 100;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uint256 netAmount = amount - fee;

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; if (keccak256(abi.encodePacked(category)) == keccak256(abi.encodePacked(&quot;profit&quot;))) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; require(
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; block.timestamp &gt;= users[msg.sender].nextMonthlyWithdraw,
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &quot;Monthly withdrawal not allowed yet&quot;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; );
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; users[msg.sender].nextMonthlyWithdraw = block.timestamp + 30 days;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; } else if (keccak256(abi.encodePacked(category)) == keccak256(abi.encodePacked(&quot;commission&quot;))) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; require(
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; block.timestamp &gt;= users[msg.sender].nextCommissionWithdraw,
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &quot;Commission withdrawal not allowed yet&quot;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; );
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; users[msg.sender].nextCommissionWithdraw = block.timestamp + 20 days;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; } else if (keccak256(abi.encodePacked(category)) == keccak256(abi.encodePacked(&quot;binary&quot;))) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; require(users[msg.sender].binaryCommissionEarned &gt;= amount, &quot;Not enough binary commission&quot;);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; users[msg.sender].binaryCommissionEarned -= amount;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; users[msg.
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
contract ArbitParagon {
address public owner;
address public companyWallet;
uint256 public referralCommission = 5; // 5% referral commission
uint256 public binaryCommission = 10; // 10% binary commission
uint256 public monthlyProfit = 6; // 6% monthly profit
uint256 public withdrawalFee = 3; // 3% withdrawal fee
uint256 public maxBinaryDaily = 10000 * 10**18; // $10000 max binary daily commission
uint256 public goldenRewardVolume = 300000 * 10**18; // $300,000 for Golden Reward
struct User {
address wallet;
uint256 totalDeposit;
uint256 totalWithdraw;
uint256 leftVolume;
uint256 rightVolume;
uint256 referralCommissionEarned;
uint256 binaryCommissionEarned;
uint256 goldenRewardEarned;
uint256 nextMonthlyWithdraw;
uint256 nextCommissionWithdraw;
uint256 lastBinaryResetTime;
uint256 totalBinaryWithdrawn;
}
mapping(address => User) public users;
mapping(address => address) public referrals; // Wallet -> referrer
mapping(address => bool) public activeUsers;
event Deposit(address indexed user, uint256 amount);
event Withdraw(address indexed user, uint256 amount, string category);
event GoldenRewardEarned(address indexed user, uint256 reward);
modifier onlyOwner() {
require(msg.sender == owner, "Only owner can perform this action");
_;
}
constructor(address _companyWallet) {
owner = msg.sender;
companyWallet = _companyWallet;
}
// Function to activate user with referral
function activateUser(address referrer) external payable {
require(!activeUsers[msg.sender], "User already active");
require(msg.value >= 150 * 10**18, "Minimum activation fee is $150");
activeUsers[msg.sender] = true;
referrals[msg.sender] = referrer;
// Add volumes for binary tree
if (users[referrer].leftVolume == 0) {
users[referrer].leftVolume += msg.value;
} else {
users[referrer].rightVolume += msg.value;
}
emit Deposit(msg.sender, msg.value);
}
// Function to deposit funds for investment
function deposit() external payable {
require(activeUsers[msg.sender], "User is not active");
require(msg.value >= 100 * 10**18, "Minimum deposit is $100");
uint256 commission = (msg.value * referralCommission) / 100;
address referrer = referrals[msg.sender];
users[referrer].referralCommissionEarned += commission;
users[msg.sender].totalDeposit += (msg.value - commission);
emit Deposit(msg.sender, msg.value);
}
// Function to withdraw funds
function withdraw(string memory category, uint256 amount) external {
require(activeUsers[msg.sender], "User is not active");
require(amount > 0, "Withdraw amount must be greater than zero");
uint256 fee = (amount * withdrawalFee) / 100;
uint256 netAmount = amount - fee;
if (keccak256(abi.encodePacked(category)) == keccak256(abi.encodePacked("profit"))) {
require(
block.timestamp >= users[msg.sender].nextMonthlyWithdraw,
"Monthly withdrawal not allowed yet"
);
users[msg.sender].nextMonthlyWithdraw = block.timestamp + 30 days;
} else if (keccak256(abi.encodePacked(category)) == keccak256(abi.encodePacked("commission"))) {
require(
block.timestamp >= users[msg.sender].nextCommissionWithdraw,
"Commission withdrawal not allowed yet"
);
users[msg.sender].nextCommissionWithdraw = block.timestamp + 20 days;
} else if (keccak256(abi.encodePacked(category)) == keccak256(abi.encodePacked("binary"))) {
require(users[msg.sender].binaryCommissionEarned >= amount, "Not enough binary commission");
users[msg.sender].binaryCommissionEarned -= amount;
}
users[msg.