/* Custom styles */
.card {
  transition: transform 0.2s;
}

.card:hover {
  transform: translateY(-2px);
}

.list-group-item {
  transition: background-color 0.2s;
}

.list-group-item:hover {
  background-color: var(--bs-secondary-bg);
}

.list-group-item i {
  margin-right: 8px;
}

/* Dark mode adjustments */
[data-bs-theme="dark"] {
  --bs-body-bg: #1a1d20;
  --bs-body-color: #e9ecef;
  --bs-table-hover-bg: rgba(255, 255, 255, 0.05);
  --bs-table-bg: #1a1d20;
  --bs-table-border-color: #2c3034;
}

/* Choices.js Dark Mode Overrides */
[data-bs-theme="dark"] .choices__list--dropdown,
[data-bs-theme="dark"] .choices__list[aria-expanded] {
  background-color: var(--bs-tertiary-bg, #2b3035); /* Use tertiary or a fallback */
  border-color: var(--bs-border-color);
  color: var(--bs-body-color);
}

[data-bs-theme="dark"] .choices__item--choice {
  color: var(--bs-body-color);
}

/* Replace the previous choices__input rule with these more specific ones */
[data-bs-theme="dark"] .choices__inner .choices__input {
  background-color: var(--bs-body-bg);
  color: var(--bs-body-color);
  border: none;
}
[data-bs-theme="dark"] .choices__list--dropdown .choices__input {
  background-color: var(--bs-body-bg);
  color: var(--bs-body-color);
}

[data-bs-theme="dark"] .choices__list--dropdown .choices__item--choice.is-highlighted {
  background-color: var(--bs-primary-bg-subtle, rgba(var(--bs-primary-rgb), 0.2)); /* Subtle highlight */
  color: var(--bs-primary-text-emphasis, var(--bs-primary)); /* Highlight text color */
}

/* Style the main choices container */
[data-bs-theme="dark"] .choices[data-type*="select-one"] .choices__inner {
  background-color: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color);
  color: var(--bs-body-color);
}

/* Style the selected item text color */
[data-bs-theme="dark"] .choices__list--single .choices__item {
  color: var(--bs-body-color);
}

/* Remove focus outline which might look odd in dark mode */
[data-bs-theme="dark"] .choices__inner:focus,
[data-bs-theme="dark"] .choices__input:focus {
  outline: none;
  box-shadow: none;
}

/* Adjust dropdown icon color */
[data-bs-theme="dark"] .choices[data-type*="select-one"]::after {
  border-color: var(--bs-body-color) transparent transparent;
}

/* Light mode base colors */
:root {
  --bs-table-hover-bg: rgba(0, 0, 0, 0.02);
  --bs-table-bg: #ffffff;
}

/* Date Range Picker Styles */
.daterangepicker {
  background-color: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color);
  color: var(--bs-body-color);
  font-family: inherit;
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

.daterangepicker .calendar-table {
  background-color: var(--bs-body-bg);
  border: none;
}

.daterangepicker .calendar-table th, 
.daterangepicker .calendar-table td {
  color: var(--bs-body-color);
}

.daterangepicker td.off, 
.daterangepicker td.off.in-range, 
.daterangepicker td.off.start-date, 
.daterangepicker td.off.end-date {
  background-color: transparent;
  color: var(--bs-secondary-color);
}

.daterangepicker td.available:hover, 
.daterangepicker th.available:hover {
  background-color: var(--bs-table-hover-bg);
}

.daterangepicker td.active, 
.daterangepicker td.active:hover {
  background-color: var(--bs-primary);
  color: #fff;
}

.daterangepicker td.in-range {
  background-color: var(--bs-primary-bg-subtle);
  color: var(--bs-body-color);
}

.daterangepicker .ranges li {
  color: var(--bs-body-color);
  padding: 0.5rem 1rem;
}

.daterangepicker .ranges li:hover,
.daterangepicker .ranges li.active {
  background-color: var(--bs-primary);
  color: #fff;
}

.daterangepicker:after {
  border-bottom-color: var(--bs-body-bg);
}

.daterangepicker:before {
  border-bottom-color: var(--bs-border-color);
}

.daterangepicker .drp-buttons {
  border-top: 1px solid var(--bs-border-color);
}

.daterangepicker select.monthselect, 
.daterangepicker select.yearselect {
  background-color: var(--bs-body-bg);
  color: var(--bs-body-color);
  border: 1px solid var(--bs-border-color);
  border-radius: 4px;
  padding: 2px 5px;
  cursor: pointer;
}

.daterangepicker select.monthselect option,
.daterangepicker select.yearselect option {
  background-color: var(--bs-body-bg);
  color: var(--bs-body-color);
  cursor: pointer;
}

