/* ==========================================================================
   HOJA DE ESTILOS: Inicio Mercarancho (HOME)
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. HERO CAROUSEL
   Descripción: Estilos para el banner principal deslizante de la página de inicio.
   -------------------------------------------------------------------------- */

/* Contenedor principal del carrusel, define la altura y oculta elementos fuera de su área */
.mr-hero-carousel { 
    width: 100%; 
    margin-bottom: 30px; 
    position: relative; 
    height: 380px; 
    overflow: hidden; 
}

/* Pista de desplazamiento horizontal que contiene los elementos del carrusel */
.carousel-track { 
    display: flex; 
    overflow-x: auto; 
    scroll-snap-type: x mandatory; 
    scroll-behavior: smooth; 
    height: 100%; 
    scrollbar-width: none; 
}

/* Oculta la barra de desplazamiento nativa del navegador para una apariencia limpia */
.carousel-track::-webkit-scrollbar { 
    display: none; 
}

/* Cada elemento individual (imagen/banner) dentro del carrusel */
.carousel-slide { 
    flex: 0 0 100%; 
    height: 100%; 
    background-size: cover; 
    background-position: center; 
    scroll-snap-align: start; 
}

/* Contenedor de los puntos de navegación ubicados en la parte inferior del carrusel */
.carousel-dots { 
    position: absolute; 
    bottom: 20px; 
    left: 50%; 
    transform: translateX(-50%); 
    display: flex; 
    gap: 12px; 
    z-index: 100; 
    background: rgba(0,0,0,0.2); 
    padding: 8px 15px; 
    border-radius: 20px; 
}

/* Estilo de cada punto de navegación inactivo */
.dot { 
    width: 12px; 
    height: 12px; 
    border-radius: 50%; 
    background: rgba(255,255,255,0.6); 
    cursor: pointer; 
    transition: all 0.3s ease; 
    border: 1px solid rgba(0,0,0,0.3); 
}

/* Estilo del punto de navegación activo, indicando la diapositiva actual */
.dot.active { 
    background: var(--mr-red) !important; 
    transform: scale(1.3); 
    box-shadow: 0 0 8px rgba(195, 0, 47, 0.6); 
}

/* --------------------------------------------------------------------------
   2. NAVEGACIÓN DE CATEGORÍAS
   Descripción: Enlaces circulares con iconos para filtrado rápido de categorías.
   -------------------------------------------------------------------------- */

/* Contenedor principal que agrupa los enlaces de categorías en un diseño flexible */
.mr-categories-circles { 
    display: flex; 
    justify-content: center; 
    gap: 35px; 
    margin: 40px 0; 
    flex-wrap: wrap; 
}

/* Contenedor individual para cada categoría, alinea icono y texto */
.cat-circle-item { 
    text-decoration: none; 
    display: flex; 
    flex-direction: column; 
    align-items: center; 
    gap: 12px; 
    color: var(--mr-text-dark); 
    font-size: 14px; 
    font-weight: 500; 
}

/* Círculo que contiene la imagen representativa de la categoría */
.cat-icon { 
    width: 85px; 
    height: 85px; 
    border-radius: 50%; 
    display: flex; 
    justify-content: center; 
    align-items: center; 
    box-shadow: 0 4px 10px rgba(0,0,0,0.08); 
    transition: transform 0.2s, box-shadow 0.2s; 
    border: 2px solid transparent; 
    overflow: hidden; 
}

/* Comportamiento de la imagen dentro del círculo */
.cat-icon img { 
    width: 100%; 
    height: 100%; 
    object-fit: cover; 
    border-radius: 50%; 
    transition: transform 0.3s ease; 
}

/* Animaciones y cambios de color al pasar el cursor sobre la categoría */
.cat-circle-item:hover .cat-icon { 
    transform: translateY(-5px); 
    box-shadow: 0 6px 15px rgba(18, 91, 41, 0.2); 
    border-color: var(--mr-green); 
}
.cat-circle-item:hover .cat-icon img { transform: scale(1.1); }
.cat-circle-item:hover span { color: var(--mr-green); }

