@import url('https://fonts.googleapis.com/css2?family=Arima:wght@100..700&family=Raleway:ital,wght@0,100..900;1,100..900&display=swap');

body {
    font-family: "Raleway", sans-serif;
    font-optical-sizing: auto;
    margin: 0;
    padding: 0;
    font-weight: 400;
    font-style: normal;
    overflow-x: hidden;
}

header {
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 1000;
    background-color: var(--white-color);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.seccion.margen>div,
.nav {
    max-width: 1500px;
    margin: 0 auto;
    padding: 120px 70px;
}

.newsection {
    padding-top: 150px;
    padding-bottom: 150px;
}

.cuerpo {
    width: 100%;
    margin-top: 80px;
}

:root {
    --font-primary: "Raleway", sans-serif;
    --font-secondary: "Arima", system-ui;
    --primary-color: #171A1F;
    --secondary-color: #1B5E20;
    --tertiary-color: #4CAF50;
    --nav-color-movile: #333333;
    --white-color: #FFFFFF;
    --black-color: #000000;
    --text-parrafo: 16px;
    --text-h1: 40px;
    --text-h2: 26px;
    --text-h3: 18px;
    --texto-item: 16px;
    --text-h1-movile: 30px;
    --text-h3-movile: 12px;
    --text-h2-movile: 16px;
    --text-parrafo-movile: 14px;
    --texto-item-movile: 16px;
    --texto-footer: 14px;
    --heigth-nav: 72px;
}

.text-justify, .ql-align-justify {
    text-align: justify;
}

.blanco {
    color: var(--white-color) !important;
}

.blanco-bg {
    background-color: var(--white-color);
}

.negro {
    color: var(--black-color);
}

.negro-bg {
    background-color: var(--black-color) !important;
}

.primary {
    color: var(--primary-color);
}

.primary-bg {
    background-color: var(--primary-color) !important;
}

.secundary {
    color: var(--secondary-color);
}

.secundary-bg {
    background-color: var(--secondary-color);
}

.tertiary {
    color: var(--tertiary-color);
}

.tertiary-bg {
    background-color: var(--tertiary-color);
}

.placeholder-1 {
    color: var(--placeholder-1-color);
}

.placeholder-2 {
    color: var(--placeholder-2-color);
}

.center {
    flex-grow: 0;
    text-align: center;
}

.left {
    flex-grow: 0;
    text-align: left;
}

.justify-content-evenly {
    justify-content: space-evenly;
}

.w-full {
    width: 100%;
}

.flex {
    display: flex;
}

p {
    font-family: var(--font-secondary);
    font-size: var(--text-parrafo);
}

h1,
.h1 {
    font-family: var(--font-primary);
    font-size: var(--text-h1);
    font-weight: bold;
}

h2,
.h2 {
    font-family: var(--font-primary);
    font-size: var(--text-h2);
    font-weight: bold;
}

h3,
.h3 {
    font-family: var(--font-primary);
    font-size: var(--text-h3);
    font-style: italic;
    font-weight: 400;
}

a,
a:hover {
    color: var(--primary-color);
    text-decoration: none;
}

.texto-footer {
    font-size: var(--texto-footer);
}

.d-none {
    display: none;
}

.d-block {
    display: block;
}

.btn {
    border-radius: 20.5px !important;
    border: none !important;
    border-color: transparent !important;
    background: var(--secondary-color, #1B5E20) !important;
    font-size: var(--texto-item) !important;
    cursor: pointer;
    margin: 0;
    padding: 4px 20px;
    font-weight: 500;
    align-content: center;
    overflow-wrap: break-word;
    text-decoration: none !important;
}

.btn.btn2 {
    border: 1px solid #FFF;
    background: var(--primary-color, #171A1F) !important;
}


img {
    max-width: 100%;
    height: auto;
}

.navbar-nav .nav-item .nav-link.active {
    border-bottom: 5px solid var(--tertiary-color);
    /* Un verde vibrante, ajusta el color si deseas */
    padding-bottom: 3px;
    /* Pequeño ajuste para que el subrayado no pegue mucho al texto */
}

/* Opcional: Estilo al pasar el ratón por los enlaces */
.navbar-nav .nav-item .nav-link:hover {
    color: #d4d4d4;
    /* Color más claro al pasar el ratón */
}


/*********home***********/


/* Estilos generales de la Sección Banner */
#banner {
    background-color: var(--primary-color);
    /* Usando tu variable */
    min-height: 95vh;
    /* Altura principal para escritorio */
    display: flex;
    align-items: center;
    justify-content: center;
    /* ELIMINADO: margin-top: 25rem; -- Esto es probable que cause que no se vea bien */
    width: 100%;
    /* Asegura que ocupe todo el ancho */
    overflow: hidden;
    /* Para manejar cualquier posible desbordamiento */
}

/* Estilos para el Carrusel en sí */
#carouselExampleRide {
    width: 100%;
    height: 100vh;
    /* La altura del carrusel debe coincidir con la de la sección */
}

/* Estilos para cada Item del Carrusel */
.carousel-item {
    height: 100vh;
    /* La altura de cada slide debe coincidir */
    position: relative;
    /* CRUCIAL: Necesario para que .carousel-caption se posicione correctamente */
}

/* Estilos para la Imagen dentro del Carousel Item */
.banner-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    /* Asegura que la imagen cubra todo el espacio sin distorsionarse */
    filter: brightness(0.7);
    /* Oscurece un poco la imagen para que el texto blanco resalte */
}


