/*
 * Offer Gallery component — responsive image grid.
 * Desktop: 3 columns. Tablet: 2 columns. Mobile: 1 column.
 */

.tv-offer-gallery {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--tv-space-6);
    width: 100%;
}

.tv-offer-gallery__title {
    font-family: var(--tv-font-heading);
    font-size: 1.75rem;
    color: var(--tv-color-text);
    margin: 0 0 var(--tv-space-6);
    font-weight: 800;
}

.tv-offer-gallery__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--tv-space-4);
}

.tv-offer-gallery__item {
    display: block;
    overflow: hidden;
    aspect-ratio: 4 / 3;
    background: var(--tv-color-cream);
    transition: transform 0.2s ease;
}

.tv-offer-gallery__item:hover,
.tv-offer-gallery__item:focus-visible {
    transform: translateY(-2px);
}

.tv-offer-gallery__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}

.tv-offer-gallery__item:hover .tv-offer-gallery__img,
.tv-offer-gallery__item:focus-visible .tv-offer-gallery__img {
    transform: scale(1.04);
}

@media (max-width: 1024px) {
    .tv-offer-gallery__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    .tv-offer-gallery {
        padding: 0 var(--tv-space-4);
    }

    .tv-offer-gallery__grid {
        grid-template-columns: 1fr;
    }
}
