:root {
  /* Colors */
  --color-danger: rgba(220, 53, 69, 1);
  --color-danger-alt: rgba(234, 67, 53, 1);
  --color-danger-dark: rgba(220, 38, 38, 1);
  --color-warning: rgba(241, 149, 28, 1);
  --color-accent: #f7941d;
  --color-muted: #6c757d;
  --color-muted-dark: #495057;
  --color-muted-bg: #f8f9fa;
  --color-success: #198754;
  --color-purple: #9c27b0;
  --color-border-light: #f1f3f4;
  --color-border-dark: #374151;

  /* Glassmorphism effects */
  --glass-bg-light: rgba(223, 223, 223, 0.18);
  --glass-bg-light-hover: rgba(255, 255, 255, 0.35);
  --glass-bg-dark: rgba(31, 31, 31, 0.4);
  --glass-bg-dark-hover: rgba(42, 42, 42, 0.5);
  --glass-border: rgba(255, 255, 255, 0.18);
  --glass-border-hover: rgba(255, 255, 255, 0.25);
  --glass-action-bg: rgba(255, 255, 255, 0.2);
  --glass-action-hover: rgba(255, 255, 255, 0.3);

  /* Blur values */
  --blur-sm: blur(5px);
  --blur-md: blur(10px);
  --blur-lg: blur(14px);
  --blur-hover: blur(15px);
  --blur-xl: blur(16px);

  /* Spacing */
  --card-radius: 12px;
  --section-radius: 16px;
  --badge-radius: 12px;

  /* Transitions */
  --transition-smooth: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-fast: all 0.3s ease;
  --transition-quick: all 0.2s ease;
  --transition-shimmer: left 0.5s;

  /* Shadows */
  --shadow-card: 0 8px 8px 0 rgba(185, 185, 185, 0.2);
  --shadow-card-hover: 0 12px 10px 0 rgba(84, 84, 84, 0.1);
  --shadow-overdue: 0 8px 24px rgba(220, 53, 69, 0.12);
  --shadow-overdue-intense: 0 10px 28px rgba(220, 53, 69, 0.18);
  --shadow-dark: 0 8px 32px 0 rgba(0, 0, 0, 0.5);
  --shadow-dark-hover: 0 12px 40px 0 rgba(0, 0, 0, 0.6);
}

[data-bs-theme="dark"] {
  --glass-bg-light: rgba(31, 31, 31, 0.4);
  --glass-bg-light-hover: rgba(42, 42, 42, 0.5);
  --glass-border: rgba(255, 255, 255, 0.1);
  --glass-border-hover: rgba(255, 255, 255, 0.15);
  --glass-action-bg: rgba(255, 255, 255, 0.08);
  --glass-action-hover: rgba(255, 255, 255, 0.15);
  --color-muted-bg: #2a2a2a;
  --blur-lg: blur(12px);
  --blur-hover: blur(16px);
  --shadow-overdue: 0 8px 24px rgba(220, 53, 69, 0.2);
  --shadow-overdue-intense: 0 10px 28px rgba(220, 53, 69, 0.18);
}

/* Header styling */
.task-card-table-header {
  font-size: 0.9rem;
}

.bg-gradient-to-t {
  background: linear-gradient(
    to top,
    rgba(255, 255, 255, 1),
    rgba(255, 255, 255, 0)
  );
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .task-card-table-header {
    display: none;
  }
}

/* Overdue Section Container */
.overdue-section {
  border-radius: var(--section-radius);
  padding: 24px;
  border: 2px solid rgba(220, 53, 69, 0.2);
  box-shadow: var(--shadow-overdue);
  position: relative;
  animation: pulse-shadow 3s ease-in-out infinite;
}

@keyframes pulse-shadow {
  0%,
  100% {
    box-shadow: var(--shadow-overdue);
  }
  50% {
    box-shadow: var(--shadow-overdue-intense);
  }
}

.overdue-section .client-section-mini {
  border-bottom: 1px solid rgba(220, 53, 69, 0.1);
  padding-bottom: 16px;
}

.overdue-section .client-section-mini:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.overdue-section .client-section-mini .tasks-container {
  display: flex;
  flex-direction: column;
}

