/* ============================================================
   MODERN OVERRIDES — Tailwind-era styling for CMP
   Applied AFTER main.css to override Bootstrap defaults
   ============================================================ */

/* ----------------------------------------------------------
   1. GLOBAL TYPOGRAPHY
   ---------------------------------------------------------- */
body {
    font-family: 'Inter', system-ui, -apple-system, sans-serif !important;
}

/* ----------------------------------------------------------
   2. FORM ELEMENTS — Modern, clean inputs
   ---------------------------------------------------------- */
.form-control,
.form-select {
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.875rem;
    padding: 0.5rem 0.75rem;
    border: 1px solid #e2e8f0;
    border-radius: 0.5rem;
    background-color: #fff;
    color: #334155;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.form-control:focus,
.form-select:focus {
    border-color: #2563a8;
    box-shadow: 0 0 0 3px rgba(37, 99, 168, 0.1);
    outline: none;
}

.form-control::placeholder {
    color: #94a3b8;
}

.form-label {
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.025em;
    color: #64748b;
    margin-bottom: 0.35rem;
    margin-top: 0.75rem;
    transition: color 0.2s ease;
}

/* Floating label effect — highlight label when input is focused */
.col-12:focus-within > .form-label,
.col-lg-2:focus-within > .form-label,
.col-lg-3:focus-within > .form-label,
.col-lg-4:focus-within > .form-label,
.col-lg-6:focus-within > .form-label,
.col-lg-8:focus-within > .form-label,
.col-lg-12:focus-within > .form-label,
.col-md-3:focus-within > .form-label,
.col-md-4:focus-within > .form-label,
.col-md-6:focus-within > .form-label,
.col-md-8:focus-within > .form-label,
.col-md-12:focus-within > .form-label,
.mb-3:focus-within > .form-label,
.mb-2:focus-within > .form-label,
.form-group:focus-within > .form-label {
    color: #2563a8;
}

.form-check-label {
    font-size: 0.85rem;
    color: #475569;
}

.form-check-input:checked {
    background-color: #6366f1;
    border-color: #6366f1;
}

textarea.form-control {
    border-radius: 0.5rem;
}

/* Required field indicator */
.form-label .required-indicator {
    color: #ef4444;
    font-weight: 700;
    margin-left: 2px;
}

/* Validation */
.text-danger {
    font-size: 0.75rem;
}

.form-control.input-validation-error,
.form-select.input-validation-error {
    border-color: #ef4444;
}

.form-control.input-validation-error:focus,
.form-select.input-validation-error:focus {
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}

/* ----------------------------------------------------------
   3. BUTTONS — Discrete, minimal style
   ---------------------------------------------------------- */

/* Primary action button — EEN soft blue */
.btn-primary,
.btn-primary:visited {
    background-color: #2563a8;
    border-color: #2563a8;
    color: #fff;
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: none;
    border-radius: 0.5rem;
    padding: 0.375rem 0.875rem;
    transition: all 0.2s ease;
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: #1d4f8a;
    border-color: #1d4f8a;
    color: #fff;
}

/* Outline primary */
.btn-outline-primary {
    color: #2563a8;
    border-color: #bfdbfe;
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: none;
    border-radius: 0.5rem;
    padding: 0.375rem 0.875rem;
}

.btn-outline-primary:hover {
    background-color: #eff6ff;
    border-color: #93c5fd;
    color: #1d4f8a;
}

/* Danger button (delete) — soft red */
.btn-outline-danger {
    color: #dc2626;
    border-color: #fecaca;
    border-radius: 0.5rem;
    font-size: 0.75rem;
    text-transform: none;
    padding: 0.375rem 0.875rem;
}

.btn-outline-danger:hover {
    background-color: #fef2f2;
    border-color: #f87171;
    color: #b91c1c;
}

/* Icon buttons in DataTables — ALL GRAY, only delete gets red */
.btn-icon,
.btn.btn-icon {
    background: transparent !important;
    border: none !important;
    padding: 0.2rem 0.35rem;
    border-radius: 0.375rem;
    font-size: 0.875rem;
    color: #94a3b8 !important;
    transition: all 0.15s ease;
    text-decoration: none !important;
    cursor: pointer;
}

.btn-icon:hover {
    background-color: #f8fafc !important;
    color: #475569 !important;
}

/* ALL non-delete icon buttons in btn-group — soft gray */
.btn-group .btn.btn-icon,
.btn-group .btn.link-primary.btn-icon,
.btn-group .btn.link-secondary.btn-icon,
.btn-group .btn.link-success.btn-icon,
.btn-group .btn.link-warning.btn-icon {
    color: #94a3b8 !important;
}

.btn-group .btn.btn-icon:hover,
.btn-group .btn.link-primary.btn-icon:hover,
.btn-group .btn.link-secondary.btn-icon:hover,
.btn-group .btn.link-success.btn-icon:hover,
.btn-group .btn.link-warning.btn-icon:hover {
    background-color: #f8fafc !important;
    color: #475569 !important;
}

/* Delete icon button — ONLY this gets red on hover */
.btn-group .btn.link-danger.btn-icon {
    color: #cbd5e1 !important;
}

.btn-group .btn.link-danger.btn-icon:hover {
    background-color: #fef2f2 !important;
    color: #ef4444 !important;
}

/* Create new / action links in page headers */
a.btn.link-primary.btn-icon:not(.btn-group .btn) {
    color: #475569 !important;
    font-weight: 500;
}

a.btn.link-primary.btn-icon:not(.btn-group .btn):hover {
    color: #2563a8 !important;
}

/* ----------------------------------------------------------
   4. CARDS — Softer, modern
   ---------------------------------------------------------- */
.card {
    border: 1px solid #f1f5f9;
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.04), 0 1px 2px -1px rgba(0, 0, 0, 0.04);
}

