/* Mascot Flipbook Loading Animation — shared across all pages */

.mascot-loader {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 40px 20px;
    min-height: 200px;
}

.mascot-loader--sm { min-height: 80px; padding: 16px 12px; }
.mascot-loader--md { min-height: 160px; padding: 32px 20px; }
.mascot-loader--lg { min-height: 300px; padding: 40px 20px; }

.mascot-loader--inline {
    flex-direction: row;
    gap: 12px;
    min-height: auto;
    padding: 12px;
}

.mascot-loader__img {
    width: 80px;
    height: 80px;
    object-fit: contain;
    animation: mascotBounce 0.6s ease-in-out infinite;
}

.mascot-loader--sm .mascot-loader__img { width: 48px; height: 48px; }
.mascot-loader--lg .mascot-loader__img { width: 100px; height: 100px; }
.mascot-loader--inline .mascot-loader__img { width: 36px; height: 36px; }

.mascot-loader__text {
    margin-top: 16px;
    font-size: 1rem;
    color: #666;
    font-weight: 500;
}

.mascot-loader--sm .mascot-loader__text { margin-top: 8px; font-size: 0.85rem; }
.mascot-loader--lg .mascot-loader__text { font-size: 1.1rem; }
.mascot-loader--inline .mascot-loader__text { margin-top: 0; font-size: 0.85rem; }

/* Table-cell variant (used inside <td>) */
.mascot-loader-cell {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 20px 12px;
}

.mascot-loader-cell .mascot-loader__img {
    width: 40px;
    height: 40px;
}

.mascot-loader-cell .mascot-loader__text {
    margin-top: 0;
    font-size: 0.9rem;
}

@keyframes mascotBounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-15px); }
}
