.ml-gallery {
    display: flex !important;
    flex-direction: row !important;
    gap: 20px !important;
    align-items: flex-start !important;
}

.ml-thumbs-wrapper {
    display: flex !important;
    flex-direction: column !important;
    width: 85px !important;
    flex-shrink: 0 !important;
}

.ml-thumbs {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    max-height: 450px !important;
    overflow-y: scroll !important;
    scrollbar-width: none !important; /* Firefox */
}
.ml-thumbs::-webkit-scrollbar { display: none !important; } /* Chrome */

.ml-thumb {
    width: 80px !important;
    height: 80px !important;
    cursor: pointer !important;
    border: 2px solid #f0f0f0 !important;
    object-fit: cover !important;
    transition: 0.2s;
}
.ml-thumb.active { border-color: #3483fa !important; }

.ml-main {
    flex-grow: 1 !important;
}

/* FIX DO ZOOM: Aqui impedimos que a imagem saia do quadrado */
.ml-zoom-container {
    position: relative !important;
    overflow: hidden !important; /* OBRIGATÓRIO PARA NÃO ESTOURAR */
    border: 1px solid #ddd !important;
    background: #fff !important;
    cursor: zoom-in !important;
    display: block !important;
}

#ml-main-image {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    transition: transform 0.15s ease-out !important;
    transform: scale(1) !important;
    display: block !important;
}

.ml-arrow {
    background: none !important;
    border: none !important;
    font-size: 24px !important;
    cursor: pointer !important;
    padding: 5px !important;
}