/**
 * IFINSTA Modal Component - Unified Design System
 * Modal dialogs with smooth animations and consistent styling
 */

.ifinsta-modal-wrapper {
    position: fixed;
    inset: 0;
    z-index: var(--ifinsta-z-modal, 900);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--ifinsta-space-4);
    pointer-events: none;
    transition: opacity var(--ifinsta-transition-slow), visibility var(--ifinsta-transition-slow);
}

.ifinsta-modal-wrapper[aria-hidden="true"],
.ifinsta-modal-wrapper.ifinsta-hidden {
    opacity: 0;
    visibility: hidden;
}

.ifinsta-modal-wrapper[aria-hidden="false"]:not(.ifinsta-hidden) {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.ifinsta-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: -1;
}

.ifinsta-modal {
    background: var(--ifinsta-white);
    border-radius: var(--ifinsta-radius-2xl);
    box-shadow: var(--ifinsta-shadow-lg);
    width: 100%;
    max-width: 500px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transform: scale(0.95);
    transition: transform var(--ifinsta-transition-slow);
}

.ifinsta-modal-wrapper[aria-hidden="false"] .ifinsta-modal {
    transform: scale(1);
}

.ifinsta-modal--sm {
    max-width: 400px;
}

.ifinsta-modal__header {
    padding: var(--ifinsta-space-4) var(--ifinsta-space-6);
    border-bottom: 1px solid var(--ifinsta-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.ifinsta-modal__title {
    font-size: var(--ifinsta-h3);
    font-weight: var(--ifinsta-font-semibold);
    color: var(--ifinsta-text-primary);
    margin: 0;
}

.ifinsta-modal__body {
    padding: var(--ifinsta-space-4) var(--ifinsta-space-6);
    color: var(--ifinsta-text-secondary);
    font-size: var(--ifinsta-body);
    line-height: var(--ifinsta-leading-body);
    max-height: 60vh;
    text-align: left;
}

.ifinsta-modal__body p {
    margin-bottom: var(--ifinsta-space-3, 12px);
}

.ifinsta-modal__body p:last-child {
    margin-bottom: 0;
}

.ifinsta-modal__footer {
    padding: var(--ifinsta-space-4) var(--ifinsta-space-6);
    background: var(--ifinsta-surface-1);
    border-top: 1px solid var(--ifinsta-border);
    display: flex;
    justify-content: flex-end;
    gap: var(--ifinsta-space-3);
}

#ifinsta-session-timeout-countdown {
    font-weight: var(--ifinsta-font-bold);
    color: var(--ifinsta-primary);
    font-variant-numeric: tabular-nums;
}

#ifinsta-session-timeout-countdown.ifinsta-text-danger {
    color: var(--ifinsta-danger);
    animation: ifinsta-pulse 1s var(--ifinsta-ease-in-out) infinite;
}

@keyframes ifinsta-pulse {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: .5;
    }
}