/*********************************************************
    Lazy loading
*********************************************************/

[data-src] {
    opacity: 0;
}

.lazy-loading {
    opacity: 0;
    transition: opacity 0.3s ease;
}

.lazy-loading-active {
    opacity: 0.5;
}

.lazy-loaded {
    opacity: 1;
}

.lazy-load-error {
    border: 2px dashed #ff6b6b;
}

.lazy-load-failed {
    background-color: #f8f9fa;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #6c757d;
}

.lazy-loading[data-src] {
    filter: blur(10px);
    transform: scale(1.02);
    transition: filter 0.3s ease, transform 0.3s ease;
}

.lazy-loaded[data-src] {
    filter: blur(0);
    transform: scale(1);
}

.lazy-container {
    position: relative;
    overflow: hidden;
}

.lazy-container::before {
    content: '';
    display: block;
    padding-top: 56.25%;
}

.lazy-container img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}