
/* ── Medidas: grid en tbody (tr display:contents) para alinear TODAS las filas ── */
#product-data-div table {
    max-width: 44rem !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

#product-data-div table tbody {
    display: grid !important;
    grid-template-columns: max-content 64px max-content !important;
    column-gap: 1rem !important;
    row-gap: 0.35rem !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
}

#product-data-div table tbody tr {
    display: contents !important;
}

#product-data-div table tbody th.hidden {
    grid-column: 1 / -1 !important;
}

#product-data-div table tbody th:not(.hidden) {
    grid-column: 1 !important;
    justify-self: start !important;
    width: auto !important;
    padding-right: 4rem !important;
}

#product-data-div table tbody td.product-measure-icon {
    grid-column: 2 !important;
    width: 64px !important;
    min-width: 64px !important;
    max-width: 64px !important;
    justify-self: center !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    padding-left: 0 !important;
}

#product-data-div table tbody td.product-measure-value {
    grid-column: 3 !important;
    width: auto !important;
    max-width: 100% !important;
    min-width: 0 !important;
    text-align: left !important;
    white-space: nowrap !important;
    box-sizing: border-box !important;
}

/* Fila sin ícono: ocultar celda vacía; el valor arranca desde col 2 (posición del ícono) */
#product-data-div table tbody td.product-measure-icon:empty {
    display: none !important;
}

#product-data-div table tbody td.product-measure-icon:empty + td.product-measure-value {
    grid-column: 2 / -1 !important;
}

@media (max-width: 640px) {
    /* Mantener las 3 columnas pero compactas */
    #product-data-div table tbody {
        grid-template-columns: max-content 40px max-content !important;
        column-gap: 0.5rem !important;
        row-gap: 0.5rem !important;
        justify-content: center !important;
    }
    #product-data-div table tbody th:not(.hidden) {
        padding-right: 1.25rem !important;
    }
    #product-data-div table tbody td.product-measure-icon {
        width: 40px !important;
        min-width: 40px !important;
        max-width: 40px !important;
    }
    #product-data-div table td.product-measure-icon svg {
        width: 40px !important;
        height: 40px !important;
        min-width: 40px !important;
        min-height: 40px !important;
        max-width: 40px !important;
        max-height: 40px !important;
    }
    #product-data-div table tbody td.product-measure-value {
        white-space: normal !important;
    }
}

@media (max-width: 420px) {
    #product-data-div table tbody {
        grid-template-columns: max-content 32px minmax(0, 1fr) !important;
        column-gap: 0.4rem !important;
    }
    #product-data-div table tbody th:not(.hidden) {
        padding-right: 0.75rem !important;
    }
    #product-data-div table tbody td.product-measure-icon {
        width: 32px !important;
        min-width: 32px !important;
        max-width: 32px !important;
    }
    #product-data-div table td.product-measure-icon svg {
        width: 32px !important;
        height: 32px !important;
        min-width: 32px !important;
        min-height: 32px !important;
        max-width: 32px !important;
        max-height: 32px !important;
    }
}

/* SOLUCIÓN: Ocultar completamente el overflow en la columna del grid */
.carousel-wrapper-with-code .main-slider-row-custom {
    overflow: hidden !important;
}

.carousel-wrapper-with-code .main-slider-row-custom > * {
    min-width: 0 !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
}

/* Contenedor stage: recorte absoluto con inset negativo para compensar gap del grid */
.carousel-wrapper-with-code .main-slider-container--stage {
    overflow: hidden !important;
    overflow-x: clip !important;
    overflow-y: visible !important;
    /* Compensar el gap del grid que empuja el contenido */
    margin-left: calc(-1 * clamp(1px, 0.6vw, 5px)) !important;
    margin-right: calc(-1 * clamp(1px, 0.6vw, 5px)) !important;
    padding-left: clamp(1px, 0.6vw, 5px) !important;
    padding-right: clamp(1px, 0.6vw, 5px) !important;
}