.fruit-item {
    border-radius: 12px;
    /* border: 1px solid var(--tertiary-color, #4CAF50); */
    border: 1px solid rgba(255, 255, 255, 0.33);
    background: #1D232C;
    box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    /* Suave transición al pasar el mouse */
    cursor: pointer;
    /* Indica que es interactivo */
    width: 100%;
    height: 150px;
}

.fruit-item.active {
    border: 1px solid var(--tertiary-color, #4CAF50);
    box-shadow: 0 0 10px #4CAF50;
    transform: scale(1.05);
    transition: all 0.3s ease-in-out;
    /* Transición para el borde y la escala */
}

.fruit-item:hover {
    transform: translateY(-5px);
    /* Pequeño efecto de elevación al pasar el mouse */
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.4);
    /* Sombra al pasar el mouse */
}

.fruit-item img {
    width: 70%;
    object-fit: contain;
}

.info-frutos {
    width: 30rem;
    text-align: end;
    transition: opacity 0.4s ease-in-out, transform 0.4s ease-in-out;
}

.contenedor-frutos {
    padding: 0 70px;
    margin-left: 6rem;
}

.contenedor-frutos>h3 {
    margin-bottom: 57px;
}

.banner-fruto-lateral {
    height: 46rem;
    width: 48rem;
    overflow: hidden;
    transition: opacity 0.5s ease-in-out, transform 0.5s ease-in-out;
}

.seccion-frutos {
    width: 32rem;
    margin-right: 25px;
}

.item-fruta {
    justify-items: center;
    margin: 5px 0;
}

/* Variables CSS personalizadas para el carrusel */
:root {
    --carousel-main-width: 100%;
    /* Ancho máximo del contenedor del carrusel */
    --carousel-single-item-width: 300px;
    /* Ancho de cada elemento del carrusel */
    --carousel-single-item-height: 200px;
    /* Alto de cada elemento del carrusel */
    --carousel-item-spacing: 0px;
    /* Espacio entre los elementos del carrusel */

    /* Colores para modo claro/oscuro, usando variables de Bootstrap para integración */
    --bs-card-border-color: rgba(0, 0, 0, 0.25);
    /* Color del borde de la tarjeta en modo claro */
}

/* Estilos del contenedor principal del carrusel personalizado */
.custom-marquee-carousel {
    position: relative;
    /* Posicionamiento relativo para elementos internos */
    width: var(--carousel-main-width);
    /* Ancho definido por variable */
    height: var(--carousel-single-item-height);
    /* Alto definido por variable */
    overflow: clip;
    /* Recortar contenido que se desborda */
}

/* Máscara para efecto de desvanecimiento en los lados del carrusel */
.custom-marquee-carousel[data-mask] {
    mask-image: linear-gradient(to right,
            transparent,
            black 10% 90%,
            transparent);
}