.card-header {
    background-color: transparent;
    border-bottom: 1px solid #f1f5f9;
    font-weight: 600;
    font-size: 0.875rem;
    color: #334155;
}

/* ----------------------------------------------------------
   5. TABLES / DATATABLES — Clean, minimal
   ---------------------------------------------------------- */
table.dataTable {
    border-collapse: separate !important;
    border-spacing: 0;
}

table.dataTable thead th {
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #64748b;
    border-bottom: 2px solid #e2e8f0 !important;
    padding: 0.75rem 1rem;
    background: transparent;
}

table.dataTable tbody td {
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.85rem;
    color: #334155;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid #f1f5f9;
    vertical-align: middle;
}

table.dataTable tbody tr:hover td {
    background-color: #f8fafc;
}

table.dataTable tbody tr:last-child td {
    border-bottom: none;
}

/* DataTable controls */
.dt-container .dt-length label,
.dt-container .dt-search label {
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.8rem;
    color: #64748b;
}

.dt-container .dt-search input {
    font-family: 'Inter', system-ui, sans-serif;
    border: 1px solid #e2e8f0;
    border-radius: 0.5rem;
    padding: 0.375rem 0.75rem;
    font-size: 0.85rem;
    transition: border-color 0.15s ease;
}

.dt-container .dt-search input:focus {
    border-color: #6366f1;
    box-shadow: 0 0 0 3px rgba(37, 99, 168, 0.1);
    outline: none;
}

.dt-container .dt-length select {
    border: 1px solid #e2e8f0;
    border-radius: 0.375rem;
    padding: 0.25rem 0.5rem;
    font-size: 0.85rem;
}

.dt-container .dt-info {
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.8rem;
    color: #94a3b8;
}

/* DataTable pagination */
.dt-container .dt-paging .dt-paging-button {
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.75rem;
    border-radius: 0.375rem !important;
    border: 1px solid #e2e8f0 !important;
    color: #475569 !important;
    padding: 0.2rem 0.5rem !important;
    margin: 0 0.1rem;
    transition: all 0.15s ease;
}

.dt-container .dt-paging .dt-paging-button:hover {
    background: #eff6ff !important;
    border-color: #bfdbfe !important;
    color: #2563a8 !important;
}

