/* Estilos personalizados para el Sistema de Gestión de Granjas - HerdData ARROYOS */

:root {
    /* Colores corporativos HerdData ARROYOS */
    --primary-color: #e85d26;
    /* Naranja corporativo principal (HerdData) */
    --secondary-color: #475569;
    /* Azul grisáceo */
    --success-color: #059669;
    /* Verde corporativo */
    --danger-color: #dc2626;
    /* Rojo para errores */
    --warning-color: #d97706;
    /* Naranja para advertencias */
    --info-color: #0284c7;
    /* Azul información */
    --light-color: #f8fafc;
    /* Gris muy claro */
    --dark-color: #1e293b;
    /* Azul oscuro */
    --accent-color: #f97316;
    /* Naranja accent */
    --text-primary: #1c1c1a;
    /* Texto principal */
    --text-secondary: #64748b;
    /* Texto secundario */

    /* ===== TEMA: variables semánticas (Light por defecto) ===== */
    --bg-body:        #f8fafc;
    --bg-body-end:    #e2e8f0;
    --bg-card:        #ffffff;
    --bg-card-header: #e85d26;
    --bg-table-thead: #343a40;
    --bg-table-hover: rgba(13, 110, 253, 0.1);
    --bg-input:       #ffffff;
    --bg-input-border: #e9ecef;
    --bg-code:        #f8f9fa;
    --bg-upload:      #f8f9fa;
    --bg-upload-hover:#e3f2fd;

    --theme-text-primary:   #1c1c1a;
    --theme-text-secondary: #64748b;
    --theme-text-code:      #0056b3;

    --border-color:   #e2e8f0;
    --shadow-color:   rgba(0, 0, 0, 0.075);
    --shadow-hover:   rgba(0, 0, 0, 0.15);
}

/* Overrides para Bootstrap para usar colores corporativos */
.bg-primary {
    background-color: var(--primary-color) !important;
}

.text-primary {
    /* color: var(--primary-color) !important; */
}

.btn-primary {
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
}

.btn-primary:hover {
    background-color: #c2410c !important;
    /* Darker orange */
    border-color: #c2410c !important;
}

.btn-outline-primary {
    color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
}

.btn-outline-primary:hover {
    background-color: var(--primary-color) !important;
    color: white !important;
}

body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    background-color: var(--bg-body);
    color: var(--theme-text-primary);
}

/* Navbar personalizada con branding Santiago Arroyos */
.navbar-brand {
    font-weight: bold;
    font-size: 1.5rem;
    color: #ffffff;
}

.navbar-nav .nav-link {
    font-weight: 500;
    transition: all 0.3s ease;
}

.navbar-nav .nav-link:hover {
    transform: translateY(-2px);
}

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

/* Cards personalizadas */
.card {
    border: none;
    border-radius: 0.75rem;
    box-shadow: 0 0.125rem 0.25rem var(--shadow-color);
    transition: all 0.3s ease;
}

.card:hover {
    box-shadow: 0 0.5rem 1rem var(--shadow-hover);
}

.card-header {
    border-radius: 0.75rem 0.75rem 0 0 !important;
    border: none;
}

/* Tablas personalizadas */
.table {
    border-radius: 0.5rem;
    overflow: hidden;
}

.table thead th {
    background: var(--bg-table-thead);
    color: white;
    border: none;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.875rem;
    letter-spacing: 0.5px;
}

.table tbody tr {
    transition: background-color 0.15s ease;
}

.table tbody tr:hover {
    background-color: var(--bg-table-hover);
}

/* Botones personalizados */
.btn {
    border-radius: 0.5rem;
    font-weight: 500;
    transition: all 0.3s ease;
    border: none;
}

.btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

.btn-primary {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}

.btn-success {
    background-color: var(--success-color);
    border-color: var(--success-color);
}

.btn-danger {
    background-color: var(--danger-color);
    border-color: var(--danger-color);
}

.btn-warning {
    background-color: var(--warning-color);
    border-color: var(--warning-color);
    color: #000;
}

.btn-info {
    background-color: var(--info-color);
    border-color: var(--info-color);
}

/* Modales personalizados */
.modal-content {
    border: none;
    border-radius: 1rem;
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.175);
}