/* --------------------------------------------------------------------------
   3. BANNERS INFORMATIVOS (Estrategia de Conversión)
   Descripción: 3 bloques con imagen de fondo y texto superpuesto en HTML.
   -------------------------------------------------------------------------- */

.mr-info-banners-section { 
    margin: 50px 0; 
}

.mr-info-banners-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr); 
    gap: 20px;
}

/* Contenedor principal de cada banner */
.info-banner-card {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 140px;
    border-radius: 12px;
    text-decoration: none;
    overflow: hidden;
    background-size: cover;
    background-position: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.info-banner-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 24px rgba(0,0,0,0.15);
}

/* Capa oscura (Degradado) para garantizar que el texto blanco se lea perfecto */
.banner-overlay {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: linear-gradient(to right, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.4) 60%, rgba(0,0,0,0.1) 100%);
    z-index: 1;
    transition: background 0.3s ease;
}

/* El banner central tiene un tinte verde sutil para destacar */
.overlay-green {
    background: linear-gradient(to right, rgba(18, 91, 41, 0.9) 0%, rgba(0,0,0,0.5) 70%, rgba(0,0,0,0.1) 100%);
}

/* Contenedor del texto (se posiciona sobre el overlay) */
.banner-content {
    position: relative;
    z-index: 2;
    padding: 25px;
    color: #fff;
    max-width: 80%; /* Evita que el texto llegue hasta la orilla derecha */
}

/* Etiqueta superior pequeña */
.banner-badge {
    display: inline-block;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 8px;
    color: #e0e0e0;
}

/* Título del banner */
.banner-content h3 {
    font-size: 20px;
    font-weight: 700;
    margin: 0 0 6px 0;
    color: #fff !important;
    text-shadow: 1px 1px 3px rgba(0,0,0,0.5);
}

/* Párrafo descriptivo */
.banner-content p {
    font-size: 13px;
    margin: 0 0 3px 0;
    color: #f5f5f5 !important;
    line-height: 1.3;
}

/* Enlace / Call to Action */
.banner-cta {
    font-size: 12px;
    font-weight: 700;
    color: #fff;
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: color 0.2s ease;
}

.info-banner-card:hover .banner-cta {
    color: var(--mr-green);
    text-decoration-color: var(--mr-green);
}

/* Comportamiento especial en hover para el banner central */
.banner-center:hover .banner-cta {
    color: #fff;
    text-decoration: none;
    background-color: var(--mr-red);
    padding: 4px 8px;
    border-radius: 4px;
}


/* --------------------------------------------------------------------------
   4. ESTILIZACIÓN DEL SHORTCODE
   Descripción: Personalización del listado de anuncios (cuadrícula y tarjetas).
   -------------------------------------------------------------------------- */

/* Separación inferior para los bloques enteros de productos */
.mr-products-section { margin-bottom: 50px; }

/* Estructura de cuadrícula adaptable para las tarjetas de listado */
.mr-grid .rtcl-grid-view {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)) !important; 
    gap: 16px !important;
    align-items: stretch !important; 
}

/* Oculta los pseudo-elementos generados por defecto en el contenedor de la cuadrícula */
.mr-grid .rtcl-grid-view::before,
.mr-grid .rtcl-grid-view::after {
    display: none !important;
}

/* Estilos del contenedor principal de cada tarjeta de producto */
.mr-grid .rtcl-listing-item {
    width: 100% !important; 
    max-width: 100% !important;
    flex: none !important; 
    float: none !important; 
    margin: 0 !important;
    
    background: #fff;
    border-radius: 8px;
    border: 1px solid #e0e0e0;
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    display: flex;
    flex-direction: column;
    height: 100%; 
    min-width: 0 !important; 
}

/* Efecto de sombra y elevación en la tarjeta al pasar el cursor */
.mr-grid .rtcl-listing-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 16px rgba(0,0,0,0.12);
}

/* Contenedor de la imagen superior de la tarjeta, forzando formato cuadrado */
.mr-grid .listing-thumb {
    width: 100%;
    aspect-ratio: 1 / 1; 
    overflow: hidden;
    position: relative;
    background: var(--mr-gray-bg); 
    border-bottom: 1px solid #f0f0f0; 
    max-width: 100% !important;
}

