/* /static/css/theme.css */
/* Version: 2025-11-12-15:25 - Cache busting update */

/* 1. Default (Light) Theme Variables */
:root {
  --bs-body-bg: #f8f9fa;
  --bs-body-color: #212529;
  --bs-secondary-bg: #e9ecef;
  --bs-tertiary-bg: #ffffff;
  --bs-border-color: #dee2e6;
  --bs-link-color: #0d6efd;
  --bs-link-hover-color: #0a58ca;
  --bs-primary-rgb: 13, 110, 253;
  --bs-secondary-color: #6c757d;
  
  /* Kanban specific variables */
  --kanban-bg: #f8f9fa;
  --column-bg: #e9ecef;
  --card-bg: #ffffff;
  --text-light: #6c757d;
  --text-dark: #212529;
}

/* 2. Dark Theme Overrides */
[data-bs-theme="dark"] {
  --bs-body-bg: #212529;
  --bs-body-color: #dee2e6;
  --bs-secondary-bg: #343a40;
  --bs-tertiary-bg: #2c3034;
  --bs-border-color: #495057;
  --bs-link-color: #6ea8fe;
  --bs-link-hover-color: #8bb9fe;
  --bs-primary-rgb: 110, 168, 254;
  --bs-secondary-color: #adb5bd;
  color-scheme: dark;
  
  /* Dark theme kanban variables */
  --kanban-bg: #212529;
  --column-bg: #343a40;
  --card-bg: #2c3034;
  --text-light: #adb5bd;
  --text-dark: #dee2e6;
}