.modal-header {
    background-color: var(--primary-color);
    color: white;
    border-radius: 1rem 1rem 0 0;
    border: none;
}

.modal-header .btn-close {
    filter: invert(1);
}

/* Formularios personalizados */
.form-control,
.form-select {
    border-radius: 0.5rem;
    border: 2px solid var(--bg-input-border);
    transition: all 0.3s ease;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.25);
}

.form-label {
    font-weight: 600;
    color: var(--theme-text-primary);
    margin-bottom: 0.5rem;
}

/* Estados de las filas */
.status-active {
    color: var(--success-color);
    font-weight: 600;
}

.status-inactive {
    color: var(--danger-color);
    font-weight: 600;
}

/* Badges personalizados */
.badge {
    border-radius: 0.375rem;
    font-weight: 500;
}

/* Animaciones */
@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.content-section {
    animation: fadeIn 0.5s ease-in-out;
}

/* Loading spinner personalizado */
#loadingSpinner {
    z-index: 9999;
}

.spinner-border {
    border-width: 0.3rem;
}

/* Toast personalizado */
.toast {
    border-radius: 0.75rem;
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

.toast-header {
    background-color: var(--primary-color);
    color: white;
    border-radius: 0.75rem 0.75rem 0 0;
    border: none;
}

.toast-header .btn-close {
    filter: invert(1);
}

/* Responsive design */
@media (max-width: 768px) {
    .table-responsive {
        font-size: 0.875rem;
    }

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

    .modal-dialog {
        margin: 0.5rem;
    }
}

/* Utilidades personalizadas */
.text-gradient {
    color: var(--primary-color);
}

.shadow-custom {
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

.border-gradient {
    border: 2px solid var(--primary-color);
}

/* Iconos personalizados */
.fas,
.far,
.fab {
    transition: all 0.3s ease;
}

.btn:hover .fas,
.btn:hover .far,
.btn:hover .fab {
    transform: scale(1.1);
}

/* Estados de carga */
.loading {
    opacity: 0.6;
    pointer-events: none;
}

/* Mensajes de error */
.error-message {
    color: var(--danger-color);
    font-size: 0.875rem;
    margin-top: 0.25rem;
}

/* Mensajes de éxito */
.success-message {
    color: var(--success-color);
    font-size: 0.875rem;
    margin-top: 0.25rem;
}

/* Estilos para el indicador de pasos */
.step-indicator {
    display: flex;
    justify-content: space-between;
    margin-bottom: 30px;
}

.step {
    flex: 1;
    text-align: center;
    position: relative;
}

.step:not(:last-child)::after {
    content: '';
    position: absolute;
    top: 20px;
    right: -50%;
    width: 100%;
    height: 3px;
    background-color: #dee2e6;
}

.step.active:not(:last-child)::after {
    background-color: #28a745;
}

.step-number {
    width: 40px;
    height: 40px;
    line-height: 40px;
    border-radius: 50%;
    background-color: #dee2e6;
    margin: 0 auto 10px;
    font-weight: bold;
    color: white;
}

.step.active .step-number {
    background-color: #28a745;
}

.step.completed .step-number {
    background-color: #007bff;
}

/* Área de carga de archivos */
.upload-area {
    border: 2px dashed #007bff;
    border-radius: 10px;
    padding: 40px;
    text-align: center;
    background-color: var(--bg-upload);
    transition: all 0.3s ease;
    cursor: pointer;
}

.upload-area:hover {
    border-color: #0056b3;
    background-color: var(--bg-upload-hover);
}

.upload-area.dragover {
    border-color: #28a745;
    background-color: #d4edda;
}

/* Estilos para acciones en cards y tablas */
.data-card-actions {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
    /* margin-top: 0.75rem; */
    /* padding-top: 0.75rem; */
    /* border-top: 1px solid #f0f0f0; */
}

.data-card-actions button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.375rem 0.75rem;
    white-space: nowrap;
}

/* Asegurar que los botones de la tabla tengan espaciado correcto */
table .data-card-actions {
    display: flex;
    gap: 0.25rem;
}

/* Asegurar que la celda de acciones en tablas no expanda excesivamente */
table td {
    vertical-align: middle !important;
}

table td:last-child {
    vertical-align: middle !important;
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
    white-space: nowrap;
}



#corralesTab .nav-link.corral-con-animales:not(.active) {
    color: var(--success-color);
    font-weight: 600;
    background-color: rgba(5, 150, 105, 0.12);
    border-radius: 0.5rem;
}