.dt-container .dt-paging .dt-paging-button.current {
    background: #2563a8 !important;
    border-color: #2563a8 !important;
    color: #fff !important;
    font-weight: 600;
}

.dt-container .dt-paging .dt-paging-button.disabled {
    color: #cbd5e1 !important;
    border-color: #f1f5f9 !important;
}

/* ----------------------------------------------------------
   6. BADGES — Modern pills
   ---------------------------------------------------------- */
.badge {
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.7rem;
    font-weight: 500;
    padding: 0.25rem 0.5rem;
    border-radius: 9999px;
    letter-spacing: 0.01em;
}

/* ----------------------------------------------------------
   7. NAV TABS — Clean underline style
   ---------------------------------------------------------- */
.nav-underline .nav-link {
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.85rem;
    font-weight: 500;
    color: #64748b;
    padding: 0.5rem 1rem;
    border-bottom: 2px solid transparent;
    transition: color 0.15s ease, border-color 0.15s ease;
}

.nav-underline .nav-link:hover {
    color: #334155;
    border-bottom-color: #e2e8f0;
}

.nav-underline .nav-link.active {
    color: #1e293b;
    font-weight: 600;
    border-bottom-color: #2563a8;
}

.border-tab-menu {
    border-bottom: 1px solid #e2e8f0;
    margin-top: -2px;
}

/* ----------------------------------------------------------
   8. SECTION HEADERS in forms (e.g., "Identity", "Classification")
   ---------------------------------------------------------- */
.card .text-muted.small.text-uppercase.fw-semibold,
.card small.text-muted.text-uppercase {
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    color: #94a3b8 !important;
    margin-top: 1.5rem;
    margin-bottom: 0.5rem;
    display: block;
}

/* ----------------------------------------------------------
   9. PAGE HEADER
   ---------------------------------------------------------- */
.header-main-section h4 {
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 1.25rem;
    font-weight: 600;
    color: #1e293b;
}

/* ----------------------------------------------------------
   10. SELECT2 / TOMSELECT overrides
   ---------------------------------------------------------- */
.select2-container {
    border-radius: 0.5rem;
    border-color: #e2e8f0;
}

.select2-container .select2-selection--single {
    font-family: 'Inter', system-ui, sans-serif !important;
    font-size: 0.85rem !important;
}

.ts-wrapper .ts-control {
    font-family: 'Inter', system-ui, sans-serif;
    border-color: #e2e8f0;
    border-radius: 0.5rem;
}

.ts-wrapper .ts-control:focus-within,
.ts-wrapper.focus .ts-control {
    border-color: #6366f1;
    box-shadow: 0 0 0 3px rgba(37, 99, 168, 0.1);
}

/* ----------------------------------------------------------
   11. ALERTS — Softer modern alerts
   ---------------------------------------------------------- */
.alert-danger {
    background-color: #fef2f2;
    border-color: #fecaca;
    color: #991b1b;
    border-radius: 0.75rem;
    font-size: 0.875rem;
}

.alert-success {
    background-color: #ecfdf5;
    border-color: #a7f3d0;
    color: #065f46;
    border-radius: 0.75rem;
    font-size: 0.875rem;
}

/* ----------------------------------------------------------
   12. DARK MODE overrides
   ---------------------------------------------------------- */