/* Client sections */
.client-section {
  border-bottom: 1px solid var(--color-border-light);
  padding-bottom: 20px;
}

.client-header {
  display: flex;
  align-items: center;
  gap: 12px;
}



/* Tasks container */
.tasks-container {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Glassmorphism task rows */
.task-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px;
  background: var(--glass-bg-light);
  backdrop-filter: var(--blur-lg);
  -webkit-backdrop-filter: var(--blur-lg);
  border: 1px solid var(--glass-border);
  box-shadow: var(--shadow-card);
  border-radius: var(--card-radius);
  cursor: pointer;
  transition: var(--transition-smooth);
  position: relative;
  overflow: hidden;
}

.task-row::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.1) 0%,
    rgba(255, 255, 255, 0.05) 50%,
    rgba(255, 255, 255, 0.02) 100%
  );
  pointer-events: none;
  border-radius: inherit;
}

.task-row:hover {
  background: var(--glass-bg-light-hover);
  backdrop-filter: var(--blur-hover);
  -webkit-backdrop-filter: var(--blur-hover);
  border: 1px solid var(--glass-border-hover);
  transform: translateY(-2px);
  box-shadow: var(--shadow-card-hover);
}

.task-row.due-today {
  transition: var(--transition-smooth)
}

.task-row.due-today:hover {
  transform: translateY(-2px);
}

/* Priority indicators */
.task-row.priority-high {
  border-left: 4px solid rgba(234, 67, 53, 0.8);
}

.task-row.priority-high:hover {
  background: rgba(234, 67, 53, 0.12);
  border-left: 4px solid rgba(234, 67, 53, 0.9);
}

.task-row.priority-medium,
.task-row.priority-low {
  border-left: 4px solid rgba(241, 149, 28, 0.3);
}

/* Overdue tasks inside the overdue section */
.overdue-section .task-row.is-overdue {
  background: rgba(234, 67, 53, 0.08);
  border: 1px solid rgba(234, 67, 53, 0.2);
  border-left: 4px solid rgba(234, 67, 53, 0.8);
  box-shadow: 0 4px 12px rgba(234, 67, 53, 0.1);
}

.overdue-section .task-row.is-overdue::before {
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.1) 0%,
    rgba(255, 255, 255, 0.05) 50%,
    rgba(255, 255, 255, 0.02) 100%
  );
}

.overdue-section .task-row.is-overdue:hover {
  background: rgba(234, 67, 53, 0.12);
  border: 1px solid rgba(234, 67, 53, 0.3);
  box-shadow: 0 6px 16px rgba(234, 67, 53, 0.15);
  transform: translateY(-2px);
}

/* COMPLETED TASKS - Simple Faded Style */
.task-row.completed {
  opacity: 0.5;
  padding: 12px 16px;
  filter: grayscale(0.3);
}

.task-row.completed:hover {
  opacity: 0.65;
  filter: grayscale(0.15);
}

/* Completed Tasks Section - matches archived client styling */
.completed-tasks-section {
  position: relative;
  background-color: rgba(249, 250, 251, 0.7);
  border-radius: 12px;
  padding: 24px;
  margin-top: 32px;
  margin-bottom: 20px;
  border: 1px dashed #e9ecef;
}

[data-bs-theme="dark"] .completed-tasks-section {
  background-color: #17181bb2;
  border: 1px dashed #5a5a5a;
}

/* Completed tasks section header */
.completed-tasks-section .client-header {
  opacity: 0.85;
}

.completed-tasks-section .client-name {
  color: #6c757d !important;
}

[data-bs-theme="dark"] .completed-tasks-section .client-name {
  color: #9ca3af !important;
}

/* Separator between completed task clients */
.completed-tasks-section .client-section {
  border-bottom-color: rgba(108, 117, 125, 0.15);
}

[data-bs-theme="dark"] .completed-tasks-section .client-section {
  border-bottom-color: rgba(108, 117, 125, 0.25);
}

/* Completed section divider from active tasks */
.completed-tasks-section::before {
  content: "";
  position: absolute;
  top: -20px;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    rgba(0, 0, 0, 0),
    rgba(0, 0, 0, 0.1) 50%,
    rgba(0, 0, 0, 0)
  );
}