/* Invertir dirección de la animación si el atributo 'data-reverse' está presente */
.custom-marquee-carousel[data-reverse] .custom-marquee-item {
    animation-direction: reverse;
}

/* Pausar animación al pasar el ratón sobre el carrusel */
.custom-marquee-carousel:hover .custom-marquee-item {
    animation-play-state: paused;
}

/* Estilos de los elementos individuales del carrusel (tarjetas) */
.custom-marquee-item {
    position: absolute;
    /* Posicionamiento absoluto para la animación */
    top: 0;
    left: calc(100% + var(--carousel-item-spacing));
    /* Posición inicial fuera de la vista */
    width: var(--carousel-single-item-width);
    /* Ancho de la tarjeta */
    height: var(--carousel-single-item-height);
    /* Alto de la tarjeta */
    /* Se eliminó grid-template-rows ya que el contenido se superpondrá */
    padding-bottom: 0;
    /* No padding-bottom en el artículo mismo */
    border-radius: 0px;
    /* Bordes redondeados */
    background: transparent;
    /* El fondo será la imagen y la superposición */
    border: 1px solid var(--bs-card-border-color);
    /* Borde de la tarjeta */
    overflow: hidden;
    /* Asegurar que la imagen y el overlay respeten el border-radius */

    /* Propiedades de animación */
    will-change: transform;
    /* Optimización para animaciones de transformación */
    animation-name: marquee-animation;
    /* Nombre de la animación */
    animation-duration: var(--carousel-animation-duration);
    /* Duración de la animación */
    animation-timing-function: linear;
    /* Función de temporización lineal */
    animation-iteration-count: infinite;
    /* Repetición infinita */
    /* animation-delay se establece con JavaScript para un desplazamiento secuencial */
}

.custom-marquee-item::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--secondary-color);
    /* Rojo con 40% de opacidad. Ajusta 0.4 a tu gusto. */
    opacity: 0.7;
    /* Opacidad del overlay */
    border-radius: 0px;
    /* Asegura que el overlay tenga el mismo border-radius que el item */
    z-index: 1;
    /* Un z-index entre la imagen (1) y el contenido (2) */
}

/* Estilos de la imagen dentro de la tarjeta del carrusel */
.custom-marquee-item img {
    position: absolute;
    /* Posicionamiento absoluto para cubrir la tarjeta */
    top: 0;
    left: 0;
    width: 100%;
    /* Ancho completo */
    height: 100%;
    /* Alto completo */
    object-fit: cover;
    /* Ajustar imagen para cubrir el área */
    border-radius: 0px;
    /* La imagen ahora tiene los bordes redondeados completos de la tarjeta */
    z-index: 1;
    /* Asegurar que la imagen esté detrás de la superposición */
}

/* Estilos de la capa de superposición del contenido de texto */
.item-overlay-content {
    position: absolute;
    /* Posicionamiento absoluto para superponer */
    bottom: 0;
    /* Alinear a la parte inferior de la tarjeta */
    left: 0;
    right: 0;
    z-index: 2;
    /* Asegurar que la superposición esté encima de la imagen */
    background: var(--overlay-bg-light);
    /* Fondo semitransparente para el texto */
    color: var(--overlay-text-light);
    /* Color del texto sobre la superposición */
    padding: 0 1rem;
    /* Relleno dentro de la superposición */
    border-radius: 0 0 10px 10px;
    /* Bordes inferiores redondeados para coincidir con la tarjeta */
    display: flex;
    /* Usar flexbox para organizar el contenido */
    flex-direction: column;
    /* Organizar elementos en columna */
    justify-content: flex-end;
    /* Empujar el contenido hacia la parte inferior */
    height: auto;
    /* Permitir que la altura se ajuste al contenido */
    min-height: 50%;
    /* Asegurar que cubra al menos la mitad de la imagen */
    text-align: end;
    /* Alinear el texto a la derecha */
}

/* Estilos del título de la tarjeta */
.custom-marquee-item h2 {
    font-size: 1.2rem;
    /* Tamaño de fuente del título */
    font-weight: 300;
    /* Peso de la fuente */
    padding-block: 0.25rem;
    /* Relleno vertical ajustado */
    margin: 0 0 0.5rem 0;
    /* Margen inferior para separar del párrafo */
    color: inherit;
    /* Heredar color de la capa de superposición */
    text-shadow: #000000 0px 0px 5px;
    /* Sombra de texto para mejorar la legibilidad */
}

