.gallery-background {
    /* background-color: black; */
    background-color: #f6f6f6;
}

.div-gallery {
    transition: transform 0.3s ease;
}
.div-gallery:hover{
    transform: scale(1.07);
}

.gallery-card {
    background-color: #f2f2f2;
    border: none;
    position: relative;
    overflow: hidden;
    border-radius: 5px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.gallery-thumbnail {
    width: 100%;
    height: 250px;
    object-fit: cover;
    transition: filter 0.3s ease;
}

.gallery-card:hover .gallery-thumbnail {
    filter: brightness(60%);
}

.gallery-title-overlay {
    position: absolute;
    bottom: 0;
    width: 100%;
    padding: 0.8rem;
    background: linear-gradient(to top, 
    rgba(0, 0, 0, 0.7), 
    rgba(0, 0, 0, 0.5), 
    transparent);
}

.gallery-title-overlay h5 {
    color: white;
    font-size: 1.1rem;
    font-weight: 600;
    margin: 0;
}

.gallery-description-overlay {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: white;
    font-size: 1rem;
    font-weight: 500;
    text-align: center;
    opacity: 0;
    transition: opacity 0.3s ease;
    pointer-events: none;
    width: 90%;
}

.gallery-card:hover .gallery-description-overlay {
    opacity: 1;
}

.gallery-image {
    transition: transform 0.3s ease;
}

.gallery-image:hover {
    transform: scale(1.05);
}

.modal-header {
    background-color: black;
    color: #fff;
    border-radius: 0;
}

.modal-header .btn-close {
    filter: invert(1);
}

.modal-body {
    background-color: #F2F2F2;
    max-height: 80dvh;
    overflow-y: auto;
    scroll-behavior: smooth;
}

.fade-in {
    opacity: 0;
    transform: scale(0.95);
    animation: fadeInZoom 0.4s ease-out forwards;
}

@keyframes fadeInZoom {
    to {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes zoomIn {
    from {
        transform: scale(0.8);
        opacity: 0;
    }

    to {
        transform: scale(1);
        opacity: 1;
    }
}

.load-more {
    text-align: right;
    margin-top: 1rem;
}

@keyframes zoomOut {
    from {
        transform: scale(1);
        opacity: 1;
    }
    to {
        transform: scale(0.8);
        opacity: 0;
    }
}

.image-viewer-content.zoom-out {
    animation: zoomOut 0.3s ease forwards;
}
