[data-theme="dark"] .progress-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

/* Utility: chips, dots, tints, legend */
.chip { display:inline-flex; align-items:center; gap:6px; padding:2px 10px; border-radius:999px; font-size:12px; font-weight:600; line-height:1.4; }
.chip--allowed { background:#28a745; color:#ffffff; }
.chip--excluded { background:#ff6b6b; color:#ffffff; }
.chip--review { background:#e9ecef; color:#495057; }
.chip--logic-ok { display: inline-block; }
.chip--logic-issue { display: inline-block; }
.chip--neutral { background:#e9ecef; color:#495057; }
.dot { width:8px; height:8px; border-radius:50%; display:inline-block; }
.dot--logic-ok { width: 8px; height: 8px; }
.dot--logic-issue { width: 8px; height: 8px; }
.row-tint--excluded { background: rgba(220,53,69,0.06); }
.row-tint--logic { background: transparent; }
.legend { display:flex; align-items:center; gap:8px 12px; flex-wrap:wrap; }
.legend .chip { padding:2px 8px; font-weight:600; }
[data-theme="dark"] .chip--allowed { background: #28a745; color:#ffffff; }
[data-theme="dark"] .chip--excluded { background: #ff6b6b; color:#ffffff; }
[data-theme="dark"] .chip--review { background: rgba(173,181,189,.15); color:#ced4da; }

/* Themed Pause/Stop button tweaks */
.processing-controls .btn { border-radius: 8px; padding: 6px 10px; font-size: 0.875rem; }
.processing-controls #pauseBatchBtn,
.processing-controls #pauseSingleBtn { background-color: #ffe8a1; border-color: #ffdf7e; color: #7a5a00; }
.processing-controls #pauseBatchBtn:hover,
.processing-controls #pauseSingleBtn:hover { background-color: #ffd66b; border-color: #ffcc4d; color: #5c4400; }
.processing-controls #stopBatchBtn,
.processing-controls #stopSingleBtn { background-color: #f8c6c6; border-color: #f3a5a5; color: #7a1f1f; }
.processing-controls #stopBatchBtn:hover,
.processing-controls #stopSingleBtn:hover { background-color: #f3a5a5; border-color: #ed8686; color: #5a1515; }

[data-theme="dark"] .processing-controls #pauseBatchBtn,
[data-theme="dark"] .processing-controls #pauseSingleBtn { background-color: rgba(255, 200, 0, 0.25); border-color: rgba(255, 200, 0, 0.35); color: #ffd36e; }
[data-theme="dark"] .processing-controls #pauseBatchBtn:hover,
[data-theme="dark"] .processing-controls #pauseSingleBtn:hover { background-color: rgba(255, 200, 0, 0.35); }
[data-theme="dark"] .processing-controls #stopBatchBtn,
[data-theme="dark"] .processing-controls #stopSingleBtn { background-color: rgba(255, 80, 80, 0.25); border-color: rgba(255, 80, 80, 0.35); color: #ff9999; }
[data-theme="dark"] .processing-controls #stopBatchBtn:hover,
[data-theme="dark"] .processing-controls #stopSingleBtn:hover { background-color: rgba(255, 80, 80, 0.35); }
[data-theme="dark"] .chip--allowed { background: #28a745; color:#ffffff; }
[data-theme="dark"] .chip--excluded { background: #ff6b6b; color:#ffffff; }
[data-theme="dark"] .chip--review { background: rgba(173,181,189,.15); color:#ced4da; }
[data-theme="dark"] .chip--logic-ok { opacity: 0.9; }
[data-theme="dark"] .chip--logic-issue { opacity: 0.9; }
[data-theme="dark"] .chip--neutral { background: rgba(233,236,239,.15); color:#adb5bd; }
/* InsurAgent Custom Styles */

:root {
  --primary-color: #4361ee;
  --secondary-color: #3a0ca3;
  --success-color: #4cc9f0;
  --danger-color: #f72585;
  --warning-color: #ffd166;
  --light-gray: #f8f9fa;
  --dark-gray: #343a40;
  --sidebar-bg: #ffffff;
  --sidebar-active: #eef2ff;
  --text-primary: #1a1a1a;
  --text-secondary: #6c757d;
  --border-color: #e9ecef;
  --bg-primary: #f5f7fb;
  --bg-secondary: #ffffff;
  --card-bg: #ffffff;
}

/* Dark mode variables */
[data-theme="dark"] {
  --primary-color: #5b7cff;
  --secondary-color: #4c6ef5;
  --success-color: #51cf66;
  --danger-color: #ff6b6b;
  --warning-color: #ffd43b;
  --light-gray: #2d3748;
  --dark-gray: #1a202c;
  --sidebar-bg: #1a202c;
  --sidebar-active: #2d3748;
  --text-primary: #f7fafc;
  --text-secondary: #a0aec0;
  --border-color: #4a5568;
  --bg-primary: #1a202c;
  --bg-secondary: #2d3748;
  --card-bg: #2d3748;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  background-color: var(--bg-primary);
  color: var(--text-primary);
  transition: background-color 0.3s ease, color 0.3s ease;
}

/* Login layout improvements */
html, body {
  height: 100%;
}

/* When login is visible, prevent page scroll and lock viewport */
body.login-mode {
  overflow: hidden;
  height: 100vh;
}

#loginContainer {
  min-height: 100vh !important;
  overflow: hidden; /* prevent page scroll on small variations */
}

.login-left {
  background: linear-gradient(135deg, #ffffff 0%, #f6f9ff 100%);
}

.login-right img {
  object-fit: cover;
}

/* Lift the login card slightly upward for better visual balance */
.login-card {
  margin-top: -3vh; /* subtle lift on most screens */
}

@media (max-height: 750px) {
  /* On shorter screens, lift a bit more */
  .login-card {
    margin-top: -6vh;
  }
}

/* Brand coloring for login heading */
.login-brand {
  font-weight: 700;
}
.login-brand .brand-dark {
  color: #2c3e50; /* dark slate like in app sidebar title */
}
.login-brand .brand-accent {
  background: linear-gradient(135deg, #4361ee, #4c79f0);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

@media (max-width: 991.98px) {
  /* Ensure full-viewport fit on laptops and smaller screens */
  #loginContainer .row {
    min-height: 100vh;
  }
  .login-left {
    padding: 2rem !important;
  }
}

/* App Layout */
.app-container {
  display: flex;
  min-height: 100vh;
}

/* Sidebar Styles */
.sidebar {
  width: 250px;
  background-color: var(--sidebar-bg);
  border-right: 1px solid var(--border-color);
  padding: 1.5rem 1rem;
  position: fixed;
  height: 100vh;            /* full height */
  display: flex;            /* flex column layout */
  flex-direction: column;
}

.sidebar-header {
  padding: 0 0.5rem;
  margin-bottom: 2rem;
}

.sidebar-header-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.sidebar-back-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background-color: transparent;
  border: none;
  border-radius: 6px;
  color: #64748b;
  cursor: pointer;
  transition: all 0.3s ease;
  font-size: 1rem;
  flex-shrink: 0;
}

.sidebar-back-btn:hover {
  background-color: #f1f5f9;
  opacity: 0.8;
  color: #475569;
}

.sidebar-back-btn:active {
  background-color: #e2e8f0;
  opacity: 0.9;
}

.logo {
  font-size: 1.5rem;
  font-weight: 600;
  color: #2c3e50;
  margin: 0;
}

.logo span {
  color: var(--primary-color);
}

.sidebar-menu { display: flex; flex-direction: column; gap: 0.5rem; }
.sidebar-nav { flex: 1 1 auto; overflow-y: auto; padding: 0; }
.sidebar-footer { border-top: 1px solid var(--border-color); padding-top: 0.75rem; }

/* Push specific section to bottom */
/* Revert sidebar items to original continuous list */
.sidebar-menu { position: static; padding-bottom: 0; }
.sidebar-bottom { position: static; left: auto; right: auto; bottom: auto; padding: 0; display: block; }
.sidebar-bottom .sidebar-divider { margin: 1rem 0; }
.sidebar-bottom .menu-item + .menu-item { margin-top: 0; }

.menu-item {
  display: flex;
  align-items: center;
  padding: 0.75rem 1rem;
  color: #64748b;
  text-decoration: none;
  transition: all 0.3s ease;
  border-radius: 8px;
}

.menu-item:hover {
  background-color: rgba(67, 97, 238, 0.1);
  color: var(--primary-color);
}

.menu-item.active {
  background-color: var(--primary-color);
  color: white;
}

.menu-item i {
  margin-right: 1rem;
  font-size: 1.25rem;
}

.sidebar-divider {
  height: 1px;
  background-color: var(--border-color);
  margin: 1rem 0;
}

/* Claims Page Styles */
.claims-page {
  padding: 2rem;
  background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
  min-height: 100vh;
}

.claims-header {
  margin-bottom: 2rem;
}

.claims-title {
  font-size: 2rem;
  font-weight: 600;
  color: #1a202c;
  margin: 0 0 1.5rem 0;
}

.claims-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}

.search-input-container {
  position: relative;
  flex: 1;
  max-width: 320px;
}

.search-icon {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: #94a3b8;
  font-size: 1rem;
}

.search-input {
  width: 100%;
  padding: 0.75rem 1rem 0.75rem 2.5rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  font-size: 0.875rem;
  color: #334155;
  background-color: white;
  transition: all 0.2s ease;
}

.search-input:focus {
  outline: none;
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(67, 97, 238, 0.1);
}

.filter-dropdowns {
  display: flex;
  gap: 0.75rem;
}

.dropdown-container {
  position: relative;
}

.filter-dropdown {
  appearance: none;
  padding: 0.75rem 2.5rem 0.75rem 1rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  font-size: 0.875rem;
  color: #64748b;
  background-color: white;
  cursor: pointer;
  transition: all 0.2s ease;
  min-width: 120px;
}

.filter-dropdown:focus {
  outline: none;
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(67, 97, 238, 0.1);
}

.dropdown-chevron {
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  color: #94a3b8;
  font-size: 0.75rem;
  pointer-events: none;
}

.claims-table-container {
  background-color: var(--card-bg);
  border-radius: 0.75rem;
  border: 1px solid var(--border-color);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  transition: background-color 0.3s ease, border-color 0.3s ease;
}

.claims-table-header {
  display: grid;
  grid-template-columns: 2fr 1.5fr 1fr 1fr 1.5fr 1fr;
  gap: 1rem;
  padding: 1rem 1.5rem;
  background-color: var(--light-gray);
  transition: background-color 0.3s ease;
  border-bottom: 1px solid var(--border-color);
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.025em;
}

.claims-table-body {
  display: flex;
  flex-direction: column;
}

.claim-row {
  display: grid;
  grid-template-columns: 2fr 1.5fr 1fr 1fr 1.5fr 1fr;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid #f1f5f9;
  transition: all 0.2s ease;
  cursor: default;
}

.claim-row:last-child {
  border-bottom: none;
}

.claim-row.clickable {
  cursor: pointer;
}

.claim-row.clickable:hover {
  background-color: #f8fafc;
}

.claim-row:hover .actions-cell {
  opacity: 1;
  visibility: visible;
}

.claim-id-cell {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.claim-icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: #f1f5f9;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.claim-icon i {
  color: #64748b;
  font-size: 1.125rem;
}

.claim-details {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.patient-name {
  font-weight: 600;
  color: #1e293b;
  font-size: 0.875rem;
}

.claim-number {
  font-size: 0.75rem;
  color: #64748b;
}

.department-cell,
.insurance-cell {
  display: flex;
  align-items: center;
  font-size: 0.875rem;
  color: #475569;
}

.mode-cell {
  display: flex;
  align-items: center;
  font-size: 0.875rem;
  color: #475569;
}

.approval-cell {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  opacity: 1;
  visibility: visible;
}

.approval-percentage {
  font-size: 0.875rem;
  color: #475569;
  font-weight: 600;
  min-width: 40px;
}

.approval-bar {
  width: 112px;
  height: 8px;
  background-color: #f1f5f9;
  border-radius: 9999px;
  overflow: hidden;
}

.approval-bar-fill {
  height: 100%;
  background-color: #10b981;
  border-radius: 9999px;
  transition: width 0.3s ease;
}

.actions-cell {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  opacity: 1;
  visibility: visible;
}

.actions-cell .action-btn {
  width: 32px;
  height: 32px;
  border: none;
  background-color: #f8fafc;
  border-radius: 0.375rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s ease;
  color: #64748b;
  border: 1px solid #e2e8f0;
  padding: 0;
  min-width: auto;
  font-weight: normal;
  font-size: 0.875rem;
}

.actions-cell .action-btn:hover {
  background-color: #e2e8f0;
  color: #475569;
  border-color: #cbd5e1;
  transform: none;
  box-shadow: none;
}

.actions-cell .action-btn i {
  font-size: 1rem;
}

/* Responsive adjustments */
@media (max-width: 1024px) {
  .claims-controls {
    flex-direction: column;
    align-items: stretch;
    gap: 1rem;
  }
  
  .search-input-container {
    max-width: none;
  }
  
  .filter-dropdowns {
    justify-content: flex-start;
  }
}

@media (max-width: 768px) {
  .claims-page {
    padding: 1rem;
  }
  
  .claims-table-header,
  .claim-row {
    grid-template-columns: 1fr;
    gap: 0.5rem;
  }
  
  .claims-table-header {
    display: none;
  }
  
  .claim-row {
    display: block;
    padding: 1rem;
  }
  
  .claim-row > div {
    margin-bottom: 0.5rem;
  }
}

/* Claim Detail Page Styles */
.claim-detail-header {
  background: linear-gradient(135deg, #FAFBFC 0%, #F1F5F9 100%);
  padding: 1.5rem 2rem;
  border-bottom: 1px solid #e2e8f0;
  margin-bottom: 2rem;
}

.breadcrumb-section {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.back-arrow-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--border-color);
  background: var(--card-bg);
  border-radius: 0.5rem;
  cursor: pointer;
  transition: all 0.2s ease;
  color: var(--text-secondary);
  font-size: 1.3rem;
  font-weight: 600;
}

.back-arrow-btn i {
  color: var(--primary-color);
}

.back-arrow-btn:hover {
  background: var(--light-gray);
  color: var(--text-primary);
  border-color: var(--primary-color);
  transform: translateX(-2px);
}

.back-arrow-btn:active {
  transform: translateX(-1px);
}

.breadcrumb {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
}

.breadcrumb-item {
  color: #64748b;
}

.breadcrumb-item.current {
  color: #1e293b;
  font-weight: 600;
}

.breadcrumb-separator {
  color: #cbd5e1;
}

.claim-detail-tabs {
  display: flex;
  gap: 2rem;
  border-bottom: 1px solid #e2e8f0;
}

.tab-btn {
  padding: 0.75rem 0;
  border: none;
  background: none;
  color: #64748b;
  font-weight: 500;
  cursor: default;
  border-bottom: 2px solid transparent;
  transition: all 0.2s ease;
  font-size: 0.9rem;
}

.tab-btn.active {
  color: #3b82f6;
  border-bottom-color: #3b82f6;
  font-weight: 600;
}

.claim-detail-content {
  padding: 0 2rem;
}

/* Claim Details Pills */
.claim-details-pills {
  display: flex;
  gap: 1rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
}

.claim-pill {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: 1rem;
  background: white;
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  min-width: 140px;
}

.pill-label {
  font-size: 0.75rem;
  color: #64748b;
  font-weight: 500;
}

.pill-value {
  font-size: 0.875rem;
  color: #1e293b;
  font-weight: 600;
}

.status-pill .pill-value {
  padding: 0.25rem 0.75rem;
  border-radius: 1rem;
  font-size: 0.75rem;
  font-weight: 500;
  background: #fef3c7;
  color: #92400e;
}

/* Info Pills Row */
.info-pills-row {
  display: flex;
  gap: 1rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
}

.info-pill {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem;
  background: white;
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  flex: 1;
  min-width: 200px;
}

.info-pill-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  background: #f1f5f9;
  border-radius: 50%;
  color: #64748b;
}

.info-pill-content {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.info-pill-label {
  font-size: 0.75rem;
  color: #64748b;
  font-weight: 500;
}

.info-pill-value {
  font-size: 0.875rem;
  color: #1e293b;
  font-weight: 600;
}

.info-pill-value.link {
  color: #3b82f6;
  cursor: pointer;
}

/* Quick Actions */
.quick-actions-section {
  margin-bottom: 2rem;
}

.quick-actions-title {
  font-size: 1.125rem;
  font-weight: 700;
  color: #1e293b;
  margin-bottom: 1rem;
}

.quick-actions-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}

.quick-action-card {
  background: white;
  border: 1px solid #e2e8f0;
  border-radius: 1rem;
  overflow: hidden;
}

.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.5rem 1.5rem 1rem;
}

.card-title-section {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.card-title {
  font-size: 1rem;
  font-weight: 700;
  color: #1e293b;
  margin: 0;
}

.issue-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  background: #ef4444;
  color: white;
  border-radius: 50%;
  font-size: 0.75rem;
  font-weight: 600;
}

.why-chip {
  padding: 0.25rem 0.75rem;
  background: #f1f5f9;
  border: 1px solid #e2e8f0;
  border-radius: 1rem;
  font-size: 0.75rem;
  color: #64748b;
  cursor: pointer;
}

.generate-new-btn {
  padding: 0.5rem 1rem;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  font-size: 0.875rem;
  color: #64748b;
  cursor: pointer;
  font-weight: 500;
}

.card-body {
  padding: 0 1.5rem 1.5rem;
}

.issue-content {
  color: #64748b;
  font-size: 0.875rem;
  margin-bottom: 1rem;
  line-height: 1.5;
}

.issue-title {
  font-weight: 600;
  color: #1e293b;
  margin-bottom: 0.5rem;
}

.issue-description {
  color: #64748b;
  margin-bottom: 1rem;
}

.policy-exclusion-item {
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 0.5rem;
  padding: 0.75rem;
  margin-bottom: 0.5rem;
}

.exclusion-header {
  font-weight: 500;
  color: #dc2626;
  margin-bottom: 0.25rem;
}

.exclusion-reason {
  color: #7f1d1d;
  font-size: 0.875rem;
}

.edit-btn {
  padding: 0.5rem 1rem;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  font-size: 0.875rem;
  color: #64748b;
  cursor: pointer;
}

.recommendations-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}

.recommendation-item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.recommendation-checkbox {
  margin-top: 0.125rem;
}

.recommendation-text {
  font-size: 0.875rem;
  color: #374151;
  line-height: 1.5;
}

.no-recommendations {
  color: #9ca3af;
  font-style: italic;
  text-align: center;
  padding: 1rem;
}

.card-actions {
  display: flex;
  gap: 0.75rem;
  padding: 0 1.5rem 1.5rem;
}

.btn {
  padding: 0.75rem 1.5rem;
  border-radius: 0.5rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  flex: 1;
  border: none;
  font-size: 0.875rem;
}

.btn-primary {
  background: #4F46E5;
  color: white;
  border: 1px solid #4F46E5;
}

.btn-primary:hover {
  background: #4338CA;
}

.btn-secondary {
  background: #6B7280;
  color: white;
  border: 1px solid #6B7280;
}

.btn-secondary:hover {
  background: #5B6371;
}

/* Responsive adjustments for claim detail */
@media (max-width: 1024px) {
  .quick-actions-cards {
    grid-template-columns: 1fr;
  }
  
  .claim-details-pills,
  .info-pills-row {
    flex-direction: column;
  }
  
  .claim-pill,
  .info-pill {
    min-width: auto;
  }
}

@media (max-width: 768px) {
  .claim-detail-header {
    padding: 1rem;
  }
  
  .claim-detail-content {
    padding: 0 1rem;
  }
  
  .claim-detail-tabs {
    overflow-x: auto;
    gap: 1rem;
  }
  
  .tab-btn {
    white-space: nowrap;
  }
}

/* Finance Page Styles */
.finance-page {
  padding: 0;
  background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
  min-height: 100vh;
}

.finance-header {
  background: #FAFBFC;
  padding: 1.5rem 2rem;
  border-bottom: 1px solid #e2e8f0;
  margin-bottom: 2rem;
}

.finance-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: #1e293b;
  margin: 0;
}

.finance-tabs {
  display: flex;
  gap: 2rem;
  border-bottom: 1px solid #e2e8f0;
  margin-top: 1.5rem;
}

.finance-content {
  padding: 0 2rem;
  max-width: 1400px;
  margin: 0 auto;
}

.finance-section {
  margin-bottom: 2rem;
}

.section-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: #374151;
  margin-bottom: 1rem;
  background: #f1f5f9;
  padding: 0.75rem 1rem;
  border-radius: 0.5rem;
  border-left: 4px solid #3b82f6;
}

/* Financial Overview Grid */
.finance-overview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.finance-card {
  background: white;
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  padding: 1rem;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
  transition: all 0.2s ease;
}

.finance-card:hover {
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  transform: translateY(-1px);
}

.card-label {
  font-size: 0.875rem;
  color: #64748b;
  font-weight: 500;
  margin-bottom: 0.5rem;
  line-height: 1.4;
}

.card-value {
  font-size: 1.5rem;
  font-weight: 700;
  color: #1e293b;
  line-height: 1.2;
}

/* Pending Payout Grid */
.payout-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.payout-card {
  min-height: 120px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Quick Actions Grid */
.quick-actions-grid {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.action-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem 1.5rem;
  border: none;
  border-radius: 0.75rem;
  font-weight: 600;
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.2s ease;
  color: white;
  min-width: 180px;
  justify-content: center;
}

.action-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

.btn-reports {
  background: #16A34A;
  border: 1px solid #16A34A;
}

.btn-reports:hover {
  background: #15803D;
}

.btn-payouts {
  background: #DC2626;
  border: 1px solid #DC2626;
}

.btn-payouts:hover {
  background: #B91C1C;
}

.btn-investigate {
  background: #2563EB;
  border: 1px solid #2563EB;
}

.btn-investigate:hover {
  background: #1D4ED8;
}

.action-btn i {
  font-size: 1rem;
}

/* Responsive adjustments for Finance page */
@media (max-width: 1024px) {
  .finance-overview-grid {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  }
  
  .payout-grid {
    grid-template-columns: 1fr;
  }
  
  .quick-actions-grid {
    flex-direction: column;
  }
  
  .action-btn {
    min-width: auto;
  }
}

@media (max-width: 768px) {
  .finance-header {
    padding: 1rem;
  }
  
  .finance-content {
    padding: 0 1rem;
  }
  
  .finance-tabs {
    overflow-x: auto;
    gap: 1rem;
  }
  
  .tab-btn {
    white-space: nowrap;
  }
  
  .finance-overview-grid {
    grid-template-columns: 1fr;
  }
  
  .card-value {
    font-size: 1.5rem;
  }
}

/* Main Content Area */
.main-content {
  flex: 1;
  margin-left: 250px;
  background-color: var(--bg-primary);
  min-height: 100vh;
  transition: background-color 0.3s ease;
}

/* Top Navigation */
.top-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 2rem;
  background-color: var(--bg-secondary);
  border-bottom: 1px solid var(--border-color);
  transition: background-color 0.3s ease;
}

.menu-toggle {
  display: none;
  font-size: 1.5rem;
  cursor: pointer;
  color: var(--text-secondary);
}

/* Theme Toggle Button */
.theme-toggle {
  margin-right: 1rem;
}

.theme-toggle-btn {
  background: none;
  border: none;
  font-size: 1.2rem;
  cursor: pointer;
  color: var(--text-secondary);
  transition: all 0.3s ease;
  padding: 0.5rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
}

.theme-toggle-btn:hover {
  background-color: var(--light-gray);
  color: var(--primary-color);
}

[data-theme="dark"] .theme-toggle-btn {
  color: var(--text-primary);
}

[data-theme="dark"] .theme-toggle-btn:hover {
  background-color: var(--border-color);
}

/* Dark mode form elements */
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
  background-color: var(--card-bg);
  border-color: var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
  background-color: var(--card-bg);
  border-color: var(--primary-color);
  color: var(--text-primary);
}

/* Dark mode buttons */
[data-theme="dark"] .btn-outline-secondary {
  border-color: var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .btn-outline-secondary:hover {
  background-color: var(--border-color);
  border-color: var(--border-color);
  color: var(--text-primary);
}

/* Comprehensive dark mode button fixes */
[data-theme="dark"] .btn-primary {
  background: linear-gradient(135deg, var(--primary-color), #4c79f0);
  color: white;
  border-color: var(--primary-color);
}

[data-theme="dark"] .btn-primary:hover {
  background: linear-gradient(135deg, #3d5bd6, #4266e0);
  color: white;
}

[data-theme="dark"] .btn-secondary {
  background-color: var(--text-secondary);
  color: white;
  border-color: var(--text-secondary);
}

[data-theme="dark"] .btn-secondary:hover {
  background-color: var(--text-primary);
  color: white;
}

[data-theme="dark"] .btn-outline-primary {
  border-color: var(--primary-color);
  color: var(--primary-color);
  background: transparent;
}

[data-theme="dark"] .btn-outline-primary:hover {
  background-color: var(--primary-color);
  color: white;
}

[data-theme="dark"] .action-btn {
  background-color: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .action-btn:hover {
  background-color: var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .btn-reports {
  background: #16A34A;
  color: white;
  border-color: #16A34A;
}

[data-theme="dark"] .btn-reports:hover {
  background: #15803D;
  color: white;
}

[data-theme="dark"] .btn-payouts {
  background: #DC2626;
  color: white;
  border-color: #DC2626;
}

[data-theme="dark"] .btn-payouts:hover {
  background: #B91C1C;
  color: white;
}

[data-theme="dark"] .btn-investigate {
  background: #2563EB;
  color: white;
  border-color: #2563EB;
}

[data-theme="dark"] .btn-investigate:hover {
  background: #1D4ED8;
  color: white;
}

[data-theme="dark"] .upload-btn {
  background-color: var(--primary-color);
  color: white;
  border-color: var(--primary-color);
}

[data-theme="dark"] .upload-btn:hover {
  background-color: #3651d4;
  color: white;
}

[data-theme="dark"] .btn-filter {
  background-color: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .btn-filter:hover {
  border-color: var(--primary-color);
  color: var(--primary-color);
}

[data-theme="dark"] .btn-action {
  background-color: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .btn-action.view {
  background-color: rgba(67, 97, 238, 0.2);
  color: var(--primary-color);
}

[data-theme="dark"] .btn-action.edit {
  background-color: rgba(76, 201, 240, 0.2);
  color: var(--success-color);
}

[data-theme="dark"] .btn-more {
  background-color: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .btn-more:hover {
  background-color: var(--border-color);
  color: var(--text-primary);
}

/* Dark mode modals */
[data-theme="dark"] .modal-content {
  background-color: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .modal-header {
  border-bottom-color: var(--border-color);
}

[data-theme="dark"] .modal-footer {
  border-top-color: var(--border-color);
}

/* Dark mode cards */
[data-theme="dark"] .upload-method-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .upload-method-card:hover {
  border-color: rgba(67, 97, 238, 0.3);
}

[data-theme="dark"] .config-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .config-card h4 {
  color: var(--text-primary);
}

[data-theme="dark"] .progress-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .preview-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .sample-case-card {
  background: var(--light-gray);
  border-color: var(--border-color);
}

[data-theme="dark"] .sample-case-card:hover {
  border-color: var(--primary-color);
}

[data-theme="dark"] .recommendation-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .recommendation-card .card-header {
  background: linear-gradient(135deg, var(--light-gray) 0%, var(--border-color) 100%);
  border-bottom-color: var(--border-color);
}

[data-theme="dark"] .recommendation-card .card-title {
  color: var(--text-primary);
}

[data-theme="dark"] .card-title {
  color: var(--text-primary);
}

[data-theme="dark"] .card-label {
  color: var(--text-secondary);
}

[data-theme="dark"] .card-value {
  color: var(--text-primary);
}

/* Dark mode finance cards */
[data-theme="dark"] .finance-card {
  background: var(--card-bg) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .finance-card .card-label {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .finance-card .card-value {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .payout-card {
  background: var(--card-bg) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .payout-card .card-label {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .payout-card .card-value {
  color: var(--text-primary) !important;
}

/* Dark mode quick action cards */
[data-theme="dark"] .quick-action-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .quick-action-card .card-title {
  color: var(--text-primary);
}

/* Dark mode visual cards */
[data-theme="dark"] .visual-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .visual-card .visual-header h3 {
  color: var(--text-primary);
}

/* Dark mode upload area */
[data-theme="dark"] .upload-area {
  background: var(--light-gray);
  border-color: var(--border-color);
}

[data-theme="dark"] .upload-area:hover {
  border-color: var(--primary-color);
}

/* Dark mode sample cases section */
[data-theme="dark"] .sample-cases-compact-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .sample-file-info {
  color: var(--text-primary);
}

[data-theme="dark"] .sample-cases-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .sample-cases-card h4 {
  color: var(--text-primary);
}

/* Dark mode results section */
[data-theme="dark"] .results-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

/* Dark mode patient details */
[data-theme="dark"] .patient-details-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .patient-details-header h2 {
  color: var(--text-primary);
}

/* Dark mode claim detail cards */
[data-theme="dark"] .claim-details-pills {
  background: var(--light-gray);
  border-color: var(--border-color);
}

[data-theme="dark"] .claim-pill {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .claim-pill .pill-label {
  color: var(--text-secondary);
}

[data-theme="dark"] .claim-pill .pill-value {
  color: var(--text-primary);
}

[data-theme="dark"] .info-pill {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .info-pill .info-pill-label {
  color: var(--text-secondary);
}

[data-theme="dark"] .info-pill .info-pill-value {
  color: var(--text-primary);
}

/* Additional dark mode fixes for remaining white backgrounds */
[data-theme="dark"] .upload-section {
  background-color: var(--card-bg);
}

[data-theme="dark"] .claims-section {
  background-color: var(--card-bg);
}

[data-theme="dark"] .visual-card {
  background-color: var(--card-bg);
}

[data-theme="dark"] .patient-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .patient-header {
  color: var(--text-primary);
}

[data-theme="dark"] .patient-info h5 {
  color: var(--text-primary);
}

[data-theme="dark"] .patient-info .patient-id {
  color: var(--text-secondary);
}

[data-theme="dark"] .status-badge.allowed {
  background-color: rgba(40, 167, 69, 0.2);
  color: var(--success-color);
  border-color: var(--success-color);
}

[data-theme="dark"] .status-badge.excluded {
  background-color: rgba(220, 53, 69, 0.2);
  color: var(--danger-color);
  border-color: var(--danger-color);
}

[data-theme="dark"] .status-badge.error {
  background-color: rgba(255, 193, 7, 0.2);
  color: var(--warning-color);
  border-color: var(--warning-color);
}

[data-theme="dark"] .status-badge.unknown {
  background-color: rgba(108, 117, 125, 0.2);
  color: var(--text-secondary);
  border-color: var(--border-color);
}

/* Dark mode patient details section */
[data-theme="dark"] .patient-details {
  color: var(--text-primary);
}

[data-theme="dark"] .patient-details h6 {
  color: var(--text-primary);
}

[data-theme="dark"] .patient-details p {
  color: var(--text-secondary);
}

[data-theme="dark"] .patient-details .submitted-details {
  color: var(--text-secondary);
}

/* Dark mode coverage status */
[data-theme="dark"] .coverage-status {
  color: var(--text-primary);
}

[data-theme="dark"] .coverage-status h6 {
  color: var(--text-primary);
}

[data-theme="dark"] .coverage-status p {
  color: var(--text-secondary);
}

/* Dark mode results grid */
[data-theme="dark"] .results-grid {
  background-color: var(--bg-primary);
}

/* Dark mode patient info section */
[data-theme="dark"] .patient-info-section {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .patient-info-section h2 {
  color: var(--text-primary);
}

/* Dark mode patient details header */
[data-theme="dark"] .patient-details-header {
  background: var(--card-bg) !important;
  border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .patient-details-header h2 {
  color: var(--text-primary) !important;
}

/* Comprehensive dark mode fixes for all remaining components */

/* Dark mode login page */
[data-theme="dark"] .login-left {
  background: linear-gradient(135deg, var(--card-bg) 0%, var(--light-gray) 100%);
}

[data-theme="dark"] .login-brand .brand-dark {
  color: var(--text-primary);
}

/* Dark mode claims page */
[data-theme="dark"] .claims-page {
  background: linear-gradient(135deg, var(--bg-primary) 0%, var(--light-gray) 100%);
}

/* Dark mode claim detail header */
[data-theme="dark"] .claim-detail-header {
  background: linear-gradient(135deg, var(--card-bg) 0%, var(--light-gray) 100%);
  border-bottom-color: var(--border-color);
}

/* Dark mode finance page */
[data-theme="dark"] .finance-page {
  background: linear-gradient(135deg, var(--bg-primary) 0%, var(--light-gray) 100%);
}

[data-theme="dark"] .finance-header {
  background: var(--card-bg);
  border-bottom-color: var(--border-color);
}

/* Dark mode section titles */
[data-theme="dark"] .section-title {
  background: var(--light-gray);
  border-left-color: var(--primary-color);
}

/* Dark mode approval bars */
[data-theme="dark"] .approval-bar {
  background-color: var(--light-gray);
}

[data-theme="dark"] .approval-bar-fill {
  background-color: var(--success-color);
}

/* Dark mode claim rows */
[data-theme="dark"] .claim-row {
  border-bottom-color: var(--border-color);
}

[data-theme="dark"] .claim-row.clickable:hover {
  background-color: var(--light-gray);
}

/* Dark mode claim icons */
[data-theme="dark"] .claim-icon {
  background-color: var(--light-gray);
}

/* Dark mode action buttons */
[data-theme="dark"] .actions-cell .action-btn {
  background-color: var(--light-gray);
  border-color: var(--border-color);
}

[data-theme="dark"] .actions-cell .action-btn:hover {
  background-color: var(--border-color);
  border-color: var(--border-color);
}

/* Dark mode back arrow button */
[data-theme="dark"] .back-arrow-btn {
  background: var(--card-bg) !important;
  border-color: var(--border-color) !important;
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .back-arrow-btn i {
  color: var(--primary-color) !important;
}

[data-theme="dark"] .back-arrow-btn:hover {
  background: var(--light-gray) !important;
  color: var(--text-primary) !important;
  border-color: var(--primary-color) !important;
}

[data-theme="dark"] .back-arrow-btn:hover i {
  color: var(--primary-color) !important;
}

/* Dark mode tabs */
[data-theme="dark"] .claim-detail-tabs {
  border-bottom-color: var(--border-color);
}

/* Dark mode pills */
[data-theme="dark"] .claim-pill {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .status-pill {
  background: rgba(255, 193, 7, 0.2);
  color: var(--warning-color);
}

/* Dark mode info pills */
[data-theme="dark"] .info-pill {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .info-pill-icon {
  background: var(--light-gray);
}

/* Dark mode quick action cards */
[data-theme="dark"] .quick-action-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

/* Dark mode issue badges */
[data-theme="dark"] .issue-badge {
  background: var(--danger-color);
}

/* Dark mode why chip */
[data-theme="dark"] .why-chip {
  background: var(--light-gray);
  border-color: var(--border-color);
}

/* Dark mode generate new button */
[data-theme="dark"] .generate-new-btn {
  background: var(--light-gray);
  border-color: var(--border-color);
}

/* Dark mode policy exclusion items */
[data-theme="dark"] .policy-exclusion-item {
  background: rgba(220, 53, 69, 0.1);
  border-color: var(--danger-color);
}

/* Dark mode edit button */
[data-theme="dark"] .edit-btn {
  background: var(--light-gray);
  border-color: var(--border-color);
}

/* Dark mode apply button */
[data-theme="dark"] .apply-btn {
  background: var(--light-gray);
  border-color: var(--border-color);
}

/* Dark mode finance tabs */
[data-theme="dark"] .finance-tabs {
  border-bottom-color: var(--border-color);
}

[data-theme="dark"] .finance-tabs .tab-btn {
  color: var(--text-secondary);
  background: none;
}

[data-theme="dark"] .finance-tabs .tab-btn.active {
  color: var(--primary-color);
  border-bottom-color: var(--primary-color);
  background: none;
}

[data-theme="dark"] .finance-tabs .tab-btn:hover {
  color: var(--text-primary);
  background: none;
}

/* Dark mode finance overview grid */
[data-theme="dark"] .finance-overview-grid {
  background-color: var(--bg-primary);
}

/* Dark mode payout grid */
[data-theme="dark"] .payout-grid {
  background-color: var(--bg-primary);
}

/* Dark mode quick actions grid */
[data-theme="dark"] .quick-actions-grid {
  background-color: var(--bg-primary);
}

/* Dark mode action buttons in finance */
[data-theme="dark"] .action-btn {
  background-color: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .action-btn:hover {
  background-color: var(--light-gray);
}

/* Dark mode search containers */
[data-theme="dark"] .search-input-container {
  background-color: var(--light-gray);
}

/* Dark mode filter dropdowns */
[data-theme="dark"] .filter-dropdowns {
  background-color: var(--bg-primary);
}

/* Dark mode dropdown containers */
[data-theme="dark"] .dropdown-container {
  background-color: var(--card-bg);
}

/* Dark mode search boxes */
[data-theme="dark"] .search-box {
  background-color: var(--card-bg);
  border-color: var(--border-color);
}

/* Dark mode choose file */
[data-theme="dark"] .choose-file {
  background-color: var(--light-gray);
  border-color: var(--border-color);
}

/* Dark mode file status */
[data-theme="dark"] .file-status {
  color: var(--text-secondary);
}

/* Dark mode upload container */
[data-theme="dark"] .upload-container {
  background-color: var(--card-bg);
  border-color: var(--border-color);
}

/* Dark mode visual cards */
[data-theme="dark"] .visual-card {
  background-color: var(--card-bg);
  border-color: var(--border-color);
}

/* Dark mode visual header */
[data-theme="dark"] .visual-header {
  background-color: var(--light-gray);
  border-bottom-color: var(--border-color);
}

/* Dark mode btn more */
[data-theme="dark"] .btn-more {
  background-color: var(--light-gray);
  border-color: var(--border-color);
}

[data-theme="dark"] .btn-more:hover {
  background-color: var(--border-color);
}

/* Dark mode chart placeholder */
[data-theme="dark"] .chart-placeholder {
  background-color: var(--light-gray);
  color: var(--text-secondary);
}

/* Dark mode metrics visuals section */
[data-theme="dark"] .metrics-visuals-section {
  background-color: var(--bg-primary);
}

/* Dark mode search filter */
[data-theme="dark"] .search-filter {
  background-color: var(--bg-primary);
}

/* Dark mode user menu elements */
[data-theme="dark"] .user-menu {
  background-color: var(--bg-primary);
}

[data-theme="dark"] .notification {
  background-color: var(--light-gray);
}

[data-theme="dark"] .language-selector {
  background-color: var(--light-gray);
}

[data-theme="dark"] .language-selector:hover {
  background-color: var(--border-color);
}

[data-theme="dark"] .user-profile {
  background-color: var(--light-gray);
}

[data-theme="dark"] .user-profile:hover {
  background-color: var(--border-color);
}

/* Dark mode profile image */
[data-theme="dark"] .profile-image {
  border-color: var(--border-color);
}

/* Dark mode flag icon */
[data-theme="dark"] .flag-icon {
  border-color: var(--border-color);
}

/* Dark mode notification badge */
[data-theme="dark"] .notification .badge {
  background-color: var(--danger-color);
  color: white;
}

/* Dark mode demo page specific */
[data-theme="dark"] .demo-header {
  background-color: var(--bg-primary);
}

[data-theme="dark"] .demo-title-section {
  background-color: var(--bg-primary);
}

/* Dark mode upload methods section */
[data-theme="dark"] .upload-methods-section {
  background-color: var(--bg-primary);
}

/* Dark mode sample cases section */
[data-theme="dark"] .sample-cases-section {
  background-color: var(--bg-primary);
}

/* Dark mode config section */
[data-theme="dark"] .config-section {
  background-color: var(--bg-primary);
}

/* Dark mode progress section */
[data-theme="dark"] .progress-section {
  background-color: var(--bg-primary);
}

/* Dark mode preview section */
[data-theme="dark"] .preview-section {
  background-color: var(--bg-primary);
}

/* Dark mode results section */
[data-theme="dark"] .results-section {
  background-color: var(--bg-primary);
}

/* Dark mode patient details section */
[data-theme="dark"] .patient-details-section {
  background-color: var(--bg-primary);
}

/* Dark mode clinical table */
[data-theme="dark"] .clinical-table {
  background-color: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .clinical-table th {
  background-color: var(--light-gray);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .clinical-table td {
  background-color: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--border-color);
}

/* Dark mode medical logic section */
[data-theme="dark"] .medical-logic-section {
  background: var(--card-bg);
  border-color: var(--border-color);
}

/* Dark mode excluded recommendations section */
[data-theme="dark"] .excluded-recommendations-section {
  background-color: var(--light-gray);
  border-color: var(--warning-color);
}

/* Dark mode excluded field card */
[data-theme="dark"] .excluded-field-card {
  background-color: var(--card-bg);
  border-left-color: var(--danger-color);
}

/* Dark mode unified recommendations section */
[data-theme="dark"] .unified-recommendations-section {
  background: linear-gradient(135deg, var(--light-gray) 0%, var(--card-bg) 100%);
  border-color: var(--border-color);
}

/* Dark mode recommendation card */
[data-theme="dark"] .recommendation-card {
  background: var(--card-bg);
  border-color: var(--border-color);
}

/* Dark mode recommendation card header */
[data-theme="dark"] .recommendation-card .card-header {
  background: linear-gradient(135deg, var(--light-gray) 0%, var(--border-color) 100%);
  border-bottom-color: var(--border-color);
}

/* Dark mode recommendation card body */
[data-theme="dark"] .recommendation-card .card-body {
  background-color: var(--card-bg);
}

/* Dark mode recommendation card actions */
[data-theme="dark"] .recommendation-card .card-actions {
  background-color: var(--card-bg);
  border-top-color: var(--border-color);
}

/* Dark mode sample case header */
[data-theme="dark"] .sample-case-header {
  background-color: var(--light-gray);
  border-bottom-color: var(--border-color);
}

/* Dark mode sample case content */
[data-theme="dark"] .sample-case-content {
  background-color: var(--card-bg);
}

/* Dark mode sample case card */
[data-theme="dark"] .sample-case-card {
  background: var(--light-gray);
  border-color: var(--border-color);
}

[data-theme="dark"] .sample-case-card:hover {
  border-color: var(--primary-color);
}

/* Dark mode login form elements */
[data-theme="dark"] .login-card {
  background-color: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .login-card .form-control {
  background-color: var(--light-gray);
  border-color: var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .login-card .form-control:focus {
  background-color: var(--light-gray);
  border-color: var(--primary-color);
  color: var(--text-primary);
}

[data-theme="dark"] .login-card .form-label {
  color: var(--text-primary);
}

[data-theme="dark"] .login-card .form-check-label {
  color: var(--text-primary);
}

[data-theme="dark"] .login-card .text-muted {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .login-card .text-decoration-underline {
  color: var(--primary-color);
}

/* Dark mode login error */
[data-theme="dark"] .login-card .text-danger {
  color: var(--danger-color) !important;
}

[data-theme="dark"] .clinical-table-container {
  background: var(--card-bg);
}

/* Additional dark mode text fixes for all remaining elements */

/* Dark mode breadcrumb elements */
[data-theme="dark"] .breadcrumb-item {
  color: var(--text-secondary);
}

[data-theme="dark"] .breadcrumb-item.current {
  color: var(--text-primary);
}

[data-theme="dark"] .breadcrumb-separator {
  color: var(--border-color);
}

/* Dark mode tab buttons */
[data-theme="dark"] .tab-btn {
  color: var(--text-secondary);
}

[data-theme="dark"] .tab-btn.active {
  color: var(--primary-color);
  border-bottom-color: var(--primary-color);
}

/* Dark mode pill labels and values */
[data-theme="dark"] .pill-label {
  color: var(--text-secondary);
}

[data-theme="dark"] .pill-value {
  color: var(--text-primary);
}

[data-theme="dark"] .info-pill-label {
  color: var(--text-secondary);
}

[data-theme="dark"] .info-pill-value {
  color: var(--text-primary);
}

[data-theme="dark"] .info-pill-value.link {
  color: var(--primary-color);
}

/* Dark mode quick actions title */
[data-theme="dark"] .quick-actions-title {
  color: var(--text-primary);
}

/* Dark mode card titles */
[data-theme="dark"] .card-title {
  color: var(--text-primary);
}

/* Dark mode issue content */
[data-theme="dark"] .issue-content {
  color: var(--text-secondary);
}

[data-theme="dark"] .issue-title {
  color: var(--text-primary);
}

[data-theme="dark"] .issue-description {
  color: var(--text-secondary);
}

/* Dark mode exclusion elements */
[data-theme="dark"] .exclusion-header {
  color: var(--danger-color);
}

[data-theme="dark"] .exclusion-reason {
  color: var(--text-secondary);
}

/* Dark mode recommendation text */
[data-theme="dark"] .recommendation-text {
  color: var(--text-primary);
}

[data-theme="dark"] .no-recommendations {
  color: var(--text-secondary);
}

/* Dark mode finance title */
[data-theme="dark"] .finance-title {
  color: var(--text-primary);
}

/* Dark mode section titles */
[data-theme="dark"] .section-title {
  color: var(--text-primary);
}

/* Dark mode card labels and values */
[data-theme="dark"] .card-label {
  color: var(--text-secondary);
}

[data-theme="dark"] .card-value {
  color: var(--text-primary);
}

/* Dark mode claim icon */
[data-theme="dark"] .claim-icon i {
  color: var(--text-secondary);
}

/* Dark mode department and mode cells */
[data-theme="dark"] .department-cell {
  color: var(--text-primary);
}

[data-theme="dark"] .mode-cell {
  color: var(--text-primary);
}

/* Dark mode approval percentage */
[data-theme="dark"] .approval-percentage {
  color: var(--text-primary);
}

/* Dark mode actions cell */
[data-theme="dark"] .actions-cell .action-btn {
  color: var(--text-secondary);
}

[data-theme="dark"] .actions-cell .action-btn:hover {
  color: var(--text-primary);
}

/* Dark mode back arrow button */
[data-theme="dark"] .back-arrow-btn {
  color: var(--text-secondary);
}

[data-theme="dark"] .back-arrow-btn:hover {
  color: var(--text-primary);
}

/* Dark mode why chip */
[data-theme="dark"] .why-chip {
  color: var(--text-secondary);
}

/* Dark mode generate new button */
[data-theme="dark"] .generate-new-btn {
  color: var(--text-secondary);
}

/* Dark mode edit button */
[data-theme="dark"] .edit-btn {
  color: var(--text-secondary);
}

/* Dark mode apply button */
[data-theme="dark"] .apply-btn {
  color: var(--text-secondary);
}

/* Dark mode choose file */
[data-theme="dark"] .choose-file span {
  color: var(--text-primary);
}

/* Dark mode file status */
[data-theme="dark"] .file-status {
  color: var(--text-secondary);
}

/* Dark mode upload area */
[data-theme="dark"] .upload-area {
  background-color: var(--light-gray);
  border-color: var(--border-color);
}

[data-theme="dark"] .upload-area h4 {
  color: var(--text-primary);
}

/* Dark mode upload content */
[data-theme="dark"] .upload-content {
  color: var(--text-primary);
}

/* Dark mode manual entry section */
[data-theme="dark"] .manual-entry-section {
  background-color: var(--card-bg);
  border-color: var(--border-color);
}

/* Dark mode sample case content */
[data-theme="dark"] .sample-case-content {
  color: var(--text-primary);
}

/* Dark mode config section */
[data-theme="dark"] .config-section {
  color: var(--text-primary);
}

/* Dark mode progress section */
[data-theme="dark"] .progress-section {
  color: var(--text-primary);
}

/* Dark mode preview section */
[data-theme="dark"] .preview-section {
  color: var(--text-primary);
}

/* Dark mode results section */
[data-theme="dark"] .results-section {
  color: var(--text-primary);
}

/* Dark mode patient details section */
[data-theme="dark"] .patient-details-section {
  color: var(--text-primary);
}

/* Dark mode claims page */
[data-theme="dark"] .claims-page {
  color: var(--text-primary);
}

[data-theme="dark"] .claims-header {
  color: var(--text-primary);
}

[data-theme="dark"] .claims-title {
  color: var(--text-primary);
}

[data-theme="dark"] .claims-controls {
  color: var(--text-primary);
}

/* Dark mode pending page */
[data-theme="dark"] .pending-page {
  color: var(--text-primary);
}

/* Dark mode finance page */
[data-theme="dark"] .finance-page {
  color: var(--text-primary);
}

[data-theme="dark"] .finance-header {
  color: var(--text-primary);
}

[data-theme="dark"] .finance-content {
  color: var(--text-primary);
}

[data-theme="dark"] .finance-section {
  color: var(--text-primary);
}

/* Dark mode dashboard page */
[data-theme="dark"] .dashboard-page {
  color: var(--text-primary);
}

[data-theme="dark"] .metrics-container {
  color: var(--text-primary);
}

[data-theme="dark"] .metrics-visuals-section {
  color: var(--text-primary);
}

[data-theme="dark"] .metrics-visuals-section h2 {
  color: var(--text-primary);
}

/* Dark mode metric cards */
[data-theme="dark"] .metric-card {
  background-color: var(--card-bg) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .metric-card .metric-info h3 {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .metric-card .metric-value {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .metric-card .metric-icon {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .visual-header h3 {
  color: var(--text-primary);
}

/* Dark mode upload container */
[data-theme="dark"] .upload-container {
  color: var(--text-primary);
}

/* Dark mode section headers */
[data-theme="dark"] .section-header h2 {
  color: var(--text-primary);
}

[data-theme="dark"] .section-header p {
  color: var(--text-secondary);
}

/* Dark mode demo title section */
[data-theme="dark"] .demo-title-section h1 {
  color: var(--text-primary);
}

[data-theme="dark"] .demo-subtitle {
  color: var(--text-secondary);
}

/* Dark mode upload card header */
[data-theme="dark"] .upload-card-header h3 {
  color: var(--text-primary);
}

[data-theme="dark"] .upload-card-header p {
  color: var(--text-secondary);
}

/* Dark mode upload text */
[data-theme="dark"] .upload-text h4 {
  color: var(--text-primary);
}

[data-theme="dark"] .upload-text p {
  color: var(--text-secondary);
}

[data-theme="dark"] .upload-text .browse-link {
  color: var(--primary-color);
}

/* Dark mode feature items */
[data-theme="dark"] .feature-item span {
  color: var(--text-primary);
}

/* Dark mode form labels */
[data-theme="dark"] .form-label {
  color: var(--text-primary);
}

/* Dark mode sample cases card */
[data-theme="dark"] .sample-cases-card h4 {
  color: var(--text-primary);
}

[data-theme="dark"] .sample-cases-card p {
  color: var(--text-secondary);
}

/* Dark mode config card */
[data-theme="dark"] .config-card h4 {
  color: var(--text-primary);
}

/* Dark mode progress header */
[data-theme="dark"] .progress-header h4 {
  color: var(--text-primary);
}

[data-theme="dark"] .progress-text {
  color: var(--text-primary);
}

[data-theme="dark"] .progress-details small {
  color: var(--text-secondary);
}

/* Dark mode preview header */
[data-theme="dark"] .preview-header h4 {
  color: var(--text-primary);
}

/* Dark mode results header */
[data-theme="dark"] .results-header h3 {
  color: var(--text-primary);
}

/* Dark mode table headers and cells */
[data-theme="dark"] .table th {
  color: var(--text-primary);
}

[data-theme="dark"] .table td {
  color: var(--text-primary);
}

/* Dark mode notification badge */
[data-theme="dark"] .notification .badge {
  color: white;
}

/* Dark mode user name and role */
[data-theme="dark"] .user-name {
  color: var(--text-primary);
}

[data-theme="dark"] .user-role {
  color: var(--text-secondary);
}

/* Dark mode language selector */
[data-theme="dark"] .language-selector span {
  color: var(--text-primary);
}

/* Dark mode search container */
[data-theme="dark"] .search-container i {
  color: var(--text-secondary);
}

/* Dark mode chart placeholder */
[data-theme="dark"] .chart-placeholder {
  color: var(--text-secondary);
}

/* Dark mode metric icon */
[data-theme="dark"] .metric-icon {
  color: var(--text-secondary);
}

/* Dark mode breadcrumb separator */
[data-theme="dark"] .breadcrumb-separator {
  color: var(--border-color);
}

/* Dark mode small text and muted text */
[data-theme="dark"] small {
  color: var(--text-secondary);
}

[data-theme="dark"] .text-muted {
  color: var(--text-secondary) !important;
}

/* Dark mode links */
[data-theme="dark"] a {
  color: var(--primary-color);
}

/* Dark mode headings */
[data-theme="dark"] h1, [data-theme="dark"] h2, [data-theme="dark"] h3, 
[data-theme="dark"] h4, [data-theme="dark"] h5, [data-theme="dark"] h6 {
  color: var(--text-primary);
}

/* Dark mode paragraphs */
[data-theme="dark"] p {
  color: var(--text-primary);
}

/* Dark mode spans */
[data-theme="dark"] span {
  color: var(--text-primary);
}

/* Dark mode divs */
[data-theme="dark"] div {
  color: var(--text-primary);
}

/* Dark mode list items */
[data-theme="dark"] li {
  color: var(--text-primary);
}

/* Dark mode labels */
[data-theme="dark"] label {
  color: var(--text-primary);
}

[data-theme="dark"] .medical-logic-section {
  background: var(--card-bg);
}

/* Dark mode page titles and headers - Additional fixes */
[data-theme="dark"] .finance-title {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .claims-title {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .page-title {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .header-title {
  color: var(--text-primary) !important;
}

/* Dark mode breadcrumb section */
[data-theme="dark"] .breadcrumb-section {
  color: var(--text-primary);
}

/* Dark mode page headers */
[data-theme="dark"] .page-header {
  background: var(--card-bg);
  border-bottom-color: var(--border-color);
}

[data-theme="dark"] .page-header h1 {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .page-header h2 {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .page-header h3 {
  color: var(--text-primary) !important;
}

/* Additional comprehensive dark mode fixes for all remaining white backgrounds */

/* Dark mode upload section */
[data-theme="dark"] .upload-section {
  background-color: var(--card-bg) !important;
}

/* Dark mode claims section */
[data-theme="dark"] .claims-section {
  background-color: var(--card-bg) !important;
}

/* Dark mode visual card */
[data-theme="dark"] .visual-card {
  background-color: var(--card-bg) !important;
}

/* Dark mode upload method card */
[data-theme="dark"] .upload-method-card {
  background: var(--card-bg) !important;
}

/* Dark mode config card */
[data-theme="dark"] .config-card {
  background: var(--card-bg) !important;
}

/* Dark mode progress card */
[data-theme="dark"] .progress-card {
  background: var(--card-bg) !important;
}

/* Dark mode preview card */
[data-theme="dark"] .preview-card {
  background: var(--card-bg) !important;
}

/* Dark mode patient card */
[data-theme="dark"] .patient-card {
  background: var(--card-bg) !important;
}

/* Dark mode clinical table container */
[data-theme="dark"] .clinical-table-container {
  background: var(--card-bg) !important;
}

/* Dark mode medical logic section */
[data-theme="dark"] .medical-logic-section {
  background: var(--card-bg) !important;
}

/* Dark mode excluded recommendations section */
[data-theme="dark"] .excluded-recommendations-section {
  background-color: rgba(255, 193, 7, 0.1) !important;
}

/* Dark mode excluded field card */
[data-theme="dark"] .excluded-field-card {
  background-color: var(--card-bg) !important;
}

/* Dark mode unified recommendations section */
[data-theme="dark"] .unified-recommendations-section {
  background: linear-gradient(135deg, var(--light-gray) 0%, var(--card-bg) 100%) !important;
}

/* Dark mode recommendation card */
[data-theme="dark"] .recommendation-card {
  background: var(--card-bg) !important;
}

/* Dark mode sample cases card */
[data-theme="dark"] .sample-cases-card {
  background: var(--card-bg) !important;
}

/* Dark mode status badges */
[data-theme="dark"] .status-badge.error {
  background: rgba(255, 193, 7, 0.2) !important;
  color: var(--warning-color) !important;
}

[data-theme="dark"] .status-badge.unknown {
  background-color: rgba(255, 193, 7, 0.2) !important;
  color: var(--warning-color) !important;
  border-color: var(--warning-color) !important;
}

/* Dark mode clinical row excluded */
[data-theme="dark"] .clinical-row.excluded {
  background-color: rgba(220, 53, 69, 0.1) !important;
}

/* Dark mode tab buttons */
[data-theme="dark"] .tab-btn {
  background: var(--card-bg) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .tab-btn.active {
  background: var(--primary-color) !important;
  color: white !important;
  border-color: var(--primary-color) !important;
}

/* Dark mode search inputs */
[data-theme="dark"] .search-input {
  background-color: var(--card-bg) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

/* Dark mode filter dropdowns */
[data-theme="dark"] .filter-dropdown {
  background-color: var(--card-bg) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

/* Dark mode pill elements */
[data-theme="dark"] .claim-pill {
  background: var(--card-bg) !important;
  border-color: var(--border-color) !important;
}

/* Dark mode info pill */
[data-theme="dark"] .info-pill {
  background: var(--card-bg) !important;
  border-color: var(--border-color) !important;
}

/* Dark mode quick action card */
[data-theme="dark"] .quick-action-card {
  background: var(--card-bg) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .excluded-recommendations-section {
  background-color: var(--light-gray);
  border-color: var(--warning-color);
}

[data-theme="dark"] .excluded-field-card {
  background-color: var(--card-bg);
}

[data-theme="dark"] .unified-recommendations-section {
  background: linear-gradient(135deg, var(--light-gray) 0%, var(--card-bg) 100%);
  border-color: var(--border-color);
}

[data-theme="dark"] .recommendation-card {
  background: var(--card-bg);
}

[data-theme="dark"] .sample-cases-card {
  background: var(--card-bg);
}

/* Dark mode status badges */
[data-theme="dark"] .status-badge.error {
  background: rgba(255, 193, 7, 0.2);
  color: var(--warning-color);
}

[data-theme="dark"] .status-badge.unknown {
  background-color: rgba(255, 193, 7, 0.2);
  color: var(--warning-color);
  border-color: var(--warning-color);
}

/* Dark mode clinical rows */
[data-theme="dark"] .clinical-row.excluded {
  background-color: rgba(220, 53, 69, 0.1);
}

/* Dark mode dropdown and select elements */
[data-theme="dark"] .dropdown-container select,
[data-theme="dark"] .filter-dropdown {
  background-color: var(--card-bg);
  border-color: var(--border-color);
  color: var(--text-primary);
}

/* Dark mode search boxes */
[data-theme="dark"] .search-box {
  background-color: var(--card-bg);
  border-color: var(--border-color);
}

/* Dark mode pills and badges */
[data-theme="dark"] .claim-pill.status-pill {
  background: var(--card-bg);
  border-color: var(--border-color);
}

/* Dark mode table headers */
[data-theme="dark"] .table-light {
  background-color: var(--light-gray);
  color: var(--text-primary);
}

/* Dark mode progress bars */
[data-theme="dark"] .progress {
  background-color: var(--border-color);
}

/* Dark mode alerts */
[data-theme="dark"] .alert {
  background-color: var(--light-gray);
  border-color: var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .alert-info {
  background-color: rgba(13, 202, 240, 0.1);
  border-color: var(--success-color);
  color: var(--text-primary);
}

/* Comprehensive dark mode text fixes */
[data-theme="dark"] .sidebar-back-btn {
  color: var(--text-secondary);
}

[data-theme="dark"] .sidebar-back-btn:hover {
  color: var(--text-primary);
}

[data-theme="dark"] .menu-item {
  color: var(--text-secondary);
}

[data-theme="dark"] .claims-title {
  color: var(--text-primary);
}

[data-theme="dark"] .patient-name {
  color: var(--text-primary);
}

[data-theme="dark"] .claim-number {
  color: var(--text-secondary);
}

[data-theme="dark"] .department-cell,
[data-theme="dark"] .mode-cell {
  color: var(--text-secondary);
}

[data-theme="dark"] .approval-percentage {
  color: var(--text-secondary);
}

[data-theme="dark"] .actions-cell .action-btn {
  color: var(--text-secondary);
}

[data-theme="dark"] .actions-cell .action-btn:hover {
  color: var(--text-primary);
}

[data-theme="dark"] .back-arrow-btn {
  color: var(--text-secondary);
}

[data-theme="dark"] .back-arrow-btn:hover {
  color: var(--text-primary);
}

[data-theme="dark"] .breadcrumb-item {
  color: var(--text-secondary);
}

[data-theme="dark"] .breadcrumb-item.current {
  color: var(--text-primary);
}

[data-theme="dark"] .tab-btn {
  color: var(--text-secondary);
}

[data-theme="dark"] .tab-btn.active {
  color: var(--primary-color);
}

[data-theme="dark"] .pill-label {
  color: var(--text-secondary);
}

[data-theme="dark"] .pill-value {
  color: var(--text-primary);
}

[data-theme="dark"] .info-pill-icon {
  color: var(--text-secondary);
}

[data-theme="dark"] .info-pill-label {
  color: var(--text-secondary);
}

[data-theme="dark"] .info-pill-value {
  color: var(--text-primary);
}

[data-theme="dark"] .info-pill-value.link {
  color: var(--primary-color);
}

[data-theme="dark"] .quick-actions-title {
  color: var(--text-primary);
}

[data-theme="dark"] .card-title {
  color: var(--text-primary);
}

[data-theme="dark"] .why-chip {
  color: var(--text-secondary);
}

[data-theme="dark"] .edit-btn {
  color: var(--text-secondary);
}

[data-theme="dark"] .issue-content {
  color: var(--text-secondary);
}

[data-theme="dark"] .issue-title {
  color: var(--text-primary);
}

[data-theme="dark"] .issue-description {
  color: var(--text-secondary);
}

[data-theme="dark"] .exclusion-header {
  color: var(--danger-color);
}

[data-theme="dark"] .exclusion-reason {
  color: var(--danger-color);
}

[data-theme="dark"] .apply-btn {
  color: var(--text-secondary);
}

[data-theme="dark"] .recommendation-text {
  color: var(--text-primary);
}

[data-theme="dark"] .no-recommendations {
  color: var(--text-secondary);
}

[data-theme="dark"] .finance-title {
  color: var(--text-primary);
}

[data-theme="dark"] .section-title {
  color: var(--text-primary);
}

[data-theme="dark"] .card-label {
  color: var(--text-secondary);
}

[data-theme="dark"] .card-value {
  color: var(--text-primary);
}

[data-theme="dark"] .claim-icon i {
  color: var(--text-secondary);
}

/* Dark mode form elements text */
[data-theme="dark"] .form-control::placeholder,
[data-theme="dark"] .form-select::placeholder {
  color: var(--text-secondary);
}

[data-theme="dark"] .search-input::placeholder {
  color: var(--text-secondary);
}

/* Dark mode demo page specific fixes */
[data-theme="dark"] .demo-title-section h1 {
  color: var(--text-primary);
}

[data-theme="dark"] .demo-subtitle {
  color: var(--text-secondary);
}

[data-theme="dark"] .upload-card-header h3 {
  color: var(--text-primary);
}

[data-theme="dark"] .upload-card-header p {
  color: var(--text-secondary);
}

[data-theme="dark"] .upload-text h4 {
  color: var(--text-primary);
}

[data-theme="dark"] .upload-text p {
  color: var(--text-secondary);
}

[data-theme="dark"] .upload-text .browse-link {
  color: var(--primary-color);
}

[data-theme="dark"] .feature-item span {
  color: var(--text-primary);
}

[data-theme="dark"] .form-label {
  color: var(--text-primary);
}

[data-theme="dark"] .sample-cases-card h4 {
  color: var(--text-primary);
}

[data-theme="dark"] .sample-cases-card p {
  color: var(--text-secondary);
}

[data-theme="dark"] .config-card h4 {
  color: var(--text-primary);
}

[data-theme="dark"] .progress-header h4 {
  color: var(--text-primary);
}

[data-theme="dark"] .progress-text {
  color: var(--text-primary);
}

[data-theme="dark"] .progress-details small {
  color: var(--text-secondary);
}

[data-theme="dark"] .preview-header h4 {
  color: var(--text-primary);
}

[data-theme="dark"] .results-header h3 {
  color: var(--text-primary);
}

/* Dark mode table text */
[data-theme="dark"] .table th {
  color: var(--text-primary);
}

[data-theme="dark"] .table td {
  color: var(--text-primary);
}

[data-theme="dark"] .table-hover tbody tr:hover {
  background-color: var(--light-gray);
}

/* Dark mode notification badge */
[data-theme="dark"] .notification .badge {
  background-color: var(--danger-color);
  color: white;
}

/* Dark mode user profile text */
[data-theme="dark"] .user-name {
  color: var(--text-primary);
}

[data-theme="dark"] .user-role {
  color: var(--text-secondary);
}

/* Dark mode language selector text */
[data-theme="dark"] .language-selector span {
  color: var(--text-primary);
}

/* Dark mode search icon */
[data-theme="dark"] .search-container i {
  color: var(--text-secondary);
}

/* Dark mode chart placeholder */
[data-theme="dark"] .chart-placeholder {
  background-color: var(--light-gray);
  color: var(--text-secondary);
}

/* Dark mode metric icons */
[data-theme="dark"] .metric-icon {
  color: white;
}

/* Dark mode upload area text */
[data-theme="dark"] .upload-area {
  color: var(--text-secondary);
}

[data-theme="dark"] .upload-area h4 {
  color: var(--text-primary);
}

/* Dark mode breadcrumb separator */
[data-theme="dark"] .breadcrumb-separator {
  color: var(--border-color);
}

/* Additional dark mode text field fixes */
[data-theme="dark"] .form-control {
  color: var(--text-primary);
}

[data-theme="dark"] .form-select {
  color: var(--text-primary);
}

[data-theme="dark"] .search-input {
  color: var(--text-primary);
}

[data-theme="dark"] .filter-dropdown {
  color: var(--text-primary);
}

/* Dark mode textarea */
[data-theme="dark"] textarea.form-control {
  color: var(--text-primary);
}

/* Dark mode small text elements */
[data-theme="dark"] small {
  color: var(--text-secondary);
}

[data-theme="dark"] .text-muted {
  color: var(--text-secondary) !important;
}

/* Dark mode links */
[data-theme="dark"] a {
  color: var(--primary-color);
}

[data-theme="dark"] a:hover {
  color: var(--primary-color);
  opacity: 0.8;
}

/* Dark mode headings */
[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] h4,
[data-theme="dark"] h5,
[data-theme="dark"] h6 {
  color: var(--text-primary);
}

/* Dark mode paragraphs */
[data-theme="dark"] p {
  color: var(--text-primary);
}

/* Dark mode spans */
[data-theme="dark"] span {
  color: inherit;
}

/* Dark mode divs with text */
[data-theme="dark"] div {
  color: inherit;
}

/* Dark mode list items */
[data-theme="dark"] li {
  color: var(--text-primary);
}

/* Dark mode labels */
[data-theme="dark"] label {
  color: var(--text-primary);
}

/* Dark mode specific demo page elements */
[data-theme="dark"] .upload-content {
  color: var(--text-secondary);
}

[data-theme="dark"] .upload-content h4 {
  color: var(--text-primary);
}

[data-theme="dark"] .upload-content p {
  color: var(--text-secondary);
}

[data-theme="dark"] .upload-content small {
  color: var(--text-secondary);
}

/* Dark mode manual entry section */
[data-theme="dark"] .manual-entry-section {
  color: var(--text-primary);
}

[data-theme="dark"] .manual-entry-section .form-label {
  color: var(--text-primary);
}

/* Dark mode sample case content */
[data-theme="dark"] .sample-case-content {
  color: var(--text-primary);
}

/* Dark mode configuration section */
[data-theme="dark"] .config-section {
  color: var(--text-primary);
}

/* Dark mode progress section */
[data-theme="dark"] .progress-section {
  color: var(--text-primary);
}

/* Dark mode preview section */
[data-theme="dark"] .preview-section {
  color: var(--text-primary);
}

/* Dark mode results section */
[data-theme="dark"] .results-section {
  color: var(--text-primary);
}

/* Dark mode patient details section */
[data-theme="dark"] .patient-details-section {
  color: var(--text-primary);
}

/* Dark mode claims page specific */
[data-theme="dark"] .claims-page {
  color: var(--text-primary);
}

[data-theme="dark"] .claims-header {
  color: var(--text-primary);
}

[data-theme="dark"] .claims-title {
  color: var(--text-primary);
}

[data-theme="dark"] .claims-controls {
  color: var(--text-primary);
}

/* Dark mode pending page specific */
[data-theme="dark"] .pending-page {
  color: var(--text-primary);
}

/* Dark mode finance page specific */
[data-theme="dark"] .finance-page {
  color: var(--text-primary);
}

[data-theme="dark"] .finance-header {
  color: var(--text-primary);
}

[data-theme="dark"] .finance-content {
  color: var(--text-primary);
}

[data-theme="dark"] .finance-section {
  color: var(--text-primary);
}

/* Dark mode dashboard specific */
[data-theme="dark"] .dashboard-page {
  color: var(--text-primary);
}

[data-theme="dark"] .metrics-container {
  color: var(--text-primary);
}

[data-theme="dark"] .metrics-visuals-section {
  color: var(--text-primary);
}

[data-theme="dark"] .metrics-visuals-section h2 {
  color: var(--text-primary);
}

/* Dark mode visual header */
[data-theme="dark"] .visual-header h3 {
  color: var(--text-primary);
}

/* Dark mode upload container */
[data-theme="dark"] .upload-container {
  color: var(--text-primary);
}

[data-theme="dark"] .choose-file span {
  color: var(--text-primary);
}

[data-theme="dark"] .file-status {
  color: var(--text-secondary);
}

/* Dark mode section headers */
[data-theme="dark"] .section-header h2 {
  color: var(--text-primary);
}

[data-theme="dark"] .section-header p {
  color: var(--text-secondary);
}

/* Dark mode CSV preview table */
[data-theme="dark"] .preview-card .table {
  background-color: var(--card-bg);
  color: var(--text-primary);
}

[data-theme="dark"] .preview-card .table thead.table-light {
  background-color: var(--light-gray) !important;
  color: var(--text-primary);
}

[data-theme="dark"] .preview-card .table thead th {
  background-color: var(--light-gray) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color);
}

[data-theme="dark"] .preview-card .table tbody td {
  background-color: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .preview-card .table-hover tbody tr:hover {
  background-color: var(--light-gray);
}

[data-theme="dark"] .preview-card .table-hover tbody tr:hover td {
  background-color: var(--light-gray);
  color: var(--text-primary);
}

/* Dark mode table responsive wrapper */
[data-theme="dark"] .preview-card .table-responsive {
  background-color: var(--card-bg);
}

/* Dark mode preview card specific styling */
[data-theme="dark"] .preview-card .table {
  border-color: var(--border-color);
}

[data-theme="dark"] .preview-card .table th,
[data-theme="dark"] .preview-card .table td {
  border-color: var(--border-color);
}

/* Dark mode results table styling */
[data-theme="dark"] .results-section .table {
  background-color: var(--card-bg);
  color: var(--text-primary);
}

[data-theme="dark"] .results-section .table thead {
  background-color: var(--light-gray);
  color: var(--text-primary);
}

[data-theme="dark"] .results-section .table thead th {
  background-color: var(--light-gray);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .results-section .table tbody td {
  background-color: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .results-section .table-hover tbody tr:hover {
  background-color: var(--light-gray);
}

[data-theme="dark"] .results-section .table-hover tbody tr:hover td {
  background-color: var(--light-gray);
  color: var(--text-primary);
}

/* Dark mode modal table styling */
[data-theme="dark"] .modal .table {
  background-color: var(--card-bg);
  color: var(--text-primary);
}

[data-theme="dark"] .modal .table thead {
  background-color: var(--light-gray);
  color: var(--text-primary);
}

[data-theme="dark"] .modal .table thead th {
  background-color: var(--light-gray);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .modal .table tbody td {
  background-color: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .modal .table-hover tbody tr:hover {
  background-color: var(--light-gray);
}

[data-theme="dark"] .modal .table-hover tbody tr:hover td {
  background-color: var(--light-gray);
  color: var(--text-primary);
}

/* Dark mode patient details table */
[data-theme="dark"] .patient-details-section .table {
  background-color: var(--card-bg);
  color: var(--text-primary);
}

[data-theme="dark"] .patient-details-section .table thead {
  background-color: var(--light-gray);
  color: var(--text-primary);
}

[data-theme="dark"] .patient-details-section .table thead th {
  background-color: var(--light-gray);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .patient-details-section .table tbody td {
  background-color: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .patient-details-section .table-hover tbody tr:hover {
  background-color: var(--light-gray);
}

[data-theme="dark"] .patient-details-section .table-hover tbody tr:hover td {
  background-color: var(--light-gray);
  color: var(--text-primary);
}

.search-container {
  display: flex;
  align-items: center;
  background-color: var(--light-gray);
  transition: background-color 0.3s ease;
  border-radius: 30px;
  padding: 0.5rem 1rem;
  width: 300px;
}

.search-container i {
  color: var(--text-secondary);
  margin-right: 0.5rem;
}

.search-input {
  border: none;
  background: transparent;
  outline: none;
  width: 100%;
  color: var(--text-primary);
}

.user-menu {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.notification {
  position: relative;
  cursor: pointer;
}

.notification i {
  font-size: 1.25rem;
  color: var(--text-secondary);
}

.badge {
  position: absolute;
  top: -8px;
  right: -8px;
  background-color: #ff4757;
  color: white;
  border-radius: 50%;
  width: 18px;
  height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
}

.language-selector {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 8px;
  transition: all 0.3s ease;
}

.language-selector:hover {
  background-color: #f5f7fb;
}

.flag-icon {
  width: 24px;
  height: 16px;
  object-fit: cover;
  border-radius: 2px;
}

.user-profile {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 8px;
  transition: all 0.3s ease;
}

.user-profile:hover {
  background-color: #f5f7fb;
}

.user-profile {
  position: relative;
  cursor: pointer;
}

/* Profile Dropdown */
.profile-dropdown {
  position: absolute;
  top: 100%;
  right: 0;
  background: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  min-width: 180px;
  z-index: 1000;
  display: none;
  margin-top: 4px;
}

.profile-dropdown.show {
  display: block;
}

.dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  color: var(--text-primary);
  cursor: pointer;
  transition: background-color 0.2s ease;
  font-size: 0.875rem;
}

.dropdown-item:hover {
  background-color: var(--light-gray);
}


.dropdown-item i {
  font-size: 1rem;
  width: 16px;
  text-align: center;
}

.dropdown-divider {
  height: 1px;
  background-color: var(--border-color);
  margin: 0.25rem 0;
}

.logout-item {
  color: var(--danger-color);
}

.logout-item:hover {
  background-color: rgba(220, 53, 69, 0.1);
  color: var(--danger-color);
}

.profile-image {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  object-fit: cover;
}

.user-info {
  display: flex;
  flex-direction: column;
}

.user-name {
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--text-primary);
}

.user-role {
  font-size: 0.75rem;
  color: var(--text-secondary);
}

/* Page Container */
.page-container {
  padding: 2rem;
  display: none;
}

.page-container.active {
  display: block;
}

/* Metrics Cards */
.metrics-container {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.metric-card {
  background-color: var(--card-bg);
  border-radius: 16px;
  padding: 1.5rem;
  border: 1px solid var(--border-color);
  display: flex;
  justify-content: space-between;
  transition: background-color 0.3s ease;
  align-items: center;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.metric-info h3 {
  color: var(--text-secondary);
  font-size: 0.875rem;
  font-weight: 500;
  margin-bottom: 0.5rem;
}

.metric-value {
  color: var(--text-primary);
  font-size: 2rem;
  font-weight: 600;
  margin: 0;
}

.metric-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.metric-icon i {
  font-size: 1.5rem;
  color: white;
}

.metric-icon.purple {
  background-color: #6c5ce7;
}

.metric-icon.yellow {
  background-color: #fdcb6e;
}

.metric-icon.green {
  background-color: #00b894;
}

.metric-icon.orange {
  background-color: #e17055;
}

/* Upload Section */
.upload-section {
  background-color: white;
  border-radius: 16px;
  padding: 1.5rem;
  margin-bottom: 2rem;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.upload-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.choose-file {
  display: flex;
  gap: 1rem;
  align-items: center;
}

.file-status {
  color: var(--text-secondary);
}

.upload-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background-color: var(--primary-color);
  color: white;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.3s ease;
}

.upload-btn:hover {
  background-color: #3651d4;
}

/* Claims Section */
.claims-section {
  background-color: white;
  border-radius: 16px;
  padding: 1.5rem;
  margin-bottom: 2rem;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
}

.section-header h2 {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
}

.search-filter {
  display: flex;
  gap: 1rem;
  align-items: center;
}

.search-box {
  display: flex;
  align-items: center;
  background-color: #f5f7fb;
  border-radius: 8px;
  padding: 0.5rem 1rem;
  width: 250px;
}

.search-box i {
  color: var(--text-secondary);
  margin-right: 0.5rem;
}

.search-box input {
  border: none;
  background: transparent;
  outline: none;
  width: 100%;
}

.btn-filter {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background-color: white;
  border: 1px solid var(--border-color);
  border-radius: 8px;
  color: var(--text-primary);
  cursor: pointer;
  transition: all 0.3s ease;
}

.btn-filter:hover {
  border-color: var(--primary-color);
  color: var(--primary-color);
}

/* Claims Table */
.claims-table {
  width: 100%;
  overflow-x: auto;
}

.claims-table table {
  width: 100%;
  border-collapse: collapse;
}

.claims-table th {
  text-align: left;
  padding: 1rem;
  color: var(--text-secondary);
  font-weight: 500;
  border-bottom: 1px solid var(--border-color);
}

.claims-table td {
  padding: 1rem;
  border-bottom: 1px solid var(--border-color);
}

.claim-id {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.claim-id i {
  color: var(--primary-color);
  font-size: 1.25rem;
}

.claim-id div {
  display: flex;
  flex-direction: column;
}

.claim-id .name {
  font-weight: 500;
  color: var(--text-primary);
}

.claim-id .id {
  font-size: 0.75rem;
  color: var(--text-secondary);
}

.probability-container {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.probability-bar {
  flex: 1;
  height: 6px;
  background-color: #f5f7fb;
  border-radius: 3px;
  overflow: hidden;
}

.probability-fill {
  height: 100%;
  background-color: var(--primary-color);
  border-radius: 3px;
}

.action-buttons {
  display: flex;
  gap: 0.5rem;
}

.btn-action {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
}

.btn-action.view {
  background-color: rgba(67, 97, 238, 0.1);
  color: var(--primary-color);
}

.btn-action.edit {
  background-color: rgba(76, 201, 240, 0.1);
  color: var(--success-color);
}

.btn-action:hover {
  transform: translateY(-2px);
}

/* Metrics & Visuals Section */
.metrics-visuals-section {
  margin-top: 2rem;
}

.metrics-visuals-section h2 {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 1.5rem;
}

.visuals-container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
}

.visual-card {
  background-color: white;
  border-radius: 16px;
  padding: 1.5rem;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.visual-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
}

.visual-header h3 {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
}

.btn-more {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: none;
  background-color: transparent;
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
}

.btn-more:hover {
  background-color: #f5f7fb;
}

.chart-placeholder {
  height: 200px;
  background-color: #f5f7fb;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
}

/* Demo Page Styles */
.demo-content {
  padding: 2rem;
}

/* Demo Header Styles */
.demo-header {
  text-align: center;
  margin-bottom: 3rem;
  padding: 2rem 0;
}

.demo-title-section h1 {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 1rem;
  background: linear-gradient(135deg, var(--primary-color), #4c79f0);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.demo-subtitle {
  font-size: 1.1rem;
  color: var(--text-secondary);
  max-width: 600px;
  margin: 0 auto;
}

/* Upload Methods Section */
.upload-methods-section {
  margin-bottom: 3rem;
}

.upload-method-card {
  background: white;
  border-radius: 20px;
  padding: 2rem;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
  height: 100%;
  transition: all 0.3s ease;
  border: 2px solid transparent;
}

.upload-method-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.12);
  border-color: rgba(67, 97, 238, 0.2);
}

.upload-card-header {
  text-align: center;
  margin-bottom: 2rem;
}

.upload-card-icon {
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, var(--primary-color), #4c79f0);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.5rem;
}

.upload-card-icon i {
  font-size: 1.5rem;
  color: white;
}

.upload-card-header h3 {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 0.5rem;
}

.upload-card-header p {
  color: var(--text-secondary);
  margin: 0;
}

/* Upload Area Styles */
.upload-area {
  border: 2px dashed #e1e5f3;
  border-radius: 16px;
  padding: 2rem;
  text-align: center;
  background: linear-gradient(135deg, #f8faff, #f1f5ff);
  cursor: pointer;
  transition: all 0.3s ease;
  margin-bottom: 1.5rem;
}

.upload-area:hover,
.upload-area.drag-over {
  border-color: var(--primary-color);
  background: linear-gradient(135deg, #f0f4ff, #e8f0ff);
  transform: scale(1.02);
}

.upload-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}

.upload-icon-large {
  width: 80px;
  height: 80px;
  background: rgba(67, 97, 238, 0.1);
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.upload-icon-large i {
  font-size: 2rem;
  color: var(--primary-color);
}

.upload-text h4 {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 0.5rem;
}

.upload-text p {
  color: var(--text-secondary);
  margin-bottom: 0.5rem;
}

.browse-link {
  color: var(--primary-color);
  font-weight: 500;
  text-decoration: underline;
  cursor: pointer;
}

.browse-link:hover {
  color: #3d5bd6;
}

/* Upload Features */
.upload-features {
  display: flex;
  justify-content: space-around;
  margin-top: 1rem;
}

.feature-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9rem;
  color: var(--text-secondary);
}

.feature-item i {
  font-size: 1rem;
}

/* Manual Entry Section */
.manual-entry-section {
  background: #f8faff;
  border-radius: 16px;
  padding: 1.5rem;
}

.form-group {
  margin-bottom: 1rem;
}

.form-label {
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 0.5rem;
  display: block;
}

.form-control {
  border: 1px solid #e1e5f3;
  border-radius: 8px;
  padding: 0.75rem;
  font-size: 0.9rem;
  transition: all 0.3s ease;
}

.form-control:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(67, 97, 238, 0.1);
  outline: none;
}

.form-select {
  border: 1px solid #e1e5f3;
  border-radius: 8px;
  padding: 0.75rem;
  font-size: 0.9rem;
  background-color: white;
  transition: all 0.3s ease;
}

.form-select:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(67, 97, 238, 0.1);
  outline: none;
}

/* Configuration Section */
.config-section {
  margin-bottom: 3rem;
}

.config-card {
  background: white;
  border-radius: 16px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
  border: 1px solid #f0f2f5;
}

.config-card h4 {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
}

.config-card h4 i {
  color: var(--primary-color);
}

/* Progress Section */
.progress-section {
  margin-bottom: 3rem;
}

.progress-card {
  background: white;
  border-radius: 16px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
  border: 1px solid #f0f2f5;
}

.progress-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
}

.progress-header h4 {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
  display: flex;
  align-items: center;
}

.progress-header h4 i {
  color: var(--primary-color);
}

.progress-text {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--primary-color);
}

.progress {
  height: 12px;
  border-radius: 6px;
  background-color: #f0f2f5;
}

.progress-bar {
  border-radius: 6px;
  background: linear-gradient(90deg, var(--primary-color), #4c79f0);
}

.progress-details {
  margin-top: 1rem;
}

/* Preview Section */
.preview-section {
  margin-bottom: 3rem;
}

.preview-card {
  background: white;
  border-radius: 16px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
  border: 1px solid #f0f2f5;
}

.preview-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
}

.preview-header h4 {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
}

.preview-actions {
  display: flex;
  gap: 1rem;
}

.table-responsive {
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid #f0f2f5;
}

.table {
  margin: 0;
}

.table th {
  background-color: #f8faff;
  color: var(--text-primary);
  font-weight: 600;
  border: none;
  padding: 1rem;
}

.table td {
  padding: 1rem;
  border-color: #f0f2f5;
  vertical-align: middle;
}

.table-hover tbody tr:hover {
  background-color: rgba(67, 97, 238, 0.05);
}

/* Results Section */
.results-section {
  margin-bottom: 3rem;
}

.results-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 2rem;
}

.results-header h3 {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
  display: flex;
  align-items: center;
}

.results-header h3 i {
  color: var(--primary-color);
}

.results-actions {
  display: flex;
  gap: 1rem;
}

.results-grid {
  display: grid;
  gap: 1.5rem;
}

/* Button Styles */
.btn {
  border-radius: 8px;
  padding: 0.75rem 1.5rem;
  font-weight: 500;
  font-size: 0.9rem;
  border: none;
  cursor: pointer;
  transition: all 0.3s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.btn i {
  margin-right: 0.5rem;
}

.btn-primary {
  background: linear-gradient(135deg, var(--primary-color), #4c79f0);
  color: white;
}

.btn-primary:hover {
  background: linear-gradient(135deg, #3d5bd6, #4266e0);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(67, 97, 238, 0.3);
}

.btn-secondary {
  background-color: #6c757d;
  color: white;
}

.btn-secondary:hover {
  background-color: #5a6268;
  transform: translateY(-2px);
}

.btn-outline-primary {
  border: 2px solid var(--primary-color);
  color: var(--primary-color);
  background: transparent;
}

.btn-outline-primary:hover {
  background-color: var(--primary-color);
  color: white;
  transform: translateY(-2px);
}

.btn-outline-secondary {
  border: 2px solid #6c757d;
  color: #6c757d;
  background: transparent;
}

.btn-outline-secondary:hover {
  background-color: #6c757d;
  color: white;
  transform: translateY(-2px);
}

.w-100 {
  width: 100%;
}

/* Modal Enhancements */
.modal-content {
  border-radius: 16px;
  border: none;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}

.modal-header {
  border-bottom: 1px solid #f0f2f5;
  padding: 1.5rem 2rem;
}

.modal-title {
  font-weight: 600;
  color: var(--text-primary);
}

.modal-body {
  padding: 2rem;
}

.modal-footer {
  border-top: 1px solid #f0f2f5;
  padding: 1.5rem 2rem;
}

/* Alert Container */
#alertContainer {
  position: fixed;
  top: 1rem;
  right: 1rem;
  z-index: 1050;
}

.alert {
  min-width: 300px;
  max-width: 500px;
  margin-bottom: 1rem;
  border-radius: 8px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

/* Loading Spinner */
#loadingSpinner {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1060;
  background-color: rgba(255, 255, 255, 0.9);
  padding: 2rem;
  border-radius: 16px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* Responsive Design */
@media (max-width: 1200px) {
  .metrics-container {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .visuals-container {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .sidebar {
    transform: translateX(-100%);
    position: fixed;
    z-index: 1040;
    transition: transform 0.3s ease;
  }
  
  .sidebar.show {
    transform: translateX(0);
  }
  
  .main-content {
    margin-left: 0;
  }
  
  .menu-toggle {
    display: block;
  }
  
  .metrics-container {
    grid-template-columns: 1fr;
  }
  
  .search-filter {
    flex-direction: column;
    align-items: stretch;
  }
  
  .search-box {
    width: 100%;
  }
  
  .demo-title-section h1 {
    font-size: 2rem;
  }
  
  .upload-methods-section .row {
    flex-direction: column;
  }
  
  .upload-method-card {
    margin-bottom: 2rem;
  }
  
  .config-card .row {
    flex-direction: column;
  }
  
  .preview-header,
  .results-header {
    flex-direction: column;
    gap: 1rem;
    align-items: stretch;
  }
  
  .preview-actions,
  .results-actions {
    justify-content: center;
  }
  
  .upload-features {
    flex-direction: column;
    gap: 0.5rem;
  }
}

/* Additional Utility Classes */
.summary-stat {
  padding: 1rem;
}

.stat-value {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.2;
}

.stat-label {
  font-size: 0.85rem;
  color: var(--text-secondary);
  margin-top: 0.25rem;
}

.result-icon {
  display: flex;
  justify-content: center;
  align-items: center;
}

.probability-display {
  background: #f8faff;
  border-radius: 8px;
  padding: 0.75rem;
}

.clinical-flags .badge {
  font-size: 0.7rem;
  font-weight: 500;
}

/* Responsive Adjustments for Demo Page */
@media (max-width: 768px) {
  .demo-title-section h1 {
    font-size: 2rem;
  }
  
  .upload-methods-section .row {
    flex-direction: column;
  }
  
  .upload-method-card {
    margin-bottom: 2rem;
  }
  
  .config-card .row {
    flex-direction: column;
  }
  
  .preview-header,
  .results-header {
    flex-direction: column;
    gap: 1rem;
    align-items: stretch;
  }
  
  .preview-actions,
  .results-actions {
    justify-content: center;
  }
  
  .upload-features {
    flex-direction: column;
    gap: 0.5rem;
  }
}

/* Multi-step Demo Workflow Styles */

/* Batch Results Section */
.batch-results-section {
    margin-top: 2rem;
}

.batch-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 2px solid #e9ecef;
}

.batch-title h3 {
    color: #2c3e50;
    margin: 0;
    font-weight: 600;
}

.progress-container {
    background: #f8f9fa;
    border-radius: 12px;
    padding: 1.5rem;
    margin-bottom: 2rem;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    border: 1px solid #e9ecef;
}

.progress-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5rem;
}

.progress-label {
    font-weight: 600;
    color: #495057;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.progress-label::before {
    content: '⚡';
    display: inline-block;
    animation: pulse 1.5s infinite;
}

.progress-percentage {
    font-weight: 700;
    color: #007bff;
    font-size: 1.1rem;
    transition: all 0.3s ease;
    padding: 0.25rem 0.5rem;
    border-radius: 6px;
    background: rgba(0, 123, 255, 0.1);
}

.progress-status {
    font-size: 0.9rem;
    color: #6c757d;
    margin-top: 0.5rem;
    transition: all 0.3s ease;
    padding: 0.5rem;
    background: rgba(108, 117, 125, 0.05);
    border-radius: 6px;
    border-left: 3px solid #007bff;
}

/* Enhanced Progress Bar Styling */
.progress {
    height: 8px;
    background-color: #e9ecef;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.1);
    margin: 0.75rem 0;
}

.progress-bar {
    height: 100%;
    background: linear-gradient(45deg, #007bff, #0056b3);
    border-radius: 10px;
    transition: width 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    position: relative;
    overflow: hidden;
}

.progress-bar::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
    animation: shimmer 2s infinite;
}

.progress-bar.progress-bar-striped {
    background-image: linear-gradient(45deg, rgba(255,255,255,.15) 25%, transparent 25%, transparent 50%, rgba(255,255,255,.15) 50%, rgba(255,255,255,.15) 75%, transparent 75%, transparent);
    background-size: 1rem 1rem;
}

.progress-bar.progress-bar-animated {
    animation: progress-bar-stripes 1s linear infinite, pulse-glow 2s ease-in-out infinite alternate;
}

/* Animation Keyframes */
@keyframes progress-bar-stripes {
    0% {
        background-position: 1rem 0;
    }
    100% {
        background-position: 0 0;
    }
}

@keyframes shimmer {
    0% {
        transform: translateX(-100%);
    }
    100% {
        transform: translateX(100%);
    }
}

@keyframes pulse {
    0%, 100% {
        opacity: 1;
        transform: scale(1);
    }
    50% {
        opacity: 0.7;
        transform: scale(1.1);
    }
}

@keyframes pulse-glow {
    0% {
        box-shadow: 0 0 5px rgba(0, 123, 255, 0.3);
    }
    100% {
        box-shadow: 0 0 20px rgba(0, 123, 255, 0.6), 0 0 30px rgba(0, 123, 255, 0.3);
    }
}

/* Completion state styling */
.progress-container.completed .progress-label {
    color: #28a745;
}

.progress-container.completed .progress-label::before {
    content: '✅';
    animation: none;
}

.progress-container.completed .progress-percentage {
    color: #28a745;
    background: rgba(40, 167, 69, 0.1);
}

.progress-container.completed .progress-status {
    color: #28a745;
    border-left-color: #28a745;
    background: rgba(40, 167, 69, 0.05);
}

.progress-container.completed .progress-bar {
    background: linear-gradient(45deg, #28a745, #1e7e34);
    animation: completion-celebration 1s ease-out;
}

@keyframes completion-celebration {
    0% {
        transform: scaleY(1);
    }
    50% {
        transform: scaleY(1.1);
    }
    100% {
        transform: scaleY(1);
    }
}

/* Patient Cards */
.patients-results {
    display: grid;
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.patient-card {
    background: white;
    border-radius: 12px;
    padding: 1.5rem;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    border-left: 4px solid #dee2e6;
    transition: all 0.3s ease;
}

.patient-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0,0,0,0.15);
}

.patient-card.allowed {
    border-left-color: #28a745;
}

.patient-card.excluded {
    border-left-color: #dc3545;
}

.patient-card.error {
    border-left-color: #ffc107;
}

.patient-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.patient-info h5 {
    margin: 0;
    color: #2c3e50;
    font-weight: 600;
}

.claim-id {
    font-size: 0.9rem;
    color: #6c757d;
    margin-top: 0.25rem;
}

.status-badge {
    padding: 0.4rem 0.8rem;
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
}

.status-badge.allowed {
    background: #d4edda;
    color: #155724;
}

.status-badge.excluded {
    background: #f8d7da;
    color: #721c24;
}

.status-badge.error {
    background: #fff3cd;
    color: #856404;
}

.patient-details {
    margin-bottom: 1rem;
}

.detail-row {
    display: flex;
    margin-bottom: 0.5rem;
    font-size: 0.9rem;
}

.detail-row .label {
    font-weight: 600;
    color: #495057;
    min-width: 80px;
    margin-right: 0.5rem;
}

.detail-row .value {
    color: #6c757d;
    flex: 1;
}

.patient-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 1rem;
    border-top: 1px solid #e9ecef;
}

.approval-score {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.score-label {
    font-weight: 600;
    color: #495057;
}

.score-value {
    font-weight: 700;
    font-size: 1.1rem;
    color: #007bff;
}

.view-details-btn {
    padding: 0.25rem 0.5rem;
    font-size: 0.75rem;
    width: auto !important;
    min-width: auto !important;
    max-width: 120px;
    flex-shrink: 0;
    white-space: nowrap;
}

/* Patient Details Section */
.patient-details-section {
    margin-top: 2rem;
}

.details-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 2px solid #e9ecef;
}

.patient-title h3 {
    color: #2c3e50;
    margin: 0;
    font-weight: 600;
}

.details-tabs {
    display: flex;
    gap: 0.5rem;
}

.tab-btn {
    padding: 0.5rem 1rem;
    border: 1px solid #dee2e6;
    background: white;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.tab-btn.active {
    background: #007bff;
    color: white;
    border-color: #007bff;
}

.clinical-table-container {
    background: white;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    margin-bottom: 2rem;
}

.clinical-details-table {
    border-collapse: separate;
    border-spacing: 0;
    margin-bottom: 0;
}

.clinical-details-table th {
    background-color: #343a40;
    color: white;
    font-weight: 600;
    text-align: left;
    padding: 15px 12px;
    border: none;
    vertical-align: middle;
    position: sticky;
    top: 0;
    z-index: 10;
}

.clinical-details-table td {
    padding: 12px;
    vertical-align: middle;
    border-bottom: 1px solid #e9ecef;
    word-wrap: break-word;
    max-width: 0;
}

/* Specific column widths for better alignment */
.clinical-details-table th:nth-child(1),
.clinical-details-table td:nth-child(1) {
    width: 15%;
    min-width: 120px;
}

.clinical-details-table th:nth-child(2),
.clinical-details-table td:nth-child(2) {
    width: 25%;
    min-width: 180px;
}

.clinical-details-table th:nth-child(3),
.clinical-details-table td:nth-child(3) {
    width: 15%;
    min-width: 120px;
    text-align: center;
}

.clinical-details-table th:nth-child(4),
.clinical-details-table td:nth-child(4) {
    width: 30%;
    min-width: 200px;
}

.clinical-details-table th:nth-child(5),
.clinical-details-table td:nth-child(5) {
    width: 15%;
    min-width: 120px;
}

.clinical-row.excluded {
    background-color: #fff5f5;
}

.clinical-row.allowed {
    background-color: #f0fff4;
}

.clinical-row.unknown {
    background-color: #f8f9fa;
}

.clinical-field {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.clinical-details-table .bi-check-circle {
    color: #28a745;
}

.clinical-details-table .bi-x-circle {
    color: #dc3545;
}

.clinical-details-table .bi-question-circle {
    color: #6c757d;
}

.field-name {
    font-weight: 500;
    text-transform: capitalize;
}

.submitted-details {
    max-width: 200px;
    word-wrap: break-word;
}

.coverage-status .status-badge {
    padding: 0.25rem 0.75rem;
    border-radius: 20px;
    font-size: 0.875rem;
    font-weight: 500;
}

.status-badge.allowed {
    background-color: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
}

.status-badge.excluded {
    background-color: #ff6b6b;
    color: #ffffff;
    border: 1px solid #ff5252;
}

.status-badge.unknown {
    background-color: #e2e3e5;
    color: #495057;
    border: 1px solid #ced4da;
}

.policy-evaluation {
    max-width: 250px;
    font-size: 0.9rem;
    color: #6c757d;
}

.policy-source {
    font-size: 0.875rem;
    color: #6c757d;
}

.recommendations {
    min-width: 150px;
}

.recommendations-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.form-check {
    display: flex;
    align-items: flex-start;
    margin-bottom: 12px;
    padding-left: 0;
}

.form-check-input {
    width: 18px;
    height: 18px;
    margin-top: 3px;
    margin-right: 12px;
    flex-shrink: 0;
    border: 2px solid #dee2e6;
    border-radius: 4px;
    transition: all 0.2s ease;
}

.form-check-input:checked {
    background-color: #4361ee;
    border-color: #4361ee;
    box-shadow: 0 0 0 3px rgba(67, 97, 238, 0.1);
}

.form-check-label {
    margin-bottom: 0;
    line-height: 1.4;
    color: #495057;
    cursor: pointer;
    flex: 1;
    padding-top: 1px;
}

.form-check-label:hover {
    color: #2c3e50;
}

/* Medical Logic Section */
.medical-logic-section {
    background: white;
    border-radius: 8px;
    padding: 2rem;
    margin-bottom: 2rem;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.medical-logic-section h3 {
    color: #2c3e50;
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: 1.5rem;
}

.coherence-score-section {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 2rem;
    padding: 1rem;
    background: #f8f9fa;
    border-radius: 8px;
}

.coherence-label {
    font-weight: 500;
    color: #495057;
}

.coherence-badge {
    background: #ffd166;
    color: #856404;
    padding: 0.5rem 1rem;
    border-radius: 20px;
    font-weight: 600;
    font-size: 1rem;
}

/* Clinical Flag Cards */
.clinical-flag-card {
    border: 1px solid #ffeaa7;
    border-radius: 8px;
    padding: 1.5rem;
    margin-bottom: 1rem;
    background: #fffbf0;
}

.clinical-flag-card .flag-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.clinical-flag-card .flag-title {
    font-weight: 600;
    color: #856404;
}

.recommendations-section {
    margin-top: 1rem;
}

.recommendations-label {
    font-weight: 500;
    color: #495057;
    display: block;
    margin-bottom: 0.75rem;
}

.recommendations-checkboxes {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.apply-btn {
    padding: 0.2rem 0.5rem !important;
    font-size: 0.65rem !important;
    font-weight: 600;
    border-radius: 6px !important;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    min-height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border: 1.5px solid #4361ee !important;
    background: linear-gradient(135deg, #4361ee, #3a0ca3) !important;
    color: white !important;
    box-shadow: 0 2px 4px rgba(67, 97, 238, 0.15);
    position: relative;
    overflow: hidden;
}

.apply-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
    transition: left 0.5s;
}

.apply-btn:hover {
    transform: translateY(-1px) scale(1.02);
    box-shadow: 0 4px 12px rgba(67, 97, 238, 0.3);
    border-color: #3a0ca3 !important;
    background: linear-gradient(135deg, #3a0ca3, #4361ee) !important;
}

.apply-btn:hover::before {
    left: 100%;
}

.apply-btn:active {
    transform: translateY(0) scale(0.98);
    box-shadow: 0 2px 4px rgba(67, 97, 238, 0.2);
}

/* Generate New Button Styles */
.generate-new-btn,
.generate-new-clinical-btn {
    padding: 0.2rem 0.5rem !important;
    font-size: 0.65rem !important;
    font-weight: 600;
    border-radius: 6px !important;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    min-height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border: 1.5px solid #6c757d !important;
    background: linear-gradient(135deg, #f8f9fa, #e9ecef) !important;
    color: #495057 !important;
    box-shadow: 0 2px 4px rgba(108, 117, 125, 0.1);
    position: relative;
    overflow: hidden;
}

.generate-new-btn::before,
.generate-new-clinical-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(108, 117, 125, 0.1), transparent);
    transition: left 0.5s;
}

.generate-new-btn:hover,
.generate-new-clinical-btn:hover {
    background: linear-gradient(135deg, #e9ecef, #dee2e6) !important;
    border-color: #5a6268 !important;
    color: #343a40 !important;
    transform: translateY(-1px) scale(1.02);
    box-shadow: 0 4px 12px rgba(108, 117, 125, 0.2);
}

.generate-new-btn:hover::before,
.generate-new-clinical-btn:hover::before {
    left: 100%;
}

.generate-new-btn:active,
.generate-new-clinical-btn:active {
    transform: translateY(0) scale(0.98);
    box-shadow: 0 2px 4px rgba(108, 117, 125, 0.15);
}

/* Loading state for buttons */
.generate-new-btn:disabled,
.generate-new-clinical-btn:disabled,
.apply-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none !important;
    pointer-events: none;
}

.generate-new-btn:disabled::before,
.generate-new-clinical-btn:disabled::before,
.apply-btn:disabled::before {
    display: none;
}

/* Spin animation for loading spinner */
.spin-animation {
    animation: spin 1s linear infinite;
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

/* Button container spacing */
.recommendation-buttons,
.clinical-recommendation-buttons {
    display: flex;
    gap: 0.4rem;
    align-items: center;
    margin-top: 0.75rem;
}

/* Add subtle animation for button appearances */
.apply-btn,
.generate-new-btn,
.generate-new-clinical-btn {
    animation: buttonFadeIn 0.3s ease-out;
}

@keyframes buttonFadeIn {
    from {
        opacity: 0;
        transform: translateY(8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .apply-btn,
    .generate-new-btn,
    .generate-new-clinical-btn {
        padding: 0.15rem 0.4rem !important;
        font-size: 0.6rem !important;
        min-height: 22px;
        letter-spacing: 0.3px;
    }
    
    .recommendation-buttons,
    .clinical-recommendation-buttons {
        gap: 0.3rem;
        flex-wrap: wrap;
    }
}

.no-flags-message {
    text-align: center;
    padding: 2rem;
    background: #f8f9fa;
    border-radius: 8px;
    border: 1px dashed #dee2e6;
}

/* Submission Actions */
.single-result-content .result-actions {
    border-top: 1px solid #e9ecef;
    padding-top: 1.5rem;
}

/* Success Alert for No Clinical Issues */
.single-result-content .alert-success {
    background-color: #d1f2eb;
    border-color: #27ae60;
    color: #0e7245;
}

/* Evaluation Confirmation */
.evaluation-confirmation {
    text-align: center;
}

.confirmation-header {
    margin-bottom: 2rem;
}

.evaluation-summary {
    background-color: #f8f9fa;
    border-radius: 8px;
    padding: 1.5rem;
    margin: 1.5rem 0;
}

.summary-item h5 {
    margin-bottom: 0.25rem;
}

.applied-recommendations {
    text-align: left;
    background-color: #d1f2eb;
    border-radius: 6px;
    padding: 1rem;
}

.field-recommendations {
    margin-bottom: 0.75rem;
}

.field-recommendations:last-child {
    margin-bottom: 0;
}

.recommendation-list {
    margin: 0.25rem 0 0 0;
    padding-left: 1rem;
}

.recommendation-list li {
    margin-bottom: 0.25rem;
    color: #495057;
}

/* Modal Size Enhancement */
#singleResultModal .modal-dialog {
    max-width: 900px;
}

#singleResultModal .modal-body {
    max-height: 70vh;
    overflow-y: auto;
}

/* Excluded Field Recommendations Styles */
.excluded-recommendations-section {
    background-color: #fff8e6;
    border: 1px solid #ffc107;
    border-radius: 12px;
    padding: 1.5rem;
    margin: 1.5rem 0;
}

.excluded-recommendations-section h5,
.excluded-recommendations-section h6 {
    color: #856404;
    margin-bottom: 0.75rem;
    font-weight: 600;
}

.excluded-field-card {
    background-color: white;
    border-left: 4px solid #dc3545;
    margin-bottom: 1rem;
    transition: all 0.3s ease;
}

.excluded-field-card:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.excluded-field-card .field-header {
    border-bottom: 1px solid #e9ecef;
    padding-bottom: 0.75rem;
}

.excluded-field-card .field-title {
    color: #dc3545;
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.excluded-field-card .field-explanation {
    font-size: 0.875rem;
    line-height: 1.4;
}

.excluded-field-card .recommendations-content {
    padding-top: 0.75rem;
}

.excluded-field-card .recommendation-item {
    margin-bottom: 0.5rem;
    padding: 0.25rem 0;
}

.excluded-field-card .form-check-label {
    font-size: 0.875rem;
    line-height: 1.4;
    color: #495057;
}

.excluded-field-card .recommendation-buttons {
    border-top: 1px solid #f8f9fa;
    padding-top: 0.75rem;
    margin-top: 0.75rem;
}

/* Applied recommendation styling */
.applied-recommendation {
    background-color: #d4edda;
    border: 1px solid #c3e6cb;
    border-radius: 6px;
    padding: 0.5rem;
    margin-top: 0.25rem;
    font-size: 0.875rem;
}

.applied-recommendation strong {
    color: #155724;
}

/* Fade in animation for success messages */
@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Enhanced button styles for excluded recommendations */
.apply-excluded-btn,
.generate-new-excluded-btn {
    font-size: 0.875rem;
    padding: 0.375rem 0.75rem;
    border-radius: 6px;
    transition: all 0.3s ease;
}

.apply-excluded-btn {
    background-color: #28a745;
    border-color: #28a745;
    color: white;
}

.apply-excluded-btn:hover {
    background-color: #218838;
    border-color: #1e7e34;
    transform: translateY(-1px);
}

.generate-new-excluded-btn {
    background-color: transparent;
    border-color: #6c757d;
    color: #6c757d;
}

.generate-new-excluded-btn:hover {
    background-color: #6c757d;
    color: white;
    transform: translateY(-1px);
}

/* Status badge improvements */
.status-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.75rem;
    border-radius: 12px;
    font-size: 0.875rem;
    font-weight: 500;
    text-transform: capitalize;
}

.status-badge.allowed {
    background-color: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
}

.status-badge.excluded {
    background-color: #ff6b6b;
    color: #ffffff;
    border: 1px solid #ff5252;
}

.status-badge.unknown {
    background-color: #fff3cd;
    color: #856404;
    border: 1px solid #ffeaa7;
}

/* Clinical row enhancements */
.clinical-row {
    transition: all 0.3s ease;
}

.clinical-row.excluded {
    background-color: rgba(220, 53, 69, 0.05);
}

.clinical-row.allowed {
    background-color: rgba(40, 167, 69, 0.05);
}

.clinical-row:hover {
    background-color: rgba(0, 0, 0, 0.02);
}

/* Icons with status colors */
.bi.allowed {
    color: #28a745;
}

.bi.excluded {
    color: #dc3545;
}

.bi.unknown {
    color: #ffc107;
}

/* Enhanced modal styles for single claims */
#singleResultModal .excluded-recommendations-section {
    background-color: #fef8e7;
    border: 1px solid #ffc107;
    border-radius: 8px;
    padding: 1rem;
}

#singleResultModal .excluded-field-card {
    border-left: 3px solid #dc3545;
    padding: 1rem;
}

#singleResultModal .field-title {
    font-size: 0.9rem;
}

#singleResultModal .form-check-label {
    font-size: 0.8rem;
}

/* Decision badge enhancements */
.decision-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.75rem 1.5rem;
    border-radius: 12px;
    font-size: 1.1rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.decision-badge.allowed {
    background-color: #d4edda;
    color: #155724;
    border: 2px solid #28a745;
}

.decision-badge.excluded {
    background-color: #f8d7da;
    color: #721c24;
    border: 2px solid #dc3545;
}

/* Success Message Styles */
.success-message {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 9999;
    opacity: 0;
    transition: all 0.3s ease;
    pointer-events: none;
}

.success-message.show {
    opacity: 1;
    pointer-events: auto;
}

.success-content {
    background: linear-gradient(135deg, #28a745, #20c997);
    color: white;
    padding: 2rem 3rem;
    border-radius: 16px;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: 1.25rem;
    font-weight: 600;
    text-align: center;
    min-width: 400px;
    animation: successPulse 0.6s ease-out;
}

.success-content i {
    font-size: 2rem;
    color: #ffffff;
}

@keyframes successPulse {
    0% {
        transform: scale(0.8);
        opacity: 0;
    }
    50% {
        transform: scale(1.05);
    }
    100% {
        transform: scale(1);
        opacity: 1;
    }
}

/* Dark mode success message */
[data-theme="dark"] .success-content {
    background: linear-gradient(135deg, #28a745, #20c997);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.5);
}

/* Bottom Success Message Styles */
.success-message-bottom {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%) translateY(100px);
    z-index: 9999;
    opacity: 0;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    pointer-events: none;
    max-width: 90%;
    width: 500px;
}

.success-message-bottom.show {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
    pointer-events: auto;
}

.success-content-bottom {
    background: linear-gradient(135deg, #28a745, #20c997);
    color: white;
    padding: 1rem 1.5rem;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
    display: flex;
    align-items: center;
    gap: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(10px);
}

.success-icon {
    flex-shrink: 0;
}

.success-icon i {
    font-size: 1.5rem;
    color: #ffffff;
}

.success-text {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.success-title {
    font-weight: 600;
    font-size: 1rem;
    color: #ffffff;
}

.success-message-text {
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.9);
    line-height: 1.4;
}

.success-close-btn {
    background: none;
    border: none;
    color: rgba(255, 255, 255, 0.8);
    cursor: pointer;
    padding: 0.25rem;
    border-radius: 4px;
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.success-close-btn:hover {
    background: rgba(255, 255, 255, 0.1);
    color: #ffffff;
}

.success-close-btn i {
    font-size: 1.2rem;
}

/* Dark mode bottom success message */
[data-theme="dark"] .success-content-bottom {
    background: linear-gradient(135deg, #28a745, #20c997);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4);
    border: 1px solid rgba(255, 255, 255, 0.1);
}

/* Responsive design for bottom success message */
@media (max-width: 768px) {
    .success-message-bottom {
        left: 10px;
        right: 10px;
        transform: translateY(100px);
        max-width: none;
        width: auto;
    }
    
    .success-message-bottom.show {
        transform: translateY(0);
    }
    
    .success-content-bottom {
        padding: 0.875rem 1.25rem;
    }
    
    .success-title {
        font-size: 0.95rem;
    }
    
    .success-message-text {
        font-size: 0.85rem;
    }
}

.decision-badge i {
    margin-right: 0.5rem;
    font-size: 1.2rem;
}

/* Score value styling */
.score-value {
    font-weight: 700;
    font-size: 1.25rem;
}

.score-value.high {
    color: #28a745;
}

.score-value.medium {
    color: #ffc107;
}

.score-value.low {
  color: #dc3545;
}

/* Unified Recommendations Section */
.unified-recommendations-section {
  background: linear-gradient(135deg, #f8f9fb 0%, #ffffff 100%);
  border: 1px solid #e9ecef;
  border-radius: 12px;
  padding: 1.5rem;
  margin: 1.5rem 0;
}

/* Smooth section hiding transitions */
.policy-exclusions-section,
.clinical-logic-section {
  transition: opacity 0.3s ease, max-height 0.3s ease, margin 0.3s ease, padding 0.3s ease;
  overflow: hidden;
}

.policy-exclusions-section[style*="display: none"],
.clinical-logic-section[style*="display: none"] {
  opacity: 0;
  max-height: 0;
  margin: 0;
  padding: 0;
}

/* Recommendation card hiding transitions */
.recommendation-card {
  transition: opacity 0.3s ease, max-height 0.3s ease, margin 0.3s ease;
  overflow: hidden;
}

.recommendation-card[style*="display: none"] {
  opacity: 0;
  max-height: 0;
  margin: 0;
}

.unified-recommendations-section h3 {
  color: #2c3e50;
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
}

.unified-recommendations-section h3 i {
  color: #ffd166;
  margin-right: 0.5rem;
}

.unified-recommendations-section h5 {
  color: #2c3e50;
  font-size: 1.1rem;
  font-weight: 600;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
}

.unified-recommendations-section h5 i {
  color: #ffd166;
  margin-right: 0.5rem;
}

.coherence-score-section {
  background: linear-gradient(135deg, #6c5ce7 0%, #74b9ff 100%);
  border-radius: 8px;
  padding: 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}

.coherence-label {
  color: white;
  font-weight: 500;
  font-size: 0.95rem;
}

.coherence-badge {
  background: rgba(255, 255, 255, 0.2);
  color: white;
  padding: 0.4rem 0.8rem;
  border-radius: 20px;
  font-weight: 600;
  font-size: 1rem;
}

.metric-label {
  color: #6c757d;
  font-weight: 500;
  font-size: 0.9rem;
}

.score-badge.coherence {
  background: linear-gradient(135deg, #00b894 0%, #00cec9 100%);
  color: white;
  padding: 0.3rem 0.7rem;
  border-radius: 15px;
  font-weight: 600;
  font-size: 0.9rem;
}

.recommendation-card {
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
  border-radius: 12px;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 2px 6px;
  transition: all 0.3s ease;
  overflow: hidden;
}

.recommendation-card:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}

.recommendation-card.policy_exclusion {
  border-left: 4px solid #dc3545;
}

.recommendation-card.clinical_logic {
  border-left: 4px solid #ffc107;
}

.recommendation-card .card-header {
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
  border-bottom: 1px solid #dee2e6;
  padding: 1rem;
}

.recommendation-title {
  color: #2c3e50;
  font-size: 1rem;
  font-weight: 600;
  margin: 0;
  display: flex;
  align-items: center;
}

.recommendation-description {
  color: #6c757d;
  font-size: 0.9rem;
  margin: 0.5rem 0;
}

.source-badge {
  font-size: 0.75rem;
  padding: 0.25rem 0.6rem;
  border-radius: 12px;
  font-weight: 500;
}

.source-badge.bg-danger {
  background-color: #dc3545 !important;
  color: white;
}

.source-badge.bg-warning {
  background-color: #ffc107 !important;
  color: #212529;
}

.recommendation-card .card-body {
  padding: 16px;
}

.recommendations-list {
  margin-bottom: 16px;
}

.recommendation-item {
  margin-bottom: 10px;
  padding: 8px 0;
  border-bottom: 1px solid #f8f9fa;
}

.recommendation-item:last-child {
  border-bottom: none;
  margin-bottom: 0;
}

.recommendation-item .form-check {
  margin-bottom: 0;
}

.recommendation-item .form-check-input {
  margin-top: 2px;
}

.recommendation-buttons {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 12px;
}

.apply-unified-btn,
.generate-new-unified-btn {
  padding: 6px 12px;
  font-size: 0.875rem;
  border-radius: 6px;
  font-weight: 500;
  transition: all 0.2s ease;
}

/* Responsive Design for Unified Recommendations */
@media (max-width: 768px) {
  .unified-recommendations-section {
    padding: 1rem;
    margin: 1rem 0;
  }
  
  .recommendation-card .card-header {
    padding: 0.75rem;
  }
  
  .recommendation-card .card-body {
    padding: 0.75rem;
  }
  
  .recommendation-buttons {
    flex-direction: column;
    gap: 0.5rem;
  }
  
  .apply-unified-btn,
  .generate-new-unified-btn {
    width: 100%;
    justify-content: center;
  }
  
  .coherence-score-section {
    flex-direction: column;
    text-align: center;
    gap: 0.5rem;
  }
}

/* Enhanced Table Alignment and Styling */
.clinical-details-table {
  border-collapse: separate;
  border-spacing: 0;
  margin-bottom: 0;
}

.clinical-details-table th {
  background-color: #343a40;
  color: white;
  font-weight: 600;
  text-align: left;
  padding: 15px 12px;
  border: none;
  vertical-align: middle;
  position: sticky;
  top: 0;
  z-index: 10;
}

.clinical-details-table td {
  padding: 12px;
  vertical-align: middle;
  border-bottom: 1px solid #e9ecef;
  word-wrap: break-word;
  max-width: 0;
}

/* Specific column widths for better alignment */
.clinical-details-table th:nth-child(1),
.clinical-details-table td:nth-child(1) {
  width: 15%;
  min-width: 120px;
}

.clinical-details-table th:nth-child(2),
.clinical-details-table td:nth-child(2) {
  width: 25%;
  min-width: 180px;
}

.clinical-details-table th:nth-child(3),
.clinical-details-table td:nth-child(3) {
  width: 15%;
  min-width: 120px;
  text-align: center;
}

.clinical-details-table th:nth-child(4),
.clinical-details-table td:nth-child(4) {
  width: 30%;
  min-width: 200px;
}

.clinical-details-table th:nth-child(5),
.clinical-details-table td:nth-child(5) {
  width: 15%;
  min-width: 120px;
}

/* Enhanced Back to Results Button Styling */
.back-to-results-btn {
  background: linear-gradient(135deg, #4361ee, #3a0ca3);
  border: none;
  color: white;
  padding: 4px 8px;
  border-radius: 4px;
  font-weight: 600;
  font-size: 0.75rem;
  transition: all 0.3s ease;
  box-shadow: 0 2px 4px rgba(67, 97, 238, 0.2);
  width: auto !important;
  max-width: 120px;
  display: inline-flex;
  align-items: center;
  margin-left: auto;
  flex-shrink: 0;
  white-space: nowrap;
}

.back-to-results-btn:hover {
  background: linear-gradient(135deg, #3a0ca3, #2d0a8a);
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(67, 97, 238, 0.3);
  color: white;
}

.back-to-results-btn:active {
  transform: translateY(0);
  box-shadow: 0 2px 4px rgba(67, 97, 238, 0.2);
}

.back-to-results-btn i {
  margin-right: 3px;
}

/* Enhanced Patient Details Header */
.patient-details-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px;
  background: var(--card-bg);
  border-bottom: 1px solid var(--border-color);
  margin-bottom: 0;
  transition: background-color 0.3s ease, border-color 0.3s ease;
}

.patient-info-section h2 {
  margin: 0;
  color: #2c3e50;
  font-weight: 600;
  font-size: 1.5rem;
}

/* Enhanced Checkbox Alignment for Recommendations */
.form-check {
  display: flex;
  align-items: flex-start;
  margin-bottom: 12px;
  padding-left: 0;
}

.form-check-input {
  width: 18px;
  height: 18px;
  margin-top: 3px;
  margin-right: 12px;
  flex-shrink: 0;
  border: 2px solid #dee2e6;
  border-radius: 4px;
  transition: all 0.2s ease;
}

.form-check-input:checked {
  background-color: #4361ee;
  border-color: #4361ee;
  box-shadow: 0 0 0 3px rgba(67, 97, 238, 0.1);
}

.form-check-label {
  margin-bottom: 0;
  line-height: 1.4;
  color: #495057;
  cursor: pointer;
  flex: 1;
  padding-top: 1px;
}

.form-check-label:hover {
  color: #2c3e50;
}

/* Enhanced Recommendation Cards Alignment */
.recommendation-card .card-body {
  padding: 16px;
}

.recommendations-list {
  margin-bottom: 16px;
}

.recommendation-item {
  margin-bottom: 10px;
  padding: 8px 0;
  border-bottom: 1px solid #f8f9fa;
}

.recommendation-item:last-child {
  border-bottom: none;
  margin-bottom: 0;
}

.recommendation-item .form-check {
  margin-bottom: 0;
}

.recommendation-item .form-check-input {
  margin-top: 2px;
}

/* Enhanced Recommendation Buttons */
.recommendation-buttons {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 12px;
}

.apply-unified-btn,
.generate-new-unified-btn {
  padding: 6px 12px;
  font-size: 0.875rem;
  border-radius: 6px;
  font-weight: 500;
  transition: all 0.2s ease;
}

/* Clinical Table Wrapper for Better Scrolling */
.clinical-table-wrapper {
  overflow-x: auto;
  border-radius: 8px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  background: white;
}

/* Responsive Table Adjustments */
@media (max-width: 768px) {
  .patient-details-header {
    flex-direction: column;
    gap: 15px;
    align-items: stretch;
  }
  
  .back-to-results-btn {
    align-self: flex-end;
    width: auto;
  }
  
  .clinical-details-table th,
  .clinical-details-table td {
    padding: 8px 6px;
    font-size: 0.875rem;
  }
  
  .clinical-details-table th:nth-child(1),
  .clinical-details-table td:nth-child(1) {
    min-width: 100px;
  }
  
  .clinical-details-table th:nth-child(2),
  .clinical-details-table td:nth-child(2) {
    min-width: 140px;
  }
  
  .form-check-input {
    width: 16px;
    height: 16px;
    margin-right: 10px;
  }
  
  .recommendation-buttons {
    gap: 6px;
  }
}

/* Sample Cases Section Styles */
.sample-cases-section {
  margin: 1rem 0;
}

/* Compact Sample Cases Card */
.sample-cases-compact-card {
  background: white;
  border-radius: 12px;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 2px 6px;
  border: 1px solid var(--border-color);
  padding: 0.75rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  transition: all 0.3s ease;
  max-width: 400px;
  margin: 0 auto;
}

.sample-cases-compact-card:hover {
  transform: translateY(-1px);
  box-shadow: rgba(0, 0, 0, 0.15) 0px 4px 12px;
}

.sample-file-info {
  display: flex;
  align-items: center;
  font-weight: 500;
  color: var(--text-primary);
  font-size: 0.9rem;
}

.sample-filename {
  white-space: nowrap;
}

.compact-download-btn {
  border-radius: 8px;
  font-weight: 500;
  font-size: 0.8rem;
  padding: 0.4rem 0.8rem;
  transition: all 0.3s ease;
  white-space: nowrap;
}

.compact-download-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

/* Responsive design for compact card */
@media (max-width: 576px) {
  .sample-cases-compact-card {
    flex-direction: column;
    gap: 0.5rem;
    text-align: center;
    padding: 0.75rem;
  }
  
  .compact-download-btn {
    width: 100%;
  }
}

/* Legacy styles for backward compatibility */

.sample-cases-card {
  background: white;
  border-radius: 8px;
  padding: 1rem;
  box-shadow: 0 1px 6px rgba(0, 0, 0, 0.06);
  border: 1px solid var(--border-color);
}

.sample-cases-card h4 {
  color: var(--primary-color);
  margin-bottom: 0.25rem;
  font-weight: 600;
  font-size: 1rem;
}

.sample-case-card {
  background: #f8f9fa;
  border-radius: 6px;
  padding: 1rem;
  height: 100%;
  border: 1px solid #e9ecef;
  transition: all 0.3s ease;
}

.sample-case-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  border-color: var(--primary-color);
}

.sample-case-header {
  display: flex;
  align-items: center;
  margin-bottom: 0.5rem;
}

.sample-case-header i {
  font-size: 1.25rem;
  margin-right: 0.5rem;
}

.sample-case-header h5 {
  margin: 0;
  color: var(--text-primary);
  font-weight: 600;
}

.sample-case-content {
  margin-bottom: 1rem;
}

.sample-case-content p {
  margin-bottom: 0.5rem;
  font-size: 0.9rem;
}

.sample-case-content p:last-child {
  margin-bottom: 0;
}

.sample-case-content strong {
  color: var(--text-primary);
}

.sample-case-content .text-muted {
  font-size: 0.8rem;
  line-height: 1.4;
}

.sample-case-card .btn {
  border-radius: 6px;
  font-weight: 500;
  transition: all 0.3s ease;
}

.sample-case-card .btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

/* Responsive adjustments for sample cases */
@media (max-width: 768px) {
  .sample-cases-card {
    padding: 0.75rem;
  }
  
  .sample-case-card {
    padding: 0.75rem;
    margin-bottom: 0.75rem;
  }
  
  .sample-case-header {
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
  }
  
  .sample-case-header i {
    margin-right: 0;
    margin-bottom: 0.5rem;
  }
}


/* Patient name link styles */
.patient-name-link {
  cursor: pointer;
  color: var(--primary-color);
  text-decoration: none;
  transition: all 0.3s ease;
}

.patient-name-link:hover {
  color: var(--primary-hover);
  text-decoration: underline;
}

/* Dashboard table clickable row styles */
.clickable-row {
  cursor: pointer;
  transition: all 0.3s ease;
}

.clickable-row:hover {
  background-color: #f8f9fa;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.clickable-row:hover .name {
  color: var(--primary-color);
}

/* Dark mode support for clickable rows */
[data-theme="dark"] .clickable-row:hover {
  background-color: var(--light-gray);
}

/* Submitted Indicator Styles */
.submitted-indicator {
    background: linear-gradient(135deg, #28a745, #20c997);
    color: white;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 4px 8px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    gap: 4px;
    box-shadow: 0 2px 4px rgba(40, 167, 69, 0.3);
    transition: all 0.3s ease;
    white-space: nowrap;
}

.submitted-indicator:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(40, 167, 69, 0.4);
}

.submitted-indicator i {
    font-size: 0.7rem;
}

/* Tooltip styling */
.submitted-indicator[data-bs-toggle="tooltip"] {
    cursor: help;
}

/* Patient status container to ensure proper alignment */
.patient-status {
    align-items: center;
    gap: 8px; /* 8px spacing between badges as requested */
}

/* Patient card positioning context */
.patient-card {
    position: relative;
}

/* Dark mode support for submitted indicator */
[data-theme="dark"] .submitted-indicator {
    background: linear-gradient(135deg, #198754, #20c997);
    box-shadow: 0 2px 4px rgba(25, 135, 84, 0.3);
}

[data-theme="dark"] .submitted-indicator:hover {
    box-shadow: 0 4px 8px rgba(25, 135, 84, 0.4);
}

[data-theme="dark"] .clickable-row:hover .name {
  color: var(--primary-color);
}