#corralesTab .nav-link.corral-con-animales.active {
    font-weight: 700;
}

/* ==================== MEJORAS TABLA MOVIMIENTOS ==================== */

/* Mejorar contraste de encabezados de tabla */
.table-dark th {
    background-color: #212529 !important;
    color: #ffffff !important;
    font-weight: 600;
    border-bottom: 2px solid #dee2e6;
}

/* Encabezados clickeables para ordenar */
.table thead th.sortable,
.table thead th[style*="cursor: pointer"] {
    background-color: #1e3a8a !important;
    color: #ffffff !important;
    transition: background-color 0.2s ease;
    user-select: none;
    cursor: pointer;
    position: relative;
}

.table thead th.sortable:hover,
.table thead th[style*="cursor: pointer"]:hover {
    background-color: #0056b3 !important;
}

.table thead th.sortable i.fa-sort,
.table thead th[style*="cursor: pointer"] i.fa-sort {
    opacity: 0.5;
    margin-left: 5px;
    font-size: 0.8rem;
    transition: opacity 0.2s ease;
}

.table thead th.sortable:hover i.fa-sort,
.table thead th[style*="cursor: pointer"]:hover i.fa-sort {
    opacity: 1;
}

.table thead th.sortable i.fa-sort-up,
.table thead th.sortable i.fa-sort-down {
    opacity: 1;
    color: #fff;
    font-weight: bold;
}

/* Mejorar visibilidad de código DIB */
code {
    background-color: var(--bg-code);
    padding: 2px 6px;
    border-radius: 3px;
    color: var(--theme-text-code);
    font-size: 0.9rem;
    font-weight: 600;
}

/* Badges en tabla más visibles */
.table .badge {
    font-size: 0.85rem;
    padding: 0.35em 0.65em;
    font-weight: 600;
}

/* Select de corral en tabla */
.table select.corral-nuevo {
    font-size: 0.85rem;
    padding: 0.25rem 0.5rem;
}

/* Mejorar contraste de badges de estado */
.badge.bg-success {
    background-color: #059669 !important;
}

.badge.bg-secondary {
    background-color: #6c757d !important;
}

.badge.bg-info {
    background-color: #0284c7 !important;
}

/* Buscador destacado */
#buscarAnimalMovimiento {
    border: 2px solid #0284c7;
}

#buscarAnimalMovimiento:focus {
    border-color: #0056b3;
    box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.25);
}

/* Botón de corral masivo */
#corralMasivoMovimiento {
    border: 2px solid #059669;
}

/* Estilos para badges de supresión (Alineación con Mobile) */
.supresion-badge {
    display: inline-block;
    padding: 0.25rem 0.5rem;
    border-radius: 0.375rem;
    font-size: 0.8rem;
    font-weight: 600;
}

.supresion-carne {
    background-color: #fee2e2;
    color: #991b1b;
    border: 1px solid #fca5a5;
}

.supresion-leche {
    background-color: #dbeafe;
    color: #1e40af;
    border: 1px solid #93c5fd;
}

/* Autocomplete results */
.list-group-item-action {
    cursor: pointer;
    transition: background-color 0.2s;
}

.list-group-item-action:hover {
    background-color: #f1f5f9;
}

#tratNuevoMedResultados, #tratNuevoAnimalResultados {
    max-height: 250px;
    overflow-y: auto;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

