/* ========================================
   Theme Overrides & Compatibility
   ======================================== */

/* ===== OPERATIONS DASHBOARD SPECIFIC STYLES ===== */

/* Legend Toggle Container - Right alignment */
.legend-toggle-container {
  text-align: right !important;
}

/* Toggle Status Legend Button - Alatsi font */
#toggleStatusLegend {
  font-family: 'Alatsi', sans-serif !important;
}

/* ===== UNIFIED TIME RANGE BUTTON STYLING ===== */

/* Override Bootstrap btn-primary styles on time range buttons to use unified styling */
.time-tab-compact.btn-primary,
.time-tab-compact.btn-primary:hover,
.time-tab-compact.btn-primary:focus,
.time-tab-compact.btn-primary:active,
.time-tab-compact.btn-primary.active,
.time-tab-compact.btn-primary:not(:disabled):not(.disabled):active,
.time-tab-compact.btn-primary:not(:disabled):not(.disabled):active:focus {
  background: var(--sparrow-green) !important;
  border-color: transparent !important;
  color: #000 !important;
  box-shadow: none !important;
  transform: none !important;
  outline: none !important;
}

/* Additional high-specificity override for stubborn Bootstrap classes */
.time-range-btn.time-tab-compact.btn-primary:not(:disabled):not(.disabled):active,
.time-range-btn.time-tab-compact.btn-primary:not(:disabled):not(.disabled):active:focus,
.time-range-btn.time-tab-compact.btn-primary:not(:disabled):not(.disabled).active {
  background-color: var(--sparrow-green) !important;
  background: var(--sparrow-green) !important;
  border-color: transparent !important;
  color: #000 !important;
  box-shadow: none !important;
  transform: none !important;
  outline: none !important;
}

/* Override Bootstrap btn-outline-primary styles on time range buttons */
.time-tab-compact.btn-outline-primary,
.time-tab-compact.btn-outline-primary:hover,
.time-tab-compact.btn-outline-primary:focus {
  background: transparent !important;
  border-color: transparent !important;
  color: #718096 !important;
  box-shadow: none !important;
  transform: none !important;
}

.time-tab-compact.btn-outline-primary:hover {
  background: #e2e8f0 !important;
  color: #2d3748 !important;
}

/* Ensure the unified .active class always takes precedence */
.time-tab-compact.active {
  background: var(--sparrow-green) !important;
  color: #000 !important;
  border-color: transparent !important;
  box-shadow: none !important;
  transform: none !important;
}

/* ===== UNIFIED COMPRESSED FILTER BAR STYLING ===== */

/* Main filter bar container */
.compressed-filter-bar {
  background: white !important;
  border-radius: 16px !important;
  padding: 16px 20px !important;
  margin-bottom: 20px !important;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08) !important;
  border: 1px solid #e9ecef !important;
}

.filter-form {
  margin: 0 !important;
}

/* Filter row layout */
.compressed-filter-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 20px !important;
}

.compressed-filter-row.balanced-filter-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) !important;
  align-items: center !important;
  column-gap: 20px !important;
}

/* Account selection section */
.account-section {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex: 1 !important;
}

.balanced-filter-row .account-section {
  flex: none !important;
  min-width: 0 !important;
  justify-self: start !important;
}

/* Carrier/secondary filter section (center column of the compressed filter bar) */
.carrier-account-section {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.5rem !important;
  padding: 0 1rem !important;
  min-width: 240px !important;
}

.balanced-filter-row .carrier-account-section {
  justify-self: center !important;
}

.balanced-filter-row .date-section {
  justify-self: end !important;
}

/* Date section */
.date-section {
  display: flex !important;
  flex-direction: row !important;
  gap: 0.75rem !important;
  align-items: center !important;
  justify-content: flex-end !important;
  flex-wrap: nowrap !important;
}

/* Compact select styling */
.compact-select {
  min-width: 200px !important;
  max-width: 300px !important;
  font-size: 0.9rem !important;
  border: 1px solid #ced4da !important;
  border-radius: 8px !important;
  padding: 8px 12px !important;
  background: white !important;
}

/* Child selection button */
.child-btn {
  border: 1px solid #e1e5e9 !important;
  border-radius: 4px !important;
  padding: 0.375rem 0.625rem !important;
  font-size: 0.8125rem !important;
  background-color: #fff !important;
  color: #2d3748 !important;
  min-width: 180px !important;
  height: 48px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  cursor: pointer !important;
}

.child-btn:hover {
  border-color: var(--sparrow-green) !important;
  background-color: rgba(196, 255, 97, 0.1) !important;
}

/* Apply button */
.apply-btn-compact {
  background: var(--sparrow-green) !important;
  border: none !important;
  color: #000 !important;
  padding: 0.5rem 1rem !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
}

.apply-btn-compact:hover {
  background: #b8e986 !important;
  transform: translateY(-1px) !important;
}

/* Date display */
.date-display-compact {
  font-size: 0.75rem !important;
  color: #6b7280 !important;
  font-weight: 600 !important;
  text-align: left !important;
  white-space: nowrap !important;
  flex: 0 0 auto !important;
  padding-right: 0 !important;
}

/* Time tabs container */
.time-tabs-compact {
  display: flex !important;
  gap: 0.25rem !important;
  background: #f8fafc !important;
  border-radius: 999px !important;
  padding: 0.2rem !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.05) !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
}

