:root {
    --themeColorA: #5A2582;
    --themeColorHover: #453571;
    --color-red: #ff0000;
    --hover-color-red: #cc0000;
    --font-small: 14px;
    --weight-normal: 400;
    --weight-bold: 700;
    --gradient-yellow: linear-gradient(to right, #ffcc00, #ff9900);
    --index-menu: 1000;
}

/* HEADER */
.main_header {
    color: var(--themeColorA);
    background-color: var(--themeColorA);
    position: sticky;
    top: 0;
    height: 70px; /* Altura fixa para desktop */
    z-index: 10;
    border-bottom: 1px solid #eeeeee;
}

.main_header .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%; /* Garante que o container ocupe a altura total do header */
}

/* Logo */
.main_header_logo img {
    padding: 7px 20px 20px 20px;
    width: 180px;
    max-width: 100%;
}

.main_header_logo img a {
    cursor: pointer;
}

/* Nav */
.main_header_nav {
    display: flex; /* Layout flexbox para os itens de navegação */
    align-items: center;
    margin-top: 20px;
    gap: 10px; /* Espaçamento entre os elementos diretos da nav */
}

/* O span que contém os botões mobile - OCULTO NO DESKTOP */
.main_header_nav .mobile-buttons-wrapper {
    display: none;
}

.main_header_nav_links {
    display: block !important;
    margin-top: -30px;
}

.main_header_nav_links .link {
    display: inline-block;
    padding: 6px 12px;
    text-decoration: none;
    color: #ffffff;
    font-weight: var(--weight-normal);
    font-size: var(--font-small);
}

.main_header_nav_links .link:hover {
    background: var(--themeColorHover);
    color: #ffffff;
}

.main_header_nav_links .login {
    background: var(--themeColorA);
    color: #ffffff;
    font-weight: var(--weight-normal);
}

.main_header_nav_links .login:hover {
    background: var(--themeColorHover);
}

/* Mobile */
.main_header_nav_mobile,
.main_header_nav_mobile_close {
    display: none;
}

@media (max-width: 62em) {
    .main_header {
        height: auto; /* Permite que a altura do cabeçalho se ajuste ao conteúdo no mobile */
        padding: 0; /* Remove padding que possa conflitar com o container */
    }

    .main_header .container {
        /* Garante que o container flex esteja ativo para layout logo esquerda / botões direita */
        /* As propriedades display, align-items, justify-content já vêm da regra global */
        padding: 10px 20px; /* Adiciona padding interno para respiro do conteúdo */
    }

    .main_header_logo {
        /* A logo estará à esquerda devido ao justify-content: space-between do container */
        margin-top: 0;
        margin-bottom: 0;
        text-align: left; /* Garante que a imagem dentro do logo div se alinhe à esquerda */
    }

    .main_header_logo img {
        padding: 0;
        width: 150px; /* Ajusta o tamanho da logo para mobile */
        max-width: 100%;
        height: auto;
    }

    /* Ajustes para a área de navegação (que contém os botões mobile) */
    .main_header_nav {
        /* Ocupa o espaço restante e é alinhado à direita pelo container flex */
        display: block; /* Não precisa ser um flex container em si, o wrapper faz isso */
        margin-top: 0;
        gap: 0;
        /* Remove width: 100% e justify-content: center que centralizava os botões no mobile anterior */
    }

    /* Exibe e organiza os botões dentro do wrapper no mobile */
    .main_header_nav .mobile-buttons-wrapper {
        display: flex; /* Torna o wrapper flex para organizar os botões */
        flex-direction: column; /* Empilha os botões verticalmente */
        align-items: flex-end; /* Alinha os botões à direita dentro do wrapper */
        gap: 5px; /* Espaço vertical entre os botões */
        flex-wrap: nowrap; /* Evita quebra de linha desnecessária para coluna */
    }

    /* Os links individuais que são os botões mobile */
    .main_header_nav .mobile_menu {
        display: block; /* Garante que ocupem a largura e empilhem */
        padding: 4px 8px; /* Ajusta padding para um visual mais compacto */
        text-decoration: none;
        text-transform: uppercase;
        font-weight: var(--weight-bold);
        font-size: var(--font-small);
        border: 1px solid var(--themeColorA);
        background: var(--themeColorA);
        color: #ffffff;
        white-space: nowrap; /* Impede que o texto quebre dentro do botão */
    }

    .main_header_nav .mobile_menu:hover {
        background: var(--themeColorHover);
        color: #ffffff;
    }

    /* Oculte o menu slide-out por padrão no mobile */
    .main_header_nav_links {
        display: none !important; /* Esconde o menu principal no mobile, ele será exibido por JS */
        position: fixed;
        z-index: var(--index-menu);
        left: 100%;
        top: 0;
        background: #ffffff;
        width: 300px;
        height: 100%;
        max-width: 80%;
        padding: 20px;
        border-left: 1px solid var(--themeColorA);
        margin-top: 0; /* Remove margem superior negativa que afetaria o layout */
    }

    /* Estilos para os links do menu mobile quando visíveis */
    .main_header_nav_links .login,
    .main_header_nav_links .link {
        background: none;
        display: block;
        color: #555555;
        padding: 10px;
        transition-duration: 0s;
    }

    .main_header_nav_links .link:hover {
        color: #ffffff;
        background: #ffffff;
        background-image: var(--gradient-yellow);
    }
}