[data-bs-theme="dark"] .completed-tasks-section::before {
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0),
    rgba(255, 255, 255, 0.1) 50%,
    rgba(255, 255, 255, 0)
  );
}

/* Task content */
.task-main {
  flex: 1;
  min-width: 0;
}

.task-title {
  margin-bottom: 6px;
  line-height: 1.4;
}

.task-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.due-info {
  display: flex;
  align-items: center;
  gap: 4px;
}

/* Action buttons with glassmorphism */
.homepage-task-actions {
  display: flex;
  gap: 4px;
  align-items: center;
  opacity: 0.6;
  transition: var(--transition-quick);
}

.task-row:hover .homepage-task-actions {
  opacity: 1;
}

.action-btn,
.btn-complete-task {
  width: 32px;
  height: 32px;
  background: var(--glass-action-bg);
  backdrop-filter: var(--blur-sm);
  -webkit-backdrop-filter: var(--blur-sm);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: var(--color-muted);
  transition: var(--transition-fast);
}

.action-btn:hover,
.btn-complete-task:hover {
  background: var(--glass-action-hover);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-color: rgba(255, 255, 255, 0.2);
  color: var(--color-muted-dark);
  transform: scale(1.05);
}

.btn-complete-task:hover {
  background: rgba(25, 135, 84, 0.2);
  border-color: rgba(25, 135, 84, 0.3);
  color: var(--color-success);
}

/* Shimmer effect */
.task-row::after {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.1),
    transparent
  );
  transition: var(--transition-shimmer);
  pointer-events: none;
}

.task-row:hover::after {
  left: 100%;
}

/* Dark theme */
[data-bs-theme="dark"] .overdue-section {
  background: rgba(31, 31, 31, 0.6);
  border: 2px solid rgba(220, 53, 69, 0.3);
  box-shadow: var(--shadow-overdue);
}

[data-bs-theme="dark"] .overdue-section .client-section-mini {
  border-bottom-color: rgba(220, 53, 69, 0.2);
}



[data-bs-theme="dark"] .client-count {
  background: var(--color-muted-bg);
  color: #9ca3af;
}

[data-bs-theme="dark"] .client-section {
  border-bottom-color: var(--color-border-dark);
}

[data-bs-theme="dark"] .task-row {
  background: var(--glass-bg-light);
  backdrop-filter: var(--blur-lg);
  -webkit-backdrop-filter: var(--blur-lg);
  box-shadow: var(--shadow-dark);
}

[data-bs-theme="dark"] .task-row::before {
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.05) 0%,
    rgba(255, 255, 255, 0.02) 50%,
    rgba(255, 255, 255, 0.01) 100%
  );
}

[data-bs-theme="dark"] .task-row:hover {
  background: var(--glass-bg-light-hover);
  backdrop-filter: var(--blur-hover);
  -webkit-backdrop-filter: var(--blur-hover);
  box-shadow: var(--shadow-dark-hover);
}

[data-bs-theme="dark"] .task-row.priority-high {
  border-left: 4px solid rgba(220, 38, 38, 0.8);
}

[data-bs-theme="dark"] .task-row.priority-medium,
[data-bs-theme="dark"] .task-row.priority-low {
  border-left: 4px solid rgba(241, 149, 28, 0.3);
}

[data-bs-theme="dark"] .overdue-section .task-row.is-overdue {
  background: rgba(220, 38, 38, 0.15);
  border: 1px solid rgba(220, 38, 38, 0.25);
  box-shadow: 0 4px 12px rgba(220, 38, 38, 0.2);
}

[data-bs-theme="dark"] .overdue-section .task-row.is-overdue:hover {
  background: rgba(220, 38, 38, 0.2);
  border: 1px solid rgba(220, 38, 38, 0.35);
  box-shadow: 0 6px 16px rgba(220, 38, 38, 0.25);
}

/* Completed tasks - Dark theme */
[data-bs-theme="dark"] .task-row.completed {
  opacity: 0.45;
  filter: grayscale(0.4);
}

[data-bs-theme="dark"] .task-row.completed:hover {
  opacity: 0.6;
  filter: grayscale(0.2);
}

