.menu-icon{
    display: none;
}


/* RESET Y BASE */
.header-main {
    /* background: #cf2626; */
    /* border-bottom: 3px solid var(--verde); */
    padding: 1em;
}

.header-container {
    display: flex;
    align-items: stretch; /* Esto hace que el logo y la zona nav tengan el mismo alto */
    justify-content: space-between;
}

/* AREA LOGO */
.logo-area {
    display: flex;
    align-items: center;
    cursor: pointer;
    /* flex: 0 0 250px; */ /* Ancho fijo para el logo */
}

.logo-area img {
    max-height: 7em; /* Ajusta según el tamaño de tu logo */
    width: auto;
}

/* AREA NAVEGACIÓN (DERECHA) */
.nav-area {
    display: flex;
    flex-direction: column;
    justify-content: space-between; /* Botón arriba, Menú abajo */
    align-items: flex-end; /* Todo alineado a la derecha */
    flex: 1;
}
.top-row{
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    width: 100%;
}


/* BOTÓN SOY ASOCIADO */
.utilidadesBox ul { list-style: none; margin: 0; padding: 0; }
.utilidadesBox a {
    background-color: var(--verde);
    color: #fff;
    padding: 8px 20px;
    border-radius: 25px;
    text-decoration: none;
    font-weight: bold;
    font-size: 14px;
    transition: 0.3s;
    display: inline-block;
}
.utilidadesBox a:hover { background-color: var(--verde-oscuro); }

/* AJUSTE MENU.PHP */
.navbar { background: transparent; } /* Quitamos el verde de fondo aquí para que se vea blanco */
.navbar-menu { display: flex; gap: 5px; align-items: center; }
.navbar a {
    color: #173a5b !important;
    padding: 10px 15px;
    font-weight: 700;
    font-size: 0.9em;
    transition: all 0.5s;
}
.navbar a:hover { 
    color: var(--verde-oscuro) !important; 
    background-color: #fff;
    border-radius: 5px;
    padding: 10px 15px;
     
}

/* RESPONSIVE MÓVIL (< 800px) */
@media screen and (max-width: 800px) {
    .header-container {
        flex-direction: row; /* Mantenemos logo y hamburguesa en línea */
        align-items: center;
        height: 70px;
    }

    .nav-area {
        flex-direction: row;
        justify-content: flex-end;
        align-items: center;
    }

    .top-row { display: none; } /* Ocultamos el botón en móvil para no saturar */

    .navbar-menu {
        position: fixed;
        top: 70px;
        left: -100%; /* Menú oculto a la izquierda */
        width: 90%;
        height: calc(100vh - 70px);
        background: var(--verde);
        flex-direction: column;
        transition: 0.4s;
        box-shadow: 5px 0 15px rgba(0,0,0,0.1);
        padding-top: 20px;
        z-index: 9999;
    }

    .navbar-menu.active { left: 0; top: 0;height: 100%; } /* Entra desde la izquierda */
    
    .menu-icon { display: block; color: var(--verde); font-size: 28px; }
}


/* Escritorio */
.dropdown-content.single-column {
    min-width: 250px;
    display: none;
    flex-direction: column;
}

.dropdown-content.multi-column {
    display: none;
    grid-template-columns: repeat(2, 1fr);
    width: 500px;
}

.dropdown:hover > .dropdown-content {
    display: flex; /* Para single-column */
}
.dropdown:hover > .dropdown-content.multi-column {
    display: grid; /* Para multi-column */
}

.dropdown-content a {
    color: #173a5b !important;
    padding: 10px 15px;
    font-weight: 700;
    font-size: 0.9em;
    transition: all 0.5s;
    border-bottom: 1px solid #4893e380;
}

/* Limpieza de subniveles en escritorio */
.dropdown-content {
    display: none;
    position: absolute;
    background-color: #fff;
    min-width: 250px;
    box-shadow: 0px 8px 16px rgba(0,0,0,0.1);
    z-index: 999;
    padding: 0px 0;
    flex-direction: column; /* Una columna por defecto */
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px;
    top: 145px;
}

/* Solo si la clase multi-column está presente (inyectada por PHP > 15 items) */
.dropdown-content.multi-column {
    display: none; 
    grid-template-columns: repeat(2, 1fr);
    width: 550px;
}

.dropdown:hover > .dropdown-content { display: flex; }
.dropdown:hover > .dropdown-content.multi-column { display: grid; }

/* REVISIÓN MOBILE: Tipo Acordeón */
@media screen and (max-width: 800px) {
    .navbar-menu {
        flex-direction: column;
        height: auto;
        top: 0;
        height: 100%;
    }
    
    .dropdown-content {
        position: relative; /* Empuja el contenido hacia abajo */
        /* width: 100% !important; */
        display: none; /* Se activa con la clase .open */
        /* box-shadow: none; */
        background: #f1f1f1;
        /* padding-left: 15px; */
    }

    .dropdown.open > .dropdown-content {
       display: flex!important;
    }
}