/* ==================== TRANSICIÓN SUAVE DE TEMA ==================== */
body,
.card,
.card-header,
.card-body,
.table thead th,
.table tbody tr,
.modal-content,
.modal-header,
.modal-body,
.modal-footer,
.form-control,
.form-select,
.dropdown-menu,
.toast,
code,
input, select, textarea,
.list-group-item {
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

/* ============================================================
   MODO NOCHE — Paleta Arroyos Dark Obsidian
   ============================================================ */
[data-theme="dark"] {
    /* Superficies */
    --bg-body:          #1b110c;
    --bg-body-end:      #241914;
    --bg-card:          #241914;
    --bg-card-header:   #FF8A3D;
    --bg-table-thead:   #1b110c;
    --bg-table-hover:   rgba(255, 138, 61, 0.10);
    --bg-input:         #241914;
    --bg-input-border:  #433730;
    --bg-code:          #2d201a;
    --bg-upload:        #241914;
    --bg-upload-hover:  #2d201a;

    /* Texto */
    --theme-text-primary:   #F4F4F5;
    --theme-text-secondary: #A1A1AA;
    --theme-text-code:      #FF8A3D;

    /* Bordes y sombras */
    --border-color:   #ffffff1a;
    --shadow-color:   rgba(0, 0, 0, 0.4);
    --shadow-hover:   rgba(0, 0, 0, 0.6);

    /* Marca */
    --primary-color:  #FF8A3D;
    --info-color:     #00A3E0;
    --success-color:  #22C55E;
    --danger-color:   #EF4444;
    --warning-color:  #F97316;
}

/* — Body — */
[data-theme="dark"] body {
    background-color: var(--bg-body);
    color: var(--theme-text-primary);
}

/* — Cards — */
[data-theme="dark"] .card {
    background-color: var(--bg-card) !important;
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-color);
}
[data-theme="dark"] .card-header {
    background-color: var(--bg-card-header) !important;
    color: #FFFFFF;
    border: none;
}
[data-theme="dark"] .card-body {
    background-color: var(--bg-card) !important;
    color: var(--theme-text-primary);
}
/* Override bg-white inline */
[data-theme="dark"] .bg-white {
    background-color: var(--bg-card) !important;
}

/* — Tablas — */
[data-theme="dark"] .table {
    color: var(--theme-text-primary);
    border-color: var(--border-color);
}
[data-theme="dark"] .table thead th {
    background: var(--bg-table-thead) !important;
    color: var(--theme-text-primary);
    border-bottom: 2px solid var(--primary-color);
}
[data-theme="dark"] .table tbody tr {
    color: var(--theme-text-primary);
    border-color: var(--border-color);
}
[data-theme="dark"] .table tbody tr:hover {
    background-color: var(--bg-table-hover) !important;
}
[data-theme="dark"] .table-striped tbody tr:nth-of-type(odd) {
    background-color: rgba(255, 255, 255, 0.06) !important;
}
[data-theme="dark"] .table-dark th {
    background-color: #1b110c !important;
    color: var(--theme-text-primary);
    border-bottom-color: var(--border-color);
}
[data-theme="dark"] .table thead th.sortable,
[data-theme="dark"] .table thead th[style*="cursor: pointer"] {
    background-color: #2d201a !important;
}

/* — Modales — */
[data-theme="dark"] .modal-content {
    background-color: var(--bg-card) !important;
    border: 1px solid var(--border-color);
}
[data-theme="dark"] .modal-header {
    background: var(--bg-card-header) !important;
    color: #FFFFFF;
}
[data-theme="dark"] .modal-body {
    background-color: var(--bg-card) !important;
    color: var(--theme-text-primary);
}
[data-theme="dark"] .modal-footer {
    background-color: var(--bg-card) !important;
    border-top-color: var(--border-color);
}
[data-theme="dark"] .modal-title {
    color: #FFFFFF;
}
[data-theme="dark"] .btn-close {
    filter: invert(1);
}

/* — Formularios — */
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
    background-color: var(--bg-input) !important;
    border-color: var(--bg-input-border);
    color: var(--theme-text-primary);
}
[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 0.2rem rgba(255, 138, 61, 0.25);
    color: var(--theme-text-primary);
    background-color: #2d201a !important;
}
[data-theme="dark"] .form-label {
    color: var(--theme-text-primary);
}
[data-theme="dark"] .form-control::placeholder {
    color: var(--theme-text-secondary);
}
[data-theme="dark"] .form-text {
    color: var(--theme-text-secondary);
}

[data-theme="dark"] input[type="text"],
[data-theme="dark"] input[type="number"],
[data-theme="dark"] input[type="date"],
[data-theme="dark"] input[type="search"],
[data-theme="dark"] select,
[data-theme="dark"] textarea {
    background-color: var(--bg-input) !important;
    border-color: var(--bg-input-border);
    color: var(--theme-text-primary);
}

