body {
    font-size: 0.9rem;
}

#wrapper {
    min-height: 100vh;
}

nav .nav-link:hover {
    background-color: rgba(255, 255, 255, 0.1);
    border-radius: 0.375rem;
}

/* Full-screen modals on small screens */
@media (max-width: 575.98px) {
    .modal-dialog {
        margin: 0;
        max-width: 100%;
        height: 100%;
    }
    .modal-content {
        border-radius: 0;
        min-height: 100%;
    }
    .modal-dialog-scrollable .modal-content {
        max-height: 100vh;
    }
}

/* Wrap page-header action rows on mobile */
.page-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

/* Ensure tables with many columns scroll rather than squash */
.table-responsive-always {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