/* 3. Dark theme body and card styling */
[data-bs-theme="dark"] body {
  background-color: var(--bs-body-bg) !important;
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .card, 
[data-bs-theme="dark"] .modal-content {
  background-color: var(--bs-tertiary-bg) !important;
  border-color: var(--bs-border-color) !important;
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .table {
  --bs-table-bg: var(--bs-tertiary-bg);
  --bs-table-border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .table th {
  color: var(--bs-body-color) !important;
  background-color: var(--bs-secondary-bg) !important;
  border-color: var(--bs-border-color) !important;
}

[data-bs-theme="dark"] .table thead th {
  color: var(--bs-body-color) !important;
}

/* 4. Dark theme specific navigation support */
[data-bs-theme="dark"] .navbar {
  background: linear-gradient(135deg, #343a40 0%, #495057 100%) !important;
}

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

[data-bs-theme="dark"] .form-control, 
[data-bs-theme="dark"] .form-select {
  background-color: var(--bs-tertiary-bg) !important;
  border-color: var(--bs-border-color) !important;
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .form-control:focus, 
[data-bs-theme="dark"] .form-select:focus {
  background-color: var(--bs-tertiary-bg) !important;
  color: var(--bs-body-color) !important;
}

/* 5. Dark theme text color fixes */
[data-bs-theme="dark"] .text-muted {
  color: var(--bs-secondary-color) !important;
}

/* 6. Dashboard specific fixes */
[data-bs-theme="dark"] .dashboard-container {
  background: linear-gradient(135deg, var(--bs-body-bg) 0%, var(--bs-secondary-bg) 100%) !important;
}

[data-bs-theme="dark"] .dashboard-header {
  background: linear-gradient(135deg, var(--bs-tertiary-bg) 0%, var(--bs-secondary-bg) 100%) !important;
  border: 1px solid var(--bs-border-color) !important;
}

[data-bs-theme="dark"] .dashboard-title {
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .dashboard-subtitle {
  color: var(--bs-secondary-color) !important;
}

[data-bs-theme="dark"] .card-header {
  background: linear-gradient(135deg, var(--bs-tertiary-bg) 0%, var(--bs-secondary-bg) 100%) !important;
  border-bottom: 1px solid var(--bs-border-color) !important;
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .card-title {
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .card-header h5 {
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .card-header .card-title {
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .card-header i {
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .card-header .d-flex * {
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .card-header .badge {
  background-color: var(--bs-primary) !important;
  color: white !important;
}

[data-bs-theme="dark"] .navbar .badge.bg-warning {
  color: black !important;
}

[data-bs-theme="dark"] .badge.bg-warning.text-dark {
  color: black !important;
}

/* 7. Kanban board styles */
.kanban-board-container {
  display: flex !important;
  gap: 1rem;
  overflow-x: auto;
  padding-bottom: 1rem;
  background-color: var(--kanban-bg);
}

/* Explicit fallback styles for system theme (when no data-bs-theme attribute) */
html:not([data-bs-theme]) .kanban-board-container {
  background-color: #f8f9fa;
}

html:not([data-bs-theme]) .kanban-column {
  background-color: #ffffff;
}

html:not([data-bs-theme]) .kanban-column-header {
  background-color: #f8f9fa;
  color: #212529;
}

.kanban-column {
  flex: 0 0 350px !important;
  background-color: #ffffff;
  border-radius: 8px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.1);
  max-height: 80vh;
  display: flex !important;
  flex-direction: column !important;
}

.kanban-column-header {
  padding: 1rem;
  background-color: #f8f9fa;
  border-bottom: 1px solid #dee2e6;
  border-radius: 8px 8px 0 0;
  font-weight: 600;
}

.kanban-column-task-count {
  color: #6c757d;
  font-weight: 500;
}

.kanban-column-body {
  flex: 1;
  overflow-y: auto;
  padding: 0.5rem;
}

.kanban-card {
  background-color: #ffffff;
  border: 1px solid #dee2e6;
  border-radius: 6px;
  padding: 0.75rem;
  margin-bottom: 0.5rem;
  cursor: grab;
  transition: box-shadow 0.2s ease;
}

.kanban-card:hover {
  box-shadow: 0 4px 8px rgba(0,0,0,0.15);
}

.kanban-card-title a {
  text-decoration: none;
  color: #212529;
  font-weight: 500;
}

.kanban-card-title a:hover {
  color: #0d6efd;
}

.kanban-card-meta {
  color: #6c757d;
  font-size: 0.875rem;
  margin-top: 0.5rem;
}

.kanban-card-assignee {
  color: #495057;
}

/* Dark theme kanban support */
[data-bs-theme="dark"] .kanban-board-container {
  background-color: var(--bs-body-bg) !important;
}

[data-bs-theme="dark"] .kanban-column {
  background-color: var(--bs-secondary-bg) !important;
}

[data-bs-theme="dark"] .kanban-column-header {
  color: var(--bs-body-color) !important;
  background-color: var(--bs-secondary-bg) !important;
  border-bottom: 1px solid var(--bs-border-color) !important;
}

[data-bs-theme="dark"] .kanban-column-header .kanban-column-task-count {
  background-color: var(--bs-border-color) !important;
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .kanban-card {
  background-color: var(--bs-tertiary-bg) !important;
  border-color: var(--bs-border-color) !important;
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .kanban-card-title a {
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .kanban-card-meta {
  color: var(--bs-secondary-color) !important;
}

[data-bs-theme="dark"] .kanban-card-assignee {
  color: var(--bs-secondary-color) !important;
}

/* 8. Override any hardcoded backgrounds and text colors */
[data-bs-theme="dark"] * {
  border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .bg-light {
  background-color: var(--bs-secondary-bg) !important;
}

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

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

[data-bs-theme="dark"] .list-group-item {
  background-color: var(--bs-tertiary-bg) !important;
  border-color: var(--bs-border-color) !important;
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .list-group-item a {
  color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .list-group-item.active {
  background-color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
}

[data-bs-theme="dark"] .list-group-item.active a {
  color: white !important;
}

/* 9. Task Status Badge Styles */
/* Light theme status badges - increased specificity to override Bootstrap */
.badge.bg-new,
.bg-new.badge {
  background-color: #6c757d !important; /* Gray */
  color: white !important;
}

.badge.bg-pending_approval,
.bg-pending_approval.badge {
  background-color: #ffc107 !important; /* Yellow */
  color: #212529 !important; /* Dark text for contrast */
}

.badge.bg-pending_assignment_approval,
.bg-pending_assignment_approval.badge {
  background-color: #fd7e14 !important; /* Orange */
  color: white !important;
}

.badge.bg-in_progress,
.bg-in_progress.badge {
  background-color: #0d6efd !important; /* Blue */
  color: white !important;
}

.badge.bg-pending,
.bg-pending.badge {
  background-color: #6f42c1 !important; /* Purple */
  color: white !important;
}

.badge.bg-completed,
.bg-completed.badge {
  background-color: #198754 !important; /* Green */
  color: white !important;
}

.badge.bg-approved,
.bg-approved.badge {
  background-color: #20c997 !important; /* Teal */
  color: white !important;
}

.badge.bg-rejected,
.bg-rejected.badge {
  background-color: #dc3545 !important; /* Red */
  color: white !important;
}

/* Dark theme status badges - ensure good contrast with increased specificity */
[data-bs-theme="dark"] .badge.bg-new,
[data-bs-theme="dark"] .bg-new.badge {
  background-color: #6c757d !important;
  color: white !important;
}

[data-bs-theme="dark"] .badge.bg-pending_approval,
[data-bs-theme="dark"] .bg-pending_approval.badge {
  background-color: #ffc107 !important;
  color: #212529 !important; /* Keep dark text for yellow background */
}

[data-bs-theme="dark"] .badge.bg-pending_assignment_approval,
[data-bs-theme="dark"] .bg-pending_assignment_approval.badge {
  background-color: #fd7e14 !important;
  color: white !important;
}

[data-bs-theme="dark"] .badge.bg-in_progress,
[data-bs-theme="dark"] .bg-in_progress.badge {
  background-color: #0d6efd !important;
  color: white !important;
}

[data-bs-theme="dark"] .badge.bg-pending,
[data-bs-theme="dark"] .bg-pending.badge {
  background-color: #6f42c1 !important;
  color: white !important;
}

[data-bs-theme="dark"] .badge.bg-completed,
[data-bs-theme="dark"] .bg-completed.badge {
  background-color: #198754 !important;
  color: white !important;
}

[data-bs-theme="dark"] .badge.bg-approved,
[data-bs-theme="dark"] .bg-approved.badge {
  background-color: #20c997 !important;
  color: white !important;
}

/* 10. Custom Status and Priority Badge Classes */
/* These use completely custom class names to avoid Bootstrap conflicts */

.status-badge {
  display: inline-block;
  padding: 0.35em 0.65em;
  font-size: 0.75em;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: 0.375rem;
  border: 1px solid transparent;
}

.priority-badge {
  display: inline-block;
  padding: 0.35em 0.65em;
  font-size: 0.75em;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: 0.375rem;
  border: 1px solid transparent;
}

/* Status badge colors */
.status-new { background-color: #6c757d; color: white; }
.status-pending_approval { background-color: #ffc107; color: #212529; }
.status-pending_assignment_approval { background-color: #fd7e14; color: white; }
.status-in_progress { background-color: #0d6efd; color: white; }
.status-pending { background-color: #6f42c1; color: white; }
.status-completed { background-color: #198754; color: white; }
.status-approved { background-color: #20c997; color: white; }
.status-rejected { background-color: #dc3545; color: white; }

/* Priority badge colors */
.priority-low { background-color: #6c757d; color: white; }
.priority-medium { background-color: #0dcaf0; color: #212529; }
.priority-high { background-color: #fd7e14; color: white; }
.priority-urgent { background-color: #dc3545; color: white; }

/* Dark theme support for custom badges */
[data-bs-theme="dark"] .status-new { background-color: #6c757d; color: white; }
[data-bs-theme="dark"] .status-pending_approval { background-color: #ffc107; color: #212529; }
[data-bs-theme="dark"] .status-pending_assignment_approval { background-color: #fd7e14; color: white; }
[data-bs-theme="dark"] .status-in_progress { background-color: #0d6efd; color: white; }
[data-bs-theme="dark"] .status-pending { background-color: #6f42c1; color: white; }
[data-bs-theme="dark"] .status-completed { background-color: #198754; color: white; }
[data-bs-theme="dark"] .status-approved { background-color: #20c997; color: white; }
[data-bs-theme="dark"] .status-rejected { background-color: #dc3545; color: white; }

[data-bs-theme="dark"] .priority-low { background-color: #6c757d; color: white; }
[data-bs-theme="dark"] .priority-medium { background-color: #0dcaf0; color: #212529; }
[data-bs-theme="dark"] .priority-high { background-color: #fd7e14; color: white; }
[data-bs-theme="dark"] .priority-urgent { background-color: #dc3545; color: white; }