/**
 * Dark Mode Styles
 * 
 * CSS variables and styles for dark mode theme
 * 
 * @package Trippy's Food Corporation ERP
 * @version 2.0
 */

/* Dark mode root variables - compatible with Tailwind's dark class */
:root[data-theme="dark"], .dark {
    /* Background colors */
    --bg-primary: #1a1a1a;
    --bg-secondary: #2d2d2d;
    --bg-tertiary: #3a3a3a;
    --bg-card: #2a2a2a;
    --bg-input: #333333;
    --bg-hover: #404040;
    
    /* Text colors */
    --text-primary: #ffffff;
    --text-secondary: #e0e0e0;
    --text-muted: #b0b0b0;
    --text-disabled: #666666;
    
    /* Vehicle management text colors */
    --text-tertiary: #b0b0b0;
    --text-inverse: #111827;
    
    /* Border colors */
    --border-primary: #444444;
    --border-secondary: #555555;
    --border-input: #666666;
    
    /* Button colors */
    --btn-primary-bg: #3b82f6;
    --btn-primary-hover: #2563eb;
    --btn-secondary-bg: #374151;
    --btn-secondary-hover: #4b5563;
    
    /* Status colors */
    --success: #10b981;
    --warning: #f59e0b;
    --error: #ef4444;
    --info: #3b82f6;
    
    /* Vehicle management specific colors */
    --vehicle-primary: #0068E1;
    --vehicle-primary-dark: #0055BD;
    --vehicle-success: #0A9E67;
    --vehicle-warning: #F5B14C;
    --vehicle-danger: #E43F55;
    --vehicle-info: #3B82F6;
    
    /* Vehicle management background colors */
    --vehicle-bg-primary-light: #1e293b;
    --vehicle-bg-success-light: #14532d;
    --vehicle-bg-warning-light: #7c2d12;
    --vehicle-bg-danger-light: #7f1d1d;
    --vehicle-bg-info-light: #1e3a8a;
}

/* Dark mode base styles - compatible with Tailwind's dark class */
[data-theme="dark"], .dark {
    color-scheme: dark;
}

[data-theme="dark"] body, .dark body {
    background-color: var(--bg-primary);
    color: var(--text-primary);
}

/* Base text color override for dark mode */
[data-theme="dark"] body,
[data-theme="dark"] body p,
[data-theme="dark"] body li,
[data-theme="dark"] body span,
[data-theme="dark"] body td,
[data-theme="dark"] body th,
.dark body,
.dark body p,
.dark body li,
.dark body span,
.dark body td,
.dark body th {
    color: var(--text-primary);
}

/* Reset colors for specific elements that need different colors */
[data-theme="dark"] .text-red-600, 
[data-theme="dark"] .text-red-700,
[data-theme="dark"] .text-red-800,
[data-theme="dark"] .dropdown-toggle,
[data-theme="dark"] a.text-red-600,
[data-theme="dark"] button.text-red-600 {
    color: #ff6b6b !important;
}

/* Header buttons in dark mode */
[data-theme="dark"] header button.bg-white,
[data-theme="dark"] header div[x-data] button.border-gray-200 {
    background-color: var(--bg-card) !important;
    border-color: var(--border-primary) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] header button:hover {
    background-color: var(--bg-hover) !important;
}

[data-theme="dark"] header .text-gray-700 {
    color: var(--text-secondary) !important;
}

/* Language selector icon and backdrop */
[data-theme="dark"] header button .fa-globe.text-red-600 {
    color: #ff6b6b !important;
}

[data-theme="dark"] header.bg-white\/80,
[data-theme="dark"] header.backdrop-blur {
    background-color: rgba(26, 26, 26, 0.8) !important;
}

/* Keep icons and special elements visible */
[data-theme="dark"] i.fas,
[data-theme="dark"] i.far,
[data-theme="dark"] i.fab,
[data-theme="dark"] svg {
    color: inherit;
}

/* Ensure proper contrast for specific elements */
[data-theme="dark"] .text-green-500 { color: #10b981 !important; }
[data-theme="dark"] .text-blue-600 { color: #3b82f6 !important; }
[data-theme="dark"] .text-yellow-600 { color: #f59e0b !important; }

[data-theme="dark"] .bg-red-600 {
    background-color: #e53e3e !important;
    color: white !important;
}

/* Cards and containers */
[data-theme="dark"] .card,
[data-theme="dark"] .bg-white,
[data-theme="dark"] .settings-card,
[data-theme="dark"] main .bg-white,
[data-theme="dark"] #addUserModal .bg-white,
[data-theme="dark"] #confirmationModal .bg-white {
    background-color: var(--bg-card) !important;
    border-color: transparent !important;
}

/* Main content area */
[data-theme="dark"] main.bg-gray-50 {
    background-color: var(--bg-primary) !important;
}

/* Navbar and header */
[data-theme="dark"] #sidebar {
    background-color: var(--bg-primary) !important;
    border-color: var(--border-primary) !important;
}

[data-theme="dark"] #sidebar a,
[data-theme="dark"] #sidebar .dropdown-toggle {
    color: var(--text-primary) !important;
}

/* Fix for specifically styled sidebar links and dropdown toggles */
[data-theme="dark"] #sidebar .text-gray-700 {
    color: var(--text-primary) !important;
}

