/* modal */

div.modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;

    z-index: 8888;
}

div.modal > div.container {
    position: absolute;
    top: 50%;
    left: 50%;

    width: 100%;

    transform: translate(-50%, -50%);

    background: var(--color-white);

    box-shadow: 0 0 20rem 0 var(--color-dark-24);

    border-radius: 1rem;

    z-index: 88;
}

div.modal.sm > div.container {
    max-width: 20rem;
}

div.modal.md > div.container {
    max-width: 30rem;
}

div.modal.lg > div.container {
    max-width: 40rem;
}

div.modal.xl > div.container {
    max-width: 50rem;
}

div.modal > div.container > div.header {
    display: flex;
    align-items: center;
    justify-content: space-between;

    padding: .85rem .85rem .85rem 1.25rem;

    border-bottom: 1px solid var(--color-dark-16);
}

div.modal > div.container > div.header > span.title {
    font-weight: 600;
}

div.modal > div.container > div.header > button.close {
    width: 2rem;
    height: 2rem;

    display: inline-flex;
    align-items: center;
    justify-content: center;

    border-radius: 0.5rem;

    color: var(--color-dark-72);

    cursor: pointer;
}

div.modal > div.container > div.header > button.close:hover {
    background: var(--color-dark-04);
}

div.modal > div.container > div.header > button.close > i {
    width: 2rem;
    height: 2rem;

    display: inline-flex;
    align-items: center;
    justify-content: center;

    font-size: 1.5rem;
}

div.modal > div.container > div.body {
    padding: 1.25rem;

    display: flex;
    flex-direction: column;
    gap: 1rem;

    overflow-y: auto;

    max-height: 80vh;

    border-radius: 1rem;
}

div.modal > div.backdrop {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;

    background: var(--color-dark-48);

    z-index: 8;
}