html, body {
    height: 100%;
    margin: 0;
}
body {
    display: flex;
    flex-direction: column;
}
main {
    flex: 1;
}

.login-card {
    background-color: white;
    border: 1px solid #d0d0d0;
    border-radius: 10px;
    padding: 30px;
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
    width: 100%;
    max-width: 400px;
}

.input-group .btn {
    padding-top: 0.375rem;
    padding-bottom: 0.375rem;
    height: 100%;
}


/* Animação modal */
.fadeInDown {
    animation: fadeInDown 0.4s ease-out both;
}
@keyframes fadeInDown {
    0% { opacity: 0; transform: translateY(-20px); }
    100% { opacity: 1; transform: translateY(0); }
}
/* Estilização DataTables */
/* Paginação DataTables mobile */
@media (max-width: 576px) {
    .dataTables_wrapper .dataTables_paginate .paginate_button.previous .page-link,
    .dataTables_wrapper .dataTables_paginate .paginate_button.next .page-link {
        font-size: 0;
        padding-left: 0.75rem;
        padding-right: 0.75rem;
    }
    .dataTables_wrapper .dataTables_paginate .paginate_button.previous .page-link::after {
        content: '<<';
        font-size: 1rem;
    }
    .dataTables_wrapper .dataTables_paginate .paginate_button.next .page-link::after {
        content: '>>';
        font-size: 1rem;
    }
}

/* Botão quadrado para ícones */
.btn-square {
    width: 2rem;          /* tamanho sugerido para .btn-sm */
    height: 2rem;
    padding: 0;
    display: inline-flex; /* centraliza o ícone */
    align-items: center;
    justify-content: center;
    line-height: 1;
    aspect-ratio: 1 / 1;  /* redundante, ajuda em alguns casos */
}