/* Time tab buttons */
.time-tab-compact {
  border: none !important;
  border-radius: 999px !important;
  background: transparent !important;
  color: #4a5568 !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  padding: 0.35rem 0.85rem !important;
  white-space: nowrap !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: all 0.15s ease !important;
  min-width: 44px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0 !important;
  margin: 0 !important;
}

.time-tab-compact:hover {
  color: #1a202c !important;
  background: rgba(0, 0, 0, 0.03) !important;
  transform: none !important;
}

.time-tab-compact.active,
.time-tab-compact.selected {
  background: var(--sparrow-green) !important;
  color: #000 !important;
  border-color: transparent !important;
  box-shadow: 0 6px 12px rgba(196, 255, 97, 0.35) !important;
  transform: none !important;
}

.time-tab-compact:focus-visible {
  outline: 2px solid #3182ce !important;
  outline-offset: 2px !important;
}

/* Custom tab styling */
.custom-tab {
  min-width: 58px !important;
}

/* Responsive design */
@media (max-width: 820px) {
  .compressed-filter-row {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0.75rem !important;
  }

  .compressed-filter-row.balanced-filter-row {
    display: flex !important;
  }
  
  .account-section {
    justify-content: center !important;
  }
  
  .date-section {
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
  }
  
  .compact-select,
  .child-btn {
    min-width: auto !important;
    width: 100% !important;
    max-width: 280px !important;
  }

  .carrier-account-section {
    padding: 0.75rem 0 !important;
    min-width: 100% !important;
  }

  .time-tabs-compact {
    width: 100% !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
    border-radius: 1rem !important;
  }

  .time-tab-compact {
    flex: 1 1 auto !important;
  }
  
  .date-display-compact {
    text-align: center !important;
    max-width: 280px !important;
    margin: 0 auto !important;
  }
}

/* ===== UNIFIED CARD STYLING (Standard from Operations Dashboard) ===== */

/* Base Card Theme */
.card-theme {
  border: 1px solid rgba(0,0,0,0.06) !important;
  background: var(--card-bg) !important;
  border-radius: 12px !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.08) !important;
  transition: all 0.3s ease !important;
  overflow: hidden !important;
}

.card-theme:hover {
  box-shadow: 0 4px 12px rgba(0,0,0,0.12) !important;
  transform: translateY(-1px) !important;
  border-color: rgba(126, 211, 33, 0.2) !important;
}

.card-theme .card-header {
  color: var(--sparrow-black) !important;
  border: none !important;
  border-bottom: 1px solid #e9ecef !important;
  padding: 0.4rem 1.5rem !important;
  font-weight: 600 !important;
  position: relative !important;
}

.card-theme .card-header::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 1.5rem;
  right: 1.5rem;
  height: 3px;
  border-radius: 2px 2px 0 0;
}

.card-theme .card-header h5 {
  font-family: 'Outfit', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  margin: 0 !important;
}

/* Metric Cards */
.metric-card {
  border: none !important;
  background: var(--card-bg) !important;
  border-radius: 16px !important;
  box-shadow: var(--shadow-card) !important;
  transition: all 0.3s ease !important;
  overflow: hidden !important;
  position: relative !important;
  min-height: 120px !important;
}

.metric-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
}

.metric-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--shadow-hover) !important;
}

.metric-card .card-body {
  padding: 1.25rem 1rem !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: center !important;
}

/* Metric Card Content */
.metric-value {
  font-family: 'Outfit', sans-serif !important;
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
  line-height: 1 !important;
  text-align: center !important;
}

.metric-counter {
  transform-origin: center;
  will-change: transform, opacity;
}

.metric-counter.metric-counter-animating {
  animation: metricCounterRise 0.45s ease-out;
}

