/* ==========================================================================
 * Widget: Text-Image
 * BEM naming: .wb-text-image, .wb-text-image__element, .wb-text-image__element--modifier
 * All colours use CSS variables from Elementor global tokens or geniova.css.
 * ========================================================================== */


/* --------------------------------------------------------------------------
 * Main container
 * -------------------------------------------------------------------------- */
.wb-text-image {
    overflow: hidden;
    /* Text ↔ image spacing: overridden by Elementor control image_text_gap (inline --wb-text-image-text-media-gap). */
    --wb-text-image-text-media-gap: var(--section-padding-padding-section-medium);
    /* Space above footnote (below main content): overridden by Elementor control footnote_margin_top. */
    --wb-text-image-footnote-margin-top: var(--spacing-16x, 2rem);
}

.wb-text-image__container {
    max-width: var(--container-container-large, 80rem);
    margin: 0 auto;
}


/* --------------------------------------------------------------------------
 * Content grid (2-column layout)
 * -------------------------------------------------------------------------- */

.wb-text-image__content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
    grid-auto-columns: 1fr;
}

/* Vertical centering for side-by-side layouts */
.wb-text-image__content--text-first,
.wb-text-image__content--image-first {
    align-items: center;
}

/* Image-bottom: stretch children */
.wb-text-image__content--image-bottom {
    align-items: stretch;
}

/* Image-bottom: gap between text and image on desktop only */
@media (min-width: 992px) {
    .wb-text-image__content--image-bottom {
        gap: var(--section-padding-padding-section-medium);
    }
}

/* No image: single column */
.wb-text-image__content--no-image {
    display: block;
}

.wb-text-image__content--no-image .wb-text-image__text {
    max-width: none;
    width: 100%;
}

/* Image-bottom + no-image: keep 2-column for text split */
.wb-text-image__content--image-bottom.wb-text-image__content--no-image {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-16x, 2rem); /* Mantener gap: CSS Grid estándar */
}

/* Desktop only: padding between text and image columns (skip when no image) */
@media (min-width: 768px) {
    .wb-text-image__content--text-first:not(.wb-text-image__content--no-image) .wb-text-image__text {
        padding-right: var(--wb-text-image-text-media-gap);
    }
    .wb-text-image__content--image-first:not(.wb-text-image__content--no-image) .wb-text-image__text {
        padding-left: var(--wb-text-image-text-media-gap);
    }
}


/* --------------------------------------------------------------------------
 * Logo
 * -------------------------------------------------------------------------- */

.wb-text-image__logo {
    display: block;
    margin-bottom: var(--section-padding-padding-section-small, 3rem);
}

.wb-text-image__logo-img {
    height: auto;
    max-width: 100%;
    display: block;
}


/* --------------------------------------------------------------------------
 * Tagline, title, description
 * Spacing via global: [class*="__tagline"] mb 8x, [class*="__title"] mb 12x
 * -------------------------------------------------------------------------- */

.wb-text-image .wb-text-image__description {
    margin-bottom: 0;
}

.wb-text-image__description-2 {
    margin-top: var(--spacing-8x, 1rem);
    margin-bottom: 0;
    color: var(--e-global-color-text, var(--color-scheme-1--text));
}


/* --------------------------------------------------------------------------
 * Features list
 * -------------------------------------------------------------------------- */

.wb-text-image__features {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-column-gap: var(--spacing-8x, 1rem); /* Mantener gap: CSS Grid estándar */
    grid-row-gap: var(--spacing-8x, 1rem); /* Mantener gap: CSS Grid estándar */
    grid-template-rows: auto;
    grid-auto-columns: 1fr;
    padding-top: var(--spacing-16x, 2rem);
    padding-bottom: var(--spacing-4x, 0.5rem);
}

.wb-text-image__feature {
    display: flex;
}

.wb-text-image__feature > *:not(:last-child) {
    margin-right: var(--spacing-8x, 1rem);
}

.wb-text-image__feature-icon {
    flex: none;
    align-self: flex-start;
}


/* --------------------------------------------------------------------------
 * Blocks grid (2 columns)
 * -------------------------------------------------------------------------- */

.wb-text-image__blocks {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-column-gap: var(--spacing-12x, 1.5rem); /* Mantener gap: CSS Grid estándar */
    grid-row-gap: var(--spacing-12x, 1.5rem); /* Mantener gap: CSS Grid estándar */
    grid-template-rows: auto;
    padding-top: var(--spacing-16x, 2rem);
    padding-bottom: var(--spacing-4x, 0.5rem);
}

