/* === VARIABLES GLOBALES Y TEMAS === */
:root {
    --primary-color: #0d6efd;
    --secondary-color: #6c757d;
    --success-color: #198754; /* Añadido por si se usa */
    --info-color: #0dcaf0;    /* Añadido por si se usa */
    --warning-color: #ffc107; /* Añadido por si se usa */
    --danger-color: #dc3545;  /* Añadido por si se usa */
    --light-gray: #f0f2f5; /* Fondo página login */
    --white-panel: #ffffff;
    --border-color-light: #dee2e6; /* Borde sutil */
    --shadow-light: 0 5px 15px rgba(0, 0, 0, 0.1); /* Sombra más definida */

    /* --- Tema Claro (Sidebar/Navbar Oscuras por defecto) --- */
    --bg-light: var(--light-gray); /* Fondo general */
    --text-light: #212529; /* Texto general */
    /* Login claro */
    --panel-bg-light: var(--white-panel);
    --input-bg-light: #f0f2f5;
    --input-border-light: #ced4da;
    --social-icon-color-light: #4b4f56;
    --social-icon-hover-light: var(--primary-color);
    /* Dashboard Claro - Barras Oscuras */
    --sidebar-bg-light: #212529; /* Fondo Sidebar oscuro */
    --sidebar-text-light: #adb5bd; /* Texto Sidebar claro */
    --sidebar-link-active-bg-light: var(--primary-color);
    --sidebar-link-active-text-light: #ffffff;
    --navbar-bg-light: #212529; /* Fondo Navbar oscuro */
    --navbar-border-light: #343a40; /* Borde inferior Navbar oscuro */
    --content-bg-light: #f8f9fc; /* Fondo Contenido claro */
    --card-bg-light: var(--white-panel); /* Fondo cards claro */
    --card-header-bg-light: #f8f9fa;
    --result-border-light: #dee2e6; /* Borde para resultados */
    --card-border-light: rgba(0, 0, 0, 0.125); /* Borde tarjeta general */


    /* --- Tema Oscuro --- */
    --bg-dark: #16191c;
    --text-dark: #e4e6eb;
    --panel-bg-dark: #242526;
    --input-bg-dark: #3a3b3c;
    --input-border-dark: #3e4042;
    --border-color-dark: #3e4042;
    --social-icon-color-dark: #b0b3b8;
    --social-icon-hover-dark: #e4e6eb;
    --shadow-dark: 0 5px 15px rgba(0, 0, 0, 0.3);
    /* Dashboard Oscuro */
    --sidebar-bg-dark: #212529; /* Mantener oscuro */
    --sidebar-text-dark: #adb5bd; /* Mantener claro */
    --sidebar-link-active-bg-dark: #0d6efd;
    --sidebar-link-active-text-dark: #fff;
    --navbar-bg-dark: #212529; /* Mantener oscuro */
    --content-bg-dark: #16191c; /* Fondo contenido oscuro */
    --card-bg-dark: #212529; /* Fondo cards dashboard oscuro */
    --card-border-dark: #444; /* Borde cards dashboard */
    --card-header-bg-dark: #2c3034; /* Fondo headers oscuro */
    --text-muted-dark: #adb5bd; /* Texto muted oscuro (más claro que el default gris) */
    --result-border-dark: #444; /* Borde para resultados oscuro */
}

/* === ESTILOS BASE === */
body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    transition: background-color 0.3s ease, color 0.3s ease;
    color: var(--text-light);
    overflow-x: hidden;
    background-color: var(--bg-light);
}
body.login-page-body { padding: 1rem; }