@keyframes metricCounterRise {
  0% {
    opacity: 0.7;
    transform: translateY(6px) scale(0.985);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.metric-label {
  font-size: 0.8rem !important;
  color: var(--text-secondary) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.3px !important;
  text-align: center !important;
}

/* Metric Icons */
.metric-icon {
  width: 50px !important;
  height: 50px !important;
  border-radius: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.25rem !important;
  color: white !important;
  position: relative !important;
  overflow: hidden !important;
}

.metric-icon::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(45deg, rgba(255,255,255,0.1), rgba(255,255,255,0));
}

.metric-icon-img {
  width: 50px !important;
  height: 50px !important;
  object-fit: contain !important;
  z-index: 1 !important;
  position: relative !important;
}

/* Metrics Row Layout */
.metrics-row {
  display: flex !important;
  flex-wrap: wrap !important;
}

.metrics-row > [class*="col-"] {
  display: flex !important;
  flex-direction: column !important;
}

.metrics-row .card-theme {
  height: 100% !important;
  display: flex !important;
  flex-direction: column !important;
}

.metrics-row .card-theme .card-body {
  flex: 1 !important;
}

.metric-card .d-flex {
  align-items: stretch !important;
}

@media (prefers-reduced-motion: reduce) {
  .metric-counter.metric-counter-animating {
    animation: none !important;
  }
}

/* ===== OVERRIDE BOOTSTRAP & SITE.CSS CONFLICTS ===== */

/* Reset body background from site.css */
body {
  background: var(--body-bg) !important;
  color: var(--text-primary) !important;
  font-family: var(--font-family-sans) !important;
  padding-top: 0 !important; /* Reset site.css padding */
}

/* Override header styles from site.css */
header {
  background: var(--header-bg) !important;
  height: var(--header-height) !important;
  padding: 0 1.5rem !important;
  box-shadow: none !important;
  border-bottom: 1px solid var(--header-border) !important;
}

/* Override button styles from site.css */
.btn-cta,
.btn-cta-primary,
.btn-cta-outline {
  border-radius: var(--border-radius) !important;
  font-family: var(--font-family-sans) !important;
  font-size: var(--font-size-sm) !important;
  font-weight: var(--font-weight-medium) !important;
  padding: 0.5rem 1rem !important;
  transition: all var(--transition-fast) !important;
}

.btn-cta-primary {
  background-color: var(--primary-500) !important;
  border-color: var(--primary-500) !important;
  color: var(--sparrow-black) !important;
}

.btn-cta-primary:hover {
  background-color: var(--primary-600) !important;
  border-color: var(--primary-600) !important;
  color: var(--sparrow-black) !important;
  transform: translateY(-1px) !important;
}

.btn-cta-outline {
  background-color: transparent !important;
  border-color: var(--primary-500) !important;
  color: var(--primary-600) !important;
}

.btn-cta-outline:hover {
  background-color: var(--primary-50) !important;
  border-color: var(--primary-600) !important;
  color: var(--primary-700) !important;
}

/* ===== FORM CONTROLS ===== */

/* Override input styles from site.css */
input, select, textarea {
  background-color: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--border-radius) !important;
  font-family: var(--font-family-sans) !important;
  font-size: var(--font-size-sm) !important;
  padding: 0.75rem !important;
  width: 100% !important;
  transition: all var(--transition-fast) !important;
}

input:focus, select:focus, textarea:focus {
  border-color: var(--primary-500) !important;
  box-shadow: var(--focus-ring) !important;
  outline: none !important;
}

/* Form labels */
label {
  color: var(--text-primary) !important;
  font-weight: var(--font-weight-medium) !important;
  font-size: var(--font-size-sm) !important;
  margin-bottom: 0.5rem !important;
}

/* ===== CARD STYLES ===== */

/* Override card styles from site.css */
.card, .mantine-card {
  background-color: var(--card-bg) !important;
  border: 1px solid var(--card-border) !important;
  border-radius: var(--border-radius-lg) !important;
  box-shadow: var(--shadow-sm) !important;
  color: var(--text-primary) !important;
  margin-bottom: 1.5rem !important;
  padding: 0 !important; /* Reset padding, let card-body handle it */
  transition: all var(--transition-normal) !important;
}

.card:hover, .mantine-card:hover {
  box-shadow: var(--shadow-md) !important;
  transform: translateY(-2px) !important;
}

/* ===== NAVIGATION OVERRIDES ===== */

/* Override Bootstrap nav-pills default blue styling */
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
  color: var(--sparrow-black) !important;

  border: none !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3) !important;
}

.nav-pills .nav-link.active:hover,
.nav-pills .show > .nav-link:hover {
  color: var(--sparrow-black) !important;
  background-color: #bfbfbf !important;
}

/* Override nav-pills default behavior */
.nav-pills .nav-link {
  color: var(--sidebar-text-muted) !important;
  background-color: transparent !important;
  border: none !important;
  transition: all var(--transition-fast) !important;
}

.nav-pills .nav-link:hover {
  color: var(--sparrow-black) !important;
  background-color: #ebebeb !important;
}

/* Override the green flash from _NavigationPartial.cshtml */
.sidebar-content .nav-link:hover {
  background: #ebebeb !important; /* Override the rgba(126, 211, 33, 0.1) */
}

.sidebar-content .nav-link:focus {
  background: #ebebeb !important;
  outline: none !important;
}

/* Override nav styles from site.css */
nav {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  width: 100% !important;
  padding-right: 0 !important; /* Reset site.css padding */
}

nav ul {
  display: flex !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  gap: 1rem !important; /* Reduce from 2rem in site.css */
}

nav a {
  color: var(--text-primary) !important;
  font-weight: var(--font-weight-medium) !important;
  text-decoration: none !important;
  transition: all var(--transition-fast) !important;
  padding: 0.5rem 1rem !important;
  border-radius: var(--border-radius) !important;
}

nav a:hover {
  color: var(--primary-600) !important;
  background-color: var(--primary-50) !important;
}

nav a.active {
  color: var(--primary-600) !important;
  background-color: var(--primary-100) !important;
}

/* ===== SEARCH BOX OVERRIDES ===== */

.search-box {
  position: relative !important;
  width: 250px !important;
  margin: 0 !important; /* Reset site.css margins */
}

.search-box input {
  width: 100% !important;
  padding: 0.5rem 2.5rem 0.5rem 0.75rem !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--border-radius) !important;
  font-size: var(--font-size-sm) !important;
  background-color: var(--card-bg) !important;
  color: var(--text-primary) !important;
  transition: all var(--transition-fast) !important;
}

.search-box input:focus {
  border-color: var(--primary-500) !important;
  box-shadow: var(--focus-ring) !important;
  outline: none !important;
}

.search-box::after {
  color: var(--primary-500) !important;
  right: 0.75rem !important;
}

