/* ===== LEVEL UP MODAL FEATURE ===== */
/* Level-up modal enhancements and confetti effects */

/* Prevent level-up modals from being closed by clicking outside */
#level-up-modal.modal-overlay,
#transform-level-up-modal.modal-overlay {
    pointer-events: auto;
}

#level-up-modal.modal-overlay .ds-modal,
#transform-level-up-modal.modal-overlay .ds-modal {
    pointer-events: auto;
}

/* Hide close button on level-up modals if present */
#level-up-modal .modal-close-button,
#transform-level-up-modal .modal-close-button {
    display: none !important;
}

/* Level Up Modal Content */
.level-up-modal-content {
    position: relative;
    overflow: visible;
}

.level-up-modal-body {
    position: relative;
    z-index: 1;
}

/* Level Up Pet Preview */
.level-up-pet-preview,
.level-up-modal-body .level-up-pet-preview,
#level-up-content .level-up-pet-preview {
    width: 100% !important;
    height: 200px !important;
    min-height: 200px !important;
    max-height: 200px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
    flex-shrink: 0 !important;
    box-sizing: border-box !important;
    position: relative !important;
    margin-bottom: var(--spacing-medium);
    /* Prevent content from affecting parent dimensions */
    contain: layout size;
    isolation: isolate;
}

.level-up-pet-info {
    text-align: center;
    margin-bottom: var(--spacing-medium);
}

.level-up-pet-name {
    font-size: var(--font-size-2xl); /* 32px - reduced from 48px for mobile */
    font-weight: var(--font-weight-bold);
    color: var(--color-accent-primary);
    margin-bottom: var(--spacing-small);
}

.level-up-pet-description {
    font-size: var(--font-size-md);
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-medium);
}

/* Pet shop content in level-up modal */
#level-up-pet-shop-content {
    flex: 1;
    overflow: auto;
    min-height: 0;
    -webkit-overflow-scrolling: touch;
}

#level-up-pet-shop-grid {
    padding: var(--spacing-medium);
}

/* Confetti Canvas */
.confetti-canvas {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 2000;
    overflow: hidden;
}

.confetti-particle {
    position: absolute;
    pointer-events: none;
}