.wb-text-image__block-icon {
    width: 3rem;
    height: 3rem;
    margin-bottom: var(--spacing-8x, 1rem);
}

.wb-text-image .wb-text-image__block-title {
    margin-bottom: var(--spacing-8x, 1rem);
}


/* --------------------------------------------------------------------------
 * Media wrapper (image side)
 * -------------------------------------------------------------------------- */

.wb-text-image__media {
    border-radius: var(--radius-small);
    overflow: hidden;
}

.wb-text-image__image {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

/* Image-bottom layout: space between text block and media (one margin on wrapper; inner img has no extra margin-top). */
.wb-text-image__media--bottom {
    margin-top: var(--wb-text-image-text-media-gap);
}

.wb-text-image__media--bottom .wb-text-image__image {
    width: 100%;
    height: auto;
    display: block;
    margin-top: 0;
}


/* --------------------------------------------------------------------------
 * Footnote
 * -------------------------------------------------------------------------- */

.wb-text-image__footnote {
    margin-top: var(--wb-text-image-footnote-margin-top);
    padding-top: var(--spacing-8x, 1rem);
    font-size: var(--e-global-typography-a22beb5-font-size, 0.875rem);
    line-height: 1.5;
    color: var(--_primitives---colors--neutral-dark);
}

.wb-text-image__footnote p {
    margin: 0;
}

.wb-text-image__footnote a {
    color: var(--color-scheme-1--accent);
    text-decoration: underline;
    transition: color 0.3s ease;
}

.wb-text-image__footnote a:hover {
    color: var(--_primitives---colors--razzmatazz-dark);
}


/* ==========================================================================
 * CAROUSEL
 * ========================================================================== */

.wb-text-image__media-container {
    position: relative;
    width: 100%;
}

/* Single image — visible by default */
.wb-text-image__single-image {
    display: block;
}

/* Carousel — hidden by default */
.wb-text-image__carousel {
    display: none;
    position: relative;
    width: 100%;
}

/* Desktop (>991px): toggle image vs carousel */
@media (min-width: 992px) {
    .wb-text-image__media-container[data-carousel-desktop="1"] .wb-text-image__single-image {
        display: none;
    }

    .wb-text-image__media-container[data-carousel-desktop="1"] .wb-text-image__carousel {
        display: block;
    }

    .wb-text-image__media-container[data-carousel-desktop="0"] .wb-text-image__single-image {
        display: block;
    }

    .wb-text-image__media-container[data-carousel-desktop="0"] .wb-text-image__carousel {
        display: none;
    }
}

/* Mobile/Tablet (<=991px): toggle image vs carousel */
@media (max-width: 991px) {
    .wb-text-image__media-container[data-carousel-mobile="1"] .wb-text-image__single-image {
        display: none;
    }

    .wb-text-image__media-container[data-carousel-mobile="1"] .wb-text-image__carousel {
        display: block;
    }

    .wb-text-image__media-container[data-carousel-mobile="0"] .wb-text-image__single-image {
        display: block;
    }

    .wb-text-image__media-container[data-carousel-mobile="0"] .wb-text-image__carousel {
        display: none;
    }
}

/* Carousel viewport */
.wb-text-image__carousel-viewport {
    overflow: hidden;
    width: 100%;
}

/* Carousel track */
.wb-text-image__carousel-track {
    display: flex;
    transition: transform 0.5s ease;
    gap: 0;
}

/* Carousel slide */
.wb-text-image__carousel-slide {
    flex: 0 0 100%;
    min-width: 100%;
}

/* Carousel image */
.wb-text-image__carousel-img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

/* Carousel arrows */
.wb-text-image__carousel-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    cursor: pointer;
    background: var(--_primitives---opacity--white-90);
    border: none;
    border-radius: 50%;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.3s ease, opacity 0.3s ease;
    box-shadow: 0 2px 8px var(--_primitives---opacity--neutral-darkest-15);
}

.wb-text-image__carousel-arrow:hover {
    background: var(--color-scheme-1--foreground);
}

.wb-text-image__carousel-arrow--prev {
    left: var(--spacing-8x, 1rem);
}

.wb-text-image__carousel-arrow--next {
    right: var(--spacing-8x, 1rem);
}