/* ===== TABLE OVERRIDES ===== */

/* Override table styles */
.table {
  color: var(--text-primary) !important;
  font-family: var(--font-family-sans) !important;
}

.table th {
  background-color: var(--gray-50) !important;
  color: var(--text-secondary) !important;
  font-weight: var(--font-weight-semibold) !important;
  font-size: var(--font-size-sm) !important;
  border-bottom: 1px solid var(--border-color) !important;
  padding: 0.75rem 1rem !important;
}

.table td {
  color: var(--text-primary) !important;
  font-size: var(--font-size-sm) !important;
  border-bottom: 1px solid var(--border-color-light) !important;
  padding: 0.75rem 1rem !important;
}

.table-hover tbody tr:hover {
  background-color: var(--gray-50) !important;
  color: var(--text-primary) !important;
}

/* ===== DROPDOWN OVERRIDES ===== */

/* Override dropdown styles from site.css */
.dropdown-menu {
  background-color: var(--card-bg) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--border-radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  padding: 0.5rem 0 !important;
  margin-top: 0.5rem !important;
}

.dropdown-item {
  color: var(--text-primary) !important;
  font-size: var(--font-size-sm) !important;
  padding: 0.5rem 1rem !important;
  transition: all var(--transition-fast) !important;
}

.dropdown-item:hover,
.dropdown-item:focus {
  background-color: var(--gray-50) !important;
  color: var(--primary-600) !important;
}

.dropdown-item.active,
.dropdown-item:active {
  background-color: var(--primary-100) !important;
  color: var(--primary-700) !important;
}

/* ===== PAGINATION OVERRIDES ===== */

.pagination {
  --bs-pagination-bg: var(--card-bg);
  --bs-pagination-border-color: var(--border-color);
  --bs-pagination-color: var(--text-primary);
  --bs-pagination-hover-bg: var(--gray-50);
  --bs-pagination-hover-border-color: var(--border-color);
  --bs-pagination-hover-color: var(--primary-600);
  --bs-pagination-active-bg: var(--primary-500);
  --bs-pagination-active-border-color: var(--primary-500);
  --bs-pagination-active-color: white;
  --bs-pagination-disabled-bg: var(--gray-100);
  --bs-pagination-disabled-border-color: var(--border-color-light);
  --bs-pagination-disabled-color: var(--text-muted);
}

/* ===== BADGE OVERRIDES ===== */

.badge {
  font-family: var(--font-family-sans) !important;
  font-size: var(--font-size-xs) !important;
  font-weight: var(--font-weight-medium) !important;
  padding: 0.25rem 0.75rem !important;
  border-radius: 9999px !important;
}

.bg-primary,
.badge.bg-primary {
  background-color: var(--primary-100) !important;
  color: var(--primary-800) !important;
}

.bg-success,
.badge.bg-success {
  background-color: var(--success-50) !important;
  color: #000000 !important
}

.bg-warning,
.badge.bg-warning {
  background-color: var(--warning-50) !important;
  color: #000000 !important;
}

.bg-danger,
.badge.bg-danger {
  background-color: var(--error-50) !important;
  color: #dd1a1a !important;
}

.bg-info,
.badge.bg-info {
  background-color: var(--info-50) !important;
  color: #000000 !important;
}

.bg-secondary,
.badge.bg-secondary {
  background-color: var(--gray-100) !important;
  color: var(--gray-800) !important;
}

/* ===== ALERT OVERRIDES ===== */

.alert {
  border-radius: var(--border-radius-lg) !important;
  border: 1px solid !important;
  font-family: var(--font-family-sans) !important;
  font-size: var(--font-size-sm) !important;
  padding: 1rem !important;
}

.alert-primary {
  background-color: var(--primary-50) !important;
  border-color: var(--primary-200) !important;
  color: var(--primary-800) !important;
}

.alert-success {
  background-color: var(--success-50) !important;
  border-color: var(--success-100) !important;
  color: var(--success-800) !important;
}

.alert-warning {
  background-color: var(--warning-50) !important;
  border-color: var(--warning-100) !important;
  color: var(--warning-800) !important;
}

.alert-danger {
  background-color: var(--error-50) !important;
  border-color: var(--error-100) !important;
  color: var(--error-800) !important;
}

.alert-info {
  background-color: var(--info-50) !important;
  border-color: var(--info-100) !important;
  color: var(--info-800) !important;
}

/* ===== TOASTR OVERRIDES ===== */

#toast-container > .toast {
  border-radius: var(--border-radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  font-family: var(--font-family-sans) !important;
  font-size: var(--font-size-sm) !important;
}

#toast-container > .toast-success {
  background-color: var(--success-600) !important;
}

#toast-container > .toast-error {
  background-color: var(--error-600) !important;
}

#toast-container > .toast-info {
  background-color: var(--info-600) !important;
}

#toast-container > .toast-warning {
  background-color: var(--warning-600) !important;
}

/* ===== SELECT2 OVERRIDES ===== */

.select2-container--bootstrap4 .select2-selection {
  background-color: var(--card-bg) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--border-radius) !important;
  color: var(--text-primary) !important;
  font-family: var(--font-family-sans) !important;
  font-size: var(--font-size-sm) !important;
  padding: 0.75rem !important;
  height: auto !important;
  min-height: calc(1.5em + 1.5rem + 2px) !important;
}