/* Keyframes de la animación de desplazamiento (marquee) */
@keyframes marquee-animation {
    100% {
        transform: translateX(calc((var(--carousel-items) * (var(--carousel-single-item-width) + var(--carousel-item-spacing))) * -1));
    }
}

.separador {
    position: relative;
    bottom: 4rem;
}

.separador2 {
    position: relative;
    bottom: -0.5rem;
}

.card-img-top-container {
    width: 150px;
}

/* Estilos para el contenedor de la imagen y el texto superpuesto */
.image-overlay-container {
    position: relative;
    /* Esencial para el posicionamiento absoluto del texto */
    width: 100%;
    /* El contenedor debe tener un ancho definido, a menudo 100% de su padre */
    height: 300px;
    /* <--- ESTO ES CLAVE: Define una altura fija o mínima para el contenedor */
    overflow: hidden;
    /* Recorta cualquier parte de la imagen que se desborde al usar object-fit: cover */
    display: flex;
    /* Ayuda a centrar el texto, aunque 'absolute' también lo hace */
    justify-content: center;
    /* Centra el texto horizontalmente con flexbox */
    align-items: center;
    /* Centra el texto verticalmente con flexbox */
}

/* Estilos para la imagen dentro del contenedor */
.overlay-image {
    position: absolute;
    /* Coloca la imagen de forma absoluta dentro de su contenedor relativo */
    top: 0;
    left: 0;
    width: 100%;
    /* La imagen ocupa el 100% del ANCHO del contenedor */
    height: 100%;
    /* La imagen ocupa el 100% de la ALTURA del contenedor */
    object-fit: cover;
    /* ¡ESTO ES LO MÁS IMPORTANTE! */
    display: block;
    /* Elimina cualquier espacio adicional debajo de la imagen (común con imágenes inline) */
    z-index: 1;
    /* Asegura que la imagen esté debajo del texto superpuesto */
    filter: brightness(80%);
    /* Opcional: Oscurece la imagen para mejorar la legibilidad del texto */
}

/* Estilos para el texto que se superpone (como antes) */
.overlay-text {
    position: absolute;
    /* Posiciona el texto sobre la imagen */
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80%;
    max-width: 800px;
    text-align: center;
    z-index: 2;
    /* Asegura que el texto esté por encima de la imagen */
}

/* Nuevo contenedor principal para el efecto de blob */
.image-wrapper-with-blob {
    position: relative;
    width: 280px;
    height: 320px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 20px;
}

/* Pseudo-elemento para la forma verde de fondo */
.image-wrapper-with-blob::before {
    content: '';
    position: absolute;
    top: -20px;
    left: -20px;
    width: calc(100% + 40px);
    height: calc(100% + 40px);
    background-color: var(--tertiary-color);
    border-radius: 20px;
    transform: rotate(-8deg);
    transform-origin: center center;
    z-index: 0;
    /* <-- AQUÍ ESTÁ LA CLAVE */
}

/* Estilos para la imagen principal */
.image-inside-wrapper {
    position: relative;
    /* <-- Y AQUÍ ESTÁ LA OTRA CLAVE */
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 15px;
    z-index: 99;
    /* <-- Y ESTA */
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
    transform: scale(1.1);
}

#contacto {
    background: url('/img/fondocontacto.png');
    background-size: cover;
    /* Optional: Makes the image cover the entire div */
    background-position: center center;
    /* Optional: Centers the image */
    background-repeat: no-repeat;
    /* Optional: Prevents the image from repeating */
    padding: 100px 50px;
    /* Optional: Adds padding around the content */
    height: 100%;
    /* Example height */
}

#contacto .fondo-contacto {
    border-radius: 14px;
    margin: auto;
    width: 100%;
    height: 100%;
}

.custom-input-shadow {
    /* Basic shadow for the "lifted" effect */
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24);
    border: none;
    /* Remove default border to let shadow define the edge */
    transition: all 0.3s cubic-bezier(.25, .8, .25, 1);
    /* Smooth transition for hover/focus */
    border-radius: 0.375rem;
    /* Match Bootstrap's default border-radius */
    background-color: #f6f6f6;
    /* Slightly off-white background if needed, like the image */
}

