Bep20 contract maxwallet

A simple contract that I will add liquidity and use to trade. I added the _maxWalletToken value as an extra. Do you think it makes sense? What are the points, security vulnerabilities, etc. that I will have problems with?
Best regards

pragma solidity ^0.8.2;

contract CarrotNetwork {
    mapping(address => uint) public balances;
    mapping(address => mapping(address => uint)) public allowance;
    uint public totalSupply = 15000000 * 10 ** 18;
    string public name = "CarrotNetwork";
    string public symbol = "CARROT";
    uint public decimals = 18;
    uint256 public _maxWalletToken = 45 * 10**4 * 10**18;
    event Transfer(address indexed from, address indexed to, uint value);
    event Approval(address indexed owner, address indexed spender, uint value);
    constructor() {
        balances[msg.sender] = totalSupply;
        emit Transfer(address(0), msg.sender, totalSupply);
    function balanceOf(address owner) public returns(uint) {
        return balances[owner];
    function transfer(address to, uint value) public returns(bool) {
        require(balanceOf(msg.sender) >= value, 'balance too low');
                balances[to] + value <= _maxWalletToken,
                "Exceeds maximum wallet token amount (450,000)"
        balances[to] += value;
        balances[msg.sender] -= value;
       emit Transfer(msg.sender, to, value);
             return true;
    function transferFrom(address from, address to, uint value) public returns(bool) {
        require(balanceOf(from) >= value, 'balance too low');
        require(allowance[from][msg.sender] >= value, 'allowance too low');
        balances[to] += value;
        balances[from] -= value;
        emit Transfer(from, to, value);
        return true;   
    function approve(address spender, uint value) public returns (bool) {
        allowance[msg.sender][spender] = value;
        emit Approval(msg.sender, spender, value);
        return true;