[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select {
    background-color: #1e293b;
    border-color: #334155;
    color: #e2e8f0;
}

[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-select:focus {
    border-color: #60a5e8;
    box-shadow: 0 0 0 3px rgba(129, 140, 248, 0.15);
}

[data-bs-theme="dark"] .form-label {
    color: #94a3b8;
}

/* Dark mode floating label highlight */
[data-bs-theme="dark"] .col-12:focus-within > .form-label,
[data-bs-theme="dark"] .col-lg-2:focus-within > .form-label,
[data-bs-theme="dark"] .col-lg-3:focus-within > .form-label,
[data-bs-theme="dark"] .col-lg-4:focus-within > .form-label,
[data-bs-theme="dark"] .col-lg-6:focus-within > .form-label,
[data-bs-theme="dark"] .col-lg-8:focus-within > .form-label,
[data-bs-theme="dark"] .col-lg-12:focus-within > .form-label,
[data-bs-theme="dark"] .col-md-3:focus-within > .form-label,
[data-bs-theme="dark"] .col-md-4:focus-within > .form-label,
[data-bs-theme="dark"] .col-md-6:focus-within > .form-label,
[data-bs-theme="dark"] .col-md-8:focus-within > .form-label,
[data-bs-theme="dark"] .col-md-12:focus-within > .form-label,
[data-bs-theme="dark"] .mb-3:focus-within > .form-label,
[data-bs-theme="dark"] .mb-2:focus-within > .form-label,
[data-bs-theme="dark"] .form-group:focus-within > .form-label {
    color: #60a5e8;
}

[data-bs-theme="dark"] .card {
    background-color: #1e293b;
    border-color: #334155;
}

[data-bs-theme="dark"] table.dataTable thead th {
    color: #94a3b8;
    border-bottom-color: #334155 !important;
}

[data-bs-theme="dark"] table.dataTable tbody td {
    color: #cbd5e1;
    border-bottom-color: #1e293b;
}

[data-bs-theme="dark"] table.dataTable tbody tr:hover td {
    background-color: #334155;
}

[data-bs-theme="dark"] .btn-icon:hover {
    background-color: #334155 !important;
    color: #f1f5f9 !important;
}

[data-bs-theme="dark"] .btn-group .btn.link-danger.btn-icon {
    color: #64748b !important;
}

[data-bs-theme="dark"] .btn-group .btn.link-danger.btn-icon:hover {
    background-color: rgba(239, 68, 68, 0.1) !important;
    color: #f87171 !important;
}

[data-bs-theme="dark"] .btn-group .btn.link-primary.btn-icon,
[data-bs-theme="dark"] .btn-group .btn.link-secondary.btn-icon,
[data-bs-theme="dark"] .btn-group .btn.link-success.btn-icon,
[data-bs-theme="dark"] .btn-group .btn.link-warning.btn-icon {
    color: #64748b !important;
}

[data-bs-theme="dark"] .btn-group .btn.link-primary.btn-icon:hover,
[data-bs-theme="dark"] .btn-group .btn.link-secondary.btn-icon:hover,
[data-bs-theme="dark"] .btn-group .btn.link-success.btn-icon:hover,
[data-bs-theme="dark"] .btn-group .btn.link-warning.btn-icon:hover {
    background-color: #334155 !important;
    color: #f1f5f9 !important;
}

[data-bs-theme="dark"] .dt-container .dt-search input {
    background-color: #1e293b;
    border-color: #334155;
    color: #e2e8f0;
}

[data-bs-theme="dark"] .dt-container .dt-paging .dt-paging-button {
    border-color: #334155 !important;
    color: #94a3b8 !important;
}

[data-bs-theme="dark"] .dt-container .dt-paging .dt-paging-button:hover {
    background-color: #334155 !important;
    color: #f1f5f9 !important;
}

[data-bs-theme="dark"] .dt-container .dt-paging .dt-paging-button.current {
    background-color: #6366f1 !important;
    border-color: #6366f1 !important;
    color: #fff !important;
}

[data-bs-theme="dark"] .nav-underline .nav-link {
    color: #94a3b8;
}

[data-bs-theme="dark"] .nav-underline .nav-link.active {
    color: #f1f5f9;
    border-bottom-color: #60a5e8;
}

[data-bs-theme="dark"] .header-main-section h4 {
    color: #f1f5f9;
}

[data-bs-theme="dark"] .btn-primary {
    background-color: #3b82c4;
    border-color: #3b82c4;
    color: #fff;
}

[data-bs-theme="dark"] .btn-primary:hover {
    background-color: #60a5e8;
    border-color: #60a5e8;
    color: #fff;
}

[data-bs-theme="dark"] .dt-container .dt-paging .dt-paging-button:hover {
    background-color: rgba(37, 99, 168, 0.15) !important;
    border-color: #3b82c4 !important;
    color: #93c5fd !important;
}

[data-bs-theme="dark"] .dt-container .dt-paging .dt-paging-button.current {
    background-color: #3b82c4 !important;
    border-color: #3b82c4 !important;
    color: #fff !important;
}

/* ----------------------------------------------------------
   13. DATATABLE EXPORT BUTTONS — Small, discrete
   ---------------------------------------------------------- */
.dt-buttons .dt-button {
    font-family: 'Inter', system-ui, sans-serif !important;
    font-size: 0.7rem !important;
    padding: 0.25rem 0.6rem !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 0.375rem !important;
    background: #fff !important;
    color: #64748b !important;
    font-weight: 500;
    transition: all 0.15s ease;
}

.dt-buttons .dt-button:hover {
    background: #f8fafc !important;
    border-color: #cbd5e1 !important;
    color: #334155 !important;
}

[data-bs-theme="dark"] .dt-buttons .dt-button {
    background: #1e293b !important;
    border-color: #334155 !important;
    color: #94a3b8 !important;
}

[data-bs-theme="dark"] .dt-buttons .dt-button:hover {
    background: #334155 !important;
    color: #f1f5f9 !important;
}

/* ----------------------------------------------------------
   14. SKELETON LOADER for DataTables
   ---------------------------------------------------------- */
.dt-skeleton {
    padding: 1rem 1.5rem;
}
.dt-skeleton-row {
    display: flex;
    gap: 1rem;
    margin-bottom: 0.75rem;
    align-items: center;
}
.dt-skeleton-cell {
    height: 0.75rem;
    background: linear-gradient(90deg, #e2e8f0 25%, #f1f5f9 50%, #e2e8f0 75%);
    background-size: 200% 100%;
    animation: skeleton-pulse 1.5s ease-in-out infinite;
    border-radius: 0.25rem;
}
.dt-skeleton-cell:nth-child(1) { width: 25%; }
.dt-skeleton-cell:nth-child(2) { width: 15%; }
.dt-skeleton-cell:nth-child(3) { width: 20%; }
.dt-skeleton-cell:nth-child(4) { width: 15%; }
.dt-skeleton-cell:nth-child(5) { width: 10%; }

@keyframes skeleton-pulse {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

[data-bs-theme="dark"] .dt-skeleton-cell {
    background: linear-gradient(90deg, #334155 25%, #1e293b 50%, #334155 75%);
    background-size: 200% 100%;
    animation: skeleton-pulse 1.5s ease-in-out infinite;
}

/* ----------------------------------------------------------
   15. TOASTR OVERRIDES — Better positioning and visibility
   ---------------------------------------------------------- */
#toast-container {
    top: 5rem !important;
    right: 1.5rem !important;
}

#toast-container > .toast {
    opacity: 1 !important;
    border-radius: 0.75rem !important;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15) !important;
    font-family: 'Inter', system-ui, sans-serif !important;
    padding: 1rem 1.25rem !important;
    min-width: 300px;
}

#toast-container > .toast-success {
    background-color: #059669 !important;
}

#toast-container > .toast-error {
    background-color: #dc2626 !important;
}

