/* Product Card Skeleton Loader */
.skeleton-loader {
    position: relative;
    overflow: hidden;
    background-color: #f0f0f0;
}

.skeleton-loader::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    transform: translateX(-100%);
    background: linear-gradient(
        90deg,
        rgba(255, 255, 255, 0) 0,
        rgba(255, 255, 255, 0.2) 20%,
        rgba(255, 255, 255, 0.5) 60%,
        rgba(255, 255, 255, 0)
    );
    animation: shimmer 2s infinite;
}

@keyframes shimmer {
    100% {
        transform: translateX(100%);
    }
}

/* Product Card Skeleton Structure */
.product-card-skeleton {
    display: block;
    width: 100%;
}

.product-card-skeleton .skeleton-image {
    width: 100%;
    padding-top: 100%; /* 1:1 Aspect Ratio */
    background-color: #e0e0e0;
    border-radius: 4px;
    margin-bottom: 10px;
}

.product-card-skeleton .skeleton-title {
    height: 16px;
    background-color: #e0e0e0;
    border-radius: 4px;
    margin-bottom: 8px;
    width: 80%;
}

.product-card-skeleton .skeleton-price {
    height: 14px;
    background-color: #e0e0e0;
    border-radius: 4px;
    width: 40%;
}

.product-card-skeleton .skeleton-badge {
    height: 20px;
    width: 60px;
    background-color: #e0e0e0;
    border-radius: 12px;
    margin-bottom: 8px;
}

/* POS Product Card Skeleton */
.pos-product-skeleton {
    width: 140px;
    margin: 0 8px;
}

@media (min-width: 1200px) {
    .pos-product-skeleton {
        width: 180px;
    }
}

@media (min-width: 1400px) {
    .pos-product-skeleton {
        width: 210px;
    }
}

.pos-product-skeleton .skeleton-image {
    height: 120px;
    background-color: #e0e0e0;
    border-radius: 4px 4px 0 0;
}

@media (min-width: 1200px) {
    .pos-product-skeleton .skeleton-image {
        height: 180px;
    }
}

@media (min-width: 1400px) {
    .pos-product-skeleton .skeleton-image {
        height: 210px;
    }
}

.pos-product-skeleton .skeleton-body {
    padding: 8px 12px;
}

.pos-product-skeleton .skeleton-title {
    height: 14px;
    background-color: #e0e0e0;
    border-radius: 4px;
    margin-bottom: 8px;
    width: 90%;
}

.pos-product-skeleton .skeleton-price {
    height: 12px;
    background-color: #e0e0e0;
    border-radius: 4px;
    width: 50%;
}

/* Frontend Product Card Skeleton */
.frontend-product-skeleton .skeleton-image {
    padding-top: 100%;
    background-color: #e0e0e0;
    border-radius: 4px;
    margin-bottom: 12px;
}

.frontend-product-skeleton .skeleton-title {
    height: 18px;
    background-color: #e0e0e0;
    border-radius: 4px;
    margin-bottom: 10px;
    width: 85%;
}

.frontend-product-skeleton .skeleton-subtitle {
    height: 14px;
    background-color: #e0e0e0;
    border-radius: 4px;
    margin-bottom: 8px;
    width: 60%;
}

.frontend-product-skeleton .skeleton-price {
    height: 16px;
    background-color: #e0e0e0;
    border-radius: 4px;
    width: 45%;
    margin-bottom: 8px;
}

.frontend-product-skeleton .skeleton-rating {
    height: 12px;
    background-color: #e0e0e0;
    border-radius: 4px;
    width: 70%;
}

/* Hide actual product card while loading */
.product-loading .product-card-content {
    display: none;
}

.product-loading .product-card-skeleton {
    display: block;
}

.product-loaded .product-card-skeleton {
    display: none;
}

.product-loaded .product-card-content {
    display: block;
}