.custom-input-shadow:focus {
    outline: none;
    /* Remove default focus outline */
    border-color: transparent;
    /* Ensure border doesn't appear on focus */
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16), 0 3px 6px rgba(0, 0, 0, 0.23);
    /* More prominent shadow on focus */
}

/* If you want to customize Bootstrap's form-control default focus effect,
   you might need to override its --bs-focus-ring-shadow */
.form-control:focus {
    box-shadow: var(--bs-form-control-focus-box-shadow);
    /* Keep Bootstrap's default focus ring */
}

/* OR if you want to completely remove Bootstrap's focus outline: */
.form-control:focus {
    box-shadow: none !important;
    /* Remove all shadows on focus from Bootstrap */
    border-color: transparent !important;
    /* Remove border on focus */
}

/* If you combine custom-input-shadow with form-control, you might need to ensure
   your custom styles are applied after Bootstrap's, or use higher specificity. */
.form-control.custom-input-shadow {
    /* Ensure border and background override Bootstrap defaults if needed */
    border: none;
    background-color: #f6f6f6;
    /* Or whatever light background color matches your image */
}

.form-control.custom-input-shadow:focus {
    /* Override Bootstrap's default focus style for the shadow */
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16), 0 3px 6px rgba(0, 0, 0, 0.23), var(--bs-form-control-focus-box-shadow, 0 0 0 0.25rem rgba(13, 110, 253, .25));
    /* Combine with optional Bootstrap focus ring */
}

.img-empresa {
    border-radius: 30px;
    box-shadow: 0 4px 5px 4px rgba(0, 0, 0, 0.25);
}

.datos-fundador {
    border-radius: 37px;
    border: 1px solid #D1D1D1;
    background: #F6F6F6;
    width: 90%;
}

.img-fundador {
    border-radius: 382px;
    margin-bottom: 25px;
}

.icon-pilar {
    border-radius: 85px;
    border: 1px solid var(--secondary-color);
    width: 85px;
    height: 85px;
    flex-shrink: 0;
}

.titulo-presentacion {
    border-bottom: 4px solid var(--secondary-color);
    display: inline-block;
    margin-bottom: 20px;
}

.imagen-producto {
    width: 90%;
    /* O el ancho que desees para tu contenedor */
    padding-top: 70%;
    /* Esto hace que la altura sea igual al ancho, creando un cuadrado */
    position: relative;
    /* Necesario para posicionar la imagen de forma absoluta dentro */
    overflow: hidden;
    /* Oculta cualquier parte de la imagen que se desborde */
    cursor: pointer;
    /* Indicates the image is interactive */
}

.imagen-producto img {
    position: absolute;
    /* Posiciona la imagen con respecto al .imagen-producto */
    top: 0;
    left: 0;
    width: 100%;
    /* La imagen ocupa el 100% del ancho del cuadrado */
    height: 100%;
    /* La imagen ocupa el 100% del alto del cuadrado */
    object-fit: cover;
    /* ¡Esta es la clave! Cubre el área manteniendo el aspecto y recortando si es necesario. */
    object-position: center;
    /* Opcional: Centra la parte visible de la imagen (por defecto es center) */
    transition: transform 0.3s ease;
    /* Smooth zoom effect on hover */
}

/* Styling for the overlay */
.overlay {
    position: absolute;
    bottom: 0;
    /* Position at the bottom of the image */
    left: 0;
    width: 100%;
    height: 50px;
    /* Adjust height as needed */
    background-color: rgba(0, 128, 0, 0.6);
    /* Semi-transparent green (R, G, B, Alpha) */
    color: white;
    display: flex;
    /* For centering the text */
    justify-content: center;
    /* Center horizontally */
    align-items: center;
    /* Center vertically */
    opacity: 0;
    /* Hidden by default */
    transition: opacity 0.3s ease;
    /* Smooth fade-in effect */
}

/* Styling for the "View More" text */
.view-more-text {
    font-weight: bold;
    font-size: 1.1em;
    /* Adjust font size as needed */
}

