/* Skeleton Loader Styles */
.skeleton-loader {
    position: relative;
    overflow: hidden;
    background: linear-gradient(90deg, #1a1a1a 25%, #2a2a2a 50%, #1a1a1a 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s ease-in-out infinite;
}

@keyframes skeleton-loading {
    0% {
        background-position: 200% 0;
    }
    100% {
        background-position: -200% 0;
    }
}

/* GLOBAL: Auto-apply skeleton to all card images */
.movie-card .card-head,
.app-card .card-head,
.game-card .card-head,
.software-card .card-head,
.card-head {
    position: relative;
    overflow: hidden;
    background: #1a1a1a;
}

/* Add skeleton overlay to card images while loading */
.movie-card .card-head::before,
.app-card .card-head::before,
.game-card .card-head::before,
.software-card .card-head::before,
.card-head::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, #1a1a1a 25%, #2a2a2a 50%, #1a1a1a 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s ease-in-out infinite;
    z-index: 1;
    opacity: 1;
    transition: opacity 0.4s ease-in-out;
    pointer-events: none;
}

/* Hide skeleton when image is loaded */
.movie-card .card-head.loaded::before,
.app-card .card-head.loaded::before,
.game-card .card-head.loaded::before,
.software-card .card-head.loaded::before,
.card-head.loaded::before {
    opacity: 0;
}

/* Card images start hidden and fade in */
.movie-card .card-img,
.app-card .card-img,
.game-card .card-img,
.software-card .card-img,
.card-img {
    opacity: 0;
    transition: opacity 0.4s ease-in-out;
    position: relative;
    z-index: 2;
}

/* Show image when loaded */
.movie-card .card-img.loaded,
.app-card .card-img.loaded,
.game-card .card-img.loaded,
.software-card .card-img.loaded,
.card-img.loaded {
    opacity: 1;
}

/* Image container with skeleton */
.image-container {
    position: relative;
    overflow: hidden;
    background: #1a1a1a;
}

.image-container img {
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
}

.image-container img.loaded {
    opacity: 1;
}

/* Skeleton overlay */
.skeleton-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, #1a1a1a 25%, #2a2a2a 50%, #1a1a1a 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s ease-in-out infinite;
    z-index: 1;
    pointer-events: none;
}

.skeleton-overlay.hidden {
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
}

/* Card skeleton for movie/series cards */
.card-skeleton {
    border-radius: 8px;
    overflow: hidden;
}

.card-skeleton .skeleton-image {
    width: 100%;
    aspect-ratio: 2/3;
    background: linear-gradient(90deg, #1a1a1a 25%, #2a2a2a 50%, #1a1a1a 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s ease-in-out infinite;
}

.card-skeleton .skeleton-title {
    height: 20px;
    margin: 10px;
    border-radius: 4px;
    background: linear-gradient(90deg, #1a1a1a 25%, #2a2a2a 50%, #1a1a1a 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s ease-in-out infinite;
}

.card-skeleton .skeleton-text {
    height: 14px;
    margin: 10px;
    width: 60%;
    border-radius: 4px;
    background: linear-gradient(90deg, #1a1a1a 25%, #2a2a2a 50%, #1a1a1a 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s ease-in-out infinite;
}

/* Lazy load image wrapper */
.lazy-image-wrapper {
    position: relative;
    overflow: hidden;
    background: #1a1a1a;
}

.lazy-image-wrapper::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, #1a1a1a 25%, #2a2a2a 50%, #1a1a1a 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s ease-in-out infinite;
    z-index: 1;
    opacity: 1;
    transition: opacity 0.3s ease-in-out;
}

.lazy-image-wrapper.loaded::before {
    opacity: 0;
}

.lazy-image-wrapper img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
}

.lazy-image-wrapper.loaded img {
    opacity: 1;
}

/* Shimmer effect variant */
.shimmer {
    background: linear-gradient(
        90deg,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, 0.05) 50%,
        rgba(255, 255, 255, 0) 100%
    );
    background-size: 200% 100%;
    animation: shimmer 1.5s ease-in-out infinite;
}

@keyframes shimmer {
    0% {
        background-position: -200% 0;
    }
    100% {
        background-position: 200% 0;
    }
}

/* Pulse effect variant */
.pulse {
    animation: pulse 1.5s ease-in-out infinite;
}

@keyframes pulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.5;
    }
}
