/* assets/css/productos.css */

/* Estilos específicos para la columna del menú de categorías */
.menu-categorias-col {
    padding: 20px;
    background-color: #f9f9f9; /* Fondo ligero para el menú */
    border-radius: 8px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
}

.menu-categorias-col h2 {
    color: #333;
    font-size: 30px;
    margin-bottom: 15px;
    border-bottom: 2px solid #eee;
    padding-bottom: 10px;
}

.lista-categorias-menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

/* El LI ahora es solo un contenedor del A, los estilos principales van en el A */
.lista-categorias-menu li {
    margin-bottom: 10px; /* Espacio entre los ítems de la lista */
}

/* Estilos para el elemento de anclaje (<a>) dentro del li */
.lista-categorias-menu li .categoria-item { /* Apunta al <a> con la clase .categoria-item */
    text-decoration: none;
    color: #555;
    font-size: 20px; /* Tamaño de fuente para el texto del enlace */
    display: block; /* Para que ocupe todo el ancho del li y el padding/hover sea más fácil */
    padding: 8px 12px 5px 12px; /* top | right | bottom | left */
    position: relative; /* Necesario para posicionar el ::before */
    overflow: hidden; /* Asegura que la línea se mantenga dentro de los límites del enlace */
    font-weight: 500; /* Peso de fuente normal */
    line-height: 22px; /* Ajustado a píxeles. Puede experimentar con este valor (ej. 20px, 21px, etc.) */
    transition: color 0.3s ease, transform 0.3s ease-out, font-weight 0.3s ease; /* Transición suave para color, línea y peso de fuente */
    cursor: pointer; /* Cambia el cursor a puntero */
    text-align: center; /* Alinea el texto en el centro del enlace */
}

/* Pseudo-elemento ::before para la línea (AHORA ES HIJO DEL <a>) */
.lista-categorias-menu li .categoria-item::before {
    content: '';
    position: absolute;
    bottom: 0; /* La línea se pega al bottom del padding */
    /* MODIFICADO: Ancho al 80% y centrado */
    width: 100%; /* Ancho de la línea al 80% del contenedor del <a> */
    left: 50%; /* Inicia en el 50% del contenedor */
    transform: translateX(-50%) translateX(-100%); /* Primero centra, luego mueve fuera de vista */
    height: 2px; /* Grosor de la línea */
    background-color: #000; /* Color de la línea */
    transition: transform 0.3s ease-out; /* Transición para que aparezca */
}

/* Estilos para el estado HOVER y ACTIVE del enlace */
.lista-categorias-menu li .categoria-item:hover { /* Solo hover en azul */
    color: #000; /* Cambia el color del texto al pasar el ratón */
    font-weight: 700; /* Pone el texto en negrita (valor 700 es negrita) */
}

.lista-categorias-menu li .categoria-item.active { /* MODIFICADO: Color negro para activo */
    color: #000; /* Color del texto cuando la categoría está activa (negro) */
    font-weight: 700; /* Pone el texto en negrita (valor 700 es negrita) */
}


/* Efecto de deslizamiento de la línea para HOVER y ACTIVE */
.lista-categorias-menu li .categoria-item:hover::before,
.lista-categorias-menu li .categoria-item.active::before {
    /* MODIFICADO: Solo la segunda parte del transform para que se deslice al centro */
    transform: translateX(-50%) translateX(0); /* Desliza la línea a la vista (centrada) */
}

/* Estilos para el contenedor grid de los productos */
.productos-grid {
    display: grid; /* ¡CLAVE! Hacemos que este sea un contenedor de grid */
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); /* Columnas responsivas */
    gap: 25px; /* Espacio entre las tarjetas de producto */
    padding: 0; /* Asegurarse de que no haya padding adicional que estorbe */
}

/* Mensaje de "No hay productos" */
.no-data-message {
    grid-column: 1 / -1; /* Ocupa todas las columnas del grid */
    text-align: center;
    padding: 40px;
    font-size: 20px;
    color: #777;
    background-color: #f0f0f0;
    border-radius: 10px;
    margin-top: 30px;
}


/* Responsive para el menú de categorías y el grid de productos */
@media (max-width: 992px) {
    .menu-categorias-col {
        width: 100%;
        padding: 15px;
    }
    
    .menu-categorias-col h2 {
        text-align: center;
        font-size: 24px;
    }

    .lista-categorias-menu {
        display: flex; /* Convierte el menú en horizontal */
        flex-wrap: wrap; 
        justify-content: center; 
        gap: 10px; 
    }

    .lista-categorias-menu li {
        margin-bottom: 0; /* No hay margen inferior si están en fila */
    }

    /* Ajuste de fuente para el enlace en pantallas medianas */
    .lista-categorias-menu li .categoria-item {
        font-size: 18px; /* Un poco más pequeño en pantallas medianas */
        line-height: 20px; /* Ajustado a píxeles */
        padding: 8px 12px 5px 12px; /* Ajuste de padding inferior también en responsive */
    }

    .productos-grid {
        grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); 
        gap: 20px;
    }
}

@media (max-width: 600px) { 
    .menu-categorias-col {
        padding: 10px;
    }
    
    .menu-categorias-col h2 {
        font-size: 20px;
    }

    .lista-categorias-menu {
        flex-direction: column; /* Vuelve a columna en pantallas pequeñas */
        align-items: stretch; /* Se estiran para ocupar el ancho disponible */
    }
    /* La línea del hover puede ser más sutil en móviles o se mantiene */
    .lista-categorias-menu li .categoria-item::before {
        height: 1px; /* Línea más fina en móviles */
    }

    /* Asegurar que el tamaño de fuente se vea bien en columnas apiladas */
    .lista-categorias-menu li .categoria-item {
        font-size: 19px;
        line-height: 21px;
        padding: 10px 12px 6px 12px; /* Ajuste de padding inferior también en responsive */
    }

    .productos-grid {
        grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); 
        gap: 15px;
    }
}