/* Hover effect: show the overlay and slightly zoom the image */
.imagen-producto:hover .overlay {
    opacity: 1;
    /* Make the overlay visible */
}

.imagen-producto:hover img {
    transform: scale(1.05);
    /* Slightly zoom in the image */
}

.img-fruta-detalle {
    justify-content: center;
    max-width: 25%;
}

.pignose-calendar {
    width: 100% !important;
    max-width: 100% !important;
    /* Adjust as needed */
    margin: 0 auto;
    /* Center the calendar */
}

.calendar-div {
    width: 80%;
    margin: 0 auto;
}

.pignose-calendar-button-schedule-pin.pignose-calendar-button-schedule-pin-disponibilidad {
    width: 100% !important;
    border-radius: 0 !important;
}

.pignose-calendar-unit.pignose-calendar-unit-date a {
    color: #000 !important;
    /* Cambia el color del texto del enlace */
}

.pignose-calendar-top-year {
    display: none !important;
}

.rango {
    display: inline-block;
    padding: 4px 30px;
    border-radius: 4px;
    background-color: var(--secondary-color);
    margin-left: 25px;
}

.rect-separador {
    display: block;
    height: 2px;
    background-color: var(--secondary-color);
    margin: 20px 0;
    width: 100%;
}

#titulo-frutas {
    z-index: -2;
}


/* Estilos específicos para la sección del carrusel */
.game-section {
    padding: 60px 0px;
    /* Ajusta el padding según sea necesario */
}

/* --- Estilos para los elementos del carrusel --- */
.game-section .owl-stage {
    margin: 15px 0;
    display: flex;
    display: -webkit-flex;
    /* Para compatibilidad */
}

.game-section .item {
    margin: 0 15px 60px;
    /* Espaciado entre items y margen inferior */
    width: 320px;
    /* Ancho inicial del item */
    height: 300px;
    /* Altura inicial del item */
    display: flex;
    display: -webkit-flex;
    align-items: flex-end;
    /* Alinea el contenido inferior */
    -webkit-align-items: flex-end;
    background: #343434 no-repeat center center / cover;
    /* Fondo por defecto */
    border-radius: 16px;
    overflow: hidden;
    position: relative;
    transition: all 0.4s ease-in-out;
    /* Transición para el tamaño y sombra */
    -webkit-transition: all 0.4s ease-in-out;
    cursor: pointer;
}

.game-section .item.active {
    width: 500px;
    /* Ancho cuando está activo */
    box-shadow: 12px 40px 40px rgba(0, 0, 0, 0.25);
    /* Sombra cuando está activo */
    -webkit-box-shadow: 12px 40px 40px rgba(0, 0, 0, 0.25);
}

.game-section .item:after {
    content: "";
    display: block;
    position: absolute;
    height: 100%;
    width: 100%;
    left: 0;
    top: 0;
    background-image: linear-gradient(rgba(0, 0, 0, 0), rgba(0, 0, 0, 1));
    /* Degradado oscuro */
}

/* --- Estilos para la descripción del item --- */
.game-section .item-desc {
    padding: 0 24px 12px;
    color: #fff;
    /* Color del texto */
    position: relative;
    z-index: 1;
    overflow: hidden;
    transform: translateY(calc(100% - 54px));
    /* Oculta parcialmente la descripción */
    -webkit-transform: translateY(calc(100% - 54px));
    transition: all 0.4s ease-in-out;
    /* Transición para la descripción */
    -webkit-transition: all 0.4s ease-in-out;
}

.game-section .item.active .item-desc {
    transform: none;
    /* Muestra completamente la descripción cuando está activo */
    -webkit-transform: none;
}


.game-section .item-desc p {
    opacity: 0;
    /* Oculta el párrafo por defecto */
    -webkit-transform: translateY(32px);
    transform: translateY(32px);
    transition: all 0.4s ease-in-out 0.2s;
    /* Transición para el párrafo */
    -webkit-transition: all 0.4s ease-in-out 0.2s;
}

.game-section .item.active .item-desc p {
    opacity: 1;
    /* Muestra el párrafo cuando está activo */
    -webkit-transform: translateY(0);
    transform: translateY(0);
}