.select2-container--bootstrap4 .select2-selection:focus,
.select2-container--bootstrap4.select2-container--focus .select2-selection {
  border-color: var(--primary-500) !important;
  box-shadow: var(--focus-ring) !important;
}

.select2-dropdown {
  background-color: var(--card-bg) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--border-radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
}

.select2-results__option {
  color: var(--text-primary) !important;
  font-family: var(--font-family-sans) !important;
  font-size: var(--font-size-sm) !important;
  padding: 0.5rem 1rem !important;
}

.select2-results__option--highlighted {
  background-color: var(--primary-50) !important;
  color: var(--primary-700) !important;
}

.select2-results__option[aria-selected="true"] {
  background-color: var(--primary-100) !important;
  color: var(--primary-800) !important;
}

/* ===== RESET CONFLICTING SITE.CSS STYLES ===== */

/* Reset hero section styles if they leak */
.hero-section {
  background: none !important;
  color: var(--text-primary) !important;
  padding: 2rem 0 !important;
}

/* Reset features section */
.features-section,
.how-it-works-section {
  background: var(--body-bg) !important;
  color: var(--text-primary) !important;
}

/* Reset CTA section */
.cta-section {
  background: var(--primary-500) !important;
  color: white !important;
}

/* Reset mantine button styles */
.mantine-button,
.mantine-button-primary,
.mantine-button-secondary,
.mantine-button-outline {
  border-radius: var(--border-radius) !important;
  font-family: var(--font-family-sans) !important;
  font-size: var(--font-size-sm) !important;
  font-weight: var(--font-weight-medium) !important;
  padding: 0.5rem 1rem !important;
  transition: all var(--transition-fast) !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}

/* ===== BOOTSTRAP BUTTON OVERRIDES ===== */

/* Override Bootstrap's default btn-primary to use sparrow-green with black text */
.btn-primary {
  background-color: #ffffff !important;
  border-color: #000000 !important;
  color: var(--sparrow-black) !important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-primary.active {
  background-color: var(--sparrow-green-dark) !important;
  border-color: var(--sparrow-green-dark) !important;
  color: var(--sparrow-black) !important;
}

.btn-primary:focus,
.btn-primary.focus {
  box-shadow: 0 0 0 0.2rem rgba(196, 255, 97, 0.5) !important;
}

.btn-primary:not(:disabled):not(.disabled):active,
.btn-primary:not(:disabled):not(.disabled).active {
  background-color: #cecfca !important;
  border-color: var(--sparrow-green-dark) !important;
  color: var(--sparrow-black) !important;
}

/* Override Bootstrap's default btn-outline-primary */
.btn-outline-primary {
  color: var(--sparrow-black) !important;
  border-color: #000000 !important;
  background-color: transparent !important;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active,
.btn-outline-primary.active {
  background-color: var(--sparrow-green) !important;
  border-color: #000000 !important;
  color: var(--sparrow-black) !important;
}

.btn-outline-primary:not(:disabled):not(.disabled):active,
.btn-outline-primary:not(:disabled):not(.disabled).active {
  background-color: var(--sparrow-green) !important;
  border-color: #000000 !important;
  color: var(--sparrow-black) !important;
}

.btn-outline-primary:focus,
.btn-outline-primary.focus {
  box-shadow: 0 0 0 0.2rem rgba(196, 255, 97, 0.5) !important;
}

/* ===== CUSTOM BUTTON STYLING TO MATCH CREATE NEW RULE BUTTON ===== */

/* Apply buttons - match Create New Rule button styling */
.apply-btn-compact {
  background-color: #ffffff !important;
  border: 1px solid #000000 !important;
  color: var(--sparrow-black) !important;
  border-radius: 0.375rem !important;
  padding: 0.375rem 0.75rem !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  transition: all 0.15s ease-in-out !important;
  cursor: pointer !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
}

.apply-btn-compact:hover {
  background-color: var(--sparrow-green-dark) !important;
  border-color: var(--sparrow-green-dark) !important;
  color: var(--sparrow-black) !important;
  transform: translateY(-1px) !important;
}

/* Date filter buttons now use the shared segmented-pill styling above */

/* ===== HELPDESK PAGE STYLING TO MATCH CREATE NEW RULE BUTTON ===== */

/* All Cases and My Cases filter tabs - match Create New Rule button styling */
.filter-tabs .filter-tab {
  background-color: #ffffff !important;
  border: 1px solid #000000 !important;
  color: var(--sparrow-black) !important;
  border-radius: 0.375rem !important;
  padding: 0.375rem 0.75rem !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  transition: all 0.15s ease-in-out !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  margin: 0 0.25rem !important;
}

.filter-tabs .filter-tab:hover {
  background-color: var(--sparrow-green-dark) !important;
  border-color: var(--sparrow-green-dark) !important;
  color: var(--sparrow-black) !important;
  transform: translateY(-1px) !important;
}

.filter-tabs .filter-tab.active {
  background-color: var(--sparrow-green) !important;
  border-color: var(--sparrow-green) !important;
  color: var(--sparrow-black) !important;
  font-weight: 600 !important;
  box-shadow: 0 2px 4px rgba(196, 255, 97, 0.3) !important;
}

/* Update filter-tabs container */
.filter-tabs {
  display: flex !important;
  gap: 0.5rem !important;
  background: transparent !important;
  border-radius: 0 !important;
  padding: 0 !important;
}

/* Quick Actions buttons - match Create New Rule button styling */
.quick-action-btn {
  background-color: #ffffff !important;
  border: 1px solid #000000 !important;
  color: var(--sparrow-black) !important;
  border-radius: 0.375rem !important;
  padding: 0.375rem 0.75rem !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  transition: all 0.15s ease-in-out !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
}

.quick-action-btn:hover {
  background-color: var(--sparrow-green-dark) !important;
  border-color: var(--sparrow-green-dark) !important;
  color: var(--sparrow-black) !important;
  transform: translateY(-1px) !important;
  text-decoration: none !important;
}

/* ===== SUMMARY CARDS STYLING TO MATCH OPERATIONS DASHBOARD ===== */

/* Helpdesk stat-card - match Operations Dashboard metric-card styling */
.stat-card {
  border: none !important;
  background: var(--card-bg) !important;
  border-radius: 16px !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08) !important;
  transition: all 0.3s ease !important;
  overflow: hidden !important;
  position: relative !important;
  padding: 1.25rem 1rem !important;
}

.stat-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 3px !important;
}

