.imagenes-container {
    display: grid;
    gap: 20px;
    padding: 20px 0;
}

/* Móvil: 1 columna */
.imagenes-container {
    grid-template-columns: 1fr;
}

/* Tablet: 2 columnas */
@media (min-width: 768px) {
    .imagenes-container {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Escritorio: 3 columnas */
@media (min-width: 1024px) {
    .imagenes-container {
        grid-template-columns: repeat(3, 1fr);
    }
}

.imagenes-container img {
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.imagenes-container img:hover {
    transform: translateY(-5px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
}

.titulo {
    justify-self: center;
    margin: 2% 0;
}

.fancybox-title.fancybox-title-float-wrap {
    visibility: hidden !important;
}


/* Efecto lupa solo para escritorio */
@media (min-width: 1024px) {
    .imagen-zoom-container {
        position: relative;
        overflow: hidden;
        border-radius: 8px;
        cursor: zoom-in;
    }

    .imagen-zoom-container img {
        transition: transform 0.3s ease;
        transform-origin: center;
    }

    .imagen-zoom-container:hover img {
        transform: scale(1.5);
    }

    /* Lupa con zoom específico en punto del cursor */
    .imagen-lupa {
        position: relative;
        overflow: hidden;
        cursor: none;
    }

    .imagen-lupa img {
        transition: none;
    }

    .lupa-zoom {
        position: absolute;
        border: 3px solid #fff;
        border-radius: 50%;
        width: 150px;
        height: 150px;
        background-repeat: no-repeat;
        background-size: 300% 300%;
        box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);
        pointer-events: none;
        opacity: 0;
        transition: opacity 0.3s ease;
    }

    .imagen-lupa:hover .lupa-zoom {
        opacity: 1;
    }
}

/* Fancybox solo para móvil y tablet */
@media (max-width: 1023px) {
    .imagen-clickable {
        cursor: pointer;
    }
}