[data-bs-theme="dark"] .action-btn,
[data-bs-theme="dark"] .btn-complete-task {
  background: var(--glass-action-bg);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.7);
}

[data-bs-theme="dark"] .action-btn:hover,
[data-bs-theme="dark"] .btn-complete-task:hover {
  background: var(--glass-action-hover);
  border-color: rgba(255, 255, 255, 0.2);
  color: rgba(255, 255, 255, 0.9);
}

[data-bs-theme="dark"] .task-row.due-today {
  background: rgba(31, 31, 31, 0.1) !important;
  box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.2) !important;
}

[data-bs-theme="dark"] .task-row.due-today:hover {
  background: rgba(42, 42, 42, 0.15) !important;
  box-shadow: 0 12px 40px 0 rgba(0, 0, 0, 0.3) !important;
}

/* Timeline specific styles */
.overdue-section,
.unscheduled-section {
  backdrop-filter: var(--blur-md);
  -webkit-backdrop-filter: var(--blur-md);
}

.client-section-mini .tasks-container {
  display: flex;
  flex-direction: column;
}

.empty-task-container {
  min-height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
}

@keyframes float {
  0%,
  100% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(-20px);
  }
}

/* Task indicator styling */
.task-indicator {
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
}

.scheduler-nav .nav-link:not(.active) .task-indicator .fa-circle {
  color: var(--color-purple) !important;
}

.scheduler-nav .nav-link:hover:not(.active) .task-indicator .fa-circle {
  color: #ffffff !important;
}

.scheduler-nav .nav-link.active .task-indicator .fa-circle {
  color: #ffffff !important;
}

.scheduler-nav .nav-link:not(.active) .task-indicator.overdue .fa-circle {
  color: var(--color-danger) !important;
}

.scheduler-nav .nav-link:hover:not(.active) .task-indicator.overdue .fa-circle {
  color: #ffffff !important;
}

/* Priority badges */
.priority-badge {
  --bs-badge-padding-x: 0.5rem;
  --bs-badge-padding-y: 0.325rem;
  --bs-badge-font-size: 0.85rem;
  --bs-badge-font-weight: 600;
  --bs-badge-color: var(--bs-body-color);
  --bs-badge-border-radius: 0.425rem;
  display: inline-block;
  padding: var(--bs-badge-padding-y) var(--bs-badge-padding-x);
  font-size: var(--bs-badge-font-size);
  font-weight: var(--bs-badge-font-weight);
  line-height: 1;
  color: var(--bs-badge-color);
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: var(--bs-badge-border-radius)
}

.priority-badge.priority-high {
  background: rgba(234, 67, 53, 0.15);
  color: var(--color-danger);
}

.priority-badge.priority-medium {
  background: rgba(255, 172, 7, 0.159);
  color: #f7941d;
}

.priority-badge.priority-low {
  background: rgba(108, 117, 125, 0.15);
  color: var(--color-muted);
}

/*this is the grouped sections container e.g. today, next week*/
.timeline-section {
  margin-bottom: 2rem;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  transition: all var(--transition-slow);
}

[data-bs-theme="dark"] .timeline-section {
  border: 1px solid #0000002b;
}

/* Timeline section headers */
.timeline-header {
  padding: 1rem 1.5rem;
  cursor: pointer;
  transition: all var(--transition-normal);
  background-color: #f1f1f1;
}

[data-bs-theme="dark"] .timeline-header {
  background-color: #0000002b;
}

.timeline-header:hover {
  background-color: rgba(0, 0, 0, 0.02);
}

.timeline-header-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Timeline tasks container - individual tasks inside the parent container */
.timeline-tasks {
  padding: 1rem;
  transition: all var(--transition-slow);
  overflow: hidden;
}

/*CODE RE-ADDED FOR TASK STATUS IN TIMELINE VIEW - NEED TO DELETE UNUSED CODE*/
/* Base styling for all status badges with data attributes - aligned with theme badges */
.badge-status, .task-status-badge, .task-status {
  display: inline-flex !important;
  align-items: center !important;
  position: relative !important;
  transition: all 0.3s ease !important;
  /* Match theme badge dimensions */
  height: 1.75rem !important;
  min-width: 1.75rem !important;
  padding: 0 0.5rem !important; /* Consistent with theme badges */
  overflow: hidden !important;
  z-index: 10 !important;
  border-radius: 5px !important;
  font-weight: 600;
  font-size: 0.85rem !important;
  line-height: 1 !important; /* Match theme badge line-height */
  justify-content: center !important; /* Center content like theme badges */
}