.stat-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12) !important;
}

/* Update stat icons to match Operations Dashboard style */
.stat-icon {
  width: 50px !important;
  height: 50px !important;
  border-radius: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.25rem !important;
  color: white !important;
  position: relative !important;
  overflow: hidden !important;
}

.stat-icon::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  background: linear-gradient(45deg, rgba(255,255,255,0.1), rgba(255,255,255,0)) !important;
}

/* Update stat values to match Operations Dashboard typography */
.stat-number {
  font-family: 'Outfit', sans-serif !important;
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
  line-height: 1 !important;
  margin: 0 !important;
}

/* Update stat labels to match Operations Dashboard typography */
.stat-info h6 {
  font-size: 0.8rem !important;
  color: var(--text-secondary) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.3px !important;
  margin: 0 0 4px 0 !important;
}

/* ===== COMMERCIAL DASHBOARD METRIC CARDS OVERRIDE ===== */

/* Ensure Commercial Dashboard uses the same metric-card styling as Operations Dashboard */
.metric-card {
  border: none !important;
  background: var(--card-bg) !important;
  border-radius: 16px !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08) !important;
  transition: all 0.3s ease !important;
  overflow: hidden !important;
  position: relative !important;
}

.metric-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 3px !important;
}

.metric-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12) !important;
}

.metric-card .card-body {
  padding: 1.25rem 1rem !important;
}

/* Ensure metric icons are consistent */
.metric-icon {
  width: 50px !important;
  height: 50px !important;
  border-radius: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.25rem !important;
  color: white !important;
  position: relative !important;
  overflow: hidden !important;
}

.metric-icon::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  background: linear-gradient(45deg, rgba(255,255,255,0.1), rgba(255,255,255,0)) !important;
}

/* Ensure metric values are consistent */
.metric-value {
  font-family: 'Outfit', sans-serif !important;
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
  line-height: 1 !important;
  text-align: center !important;
}

/* Ensure metric labels are consistent */
.metric-label {
  font-size: 0.8rem !important;
  color: var(--text-secondary) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.3px !important;
  text-align: center !important;
}

.ms-3 {
  margin-left: 0.0rem !important;
}

/* ===== CHAT BUTTON FONT FIXES ===== */

/* Fix chat buttons to use Outfit font family */
.chat-toggle-btn {
  font-family: 'Outfit', sans-serif !important;
}

.chat-close-btn {
  font-family: 'Outfit', sans-serif !important;
}

.chat-send-btn {
  font-family: 'Outfit', sans-serif !important;
}

/* Also fix any chat-related text elements */
.chat-input {
  font-family: 'Outfit', sans-serif !important;
}

.chat-message {
  font-family: 'Outfit', sans-serif !important;
}

.message-content {
  font-family: 'Outfit', sans-serif !important;
}

/* ===== CHAT TYPING INDICATOR ALIGNMENT FIXES ===== */

/* Ensure typing indicator is properly aligned in all chat implementations */
.chat-typing-indicator:not([style*="display: none"]) {
  display: flex !important;
  align-items: center !important;
  margin-bottom: 12px !important;
  padding: 8px 12px !important;
  background: #f8f9fa !important;
  border-radius: 20px !important;
  width: fit-content !important;
  font-family: 'Outfit', sans-serif !important;
}

/* Ensure consistent spacing for typing indicator text */
.chat-typing-indicator .text-muted {
  margin-left: 8px !important;
  font-size: 0.875rem !important;
  color: #6c757d !important;
}

/* ===== REPLACE ALL INTER FONT REFERENCES WITH OUTFIT ===== */

/* Dashboard classes that use Inter */
.commercial-dashboard {
  font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}

.operations-dashboard {
  font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}

/* Map popup elements */
.postcode-popup {
  font-family: 'Outfit', sans-serif !important;
}

.cluster-popup {
  font-family: 'Outfit', sans-serif !important;
}

/* Auth and landing page body overrides */
.auth-body {
  font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}

/* Global body override for landing pages */
body, html {
  font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}

/* Dashboard specific elements that may have Inter */
.dashboard-header {
  font-family: 'Outfit', sans-serif !important;
}