/* Comportamiento de la imagen para cubrir completamente su contenedor */
.mr-grid .listing-thumb img {
    width: 100% !important; 
    height: 100% !important;
    object-fit: cover; 
    padding: 0; 
    transition: transform 0.3s ease;
}

/* Efecto de zoom ligero en la imagen al interactuar con la tarjeta */
.mr-grid .rtcl-listing-item:hover .listing-thumb img {
    transform: scale(1.05); 
}

/* Contenedor que agrupa toda la información de texto debajo de la imagen */
.mr-grid .item-content {
    padding: 16px; 
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

/* Oculta elementos secundarios o redundantes generados por el plugin */
.mr-grid .rtcl-meta-buttons,
.mr-grid .rtcl-listing-badge-wrap,
.mr-grid .listing-meta .location,
.mr-grid .listing-meta .category { 
    display: none !important; 
}

/* Contenedor del precio, asigna el orden visual superior y asegura altura constante */
.mr-grid .listing-price {
    order: 1; 
    margin-bottom: 8px;
    min-height: 28px; 
    display: flex;
    align-items: center;
}

/* Estilo tipográfico principal para el valor numérico del precio */
.mr-grid .rtcl-price {
    font-size: 22px; 
    font-weight: 600; 
    color: var(--mr-green); 
}

/* Inyecta el texto alternativo "Consultar" en negritas cuando el campo de precio está vacío */
.mr-grid .listing-price:empty::after,
.mr-grid .rtcl-price:empty::after {
    content: "Precio a consultar";
    font-size: 16px;
    color: var(--mr-green); 
    font-weight: 700;
    font-style: normal;
}

/* Invierte la alineación de los elementos del precio para ubicar el símbolo de moneda a la izquierda */
.mr-grid .rtcl-price-amount bdi {
    display: flex;
    flex-direction: row-reverse;
    justify-content: flex-end;
    align-items: center;
    gap: 2px;
}

/* Contenedor del título del producto, asegura altura fija para consistencia visual */
.mr-grid .listing-title {
    order: 2; 
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    margin: 0 0 12px 0; 
    min-height: 40px; 
}

/* Estilo del enlace del título y restricción a dos líneas de texto máximo */
.mr-grid .listing-title a {
    font-size: 14px; 
    color: var(--mr-text-dark); 
    text-decoration: none;
    display: -webkit-box;
    -webkit-line-clamp: 2; 
    line-clamp: 2;         
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.4;
}

/* Interacción de color en el título al pasar el cursor */
.mr-grid .listing-title a:hover { color: var(--mr-red); }

/* Contenedor de metadatos inferiores (vistas, fecha), posicionado en el extremo inferior de la tarjeta */
.mr-grid .listing-meta {
    order: 3; 
    list-style: none;
    padding: 0;
    margin: auto 0 0 0; 
    display: flex;
    justify-content: space-between; 
    align-items: center;
    border-top: 1px dashed #eaeaea; 
    padding-top: 10px;
}

/* Estilo general para cada ítem dentro del bloque de metadatos */
.mr-grid .listing-meta li {
    font-size: 11px;
    color: #999; 
    display: flex;
    align-items: center;
    gap: 4px;
    margin: 0;
}

/* Alineación de los contenedores internos dentro de ítems de metadatos */
.mr-grid .listing-meta li.info span {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Estilo neutral forzado para los iconos tipográficos de los metadatos */
.mr-grid .listing-meta li i {
    color: #bbb !important; 
    font-size: 12px;
}

/* Resaltado de color principal para el ítem específico de estadísticas/visualizaciones */
.mr-grid .listing-meta li.info {
    color: #bbb; 
    font-weight: 500;
}

/* Resaltado de color principal para el icono asociado a estadísticas/visualizaciones */
.mr-grid .listing-meta li.info i {
    color: #bbb !important; 
}

/* Adaptación para pantallas móviles */
@media (max-width: 768px) {
    .mr-info-banners-grid {
        grid-template-columns: 1fr; /* Una sola columna en celulares */
        gap: 15px;
    }
    .info-banner-card {
        height: 120px;
    }
}