/* Add icons via ::before pseudo-element */
.badge-status::before, .task-status-badge::before, .task-status::before {
  font-family: "Font Awesome 7 Pro" !important;
  font-weight: 900 !important;
  margin-right: 0.35em !important;
  display: inline-block !important;
}

/* Edit icon using CSS pseudo-element */
.task-status-badge::after, .task-status::after {
  font-family: "Font Awesome 7 Pro" !important;
  font-weight: 900 !important;
  content: "\f044" !important; /* fa-pen-to-square icon code */
  position: absolute !important;
  right: -20px !important; /* Start off-screen */
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-size: 0.8em !important;
  transition: right 0.3s ease, opacity 0.3s ease !important;
  opacity: 0 !important;
  color: inherit !important; /* Inherit the badge text color */
}

.task-status-badge:hover, .task-status:hover {
  padding-right: 1.75rem !important; /* Make room for the icon */
}

.task-status-badge:hover::after, .task-status:hover::after {
  right: 0.35rem !important; /* Move into view */
  opacity: 1 !important;
}

/* Status-specific styling */
.badge-status[data-status="Not Started"], .task-status-badge[data-status="Not Started"], .task-status[data-status="Not Started"], .status-badge[data-status="Not Started"] {
  background-color: rgba(var(--bs-success-rgb), 0.15) !important;
  color: var(--bs-success) !important;
}
.badge-status[data-status="Not Started"]::before, .task-status-badge[data-status="Not Started"]::before, .task-status[data-status="Not Started"]::before, .status-badge[data-status="Not Started"]::before {
  font-family: "Font Awesome 7 Pro" !important;
  font-weight: 300 !important;
  font-style: normal !important;
  content: "\e6c5" !important; 
  display: inline-block !important;
}

.badge-status[data-status="In Progress"], .task-status-badge[data-status="In Progress"], .task-status[data-status="In Progress"] {
  background-color: rgba(var(--bs-warning-rgb), 0.15) !important;
  color: var(--bs-warning) !important;
}
.badge-status[data-status="In Progress"]::before, .task-status-badge[data-status="In Progress"]::before, .task-status[data-status="In Progress"]::before {
  font-family: "Font Awesome 7 Pro" !important;
  font-weight: 900 !important;
  font-style: normal !important;
  content: "\f110" !important;
  display: inline-block !important;
}

.badge-status[data-status="Waiting"], .task-status-badge[data-status="Waiting"], .task-status[data-status="Waiting"] {
  background-color: rgba(var(--bs-info-rgb), 0.15) !important;
  color: var(--bs-info) !important;
}
.badge-status[data-status="Waiting"]::before, .task-status-badge[data-status="Waiting"]::before, .task-status[data-status="Waiting"]::before {
  font-family: "Font Awesome 7 Pro"!important;
  font-weight: 400 !important;
  font-style: normal !important;
  content: "\f017" !important;
  display: inline-block !important;
}

.badge-status[data-status="Completed"], .task-status-badge[data-status="Completed"], .task-status[data-status="Completed"] {
  background-color: rgba(25, 135, 84, 0.15) !important;
  color: var(--color-success) !important;
}
.badge-status[data-status="Completed"]::before, .task-status-badge[data-status="Completed"]::before, .task-status[data-status="Completed"]::before {
  font-family: "Font Awesome 7 Pro" !important;
  font-weight: 900 !important;
  font-style: normal !important;
  content: "\f058" !important;
  display: inline-block !important;
}
[data-bs-theme="dark"] .badge-status[data-status="Completed"], 
[data-bs-theme="dark"] .task-status-badge[data-status="Completed"], 
[data-bs-theme="dark"] .task-status[data-status="Completed"] {
  background-color: rgba(16, 185, 129, 0.2) !important;
  color: #10b981 !important;
}