.metric-card {
  font-family: 'Outfit', sans-serif !important;
}

.card-header {
  font-family: 'Outfit', sans-serif !important;
}

.card-body {
  font-family: 'Outfit', sans-serif !important;
}

/* Table and data elements */
.table {
  font-family: 'Outfit', sans-serif !important;
}

.table th, .table td {
  font-family: 'Outfit', sans-serif !important;
}

/* Form elements */
input, select, textarea, button {
  font-family: 'Outfit', sans-serif !important;
}

/* Navigation elements */
.nav, .nav-link, .navbar {
  font-family: 'Outfit', sans-serif !important;
}

/* Modal and dropdown elements */
.modal, .dropdown-menu {
  font-family: 'Outfit', sans-serif !important;
}

/* Alert and notification elements */
.alert, .toast {
  font-family: 'Outfit', sans-serif !important;
}

/* Breadcrumb and pagination */
.breadcrumb, .pagination {
  font-family: 'Outfit', sans-serif !important;
}

/* ===== UTILITY CLASS FIXES ===== */

/* Override Bootstrap spacing utilities */
.mb-4 {
  margin-bottom: 0.5rem !important;
}

/* Ensure text utilities work properly */
.text-muted {
  color: var(--text-muted) !important;
}

.text-primary {
  color: var(--primary-600) !important;
}

.text-success {
  color: var(--sparrow-green-dark) !important;
}

.text-warning {
  color: var(--warning-600) !important;
}

.text-danger {
  color: var(--error-600) !important;
}

.text-info {
  color: var(--info-600) !important;
}

/* Background utilities */
.bg-light {
  background-color: var(--gray-50) !important;
  color: var(--text-primary) !important;
}

.bg-dark {
  background-color: var(--gray-800) !important;
  color: var(--gray-100) !important;
}

.bg-white {
  background-color: var(--card-bg) !important;
  color: var(--text-primary) !important;
}

.child-search-input {
  max-width: 80% !important;
}
.child-selectall-children {
  max-width: 25px !important;
}

/* ===== CHILD ACCOUNT SELECTION MODAL ===== */

#childClientSelectionModal .modal-content {
  border: 1px solid #dee2e6;
  border-radius: 0.75rem;
  overflow: hidden;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12);
}

#childClientSelectionModal .modal-header {
  background: var(--sparrow-green);
  color: #000;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

#childClientSelectionModal .modal-title {
  font-weight: 700;
}

#childClientSelectionModal .btn-close {
  opacity: 0.75;
}

#childClientSelectionModal .btn-close:hover {
  opacity: 1;
}

#childClientSelectionModal .modal-body,
#childClientSelectionModal .modal-footer {
  background: #fff;
}

#childClientSelectionModal .modal-footer {
  border-top: 1px solid #eef0f2;
}

#childClientSelectionModal .input-group {
  display: flex;
  flex-wrap: nowrap;
}

#childClientSelectionModal .input-group .form-control {
  flex: 1;
  min-width: 0;
  border-color: #ced4da;
}

#childClientSelectionModal .input-group .form-control:focus {
  border-color: var(--sparrow-green);
  box-shadow: 0 0 0 0.2rem rgba(196, 255, 97, 0.25);
}

#childClientSelectionModal .input-group .btn {
  flex-shrink: 0;
  white-space: nowrap;
}

#childClientSelectionModal .form-check {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-height: 1.5rem;
  margin-bottom: 0;
}

#childClientSelectionModal #selectAllChildrenModal {
  width: 20px;
  height: 20px;
  margin-top: 0;
  margin-left: 0;
  border-color: #adb5bd;
  cursor: pointer;
}

#childClientSelectionModal #selectAllChildrenModal:checked {
  background-color: #000;
  border-color: #000;
}

#childClientSelectionModal #selectAllChildrenModal:focus {
  border-color: var(--sparrow-green);
  box-shadow: 0 0 0 0.2rem rgba(196, 255, 97, 0.25);
}

#childClientSelectionModal .form-check-label {
  color: var(--text-primary);
  font-weight: 600 !important;
}

#childClientSelectionModal hr {
  margin: 0.75rem 0 0;
  border-color: #eef0f2;
}

#childClientSelectionModal #childClientModalContent {
  max-height: 300px;
  overflow-y: auto;
}

#childClientSelectionModal .child-selection-list {
  display: block;
  gap: 0;
  border: 1px solid #dee2e6;
  border-radius: 0.375rem;
  overflow: hidden;
}

#childClientSelectionModal .child-selection-item {
  padding: 0.5rem 0.75rem;
  border: none;
  border-bottom: 1px solid #f1f3f4;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  transition: all 0.2s ease;
  user-select: none;
  background: #fff;
}

#childClientSelectionModal .child-selection-item:last-child {
  border-bottom: none;
}

#childClientSelectionModal .child-selection-item:hover {
  background-color: rgba(196, 255, 97, 0.1);
}

#childClientSelectionModal .child-selection-item.selected {
  background-color: var(--sparrow-green);
  color: #000;
  font-weight: 500;
  border-color: transparent;
  box-shadow: none;
}

#childClientSelectionModal .child-selection-item.selected:hover {
  background-color: rgba(196, 255, 97, 0.8);
}