/* Swiper root: bloquear expansión */
.carousel-wrapper-with-code .main-slider-container--stage .swiper.main-slider {
    overflow: hidden !important;
    overflow-x: clip !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Wrapper: forzar ancho contenedor, no viewport */
.carousel-wrapper-with-code .main-slider-container--stage .swiper.main-slider .swiper-wrapper {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    transform-origin: left center !important;
    padding: 0 !important;
    margin: 0 !important;
    /* Forzar que el translate3d solo mueva slides completos */
    will-change: transform !important;
}

/* Slides: ancho forzado al 100% del wrapper */
.carousel-wrapper-with-code .main-slider-container--stage .swiper.main-slider .swiper-slide {
    width: 100% !important;
    min-width: 100% !important;
    max-width: 100% !important;
    flex-shrink: 0 !important;
    flex-grow: 0 !important;
    flex-basis: 100% !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
}

/* Contenedor de zoom: ajustado */
.carousel-wrapper-with-code .main-slider .swiper-slide.img .swiper-zoom-container {
    overflow: hidden !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Imágenes: contenidas */
.carousel-wrapper-with-code .main-slider .swiper-slide.img img {
    max-width: 100% !important;
    width: auto !important;
    height: auto !important;
    box-sizing: border-box !important;
}

/* Mobile: ajustes específicos */
@media (max-width: 768px) {
    .carousel-wrapper-with-code .main-slider-container--stage {
        margin-left: calc(-1 * 2px) !important;
        margin-right: calc(-1 * 2px) !important;
        padding-left: 2px !important;
        padding-right: 2px !important;
    }

    /* Corazón del carril derecho en position:absolute; sin esto overflow:hidden del grid lo recorta */
    .carousel-wrapper-with-code .main-slider-row-custom > .main-slider-rail--right {
        overflow: visible !important;
    }
}

@media (max-width: 480px) {
    .carousel-wrapper-with-code .main-slider-container--stage {
        margin-left: -2px !important;
        margin-right: -2px !important;
        padding-left: 2px !important;
        padding-right: 2px !important;
    }
}

/* SOLUCIÓN DE EMERGENCIA: Ocultar slides no activos */
.carousel-wrapper-with-code .main-slider .swiper-slide {
    opacity: 0 !important;
    visibility: hidden !important;
    transition: opacity 0.3s ease, visibility 0s 0.3s !important;
}

.carousel-wrapper-with-code .main-slider .swiper-slide-active {
    opacity: 1 !important;
    visibility: visible !important;
    transition: opacity 0.3s ease, visibility 0s !important;
}

.carousel-wrapper-with-code .main-slider .swiper-slide-prev,
.carousel-wrapper-with-code .main-slider .swiper-slide-next {
    opacity: 0 !important;
    visibility: hidden !important;
}

/* Asegurar que el CTA slide también se muestre cuando esté activo */
.carousel-wrapper-with-code .main-slider .swiper-slide.product-main-slide-cta.swiper-slide-active {
    opacity: 1 !important;
    visibility: visible !important;
}

/* Modal registro: esta hoja carga al final en producto; refuerza layout si otras reglas compiten */
#registrar-box.login-popup--register,
#registrar-box2.login-popup--register,
#registrar-box3.login-popup--register,
#registrar-box4.login-popup--register {
    box-sizing: border-box !important;
    max-width: min(25rem, calc(100vw - 1.5rem)) !important;
    width: min(25rem, calc(100vw - 1.5rem)) !important;
    padding: 2.75rem 14px 22px 14px !important;
    overflow: visible !important;
}

#registrar-box.login-popup--register > a.close,
#registrar-box2.login-popup--register > a.close,
#registrar-box3.login-popup--register > a.close,
#registrar-box4.login-popup--register > a.close {
    position: absolute !important;
    top: 0.5rem !important;
    right: 0.5rem !important;
    z-index: 10 !important;
    line-height: 0 !important;
}

#registrar-box.login-popup--register > a.close img.btn_close,
#registrar-box2.login-popup--register > a.close img.btn_close,
#registrar-box3.login-popup--register > a.close img.btn_close,
#registrar-box4.login-popup--register > a.close img.btn_close {
    float: none !important;
    margin: 0 !important;
    display: block !important;
}

#registrar-box .buttonlog.buttonlog--register,
#registrar-box2 .buttonlog.buttonlog--register,
#registrar-box3 .buttonlog.buttonlog--register,
#registrar-box4 .buttonlog.buttonlog--register {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    margin: 1.5rem 0 0.85rem !important;
}

form.signin--register .login-popup__password-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    grid-template-rows: auto auto !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
}

form.signin--register .login-popup__password-row .login-popup__password-toggle {
    position: static !important;
}