/* — Botones — */
[data-theme="dark"] .btn-primary {
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: #FFFFFF;
}
[data-theme="dark"] .btn-primary:hover {
    background-color: #e6762a !important;
}
[data-theme="dark"] .btn-outline-primary {
    color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
}
[data-theme="dark"] .btn-outline-primary:hover {
    background-color: var(--primary-color) !important;
    color: #FFFFFF;
}
[data-theme="dark"] .btn-success {
    background-color: var(--success-color) !important;
    border-color: var(--success-color) !important;
}
[data-theme="dark"] .btn-danger {
    background-color: var(--danger-color) !important;
    border-color: var(--danger-color) !important;
}
[data-theme="dark"] .btn-warning {
    background-color: var(--warning-color) !important;
    color: #1b110c;
}
[data-theme="dark"] .btn-light {
    background-color: #433730 !important;
    color: var(--theme-text-primary) !important;
    border-color: var(--border-color);
}

/* — Código — */
[data-theme="dark"] code {
    background-color: var(--bg-code);
    color: var(--theme-text-code);
}

/* — Upload — */
[data-theme="dark"] .upload-area {
    background-color: var(--bg-upload) !important;
    border-color: var(--primary-color);
    color: var(--theme-text-primary);
}

/* — Toast — */
[data-theme="dark"] .toast {
    background-color: var(--bg-card) !important;
    border: 1px solid var(--border-color);
}
[data-theme="dark"] .toast-body {
    color: var(--theme-text-primary);
}

/* — Dropdowns — */
[data-theme="dark"] .dropdown-menu {
    background-color: var(--bg-card) !important;
    border-color: var(--border-color);
}
[data-theme="dark"] .dropdown-item {
    color: var(--theme-text-primary);
}
[data-theme="dark"] .dropdown-item:hover {
    background-color: var(--bg-table-hover);
    color: var(--theme-text-primary);
}

/* — Badges — */
[data-theme="dark"] .badge.bg-success {
    background-color: var(--success-color) !important;
}
[data-theme="dark"] .badge.bg-secondary {
    background-color: #433730 !important;
}
[data-theme="dark"] .badge.bg-info {
    background-color: var(--info-color) !important;
}
[data-theme="dark"] .badge.bg-danger {
    background-color: var(--danger-color) !important;
}
[data-theme="dark"] .badge.bg-warning {
    background-color: var(--warning-color) !important;
    color: #1b110c;
}

/* — Supresión — */
[data-theme="dark"] .supresion-carne {
    background-color: #3b1111;
    color: #fca5a5;
    border-color: #7f1d1d;
}
[data-theme="dark"] .supresion-leche {
    background-color: #0c2a4a;
    color: #93c5fd;
    border-color: #1e40af;
}

/* — List group — */
[data-theme="dark"] .list-group-item {
    background-color: var(--bg-card) !important;
    border-color: var(--border-color);
    color: var(--theme-text-primary);
}
[data-theme="dark"] .list-group-item:hover {
    background-color: var(--bg-table-hover);
}

/* — DataTables — */
[data-theme="dark"] .dataTables_wrapper .dataTables_length select,
[data-theme="dark"] .dataTables_wrapper .dataTables_filter input {
    background-color: var(--bg-input) !important;
    border-color: var(--bg-input-border);
    color: var(--theme-text-primary);
}
[data-theme="dark"] table.dataTable tbody tr {
    background-color: var(--bg-card) !important;
    color: var(--theme-text-primary);
}
[data-theme="dark"] table.dataTable tbody tr:hover {
    background-color: var(--bg-table-hover) !important;
}
[data-theme="dark"] table.dataTable thead th {
    background-color: #1b110c !important;
    color: var(--theme-text-primary);
}
[data-theme="dark"] .dataTables_wrapper .dataTables_info {
    color: var(--theme-text-secondary) !important;
}
[data-theme="dark"] .dataTables_wrapper .dataTables_paginate .paginate_button {
    color: var(--theme-text-primary) !important;
}
[data-theme="dark"] .page-item .page-link {
    background-color: var(--bg-card);
    border-color: var(--border-color);
    color: var(--theme-text-primary);
}
[data-theme="dark"] .page-item.active .page-link {
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: #FFFFFF;
}

