/* Стили для ленивой загрузки изображений */

img[data-src] {
    opacity: 0;
    transition: opacity 0.3s ease-in;
}

img.loaded {
    opacity: 1;
}

.lazy-placeholder {
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: loading 1.5s ease-in-out infinite;
}

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

/* Эффект размытия при загрузке */
.blur-up {
    filter: blur(10px);
    transition: filter 0.3s ease-in;
}

.blur-up.loaded {
    filter: blur(0);
}