/* === ESTILOS DEL LOGIN (index.php) === */
.login-box { background-color: var(--panel-bg-light); max-width: 850px; width: 100%; min-height: 500px; transition: background-color 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease; box-shadow: var(--shadow-light); border: 1px solid var(--border-color-light); border-radius: 0.5rem; overflow: hidden; }
.login-box-image { }
.login-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.login-box-form { background-color: var(--panel-bg-light); transition: background-color 0.3s ease; }
.login-box .app-title { color: var(--text-light); }
.login-box .welcome-text { color: var(--secondary-color); font-size: 0.95rem; }
.login-box .login-input.form-control { background-color: var(--input-bg-light); border: 1px solid var(--border-color-light); transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease; padding: 0.75rem 1rem; }
.login-box .login-input.form-control:focus { border-color: var(--primary-color); box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.25); background-color: var(--white-panel); color: var(--text-light); }
.login-box .form-floating > label { color: var(--secondary-color); padding-left: 1rem; }
.login-box .form-floating > label i { margin-right: 0.5rem; width: 16px; text-align: center; }
.login-box .form-floating > .form-control { padding-left: 1rem; height: calc(3.5rem + 2px); line-height: 1.25; }
.login-box .form-floating > .form-control:focus ~ label,
.login-box .form-floating > .form-control:not(:placeholder-shown) ~ label { opacity: .65; transform: scale(.85) translateY(-.5rem) translateX(.15rem); }
.login-box .form-floating > .form-control:focus ~ label { color: var(--primary-color); opacity: 1; }
.login-box .forgot-password { font-size: 0.85em; color: var(--primary-color); }
.login-box .forgot-password:hover { text-decoration: underline !important; }
.login-box .form-check-label { font-size: 0.9em; }
.login-box .login-button { padding: 0.75rem 1rem; font-weight: 600; }
.login-box .social-text { color: var(--secondary-color); }
.login-box .social-icons a { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 50%; background-color: var(--input-bg-light); color: var(--social-icon-color-light); transition: all 0.2s ease-in-out; font-size: 1rem; text-decoration: none; border: 1px solid var(--border-color-light); }
.login-box .social-icons a:hover { transform: translateY(-2px); box-shadow: 0 2px 5px rgba(0,0,0,0.1); border-color: #adb5bd; }
.login-box .social-icons .facebook:hover { background-color: #1877f2; color: white; border-color: #1877f2; }
.login-box .social-icons .whatsapp:hover { background-color: #25d366; color: white; border-color: #25d366; }
.login-box .social-icons .instagram:hover { background-color: #e1306c; color: white; border-color: #e1306c;}
.login-box-form .theme-toggle-btn { background-color: transparent; color: var(--secondary-color); border: none; transition: color 0.3s ease; font-size: 0.85rem; padding: 0.25rem 0.5rem; }
.login-box-form .theme-toggle-btn:hover { color: var(--primary-color); }
.login-box-form .theme-toggle-btn i { margin-right: 0.25rem;}

/* === ESTILOS DEL DASHBOARD === */
#wrapper { overflow-x: hidden; display: flex; min-height: 100vh; }
#sidebar-wrapper { min-height: 100vh; width: 250px; background-color: var(--sidebar-bg-light) !important; color: var(--sidebar-text-light) !important; transition: margin-left 0.3s ease; border-right: 1px solid var(--navbar-border-light); display: flex; flex-direction: column; }
#page-content-wrapper { flex: 1; width: calc(100% - 250px); min-width: 0; background-color: var(--content-bg-light); transition: width 0.3s ease, margin-left 0.3s ease; color: var(--text-light); }
#sidebar-wrapper .sidebar-heading { background-color: var(--sidebar-bg-light) !important; color: #ffffff !important; font-weight: bold; border-bottom: 1px solid var(--navbar-border-light); }
#sidebar-wrapper .sidebar-heading img { vertical-align: middle; }
#sidebar-wrapper .list-group-item { border: none; padding: 0.8rem 1.25rem; background-color: transparent !important; color: var(--sidebar-text-light) !important; font-size: 0.95rem; }
#sidebar-wrapper .list-group-item-action:hover,
#sidebar-wrapper .list-group-item-action:focus { background-color: rgba(255, 255, 255, 0.1) !important; color: #ffffff !important; }
#sidebar-wrapper .list-group-item.active { background-color: var(--sidebar-link-active-bg-light) !important; color: var(--sidebar-link-active-text-light) !important; border-left: 3px solid darken(var(--primary-color), 10%); font-weight: bold; }
#sidebar-wrapper .list-group-item.active i { color: var(--sidebar-link-active-text-light) !important; }
#sidebar-wrapper .list-group-item i.fa-sign-out-alt { color: #dc3545 !important; }
#sidebar-wrapper .list-group-item:hover i.fa-sign-out-alt { color: #f8d7da !important; }
#sidebar-wrapper .sidebar-section-title { font-weight: bold; color: #adb5bd !important; }
.navbar { background-color: var(--navbar-bg-light) !important; box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075); z-index: 1030; padding-top: 0.5rem; padding-bottom: 0.5rem; transition: background-color 0.3s ease, border-color 0.3s ease; border-bottom: 1px solid var(--navbar-border-light) !important; }
.navbar .navbar-nav .nav-link { color: rgba(255, 255, 255, 0.75) !important; }
.navbar .navbar-nav .nav-link:hover { color: #ffffff !important; }
.navbar .navbar-toggler { border-color: rgba(255, 255, 255, 0.1) !important; }
.navbar .navbar-toggler-icon { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important; }
.navbar .dropdown-menu { background-color: var(--navbar-bg-light) !important; border-color: var(--navbar-border-light) !important; }
.navbar .dropdown-item { color: var(--sidebar-text-light) !important; }
.navbar .dropdown-item:hover, .navbar .dropdown-item:focus { background-color: rgba(255, 255, 255, 0.1) !important; color: #f8f9fa !important; }
.navbar .dropdown-divider { border-top-color: var(--navbar-border-light) !important; }
.navbar .dropdown-item.text-danger { color: #ff6b6b !important; }
.navbar .dropdown-item.text-danger:hover { color: #ff4747 !important; }
.navbar .theme-toggle-btn-nav { background: transparent !important; border: 1px solid rgba(255, 255, 255, 0.5) !important; color: rgba(255, 255, 255, 0.75) !important; padding: 0.25rem 0.5rem; font-size: 0.875rem; line-height: 1.5; transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease; }
.navbar .theme-toggle-btn-nav:hover { background: rgba(255, 255, 255, 0.1) !important; color: white !important; border-color: rgba(255, 255, 255, 0.75) !important; }
.navbar .theme-toggle-btn-nav i { margin-right: 0.25rem; }
#sidebarToggle { background-color: var(--primary-color) !important; border-color: var(--primary-color) !important; color: #fff !important; }
#wrapper.toggled #sidebar-wrapper { margin-left: -250px; }
#wrapper.toggled #page-content-wrapper { width: 100%; margin-left: 0; }

/* === Estilos Comunes Dashboard (Cards, Tablas, etc.) === */
.card { border: 1px solid var(--border-color-light); background-color: var(--card-bg-light); }
.card-header { background-color: var(--card-header-bg-light); border-bottom: 1px solid var(--border-color-light); color: var(--text-light); }
.card-body { color: var(--text-light); }
.table { color: var(--text-light); }
.table-striped tbody tr:nth-of-type(odd) { background-color: rgba(0, 0, 0, 0.03); }
.table-bordered { border-color: var(--border-color-light); }
.table-hover tbody tr:hover { background-color: rgba(0, 0, 0, 0.05); }
.table-dark { background-color: #343a40; border-color: #454d55; color: #fff;} /* Cabecera oscura tabla */
.action-link { text-decoration: none; cursor: pointer; border: none; background: none; padding: 0; display: inline; }
.action-link:hover i { opacity: 0.8; }
.img-preview { max-height: 150px; margin-top: 10px; display: none; } /* Vistas Propietario/Conductor */
.status-activo { color: var(--success-color); }
.status-inactivo { color: var(--danger-color); }

/* === Estilos Buscadores AJAX (Vistas Vehículo, etc.) === */
.search-results { position: absolute; background-color: var(--panel-bg-light); border: 1px solid var(--border-color-light); border-top: none; max-height: 200px; overflow-y: auto; width: calc(100% - 2px); z-index: 1050; display: none; border-radius: 0 0 0.375rem 0.375rem; box-shadow: var(--shadow-light); margin-top: -1px; }
.search-results .list-group-item { cursor: pointer; padding: 0.5rem 1rem; font-size: 0.9rem; background-color: transparent !important; color: var(--text-light); border-bottom: 1px solid var(--border-color-light) !important; }
.search-results .list-group-item:last-child { border-bottom: none !important; }
.search-results .list-group-item:hover { background-color: rgba(0, 0, 0, 0.05) !important; }
.search-results .result-details { font-size: 0.8rem; color: var(--secondary-color); }
.position-relative { position: relative; } /* Para contenedores de búsqueda AJAX */

/* === Estilos para Búsqueda Integrada en Dashboard === */
/* Ocultar área de resultados del dashboard si no hay búsqueda activa */
.results-area:not(.results-found) {
    display: none;
}
#dashboardSearchResults .result-item { margin-bottom: 1rem; }
#dashboardSearchResults .card { border: 1px solid var(--card-border-light); }
#dashboardSearchResults .card-header { background-color: var(--card-header-bg-light); border-bottom: 1px solid var(--card-border-light); font-weight: 600; font-size: 0.95rem; padding: 0.6rem 1rem; }
#dashboardSearchResults .card-header-icon i { color: var(--primary-color); }
#dashboardSearchResults .card-body { padding: 1rem; }
#dashboardSearchResults .data-list dt { font-weight: 600; color: var(--secondary-color); font-size: 0.8rem; margin-bottom: 0.1rem; padding-right: 0.5em; text-transform: uppercase; }
#dashboardSearchResults .data-list dd { margin-left: 0; margin-bottom: 0.4rem; font-size: 0.9rem; word-wrap: break-word; }
#dashboardSearchResults .data-list dd:last-child { margin-bottom: 0; }
#dashboardResultsContent .alert { margin-top: 1rem; }
.loading-indicator { text-align: center; padding: 1rem; }


/* === ESTILOS MODO OSCURO (GLOBAL) === */
body.dark-mode { background-color: var(--bg-dark); color: var(--text-dark); }

/* --- Login Oscuro --- */
body.dark-mode .login-box { background-color: var(--panel-bg-dark); box-shadow: var(--shadow-dark); border-color: var(--border-color-dark); }
body.dark-mode .login-box-form { background-color: var(--panel-bg-dark); }
body.dark-mode .login-box .app-title { color: var(--text-dark); }
body.dark-mode .login-box .welcome-text { color: var(--text-muted-dark); }
body.dark-mode .login-box .login-input.form-control { background-color: var(--input-bg-dark); border-color: var(--border-color-dark); color: var(--text-dark); }
body.dark-mode .login-box .login-input.form-control:focus { background-color: #444; color: var(--text-dark); border-color: var(--primary-color); box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.3); }
body.dark-mode .login-box .form-floating > label { color: var(--text-muted-dark); }
body.dark-mode .login-box .form-floating > .form-control:focus ~ label { color: var(--primary-color); }
body.dark-mode .login-box .form-check-input { background-color: var(--input-bg-dark); border-color: var(--border-color-dark); }
body.dark-mode .login-box .form-check-input:checked { background-color: var(--primary-color); border-color: var(--primary-color); }
body.dark-mode .login-box .form-check-label { color: var(--text-muted-dark); }
body.dark-mode .login-box .forgot-password { color: var(--primary-color); }
body.dark-mode .login-box hr { border-top-color: var(--border-color-dark); }
body.dark-mode .login-box .social-text { color: var(--text-muted-dark); }
body.dark-mode .login-box .social-icons a { background-color: var(--input-bg-dark); color: var(--social-icon-color-dark); border-color: var(--border-color-dark); }
body.dark-mode .login-box .social-icons a:hover { color: var(--social-icon-hover-dark); background-color: #4e4f50; border-color: #555; box-shadow: 0 2px 5px rgba(0,0,0,0.3); }
body.dark-mode .login-box .social-icons .facebook:hover { background-color: #1877f2; color: white; border-color: #1877f2; }
body.dark-mode .login-box .social-icons .whatsapp:hover { background-color: #25d366; color: white; border-color: #25d366; }
body.dark-mode .login-box .social-icons .instagram:hover { background-color: #e1306c; color: white; border-color: #e1306c;}
body.dark-mode .login-box-form .theme-toggle-btn { color: var(--text-muted-dark); }
body.dark-mode .alert-danger { background-color: #521a22; color: #f1b8c1; border-color: #843f4c; }
body.dark-mode .alert-danger .btn-close { filter: invert(1) grayscale(100%) brightness(200%); }
body.dark-mode .alert-warning { background-color: #664d03; border-color: #997404; color: #ffecb5; } /* Añadido alerta warning oscura */
body.dark-mode .alert-warning .btn-close { filter: invert(1) grayscale(100%) brightness(200%); }

/* --- Dashboard Oscuro --- */
body.dark-mode #sidebar-wrapper { background-color: var(--sidebar-bg-dark) !important; color: var(--sidebar-text-dark) !important; border-right-color: var(--card-border-dark) !important; }
body.dark-mode #sidebar-wrapper .sidebar-heading { background-color: var(--sidebar-bg-dark) !important; color: #f8f9fa !important; border-bottom-color: var(--card-border-dark) !important; }
body.dark-mode #sidebar-wrapper .list-group-item { color: var(--sidebar-text-dark) !important; }
body.dark-mode #sidebar-wrapper .list-group-item-action:hover, body.dark-mode #sidebar-wrapper .list-group-item-action:focus { background-color: rgba(255, 255, 255, 0.05) !important; color: #dee2e6 !important; }
body.dark-mode #sidebar-wrapper .list-group-item.active { background-color: var(--sidebar-link-active-bg-dark) !important; color: var(--sidebar-link-active-text-dark) !important; border-left-color: lighten(var(--primary-color), 10%) !important; }
body.dark-mode #sidebar-wrapper .list-group-item.active i { color: var(--sidebar-link-active-text-dark) !important; }
body.dark-mode #sidebar-wrapper .list-group-item i.fa-sign-out-alt { color: #dc3545 !important; }
body.dark-mode #sidebar-wrapper .list-group-item:hover i.fa-sign-out-alt { color: #f8d7da !important; }
body.dark-mode #sidebar-wrapper .sidebar-section-title { color: var(--text-muted-dark) !important; }
body.dark-mode #page-content-wrapper { background-color: var(--content-bg-dark) !important; color: var(--text-dark) !important; }
body.dark-mode .navbar { background-color: var(--navbar-bg-dark) !important; border-bottom-color: var(--card-border-dark) !important; }
body.dark-mode .navbar .navbar-nav .nav-link { color: rgba(255, 255, 255, 0.75) !important; }
body.dark-mode .navbar .navbar-nav .nav-link:hover { color: #ffffff !important; }
body.dark-mode .navbar .navbar-toggler { border-color: rgba(255, 255, 255, 0.1) !important; }
body.dark-mode .navbar .navbar-toggler-icon { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important; }
body.dark-mode .navbar .dropdown-menu { background-color: var(--navbar-bg-dark) !important; border-color: var(--card-border-dark) !important; }
body.dark-mode .navbar .dropdown-item { color: var(--sidebar-text-dark) !important; }
body.dark-mode .navbar .dropdown-item:hover, body.dark-mode .navbar .dropdown-item:focus { background-color: rgba(255, 255, 255, 0.1) !important; color: #f8f9fa !important; }
body.dark-mode .navbar .dropdown-divider { border-top-color: var(--card-border-dark) !important; }
body.dark-mode .navbar .dropdown-item.text-danger { color: #ff6b6b !important; }
body.dark-mode .navbar .dropdown-item.text-danger:hover { color: #ff4747 !important; }
body.dark-mode .navbar .theme-toggle-btn-nav { border: 1px solid var(--sidebar-text-dark) !important; color: var(--sidebar-text-dark) !important; }
body.dark-mode .navbar .theme-toggle-btn-nav:hover { background: var(--sidebar-text-dark) !important; color: var(--sidebar-bg-dark) !important; }
body.dark-mode #sidebarToggle { background-color: #495057 !important; border-color: #495057 !important; color: #fff !important; }
body.dark-mode .container-fluid { color: var(--text-dark) !important; } /* Texto general contenedor */
body.dark-mode .card { background-color: var(--card-bg-dark) !important; border-color: var(--card-border-dark) !important; color: var(--text-dark); /* Color texto card base */ }
body.dark-mode .card-header { background-color: var(--card-header-bg-dark) !important; border-bottom-color: var(--card-border-dark) !important; color: var(--text-dark) !important; }
body.dark-mode .card-body { color: var(--text-dark) !important; }
body.dark-mode .table { color: var(--text-dark) !important; }
body.dark-mode .table-striped tbody tr:nth-of-type(odd) { background-color: rgba(255, 255, 255, 0.03) !important; }
body.dark-mode .table-bordered { border-color: var(--card-border-dark) !important; }
body.dark-mode .table-hover tbody tr:hover { background-color: rgba(255, 255, 255, 0.07) !important; }
body.dark-mode .table-dark { background-color: #343a40 !important; border-color: #454d55 !important; color: #fff !important;}
body.dark-mode .status-activo { color: #20c997; }
body.dark-mode .status-inactivo { color: #fd7e14; }
/* Estilos oscuros buscadores AJAX (Vistas) */
body.dark-mode .search-results { background-color: var(--panel-bg-dark); border-color: var(--border-color-dark); }
body.dark-mode .search-results .list-group-item { color: var(--text-dark); border-bottom: 1px solid var(--border-color-dark) !important; }
body.dark-mode .search-results .list-group-item:hover { background-color: rgba(255, 255, 255, 0.07) !important; }
body.dark-mode .search-results .result-details { color: var(--text-muted-dark); }
/* Estilos oscuros input-group (buscador tabla en Vistas) */
body.dark-mode .input-group .form-control { background-color: var(--input-bg-dark); border-color: var(--border-color-dark); color: var(--text-dark); }
body.dark-mode .input-group .form-control:focus { background-color: #444; border-color: var(--primary-color); box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.3); }
body.dark-mode .input-group .btn-outline-secondary { color: var(--text-muted-dark); border-color: var(--border-color-dark); }
body.dark-mode .input-group .btn-outline-secondary:hover { background-color: var(--secondary-color); color: #fff; }
/* Estilos oscuros para Modales (Vistas) */
body.dark-mode .modal-content { background-color: var(--panel-bg-dark) !important; color: var(--text-dark) !important; border-color: var(--border-color-dark) !important; }
body.dark-mode .modal-header { background-color: var(--card-header-bg-dark) !important; border-bottom-color: var(--border-color-dark) !important; }
body.dark-mode .modal-title { color: var(--text-dark) !important; }
body.dark-mode .modal-header .btn-close { filter: invert(1) grayscale(100%) brightness(200%) !important; }
body.dark-mode .modal-body { color: var(--text-dark) !important; }
body.dark-mode .modal-body label.form-label { color: var(--text-muted-dark) !important; }
body.dark-mode .modal-body .form-control { background-color: var(--input-bg-dark) !important; border-color: var(--border-color-dark) !important; color: var(--text-dark) !important; }
body.dark-mode .modal-body .form-control:focus { background-color: #444 !important; color: var(--text-dark) !important; border-color: var(--primary-color) !important; box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.3) !important; }
body.dark-mode .modal-body .form-text { color: var(--text-muted-dark) !important; }
body.dark-mode .modal-footer { background-color: var(--card-header-bg-dark) !important; border-top-color: var(--border-color-dark) !important; }
body.dark-mode .modal-footer .btn-secondary { background-color: #5a6268 !important; border-color: #545b62 !important; color: #fff !important; }
body.dark-mode .modal-footer .btn-secondary:hover { background-color: #4e555b !important; border-color: #484e53 !important; }
body.dark-mode .modal-body input[type="file"].form-control { background-color: var(--input-bg-dark) !important; color: var(--text-muted-dark) !important; }
body.dark-mode .modal-body input[type="file"].form-control::file-selector-button { background-color: #5a6268; border-color: #545b62; color: #fff; border-radius: var(--bs-border-radius); padding: var(--bs-btn-padding-y) var(--bs-btn-padding-x); transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out; }
body.dark-mode .modal-body input[type="file"].form-control::file-selector-button:hover { background-color: #4e555b; border-color: #484e53; }

/* --- Estilos oscuros para Búsqueda Dashboard --- */
body.dark-mode #dashboardSearchResults .card { border-color: var(--card-border-dark); background-color: var(--card-bg-dark); }
body.dark-mode #dashboardSearchResults .card-header { background-color: var(--card-header-bg-dark); border-bottom-color: var(--card-border-dark); color: var(--text-dark); }
body.dark-mode #dashboardSearchResults .card-header-icon i { color: var(--link-color-dark); }
body.dark-mode #dashboardSearchResults .card-body { color: var(--text-dark); }
body.dark-mode #dashboardSearchResults .data-list dt { color: var(--footer-text-dark); }
body.dark-mode #dashboardSearchResults .data-list dd { color: var(--text-dark); }
body.dark-mode #dashboardSearchResults .text-muted { color: var(--footer-text-dark) !important; }


/* === AJUSTES RESPONSIVOS === */
@media (max-width: 767.98px) {
    /* Login */
    body.login-page-body { align-items: flex-start; padding-top: 2rem; }
    .login-box { flex-direction: column !important; max-width: 420px; min-height: auto; margin: 0 auto; box-shadow: var(--shadow-light); }
    body.dark-mode .login-box { box-shadow: var(--shadow-dark); }
    .login-box-form { padding: 2rem !important; }
    /* Dashboard */
    #sidebar-wrapper { margin-left: -250px; }
    #page-content-wrapper { width: 100%; margin-left: 0; }
    #wrapper.toggled #sidebar-wrapper { margin-left: 0; }
    /* Ajustes Búsqueda Dashboard en móvil */
     #dashboardSearchResults .data-list dt { font-size: 0.75rem; }
     #dashboardSearchResults .data-list dd { font-size: 0.85rem; }
     #dashboardSearchResults .card-body { padding: 0.8rem; }
     #dashboardSearchResults .card-header { padding: 0.5rem 0.8rem; font-size: 0.9rem; }
}