/* Dark mode overrides for Date Range Picker */
[data-bs-theme="dark"] .daterangepicker {
  background-color: #1a1d20;
  border-color: #2c3034;
}

[data-bs-theme="dark"] .daterangepicker .calendar-table {
  background-color: #1a1d20;
  border-color: #2c3034;
}

[data-bs-theme="dark"] .daterangepicker td.off,
[data-bs-theme="dark"] .daterangepicker td.off.in-range,
[data-bs-theme="dark"] .daterangepicker td.off.start-date,
[data-bs-theme="dark"] .daterangepicker td.off.end-date {
  background-color: transparent;
  color: #6c757d;
}

[data-bs-theme="dark"] .daterangepicker td.available:hover,
[data-bs-theme="dark"] .daterangepicker th.available:hover {
  background-color: rgba(255, 255, 255, 0.1);
}

[data-bs-theme="dark"] .daterangepicker .calendar-table .next span, 
[data-bs-theme="dark"] .daterangepicker .calendar-table .prev span {
  border-color: #e9ecef;
}

[data-bs-theme="dark"] .daterangepicker select.monthselect,
[data-bs-theme="dark"] .daterangepicker select.yearselect {
  background-color: #1a1d20;
  color: #e9ecef;
  border-color: #2c3034;
}

[data-bs-theme="dark"] .daterangepicker select.monthselect option,
[data-bs-theme="dark"] .daterangepicker select.yearselect option {
  background-color: #1a1d20;
  color: #e9ecef;
}

[data-bs-theme="dark"] .daterangepicker select.monthselect:hover,
[data-bs-theme="dark"] .daterangepicker select.yearselect:hover {
  background-color: #2c3034;
}


/* Table Styles */
.table {
  --bs-table-color: var(--bs-body-color);
  --bs-table-bg: var(--bs-table-bg);
  --bs-table-border-color: var(--bs-border-color);
  margin-bottom: 0;
}

.table > :not(caption) > * > * {
  padding: 1rem;
}

.table tbody tr {
  transition: all 0.2s ease;
}

.table tbody tr.expanded {
  background-color: var(--bs-table-hover-bg);
}

.table tbody tr:hover {
  background-color: var(--bs-table-hover-bg);
}

/* Card Styles */
.card {
  background-color: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color);
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

.card-body {
  padding: 1.5rem;
}

/* Form Controls */
.form-control {
  background-color: var(--bs-body-bg);
  border-color: var(--bs-border-color);
  color: var(--bs-body-color);
}

.form-control:focus {
  background-color: var(--bs-body-bg);
  border-color: var(--bs-primary);
  color: var(--bs-body-color);
}

/* Custom Status Colors */
.sentiment-positive { color: var(--bs-success); }
.sentiment-negative { color: var(--bs-danger); }
.sentiment-neutral { color: var(--bs-secondary); }

/* Modal Styles */
.modal-content {
  background-color: var(--bs-body-bg);
  border-color: var(--bs-border-color);
}

.modal-header {
  border-bottom-color: var(--bs-border-color);
}

.modal-footer {
  border-top-color: var(--bs-border-color);
}

/* Expanded Row Details */
.call-details {
  background-color: var(--bs-table-bg);
}

.call-details .card {
  background-color: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color);
}

/* Audio Player Styling */
audio {
  width: 100%;
  margin: 0.5rem 0;
  border-radius: 0.375rem;
}

/* Customize Fields Button */
#customizeFields {
  margin-top: 0.5rem;
  border-color: var(--bs-border-color);
  color: var(--bs-body-color);
}

#customizeFields:hover {
  background-color: var(--bs-secondary-bg);
}

/* Form Check in Modal */
.form-check {
  padding: 0.75rem 1.75rem;
  margin: 0;
  border-bottom: 1px solid var(--bs-border-color);
}

.form-check:last-child {
  border-bottom: none;
}

.form-check-input:checked {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
}

/* Responsive Table */
.table-responsive {
  border-radius: 0.375rem;
  border: 1px solid var(--bs-border-color);
}

/* Dashboard Enhancements */
.dashboard-wrapper {
  background: linear-gradient(180deg, var(--bs-body-bg) 0%, rgba(var(--bs-primary-rgb, 52 97 248), 0.05) 100%);
  min-height: 100vh;
}

.dashboard-hero {
  background: transparent;
  color: var(--bs-body-color);
  border-radius: 1.5rem;
  box-shadow: inset 0 0 0 1px rgba(var(--bs-primary-rgb, 52 97 248), 0.08);
}

.dashboard-hero .card-body {
  padding: 2.5rem;
}