#toast-container > .toast-warning {
    background-color: #d97706 !important;
}

#toast-container > .toast-info {
    background-color: #2563eb !important;
}

#toast-container .toast-message {
    font-size: 0.875rem;
    font-weight: 500;
    color: #fff !important;
}

#toast-container .toast-title {
    font-size: 0.8rem;
    font-weight: 700;
    margin-bottom: 0.25rem;
    color: #fff !important;
}

#toast-container .toast-close-button {
    color: rgba(255, 255, 255, 0.8) !important;
}

#toast-container .toast-progress {
    background-color: rgba(255, 255, 255, 0.3) !important;
}

/* ----------------------------------------------------------
   16. DARK MODE — Comprehensive overrides
   ---------------------------------------------------------- */

/* Body and background */
[data-bs-theme="dark"] body,
[data-bs-theme="dark"] .bg-body-tertiary {
    background-color: #0f172a !important;
    color: #e2e8f0;
}

/* Card shadows and borders */
[data-bs-theme="dark"] .card,
[data-bs-theme="dark"] .card.shadow {
    background-color: #1e293b !important;
    border-color: #334155 !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3) !important;
}

[data-bs-theme="dark"] .card-body {
    background-color: #1e293b !important;
    color: #e2e8f0;
}

[data-bs-theme="dark"] .card-header {
    background-color: #1e293b !important;
    border-color: #334155 !important;
    color: #e2e8f0;
}

