﻿/* Selecciona cualquier td que tenga un ID que contenga 'NavigationMenun' */
td[id*="NavigationMenun"] a {
    padding-top: 25px;
    margin: 5px;
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 25px;
    font-size: 12px;
    display: block; /* Asegura que el padding y background funcionen bien */
}

td#ctl00_NavigationMenun0 a {
    background-image: url(../Images/home.png);
}

td#ctl00_NavigationMenun1 a {
    background-image: url(../Images/user.svg);
}

td#ctl00_NavigationMenun2 a {
    background-image: url(../Images/admin.png);
}

td#ctl00_NavigationMenun3 a {
    background-image: url(../Images/pendientes.png);
}
td#ctl00_NavigationMenun4 a {
    background-image: url(../Images/agenda.png);
}

td#ctl00_NavigationMenun5 a {
    background-image: url(../Images/personal.png);
}

td#ctl00_NavigationMenun6 a {
    background-image: url(../Images/organizacion.png);
}

td#ctl00_NavigationMenun7 a {
    background-image: url(../Images/parametros.png);
}

td#ctl00_NavigationMenun8 a {
    background-image: url(../Images/reportes.png);
}

td#ctl00_NavigationMenun9 a {
    background-image: url(../Images/masivos.svg);
}

td#ctl00_NavigationMenun10 a {
    background-image: url(../Images/training.svg);
}

td#ctl00_NavigationMenun11 a {
    background-image: url(../Images/herramientas.svg);
}

td#ctl00_NavigationMenun12 a {
    background-image: url(../Images/config.svg);
}

td#ctl00_NavigationMenun13 a {
    background-image: url(../Images/visitantes.png);
}

td#ctl00_NavigationMenun14 a {
    background-image: url(../Images/casino.svg);
}


/* MÓVIL (Menos de 1200px) */
@media (max-width: 1199.98px) {
    .navbar-nav-custom td {
        display: flex !important; /* Alinea hijos en fila */
        flex-direction: row !important;
        align-items: center !important; /* Centra verticalmente */
        justify-content: space-between !important; /* Texto izquierda, flecha derecha */
        width: 100% !important;
        border-bottom: 1px solid rgba(255,255,255,0.1); /* Línea divisoria aquí */
        position: relative !important;
    }

    /* 2. El Enlace ya NO necesita justify-content porque el padre (TD) lo hace */
    td[id*="NavigationMenun"] a {
        display: block !important;
        flex-grow: 1; /* Ocupa todo el espacio para ser clickeable */
        padding-top: 12px !important;
        padding-bottom: 12px !important;
        padding-left: 50px !important; /* Espacio para el icono de fondo */
        background-position: 15px center !important;
        background-size: 20px !important;
        text-align: left !important;
        border-bottom: none !important; /* Quitamos el borde de aquí */
        margin: 0 !important;
    }

    /* 3. La imagen ahora se portará bien a la derecha */
    #navbarNav td img {
        display: none !important;
        position: static !important; /* Por si acaso */
        width: 12px !important;
        height: 12px !important;
        margin-right: 15px !important; /* Separación del borde derecho */
        padding: 0 !important;
        background: transparent !important; /* Quita el naranja de prueba */
        order: 2; /* Asegura que sea el último elemento */
    }

    /* Forzamos que la tabla se comporte como bloque para apilarse */
    .navbar-nav-custom table,
    .navbar-nav-custom tbody,
    .navbar-nav-custom tr {
        width: 100% !important;
    }

    /* 2. Ajuste del Submenú (el DIV que aparece al dar clic) */
    #navbarNav div.menu {
        position: absolute !important;
        right: 100% !important; /* ¡Clave! Se posiciona justo donde termina el padre a la izquierda */
        left: auto !important; /* Anulamos cualquier left previo */
        width: 220px !important; /* Dale un ancho fijo para que no colapse */
        margin-right: 2px; /* Pequeña separación estética del menú principal */
        background-color: #E3F2FD !important;
        box-shadow: -5px 5px 10px rgba(0,0,0,0.2) !important; /* Sombra hacia la izquierda */
        z-index: 10001;
        overflow: visible !important;
        transition: opacity 0.2s ease-in-out, transform 0.2s ease-out;
        opacity: 0;
        transform: translateX(10px); /* Empieza un poco movido a la derecha */
    }

        /* Creamos el triángulo usando bordes transparentes */
        #navbarNav div.menu::after {
            content: "";
            position: absolute;
            top: -30px; /* Alineado con la parte superior del primer ítem */
            right: -10px; /* Se sale 10px hacia la derecha del submenú */
            width: 0;
            height: 0;
            border-top: 10px solid transparent;
            border-bottom: 10px solid transparent;
            border-left: 10px solid #E3F2FD; /* Debe ser el mismo color de fondo de tu submenú */
            filter: drop-shadow(2px 0px 2px rgba(0,0,0,0.1)); /* Sombra sutil para la flecha */
            z-index: 10002;
        }

        #navbarNav div.menu[style*="block"],
        #navbarNav div.menu[style*="visible"] {
            opacity: 1 !important;
            transform: translateX(0) !important;
        }

    .navbar-collapse {
        margin-top: 5px;
        background-color: #036990;
        width: 100% !important;
        
        float: right;
        margin-left: auto; /* Empuja todo el bloque a la derecha */
    }

    .navbar {
        position: absolute !important;
        right: 0;
        top: 60px;
        z-index: 8000;
    }



    .header .title {
        display: flex;
        align-items: center;
    }

    .loginDisplay button.dropdown-toggle {
        font-size: 14px;
        margin-right: 10px;
        right:0;
    }
}