.hero-gradient {
  background: radial-gradient(circle at top right, rgba(var(--bs-primary-rgb, 52 97 248), 0.35), transparent 55%),
              radial-gradient(circle at bottom left, rgba(var(--bs-success-rgb, 29 191 115), 0.25), transparent 45%);
  filter: blur(0px);
  opacity: 0.85;
}

.hero-kpi {
  background: rgba(var(--bs-body-bg-rgb, 255 255 255), 0.2);
  backdrop-filter: blur(12px);
  border-radius: 1rem;
  padding: 1rem 1.5rem;
  min-width: 140px;
  border: 1px solid rgba(var(--bs-border-color-rgb, 0 0 0), 0.1);
}

[data-bs-theme="dark"] .hero-kpi {
  background: rgba(21, 25, 29, 0.6);
  border-color: rgba(255, 255, 255, 0.08);
}

.hero-kpi .label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--bs-secondary-color);
  margin-bottom: 0.25rem;
}

.hero-kpi .value {
  font-size: 1.75rem;
  font-weight: 600;
}

.dashboard-section {
  padding: 0.5rem 0;
}

.section-title {
  font-weight: 600;
  font-size: 1.5rem;
  margin-bottom: 0.25rem;
}

.section-subtitle {
  margin-bottom: 0;
  color: var(--bs-secondary-color);
}

.metric-card {
  border-radius: 1rem;
  box-shadow: 0 18px 45px -25px rgba(15, 23, 42, 0.35);
  border: 1px solid rgba(var(--bs-border-color-rgb, 0 0 0), 0.12);
}

[data-bs-theme="dark"] .metric-card {
  box-shadow: 0 18px 45px -25px rgba(0, 0, 0, 0.65);
  border-color: rgba(255, 255, 255, 0.08);
}

.metric-card .card-body {
  padding: 1.5rem;
}

.metric-label {
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  color: var(--bs-secondary-color);
  margin-bottom: 0.5rem;
}

.metric-value {
  font-size: 2rem;
  font-weight: 600;
  margin-bottom: 0.35rem;
}

.metric-caption {
  font-size: 0.9rem;
}

.metric-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
}

.list-item-workspace {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--bs-border-color);
}

.list-item-workspace:last-child {
  border-bottom: none;
}

.timeline {
  margin: 0;
  padding: 0;
}

.timeline li {
  position: relative;
  padding-left: 1.75rem;
  margin-bottom: 1.25rem;
}

.timeline li:last-child {
  margin-bottom: 0;
}

.timeline-marker {
  position: absolute;
  left: 0;
  top: 0.35rem;
  width: 0.75rem;
  height: 0.75rem;
  background: var(--bs-primary);
  border-radius: 50%;
  box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb, 52 97 248), 0.2);
}

.timeline-content small {
  display: block;
}

.finance-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 1rem;
}

.finance-summary .label {
  font-size: 0.85rem;
  text-transform: uppercase;
  color: var(--bs-secondary-color);
  letter-spacing: 0.08em;
  margin-bottom: 0.25rem;
}

.finance-summary .value {
  font-size: 1.35rem;
  font-weight: 600;
  margin: 0;
}

.table thead th {
  background: rgba(var(--bs-primary-rgb, 52 97 248), 0.04);
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  font-weight: 600;
  color: var(--bs-secondary-color);
}

.table tbody tr:hover {
  background-color: rgba(var(--bs-primary-rgb, 52 97 248), 0.05);
}

[data-bs-theme="dark"] .table tbody tr:hover {
  background-color: rgba(79, 140, 255, 0.08);
}

.table code {
  background: rgba(var(--bs-secondary-rgb, 108 117 125), 0.08);
  padding: 0.125rem 0.35rem;
  border-radius: 0.25rem;
  font-size: 0.85rem;
}

.chart-wrapper {
  position: relative;
  width: 100%;
  height: clamp(140px, 20vh, 210px);
  max-height: 210px;
}

.chart-wrapper-sm {
  height: clamp(130px, 18vh, 190px);
  max-height: 190px;
}

.chart-wrapper-md {
  height: clamp(150px, 20vh, 210px);
  max-height: 210px;
}

.chart-wrapper-lg {
  height: clamp(160px, 22vh, 230px);
  max-height: 230px;
}

.chart-wrapper canvas {
  width: 100% !important;
  height: 100% !important;
}

@media (max-width: 991.98px) {
  .dashboard-hero .card-body {
    padding: 2rem;
  }

  .hero-kpi {
    min-width: 120px;
  }

  .metric-value {
    font-size: 1.65rem;
  }

  .chart-wrapper {
    height: clamp(150px, 26vh, 220px);
  }
}

@media (max-width: 575.98px) {
  .dashboard-wrapper {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .dashboard-hero .card-body {
    padding: 1.75rem;
  }

  .chart-wrapper-lg {
    height: clamp(170px, 30vh, 220px);
  }
}