/* Text colors */
[data-bs-theme="dark"] h1, [data-bs-theme="dark"] h2,
[data-bs-theme="dark"] h3, [data-bs-theme="dark"] h4,
[data-bs-theme="dark"] h5, [data-bs-theme="dark"] h6 {
    color: #f1f5f9;
}

[data-bs-theme="dark"] p,
[data-bs-theme="dark"] span,
[data-bs-theme="dark"] label {
    color: #cbd5e1;
}

[data-bs-theme="dark"] .text-muted {
    color: #64748b !important;
}

/* Tab underlines */
[data-bs-theme="dark"] .border-tab-menu {
    border-color: #334155 !important;
}

/* Table */
[data-bs-theme="dark"] table {
    color: #e2e8f0;
}

[data-bs-theme="dark"] table th {
    color: #94a3b8 !important;
    background-color: transparent !important;
}

[data-bs-theme="dark"] table td {
    color: #cbd5e1 !important;
    border-color: #1e293b !important;
}

[data-bs-theme="dark"] table.dataTable {
    border-color: #334155 !important;
}

/* DataTable info and length */
[data-bs-theme="dark"] .dt-container .dt-info,
[data-bs-theme="dark"] .dt-container .dt-length label,
[data-bs-theme="dark"] .dt-container .dt-search label {
    color: #94a3b8 !important;
}

[data-bs-theme="dark"] .dt-container .dt-length select {
    background-color: #1e293b !important;
    border-color: #334155 !important;
    color: #e2e8f0 !important;
}

/* Alerts */
[data-bs-theme="dark"] .alert-danger {
    background-color: rgba(220, 38, 38, 0.15) !important;
    border-color: rgba(220, 38, 38, 0.3) !important;
    color: #fca5a5 !important;
}

[data-bs-theme="dark"] .alert-success {
    background-color: rgba(5, 150, 105, 0.15) !important;
    border-color: rgba(5, 150, 105, 0.3) !important;
    color: #6ee7b7 !important;
}

/* Checkboxes and form checks */
[data-bs-theme="dark"] .form-check-label {
    color: #cbd5e1;
}

[data-bs-theme="dark"] .form-check-input {
    background-color: #334155;
    border-color: #475569;
}

/* Sections and dividers */
[data-bs-theme="dark"] hr {
    border-color: #334155;
}

[data-bs-theme="dark"] .border-top,
[data-bs-theme="dark"] .border-bottom {
    border-color: #334155 !important;
}

/* Select dropdowns (non-TomSelect) */
[data-bs-theme="dark"] select.form-select option {
    background-color: #1e293b;
    color: #e2e8f0;
}

/* Breadcrumb */
[data-bs-theme="dark"] .breadcrumb-container a {
    color: #94a3b8;
}

[data-bs-theme="dark"] .breadcrumb-container span {
    color: #64748b;
}

/* Bulk actions toolbar */
[data-bs-theme="dark"] #bulkActions span {
    color: #94a3b8 !important;
}

/* Filter selects */
[data-bs-theme="dark"] select#statusFilter,
[data-bs-theme="dark"] select#opportunityTypeFilter,
[data-bs-theme="dark"] select#areaFilter {
    background-color: #1e293b;
    border-color: #334155;
    color: #e2e8f0;
}