/* ESCRITORIO (1200px o más) */
@media (min-width: 1200px) {
    /* Forzamos que la tabla principal sea horizontal */
    .navbar-nav-custom > table {
        display: table !important;
        width: auto !important;
        margin: 0 auto;
        border-collapse: separate; /* Permite espaciado entre celdas */
        border-spacing: 10px 0; /* 10px de separación constante entre botones */
    }

        .navbar-nav-custom > table > tbody > tr {
            display: flex !important; /* Aquí obligamos a los TD a ir de lado */
            flex-direction: row !important;
            justify-content: center;
        }

    .navbar-nav-custom td {
        display: block !important;
        width: 90px !important;
        float: left; /* orden de izquierda a derecha */
        padding: 0 !important;
        text-align:center;
    }

    /* Estilo para los submenús (que suelen ser DIVs con clase .menu) */
    .navbar-nav-custom div.menu {
        position: absolute !important;
        z-index: 10000; /* delante de todo */
    }
}

/* --- LIMPIEZA DE ICONOS --- */
/* Tus estilos de td#ctl00_... ya están bien, pero aseguremonos 
   de que no tengan un ancho fijo que rompa el flex */
[id*="NavigationMenun"] {
    width: auto !important;
    min-width: 80px;
}

/* --- ELEMENTOS OCULTOS --- */
#navbarNav .clear.hideSkiplink > a,
[id*="panTitleCommentFilter"] {
    display: none !important;
}

/* Texto de Menú */
#navbarNav a {
    text-decoration: none;
    display: block;
    transition: 0.3s;
    color: white;
}

/* Color del submenú*/
#navbarNav div.menu {
    background-color: #f3f3f3;
    box-shadow: 3px 3px 7px 0px #e4e4e4;
    clip: auto !important;
}

    /* Texto de subMenú */
    #navbarNav div.menu a {
        font-weight: 300;
        color: black;
        padding: 10px;
        padding-left : 30px;
        font-size: 14px;
    }

        #navbarNav div.menu a:hover {
            color: #035c90;
        }

#navbarNav td img {
    background-image: url(../Images/down-arrow.png);
    background-size: contain;
    width: 0;
    padding: 5px;
    display:none;
}

.collapse.navbar-collapse {
    /* CLAVE 1: Debe tener una posición definida para que z-index funcione */
    position: relative;
    /* CLAVE 2: Aseguramos que esté en una capa superior a la tabla */
    z-index: 1000;
}