/* --- Estilos para los puntos de navegación del Owl Carousel --- */
.game-section .owl-theme.custom-carousel .owl-dots {
    margin-top: -20px;
    /* Ajusta la posición de los puntos */
    position: relative;
    z-index: 5;
}


.contenedor-contacto {
    border-radius: 24px;
    border: 1px solid #D9D9D9;
    background: #F6F6F6;
    padding: 40px;
}

.mapa-container {
    width: 100%;
    /* Ancho máximo para el contenedor */
    margin: 20px auto;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}

.mapa-container iframe {
    width: 100%;
    height: 450px;
    /* Altura del mapa, puedes ajustarla */
    border: 0;
    /* Quita el borde por defecto del iframe */
}

/* Estilos para el encabezado del acordeón */
.accordion-header {
  margin-bottom: 0; /* Asegura que no haya margen extra en la parte inferior */
}

/* Estilos para el botón del acordeón (la pregunta) */
.accordion-button {
  background-color: #f8f9fa; /* Color de fondo claro para la pregunta */
  color: #343a40; /* Color de texto oscuro para la pregunta */
  font-size: 1.15rem; /* Tamaño de fuente ligeramente más grande */
  font-weight: 600; /* Texto seminegrita */
  padding: 1rem 1.25rem; /* Relleno interno */
  border: 1px solid rgba(0, 0, 0, 0.125); /* Borde suave */
  border-radius: 0.25rem; /* Bordes redondeados */
  text-align: left; /* Alinea el texto a la izquierda */
  width: 100%; /* El botón ocupa todo el ancho disponible */
  transition: all 0.3s ease-in-out; /* Transición suave para hover y estado */
  box-shadow: none; /* Elimina la sombra por defecto de algunos navegadores */
}

/* Estilos para el botón cuando está colapsado (cerrado) */
.accordion-button.collapsed {
  background-color: #ffffff; /* Fondo blanco cuando está cerrado */
  color: #212529; /* Color de texto más oscuro cuando está cerrado */
  border-bottom: 0; /* Quita el borde inferior cuando está colapsado para que no se duplique con el borde de la respuesta */
}

/* Estilos para el botón cuando está activo (abierto) */
.accordion-button:not(.collapsed) {
  background-color: #e9ecef; /* Fondo ligeramente gris para el estado abierto */
  color: var(--tertiary-color); /* Color azul para el texto de la pregunta abierta */
  border-bottom: 0; /* Quita el borde inferior cuando está activo */
}

/* Estilos al pasar el ratón por encima del botón */
.accordion-button:hover {
  background-color: #e2e6ea; /* Fondo un poco más oscuro al pasar el ratón */
  color: var(--tertiary-color); /* Color azul más oscuro al pasar el ratón */
  cursor: pointer; /* Cambia el cursor para indicar que es clicable */
}

/* Quita el foco azul por defecto al hacer clic */
.accordion-button:focus {
  outline: 0;
  box-shadow: 0 0 0 0.25rem rgba(37, 77, 18, 0.25); /* Sombra de foco más suave (color Bootstrap primary) */
}

/* Estilos para el cuerpo del acordeón (la respuesta) */
.accordion-collapse.collapse.show .accordion-body {
  border: 1px solid rgba(0, 0, 0, 0.125); /* Borde similar al del botón */
  border-top: 0; /* Quita el borde superior para que se una visualmente con el botón */
  background-color: #fcfcfc; /* Fondo muy claro para la respuesta */
  padding: 1rem 1.25rem; /* Relleno interno */
  font-size: 1rem; /* Tamaño de fuente estándar */
  line-height: 1.6; /* Espaciado entre líneas */
  color: #495057; /* Color de texto de la respuesta */
  border-bottom-left-radius: 0.25rem; /* Redondea las esquinas inferiores */
  border-bottom-right-radius: 0.25rem;
}

/* Custom styles for the map toggle switch */
#mapa.form-check-input {
    transform: scale(1.4); /* Adjust size */
    margin-top: 0.15rem;   /* Adjust vertical alignment */
    /* Add any other specific styles like background-color, border-color if needed */
}

/* Optional: Adjust label positioning if needed */
#mapa + .form-check-label {
    padding-top: 0.05rem; /* Small adjustment for the label text if it feels too high/low */
}