/* Dialog — modal popup */

.maf-dialog {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--maf-space-4);
    pointer-events: none;
}

/* Scrim */

.maf-dialog__scrim {
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.5);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        opacity 250ms var(--maf-easing-standard),
        visibility 250ms var(--maf-easing-standard);
}

.maf-dialog--open .maf-dialog__scrim {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

/* Panel */

.maf-dialog__panel {
    position: relative;
    width: 100%;
    max-width: 480px;
    max-height: calc(100vh - 4rem);
    display: flex;
    flex-direction: column;
    background-color: var(--maf-white);
    border-radius: var(--maf-radius-lg);
    box-shadow:
        0 11px 15px -7px rgba(0, 0, 0, 0.2),
        0 24px 38px 3px rgba(0, 0, 0, 0.14),
        0 9px 46px 8px rgba(0, 0, 0, 0.12);
    pointer-events: none;
    transform: scale(0.9);
    opacity: 0;
    transition:
        transform 250ms var(--maf-easing-enter),
        opacity 200ms var(--maf-easing-enter);
}

.maf-dialog--open .maf-dialog__panel {
    pointer-events: auto;
    transform: scale(1);
    opacity: 1;
}

/* Header */

.maf-dialog__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--maf-space-5) var(--maf-space-6) var(--maf-space-3);
    flex-shrink: 0;
}

.maf-dialog__title {
    font-family: var(--maf-font-display);
    font-weight: var(--maf-font-weight-bold);
    font-size: var(--maf-font-size-lg);
    color: var(--maf-navy);
    margin: 0;
}

.maf-dialog__close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--maf-grey-600);
    cursor: pointer;
    border-radius: 50%;
    flex-shrink: 0;
    margin-right: calc(-1 * var(--maf-space-2));
    transition: background-color var(--maf-duration-fast) var(--maf-easing-standard);
}

.maf-dialog__close:hover {
    background-color: rgba(45, 63, 88, 0.08);
    color: var(--maf-navy);
}

.maf-dialog__close:focus-visible {
    outline: 2px solid var(--maf-color-info);
    outline-offset: 2px;
}

.maf-dialog__close svg {
    width: 20px;
    height: 20px;
}

/* Body */

.maf-dialog__body {
    padding: var(--maf-space-2) var(--maf-space-6);
    overflow-y: auto;
    font-family: var(--maf-font-body);
    font-size: var(--maf-font-size-md);
    line-height: var(--maf-line-height-normal);
    color: var(--maf-color-text);
}

/* Footer */

.maf-dialog__footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--maf-space-3);
    padding: var(--maf-space-4) var(--maf-space-6) var(--maf-space-5);
    flex-shrink: 0;
}