/* CKEditor in dark mode */
[data-bs-theme="dark"] .ck.ck-editor__main > .ck-editor__editable {
    background-color: #1e293b !important;
    color: #e2e8f0 !important;
    border-color: #334155 !important;
}

[data-bs-theme="dark"] .ck.ck-toolbar {
    background-color: #0f172a !important;
    border-color: #334155 !important;
}

/* Modal backgrounds */
[data-bs-theme="dark"] .modal-content {
    background-color: #1e293b !important;
    border-color: #334155 !important;
    color: #e2e8f0;
}

[data-bs-theme="dark"] .modal-header {
    border-color: #334155 !important;
}

[data-bs-theme="dark"] .modal-footer {
    border-color: #334155 !important;
}

/* ----------------------------------------------------------
   17. DARK MODE — Tailwind class overrides
   These override tw-bg-white and tw-border-slate-100 used
   in Tailwind-styled list/form cards when dark mode is active
   ---------------------------------------------------------- */
[data-bs-theme="dark"] .tw-bg-white {
    background-color: #1e293b !important;
}

[data-bs-theme="dark"] .tw-border-slate-100 {
    border-color: #334155 !important;
}

[data-bs-theme="dark"] .tw-bg-slate-50 {
    background-color: #0f172a !important;
}

[data-bs-theme="dark"] .tw-text-slate-800 {
    color: #f1f5f9 !important;
}

[data-bs-theme="dark"] .tw-text-slate-700 {
    color: #e2e8f0 !important;
}

[data-bs-theme="dark"] .tw-text-slate-600 {
    color: #cbd5e1 !important;
}

[data-bs-theme="dark"] .tw-text-slate-500 {
    color: #94a3b8 !important;
}

[data-bs-theme="dark"] .tw-border-slate-200 {
    border-color: #334155 !important;
}

[data-bs-theme="dark"] .tw-border-slate-300 {
    border-color: #475569 !important;
}

/* Tailwind hover states in dark mode */
[data-bs-theme="dark"] .hover\:tw-bg-slate-50:hover {
    background-color: #334155 !important;
}

[data-bs-theme="dark"] .tw-bg-indigo-50 {
    background-color: rgba(99, 102, 241, 0.15) !important;
}

[data-bs-theme="dark"] .tw-bg-emerald-50 {
    background-color: rgba(16, 185, 129, 0.15) !important;
}

[data-bs-theme="dark"] .tw-bg-red-50 {
    background-color: rgba(239, 68, 68, 0.15) !important;
}

/* Gradient header on cards (e.g., Client Card) */
[data-bs-theme="dark"] .tw-from-indigo-600 {
    --tw-gradient-from: #4338ca !important;
}

/* DataTable wrapper in dark mode */
[data-bs-theme="dark"] .dt-container {
    color: #e2e8f0;
}

[data-bs-theme="dark"] .dt-container .dt-search input {
    background-color: #1e293b !important;
    border-color: #334155 !important;
    color: #e2e8f0 !important;
}

/* Tag filter (TomSelect) in dark mode */
[data-bs-theme="dark"] .ts-wrapper .ts-control {
    background-color: #1e293b !important;
    border-color: #334155 !important;
    color: #e2e8f0 !important;
}

[data-bs-theme="dark"] .ts-wrapper .ts-dropdown {
    background-color: #1e293b !important;
    border-color: #334155 !important;
    color: #e2e8f0 !important;
}

[data-bs-theme="dark"] .ts-wrapper .ts-dropdown .option:hover,
[data-bs-theme="dark"] .ts-wrapper .ts-dropdown .active {
    background-color: #334155 !important;
}

/* Sidebar gradient image in dark mode */
[data-bs-theme="dark"] .sidebar-header {
    opacity: 0.3;
}

/* Loading overlay in dark mode */
[data-bs-theme="dark"] #loadingOverlay > div {
    background-color: #1e293b !important;
}

/* Checkbox in dark mode */
[data-bs-theme="dark"] input[type="checkbox"].row-select {
    accent-color: #6366f1;
}