.wb-text-image__carousel-arrow-icon {
    width: 16px;
    height: 16px;
    color: var(--color-scheme-1--text);
    display: flex;
    align-items: center;
    justify-content: center;
}

.wb-text-image__carousel-arrow-icon svg {
    width: 100%;
    height: 100%;
}

/* Carousel dots */
.wb-text-image__carousel-dots {
    display: flex;
    justify-content: center;
    margin-top: var(--spacing-12x, 1.5rem);
    padding: var(--spacing-4x, 0.5rem) 0;
}

.wb-text-image__carousel-dots > *:not(:last-child) {
    margin-right: var(--spacing-4x, 0.5rem);
}

.wb-text-image__carousel-dots .wb-text-image__carousel-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: var(--_primitives---opacity--neutral-darkest-20);
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.3s ease;
    border: none;
    padding: 0;
}

.wb-text-image__carousel-dots .wb-text-image__carousel-dot:hover {
    background-color: var(--_primitives---opacity--neutral-darkest-40);
}

.wb-text-image__carousel-dots .wb-text-image__carousel-dot--active {
    background-color: var(--color-scheme-1--text);
    transform: scale(1.2);
}


/* ==========================================================================
 * RESPONSIVE — Tablet (<=991px)
 * ========================================================================== */

@media (max-width: 991px) {
    .wb-text-image {
        padding-left: var(--spacing-16x, 2rem);
        padding-right: var(--spacing-16x, 2rem);
    }

    .wb-text-image__content {
        grid-column-gap: var(--section-padding-padding-section-small, 3rem); /* Mantener gap: CSS Grid estándar */
        grid-template-columns: 1fr 1fr;
        grid-auto-flow: row;
    }

    /* Force single column and text-first on mobile/tablet */
    .wb-text-image__content,
    .wb-text-image__content--image-bottom,
    .wb-text-image__content--no-image,
    .wb-text-image__content--image-bottom.wb-text-image__content--no-image {
        display: flex;
        flex-direction: column;
        grid-template-columns: none;
    }

    .wb-text-image__content .wb-text-image__text {
        order: 1;
        max-width: none;
        width: 100%;
    }

    .wb-text-image__content .wb-text-image__media {
        order: 2;
        width: 100%;
        margin-top: var(--wb-text-image-text-media-gap);
    }

    .wb-text-image__content--image-bottom .wb-text-image__text-secondary {
        order: 1;
    }

    .wb-text-image__media--bottom {
        order: 2;
    }

    /* Carousel: mobile peek + bleed */
    .wb-text-image__media-container {
        overflow: visible;
    }

    .wb-text-image__media {
        overflow: visible;
    }

    .wb-text-image__carousel {
        overflow: hidden;
        width: calc(100% + 5vw + 1rem);
        max-width: none;
        margin-left: 0;
        margin-right: calc(-5vw - 1rem);
    }

    .wb-text-image__carousel-viewport {
        overflow: visible;
        width: 100%;
    }

    .wb-text-image__carousel-track {
        gap: var(--spacing-8x, 1rem); /* Mantener gap: slider track con transform */
    }

    .wb-text-image__carousel-slide {
        flex: 0 0 calc(100% - 4rem);
        min-width: calc(100% - 4rem);
    }
}


/* ==========================================================================
 * RESPONSIVE — Mobile (<=767px)
 * ========================================================================== */

@media (max-width: 767px) {
    .wb-text-image {
        padding-left: var(--spacing-8x, 1rem);
        padding-right: var(--spacing-8x, 1rem);
    }

    /* Blocks: single column on mobile */
    .wb-text-image__blocks {
        grid-template-columns: 1fr;
    }

    /* Carousel arrows smaller */
    .wb-text-image__carousel-arrow {
        width: 40px;
        height: 40px;
    }

    .wb-text-image__carousel-arrow--prev {
        left: var(--spacing-4x, 0.5rem);
    }

    .wb-text-image__carousel-arrow--next {
        right: var(--spacing-4x, 0.5rem);
    }

    .wb-text-image__carousel-dots {
        margin-top: var(--spacing-8x, 1rem);
    }

    /* Footnote smaller text (margin-top: use --wb-text-image-footnote-margin-top + footnote_margin_top control) */
    .wb-text-image__footnote {
        font-size: var(--e-global-typography-27d911f-font-size, 0.75rem);
    }
}
