/* Lazy Loading Styles */
.lazy-load {
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
    background-color: #f3f4f6;
}

.lazy-load.loaded {
    opacity: 1;
}

/* Placeholder shimmer effect */
.lazy-load:not(.loaded) {
    background: linear-gradient(90deg, #f3f4f6 25%, #e5e7eb 50%, #f3f4f6 75%);
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
    0% {
        background-position: 200% 0;
    }
    100% {
        background-position: -200% 0;
    }
}

/* Prevent layout shift */
.property-image-container {
    position: relative;
    overflow: hidden;
    background-color: #f3f4f6;
}

.property-image-container img {
    width: 100%;
    height: auto;
    display: block;
}