[data-theme="dark"] #sidebar .text-red-600,
[data-theme="dark"] #sidebar .text-red-700 {
    color: var(--text-primary) !important;
}

[data-theme="dark"] #sidebar a:hover:not(.bg-red-600),
[data-theme="dark"] #sidebar .dropdown-toggle:hover {
    background-color: var(--bg-hover) !important;
}

[data-theme="dark"] header {
    background-color: var(--bg-primary) !important;
    border-color: var(--border-primary) !important;
}

[data-theme="dark"] header .text-gray-800,
[data-theme="dark"] header button span {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .user-dropdown-menu {
    background-color: var(--bg-primary) !important;
    border-color: var(--border-primary) !important;
}

[data-theme="dark"] .mobile-menu-item {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .mobile-menu-item:hover {
    background-color: var(--bg-hover) !important;
}

/* Dropdown menus in navbar */
[data-theme="dark"] #floating-dropdowns .dropdown-menu,
[data-theme="dark"] header div[x-show="langOpen"] {
    background-color: var(--bg-primary) !important;
    border-color: var(--border-primary) !important;
}

[data-theme="dark"] #floating-dropdowns .dropdown-menu li a,
[data-theme="dark"] header div[x-show="langOpen"] a {
    color: var(--text-primary) !important;
}

[data-theme="dark"] #floating-dropdowns .dropdown-menu li a:hover,
[data-theme="dark"] header div[x-show="langOpen"] a:hover {
    background-color: var(--bg-hover) !important;
    color: var(--btn-primary-bg) !important;
}

[data-theme="dark"] #floating-dropdowns .dropdown-menu li a:not(.bg-red-600),
[data-theme="dark"] header div[x-show="langOpen"] a:not(.bg-red-600) {
    color: var(--text-primary) !important;
}

/* Language selector selected item in dark mode */
[data-theme="dark"] header div[x-show="langOpen"] a.bg-red-50 {
    background-color: var(--bg-tertiary) !important;
}

[data-theme="dark"] .bg-gray-50,
[data-theme="dark"] thead tr.bg-gray-50 {
    background-color: var(--bg-secondary) !important;
}

[data-theme="dark"] .bg-gray-100,
[data-theme="dark"] tbody tr.hover\:bg-gray-50:hover {
    background-color: var(--bg-tertiary) !important;
}

/* Modal backgrounds and confirmation dialogs */
[data-theme="dark"] #confirmationModal,
[data-theme="dark"] #addUserModal,
[data-theme="dark"] .fixed.inset-0.bg-gray-900.bg-opacity-50 {
    background-color: rgba(0, 0, 0, 0.7) !important;
}

[data-theme="dark"] .modal-content,
[data-theme="dark"] .bg-gray-50.px-4.py-3.sm\:px-6,
[data-theme="dark"] .bg-gray-50.rounded-b-lg {
    background-color: var(--bg-secondary) !important;
}

/* Text colors */
[data-theme="dark"] .text-gray-900 {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .text-gray-700 {
    color: var(--text-secondary) !important;
}

[data-theme="dark"] .text-gray-500 {
    color: var(--text-muted) !important;
}

[data-theme="dark"] .text-gray-400 {
    color: var(--text-disabled) !important;
}

/* Form elements */
[data-theme="dark"] input,
[data-theme="dark"] textarea,
[data-theme="dark"] select,
[data-theme="dark"] .rounded-md,
[data-theme="dark"] .border-gray-300 {
    background-color: var(--bg-input) !important;
    border-color: var(--border-input) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] input:focus,
[data-theme="dark"] textarea:focus,
[data-theme="dark"] select:focus {
    border-color: var(--btn-primary-bg) !important;
    box-shadow: 0 0 0 1px var(--btn-primary-bg) !important;
}

[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder {
    color: var(--text-muted) !important;
}

/* Vehicle Management Form Elements in Dark Mode */
[data-theme="dark"] .form-control {
    background-color: var(--bg-input) !important;
    border: 1px solid var(--border-input) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .form-control:focus {
    border-color: var(--vehicle-primary) !important;
    box-shadow: 0 0 0 3px rgba(0, 104, 225, 0.2) !important;
    background-color: var(--bg-input) !important;
}

[data-theme="dark"] .form-control:disabled {
    background-color: var(--bg-tertiary) !important;
    color: var(--text-disabled) !important;
}

[data-theme="dark"] .form-control.is-invalid {
    border-color: var(--vehicle-danger) !important;
    box-shadow: 0 0 0 3px rgba(228, 63, 85, 0.2) !important;
}

[data-theme="dark"] .form-control.is-valid {
    border-color: var(--vehicle-success) !important;
    box-shadow: 0 0 0 3px rgba(10, 158, 103, 0.2) !important;
}

[data-theme="dark"] .form-label {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .form-select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23b0b0b0' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e") !important;
    background-color: var(--bg-input) !important;
    border: 1px solid var(--border-input) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .form-select:focus {
    border-color: var(--vehicle-primary) !important;
    box-shadow: 0 0 0 3px rgba(0, 104, 225, 0.2) !important;
}

/* Buttons */
[data-theme="dark"] .btn-secondary,
[data-theme="dark"] button.bg-gray-100,
[data-theme="dark"] button.bg-white {
    background-color: var(--btn-secondary-bg) !important;
    border-color: var(--border-secondary) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .btn-secondary:hover,
[data-theme="dark"] button.hover\:bg-gray-50:hover,
[data-theme="dark"] button.hover\:bg-gray-200:hover {
    background-color: var(--btn-secondary-hover) !important;
}

/* Vehicle Management Buttons in Dark Mode */
[data-theme="dark"] .btn {
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

[data-theme="dark"] .btn::before {
  background: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .btn-primary {
  background-color: var(--vehicle-primary) !important;
  border-color: var(--vehicle-primary) !important;
  color: white !important;
}

[data-theme="dark"] .btn-primary:hover:not(:disabled) {
  background-color: var(--vehicle-primary-dark) !important;
  border-color: var(--vehicle-primary-dark) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px -1px rgba(0, 104, 225, 0.4) !important;
}

[data-theme="dark"] .btn-primary:active:not(:disabled) {
  background-color: var(--vehicle-primary-dark) !important;
  border-color: var(--vehicle-primary-dark) !important;
  transform: translateY(0);
  box-shadow: 0 2px 4px -1px rgba(0, 104, 225, 0.4) !important;
}

[data-theme="dark"] .btn-secondary {
  background-color: var(--btn-secondary-bg) !important;
  border-color: var(--border-secondary) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .btn-secondary:hover:not(:disabled) {
  background-color: var(--btn-secondary-hover) !important;
  border-color: var(--border-primary) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.25) !important;
}

[data-theme="dark"] .btn-secondary:active:not(:disabled) {
  background-color: var(--bg-tertiary) !important;
  border-color: var(--border-secondary) !important;
  transform: translateY(0);
  box-shadow: 0 2px 4px -1px rgba(0, 0, 0, 0.25) !important;
}

[data-theme="dark"] .btn-success {
  background-color: var(--vehicle-success) !important;
  border-color: var(--vehicle-success) !important;
  color: white !important;
}

[data-theme="dark"] .btn-success:hover:not(:disabled) {
  background-color: #088254 !important;
  border-color: #088254 !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px -1px rgba(10, 158, 103, 0.4) !important;
}

[data-theme="dark"] .btn-success:active:not(:disabled) {
  background-color: #088254 !important;
  border-color: #088254 !important;
  transform: translateY(0);
  box-shadow: 0 2px 4px -1px rgba(10, 158, 103, 0.4) !important;
}

[data-theme="dark"] .btn-warning {
  background-color: var(--vehicle-warning) !important;
  border-color: var(--vehicle-warning) !important;
  color: white !important;
}

[data-theme="dark"] .btn-warning:hover:not(:disabled) {
  background-color: #E0A144 !important;
  border-color: #E0A144 !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px -1px rgba(245, 177, 76, 0.4) !important;
}

[data-theme="dark"] .btn-warning:active:not(:disabled) {
  background-color: #E0A144 !important;
  border-color: #E0A144 !important;
  transform: translateY(0);
  box-shadow: 0 2px 4px -1px rgba(245, 177, 76, 0.4) !important;
}

[data-theme="dark"] .btn-danger {
  background-color: var(--vehicle-danger) !important;
  border-color: var(--vehicle-danger) !important;
  color: white !important;
}

[data-theme="dark"] .btn-danger:hover:not(:disabled) {
  background-color: #D23347 !important;
  border-color: #D23347 !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px -1px rgba(228, 63, 85, 0.4) !important;
}

[data-theme="dark"] .btn-danger:active:not(:disabled) {
  background-color: #D23347 !important;
  border-color: #D23347 !important;
  transform: translateY(0);
  box-shadow: 0 2px 4px -1px rgba(228, 63, 85, 0.4) !important;
}

[data-theme="dark"] .btn-outline-primary {
  background-color: transparent !important;
  color: var(--vehicle-primary) !important;
  border-color: var(--vehicle-primary) !important;
}

[data-theme="dark"] .btn-outline-primary:hover:not(:disabled) {
  background-color: rgba(0, 104, 225, 0.15) !important;
  border-color: var(--vehicle-primary) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px -1px rgba(0, 104, 225, 0.4) !important;
}

[data-theme="dark"] .btn-outline-primary:active:not(:disabled) {
  background-color: rgba(0, 104, 225, 0.25) !important;
  border-color: var(--vehicle-primary) !important;
  transform: translateY(0);
  box-shadow: 0 2px 4px -1px rgba(0, 104, 225, 0.4) !important;
}

[data-theme="dark"] .btn-outline-secondary {
  background-color: transparent !important;
  color: var(--text-secondary) !important;
  border-color: var(--border-secondary) !important;
}

[data-theme="dark"] .btn-outline-secondary:hover:not(:disabled) {
  background-color: var(--bg-hover) !important;
  border-color: var(--border-primary) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.25) !important;
}

[data-theme="dark"] .btn-outline-secondary:active:not(:disabled) {
  background-color: var(--bg-tertiary) !important;
  border-color: var(--border-secondary) !important;
  transform: translateY(0);
  box-shadow: 0 2px 4px -1px rgba(0, 0, 0, 0.25) !important;
}

[data-theme="dark"] .btn-success {
    background-color: var(--vehicle-success) !important;
    border-color: var(--vehicle-success) !important;
    color: white !important;
}

[data-theme="dark"] .btn-success:hover:not(:disabled) {
    background-color: #088254 !important;
    border-color: #088254 !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 6px -1px rgba(10, 158, 103, 0.3) !important;
}

[data-theme="dark"] .btn-success:active:not(:disabled) {
    background-color: #088254 !important;
    border-color: #088254 !important;
    transform: translateY(0);
    box-shadow: 0 2px 4px -1px rgba(10, 158, 103, 0.3) !important;
}

[data-theme="dark"] .btn-warning {
    background-color: var(--vehicle-warning) !important;
    border-color: var(--vehicle-warning) !important;
    color: white !important;
}

[data-theme="dark"] .btn-warning:hover:not(:disabled) {
    background-color: #E0A144 !important;
    border-color: #E0A144 !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 6px -1px rgba(245, 177, 76, 0.3) !important;
}

[data-theme="dark"] .btn-warning:active:not(:disabled) {
    background-color: #E0A144 !important;
    border-color: #E0A144 !important;
    transform: translateY(0);
    box-shadow: 0 2px 4px -1px rgba(245, 177, 76, 0.3) !important;
}

[data-theme="dark"] .btn-danger {
    background-color: var(--vehicle-danger) !important;
    border-color: var(--vehicle-danger) !important;
    color: white !important;
}

[data-theme="dark"] .btn-danger:hover:not(:disabled) {
    background-color: #D23347 !important;
    border-color: #D23347 !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 6px -1px rgba(228, 63, 85, 0.3) !important;
}

[data-theme="dark"] .btn-danger:active:not(:disabled) {
    background-color: #D23347 !important;
    border-color: #D23347 !important;
    transform: translateY(0);
    box-shadow: 0 2px 4px -1px rgba(228, 63, 85, 0.3) !important;
}

[data-theme="dark"] .btn-outline-primary {
    background-color: transparent !important;
    color: var(--vehicle-primary) !important;
    border-color: var(--vehicle-primary) !important;
}

[data-theme="dark"] .btn-outline-primary:hover:not(:disabled) {
    background-color: rgba(0, 104, 225, 0.1) !important;
    border-color: var(--vehicle-primary) !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 6px -1px rgba(0, 104, 225, 0.3) !important;
}

[data-theme="dark"] .btn-outline-primary:active:not(:disabled) {
    background-color: rgba(0, 104, 225, 0.2) !important;
    border-color: var(--vehicle-primary) !important;
    transform: translateY(0);
    box-shadow: 0 2px 4px -1px rgba(0, 104, 225, 0.3) !important;
}

[data-theme="dark"] .btn-outline-secondary {
    background-color: transparent !important;
    color: var(--text-secondary) !important;
    border-color: var(--border-secondary) !important;
}

[data-theme="dark"] .btn-outline-secondary:hover:not(:disabled) {
    background-color: var(--bg-hover) !important;
    border-color: var(--border-primary) !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.2) !important;
}

[data-theme="dark"] .btn-outline-secondary:active:not(:disabled) {
    background-color: var(--bg-tertiary) !important;
    border-color: var(--border-secondary) !important;
    transform: translateY(0);
    box-shadow: 0 2px 4px -1px rgba(0, 0, 0, 0.2) !important;
}

/* Borders */
[data-theme="dark"] .border-gray-200 {
    border-color: var(--border-primary) !important;
}

[data-theme="dark"] .border-gray-300 {
    border-color: var(--border-secondary) !important;
}

/* Tabs */
[data-theme="dark"] .tab-button {
    background-color: var(--bg-secondary) !important;
    border-color: var(--border-primary) !important;
    color: var(--text-secondary) !important;
}

[data-theme="dark"] .tab-button.active {
    background-color: var(--bg-card) !important;
    color: var(--text-primary) !important;
    border-bottom-color: var(--bg-card) !important;
}

[data-theme="dark"] .tab-button:hover:not(.active) {
    background-color: var(--bg-hover) !important;
}

/* Toggle switches */
[data-theme="dark"] .toggle-switch {
    /* The base inactive background is now primarily controlled by settings.css .toggle-switch */
    /* We only need to override border for dark mode if different */
    border-color: var(--border-input) !important;
}

/* Style the switch's active state based on the checkbox state in dark mode */
[data-theme="dark"] .toggle-input:checked + .toggle-switch {
    background-color: var(--btn-primary-bg) !important; /* Dark active background (blue) */
}

/* Style the circle's color in dark mode */
[data-theme="dark"] .toggle-switch::before {
    background-color: var(--text-primary) !important; /* Circle color in dark mode */
}

/* The transform for moving the circle is in settings.css .toggle-input:checked + .toggle-switch::before */
/* and should apply in dark mode as well, as it's not overridden here. */

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

[data-theme="dark"] .upload-area.dragover {
    background-color: var(--bg-hover) !important;
    border-color: var(--btn-primary-bg) !important;
}

/* Status indicators */
[data-theme="dark"] .status-good {
    color: var(--success) !important;
}

[data-theme="dark"] .status-warning {
    color: var(--warning) !important;
}

[data-theme="dark"] .status-error {
    color: var(--error) !important;
}

/* Vehicle Management Status Badges in Dark Mode */
[data-theme="dark"] .status-badge {
  transition: all 0.2s ease;
}

[data-theme="dark"] .status-badge-primary {
  background-color: var(--vehicle-bg-primary-light) !important;
  color: #93c5fd !important;
  border: 1px solid var(--vehicle-primary) !important;
}

[data-theme="dark"] .status-badge-success {
  background-color: var(--vehicle-bg-success-light) !important;
  color: #4ade80 !important;
  border: 1px solid var(--vehicle-success) !important;
}

[data-theme="dark"] .status-badge-warning {
  background-color: var(--vehicle-bg-warning-light) !important;
  color: #fbbf24 !important;
  border: 1px solid var(--vehicle-warning) !important;
}

[data-theme="dark"] .status-badge-danger {
  background-color: var(--vehicle-bg-danger-light) !important;
  color: #f87171 !important;
  border: 1px solid var(--vehicle-danger) !important;
}

[data-theme="dark"] .status-badge-info {
  background-color: var(--vehicle-bg-info-light) !important;
  color: #93c5fd !important;
  border: 1px solid var(--vehicle-info) !important;
}

[data-theme="dark"] .status-badge:focus {
  outline: 2px solid var(--vehicle-primary) !important;
  outline-offset: 2px !important;
}

/* Vehicle Management Filter Chips in Dark Mode */
[data-theme="dark"] .filter-chip {
  background-color: var(--bg-secondary) !important;
  color: var(--text-secondary) !important;
  border: 1px solid var(--border-primary) !important;
}

[data-theme="dark"] .filter-chip:hover {
  background-color: var(--bg-hover) !important;
}

[data-theme="dark"] .filter-chip .remove-btn {
  color: var(--text-tertiary) !important;
}

[data-theme="dark"] .filter-chip .remove-btn:hover {
  background-color: var(--vehicle-bg-danger-light) !important;
  color: var(--vehicle-danger) !important;
}

/* User table and form elements */
[data-theme="dark"] table thead,
[data-theme="dark"] table thead tr,
[data-theme="dark"] table thead th,
[data-theme="dark"] table thead th a {
    color: var(--text-muted) !important;
    background-color: var(--bg-secondary) !important;
}

/* Fix table header colors */
[data-theme="dark"] table th {
    background-color: var(--bg-secondary) !important;
}

[data-theme="dark"] table tbody td .text-gray-900 {
    color: var(--text-primary) !important;
}

[data-theme="dark"] table tbody tr:hover {
    background-color: var(--bg-hover) !important;
}

[data-theme="dark"] .text-sm.font-medium.text-gray-700,
[data-theme="dark"] .text-sm.text-gray-700 {
    color: var(--text-secondary) !important;
}

/* Status badges and chips */
[data-theme="dark"] .bg-green-100,
[data-theme="dark"] .bg-blue-100,
[data-theme="dark"] .bg-blue-50,
[data-theme="dark"] .bg-gray-100,
[data-theme="dark"] .bg-yellow-100,
[data-theme="dark"] .bg-red-100,
[data-theme="dark"] .bg-pink-100,
[data-theme="dark"] .bg-indigo-100 {
    background-color: var(--bg-tertiary) !important;
    border: 1px solid var(--border-secondary) !important;
}

/* Vehicle Management Dashboard Cards in Dark Mode */
[data-theme="dark"] .card.bg-primary.text-white,
[data-theme="dark"] .card.bg-success.text-white,
[data-theme="dark"] .card.bg-warning.text-white,
[data-theme="dark"] .card.bg-info.text-white {
    border: 1px solid var(--border-primary) !important;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.2) !important;
}

[data-theme="dark"] .card.bg-primary.text-white {
    background-color: var(--vehicle-bg-primary-light) !important;
}

[data-theme="dark"] .card.bg-success.text-white {
    background-color: var(--vehicle-bg-success-light) !important;
}

[data-theme="dark"] .card.bg-warning.text-white {
    background-color: var(--vehicle-bg-warning-light) !important;
}

[data-theme="dark"] .card.bg-info.text-white {
    background-color: var(--vehicle-bg-info-light) !important;
}

[data-theme="dark"] .card.bg-primary.text-white:hover,
[data-theme="dark"] .card.bg-success.text-white:hover,
[data-theme="dark"] .card.bg-warning.text-white:hover,
[data-theme="dark"] .card.bg-info.text-white:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.4), 0 4px 6px -2px rgba(0, 0, 0, 0.2) !important;
}

/* Vehicle Management Chart Containers in Dark Mode */
[data-theme="dark"] .chart-container {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-primary) !important;
    box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.3) !important;
}

[data-theme="dark"] .chart-header {
    border-bottom: 1px solid var(--border-primary) !important;
}

/* Ensure dark background for backup create container */
[data-theme="dark"] .settings-card .bg-blue-50 {
    background-color: var(--bg-tertiary) !important;
}

[data-theme="dark"] .text-green-800 {
    color: #4ade80 !important;
}

[data-theme="dark"] .text-blue-800 {
    color: #60a5fa !important;
}

[data-theme="dark"] .text-indigo-800 {
    color: #818cf8 !important;
}

[data-theme="dark"] .text-gray-800 {
    color: var(--text-secondary) !important;
}

/* Pagination in dark mode */
[data-theme="dark"] .border-gray-300.bg-white {
    background-color: var(--bg-secondary) !important;
    border-color: var(--border-primary) !important;
}

[data-theme="dark"] .hover\:bg-gray-50:hover {
    background-color: var(--bg-hover) !important;
}

/* E-Wallet Dashboard Cards */
[data-theme="dark"] .inactive-wallet-card,
[data-theme="dark"] .active-wallet-card,
[data-theme="dark"] .closed-wallet-card,
[data-theme="dark"] .total-balance-card {
    background-color: var(--bg-card) !important;
    border-color: var(--border-primary) !important;
}

/* Vehicle Management Chart Styles in Dark Mode */
[data-theme="dark"] .chart-container {
  background: var(--bg-card) !important;
  border: 1px solid var(--border-primary) !important;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.3) !important;
}

[data-theme="dark"] .chart-container:hover {
  box-shadow: 0 4px 12px 0 rgba(0, 0, 0, 0.12) !important;
}

[data-theme="dark"] .chart-header {
  border-bottom: 1px solid var(--border-primary) !important;
}

[data-theme="dark"] .chart-title {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .chart-wrapper {
  filter: invert(1) hue-rotate(180deg);
}

[data-theme="dark"] canvas {
  filter: invert(1) hue-rotate(180deg);
}

/* Ensure chart legends and labels are visible in dark mode */
[data-theme="dark"] .apexcharts-text,
[data-theme="dark"] .apexcharts-legend-text {
    fill: var(--text-primary) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .apexcharts-xaxis-label,
[data-theme="dark"] .apexcharts-yaxis-label {
    fill: var(--text-secondary) !important;
    color: var(--text-secondary) !important;
}

[data-theme="dark"] .apexcharts-tooltip {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-primary) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .apexcharts-tooltip-title {
    background: var(--bg-secondary) !important;
    border-bottom: 1px solid var(--border-primary) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .apexcharts-tooltip-series-group {
    background: var(--bg-card) !important;
    color: var(--text-primary) !important;
}

/* Chart.js specific dark mode styles */
[data-theme="dark"] .chartjs-render-monitor {
    filter: invert(1) hue-rotate(180deg);
}

/* Make sure wallet stats cards are properly styled */
[data-theme="dark"] [class*="wallet"] .card,
[data-theme="dark"] [id*="wallet"] .card {
    background-color: var(--bg-card) !important;
    border-color: var(--border-primary) !important;
}

/* E-Wallet Icon Containers */
[data-theme="dark"] .wallet-icon-container,
[data-theme="dark"] [class*="e-wallet"] circle,
[data-theme="dark"] [id*="e-wallet"] circle {
    background-color: var(--bg-tertiary) !important;
}

/* Specific styling for inactive wallet icon (yellow triangle) */
[data-theme="dark"] .inactive-wallet-icon,
[data-theme="dark"] [id*="inactive"] svg,
[data-theme="dark"] [class*="inactive"] svg {
    color: var(--warning) !important;
}

/* Message for "No e-wallets found" */
[data-theme="dark"] td[colspan] {
    background-color: var(--bg-card) !important;
    color: var(--text-secondary) !important;
}

/* Search box in e-wallet page */
[data-theme="dark"] input[type="search"],
[data-theme="dark"] [placeholder*="Search"] {
    background-color: var(--bg-input) !important;
    border-color: var(--border-input) !important;
    color: var(--text-primary) !important;
}

/* Form modal background */
[data-theme="dark"] .p-6 {
    background-color: var(--bg-card);
}

/* Notifications */
[data-theme="dark"] .notification {
    background-color: var(--bg-tertiary) !important;
    border-color: var(--border-secondary) !important;
    color: var(--text-primary) !important;
}

/* Payroll Group specific styles */
[data-theme="dark"] .bg-gradient-to-r.from-red-600.to-red-700 {
    background: linear-gradient(to right, #dc2626, #b91c1c);
}

[data-theme="dark"] .bg-gradient-to-r.from-gray-50.to-white {
    background: linear-gradient(to right, var(--bg-secondary), var(--bg-tertiary));
}

/* Payroll Group status badges */
[data-theme="dark"] .bg-green-100.text-green-800,
[data-theme="dark"] .rounded-full.bg-green-100 {
    background-color: rgba(16, 185, 129, 0.2) !important;
    color: #4ade80 !important;
}

[data-theme="dark"] .bg-red-100.text-red-800,
[data-theme="dark"] .rounded-full.bg-red-100 {
    background-color: rgba(239, 68, 68, 0.2) !important;
    color: #f87171 !important;
}

/* Payroll Group section colors */
[data-theme="dark"] .bg-blue-100,
[data-theme="dark"] .bg-green-100,
[data-theme="dark"] .bg-purple-100 {
    background-color: rgba(59, 130, 246, 0.15) !important;
}

[data-theme="dark"] .bg-blue-900,
[data-theme="dark"] .bg-green-900,
[data-theme="dark"] .bg-purple-900 {
    background-color: rgba(30, 58, 138, 0.3) !important;
}

/* Fix icon colors in dark mode for payroll groups */
[data-theme="dark"] .text-blue-600,
[data-theme="dark"] .text-green-600,
[data-theme="dark"] .text-purple-600 {
    color: #60a5fa !important;
}

[data-theme="dark"] .text-blue-300,
[data-theme="dark"] .text-green-300,
[data-theme="dark"] .text-purple-300 {
    color: #93c5fd !important;
}

/* Payroll Group form elements in dark mode */
[data-theme="dark"] .bg-gray-750 {
    background-color: #2d3748 !important;
}

/* Payroll Group status radio buttons */
[data-theme="dark"] input[type="radio"].form-radio {
    background-color: var(--bg-input);
    border-color: var(--border-input);
}

[data-theme="dark"] input[type="radio"].form-radio:checked {
    background-color: var(--btn-primary-bg);
    border-color: var(--btn-primary-bg);
}

[data-theme="dark"] input[type="radio"].text-green-500:checked {
    background-color: #10b981 !important;
    border-color: #10b981 !important;
}

[data-theme="dark"] input[type="radio"].text-gray-500:checked {
    background-color: #6b7280 !important;
    border-color: #6b7280 !important;
}

/* Status badges in payroll groups */
[data-theme="dark"] .bg-green-500 {
    background-color: #10b981 !important;
}

[data-theme="dark"] .bg-red-500 {
    background-color: #ef4444 !important;
}

[data-theme="dark"] .bg-gray-300.text-gray-700 {
    background-color: #4b5563 !important;
    color: #e5e7eb !important;
}

/* Fix inline help icons in payroll groups */
[data-theme="dark"] .text-yellow-500,
[data-theme="dark"] .fas.fa-lightbulb {
    color: #f59e0b !important;
}

/* Delete modal styling for payroll groups */
[data-theme="dark"] .bg-red-50 {
    background-color: rgba(239, 68, 68, 0.1) !important;
}

[data-theme="dark"] .border-red-100 {
    border-color: rgba(239, 68, 68, 0.2) !important;
}

[data-theme="dark"] .text-red-700 {
    color: #f87171 !important;
}

[data-theme="dark"] .text-red-500, 
[data-theme="dark"] .text-red-400 {
    color: #ef4444 !important;
}

[data-theme="dark"] .bg-red-800 {
    background-color: rgba(153, 27, 27, 0.8) !important;
}

[data-theme="dark"] .bg-red-900 {
    background-color: rgba(127, 29, 29, 0.5) !important;
}

/* Modal overlay for payroll group delete confirmation */
[data-theme="dark"] .modal-overlay {
    background-color: rgba(0, 0, 0, 0.7) !important;
}

/* Hover effects for payroll group elements */
[data-theme="dark"] .hover\:bg-red-700:hover {
    background-color: #b91c1c !important;
}

[data-theme="dark"] .hover\:bg-red-800:hover {
    background-color: #991b1b !important;
}

[data-theme="dark"] .hover\:text-red-600:hover {
    color: #dc2626 !important;
}

[data-theme="dark"] .hover\:text-red-800:hover {
    color: #b91c1c !important;
}

/* Scrollbars */
[data-theme="dark"] ::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

[data-theme="dark"] ::-webkit-scrollbar-track {
    background-color: var(--bg-secondary);
}

[data-theme="dark"] ::-webkit-scrollbar-thumb {
    background-color: var(--border-secondary);
    border-radius: 4px;
}

[data-theme="dark"] ::-webkit-scrollbar-thumb:hover {
    background-color: var(--border-input);
}

/* Animations and transitions */
[data-theme="dark"] body,
[data-theme="dark"] body * ,
.dark body,
.dark body * {
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

/* Enhanced transitions for vehicle management components */
[data-theme="dark"] .vehicle-card,
[data-theme="dark"] .btn,
[data-theme="dark"] .form-control,
[data-theme="dark"] .status-badge {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

[data-theme="dark"] .vehicle-card:hover,
[data-theme="dark"] .btn:hover {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Focus states for accessibility */
[data-theme="dark"] .vehicle-card:focus,
[data-theme="dark"] .btn:focus,
[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .nav-link:focus,
[data-theme="dark"] .status-badge:focus {
    outline: 2px solid var(--vehicle-primary);
    outline-offset: 2px;
}

/* Dark mode toggle animation */
.dark-mode-transition {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Media query for system preference */
@media (prefers-color-scheme: dark) {
    :root {
        color-scheme: dark;
    }
}

[data-theme="dark"] .bg-gray-200.text-gray-800 {
    background-color: var(--btn-secondary-bg) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .bg-gray-200.text-gray-800:hover {
    background-color: var(--btn-secondary-hover) !important;
}

/*
 * Dark Mode Overrides for diff2html
 * --------------------------------------------------
 */

[data-theme="dark"] .d2h-file-wrapper {
    border-color: var(--border-primary) !important;
}

[data-theme="dark"] .d2h-file-header {
    background-color: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .d2h-file-stats {
    background-color: var(--bg-tertiary) !important;
}

[data-theme="dark"] .d2h-lines-added {
    color: #4ade80 !important;
}

[data-theme="dark"] .d2h-lines-deleted {
    color: #f87171 !important;
}

[data-theme="dark"] .d2h-diff-table {
    background-color: var(--bg-primary) !important;
    border-color: var(--border-primary) !important;
}

[data-theme="dark"] .d2h-code-line {
    background-color: var(--bg-card) !important;
    color: var(--text-secondary) !important;
}

[data-theme="dark"] .d2h-code-line-ctn {
    background-color: var(--bg-card) !important;
}

[data-theme="dark"] .d2h-code-side-linenumber {
    background-color: var(--bg-secondary) !important;
    color: var(--text-muted) !important;
    border-color: var(--border-primary) !important;
}

[data-theme="dark"] .d2h-code-line-prefix {
    color: var(--text-muted) !important;
}

[data-theme="dark"] .d2h-info {
    background-color: #2563eb !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .d2h-ins {
    background-color: rgba(16, 185, 129, 0.15) !important;
}

[data-theme="dark"] .d2h-del {
    background-color: rgba(239, 68, 68, 0.15) !important;
}

[data-theme="dark"] .d2h-ins .d2h-code-line-prefix {
    color: #4ade80 !important;
}

[data-theme="dark"] .d2h-del .d2h-code-line-prefix {
    color: #f87171 !important;
}

/* Income Statement Dark Mode Overrides */
[data-theme="dark"] .income-statement .bg-purple-50 {
    background-color: #3730a3 !important; /* Indigo-700 */
    color: #e0e7ff !important; /* Indigo-100 */
}

[data-theme="dark"] .income-statement .text-purple-800 {
    color: #e0e7ff !important; /* Indigo-100 */
}

[data-theme="dark"] .income-statement .bg-red-50 {
    background-color: #991b1b !important; /* Red-800 */
    color: #fecaca !important; /* Red-200 */
}

[data-theme="dark"] .income-statement .text-red-800 {
    color: #fecaca !important; /* Red-200 */
}

[data-theme="dark"] .income-statement .bg-green-50 {
    background-color: #14532d !important; /* Green-900 */
    color: #dcfce7 !important; /* Green-100 */
}

[data-theme="dark"] .income-statement .text-green-800 {
    color: #dcfce7 !important; /* Green-100 */
}

/* Vehicle Management Typography in Dark Mode */
[data-theme="dark"] .vehicle-h1,
[data-theme="dark"] .vehicle-h2,
[data-theme="dark"] .vehicle-h3,
[data-theme="dark"] .vehicle-h4,
[data-theme="dark"] .vehicle-h5,
[data-theme="dark"] .vehicle-title,
[data-theme="dark"] .vehicle-subtitle,
[data-theme="dark"] .vehicle-section-title {
    color: var(--text-primary);
}

[data-theme="dark"] .vehicle-body-large,
[data-theme="dark"] .vehicle-body,
[data-theme="dark"] .vehicle-content {
    color: var(--text-secondary);
}

[data-theme="dark"] .vehicle-body-small,
[data-theme="dark"] .vehicle-caption,
[data-theme="dark"] .vehicle-overline {
    color: var(--text-tertiary);
}

[data-theme="dark"] .vehicle-card-footer {
    color: var(--text-tertiary);
}

[data-theme="dark"] .chart-title {
    color: var(--text-primary);
}

[data-theme="dark"] .form-label {
    color: var(--text-primary);
}

[data-theme="dark"] .empty-state {
    color: var(--text-tertiary);
}

[data-theme="dark"] .empty-state-title {
    color: var(--text-primary);
}

/* Vehicle Management Card Components in Dark Mode */
[data-theme="dark"] .vehicle-card {
  background: var(--bg-card);
  border: 1px solid var(--border-primary);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
}

[data-theme="dark"] .vehicle-card:hover {
  box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.4), 0 4px 6px -2px rgba(0, 0, 0, 0.2);
}

[data-theme="dark"] .vehicle-card::before {
  background: linear-gradient(90deg, var(--vehicle-primary), var(--vehicle-info));
}

[data-theme="dark"] .vehicle-card-header {
  background-color: var(--bg-secondary);
  border-bottom: 1px solid var(--border-primary);
}

[data-theme="dark"] .vehicle-card-footer {
  background-color: var(--bg-secondary);
  border-top: 1px solid var(--border-primary);
}

/* Vehicle Management Table Styles in Dark Mode */
[data-theme="dark"] .vehicle-table {
    background-color: var(--bg-card);
    border: 1px solid var(--border-primary);
}

[data-theme="dark"] .vehicle-table th {
    background-color: var(--bg-secondary);
    color: var(--text-primary);
    font-family: var(--font-family-heading);
    font-weight: var(--font-weight-semibold);
    font-size: 0.875rem;
    line-height: 1.45;
    border-bottom: 1px solid var(--border-primary);
}

[data-theme="dark"] .vehicle-table td {
    color: var(--text-secondary);
    font-family: var(--font-family-base);
    font-size: 0.875rem;
    line-height: 1.45;
    border-bottom: 1px solid var(--border-primary);
}

[data-theme="dark"] .vehicle-table tbody tr:hover {
    background-color: var(--bg-hover);
}

/* Striped table rows for better readability in dark mode */
[data-theme="dark"] .vehicle-table tbody tr:nth-child(even) {
    background-color: var(--bg-tertiary);
}

[data-theme="dark"] .vehicle-table tbody tr:nth-child(even):hover {
    background-color: var(--bg-hover);
}
