/**
 * Scroll-safe modal layout — overlay + nagłówek/stopka na miejscu, przewijana treść.
 * Dołączany globalnie; strony z własnymi stylami modali powinny zachować ten sam wzorzec.
 */

.modal {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding: max(16px, 2vh) 16px;
    box-sizing: border-box;
}

.modal > .modal-content {
    margin: 0 auto;
    max-height: calc(100vh - max(32px, 4vh));
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.modal .modal-header,
.modal .modal-footer {
    flex-shrink: 0;
}

.modal .modal-body {
    overflow-y: auto;
    flex: 1 1 auto;
    min-height: 0;
    -webkit-overflow-scrolling: touch;
}
