/* ==========================================================================
   Estilos personalizados para DataTables y Modales
   ========================================================================== */

/* DataTables customization */
.dataTables_wrapper {
    margin-top: 1rem;
}

.dataTables_filter {
    margin-bottom: 1rem;
}

.dataTables_filter input {
    border-radius: 6px;
    border: 1px solid #e2e8f0;
    padding: 0.5rem 1rem;
    transition: all 0.3s ease;
}

.dataTables_filter input:focus {
    border-color: #667eea;
    box-shadow: 0 0 0 0.2rem rgba(102, 126, 234, 0.25);
    outline: none;
}

.dataTables_length select {
    border-radius: 6px;
    border: 1px solid #e2e8f0;
    padding: 0.375rem 0.75rem;
    background-color: white;
}

.dataTables_info {
    color: #6b7280;
    font-size: 0.875rem;
}

.dataTables_paginate .paginate_button {
    border-radius: 6px !important;
    margin: 0 2px;
    transition: all 0.3s ease;
}

.dataTables_paginate .paginate_button:hover {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
    border-color: #667eea !important;
    color: white !important;
}

.dataTables_paginate .paginate_button.current {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
    border-color: #667eea !important;
    color: white !important;
}

.table thead th {
    background: linear-gradient(135deg, #17501C 0%,#17501C 100%);
    border: none;
    font-weight: 600;
    color: white;
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.05em;
    padding: 1rem 0.75rem;
}

.table tbody td {
    padding: 1rem 0.75rem;
    vertical-align: middle;
    border-bottom: 1px solid #f1f5f9;
    transition: background-color 0.2s ease;
}

.table tbody tr:hover {
    background-color: #f8fafc;
}

/* Botones de acción */
.btn-group .btn {
    margin: 0 1px;
    transition: all 0.3s ease;
}

.btn-outline-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(102, 126, 234, 0.3);
}

.btn-outline-danger:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(239, 68, 68, 0.3);
}

/* Modal mejorado */
.modal-content {
    border: none;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    border-radius: 12px;
}

.modal-header {
    border-bottom: 1px solid #f1f5f9;
    padding: 1.5rem;
}

.modal-body {
    padding: 1.5rem;
}

.modal-footer {
    border-top: 1px solid #f1f5f9;
    padding: 1.5rem;
}

/* Formularios en modales */
.form-label {
    font-weight: 600;
    color: #374151;
    margin-bottom: 0.5rem;
}

.form-control, .form-select {
    border-radius: 6px;
    border: 1px solid #e2e8f0;
    padding: 0.75rem 1rem;
    transition: all 0.3s ease;
    font-size: 0.875rem;
}

.form-control:focus, .form-select:focus {
    border-color: #667eea;
    box-shadow: 0 0 0 0.2rem rgba(102, 126, 234, 0.25);
    outline: none;
}

.form-text {
    font-size: 0.75rem;
    color: #6b7280;
    margin-top: 0.25rem;
}

.invalid-feedback {
    display: block;
    font-size: 0.75rem;
    color: #ef4444;
    margin-top: 0.25rem;
}

.form-control.is-invalid, .form-select.is-invalid {
    border-color: #ef4444;
    box-shadow: 0 0 0 0.2rem rgba(239, 68, 68, 0.25);
}

/* Alertas mejoradas */
.alert {
    border: none;
    border-radius: 8px;
    font-size: 0.875rem;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.alert-success {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    color: white;
}

.alert-danger {
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
    color: white;
}

.alert-warning {
    background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
    color: white;
}

.alert-info {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
    color: white;
}

/* Badges personalizados */
.badge {
    font-size: 0.75rem;
    padding: 0.5rem 0.75rem;
    border-radius: 6px;
}

/* Imagen thumbnail mejorada */
.img-thumbnail {
    border: 2px solid #e2e8f0;
    border-radius: 8px;
    transition: all 0.3s ease;
    cursor: pointer;
}

.img-thumbnail:hover {
    border-color: #667eea;
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.3);
}

/* Loading spinner */
.spinner-border-sm {
    width: 1rem;
    height: 1rem;
}

/* Botones mejorados */
.btn {
    border-radius: 6px;
    font-weight: 500;
    transition: all 0.3s ease;
    border: none;
}


/* Responsive mejoras */
@media (max-width: 768px) {
    .btn-group .btn {
        margin-bottom: 0.25rem;
    }

    .modal-dialog {
        margin: 1rem;
    }

    .card-header {
        flex-direction: column;
        gap: 1rem;
    }

    .card-header .btn {
        width: 100%;
    }
}

/* Animaciones sutiles */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.card {
    animation: fadeInUp 0.5s ease-out;
}

.modal.fade .modal-dialog {
    transition: transform 0.3s ease-out;
    transform: translate(0, -50px);
}

.modal.show .modal-dialog {
    transform: none;
}

/* DataTables buttons */
.dt-buttons {
    margin-bottom: 1rem;
}

.dt-buttons .btn {
    margin-right: 0.5rem;
    margin-bottom: 0.5rem;
    font-size: 0.875rem;
    padding: 0.5rem 1rem;
}

/* Mejoras para pantallas pequeñas */
.table-responsive table {
    min-width: 600px;
}

@media (max-width: 576px) {
    .table-responsive table {
        min-width: 500px;
        font-size: 0.875rem;
    }

    .table tbody td {
        padding: 0.75rem 0.5rem;
    }

    .btn-group .btn {
        padding: 0.375rem 0.5rem;
        font-size: 0.75rem;
    }
}

.btn-success {
    background-color: #2EA039; /* Foundation/Green/G300 */
    color: white;
}

/* Los texto de la paginacion de bootstrap va a usar este color: #17501C; */

.pagination .page-link {
    border-radius: 6px;
    margin: 0 2px;
    border: 1px solid #dee2e6;
    color: #17501C;
}

.active>.page-link, .page-link.active {
    z-index: 3;
    color: #fff;
    background-color: #17501C;
    border-color: #17501C;
}

.pagination {
    --bs-pagination-padding-x: 0.75rem;
    --bs-pagination-padding-y: 0.375rem;
    --bs-pagination-font-size: 1rem;
    --bs-pagination-color: #17501C;
    --bs-pagination-bg: var(--bs-body-bg);
    --bs-pagination-border-width: var(--bs-border-width);
    --bs-pagination-border-color: var(--bs-border-color);
    --bs-pagination-border-radius: var(--bs-border-radius);
    --bs-pagination-hover-color: #fff;
    --bs-pagination-hover-bg: #2a7d2e;
    --bs-pagination-hover-border-color: #17501C;
    --bs-pagination-focus-color: #fff;
    --bs-pagination-focus-bg: #2a7d2e;
    --bs-pagination-focus-box-shadow: 0 0 0 0.25rem rgba(23, 80, 28, 0.25);
    --bs-pagination-active-color: #fff;
    --bs-pagination-active-bg: #17501C;
    --bs-pagination-active-border-color: #17501C;
    --bs-pagination-disabled-color: var(--bs-secondary-color);
    --bs-pagination-disabled-bg: var(--bs-secondary-bg);
    --bs-pagination-disabled-border-color: var(--bs-border-color);
    display: flex;
    padding-left: 0;
    list-style: none;
}

.pagination .page-item.active .page-link {
    background-color: #17501C !important;
    border-color: #17501C !important;
}

.page-link:hover {

    color: white !important;
}

.card {
    border-top: 2px solid #17501C !important;
}

.swal2-actions {
    .swal2-confirm {
        background-color: #17501C !important;
        color: white !important;
    }
    .swal2-cancel {
        background-color: red !important;
        color: white !important;
    }
}