#childClientSelectionModal .selection-indicator {
  width: 20px;
  height: 20px;
  margin-right: 0;
  border: 2px solid #dee2e6;
  border-radius: 0.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.875rem;
  font-weight: bold;
  transition: all 0.2s ease;
  flex-shrink: 0;
}

#childClientSelectionModal .child-selection-item.selected .selection-indicator {
  background-color: #000;
  color: var(--sparrow-green);
  border-color: #000;
}

#childClientSelectionModal .child-name {
  flex: 1;
  color: inherit;
  font-weight: inherit;
}

/* ===== RESPONSIVE FIXES ===== */

@media (max-width: 991.98px) {
  /* Ensure mobile navigation works */
  .search-box {
    width: 100% !important;
    margin: 0.5rem 0 !important;
  }
  
  /* Mobile form controls */
  input, select, textarea {
    font-size: 16px !important; /* Prevent zoom on iOS */
  }
}

/* ===== PRINT STYLES ===== */

@media print {
  body {
    background: white !important;
    color: black !important;
  }
  
  .card {
    border: 1px solid #ccc !important;
    box-shadow: none !important;
  }
  
  #sidebar,
  #header,
  .sidebar-toggle,
  .user-dropdown {
    display: none !important;
  }
  
  main {
    margin-left: 0 !important;
    padding-top: 0 !important;
  }
}

/* ===== SECTION BUILDER TEXT EDITOR - HIGHLIGHT STYLES ===== */

/* Highlight color swatch in dropdown */
.highlight-swatch {
  display: inline-block;
  width: 18px;
  height: 18px;
  border-radius: 3px;
  border: 1px solid rgba(0, 0, 0, 0.15);
  flex-shrink: 0;
}

/* Highlight dropdown styling */
.highlight-colors-dropdown {
  min-width: 160px;
  padding: 0.25rem 0;
}

.highlight-colors-dropdown .dropdown-item {
  padding: 0.4rem 0.75rem;
  font-size: 0.875rem;
}

.highlight-colors-dropdown .dropdown-item:hover {
  background-color: var(--primary-50, #f0f9e8);
}

/* Editor toolbar dropdown button */
.editor-toolbar .dropdown-toggle::after {
  margin-left: 0.35em;
  vertical-align: 0.15em;
}

.editor-toolbar .btn-group {
  margin-left: 2px;
}

/* ===================================================================
   Scout AI Chat - Tool Progress Styles
   =================================================================== */

/* Tool Progress Display */
.dexter-progress {
    padding: 0.75rem;
    background: rgba(0, 0, 0, 0.02);
    border-radius: 8px;
    margin-bottom: 0.5rem;
    border: 1px solid rgba(0, 0, 0, 0.05);
}

.tool-calls-container {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.tool-call {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    background: white;
    border-radius: 6px;
    border-left: 3px solid #6c757d;
    font-size: 0.8rem;
    transition: all 0.2s ease;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.tool-call.running {
    border-left-color: #ffc107;
    background: #fffbf0;
}

.tool-call.complete {
    border-left-color: var(--sparrow-green, #c4ff61);
    background: #f8fff0;
}

.tool-call.error {
    border-left-color: #dc3545;
    background: #fff5f5;
}

.tool-call .tool-icon {
    font-size: 1rem;
    flex-shrink: 0;
}

.tool-call .tool-name {
    font-weight: 600;
    color: #333;
    flex-shrink: 0;
}

.tool-call .tool-args {
    flex: 1;
    color: #666;
    font-family: 'SF Mono', 'Consolas', 'Monaco', monospace;
    font-size: 0.72rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 200px;
}

.tool-call .tool-status {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    min-width: 70px;
    justify-content: flex-end;
    flex-shrink: 0;
}

.tool-call .tool-status .duration {
    font-size: 0.7rem;
    color: #666;
    font-family: 'SF Mono', 'Consolas', 'Monaco', monospace;
}

.tool-call .tool-status .checkmark {
    color: var(--sparrow-green, #c4ff61);
    font-weight: bold;
    font-size: 0.9rem;
}

.tool-call .tool-status .error-icon {
    color: #dc3545;
    font-weight: bold;
}

.tool-call .spinner-border-sm {
    width: 0.85rem;
    height: 0.85rem;
    border-width: 0.15rem;
    color: #ffc107;
}

/* Generating Answer Indicator */
.generating-indicator {
    display: flex;
    align-items: center;
    padding: 0.5rem;
    margin-top: 0.5rem;
    color: #666;
}

.generating-indicator .typing-dots {
    display: flex;
    gap: 3px;
}

.generating-indicator .typing-dots span {
    width: 6px;
    height: 6px;
    background: var(--sparrow-green, #c4ff61);
    border-radius: 50%;
    animation: dexterPulse 1.4s infinite ease-in-out both;
}

.generating-indicator .typing-dots span:nth-child(1) {
    animation-delay: -0.32s;
}

.generating-indicator .typing-dots span:nth-child(2) {
    animation-delay: -0.16s;
}

@keyframes dexterPulse {
    0%, 80%, 100% {
        transform: scale(0.6);
        opacity: 0.5;
    }
    40% {
        transform: scale(1);
        opacity: 1;
    }
}

/* Dexter Badge/Indicator */
.dexter-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.65rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 0.15rem 0.4rem;
    border-radius: 3px;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
}

/* Chat Header with Toggle */
.chat-header-with-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.chat-header-with-toggle .chat-title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}