/* Product photo lightbox polish: normalized controls and smooth image transitions. */

.product-lightbox,
.product-gallery {
    isolation: isolate;
}

.product-gallery {
    position: relative !important;
}

.product-lightbox[aria-hidden="false"],
.product-lightbox.is-open {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.product-lightbox__image-button {
    position: relative !important;
    overflow: hidden !important;
    display: grid !important;
    place-items: center !important;
    border: 0 !important;
    background: transparent !important;
    cursor: zoom-in !important;
}

.product-lightbox__image-button img,
.product-main-photo img {
    transition: opacity .24s ease, transform .24s ease !important;
    will-change: opacity, transform;
}

.product-lightbox__image-button.is-changing img,
.product-main-photo.is-changing img {
    opacity: 0 !important;
    transform: scale(.985) !important;
}

.product-gallery-arrow {
    position: absolute !important;
    top: clamp(190px, 34vw, 360px) !important;
    z-index: 7 !important;
    display: grid !important;
    place-items: center !important;
    width: 46px !important;
    height: 46px !important;
    min-width: 46px !important;
    min-height: 46px !important;
    padding: 0 !important;
    border: 1px solid rgba(17, 26, 54, .08) !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, .94) !important;
    box-shadow: 0 14px 34px rgba(17, 26, 54, .14) !important;
    backdrop-filter: blur(12px) !important;
    cursor: pointer !important;
    opacity: .94 !important;
    transform: translateY(-50%) !important;
    transition: opacity .18s ease, transform .18s ease, background .18s ease, box-shadow .18s ease !important;
}

.product-gallery-arrow--prev {
    left: 18px !important;
}

.product-gallery-arrow--next {
    right: 18px !important;
}

.product-gallery-arrow:hover,
.product-gallery-arrow:focus-visible {
    opacity: 1 !important;
    background: #fff !important;
    box-shadow: 0 18px 42px rgba(17, 26, 54, .20) !important;
}

.product-gallery-arrow:active {
    transform: translateY(-50%) scale(.96) !important;
}

.product-gallery-arrow img {
    width: 20px !important;
    height: 20px !important;
    display: block !important;
    object-fit: contain !important;
    opacity: .92 !important;
}

.product-lightbox__arrow,
.product-lightbox__close {
    position: fixed !important;
    z-index: 5 !important;
    display: grid !important;
    place-items: center !important;
    width: 52px !important;
    height: 52px !important;
    min-width: 52px !important;
    min-height: 52px !important;
    padding: 0 !important;
    border: 1px solid rgba(255, 255, 255, .34) !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, .94) !important;
    color: #111a36 !important;
    box-shadow: 0 14px 34px rgba(0, 0, 0, .18) !important;
    backdrop-filter: blur(12px) !important;
    cursor: pointer !important;
    opacity: .92 !important;
    transform: translateY(-50%) !important;
    transition: opacity .18s ease, transform .18s ease, background .18s ease, box-shadow .18s ease !important;
}

.product-lightbox__arrow:hover,
.product-lightbox__close:hover {
    opacity: 1 !important;
    background: #fff !important;
    box-shadow: 0 18px 42px rgba(0, 0, 0, .24) !important;
}

.product-lightbox__arrow:active,
.product-lightbox__close:active {
    transform: translateY(-50%) scale(.96) !important;
}

.product-lightbox__arrow img,
.product-lightbox__close img {
    display: block !important;
    width: 22px !important;
    height: 22px !important;
    object-fit: contain !important;
    opacity: .96 !important;
    filter: none !important;
}

.product-lightbox__arrow--prev {
    left: max(28px, env(safe-area-inset-left)) !important;
    top: 50% !important;
}

.product-lightbox__arrow--next {
    right: max(28px, env(safe-area-inset-right)) !important;
    top: 50% !important;
}

.product-lightbox__close {
    top: max(38px, calc(24px + env(safe-area-inset-top))) !important;
    right: max(28px, env(safe-area-inset-right)) !important;
    transform: none !important;
}

.product-lightbox__close:active {
    transform: scale(.96) !important;
}

.product-lightbox__count {
    position: fixed !important;
    left: 50% !important;
    bottom: max(26px, calc(18px + env(safe-area-inset-bottom))) !important;
    transform: translateX(-50%) !important;
    z-index: 5 !important;
    min-height: 36px !important;
    padding: 0 14px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(255, 255, 255, .94) !important;
    color: #111a36 !important;
    font-size: 14px !important;
    font-weight: 950 !important;
    box-shadow: 0 12px 30px rgba(0, 0, 0, .16) !important;
    backdrop-filter: blur(12px) !important;
}

@media (max-width: 767px) {
    .product-gallery-arrow {
        top: clamp(180px, 64vw, 390px) !important;
        width: 42px !important;
        height: 42px !important;
        min-width: 42px !important;
        min-height: 42px !important;
    }

    .product-gallery-arrow--prev {
        left: 10px !important;
    }

    .product-gallery-arrow--next {
        right: 10px !important;
    }

    .product-gallery-arrow img {
        width: 18px !important;
        height: 18px !important;
    }

    .product-lightbox__arrow,
    .product-lightbox__close {
        width: 46px !important;
        height: 46px !important;
        min-width: 46px !important;
        min-height: 46px !important;
    }

    .product-lightbox__arrow img,
    .product-lightbox__close img {
        width: 20px !important;
        height: 20px !important;
    }

    .product-lightbox__arrow--prev {
        left: max(12px, env(safe-area-inset-left)) !important;
    }

    .product-lightbox__arrow--next {
        right: max(12px, env(safe-area-inset-right)) !important;
    }

    .product-lightbox__close {
        top: max(16px, calc(12px + env(safe-area-inset-top))) !important;
        right: max(12px, env(safe-area-inset-right)) !important;
    }
}

@media (prefers-reduced-motion: reduce) {
    .product-lightbox__image-button img,
    .product-main-photo img,
    .product-gallery-arrow,
    .product-lightbox__arrow,
    .product-lightbox__close {
        transition: none !important;
    }
}