/* — Flatpickr — */
[data-theme="dark"] .flatpickr-calendar {
    background: var(--bg-card) !important;
    border-color: var(--border-color);
}
[data-theme="dark"] .flatpickr-day {
    color: var(--theme-text-primary);
}
[data-theme="dark"] .flatpickr-months .flatpickr-month {
    color: var(--theme-text-primary);
}

/* — SweetAlert2 — */
[data-theme="dark"] .swal2-popup {
    background: var(--bg-card) !important;
    color: var(--theme-text-primary);
}
[data-theme="dark"] .swal2-title {
    color: var(--theme-text-primary);
}
[data-theme="dark"] .swal2-html-container {
    color: var(--theme-text-secondary);
}

/* — Buscador movimientos — */
[data-theme="dark"] #buscarAnimalMovimiento {
    border-color: var(--info-color);
}

/* — Step indicators — */
[data-theme="dark"] .step:not(:last-child)::after {
    background-color: var(--border-color);
}
[data-theme="dark"] .step-number {
    background-color: #433730;
    color: var(--theme-text-primary);
}
[data-theme="dark"] .step.active .step-number {
    background-color: var(--success-color);
}

/* — Error/success messages — */
[data-theme="dark"] .error-message {
    color: #fca5a5;
}
[data-theme="dark"] .success-message {
    color: #86efac;
}

/* — Inline style overrides (dark mode) — */
[data-theme="dark"] .card [style*="background: linear-gradient"] {
    background-color: var(--bg-card-header) !important;
    color: #FFFFFF;
}
[data-theme="dark"] [style*="background-color: #fff"],
[data-theme="dark"] [style*="background-color:#fff"],
[data-theme="dark"] [style*="background-color: #FFF9F5"],
[data-theme="dark"] [style*="background-color:#FFF9F5"] {
    background-color: var(--bg-card) !important;
}
[data-theme="dark"] .text-muted {
    color: var(--theme-text-secondary) !important;
}
[data-theme="dark"] .text-primary {
    color: var(--primary-color) !important;
}
[data-theme="dark"] .text-dark {
    color: var(--theme-text-primary) !important;
}
[data-theme="dark"] .text-danger {
    color: var(--danger-color) !important;
}
[data-theme="dark"] .text-success {
    color: var(--success-color) !important;
}
[data-theme="dark"] .text-warning {
    color: var(--warning-color) !important;
}

/* — Navbar tweak — */
[data-theme="dark"] .navbar {
    border-bottom: 1px solid rgba(255, 138, 61, 0.2);
}

/* — Corral tabs — */
[data-theme="dark"] #corralesTab .nav-link {
    color: var(--theme-text-secondary);
}
[data-theme="dark"] #corralesTab .nav-link.corral-con-animales:not(.active) {
    color: var(--success-color);
    background-color: rgba(34, 197, 94, 0.1);
}
[data-theme="dark"] #corralesTab .nav-link.active {
    color: #FFFFFF;
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}

/* — Scrollbar sutil — */
[data-theme="dark"] ::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
[data-theme="dark"] ::-webkit-scrollbar-track {
    background: var(--bg-body);
}
[data-theme="dark"] ::-webkit-scrollbar-thumb {
    background: #433730;
    border-radius: 4px;
}
[data-theme="dark"] ::-webkit-scrollbar-thumb:hover {
    background: var(--primary-color);
}

/* ==================== PROYECCIÓN SALIDAS ==================== */
.badge.bg-orange {
    background-color: #f97316 !important;
    color: #fff;
}

.progress-bar.bg-info {
    background-color: #0ea5e9;
}

[data-theme="dark"] #planificacion-salidas-section .card {
    background-color: var(--bg-card, #241914);
    border-color: var(--border-color, rgba(255,255,255,0.1));
}

[data-theme="dark"] #planificacion-salidas-section .text-muted {
    color: var(--text-secondary, #A1A1AA) !important;
}

[data-theme="dark"] .progress {
    background-color: #334155;
}