@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap);
/* src/index.css */

:root {
    --primary-color: #002b5c;    /* dark blue */
    --secondary-color: #ffffff;  /* white */
    --background-color: #f0f2f5; /* light gray for page background */
    --card-bg: #ffffff;          /* white for cards */
    --card-border: #e0e0e0;      /* light gray border */
    --text-color: #333333;       /* dark gray for main text */
    --heading-color: #002b5c;    /* same as primary for headings */
  }
  
  * {
  box-sizing: border-box;
  margin: 0;
}
  
  body {
    background-color: #f0f2f5;
    background-color: var(--background-color);
    color: #333333;
    color: var(--text-color);
    font-family: Arial, sans-serif;
  }
  
  .content {
    padding: 1.5rem; /* space around routed pages */
  }
  
/* src/components/Navbar.css */

:root {
  --primary-color: #ffffff;
  --text-color: #1f2937;
  --text-secondary: #6b7280;
  --hover-bg: #f8fafc;
  --active-bg: #e0f2fe;
  --accent-blue: #2979ff;
  --accent-light: #64b5f6;
  --danger-red: #ef4444;
  --border-color: #e5e7eb;
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

.navbar {
  background-color: #ffffff;
  background-color: var(--primary-color);
  padding: 1rem 2rem;
  border-bottom: 1px solid #e5e7eb;
  border-bottom: 1px solid var(--border-color);
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 50;
  -webkit-backdrop-filter: blur(12px);
          backdrop-filter: blur(12px);
  background-color: rgba(255, 255, 255, 0.95);
  transition: all 0.3s ease;
}

.navbar-container {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.brand {
  font-size: 1.75rem;
  font-weight: 700;
  color: #1f2937;
  color: var(--text-color);
  text-decoration: none;
  transition: all 0.2s ease;
  letter-spacing: -0.02em;
  background: linear-gradient(135deg, #2979ff, #64b5f6);
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-light));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.brand:hover {
  transform: scale(1.02);
  filter: brightness(1.1);
}

.navbar-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* Shared base style for links */
.nav-link,
.demo-link {
  font-size: 0.925rem;
  font-weight: 500;
  text-decoration: none;
  color: #6b7280;
  color: var(--text-secondary);
  padding: 0.625rem 1rem;
  border-radius: 12px;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.nav-link::before,
.demo-link::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, rgba(41, 121, 255, 0.1), rgba(100, 181, 246, 0.1));
  opacity: 0;
  transition: opacity 0.2s ease;
  border-radius: 12px;
}

/* Enhanced hover effects */
.nav-link:hover,
.demo-link:hover {
  color: #2979ff;
  color: var(--accent-blue);
  font-weight: 600;
  transform: translateY(-1px);
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  box-shadow: var(--shadow-sm);
}

.nav-link:hover::before,
.demo-link:hover::before {
  opacity: 1;
}

/* Active route styling */
.nav-link.active {
  background: linear-gradient(135deg, rgba(41, 121, 255, 0.1), rgba(100, 181, 246, 0.1));
  color: #2979ff;
  color: var(--accent-blue);
  font-weight: 600;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  box-shadow: var(--shadow-sm);
  border: 1px solid rgba(41, 121, 255, 0.2);
}

/* Premium CTA Button */
.cta-pill {
  background: linear-gradient(135deg, #2979ff, #64b5f6);
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-light));
  color: white;
  padding: 0.625rem 1.25rem;
  border-radius: 12px;
  font-weight: 600;
  font-size: 0.875rem;
  text-decoration: none;
  border: none;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 4px 12px rgba(41, 121, 255, 0.2);
  position: relative;
  overflow: hidden;
}

.cta-pill::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 ease;
}

.cta-pill:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(41, 121, 255, 0.3);
  filter: brightness(1.05);
}

.cta-pill:hover::before {
  left: 100%;
}

.cta-pill:active {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(41, 121, 255, 0.4);
}

/* Elegant logout button */
.logout-link {
  background: none;
  border: 1px solid rgba(239, 68, 68, 0.2);
  cursor: pointer;
  font-size: 0.875rem;
  color: #ef4444;
  color: var(--danger-red);
  font-weight: 500;
  padding: 0.625rem 1rem;
  border-radius: 12px;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.logout-link::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(239, 68, 68, 0.05);
  opacity: 0;
  transition: opacity 0.2s ease;
  border-radius: 12px;
}

.logout-link:hover {
  color: #dc2626;
  font-weight: 600;
  transform: translateY(-1px);
  border-color: rgba(239, 68, 68, 0.3);
  box-shadow: 0 2px 8px rgba(239, 68, 68, 0.1);
}

.logout-link:hover::before {
  opacity: 1;
}

.logout-link:active {
  transform: translateY(0);
}

/* User Menu Styles */
.user-menu-container {
  position: relative;
  display: flex;
  align-items: center;
}

.user-menu-button {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 50%;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #6b7280;
  color: var(--text-secondary);
}

.user-menu-button:hover {
  background-color: #f8fafc;
  background-color: var(--hover-bg);
  color: #2979ff;
  color: var(--accent-blue);
  transform: scale(1.05);
}

.user-icon {
  width: 24px;
  height: 24px;
  transition: all 0.2s ease;
}

.user-dropdown {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 0.5rem;
  background: white;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--border-color);
  border-radius: 12px;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  box-shadow: var(--shadow-lg);
  min-width: 180px;
  z-index: 1000;
  overflow: hidden;
  animation: dropdownFadeIn 0.2s ease-out;
}

@keyframes dropdownFadeIn {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  padding: 0.875rem 1rem;
  border: none;
  background: none;
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 500;
  color: #6b7280;
  color: var(--text-secondary);
  transition: all 0.2s ease;
  text-align: left;
}

.dropdown-item:hover {
  background-color: #f8fafc;
  background-color: var(--hover-bg);
  color: #1f2937;
  color: var(--text-color);
}

.dropdown-item:first-child {
  border-top-left-radius: 12px;
  border-top-right-radius: 12px;
}

.dropdown-item:last-child {
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
}

.settings-item:hover {
  color: #2979ff;
  color: var(--accent-blue);
}

.admin-item:hover {
  color: #2979ff;
  color: var(--accent-blue);
}

.logout-item:hover {
  color: #ef4444;
  color: var(--danger-red);
}

.dropdown-item svg {
  flex-shrink: 0;
  transition: all 0.2s ease;
}

.settings-item:hover svg {
  color: #2979ff;
  color: var(--accent-blue);
}

.admin-item:hover svg {
  color: #2979ff;
  color: var(--accent-blue);
}

.logout-item:hover svg {
  color: #ef4444;
  color: var(--danger-red);
}

/* Desktop navigation - Clean and minimal */
@media (min-width: 769px) {
  .navbar-actions {
    gap: 1rem;
  }
  
  .nav-link,
  .demo-link {
    padding: 0.75rem 1.25rem;
    font-size: 1rem;
  }
  
  .logout-link {
    padding: 0.75rem 1.25rem;
    font-size: 1rem;
  }
}

/* Mobile-specific styles */
@media (max-width: 768px) {
  .navbar {
    padding: 0.875rem 1rem;
  }
  
  .navbar-container {
    gap: 0.75rem;
  }
  
  .navbar-actions {
    gap: 0.5rem;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  
  .navbar-actions::-webkit-scrollbar {
    display: none;
  }
  
  .nav-link,
  .demo-link {
    padding: 0.625rem 1rem;
    font-size: 0.9rem;
    white-space: nowrap;
    flex-shrink: 0;
  }
  
  .cta-pill {
    padding: 0.625rem 1.125rem;
    font-size: 0.875rem;
    white-space: nowrap;
    flex-shrink: 0;
  }
  
  .logout-link {
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    white-space: nowrap;
    flex-shrink: 0;
  }
  
  .brand {
    font-size: 1.5rem;
    flex-shrink: 0;
  }
  
  /* Ensure Tracker link is completely hidden on mobile */
  .nav-link[href="/tracker"],
  a[href*="tracker"] {
    display: none !important;
  }
}

@media (max-width: 480px) {
  .navbar {
    padding: 0.75rem 0.875rem;
  }
  
  .navbar-container {
    gap: 0.5rem;
  }
  
  .navbar-actions {
    gap: 0.375rem;
  }
  
  .nav-link,
  .demo-link {
    padding: 0.5rem 0.875rem;
    font-size: 0.85rem;
  }
  
  .cta-pill {
    padding: 0.5rem 1rem;
    font-size: 0.8rem;
  }
  
  .logout-link {
    padding: 0.5rem 0.875rem;
    font-size: 0.8rem;
  }
  
  .brand {
    font-size: 1.375rem;
  }
}

/* Smooth scrolling enhancement */
@media (prefers-reduced-motion: no-preference) {
  .navbar {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  }
}

/* Accessibility improvements */
@media (prefers-reduced-motion: reduce) {
  .nav-link,
  .demo-link,
  .cta-pill,
  .logout-link,
  .brand {
    transition: none;
  }
  
  .nav-link:hover,
  .demo-link:hover,
  .cta-pill:hover,
  .logout-link:hover,
  .brand:hover {
    transform: none;
  }
}

/* Clean spacing for authenticated users */
.navbar-actions:has(.nav-link) {
  gap: 0.75rem;
}

@media (max-width: 768px) {
  .navbar-actions:has(.nav-link) {
    gap: 0.5rem;
  }
  
  .user-dropdown {
    right: -0.5rem;
    min-width: 160px;
  }
  
  .dropdown-item {
    padding: 0.75rem 0.875rem;
    font-size: 0.8rem;
  }
}

@media (max-width: 480px) {
  .navbar-actions:has(.nav-link) {
    gap: 0.375rem;
  }
  
  .user-dropdown {
    right: -0.75rem;
    min-width: 140px;
  }
  
  .dropdown-item {
    padding: 0.625rem 0.75rem;
    font-size: 0.75rem;
  }
}

/* Profile Name Next to User Icon */
.user-profile-name {
  font-size: 0.875rem;
  color: #1f2937;
  color: var(--text-color);
  font-weight: 500;
  margin-left: 0.5rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 120px;
}

/* Dropdown Section Styles */
.dropdown-section {
  padding: 0.5rem 0;
}

.dropdown-section-title {
  font-size: 0.75rem;
  color: #6b7280;
  color: var(--text-secondary);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0.5rem 1rem 0.25rem 1rem;
  margin: 0;
}

.dropdown-divider {
  height: 1px;
  background: #e5e7eb;
  background: var(--border-color);
  margin: 0.5rem 0;
}

.profile-item {
  display: flex;
  align-items: center;
  width: 100%;
  padding: 0.75rem 1rem;
  background: transparent;
  border: none;
  color: #1f2937;
  color: var(--text-color);
  cursor: pointer;
  transition: all 0.2s ease;
  text-align: left;
}

.profile-item:hover:not(:disabled) {
  background: #f8fafc;
  background: var(--hover-bg);
}

.profile-item.active {
  background: #e0f2fe;
  background: var(--active-bg);
  color: #2979ff;
  color: var(--accent-blue);
}

.profile-item:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.profile-item-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

.profile-item-name {
  font-size: 0.875rem;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1 1;
}

.profile-item-badge {
  background: #2979ff;
  background: var(--accent-blue);
  color: white;
  padding: 0.125rem 0.5rem;
  border-radius: 12px;
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.025em;
  margin-left: 0.5rem;
  flex-shrink: 0;
}

/* Mobile Responsive */
@media (max-width: 768px) {
  .user-profile-name {
    max-width: 100px;
    font-size: 0.8rem;
  }
}
/* src/pages/LandingPage.css */

:root {
  --primary-color: #ffffff;
  --accent-blue: #2563eb;
  --accent-indigo: #4f46e5;
  --text-color: #111827;
  --text-secondary: #6b7280;
  --card-bg: #f8fafc;
  --card-border: #e5e7eb;
  --button-bg: #2563eb;
  --button-hover: #1d4ed8;
  --nav-bg: #ffffff;
  --gray-50: #f9fafb;
  --gray-100: #f3f4f6;
  --gray-200: #e5e7eb;
  --gray-300: #d1d5db;
  --gray-400: #9ca3af;
  --gray-500: #6b7280;
  --gray-600: #4b5563;
  --gray-700: #374151;
  --gray-800: #1f2937;
  --gray-900: #111827;
  --blue-50: #eff6ff;
  --blue-100: #dbeafe;
  --blue-200: #bfdbfe;
  --blue-300: #93c5fd;
  --blue-400: #60a5fa;
  --blue-500: #3b82f6;
  --blue-600: #2563eb;
  --blue-700: #1d4ed8;
  --blue-800: #1e40af;
  --indigo-50: #eef2ff;
  --indigo-100: #e0e7ff;
  --indigo-200: #c7d2fe;
  --indigo-300: #a5b4fc;
  --indigo-400: #818cf8;
  --indigo-500: #6366f1;
  --indigo-600: #4f46e5;
  --green-50: #f0fdf4;
  --green-100: #dcfce7;
  --green-200: #bbf7d0;
  --green-500: #22c55e;
  --green-600: #16a34a;
  --green-700: #15803d;
  --yellow-400: #facc15;
  --red-400: #f87171;
}

* {
  box-sizing: border-box;
}

body {
  font-family: 'Inter', sans-serif;
  margin: 0;
  background-color: #ffffff;
  color: #111827;
  color: var(--text-color);
  overflow-x: hidden;
}

.landing-container {
  width: 100%;
  margin: 0;
  padding: 0;
}

/* Utility Classes */
.min-h-screen { min-height: 100vh; }
.bg-white { background-color: #ffffff; background-color: var(--primary-color); }

/* Gradient Text Effect */
.bg-gradient-to-r { background-image: linear-gradient(to right, var(--tw-gradient-stops)); }
.from-blue-600 { --tw-gradient-from: var(--blue-600); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(37, 99, 235, 0)); }
.to-indigo-600 { --tw-gradient-to: var(--indigo-600); }
.bg-clip-text { -webkit-background-clip: text; background-clip: text; }
.text-transparent { color: transparent; }

/* Blur Utility */
.blur-3xl { filter: blur(64px); }
.bg-gray-50 { background-color: #f9fafb; background-color: var(--gray-50); }
.bg-gray-100 { background-color: #f3f4f6; background-color: var(--gray-100); }
.bg-gray-900 { background-color: #111827; background-color: var(--gray-900); }
.bg-blue-50 { background-color: #eff6ff; background-color: var(--blue-50); }
.bg-blue-100 { background-color: #dbeafe; background-color: var(--blue-100); }
.bg-blue-200 { background-color: #bfdbfe; background-color: var(--blue-200); }
.bg-blue-300 { background-color: #93c5fd; background-color: var(--blue-300); }
.bg-blue-400 { background-color: #60a5fa; background-color: var(--blue-400); }
.bg-blue-500 { background-color: #3b82f6; background-color: var(--blue-500); }
.bg-blue-600 { background-color: #2563eb; background-color: var(--blue-600); }
.bg-blue-700 { background-color: #1d4ed8; background-color: var(--blue-700); }
.bg-blue-800 { background-color: #1e40af; background-color: var(--blue-800); }

/* Background Opacity Utilities */
.bg-blue-200\/30 { background-color: rgba(191, 219, 254, 0.3); }
.bg-indigo-200\/20 { background-color: rgba(199, 210, 254, 0.2); }
.bg-indigo-50 { background-color: #eef2ff; background-color: var(--indigo-50); }
.bg-indigo-100 { background-color: #e0e7ff; background-color: var(--indigo-100); }
.bg-indigo-200 { background-color: #c7d2fe; background-color: var(--indigo-200); }
.bg-indigo-500 { background-color: #6366f1; background-color: var(--indigo-500); }
.bg-indigo-600 { background-color: #4f46e5; background-color: var(--indigo-600); }
.bg-green-50 { background-color: #f0fdf4; background-color: var(--green-50); }
.bg-green-100 { background-color: #dcfce7; background-color: var(--green-100); }
.bg-green-200 { background-color: #bbf7d0; background-color: var(--green-200); }
.bg-green-500 { background-color: #22c55e; background-color: var(--green-500); }
.bg-green-600 { background-color: #16a34a; background-color: var(--green-600); }
.bg-green-700 { background-color: #15803d; background-color: var(--green-700); }
.bg-yellow-400 { background-color: #facc15; background-color: var(--yellow-400); }
.bg-red-400 { background-color: #f87171; background-color: var(--red-400); }

.text-white { color: white; }
.text-gray-50 { color: #f9fafb; color: var(--gray-50); }
.text-gray-100 { color: #f3f4f6; color: var(--gray-100); }
.text-gray-200 { color: #e5e7eb; color: var(--gray-200); }
.text-gray-300 { color: #d1d5db; color: var(--gray-300); }
.text-gray-400 { color: #9ca3af; color: var(--gray-400); }
.text-gray-500 { color: #6b7280; color: var(--gray-500); }
.text-gray-600 { color: #4b5563; color: var(--gray-600); }
.text-gray-700 { color: #374151; color: var(--gray-700); }
.text-gray-800 { color: #1f2937; color: var(--gray-800); }
.text-gray-900 { color: #111827; color: var(--gray-900); }
.text-blue-50 { color: #eff6ff; color: var(--blue-50); }
.text-blue-100 { color: #dbeafe; color: var(--blue-100); }
.text-blue-200 { color: #bfdbfe; color: var(--blue-200); }
.text-blue-300 { color: #93c5fd; color: var(--blue-300); }
.text-blue-400 { color: #60a5fa; color: var(--blue-400); }
.text-blue-500 { color: #3b82f6; color: var(--blue-500); }
.text-blue-600 { color: #2563eb; color: var(--blue-600); }
.text-blue-700 { color: #1d4ed8; color: var(--blue-700); }
.text-blue-800 { color: #1e40af; color: var(--blue-800); }
.text-indigo-50 { color: #eef2ff; color: var(--indigo-50); }
.text-indigo-100 { color: #e0e7ff; color: var(--indigo-100); }
.text-indigo-200 { color: #c7d2fe; color: var(--indigo-200); }
.text-indigo-500 { color: #6366f1; color: var(--indigo-500); }
.text-indigo-600 { color: #4f46e5; color: var(--indigo-600); }
.text-green-50 { color: #f0fdf4; color: var(--green-50); }
.text-green-100 { color: #dcfce7; color: var(--green-100); }
.text-green-200 { color: #bbf7d0; color: var(--green-200); }
.text-green-500 { color: #22c55e; color: var(--green-500); }
.text-green-600 { color: #16a34a; color: var(--green-600); }
.text-green-700 { color: #15803d; color: var(--green-700); }
.text-yellow-400 { color: #facc15; color: var(--yellow-400); }
.text-red-400 { color: #f87171; color: var(--red-400); }

/* Additional Text Utilities */
.text-xs { font-size: 0.75rem; }
.text-2xl { font-size: 1.5rem; }
.text-italic { font-style: italic; }

.border { border-width: 1px; }
.border-2 { border-width: 2px; }
.border-t { border-top-width: 1px; }
.border-gray-100 { border-color: #f3f4f6; border-color: var(--gray-100); }
.border-gray-200 { border-color: #e5e7eb; border-color: var(--gray-200); }
.border-gray-800 { border-color: #1f2937; border-color: var(--gray-800); }
.border-blue-300 { border-color: #93c5fd; border-color: var(--blue-300); }

.rounded-lg { border-radius: 0.5rem; }
.rounded-xl { border-radius: 0.75rem; }
.rounded-2xl { border-radius: 1rem; }
.rounded-full { border-radius: 9999px; }

.shadow-lg { box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05); }
.shadow-xl { box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04); }
.shadow-2xl { box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25); }

.overflow-hidden { overflow: hidden; }

.relative { position: relative; }
.absolute { position: absolute; }
.sticky { position: -webkit-sticky; position: sticky; }
.top-0 { top: 0; }
.z-50 { z-index: 50; }

.inset-0 { top: 0; right: 0; bottom: 0; left: 0; }

/* Additional Positioning Utilities */
.top-20 { top: 5rem; }
.left-10 { left: 2.5rem; }
.right-10 { right: 2.5rem; }
.bottom-20 { bottom: 5rem; }
.-top-4 { top: -1rem; }
.-right-4 { right: -1rem; }
.-bottom-4 { bottom: -1rem; }
.-left-4 { left: -1rem; }

.px-3 { padding-left: 0.75rem; padding-right: 0.75rem; }
.px-4 { padding-left: 1rem; padding-right: 1rem; }
.px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }
.px-8 { padding-left: 2rem; padding-right: 2rem; }

.p-4 { padding: 1rem; }
.p-6 { padding: 1.5rem; }
.p-8 { padding: 2rem; }

.py-2 { padding-top: 0.5rem; padding-bottom: 0.5rem; }
.py-3 { padding-top: 0.75rem; padding-bottom: 0.75rem; }
.py-4 { padding-top: 1rem; padding-bottom: 1rem; }
.py-6 { padding-top: 1.5rem; padding-bottom: 1.5rem; }
.py-8 { padding-top: 2rem; padding-bottom: 2rem; }
.py-12 { padding-top: 3rem; padding-bottom: 3rem; }
.py-20 { padding-top: 5rem; padding-bottom: 5rem; }
.py-24 { padding-top: 6rem; padding-bottom: 6rem; }

.pt-8 { padding-top: 2rem; }
.pt-16 { padding-top: 4rem; }
.pt-20 { padding-top: 5rem; }
.pt-24 { padding-top: 6rem; }
.pt-32 { padding-top: 8rem; }
.pt-40 { padding-top: 10rem; }

.pb-8 { padding-bottom: 2rem; }
.pb-16 { padding-bottom: 4rem; }
.pb-20 { padding-bottom: 5rem; }
.pb-24 { padding-bottom: 6rem; }
.pb-32 { padding-bottom: 8rem; }

.mb-2 { margin-bottom: 0.5rem; }
.mb-4 { margin-bottom: 1rem; }
.mb-6 { margin-bottom: 1.5rem; }
.mb-8 { margin-bottom: 2rem; }
.mb-16 { margin-bottom: 4rem; }
.mb-20 { margin-bottom: 5rem; }
.mb-24 { margin-bottom: 6rem; }

.ml-2 { margin-left: 0.5rem; }
.ml-4 { margin-left: 1rem; }

.mt-6 { margin-top: 1.5rem; }
.mt-8 { margin-top: 2rem; }

.max-w-4xl { max-width: 56rem; }
.max-w-7xl { max-width: 80rem; }

.mx-auto { margin-left: auto; margin-right: auto; }

.w-3 { width: 0.75rem; }
.w-4 { width: 1rem; }
.w-5 { width: 1.25rem; }
.w-7 { width: 1.75rem; }
.w-8 { width: 2rem; }
.w-14 { width: 3.5rem; }
.w-16 { width: 4rem; }
.w-72 { width: 18rem; }
.w-96 { width: 24rem; }

.h-3 { height: 0.75rem; }
.h-4 { height: 1rem; }
.h-5 { height: 1.25rem; }
.h-7 { height: 1.75rem; }
.h-8 { height: 2rem; }
.h-14 { height: 3.5rem; }
.h-16 { height: 4rem; }
.h-72 { height: 18rem; }
.h-96 { height: 24rem; }

.text-sm { font-size: 0.875rem; }
.text-lg { font-size: 1.125rem; }
.text-xl { font-size: 1.25rem; }
.text-2xl { font-size: 1.5rem; }
.text-4xl { font-size: 2.25rem; }
.text-5xl { font-size: 3rem; }
.text-6xl { font-size: 3.75rem; }

.font-medium { font-weight: 500; }
.font-semibold { font-weight: 600; }
.font-bold { font-weight: 700; }

.leading-tight { line-height: 1.25; }
.leading-relaxed { line-height: 1.625; }

.text-center { text-align: center; }
.text-left { text-align: left; }

.inline-flex { display: inline-flex; }
.flex { display: flex; }

/* Inline Flex Utilities */
.inline-flex { display: inline-flex; }
.grid { display: grid; }
.hidden { display: none; }

/* Flex Utilities */
.flex-col { flex-direction: column; }
.flex-row { flex-direction: row; }
.items-center { align-items: center; }
.items-start { align-items: flex-start; }
.items-end { align-items: flex-end; }
.items-stretch { align-items: stretch; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.justify-start { justify-content: flex-start; }
.justify-end { justify-content: flex-end; }

.gap-1 { gap: 0.25rem; }
.gap-2 { gap: 0.5rem; }
.gap-3 { gap: 0.75rem; }
.gap-4 { gap: 1rem; }
.gap-6 { gap: 1.5rem; }
.gap-8 { gap: 2rem; }
.gap-12 { gap: 3rem; }

.space-y-2 > * + * { margin-top: 0.5rem; }
.space-y-3 > * + * { margin-top: 0.75rem; }
.space-y-4 > * + * { margin-top: 1rem; }

.group:hover .group-hover\:scale-110 { transform: scale(1.1); }
.group:hover .group-hover\:border-blue-200 { border-color: #bfdbfe; border-color: var(--blue-200); }
.group:hover .group-hover\:shadow-xl { box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04); }
.group:hover .group-hover\:-translate-y-2 { transform: translateY(-0.5rem); }

.hover\:bg-blue-50:hover { background-color: #eff6ff; background-color: var(--blue-50); }
.hover\:bg-blue-700:hover { background-color: #1d4ed8; background-color: var(--blue-700); }
.hover\:border-blue-300:hover { border-color: #93c5fd; border-color: var(--blue-300); }
.hover\:text-blue-600:hover { color: #2563eb; color: var(--blue-600); }
.hover\:shadow-xl:hover { box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04); }
.hover\:-translate-y-1:hover { transform: translateY(-0.25rem); }

.transition-all { transition-property: all; }
.transition-colors { transition-property: color, background-color, border-color, fill, stroke, -webkit-text-decoration-color; transition-property: color, background-color, border-color, text-decoration-color, fill, stroke; transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, -webkit-text-decoration-color; }
.transition-transform { transition-property: transform; }

.duration-200 { transition-duration: 200ms; }
.duration-300 { transition-duration: 300ms; }
.duration-1000 { transition-duration: 1000ms; }

.delay-300 { transition-delay: 300ms; }

.backdrop-blur-md { -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px); }

/* Additional Transition Utilities */
.transition-opacity { transition-property: opacity; }

.bg-gradient-to-br { background-image: linear-gradient(to bottom right, var(--tw-gradient-stops)); }
.bg-gradient-to-r { background-image: linear-gradient(to right, var(--tw-gradient-stops)); }

.from-blue-50 { --tw-gradient-from: var(--blue-50); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(239, 246, 255, 0)); }
.from-blue-200 { --tw-gradient-from: var(--blue-200); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(191, 219, 254, 0)); }
.from-blue-500 { --tw-gradient-from: var(--blue-500); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(59, 130, 246, 0)); }
.from-blue-600 { --tw-gradient-from: var(--blue-600); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(37, 99, 235, 0)); }
.from-blue-600 { --tw-gradient-from: var(--blue-600); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(37, 99, 235, 0)); }
.from-indigo-50 { --tw-gradient-from: var(--indigo-50); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(238, 242, 255, 0)); }
.from-indigo-200 { --tw-gradient-from: var(--indigo-200); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(199, 210, 254, 0)); }
.from-indigo-500 { --tw-gradient-from: var(--indigo-500); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(99, 102, 241, 0)); }
.from-indigo-600 { --tw-gradient-from: var(--indigo-600); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(79, 70, 229, 0)); }
.from-green-500 { --tw-gradient-from: var(--green-500); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(34, 197, 94, 0)); }
.from-green-600 { --tw-gradient-from: var(--green-600); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(22, 163, 74, 0)); }

.to-blue-400 { --tw-gradient-to: var(--blue-400); }
.to-blue-600 { --tw-gradient-to: var(--blue-600); }
.to-blue-700 { --tw-gradient-to: var(--blue-700); }
.to-indigo-20 { --tw-gradient-to: rgba(79, 70, 229, 0.2); }
.to-indigo-600 { --tw-gradient-to: var(--indigo-600); }
.to-green-600 { --tw-gradient-to: var(--green-600); }

.via-white { --tw-gradient-stops: var(--tw-gradient-from), #ffffff, var(--tw-gradient-to, rgba(255, 255, 255, 0)); }

.bg-clip-text { -webkit-background-clip: text; background-clip: text; }

.blur-3xl { filter: blur(64px); }

.opacity-60 { opacity: 0.6; }
.opacity-100 { opacity: 1; }

.cursor-not-allowed { cursor: not-allowed; }

.fill-current { fill: currentColor; }

/* Responsive Design */
@media (min-width: 640px) {
  .sm\:px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }
  .sm\:flex-row { flex-direction: row; }
  .sm\:text-lg { font-size: 1.125rem; }
}

@media (min-width: 768px) {
  .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (min-width: 1024px) {
  .lg\:px-8 { padding-left: 2rem; padding-right: 2rem; }
  .lg\:py-32 { padding-top: 8rem; padding-bottom: 8rem; }
  .lg\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .lg\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .lg\:text-5xl { font-size: 3rem; }
  .lg\:text-6xl { font-size: 3.75rem; }
}

/* Animation Classes */
.translate-y-0 { transform: translateY(0); }
.translate-y-8 { transform: translateY(2rem); }

/* Opacity Classes */
.opacity-0 { opacity: 0; }
.opacity-100 { opacity: 1; }

/* Custom Animations */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(2rem);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.transition-all.duration-1000 {
  animation: fadeInUp 1s ease-out;
}

/* Additional Utility Classes */
.bg-white\/80 { background-color: rgba(255, 255, 255, 0.8); }
.bg-blue-200\/30 { background-color: rgba(191, 219, 254, 0.3); }
.bg-indigo-200\/20 { background-color: rgba(199, 210, 254, 0.2); }

/* Button Styles */
.bg-blue-600 {
  background-color: #2563eb;
  background-color: var(--blue-600);
  color: white;
  padding: 1rem 2rem;
  border-radius: 0.75rem;
  font-weight: 600;
  font-size: 1.125rem;
  text-decoration: none;
  transition: all 0.2s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  border: none;
  cursor: pointer;
}

.bg-blue-600:hover {
  background-color: #1d4ed8;
  background-color: var(--blue-700);
  transform: translateY(-0.25rem);
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}

.border-2.border-gray-200 {
  border: 2px solid #e5e7eb;
  border: 2px solid var(--gray-200);
  color: #374151;
  color: var(--gray-700);
  padding: 1rem 2rem;
  border-radius: 0.75rem;
  font-weight: 600;
  font-size: 1.125rem;
  transition: all 0.2s ease;
  background: transparent;
  cursor: pointer;
}

.border-2.border-gray-200:hover {
  border-color: #93c5fd;
  border-color: var(--blue-300);
  background-color: #eff6ff;
  background-color: var(--blue-50);
}

/* Feature Cards */
.group {
  padding: 2rem;
  border-radius: 1rem;
  border: 1px solid #f3f4f6;
  border: 1px solid var(--gray-100);
  transition: all 0.3s ease;
  cursor: pointer;
}

.group:hover {
  border-color: #bfdbfe;
  border-color: var(--blue-200);
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  transform: translateY(-0.5rem);
}

/* Dashboard Mockup */
.bg-white.rounded-2xl.shadow-2xl {
  background: white;
  border-radius: 1rem;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  border: 1px solid #f3f4f6;
  border: 1px solid var(--gray-100);
  overflow: hidden;
}

.bg-gray-50 {
  background-color: #f9fafb;
  background-color: var(--gray-50);
  padding: 1.5rem;
  border-bottom: 1px solid #f3f4f6;
  border-bottom: 1px solid var(--gray-100);
}

/* Floating Elements */
.absolute.-top-4.-right-4,
.absolute.-bottom-4.-left-4 {
  position: absolute;
  padding: 0.75rem 1rem;
  border-radius: 0.5rem;
  font-size: 0.875rem;
  font-weight: 600;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

.absolute.-top-4.-right-4 {
  top: -1rem;
  right: -1rem;
  background-color: #dcfce7;
  background-color: var(--green-100);
  color: #15803d;
  color: var(--green-700);
}

.absolute.-bottom-4.-left-4 {
  bottom: -1rem;
  left: -1rem;
  background-color: #dbeafe;
  background-color: var(--blue-100);
  color: #1d4ed8;
  color: var(--blue-700);
}

/* Social Proof Section */
.bg-gray-50 {
  background-color: #f9fafb;
  background-color: var(--gray-50);
}

.bg-white.rounded-2xl.p-8.shadow-lg {
  background: white;
  border-radius: 1rem;
  padding: 2rem;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  border: 1px solid #f3f4f6;
  border: 1px solid var(--gray-100);
}

/* CTA Section */
.border-t.border-gray-100 {
  border-top: 1px solid #f3f4f6;
  border-top: 1px solid var(--gray-100);
}

/* Footer */
.bg-gray-900 {
  background-color: #111827;
  background-color: var(--gray-900);
  color: white;
  padding: 3rem 0;
}

/* Mobile Responsive Design */
@media (max-width: 768px) {
  /* Hero Section Mobile Fixes */
  .text-5xl, .lg\:text-6xl {
    font-size: 2.25rem !important;
    line-height: 1.2 !important;
  }
  
  .text-xl {
    font-size: 1rem !important;
    line-height: 1.5 !important;
  }
  
  .py-20 {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  
  .py-24 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  
  .px-4, .sm\:px-6, .lg\:px-8 {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  
  .gap-12 {
    gap: 1.5rem !important;
  }
  
  .gap-8 {
    gap: 1rem !important;
  }
  
  .gap-6 {
    gap: 0.75rem !important;
  }
  
  /* Grid Layouts - Stack on Mobile */
  .grid.lg\:grid-cols-2 {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }
  
  .md\:grid-cols-2, .md\:grid-cols-3 {
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
  }
  
  .lg\:grid-cols-4 {
    grid-template-columns: 1fr !important;
  }
  
  /* Flex Direction Changes */
  .flex.sm\:flex-row {
    flex-direction: column !important;
    gap: 1rem !important;
  }
  
  .justify-center {
    justify-content: center !important;
  }
  
  /* Button Adjustments */
  .bg-blue-600, .border-2.border-gray-200 {
    width: 100% !important;
    padding: 0.875rem 1.5rem !important;
    font-size: 1rem !important;
    justify-content: center !important;
  }
  
  /* Feature Cards Mobile */
  .group {
    padding: 1.5rem !important;
    margin-bottom: 1rem !important;
  }
  
  .group .w-14 {
    width: 3rem !important;
    height: 3rem !important;
  }
  
  .group h3 {
    font-size: 1.125rem !important;
    margin-bottom: 0.75rem !important;
  }
  
  .group p {
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
  }
  
  /* Stats Section Mobile */
  .grid.md\:grid-cols-3 {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }
  
  .grid.md\:grid-cols-3 .text-center {
    padding: 1rem !important;
  }
  
  .grid.md\:grid-cols-3 .w-16 {
    width: 3rem !important;
    height: 3rem !important;
  }
  
  .grid.md\:grid-cols-3 .text-4xl {
    font-size: 2.5rem !important;
  }
  
  /* Testimonial Card Mobile */
  .bg-white.rounded-2xl.p-8.shadow-lg {
    padding: 1.5rem !important;
    margin: 0 0.5rem !important;
  }
  
  .bg-white.rounded-2xl.p-8.shadow-lg p {
    font-size: 1rem !important;
    line-height: 1.6 !important;
  }
  
  .bg-white.rounded-2xl.p-8.shadow-lg footer {
    font-size: 0.875rem !important;
  }
  
  /* CTA Section Mobile */
  .max-w-4xl {
    max-width: 100% !important;
    padding: 0 1rem !important;
  }
  
  .text-4xl, .lg\:text-5xl {
    font-size: 2rem !important;
    line-height: 1.2 !important;
  }
  
  /* Floating Elements Mobile - Hide or Reposition */
  .absolute.-top-4.-right-4,
  .absolute.-bottom-4.-left-4 {
    position: static !important;
    margin: 1rem 0 !important;
    display: inline-block !important;
  }
  
  /* Dashboard Mockup Mobile */
  .bg-white.rounded-2xl.shadow-2xl {
    margin: 1rem 0 !important;
  }
  
  .bg-gray-50 {
    padding: 1rem !important;
  }
  
  .space-y-2 > * + * {
    margin-top: 0.5rem !important;
  }
  
  .space-y-3 > * + * {
    margin-top: 0.75rem !important;
  }
  
  /* Hero Section Feature Highlights Mobile */
  .flex.items-center.gap-6 {
    flex-direction: column !important;
    gap: 1rem !important;
    align-items: flex-start !important;
  }
  
  .flex.items-center.gap-6 > div {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
  }
  
  /* Ensure proper spacing */
  .mb-8 {
    margin-bottom: 1.5rem !important;
  }
  
  .mb-16 {
    margin-bottom: 2rem !important;
  }
  
  .mb-6 {
    margin-bottom: 1rem !important;
  }
  
  .mb-4 {
    margin-bottom: 0.75rem !important;
  }
  
  /* Additional Mobile Optimizations */
  
  /* Features Section - Better Mobile Layout */
  .flex.flex-row.gap-8.justify-center {
    flex-direction: column !important;
    gap: 1.5rem !important;
    align-items: center !important;
  }
  
  /* Hero Section - Better Text Spacing */
  .text-5xl.lg\:text-6xl.font-bold.text-gray-900.leading-tight.mb-6 {
    margin-bottom: 1rem !important;
  }
  
  .text-xl.text-gray-600.mb-8.leading-relaxed {
    margin-bottom: 1.5rem !important;
  }
  
  /* Hero Section - Better Button Spacing */
  .flex.flex-col.sm\:flex-row.gap-4.mb-8 {
    margin-bottom: 2rem !important;
  }
  
  /* Hero Section - Feature Highlights Better Mobile Layout */
  .flex.items-center.gap-6.text-sm.text-gray-500 {
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 1rem !important;
  }
  
  .flex.items-center.gap-6.text-sm.text-gray-500 > div {
    flex: 1 1 auto !important;
    min-width: 140px !important;
    justify-content: center !important;
  }
  
  /* Dashboard Mockup - Better Mobile Sizing */
  .relative.max-w-7xl.mx-auto.px-4.sm\:px-6.lg\:px-8.py-20.lg\:py-32 {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  
  /* Social Proof Section - Better Mobile Layout */
  .text-center.mb-16 {
    margin-bottom: 2rem !important;
  }
  
  .text-4xl.font-bold.text-gray-900.mb-4 {
    font-size: 2rem !important;
    margin-bottom: 1rem !important;
  }
  
  .text-xl.text-gray-600 {
    font-size: 1rem !important;
  }
  
  /* Testimonial Section - Better Mobile Spacing */
  .bg-white.rounded-2xl.p-8.shadow-lg.border.border-gray-100.mb-16 {
    margin-bottom: 2rem !important;
  }
  
  /* CTA Section - Better Mobile Layout */
  .py-20.bg-white.border-t.border-gray-100 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  
  .text-4xl.lg\:text-5xl.font-bold.mb-6.text-gray-900 {
    font-size: 1.75rem !important;
    margin-bottom: 1rem !important;
  }
  
  .text-xl.mb-8.text-gray-600 {
    font-size: 1rem !important;
    margin-bottom: 1.5rem !important;
  }
  
  .flex.flex-col.sm\:flex-row.gap-4.justify-center {
    gap: 1rem !important;
  }
  
  /* Footer Mobile Improvements */
  .footer-sections {
    flex-direction: column !important;
    gap: 2rem !important;
    align-items: center !important;
    text-align: center !important;
  }
  
  .footer-sections > div:last-child {
    flex-direction: column !important;
    gap: 2rem !important;
    width: 100% !important;
  }
  
  .footer-sections > div:last-child > div {
    width: 100% !important;
  }
  
  /* Ensure proper mobile spacing for all sections */
  section {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  
  /* Better mobile typography */
  h1, h2, h3 {
    word-wrap: break-word !important;
    -webkit-hyphens: auto !important;
            hyphens: auto !important;
  }
  
  /* Mobile-specific button improvements */
  button, a[role="button"] {
    min-height: 44px !important; /* iOS touch target minimum */
    touch-action: manipulation !important;
  }
  
  /* Better mobile scrolling */
  .overflow-hidden {
    overflow-x: hidden !important;
  }
  
  /* Mobile-specific spacing adjustments */
  .max-w-7xl {
    max-width: 100% !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
}

/* Extra Small Mobile Devices (320px - 480px) */
@media (max-width: 480px) {
  /* Even smaller text for very small screens */
  .text-5xl, .lg\:text-6xl {
    font-size: 1.875rem !important;
  }
  
  .text-4xl {
    font-size: 1.5rem !important;
  }
  
  .text-xl {
    font-size: 0.875rem !important;
  }
  
  /* Tighter spacing for very small screens */
  .py-20 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  
  .py-24 {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  
  .mb-8 {
    margin-bottom: 1rem !important;
  }
  
  .mb-16 {
    margin-bottom: 1.5rem !important;
  }
  
  /* Smaller padding for very small screens */
  .px-4, .sm\:px-6, .lg\:px-8 {
    padding-left: 0.75rem !important;
    padding-right: 0.75rem !important;
  }
  
  /* Smaller buttons for very small screens */
  .bg-blue-600, .border-2.border-gray-200 {
    padding: 0.75rem 1rem !important;
    font-size: 0.875rem !important;
  }
  
  /* Smaller feature cards */
  .group {
    padding: 1rem !important;
  }
  
  .group .w-14 {
    width: 2.5rem !important;
    height: 2.5rem !important;
  }
  
  /* Smaller stats */
  .grid.md\:grid-cols-3 .text-4xl {
    font-size: 2rem !important;
  }
  
  .grid.md\:grid-cols-3 .w-16 {
    width: 2.5rem !important;
    height: 2.5rem !important;
  }
}

/* Landscape Mobile Orientation */
@media (max-width: 768px) and (orientation: landscape) {
  /* Reduce vertical padding in landscape */
  .py-20 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  
  .py-24 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  
  /* Make hero section more compact in landscape */
  .text-5xl, .lg\:text-6xl {
    font-size: 2rem !important;
  }
  
  .text-xl {
    font-size: 0.875rem !important;
  }
  
  /* Stack features in 2 columns in landscape */
  .flex.flex-row.gap-8.justify-center {
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 1rem !important;
  }
  
  .flex.flex-row.gap-8.justify-center > div {
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: calc(50% - 0.5rem);
    max-width: calc(50% - 0.5rem) !important;
  }
}

/* Mobile-Only Message Page Styles */
.mobile-only-container {
  min-height: 100vh;
  background: linear-gradient(135deg, #eff6ff 0%, #ffffff 50%, #e0e7ff 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  font-family: 'Inter', sans-serif;
}

.mobile-only-content {
  max-width: 500px;
  width: 100%;
  background: white;
  border-radius: 1.5rem;
  padding: 1.5rem;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* Mobile Logo Container and Logo */
.mobile-logo-container {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 1.5rem;
  margin-top: 1rem;
}

.mobile-logo {
  width: 4rem;
  height: 4rem;
  object-fit: contain;
}

/* Mobile Typography */
.mobile-main-heading {
  font-size: 2rem;
  font-weight: 700;
  color: #111827;
  line-height: 1.2;
  margin-bottom: 1.5rem;
  word-wrap: break-word;
  -webkit-hyphens: auto;
          hyphens: auto;
}

.mobile-description {
  font-size: 1rem;
  color: #6b7280;
  line-height: 1.5;
  margin-bottom: 2rem;
  word-wrap: break-word;
}

.mobile-desktop-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: #111827;
  margin-bottom: 1rem;
  line-height: 1.3;
}

.mobile-desktop-description {
  font-size: 0.875rem;
  color: #6b7280;
  line-height: 1.5;
  margin-bottom: 1.5rem;
  word-wrap: break-word;
}

.mobile-only-content::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #3b82f6, #6366f1);
}

.mobile-header {
  margin-bottom: 2rem;
}

.mobile-main-content {
  margin-bottom: 2rem;
}

.desktop-only-message {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 1rem;
  padding: 2rem;
  margin: 2rem 0;
  position: relative;
}

.desktop-icon {
  margin-bottom: 1.5rem;
  display: flex;
  justify-content: center;
}

.coming-soon-badge {
  margin-top: 1.5rem;
}

.mobile-features {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 2rem;
  padding: 1.5rem;
  background: #f8fafc;
  border-radius: 1rem;
  border: 1px solid #e2e8f0;
}

.feature-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  justify-content: center;
  font-size: 0.875rem;
  color: #4b5563;
  font-weight: 500;
}

.mobile-footer {
  border-top: 1px solid #e5e7eb;
  padding-top: 1.5rem;
  margin-top: 2rem;
}

/* Hide user profile section on mobile landing page */
@media (max-width: 768px) {
  .user-menu-container {
    display: none !important;
  }
}

/* Responsive Breakpoints for Mobile-Only Page */

/* Small Mobile (350px and below) */
@media (max-width: 350px) {
  /* Hide thunder icon on small screens */
  .inline-flex.items-center.gap-2.bg-blue-100.text-blue-700.px-4.py-2.rounded-full.text-sm.font-semibold.mb-8 svg {
    display: none;
  }
}

/* Very Small Mobile (320px and below) */
@media (max-width: 320px) {
  .mobile-only-container {
    padding: 0.5rem;
    min-height: 100vh;
  }
  
  .mobile-only-content {
    padding: 1.25rem;
    border-radius: 0.75rem;
    max-width: 100%;
    margin: 0;
  }
  
  .mobile-logo {
    width: 2.5rem;
    height: 2.5rem;
  }
  
  .mobile-logo-container {
    margin-top: 0.75rem;
    margin-bottom: 1.25rem;
  }
  
  .mobile-main-heading {
    font-size: 1.25rem;
    margin-bottom: 0.75rem;
    line-height: 1.2;
    word-break: break-word;
  }
  
  .mobile-description {
    font-size: 0.8rem;
    margin-bottom: 1rem;
    line-height: 1.4;
    word-break: break-word;
  }
  
  .mobile-desktop-title {
    font-size: 1.125rem;
    margin-bottom: 0.5rem;
    line-height: 1.2;
  }
  
  .mobile-desktop-description {
    font-size: 0.75rem;
    margin-bottom: 1rem;
    line-height: 1.4;
    word-break: break-word;
  }
  
  .desktop-only-message {
    padding: 0.75rem;
    margin: 1.25rem 0;
  }
  
  .desktop-icon svg {
    width: 1.75rem;
    height: 1.75rem;
  }
  
  .mobile-features {
    padding: 0.75rem;
    margin-top: 1.25rem;
    gap: 0.75rem;
  }
  
  .feature-item {
    font-size: 0.75rem;
    gap: 0.375rem;
    justify-content: flex-start;
    text-align: left;
    padding: 0.5rem 0;
  }
  
  .feature-item svg {
    width: 1rem;
    height: 1rem;
    flex-shrink: 0;
  }
  
  .feature-item span {
    flex: 1 1;
    word-break: break-word;
    overflow-wrap: break-word;
  }
  
  .mobile-footer {
    margin-top: 1.25rem;
    padding-top: 0.75rem;
  }
  
  .mobile-footer p {
    font-size: 0.75rem;
    line-height: 1.3;
    word-break: break-word;
  }
  
  /* Feature tag adjustments */
  .inline-flex.items-center.gap-2.bg-blue-100.text-blue-700.px-4.py-2.rounded-full.text-sm.font-semibold.mb-8 {
    padding: 0.375rem 0.5rem;
    font-size: 0.7rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  
  
  /* Coming soon badge adjustments */
  .coming-soon-badge span {
    padding: 0.5rem 0.75rem;
    font-size: 0.75rem;
    white-space: nowrap;
  }
  
  /* Ensure all text fits properly */
  * {
    max-width: 100%;
    box-sizing: border-box;
  }
  
  /* Prevent horizontal overflow */
  .mobile-only-content * {
    word-wrap: break-word;
    overflow-wrap: break-word;
    -webkit-hyphens: auto;
            hyphens: auto;
  }
}

/* Small Mobile (400px and below) */
@media (max-width: 400px) {
  .mobile-only-container {
    padding: 0.75rem;
  }
  
  .mobile-only-content {
    padding: 1rem;
    border-radius: 1rem;
  }
  
  .mobile-logo {
    width: 3rem;
    height: 3rem;
  }
  
  .mobile-logo-container {
    margin-top: 0.875rem;
  }
  
  .mobile-main-heading {
    font-size: 1.5rem;
    margin-bottom: 1rem;
  }
  
  .mobile-description {
    font-size: 0.875rem;
    margin-bottom: 1.5rem;
  }
  
  .mobile-desktop-title {
    font-size: 1.25rem;
  }
  
  .mobile-desktop-description {
    font-size: 0.8rem;
  }
  
  .desktop-only-message {
    padding: 1rem;
    margin: 1.5rem 0;
  }
  
  .desktop-icon svg {
    width: 2.5rem;
    height: 2.5rem;
  }
  
  .mobile-features {
    padding: 0.75rem;
    margin-top: 1.5rem;
  }
  
  .feature-item {
    font-size: 0.8rem;
    gap: 0.5rem;
  }
  
  .mobile-footer {
    margin-top: 1.5rem;
    padding-top: 1rem;
  }
}

/* Small Mobile (480px and below) */
@media (max-width: 480px) {
  .mobile-only-container {
    padding: 1rem 0.75rem;
  }
  
  .mobile-only-content {
    padding: 1.25rem;
    border-radius: 1rem;
  }
  
  .mobile-logo {
    width: 3.5rem;
    height: 3.5rem;
  }
  
  .mobile-logo-container {
    margin-top: 1rem;
  }
  
  .mobile-main-heading {
    font-size: 1.75rem;
    margin-bottom: 1.25rem;
  }
  
  .mobile-description {
    font-size: 0.9rem;
    margin-bottom: 1.75rem;
  }
  
  .mobile-desktop-title {
    font-size: 1.375rem;
  }
  
  .mobile-desktop-description {
    font-size: 0.85rem;
  }
  
  .desktop-only-message {
    padding: 1.25rem;
    margin: 1.75rem 0;
  }
  
  .desktop-icon svg {
    width: 3rem;
    height: 3rem;
  }
  
  .mobile-features {
    padding: 1rem;
    margin-top: 1.75rem;
  }
  
  .feature-item {
    font-size: 0.85rem;
  }
}

/* Large Mobile (640px and below) */
@media (max-width: 640px) {
  .mobile-only-content {
    max-width: 450px;
  }
  
  .mobile-main-heading {
    font-size: 1.875rem;
  }
  
  .mobile-description {
    font-size: 0.95rem;
  }
  
  .mobile-desktop-title {
    font-size: 1.5rem;
  }
  
  .mobile-desktop-description {
    font-size: 0.9rem;
  }
}

/* Ensure mobile-only page is not affected by desktop styles */
.mobile-only-container * {
  box-sizing: border-box;
}

.mobile-only-container .bg-gradient-to-r {
  background-image: linear-gradient(to right, #3b82f6, #6366f1);
}

.mobile-only-container .bg-clip-text {
  background-clip: text;
  -webkit-background-clip: text;
}

.mobile-only-container .text-transparent {
  color: transparent;
}

/* Footer Specific Styles */
/* Footer Grid Responsive Behavior */
@media (max-width: 768px) {
  .grid.md\:grid-cols-4 {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }
  
  footer .space-y-4 {
    margin-bottom: 1.5rem;
  }
}

@media (min-width: 768px) and (max-width: 1024px) {
  .grid.md\:grid-cols-4 {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 2rem !important;
  }
}

/* Ensure proper grid layout for footer */
.grid.md\:grid-cols-4 {
  display: grid;
}

@media (min-width: 768px) {
  .md\:grid-cols-4 {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Footer link hover effects */
footer a {
  display: block;
  padding: 0.25rem 0;
  text-decoration: none !important;
}

footer a:hover {
  color: white;
  transition: color 0.2s ease;
  text-decoration: none !important;
}

/* Replace the existing footer styles in LandingPage.css with these: */

/* Landing page edge-to-edge styling for all sections */
.landing-page .content {
  padding: 0; /* Remove global padding for landing page */
}

/* Ensure all sections are full-width */
.landing-page section {
  width: 100vw;
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
}

/* Landing page footer edge-to-edge styling */
.landing-page footer {
  margin: 0 -1.5rem; /* Counteract the .content padding */
  width: calc(100% + 3rem); /* Extend beyond the padding */
  margin-bottom: -1.5rem; /* Counteract bottom padding from .content */
}

/* Footer main content */
.landing-page footer .px-8 {
  max-width: 1200px;
  margin: 0 auto;
  padding: 3rem 2rem 0 2rem; /* Add top padding, remove bottom */
}

/* Footer sections container */
.footer-sections {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0;
  margin-bottom: 0; /* Remove bottom margin */
}

/* Left section (logo and description) */
.footer-sections > div:first-child {
  flex-shrink: 0;
  max-width: 300px;
}

/* Right section (links) */
.footer-sections > div:last-child {
  display: flex;
  gap: 10rem;
}

/* Footer link sections */
.footer-sections h4 {
  font-weight: 600;
  margin-bottom: 1rem;
  color: white;
}

.footer-sections .space-y-2 {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

/* Footer links */
footer a {
  color: #9ca3af; /* text-gray-400 */
  text-decoration: none;
  transition: color 0.2s ease;
  display: block;
}

footer a:hover {
  color: white;
}

/* Copyright section */
.landing-page footer .border-t {
  border-top: 1px solid #374151; /* border-gray-800 */
  margin-top: 1.5rem; /* Reduce top margin */
  padding-top: 1.5rem; /* Reduce top padding */
  padding-bottom: 1.5rem; /* Reduce bottom padding */
  text-align: center;
  color: #9ca3af; /* text-gray-400 */
}

/* Responsive footer */
@media (max-width: 768px) {
  .footer-sections {
    flex-direction: column;
    gap: 2rem;
  }
  
  .footer-sections > div:last-child {
    flex-direction: column;
    gap: 2rem;
  }
  
  .landing-page footer .px-8 {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}
.terms-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

.terms-modal-content {
  background: #fff;
  width: min(800px, 92vw);
  max-height: 86vh;
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.15);
  display: flex;
  flex-direction: column;
  padding-left: 8px;
  padding-right: 8px;
}

.terms-modal-header {
  padding: 20px 24px 0 24px;
}

.terms-modal-header h2 {
  margin: 0;
  font-size: 1.25rem;
  color: #111827;
}

.terms-updated {
  margin: 6px 0 0 0;
  color: #6b7280;
  font-size: 0.875rem;
  margin-bottom: 12px;
}

.terms-modal-body {
  overflow: auto;
  padding: 16px 28px 0 28px;
}

.terms-section {
  margin-bottom: 16px;
}

.terms-section h3 {
  margin: 0 0 8px 0;
  color: #111827;
}

.terms-section p,
.terms-section li {
  color: #374151;
  line-height: 1.6;
}

.terms-modal-footer {
  padding: 16px 24px 20px 24px;
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  border-top: 1px solid #f3f4f6;
}

.terms-agree-btn {
  background: #2563eb;
  color: #fff;
  border: none;
  padding: 10px 16px;
  border-radius: 8px;
  cursor: pointer;
}

.terms-agree-btn:hover {
  background: #1d4ed8;
}

.terms-decline-btn {
  background: #fff;
  color: #374151;
  border: 1px solid #e5e7eb;
  padding: 10px 16px;
  border-radius: 8px;
  cursor: pointer;
}

.terms-decline-btn:hover {
  background: #f9fafb;
}


/* src/pages/SubscriptionPage.css */

:root {
  --primary-color: #ffffff;
  --accent-blue: #2979ff;
  --text-color: #1f2937;
  --text-secondary: #6b7280;
  --card-bg: #f8fafc;
  --card-border: #e5e7eb;
  --button-bg: #2979ff;
  --button-hover: #165ec9;
}

body {
  font-family: 'Inter', sans-serif;
}

.subscribe-container {
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
  padding: 3rem 2rem;
}

.subscribe-container h2 {
  font-size: 3rem;
  color: #1f2937;
  color: var(--text-color);
  margin-bottom: 1rem;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.subscribe-container .subtitle {
  font-size: 1.25rem;
  color: #6b7280;
  color: var(--text-secondary);
  margin-bottom: 3rem;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.6;
}

.plans-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  grid-gap: 2rem;
  gap: 2rem;
  margin-top: 2rem;
}

.plan-card {
  background-color: #f8fafc;
  background-color: var(--card-bg);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-radius: 16px;
  padding: 2.5rem 2rem;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
  text-align: left;
}

.plan-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #2979ff, #64b5f6);
  background: linear-gradient(90deg, var(--accent-blue), #64b5f6);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.plan-card:hover::before {
  opacity: 1;
}

.plan-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
  border-color: rgba(41, 121, 255, 0.2);
}

.plan-card.featured {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  box-shadow: 0 12px 32px rgba(41, 121, 255, 0.15);
  transform: scale(1.05);
}

.plan-card.featured::before {
  opacity: 1;
}

.plan-badge {
  display: inline-block;
  background: linear-gradient(135deg, #2979ff, #64b5f6);
  background: linear-gradient(135deg, var(--accent-blue), #64b5f6);
  color: white;
  padding: 0.25rem 1rem;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 1rem;
}

.plan-card h3 {
  font-size: 1.75rem;
  margin-bottom: 0.5rem;
  color: #1f2937;
  color: var(--text-color);
  font-weight: 700;
}

.plan-card .price {
  font-size: 2.5rem;
  margin-bottom: 0.25rem;
  font-weight: 700;
  color: #2979ff;
  color: var(--accent-blue);
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
}

.plan-card .price .currency {
  font-size: 1.5rem;
  font-weight: 600;
}

.plan-card .price .period {
  font-size: 1rem;
  color: #6b7280;
  color: var(--text-secondary);
  font-weight: 500;
}

.plan-card .description {
  color: #6b7280;
  color: var(--text-secondary);
  margin-bottom: 2rem;
  line-height: 1.5;
}

.plan-card ul {
  list-style: none;
  margin-bottom: 2rem;
  padding: 0;
}

.plan-card li {
  margin-bottom: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  color: #1f2937;
  color: var(--text-color);
  font-weight: 500;
}

.plan-card li::before {
  content: '✓';
  color: #2979ff;
  color: var(--accent-blue);
  font-weight: bold;
  font-size: 1.125rem;
  width: 20px;
  height: 20px;
  background-color: rgba(41, 121, 255, 0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.plan-button {
  background-color: #2979ff;
  background-color: var(--button-bg);
  color: white;
  border: none;
  padding: 0.875rem 2rem;
  border-radius: 8px;
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
  width: 100%;
  transition: all 0.2s ease;
  box-shadow: 0 4px 12px rgba(41, 121, 255, 0.2);
  font-family: 'Inter', sans-serif;
}

.plan-button:hover {
  background-color: #165ec9;
  background-color: var(--button-hover);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(41, 121, 255, 0.3);
}

.plan-button.secondary {
  background-color: transparent;
  color: #2979ff;
  color: var(--accent-blue);
  border: 2px solid #2979ff;
  border: 2px solid var(--accent-blue);
  box-shadow: none;
}

.plan-button.secondary:hover {
  background-color: #2979ff;
  background-color: var(--accent-blue);
  color: white;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(41, 121, 255, 0.2);
}

/* Responsive Design */
@media (max-width: 1024px) {
  .plans-grid {
    grid-template-columns: 1fr;
    max-width: 400px;
    margin: 0 auto;
  }
  
  .plan-card.featured {
    transform: none;
  }
}

@media (max-width: 768px) {
  .subscribe-container {
    padding: 2rem 1rem;
  }
  
  .subscribe-container h2 {
    font-size: 2.5rem;
  }
  
  .plan-card {
    padding: 2rem 1.5rem;
  }
}
/* src/pages/LoginPage.css - Modern Authentication Design */

:root {
  --primary-color: #ffffff;
  --accent-blue: #2979ff;
  --text-color: #1f2937;
  --text-secondary: #6b7280;
  --text-light: #9ca3af;
  --card-bg: #f8fafc;
  --card-border: #e5e7eb;
  --button-bg: #2979ff;
  --button-hover: #165ec9;
  --error-color: #ef4444;
  --error-bg: #fef2f2;
  --error-border: #fecaca;
  --input-focus: #2979ff;
  --toggle-active: #2979ff;
  --toggle-inactive: #f3f4f6;
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
  --shadow-xl: 0 12px 32px rgba(0, 0, 0, 0.08);
}

* {
  box-sizing: border-box;
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  background: #f8fafc;
  min-height: 100vh;
  margin: 0;
  padding: 0;
}

/* Main Container */
.auth-container {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem !important;
}

/* Override the .content padding specifically for LoginPage */
.content .auth-container {
  padding: 2rem !important;
  margin: -1.5rem; /* Compensate for .content padding */
}



/* Auth Card */
.auth-card {
  background: #f8fafc;
  background: var(--card-bg);
  border-radius: 20px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
  box-shadow: var(--shadow-xl);
  padding: 3rem !important;
  width: 100%;
  max-width: 600px;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  position: relative;
  overflow: hidden;
}

.auth-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #2979ff, #64b5f6);
  background: linear-gradient(90deg, var(--accent-blue), #64b5f6);
}

/* Header Section */
.auth-header {
  text-align: center;
  margin-bottom: 2.5rem;
}

.auth-header h1 {
  color: #1f2937;
  color: var(--text-color);
  font-size: 2.25rem;
  font-weight: 700;
  margin: 0 0 0.5rem 0;
  letter-spacing: -0.025em;
}

.auth-subtitle {
  color: #6b7280;
  color: var(--text-secondary);
  font-size: 1.125rem;
  margin: 0 0 2rem 0;
  font-weight: 400;
}

/* Toggle Buttons */
.auth-toggle {
  display: flex;
  background: #f3f4f6;
  background: var(--toggle-inactive);
  border-radius: 12px;
  padding: 4px;
  gap: 4px;
  max-width: 320px;
  margin: 0 auto;
}

.toggle-btn {
  flex: 1 1;
  padding: 0.75rem 1.5rem;
  border: none;
  background: transparent;
  color: #6b7280;
  color: var(--text-secondary);
  font-weight: 600;
  font-size: 0.875rem;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: inherit;
}

.toggle-btn.active {
  background: #f8fafc;
  background: var(--card-bg);
  color: #2979ff;
  color: var(--accent-blue);
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  box-shadow: var(--shadow-sm);
}

.toggle-btn:hover:not(.active) {
  color: #1f2937;
  color: var(--text-color);
}

/* Error Banner */
.error-banner {
  background: #fef2f2;
  background: var(--error-bg);
  border: 1px solid #fecaca;
  border: 1px solid var(--error-border);
  border-radius: 12px;
  padding: 1rem;
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  color: #ef4444;
  color: var(--error-color);
  font-size: 0.875rem;
  font-weight: 500;
}

.error-icon {
  flex-shrink: 0;
}

/* Form */
.auth-form {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.form-group {
  display: flex;
  flex-direction: column;
}

.form-group label {
  font-size: 0.875rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
  margin-bottom: 0.5rem;
  display: block;
}

.form-group input {
  padding: 0.875rem 1rem;
  font-size: 1rem;
  border: 2px solid #e5e7eb;
  border: 2px solid var(--card-border);
  border-radius: 12px;
  background-color: #f8fafc;
  background-color: var(--card-bg);
  color: #1f2937;
  color: var(--text-color);
  transition: all 0.2s ease;
  font-family: inherit;
  font-weight: 500;
}

.form-group input:focus {
  outline: none;
  border-color: #2979ff;
  border-color: var(--input-focus);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
  transform: translateY(-1px);
}

.form-group input::placeholder {
  color: #9ca3af;
  color: var(--text-light);
  font-weight: 400;
}

.form-group input:disabled {
  background-color: #f9fafb;
  color: #9ca3af;
  color: var(--text-light);
  cursor: not-allowed;
}

/* Auth Button */
.auth-button {
  background-color: #2979ff;
  background-color: var(--button-bg);
  color: white;
  border: none;
  padding: 1rem 1.5rem;
  font-size: 1rem;
  font-weight: 600;
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: inherit;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
  box-shadow: var(--shadow-md);
  position: relative;
  overflow: hidden;
}

.auth-button:hover:not(:disabled) {
  background-color: #165ec9;
  background-color: var(--button-hover);
  transform: translateY(-2px);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
  box-shadow: var(--shadow-lg);
}

.auth-button:active:not(:disabled) {
  transform: translateY(0);
}

.auth-button:disabled {
  opacity: 0.7;
  cursor: not-allowed;
  transform: none;
}

.auth-button.loading {
  color: transparent;
  position: relative;
}

/* Loading Spinner */
.loading-spinner {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}

.spinner {
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top: 2px solid white;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Divider */
.divider {
  text-align: center;
  margin: 2rem 0;
  position: relative;
  display: flex;
  align-items: center;
}

.divider::before,
.divider::after {
  content: '';
  flex: 1 1;
  height: 1px;
  background-color: #e5e7eb;
  background-color: var(--card-border);
}

.divider span {
  padding: 0 1rem;
  color: #6b7280;
  color: var(--text-secondary);
  font-size: 0.875rem;
  font-weight: 500;
  background-color: #f8fafc;
  background-color: var(--card-bg);
  z-index: 1;
}

/* Google Auth Button */
.google-auth-button {
  width: 100%;
  background-color: white;
  color: #1f2937;
  color: var(--text-color);
  border: 2px solid #e5e7eb;
  border: 2px solid var(--card-border);
  padding: 0.875rem 1.5rem;
  font-size: 1rem;
  font-weight: 600;
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  font-family: inherit;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  box-shadow: var(--shadow-sm);
  margin-bottom: 2rem;
}

.google-auth-button:hover:not(:disabled) {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  background-color: #f0f4ff;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
  box-shadow: var(--shadow-md);
}

.google-auth-button:active:not(:disabled) {
  transform: translateY(0);
}

.google-auth-button:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.google-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}



/* Forgot Password Link */
.forgot-password-link {
  text-align: right;
  margin-top: 0.5rem;
}

.forgot-password-btn {
  background: none;
  border: none;
  color: #2979ff;
  color: var(--accent-blue);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  text-decoration: underline;
  padding: 0;
  font-family: inherit;
  transition: color 0.2s ease;
}

.forgot-password-btn:hover {
  color: #165ec9;
  color: var(--button-hover);
}

/* Forgot Password Modal */
.forgot-password-modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 1rem;
}

.forgot-password-content {
  background: #f8fafc;
  background: var(--card-bg);
  border-radius: 20px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
  box-shadow: var(--shadow-xl);
  padding: 2rem;
  width: 100%;
  max-width: 500px;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  position: relative;
}

.forgot-password-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
}

.forgot-password-header h3 {
  margin: 0;
  color: #1f2937;
  color: var(--text-color);
  font-size: 1.5rem;
  font-weight: 700;
}

.close-btn {
  background: none;
  border: none;
  color: #6b7280;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 8px;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.close-btn:hover {
  background: #f3f4f6;
  background: var(--toggle-inactive);
  color: #1f2937;
  color: var(--text-color);
}

.forgot-password-text {
  color: #6b7280;
  color: var(--text-secondary);
  margin-bottom: 1.5rem;
  line-height: 1.6;
}

.forgot-password-form {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.reset-success {
  text-align: center;
  padding: 1rem 0;
}

.success-icon {
  color: #10b981;
  margin: 0 auto 1rem auto;
}

.reset-success h4 {
  color: #1f2937;
  color: var(--text-color);
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0 0 1rem 0;
}

.reset-success p {
  color: #6b7280;
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: 1.5rem;
}

.reset-success strong {
  color: #1f2937;
  color: var(--text-color);
}

/* Responsive Design */
@media (max-width: 640px) {
  .auth-container {
    padding: 1.5rem !important; /* Instead of 1rem */
  }
  
  .auth-card {
    padding: 2rem 1.5rem;
    border-radius: 16px;
  }
  
  .auth-header h1 {
    font-size: 2rem;
  }
  
  .auth-subtitle {
    font-size: 1rem;
  }
  
  .auth-toggle {
    max-width: 280px;
  }
  
  .toggle-btn {
    padding: 0.625rem 1.25rem;
    font-size: 0.8125rem;
  }
}

@media (max-width: 480px) {
  .auth-container {
    padding: 1rem !important; /* Minimum padding for very small screens */
  }
  
  .auth-card {
    padding: 1.5rem 1rem;
  }
  
  .auth-header h1 {
    font-size: 1.75rem;
  }
  
  .auth-toggle {
    max-width: 260px;
  }
  
  .toggle-btn {
    padding: 0.5rem 1rem;
    font-size: 0.75rem;
  }
}
/* ProfileModal.css */
.profile-modal {
  max-width: 500px;
  width: 90%;
}

.profile-modal .modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem 2rem 1rem 2rem;
  border-bottom: 1px solid var(--card-border);
}

.profile-modal .modal-header h3 {
  margin: 0;
  color: var(--text-color);
  font-size: 1.25rem;
  font-weight: 600;
}

.profile-modal .modal-body {
  padding: 1.5rem 2rem 2rem 2rem;
}

.profile-modal .modal-description {
  color: var(--text-secondary);
  margin: 0 0 1.5rem 0;
  line-height: 1.5;
}

.profile-modal .profile-form {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.profile-modal .form-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.profile-modal .form-group label {
  font-weight: 500;
  color: var(--text-color);
  font-size: 0.875rem;
}

.profile-modal .form-input {
  padding: 0.75rem 1rem;
  border: 1px solid var(--card-border);
  border-radius: 8px;
  font-size: 0.875rem;
  transition: all 0.2s ease;
  background: var(--primary-color);
  color: var(--text-color);
}

.profile-modal .form-input:focus {
  outline: none;
  border-color: var(--accent-blue);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.profile-modal .form-input.error {
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}

.profile-modal .form-input:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.profile-modal .form-help {
  color: var(--text-secondary);
  font-size: 0.75rem;
  margin-top: 0.25rem;
}

.profile-modal .error-message {
  color: #ef4444;
  font-size: 0.75rem;
  margin-top: 0.25rem;
}

.profile-modal .form-actions {
  display: flex;
  gap: 1rem;
  justify-content: flex-end;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--card-border);
}

.profile-modal .cancel-btn {
  padding: 0.75rem 1.5rem;
  border: 1px solid var(--card-border);
  border-radius: 8px;
  background: transparent;
  color: var(--text-color);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.profile-modal .cancel-btn:hover:not(:disabled) {
  background: var(--card-border);
}

.profile-modal .cancel-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.profile-modal .save-btn {
  padding: 0.75rem 1.5rem;
  border: none;
  border-radius: 8px;
  background: var(--accent-blue);
  color: white;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.profile-modal .save-btn:hover:not(:disabled) {
  background: #2563eb;
  transform: translateY(-1px);
}

.profile-modal .save-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

.profile-modal .loading-spinner {
  width: 16px;
  height: 16px;
  border: 2px solid transparent;
  border-top: 2px solid currentColor;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

/* Responsive design */
@media (max-width: 640px) {
  .profile-modal {
    width: 95%;
    margin: 1rem;
  }
  
  .profile-modal .modal-header,
  .profile-modal .modal-body {
    padding: 1rem 1.5rem;
  }
  
  .profile-modal .form-actions {
    flex-direction: column;
  }
  
  .profile-modal .cancel-btn,
  .profile-modal .save-btn {
    width: 100%;
    justify-content: center;
  }
}
/* SettingsPage.css - Modern Card-Based Design */

.settings-page {
  max-width: 900px;
  margin: 0 auto;
  padding: 2rem;
  font-family: 'Inter', sans-serif;
  background-color: var(--card-bg);
  min-height: 100vh;
}

.settings-container {
  background: transparent;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
}

.settings-container h1 {
  margin: 0 0 1rem 0;
  color: var(--text-color);
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.settings-container .subtitle {
  text-align: center;
  color: var(--text-secondary);
  font-size: 1.125rem;
  margin-bottom: 3rem;
  font-weight: 500;
}

.settings-section {
  background: var(--primary-color);
  border-radius: 16px;
  padding: 2rem;
  margin-bottom: 2rem;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.04);
  border: 1px solid var(--card-border);
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease;
}

.settings-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--accent-blue), #64b5f6);
}

.settings-section:nth-child(2)::before {
  background: linear-gradient(90deg, #ec4899, #8b5cf6);
}

.settings-section:nth-child(3)::before {
  background: linear-gradient(90deg, var(--accent-blue), #64b5f6);
}

.settings-section:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
}

.settings-section h2 {
  margin: 0 0 0.5rem 0;
  color: var(--text-color);
  font-size: 1.5rem;
  font-weight: 600;
}

/* Section Headers with Icons - CLEAN VERSION */
.section-header {
  display: flex;
  align-items: flex-start;
  gap: 1rem; /* Simple, consistent gap */
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--card-border);
}

.section-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 1.5rem;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  transition: all 0.3s ease;
}

.section-icon:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

.section-icon.profile {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
}

.section-icon.account-codes {
  background: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);
}

.section-icon.whatsapp {
  background: linear-gradient(135deg, #25d366 0%, #128c7e 100%);
}

.section-icon svg {
  width: 24px;
  height: 24px;
  color: white;
}

.section-header-content {
  flex: 1 1;
  /* Remove all the negative margins and transforms */
}

.section-header-content h2 {
  margin: 0 0 0.25rem 0;
  color: var(--text-color);
  font-size: 1.5rem;
  font-weight: 600;
}

.section-header-content .description {
  margin: 0;
  color: var(--text-secondary);
  font-size: 0.875rem;
  line-height: 1.4;
}

.section-description {
  margin: 0 0 1.5rem 0;
  color: var(--text-secondary);
  line-height: 1.5;
}

/* User Profile Styles */
.profile-form {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 1.5rem;
}

.form-group {
  margin-bottom: 1rem;
}

.form-group label {
  display: block;
  margin-bottom: 0.5rem;
  color: var(--text-color);
  font-weight: 500;
  font-size: 0.875rem;
}

.form-input {
  width: 100%;
  padding: 0.75rem;
  border: 1px solid var(--border-color);
  border-radius: 6px;
  background: var(--card-bg);
  color: var(--text-color);
  font-size: 0.875rem;
  transition: border-color 0.2s ease;
}

.form-input:focus {
  outline: none;
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.save-profile-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: var(--primary-color);
  border: none;
  border-radius: 6px;
  color: white;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.save-profile-btn:hover:not(:disabled) {
  background: var(--primary-hover);
}

.save-profile-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Account Codes Styles */
.account-codes-card {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 1.5rem;
}

.upload-section {
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--border-color);
}

.upload-section h3 {
  margin: 0 0 0.5rem 0;
  color: var(--text-color);
  font-size: 1rem;
  font-weight: 600;
}

.upload-section p {
  margin: 0 0 1rem 0;
  color: var(--text-secondary);
  font-size: 0.875rem;
}

.upload-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: 2rem;
  border: 2px dashed var(--border-color);
  border-radius: 8px;
  color: var(--text-secondary);
  text-align: center;
}

.upload-placeholder svg {
  color: var(--text-secondary);
}

.manual-entry-section {
  margin-bottom: 2rem;
}

.section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}

.section-header h3 {
  margin: 0;
  color: var(--text-color);
  font-size: 1rem;
  font-weight: 600;
}

.toggle-manual-btn {
  padding: 0.5rem 1rem;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  color: var(--text-color);
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.2s ease;
}

.toggle-manual-btn:hover {
  border-color: var(--primary-color);
  color: var(--primary-color);
}

.manual-entry-form {
  background: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 1.5rem;
  margin-top: 1rem;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 1rem;
  gap: 1rem;
  margin-bottom: 1rem;
}

.add-account-btn {
  padding: 0.75rem 1.5rem;
  background: var(--primary-color);
  border: none;
  border-radius: 6px;
  color: white;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.add-account-btn:hover:not(:disabled) {
  background: var(--primary-hover);
}

.add-account-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.account-codes-list h3 {
  margin: 0 0 1rem 0;
  color: var(--text-color);
  font-size: 1rem;
  font-weight: 600;
}

.loading-state {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem;
  color: var(--text-secondary);
  font-size: 0.875rem;
}

.empty-state {
  padding: 2rem;
  text-align: center;
  color: var(--text-secondary);
  font-size: 0.875rem;
}

.codes-table {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.code-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem;
  background: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  transition: all 0.2s ease;
}

.code-item:hover {
  border-color: var(--primary-color);
}

.code-info {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.code-value {
  font-weight: 600;
  color: var(--text-color);
  font-size: 0.875rem;
}

.code-name {
  color: var(--text-secondary);
  font-size: 0.75rem;
}

.remove-code-btn {
  padding: 0.25rem;
  background: none;
  border: none;
  color: #dc2626;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s ease;
}

.remove-code-btn:hover {
  background: rgba(220, 38, 38, 0.1);
}

/* User Profile Styles */
.profile-form {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 1.5rem;
}

.form-group {
  margin-bottom: 1rem;
}

.form-group label {
  display: block;
  margin-bottom: 0.5rem;
  color: var(--text-color);
  font-weight: 500;
  font-size: 0.875rem;
}

.form-input {
  width: 100%;
  padding: 0.75rem;
  border: 1px solid var(--border-color);
  border-radius: 6px;
  background: var(--card-bg);
  color: var(--text-color);
  font-size: 0.875rem;
  transition: border-color 0.2s ease;
}

.form-input:focus {
  outline: none;
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.save-profile-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: var(--primary-color);
  border: none;
  border-radius: 6px;
  color: white;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.save-profile-btn:hover:not(:disabled) {
  background: var(--primary-hover);
}

.save-profile-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Account Codes Styles */
.account-codes-card {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 1.5rem;
}

.upload-section {
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--border-color);
}

.upload-section h3 {
  margin: 0 0 0.5rem 0;
  color: var(--text-color);
  font-size: 1rem;
  font-weight: 600;
}

.upload-section p {
  margin: 0 0 1rem 0;
  color: var(--text-secondary);
  font-size: 0.875rem;
}

.upload-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: 2rem;
  border: 2px dashed var(--border-color);
  border-radius: 8px;
  color: var(--text-secondary);
  text-align: center;
}

.upload-placeholder svg {
  color: var(--text-secondary);
}

.manual-entry-section {
  margin-bottom: 2rem;
}

.section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}

.section-header h3 {
  margin: 0;
  color: var(--text-color);
  font-size: 1rem;
  font-weight: 600;
}

.toggle-manual-btn {
  padding: 0.5rem 1rem;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  color: var(--text-color);
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.2s ease;
}

.toggle-manual-btn:hover {
  border-color: var(--primary-color);
  color: var(--primary-color);
}

.manual-entry-form {
  background: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 1.5rem;
  margin-top: 1rem;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 1rem;
  gap: 1rem;
  margin-bottom: 1rem;
}

.add-account-btn {
  padding: 0.75rem 1.5rem;
  background: var(--primary-color);
  border: none;
  border-radius: 6px;
  color: white;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.add-account-btn:hover:not(:disabled) {
  background: var(--primary-hover);
}

.add-account-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.account-codes-list h3 {
  margin: 0 0 1rem 0;
  color: var(--text-color);
  font-size: 1rem;
  font-weight: 600;
}

.loading-state {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem;
  color: var(--text-secondary);
  font-size: 0.875rem;
}

.empty-state {
  padding: 2rem;
  text-align: center;
  color: var(--text-secondary);
  font-size: 0.875rem;
}

.codes-table {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.code-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem;
  background: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  transition: all 0.2s ease;
}

.code-item:hover {
  border-color: var(--primary-color);
}

.code-info {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.code-value {
  font-weight: 600;
  color: var(--text-color);
  font-size: 0.875rem;
}

.code-name {
  color: var(--text-secondary);
  font-size: 0.75rem;
}

.remove-code-btn {
  padding: 0.25rem;
  background: none;
  border: none;
  color: #dc2626;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s ease;
}

.remove-code-btn:hover {
  background: rgba(220, 38, 38, 0.1);
}

/* WhatsApp Integration Styles */
.whatsapp-integration-card {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 1.5rem;
  transition: all 0.2s ease;
}

.whatsapp-integration-card:hover {
  border-color: var(--primary-color);
  box-shadow: 0 2px 8px rgba(59, 130, 246, 0.1);
}

/* Error Message */
.error-message {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem;
  background: rgba(220, 38, 38, 0.1);
  border: 1px solid rgba(220, 38, 38, 0.3);
  border-radius: 6px;
  color: #dc2626;
  font-size: 0.875rem;
  margin-bottom: 1rem;
}

/* WhatsApp Setup (Not Connected) */
.whatsapp-setup-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.whatsapp-icon {
  width: 48px;
  height: 48px;
  background: #25d366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  flex-shrink: 0;
}

.whatsapp-icon.connected {
  background: #25d366;
}

.whatsapp-setup-info h3 {
  margin: 0 0 0.25rem 0;
  color: var(--text-color);
  font-size: 1.125rem;
  font-weight: 600;
}

.whatsapp-setup-info p {
  margin: 0;
  color: var(--text-secondary);
  font-size: 0.875rem;
  line-height: 1.4;
}

/* WhatsApp Number Input */
.whatsapp-number-input {
  margin-bottom: 1.5rem;
}

/* WhatsApp Button Wrapper for centering single buttons */
.whatsapp-number-input .whatsapp-button-wrapper,
.whatsapp-actions .whatsapp-button-wrapper {
  text-align: center;
  margin: 1rem 0;
}

/* Add extra padding above the Send Verification button */
.whatsapp-number-input .whatsapp-button-wrapper {
  margin-top: 2rem;
  margin-bottom: 0.5rem;
}

/* Reduce padding for Disconnect button */
.whatsapp-actions .whatsapp-button-wrapper {
  margin: 0.5rem 0;
}

/* Ensure buttons are centered within their wrappers */
.whatsapp-button-wrapper .verify-whatsapp-btn,
.whatsapp-button-wrapper .disconnect-whatsapp-btn {
  margin: 0 auto;
  /* Keep display: flex to maintain icon + text alignment */
}

.whatsapp-number-input .form-group {
  margin-bottom: 1rem;
}

.whatsapp-number-input .form-help {
  display: block;
  margin-top: 0.25rem;
  color: var(--text-secondary);
  font-size: 0.75rem;
  line-height: 1.4;
}

/* WhatsApp Verification Button */
.verify-whatsapp-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: #25d366;
  border: none;
  border-radius: 6px;
  color: white;
  font-size: 0.875rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s ease;
  width: auto; /* Changed from 100% to auto */
  min-width: 200px; /* Added minimum width */
  justify-content: center;
  margin: 0; /* Let container handle centering */
}

.verify-whatsapp-btn:hover:not(:disabled) {
  background: #128c7e;
  transform: translateY(-1px);
}

.verify-whatsapp-btn:disabled {
  background: #ccc;
  cursor: not-allowed;
  transform: none;
}



/* WhatsApp Verification States */
.whatsapp-verification-checking {
  text-align: center;
  padding: 1.5rem;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  margin-bottom: 1rem;
}

.whatsapp-verification-checking p {
  margin: 0 0 1rem 0;
  color: var(--text-color);
  font-size: 0.875rem;
  line-height: 1.4;
}

.whatsapp-verification-pending {
  text-align: center;
  padding: 1.5rem;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  margin-bottom: 1rem;
}

.whatsapp-verification-pending p {
  margin: 0 0 1rem 0;
  color: var(--text-color);
  font-size: 0.875rem;
  line-height: 1.4;
}

.whatsapp-verification-error {
  text-align: center;
  padding: 1.5rem;
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 6px;
  margin-bottom: 1rem;
}

.whatsapp-verification-error p {
  margin: 0 0 1rem 0;
  color: #dc2626;
  font-size: 0.875rem;
  line-height: 1.4;
}

.whatsapp-verification-timeout {
  text-align: center;
  padding: 1.5rem;
  background: #fffbeb;
  border: 1px solid #fed7aa;
  border-radius: 6px;
  margin-bottom: 1rem;
}

.whatsapp-verification-timeout p {
  margin: 0 0 1rem 0;
  color: #d97706;
  font-size: 0.875rem;
  line-height: 1.4;
}

.retry-verify-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background: var(--primary-color);
  border: none;
  border-radius: 4px;
  color: white;
  font-size: 0.75rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.retry-verify-btn:hover {
  background: #2563eb; /* Changed from var(--primary-dark) to theme blue */
  transform: translateY(-1px);
}

/* WhatsApp Connected State */
.whatsapp-connected {
  /* Removed padding to match Connect WhatsApp section */
  display: block;
}

.whatsapp-status-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.whatsapp-status-info h3 {
  margin: 0 0 0.25rem 0;
  color: var(--text-color);
  font-size: 1.125rem;
  font-weight: 600;
}

.whatsapp-status-info p {
  margin: 0 0 0.5rem 0;
  color: var(--text-secondary);
  font-size: 0.875rem;
}

.whatsapp-features {
  margin-bottom: 1.5rem;
}

.whatsapp-features h4 {
  margin: 0 0 0.75rem 0;
  color: var(--text-color);
  font-size: 0.875rem;
  font-weight: 600;
}

.whatsapp-instructions {
  margin: 0;
  padding-left: 1.25rem;
  color: var(--text-secondary);
  font-size: 0.875rem;
  line-height: 1.5;
}

.whatsapp-instructions li {
  margin-bottom: 0.25rem;
}

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

/* WhatsApp Actions */
.whatsapp-actions {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border-color);
}

.disconnect-whatsapp-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: #dc2626;
  border: none;
  border-radius: 6px;
  color: white;
  font-size: 0.875rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s ease;
  min-width: 200px; /* Match the verify button width */
  justify-content: center;
  margin: 0; /* Let container handle centering */
}

.disconnect-whatsapp-btn:hover:not(:disabled) {
  background: #b91c1c;
  transform: translateY(-1px);
}

.disconnect-whatsapp-btn:disabled {
  background: #ccc;
  cursor: not-allowed;
  transform: none;
}

/* Loading Spinner */
.loading-spinner {
  width: 16px;
  height: 16px;
  border: 2px solid transparent;
  border-top: 2px solid currentColor;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Connection Status */
.connection-status {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: var(--text-secondary);
  margin-top: 0.5rem;
}

.status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #ccc;
}

.status-dot.connected {
  background: #10b981;
}

/* Responsive Design */
@media (max-width: 768px) {
  .settings-page {
    padding: 1rem;
  }
  
  .settings-container {
    padding: 1.5rem;
  }
  
  .form-row {
    grid-template-columns: 1fr;
  }
  
  /* Make modal appropriately sized on mobile */
  .modal-content {
    max-width: 520px;
    width: 520px;
    margin: 0 1rem;
  }
  
  .whatsapp-setup-header {
    flex-direction: column;
    text-align: center;
    gap: 0.75rem;
  }
  
  .whatsapp-status-header {
    flex-direction: column;
    text-align: center;
    gap: 0.75rem;
  }
  
  .qr-code-image {
    width: 180px;
    height: 180px;
  }
  
  .whatsapp-actions {
    justify-content: center;
  }
  
  .disconnect-whatsapp-btn {
    width: 100%;
    justify-content: center;
  }

  .whatsapp-setup-header {
    flex-direction: column;
    text-align: center;
    gap: 0.75rem;
  }
  
  .whatsapp-icon {
    width: 40px;
    height: 40px;
  }
  
  .whatsapp-setup-info h3 {
    font-size: 1rem;
  }
  
  .whatsapp-setup-info p {
    font-size: 0.8rem;
  }
  
  .verify-whatsapp-btn,
  .disconnect-whatsapp-btn {
    padding: 0.875rem 1.25rem;
    font-size: 0.8rem;
  }
  
  .whatsapp-verification-pending,
  .whatsapp-verification-error,
  .whatsapp-verification-timeout {
    padding: 1rem;
  }
  
  .whatsapp-verification-pending p,
  .whatsapp-verification-error p,
  .whatsapp-verification-timeout p {
    font-size: 0.8rem;
  }
}

/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
  .qr-code-image {
    background: var(--card-bg);
  }
  
  .error-message {
    background: rgba(220, 38, 38, 0.1);
    border-color: rgba(220, 38, 38, 0.3);
  }
}

/* Account Codes Save Button */
.list-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}

.save-codes-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: #3b82f6;
  border: none;
  border-radius: 8px;
  color: white;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.save-codes-btn:hover:not(:disabled) {
  background: #2563eb;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.15);
}

.save-codes-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  background: var(--text-secondary);
  color: white;
}

/* File Upload Styles */
.file-upload-area {
  position: relative;
}

.file-input {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
}



.file-upload-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: 2rem;
  border: 2px dashed var(--border-color);
  border-radius: 8px;
  color: var(--text-secondary);
  text-align: center;
  cursor: pointer;
  transition: all 0.2s ease;
}

.file-upload-label:hover {
  border-color: var(--primary-color);
  color: var(--primary-color);
}

.file-upload-label svg {
  color: inherit;
}

.file-hint {
  font-size: 0.75rem;
  opacity: 0.7;
}

.upload-error {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem;
  background: rgba(220, 38, 38, 0.1);
  border: 1px solid rgba(220, 38, 38, 0.3);
  border-radius: 6px;
  color: #dc2626;
  font-size: 0.875rem;
  margin-top: 1rem;
}

/* Preview Section */
.preview-section {
  background: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 1.5rem;
}

.preview-header h4 {
  margin: 0 0 0.5rem 0;
  color: var(--text-color);
  font-size: 1rem;
  font-weight: 600;
}

.preview-header p {
  margin: 0 0 1rem 0;
  color: var(--text-secondary);
  font-size: 0.875rem;
}

/* Add padding below upload text */
.upload-section p {
  margin: 0 0 1.5rem 0; /* Increased bottom margin for more padding */
  color: var(--text-secondary);
  font-size: 0.875rem;
}

.preview-controls {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
  padding: 0.75rem;
  background: var(--bg-color);
  border-radius: 6px;
}

.select-all-btn,
.deselect-all-btn {
  padding: 0.5rem 1rem;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  color: var(--text-color);
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.2s ease;
}

.select-all-btn:hover {
  border-color: #3b82f6; /* Blue outline for Select All */
  color: #3b82f6;
}

.deselect-all-btn:hover {
  border-color: #dc2626; /* Red outline for Deselect All */
  color: #dc2626;
}

.selection-info {
  margin-left: auto;
  color: var(--text-secondary);
  font-size: 0.875rem;
}

.preview-table-container {
  max-height: 300px; /* Height for exactly 6 rows (6 * 50px per row) */
  overflow-y: auto;
  margin-bottom: 1rem;
  border: 1px solid var(--border-color);
  border-radius: 6px;
}

.preview-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--card-bg);
}

.preview-table th {
  background: var(--bg-color);
  padding: 0.75rem;
  text-align: left;
  font-weight: 600;
  color: var(--text-color);
  font-size: 0.875rem;
  border-bottom: 1px solid var(--border-color);
}

.preview-table td {
  padding: 0.75rem;
  border-bottom: 1px solid var(--border-color);
  font-size: 0.875rem;
  height: 50px; /* Fixed height for consistent row sizing */
  box-sizing: border-box;
}

.preview-table tr:last-child td {
  border-bottom: none;
}

.preview-table tr.selected-row {
  background: rgba(59, 130, 246, 0.1);
}

.code-checkbox {
  width: 16px;
  height: 16px;
  cursor: pointer;
}

.preview-codes {
  max-height: 300px;
  overflow-y: auto;
  margin-bottom: 1rem;
}

.preview-code-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.5rem;
  border-bottom: 1px solid var(--border-color);
}

.preview-code-item:last-child {
  border-bottom: none;
}

.preview-code {
  font-weight: 600;
  color: var(--text-color);
  font-size: 0.875rem;
}

.preview-name {
  color: var(--text-secondary);
  font-size: 0.875rem;
}

.preview-more {
  text-align: center;
  padding: 0.5rem;
  color: var(--text-secondary);
  font-size: 0.75rem;
  font-style: italic;
}

.preview-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  align-items: center;
}

.apply-codes-btn {
  padding: 0.75rem 1.5rem;
  background: var(--primary-color);
  border: none;
  border-radius: 6px;
  color: white;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.apply-codes-btn:hover {
  background: var(--primary-hover);
}

.cancel-upload-btn {
  padding: 0.75rem 1.5rem;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  color: var(--text-color);
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.2s ease;
}

.cancel-upload-btn:hover {
  border-color: #dc2626; /* Red outline for Cancel button */
  color: #dc2626;
}

/* Updated Button Styles to Match Upload/Tracker Design */
.save-profile-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: #3b82f6;
  border: none;
  border-radius: 8px;
  color: white;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.save-profile-btn:hover:not(:disabled) {
  background: #2563eb;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.15);
}

.add-account-btn {
  padding: 0.75rem 1.5rem;
  background: var(--primary-color);
  border: none;
  border-radius: 6px;
  color: white;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  margin: 0 auto;
  justify-content: center;
  min-width: 140px;
}

.add-account-btn:hover:not(:disabled) {
  background: var(--primary-hover);
}

.apply-codes-btn {
  padding: 0.75rem 1.5rem;
  background: #3b82f6;
  border: none;
  border-radius: 8px;
  color: white;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.apply-codes-btn:hover {
  background: #2563eb;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.15);
}

/* Center the save profile button and prevent enlargement */
.profile-form .save-profile-btn {
  margin: 0 auto;
  justify-content: center;
  min-width: 140px;
}

.profile-form .save-profile-btn:hover:not(:disabled) {
  transform: none;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Manual Entry Guide Styling */
.manual-entry-guide {
  margin: 0.75rem 0 1rem 0;
  padding: 0.75rem;
  background: rgba(59, 130, 246, 0.05);
  border-left: 3px solid #3b82f6;
  border-radius: 0 6px 6px 0;
  color: var(--text-secondary);
  font-size: 0.875rem;
  line-height: 1.5;
}

/* WhatsApp Verification Actions */
.verification-actions {
  display: flex;
  gap: 1rem; /* Add 1rem gap between buttons */
  margin-top: 1rem;
  justify-content: center; /* Center the buttons */
  align-items: center; /* Align buttons vertically */
  width: 100%; /* Ensure full width */
  flex-wrap: nowrap; /* Prevent wrapping */
}

.verification-actions .cancel-verification-btn {
  padding: 0.75rem 1.5rem;
  background: #6b7280;
  border: none;
  border-radius: 6px;
  color: white;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  margin: 0 !important; /* Override any conflicting margins to let flexbox center */
  min-width: 180px; /* Ensure consistent button width */
  flex-shrink: 0; /* Prevent button from shrinking */
  position: relative; /* Ensure positioning context */
}

.cancel-verification-btn:hover {
  background: #4b5563;
}

/* Resend Verification Button */
.verification-actions .resend-verification-btn {
  padding: 0.75rem 1.5rem;
  background: #25d366; /* WhatsApp green */
  border: none;
  border-radius: 6px;
  color: white;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  margin: 0 !important; /* Override any conflicting margins to let flexbox center */
  min-width: 180px; /* Ensure consistent button width */
  flex-shrink: 0; /* Prevent button from shrinking */
  position: relative; /* Ensure positioning context */
}

.resend-verification-btn:hover:not(:disabled) {
  background: #128c7e; /* Darker WhatsApp green on hover */
  transform: translateY(-1px);
}

/* Your Account Codes Card */
.your-account-codes-card {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 1.5rem;
  margin-top: 1rem;
}

.codes-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
}

.codes-header h3 {
  margin: 0;
  color: var(--text-color);
  font-size: 1.25rem;
  font-weight: 600;
}

.codes-count {
  background: #3b82f6; /* Changed from var(--primary-color) to theme blue for better visibility */
  color: white;
  padding: 0.25rem 0.75rem;
  border-radius: 20px;
  font-size: 0.875rem;
  font-weight: 500;
}

.codes-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}

.code-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem;
  background: white;
  border: 1px solid var(--border-color);
  border-radius: 6px;
  transition: all 0.2s ease;
}

.code-item:hover {
  border-color: #3b82f6; /* Changed from var(--primary-color) to theme blue */
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.code-info {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.code-value {
  font-weight: 600;
  color: var(--text-color);
  font-size: 1rem;
}

.code-name {
  color: var(--text-secondary);
  font-size: 0.875rem;
}

.code-actions {
  display: flex;
  gap: 0.5rem;
}

.edit-code-btn,
.remove-code-btn {
  padding: 0.5rem;
  background: transparent;
  border: 1px solid var(--border-color);
  border-radius: 4px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.2s ease;
}

.edit-code-btn:hover {
  border-color: #3b82f6; /* Changed from var(--primary-color) to theme blue */
  color: #3b82f6; /* Changed from var(--primary-color) to theme blue */
  background: rgba(59, 130, 246, 0.1); /* Changed to use theme blue */
}

.remove-code-btn:hover {
  border-color: #dc2626;
  color: #dc2626;
  background: rgba(220, 38, 38, 0.1);
}

.add-more-codes-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: #3b82f6; /* Changed to match save profile button */
  border: none;
  border-radius: 8px; /* Changed to match save profile button */
  color: white;
  font-size: 0.875rem;
  font-weight: 600; /* Changed to match save profile button */
  cursor: pointer;
  transition: all 0.2s ease;
  margin: 0 auto; /* Center the button */
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); /* Added shadow to match */
  min-width: 140px; /* Added minimum width to match save profile button */
}

.add-more-codes-btn:hover {
  background: #2563eb; /* Changed to match save profile button hover */
  transform: translateY(-1px);
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.15); /* Added hover shadow to match */
}

/* Modal Styles */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 1rem;
}

.modal-content {
  background: white;
  border-radius: 12px;
  max-width: 600px; /* Made even bigger for spacious feel */
  width: 600px; /* Fixed width for large modal */
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem 1.5rem 1rem 1.5rem;
  border-bottom: 1px solid var(--border-color);
}

.modal-header h3 {
  margin: 0;
  color: var(--text-color);
  font-size: 1.25rem;
  font-weight: 600;
}

.modal-close-btn {
  background: transparent;
  border: none;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 4px;
  transition: all 0.2s ease;
}

.modal-close-btn:hover {
  background: var(--border-color);
  color: var(--text-color);
}

.modal-body {
  padding: 1.5rem;
}

.modal-description {
  margin: 0 0 1.5rem 0;
  color: var(--text-secondary);
  font-size: 1rem;
  text-align: left; /* Changed from center to left */
}

.add-method-options {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.add-method-option {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.5rem;
  border: 2px solid var(--border-color);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.add-method-option:hover {
  border-color: #3b82f6; /* Changed from var(--primary-color) to theme blue */
  background: rgba(59, 130, 246, 0.02);
}

.method-icon {
  width: 48px;
  height: 48px;
  background: #3b82f6; /* Changed from var(--primary-color) to theme blue */
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  flex-shrink: 0;
}

.method-content h4 {
  margin: 0 0 0.5rem 0;
  color: var(--text-color);
  font-size: 1.125rem;
  font-weight: 600;
}

.method-content p {
  margin: 0;
  color: var(--text-secondary);
  font-size: 0.875rem;
  line-height: 1.5;
}

/* Manual Form Actions */
.manual-form-actions {
  display: flex;
  gap: 1rem;
  margin-top: 1.5rem;
  justify-content: center; /* Center the buttons */
}

.cancel-manual-btn {
  padding: 0.75rem 1.5rem;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  color: var(--text-color);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.cancel-manual-btn:hover {
  border-color: var(--primary-color);
  color: var(--primary-color);
}

.add-row-btn {
  padding: 0.75rem 1.5rem;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  color: var(--text-color);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.add-row-btn:hover {
  border-color: var(--primary-color);
  color: var(--primary-color);
  background: rgba(59, 130, 246, 0.05);
}

/* Fix remaining hover effects to use theme blue */
.codes-table .code-item:hover {
  border-color: #3b82f6;
}

.whatsapp-integration-card:hover {
  border-color: #3b82f6;
  box-shadow: 0 2px 8px rgba(59, 130, 246, 0.1);
}

.form-input:focus {
  outline: none;
  border-color: #3b82f6;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.save-profile-btn:hover:not(:disabled) {
  background: #2563eb;
}

.file-upload-label:hover {
  border-color: #3b82f6;
  color: #3b82f6;
}

.select-all-btn:hover,
.deselect-all-btn:hover {
  border-color: #3b82f6;
  color: #3b82f6;
}

.cancel-upload-btn:hover {
  border-color: #3b82f6;
  color: #3b82f6;
}

.cancel-manual-btn:hover {
  border-color: #3b82f6;
  color: #3b82f6;
}

.add-row-btn:hover {
  border-color: #3b82f6;
  color: #3b82f6;
  background: rgba(59, 130, 246, 0.05);
}

.add-method-option:hover {
  border-color: #3b82f6;
  background: rgba(59, 130, 246, 0.02);
}

/* Upload Chart Modal Specific Styles */
.upload-chart-instruction {
  margin: 0 0 2rem 0; /* Add proper bottom margin for spacing */
  color: var(--text-secondary);
  font-size: 1rem;
  line-height: 1.5;
  text-align: left; /* Changed from center to left */
  padding: 0 1rem;
}

/* File Upload Area Spacing */
.file-upload-area {
  margin-top: 1rem; /* Add top margin for better separation */
}

.file-upload-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem; /* Increased gap between elements */
  padding: 3rem 2rem; /* Increased padding for better proportions */
  border: 2px dashed var(--border-color);
  border-radius: 8px;
  color: var(--text-secondary);
  text-align: center;
  cursor: pointer;
  transition: all 0.2s ease;
  min-height: 200px; /* Ensure consistent height */
  justify-content: center;
}

/* Manual Input Row Styles */
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  grid-gap: 1rem;
  gap: 1rem;
  margin-bottom: 1rem;
  align-items: center; /* Changed from end to center for better alignment */
  position: relative;
}

.remove-row-btn {
  padding: 0.5rem;
  background: transparent;
  border: 2px solid #e5e7eb; /* Light gray border */
  border-radius: 4px;
  color: #6b7280; /* Gray color */
  cursor: pointer;
  transition: all 0.2s ease;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1.5rem; /* Align with input fields */
}

.remove-row-btn:hover {
  border-color: #dc2626; /* Red border on hover */
  color: #dc2626; /* Red icon on hover */
  background: rgba(220, 38, 38, 0.05); /* Light red background */
}

.save-manual-codes-btn {
  padding: 0.75rem 1.5rem;
  background: #3b82f6;
  border: none;
  border-radius: 8px;
  color: white;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.save-manual-codes-btn:hover:not(:disabled) {
  background: #2563eb;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.15);
}

.save-manual-codes-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

/* Profile Management Styles */
.loading-state {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  padding: 2rem;
  color: var(--text-secondary);
}

.empty-state {
  text-align: center;
  padding: 2rem;
  color: var(--text-secondary);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.empty-state p {
  margin: 0 0 1.5rem 0;
  font-size: 1rem;
}

.create-first-profile-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background: var(--accent-blue);
  color: white;
  border: none;
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  margin: 0 auto;
}

.create-first-profile-btn:hover {
  background: #2563eb;
  transform: translateY(-1px);
}

.current-profile-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 12px;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}

.profile-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}

.profile-header h3 {
  margin: 0;
  color: var(--text-color);
  font-size: 1.125rem;
  font-weight: 600;
}

.active-indicator {
  background: #10b981;
  color: white;
  padding: 0.25rem 0.75rem;
  border-radius: 12px;
  font-size: 0.75rem;
  font-weight: 500;
}

.profile-info {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
}

.current-profile-card .profile-field {
  margin-top: 0.25rem;
}

.current-profile-card .profile-name-text {
  color: var(--text-color) !important;
  font-size: 0.875rem;
  font-weight: 500;
  margin-top: 0;
}

.profile-details {
  flex: 1 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 0.75rem;
  gap: 0.75rem;
}

.profile-field {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.profile-field label {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.profile-field span {
  font-size: 0.875rem;
  color: var(--text-color);
  font-weight: 500;
}

.profile-name-text {
  color: #6b7280 !important;
  font-size: 1rem;
  font-weight: 500;
  margin-top: 0.5rem;
}

.profile-actions {
  display: flex;
  gap: 0.5rem;
}

.edit-profile-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem;
  background: transparent;
  border: 1px solid var(--border-color);
  border-radius: 4px;
  color: var(--text-secondary);
  font-size: 0.75rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.edit-profile-btn:hover {
  border-color: #3b82f6;
  color: #3b82f6;
  background: rgba(59, 130, 246, 0.1);
}

.profile-management {
  margin-top: 1.5rem;
}

/* Your Profiles Card - matching account codes design exactly */
.your-profiles-card {
  background: white;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 1.5rem;
  margin-top: 1rem;
}

.profiles-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid #e5e7eb;
}

.profiles-header h3 {
  margin: 0;
  color: #1f2937;
  font-size: 1.25rem;
  font-weight: 700;
}

.profiles-count {
  background: #3b82f6;
  color: white;
  padding: 0.3rem 0.8rem;
  border-radius: 12px;
  font-size: 0.8rem;
  font-weight: 600;
}

.empty-profiles-state {
  text-align: center;
  padding: 2rem;
  color: #6b7280;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.empty-profiles-state p {
  margin: 0 0 1.5rem 0;
  font-size: 0.875rem;
  color: #6b7280;
}

.add-first-profile-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: #3b82f6;
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  margin: 0 auto;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  min-width: 140px;
}

.add-first-profile-btn:hover {
  background: #2563eb;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.15);
}

.profiles-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}

.add-more-profiles-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: #3b82f6;
  border: none;
  border-radius: 8px;
  color: white;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  margin: 0 auto;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  min-width: 140px;
}

.add-more-profiles-btn:hover {
  background: #2563eb;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.15);
}

.profile-list-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}

.profile-list-header h3 {
  margin: 0;
  color: var(--text-color);
  font-size: 1rem;
  font-weight: 600;
}

.add-profile-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background: var(--accent-blue);
  color: white;
  border: none;
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.add-profile-btn:hover {
  background: #2563eb;
  transform: translateY(-1px);
}

.profile-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.profile-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem;
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 8px;
  transition: all 0.2s ease;
}

.profile-item:hover {
  border-color: var(--accent-blue);
  box-shadow: 0 2px 8px rgba(59, 130, 246, 0.1);
}

.profile-item.active {
  border-color: var(--accent-blue);
  background: rgba(59, 130, 246, 0.05);
}

.profile-item-info {
  flex: 1 1;
}

.profile-item-name {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 500;
  color: var(--text-color);
  margin-bottom: 0.25rem;
}

.active-badge {
  background: var(--accent-blue);
  color: white;
  padding: 0.125rem 0.5rem;
  border-radius: 8px;
  font-size: 0.65rem;
  font-weight: 500;
}

.profile-item-details {
  font-size: 0.75rem;
  color: var(--text-secondary);
}

.profile-item-actions {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

/* Profile Dropdown Menu */
.profile-dropdown {
  position: relative;
}

.profile-menu-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem;
  background: transparent;
  border: none;
  border-radius: 4px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.2s ease;
  width: 32px;
  height: 32px;
}

.profile-menu-btn:hover {
  color: #3b82f6;
  background: rgba(59, 130, 246, 0.1);
}

.profile-dropdown-menu {
  position: absolute;
  top: 100%;
  right: 0;
  background: white;
  border: 1px solid var(--border-color);
  border-radius: 6px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  z-index: 1000;
  min-width: 120px;
  overflow: hidden;
  margin-top: 4px;
}

.dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1rem;
  background: transparent;
  border: none;
  color: var(--text-color);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  width: 100%;
  text-align: left;
}

.dropdown-item:hover {
  background: var(--border-color);
}

.dropdown-item.edit-item:hover {
  color: #3b82f6;
  background: rgba(59, 130, 246, 0.1);
}

.dropdown-item.delete-item:hover {
  color: #dc2626;
  background: rgba(220, 38, 38, 0.1);
}

.switch-profile-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem;
  background: transparent;
  border: 1px solid var(--border-color);
  border-radius: 4px;
  color: var(--text-secondary);
  font-size: 0.75rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.switch-profile-btn:hover:not(:disabled) {
  border-color: #3b82f6;
  color: #3b82f6;
  background: rgba(59, 130, 246, 0.1);
}

.switch-profile-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.delete-profile-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem;
  background: transparent;
  border: 1px solid var(--border-color);
  border-radius: 4px;
  color: var(--text-secondary);
  font-size: 0.75rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.delete-profile-btn:hover {
  border-color: #dc2626;
  color: #dc2626;
  background: rgba(220, 38, 38, 0.1);
}

/* Responsive design for profile management */
@media (max-width: 768px) {
  .profile-info {
    flex-direction: column;
    gap: 1rem;
  }
  
  .profile-details {
    grid-template-columns: 1fr;
  }
  
  .profile-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
  }
  
  .profile-item-actions {
    width: 100%;
    justify-content: flex-end;
  }
  
  .profile-list-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
  }
}


/* src/pages/UploadPage.css */

:root {
  --primary-color: #ffffff;
  --accent-blue: #2979ff;
  --text-color: #1f2937;
  --text-secondary: #6b7280;
  --card-bg: #f8fafc;
  --card-border: #e5e7eb;
  --button-bg: #2979ff;
  --button-hover: #165ec9;
  --input-focus: #2979ff;
  --nav-bg: #ffffff;
  --success-color: #10b981;
  --success-light: #d1fae5;
  --warning-color: #f59e0b;
}

* {
  box-sizing: border-box;
}

body {
  font-family: 'Inter', sans-serif;
}

.upload-page-container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 2rem;
  font-family: 'Inter', sans-serif;
  background-color: #ffffff;
  background-color: var(--primary-color);
  min-height: 100vh;
}

.upload-page-container h2 {
  color: #1f2937;
  color: var(--text-color);
  text-align: center;
  margin-bottom: 3rem;
  font-size: 2.5rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

/* Drop Zone */
.drop-zone {
  border: 2px dashed #e5e7eb;
  border: 2px dashed var(--card-border);
  background-color: #f8fafc;
  background-color: var(--card-bg);
  border-radius: 16px;
  padding: 3rem;
  cursor: pointer;
  transition: all 0.3s ease;
  min-height: 280px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.04);
  position: relative;
  overflow: hidden;
}

.drop-zone::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #2979ff, #64b5f6);
  background: linear-gradient(90deg, var(--accent-blue), #64b5f6);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.drop-zone:hover::before {
  opacity: 1;
}

.drop-zone:hover {
  background-color: #ffffff;
  background-color: var(--primary-color);
  border-color: #2979ff;
  border-color: var(--accent-blue);
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(41, 121, 255, 0.12);
}

.drop-zone.disabled {
  opacity: 0.7;
  cursor: not-allowed;
  transform: none;
}

.drop-zone.disabled:hover {
  background-color: #f8fafc;
  background-color: var(--card-bg);
  border-color: #e5e7eb;
  border-color: var(--card-border);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.04);
}

.drop-zone.has-files {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  background-color: rgba(41, 121, 255, 0.02);
}

/* Cloud icon */
.drop-icon {
  margin-bottom: 1.5rem;
  width: 64px;
  height: 64px;
  stroke: #2979ff;
  stroke: var(--accent-blue);
  fill: none;
  stroke-width: 1.5;
  transition: all 0.3s ease;
}

.drop-zone:hover .drop-icon {
  transform: scale(1.1);
  stroke: #165ec9;
  stroke: var(--button-hover);
}

.drop-zone p {
  font-size: 1.125rem;
  color: #6b7280;
  color: var(--text-secondary);
  margin: 0;
  font-weight: 500;
  text-align: center;
  line-height: 1.6;
}

.drop-zone:hover p {
  color: #1f2937;
  color: var(--text-color);
}

/* Process button */
.process-button {
  display: block;
  margin: 2rem auto 0;
  background-color: #2979ff;
  background-color: var(--button-bg);
  color: #ffffff;
  color: var(--primary-color);
  border: none;
  padding: 1rem 2rem;
  border-radius: 12px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: 'Inter', sans-serif;
  box-shadow: 0 4px 12px rgba(41, 121, 255, 0.2);
  min-width: 140px;
}

.process-button:hover:not(:disabled) {
  background-color: #165ec9;
  background-color: var(--button-hover);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(41, 121, 255, 0.3);
}

.process-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
  box-shadow: 0 4px 12px rgba(41, 121, 255, 0.1);
}

/* Restart button (inside drop-zone) */
.restart-button {
  background-color: #2979ff;
  background-color: var(--button-bg);
  color: #ffffff;
  color: var(--primary-color);
  border: none;
  padding: 1rem 2rem;
  border-radius: 12px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: 'Inter', sans-serif;
  box-shadow: 0 4px 12px rgba(41, 121, 255, 0.2);
}

.restart-button:hover {
  background-color: #165ec9;
  background-color: var(--button-hover);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(41, 121, 255, 0.3);
}

/* Export buttons container */
.export-buttons-container {
  display: flex;
  gap: 1rem;
  justify-content: center;
  margin: 2rem auto 0;
  flex-wrap: wrap;
}

/* Export button */
.export-button {
  display: block;
  margin: 0;
  background-color: #10b981;
  background-color: var(--success-color);
  color: #ffffff;
  color: var(--primary-color);
  border: none;
  padding: 1rem 2rem;
  border-radius: 12px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: 'Inter', sans-serif;
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.2);
}

.export-test-button {
  background-color: #ffffff;
  background-color: var(--primary-color);
  color: white;
}

.export-test-button:hover {
  background-color: #165ec9;
  background-color: var(--button-hover);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(41, 121, 255, 0.3);
}

.export-button:hover {
  background-color: #059669;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(16, 185, 129, 0.3);
}

/* Processing status indicator */
.processing-status {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  margin-top: 1.5rem;
  padding: 1rem;
  background-color: #d1fae5;
  background-color: var(--success-light);
  border-radius: 12px;
  border: 1px solid #a7f3d0;
}

.processing-status .status-icon {
  width: 20px;
  height: 20px;
  border: 2px solid #10b981;
  border: 2px solid var(--success-color);
  border-top: 2px solid transparent;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

.processing-status p {
  margin: 0;
  color: #10b981;
  color: var(--success-color);
  font-weight: 600;
  font-size: 0.875rem;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Selected Files Preview Styling */
.selected-files-preview {
  margin-top: 2rem;
  background: #f8fafc;
  background: var(--card-bg);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-radius: 16px;
  padding: 1.5rem;
  max-height: 300px;
  overflow-y: auto;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.04);
  display: flex;
  flex-direction: column;
  width: 100%;
  box-sizing: border-box;
}

.files-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  flex-shrink: 0;
}

.files-header h4 {
  margin: 0;
  color: #1f2937;
  color: var(--text-color);
  font-size: 1rem;
  font-weight: 600;
}

.clear-all-btn {
  background: none;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  color: #6b7280;
  color: var(--text-secondary);
  padding: 0.5rem 0.75rem;
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.75rem;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 0.375rem;
  transition: all 0.2s ease;
  font-family: 'Inter', sans-serif;
}

.clear-all-btn:hover {
  border-color: #dc2626;
  color: #dc2626;
  background-color: rgba(220, 38, 38, 0.05);
}

.clear-all-btn:active {
  transform: scale(0.98);
}

/* File List Container */
.file-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  overflow-y: auto;
  flex: 1 1;
  padding-right: 0.5rem;
  width: 100%;
}

.file-list::-webkit-scrollbar {
  width: 6px;
}

.file-list::-webkit-scrollbar-track {
  background: #e5e7eb;
  background: var(--card-border);
  border-radius: 3px;
}

.file-list::-webkit-scrollbar-thumb {
  background: #6b7280;
  background: var(--text-secondary);
  border-radius: 3px;
}

.file-list::-webkit-scrollbar-thumb:hover {
  background: #2979ff;
  background: var(--accent-blue);
}

.file-list {
  scrollbar-width: thin;
  scrollbar-color: #6b7280 #e5e7eb;
  scrollbar-color: var(--text-secondary) var(--card-border);
}

/* File Item Layout */
.file-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1rem;
  background-color: #ffffff;
  background-color: var(--primary-color);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-radius: 8px;
  transition: all 0.2s ease;
  min-height: 60px;
  width: 100%;
  box-sizing: border-box;
  position: relative;
}

.file-item:hover {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  box-shadow: 0 2px 8px rgba(41, 121, 255, 0.1);
}

.file-info {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  flex: 1 1;
  min-width: 0;
}

.file-name {
  font-weight: 500;
  color: #1f2937;
  color: var(--text-color);
  font-size: 0.875rem;
  word-break: break-word;
  line-height: 1.3;
}

.file-size {
  font-size: 0.75rem;
  color: #6b7280;
  color: var(--text-secondary);
}

.remove-file-btn {
  background: none;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  color: #6b7280;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 6px;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  margin-left: 1rem;
  position: relative;
}

.remove-file-btn:hover {
  color: #dc2626;
  background-color: rgba(220, 38, 38, 0.1);
  border-color: rgba(220, 38, 38, 0.3);
}

.remove-file-btn:active {
  transform: scale(0.95);
}

/* Results section */
.results-section {
  margin-top: 3rem;
  background-color: #f8fafc;
  background-color: var(--card-bg);
  padding: 2.5rem;
  border-radius: 16px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.04);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  position: relative;
  overflow: hidden;
}

.results-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #10b981, #34d399);
  background: linear-gradient(90deg, var(--success-color), #34d399);
}

.results-section h3 {
  color: #1f2937;
  color: var(--text-color);
  font-size: 1.75rem;
  font-weight: 600;
  margin-bottom: 1.5rem;
  letter-spacing: -0.02em;
}

/* Spacious Results Header */
.results-header-spacious {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
}

.results-header-spacious h3 {
  margin: 0;
  font-size: 1.75rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
}

/* Spacious Review Progress */
.upload-review-progress-spacious {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.progress-info-mini {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.5rem;
}

.progress-info-mini span {
  font-size: 0.875rem;
  color: #6b7280;
  color: var(--text-secondary);
  font-weight: 500;
}

.progress-bar-mini {
  width: 150px;
  height: 6px;
  background: #e5e7eb;
  background: var(--card-border);
  border-radius: 3px;
  overflow: hidden;
}

.progress-bar-fill-mini {
  height: 100%;
  background: linear-gradient(90deg, #10b981, #34d399);
  background: linear-gradient(90deg, var(--success-color), #34d399);
  transition: width 0.3s ease;
  border-radius: 3px;
}

.start-review-btn-small {
  background: #2979ff;
  background: var(--accent-blue);
  color: white;
  border: none;
  padding: 0.625rem 1rem;
  border-radius: 8px;
  cursor: pointer;
  font-weight: 600;
  font-size: 0.875rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  transition: all 0.2s ease;
  box-shadow: 0 2px 8px rgba(41, 121, 255, 0.2);
  font-family: 'Inter', sans-serif;
}

.start-review-btn-small:hover {
  background: #165ec9;
  background: var(--button-hover);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(41, 121, 255, 0.3);
}

/* Spacious Table - Matching TrackerPage design exactly */
.table-wrapper-spacious {
  background: #ffffff;
  background: var(--primary-color);
  border-radius: 16px;
  overflow-x: auto;
  overflow-y: hidden; /* Changed from visible to hidden for consistency */
  -webkit-overflow-scrolling: touch;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.04);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  margin-bottom: 2rem;
  /* Ensure horizontal scrolling works */
  max-width: 100%;
  position: relative;
}

/* Add scrollable tbody container - matching TrackerPage */
.table-wrapper-spacious .table-body-scroll {
  max-height: 480px; /* Height for 8 rows (8 * 60px per row) */
  overflow-y: auto;
  overflow-x: visible; /* Allow horizontal overflow to be handled by parent */
}

/* Custom scrollbar styling for vertical scroll */
.table-wrapper-spacious .table-body-scroll::-webkit-scrollbar {
  width: 8px;
}

.table-wrapper-spacious .table-body-scroll::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 4px;
}

.table-wrapper-spacious .table-body-scroll::-webkit-scrollbar-thumb {
  background: #c1c1c1;
  border-radius: 4px;
}

.table-wrapper-spacious .table-body-scroll::-webkit-scrollbar-thumb:hover {
  background: #a8a8a8;
}

/* Horizontal scrollbar styling for table wrapper */
.table-wrapper-spacious::-webkit-scrollbar {
  height: 8px;
}

.table-wrapper-spacious::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 4px;
}

.table-wrapper-spacious::-webkit-scrollbar-thumb {
  background: #c1c1c1;
  border-radius: 4px;
}

.table-wrapper-spacious::-webkit-scrollbar-thumb:hover {
  background: #a8a8a8;
}









/* UploadPage specific table styling - Black header and horizontal scroll */
.upload-table-spacious {
  width: 100%;
  min-width: 1000px; /* Reduced since we removed Created column */
  border-collapse: collapse;
}

.upload-table-spacious thead tr {
  background: #000000 !important;
}

.upload-table-spacious th {
  padding: 1.5rem 2rem;
  text-align: left;
  color: white !important;
  font-weight: 600;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: none;
  background: #000000 !important;
}

.upload-table-spacious .status-column {
  width: 100px;
  text-align: center;
}

.upload-table-spacious .action-column {
  width: 100px;
  text-align: center;
}

.upload-table-spacious tbody tr {
  transition: background-color 0.2s ease;
  border-bottom: 1px solid #f3f4f6;
}

.upload-table-spacious tbody tr:nth-child(even) {
  background-color: #fafbfc;
}

.upload-table-spacious tbody tr:hover {
  background-color: rgba(41, 121, 255, 0.02);
}

.upload-table-spacious tbody tr:nth-child(even):hover {
  background-color: rgba(41, 121, 255, 0.02);
}

.upload-table-spacious tbody tr:last-child {
  border-bottom: none;
}

/* Table Cells - Matching TrackerPage */
.status-cell {
  padding: 1.5rem 2rem;
  text-align: center;
}

.data-cell {
  padding: 1.5rem 2rem;
  color: #1f2937;
  color: var(--text-color);
  font-weight: 500;
  font-size: 0.9rem;
}

.action-cell {
  padding: 1.5rem 2rem;
  text-align: center;
}

/* Action Buttons - Matching TrackerPage */
.action-buttons {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  justify-content: center;
}

.action-btn {
  background: none;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  color: #6b7280;
  color: var(--text-secondary);
  padding: 0.5rem;
  border-radius: 6px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  min-width: 32px;
  height: 32px;
}

.tick-btn:hover {
  border-color: #10b981;
  border-color: var(--success-color);
  color: #10b981;
  color: var(--success-color);
  background: rgba(16, 185, 129, 0.05);
}

.edit-btn:hover {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  color: #2979ff;
  color: var(--accent-blue);
  background: rgba(41, 121, 255, 0.05);
}

.action-btn.reviewed-tick {
  background: #10b981 !important;
  background: var(--success-color) !important;
  border-color: #10b981 !important;
  border-color: var(--success-color) !important;
  color: white !important;
}

.action-btn.reviewed-tick:hover {
  background: #059669 !important;
  border-color: #059669 !important;
  color: white !important;
}

/* Review Button Styles - Matching TrackerPage */
.review-button {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.75rem;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-radius: 6px;
  background: #ffffff;
  background: var(--primary-color);
  cursor: pointer;
  font-size: 0.75rem;
  font-weight: 500;
  transition: all 0.2s ease;
  font-family: 'Inter', sans-serif;
}

.review-button.small {
  padding: 0.375rem 0.5rem;
  font-size: 0.7rem;
}

.review-button.pending {
  color: #6b7280;
  color: var(--text-secondary);
  border-color: #e5e7eb;
  border-color: var(--card-border);
}

.review-button.pending:hover {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  color: #2979ff;
  color: var(--accent-blue);
}

.review-button.reviewed {
  color: #10b981;
  border-color: rgba(16, 185, 129, 0.3);
  background: rgba(16, 185, 129, 0.05);
}

.review-button.edited {
  color: #f59e0b;
  border-color: rgba(245, 158, 11, 0.3);
  background: rgba(245, 158, 11, 0.05);
}

.status-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  flex-shrink: 0;
}

.status-icon.small {
  width: 16px;
  height: 16px;
}

.status-icon.pending {
  background: #e5e7eb;
  background: var(--card-border);
  color: #6b7280;
  color: var(--text-secondary);
}

.status-icon.reviewed {
  background: #10b981;
  color: white;
}

.status-icon.edited {
  background: #f59e0b;
  color: white;
  border-radius: 4px;
}

.button-text {
  white-space: nowrap;
}

/* Edited Row Styling */
.edited-row {
  background-color: rgba(245, 158, 11, 0.02) !important;
}

.edited-row:hover {
  background-color: rgba(245, 158, 11, 0.05) !important;
}

.edited-field {
  color: #f59e0b !important;
  font-weight: 600 !important;
  position: relative;
}

.edited-field::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 2px;
  background: rgba(245, 158, 11, 0.3);
  border-radius: 1px;
}

/* Clickable filename styling */
.clickable-filename {
  color: #2979ff;
  color: var(--accent-blue);
  cursor: pointer;
  text-decoration: none;
  transition: color 0.2s ease;
  font-weight: 500;
}

.clickable-filename:hover {
  color: #165ec9;
  color: var(--button-hover);
}

/* Export Modal Styles */
.export-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 1rem;
  overflow: hidden;
}

.export-modal {
  background: white;
  border-radius: 16px;
  width: 100%;
  max-width: 600px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
  font-family: 'Inter', sans-serif;
  animation: slideIn 0.3s ease-out;
}

@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.export-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem 2rem;
  border-bottom: 1px solid #e5e7eb;
  border-bottom: 1px solid var(--card-border);
}

.export-modal-header h3 {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
}

.export-close-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 8px;
  color: #6b7280;
  color: var(--text-secondary);
  transition: all 0.2s ease;
}

.export-close-btn:hover {
  background: #f8fafc;
  background: var(--card-bg);
  color: #1f2937;
  color: var(--text-color);
}

.export-modal-content {
  padding: 2rem;
}

.export-description {
  margin: 0 0 2rem 0;
  color: #6b7280;
  color: var(--text-secondary);
  font-size: 1rem;
  line-height: 1.6;
}

.export-options {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.export-option-btn {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.5rem;
  border: 2px solid #e5e7eb;
  border: 2px solid var(--card-border);
  border-radius: 12px;
  background: #ffffff;
  background: var(--primary-color);
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: 'Inter', sans-serif;
  text-align: left;
}

.export-option-btn:hover:not(:disabled) {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  background: rgba(41, 121, 255, 0.02);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(41, 121, 255, 0.1);
}

.export-option-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

.export-option-btn.csv:hover:not(:disabled) {
  border-color: #10b981;
  border-color: var(--success-color);
  background: rgba(16, 185, 129, 0.02);
  box-shadow: 0 8px 24px rgba(16, 185, 129, 0.1);
}

.export-option-btn.xlsx:hover:not(:disabled) {
  border-color: #059669;
  background: rgba(5, 150, 105, 0.02);
  box-shadow: 0 8px 24px rgba(5, 150, 105, 0.1);
}

.export-option-btn.both:hover:not(:disabled) {
  border-color: #f59e0b;
  border-color: var(--warning-color);
  background: rgba(245, 158, 11, 0.02);
  box-shadow: 0 8px 24px rgba(245, 158, 11, 0.1);
}

.export-option-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: #f8fafc;
  background: var(--card-bg);
  flex-shrink: 0;
}

.export-option-btn.csv .export-option-icon {
  background: rgba(16, 185, 129, 0.1);
  color: #10b981;
  color: var(--success-color);
}

.export-option-btn.xlsx .export-option-icon {
  background: rgba(5, 150, 105, 0.1);
  color: #059669;
}

.export-option-btn.both .export-option-icon {
  background: rgba(245, 158, 11, 0.1);
  color: #f59e0b;
  color: var(--warning-color);
}

.export-option-content {
  flex: 1 1;
}

.export-option-content h4 {
  margin: 0 0 0.5rem 0;
  font-size: 1.125rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
}

.export-option-content p {
  margin: 0;
  font-size: 0.875rem;
  color: #6b7280;
  color: var(--text-secondary);
  line-height: 1.5;
}

.export-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 2rem;
  padding: 1rem;
  background: #f8fafc;
  background: var(--card-bg);
  border-radius: 8px;
  color: #6b7280;
  color: var(--text-secondary);
  font-weight: 500;
}

.export-spinner {
  width: 20px;
  height: 20px;
  border: 2px solid #e5e7eb;
  border: 2px solid var(--card-border);
  border-top: 2px solid #2979ff;
  border-top: 2px solid var(--accent-blue);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

/* Duplicate Detection Modal Styles */
.duplicate-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 1rem;
  overflow: hidden;
}

body.modal-open {
  overflow: hidden;
  position: fixed;
  width: 100%;
  height: 100%;
}

.duplicate-modal {
  background: white;
  border-radius: 16px;
  width: 100%;
  max-width: 900px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
  font-family: 'Inter', sans-serif;
}

.duplicate-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem 2rem;
  border-bottom: 1px solid #e5e7eb;
}

.duplicate-modal-header h3 {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 600;
  color: #dc2626;
}

.close-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 8px;
  color: #6b7280;
  transition: all 0.2s ease;
}

.close-btn:hover {
  background: #f3f4f6;
  color: #374151;
}

.duplicate-modal-content {
  flex: 1 1;
  overflow-y: auto;
  padding: 1.5rem 2rem;
}

.duplicate-warning {
  margin: 0 0 1.5rem 0;
  padding: 1rem;
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 8px;
  color: #dc2626;
  font-weight: 500;
}

.duplicates-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.duplicate-item {
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  overflow: hidden;
  background: #fafbfc;
}

.duplicate-details {
  padding: 1.5rem;
}

.duplicate-details h4 {
  margin: 0 0 1rem 0;
  font-size: 1.125rem;
  font-weight: 600;
  color: #374151;
}

.invoice-comparison {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  grid-gap: 1.5rem;
  gap: 1.5rem;
  align-items: center;
}

.invoice-info {
  background: white;
  padding: 1rem;
  border-radius: 8px;
  border: 1px solid #e5e7eb;
}

.invoice-info.existing {
  background: #f8fafc;
}

.info-row {
  display: flex;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.info-row:last-child {
  margin-bottom: 0;
}

.label {
  font-weight: 600;
  color: #6b7280;
  font-size: 0.875rem;
}

.value {
  font-weight: 500;
  color: #374151;
  font-size: 0.875rem;
}

.created-date {
  font-size: 0.8rem;
  color: #6b7280;
  font-style: italic;
}

.vs-indicator {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  color: #dc2626;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.duplicate-actions {
  display: flex;
  gap: 0.75rem;
  padding: 1rem 1.5rem;
  background: white;
  border-top: 1px solid #e5e7eb;
}

.action-btn.keep {
  flex: 1 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem 1rem;
  border: 2px solid transparent;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 0.875rem;
  font-family: 'Inter', sans-serif;
  background: #f0f9ff;
  color: #0369a1;
  border-color: #e0f2fe;
}

.action-btn.keep:hover,
.action-btn.keep.active {
  background: #0369a1;
  color: white;
  border-color: #0369a1;
}

.action-btn.delete {
  flex: 1 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem 1rem;
  border: 2px solid transparent;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 0.875rem;
  font-family: 'Inter', sans-serif;
  background: #fef2f2;
  color: #dc2626;
  border-color: #fecaca;
}

.action-btn.delete:hover,
.action-btn.delete.active {
  background: #dc2626;
  color: white;
  border-color: #dc2626;
}

.duplicate-modal-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem 2rem;
  border-top: 1px solid #e5e7eb;
  background: #f9fafb;
}

.bulk-actions {
  display: flex;
  gap: 0.75rem;
}

.bulk-btn {
  padding: 0.75rem 1rem;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  background: white;
  color: #374151;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 0.875rem;
  font-family: 'Inter', sans-serif;
}

.bulk-btn:hover {
  background: #f3f4f6;
  border-color: #9ca3af;
}

.bulk-btn.keep-all:hover {
  background: #dbeafe;
  border-color: #3b82f6;
  color: #1d4ed8;
}

.bulk-btn.delete-all:hover {
  background: #fee2e2;
  border-color: #ef4444;
  color: #dc2626;
}

.apply-btn {
  background: #2563eb;
  color: white;
  border: none;
  padding: 0.75rem 1.5rem;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 0.875rem;
  font-family: 'Inter', sans-serif;
}

.apply-btn:hover:not(:disabled) {
  background: #1d4ed8;
}

.apply-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Enhanced Status Indicator - Updated to match TrackerPage */
.status-indicator {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8rem;
  font-weight: 500;
  transition: all 0.2s ease;
}

.status-indicator svg {
  flex-shrink: 0;
  transition: transform 0.2s ease;
}

.status-indicator:hover svg {
  transform: scale(1.1);
}

.status-text {
  white-space: nowrap;
}

/* Platform-specific hover effects */
.enhanced-status[title*="Web"]:hover {
  color: #2979ff !important;
}

.enhanced-status[title*="Email"]:hover {
  color: #1a73e8 !important;
}

.enhanced-status[title*="Whatsapp"]:hover {
  color: #25d366 !important;
}

/* Status color variants */
.status-processed {
  color: #10b981;
}

.status-queueing {
  color: #f59e0b;
}

.status-failed {
  color: #ef4444;
}

/* Column Info Icons */
.column-header-with-info {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  justify-content: center;
}

.column-info-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.8);
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
}

.column-info-icon:hover {
  background: rgba(255, 255, 255, 0.25);
  color: rgba(255, 255, 255, 1);
  transform: scale(1.1);
}

.column-info-icon:active {
  transform: scale(0.95);
}

/* Info Popup Modal */
.info-popup-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  animation: fadeIn 0.2s ease-out;
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
}

.info-popup {
  background: white;
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
  min-width: 400px;
  max-width: 90vw;
  animation: slideIn 0.3s ease-out;
  overflow: hidden;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
}

.info-popup-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem 1.5rem;
  border-bottom: 1px solid #e5e7eb;
  border-bottom: 1px solid var(--card-border);
  background: #f8fafc;
  background: var(--card-bg);
}

.info-popup-title-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.info-popup-icon {
  color: #2979ff;
  color: var(--accent-blue);
  flex-shrink: 0;
}

.info-popup-title {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
  font-family: 'Inter', sans-serif;
}

.info-popup-close {
  background: none;
  border: none;
  color: #6b7280;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
}

.info-popup-close:hover {
  background: rgba(0, 0, 0, 0.1);
  color: #1f2937;
  color: var(--text-color);
}

.info-popup-content {
  padding: 1.5rem;
  background: white;
}

.info-popup-content p,
.info-popup-content div {
  margin: 0;
  color: #1f2937;
  color: var(--text-color);
  font-size: 1rem;
  line-height: 1.6;
  text-align: left;
  font-family: 'Inter', sans-serif;
}

@keyframes fadeIn {
  from { 
    opacity: 0; 
    -webkit-backdrop-filter: blur(0); 
            backdrop-filter: blur(0);
  }
  to { 
    opacity: 1;
    -webkit-backdrop-filter: blur(2px);
            backdrop-filter: blur(2px);
  }
}

/* Mobile Responsive Design */
@media (max-width: 1024px) {
  .upload-review-progress-spacious {
    flex-direction: column;
    align-items: flex-start;
    gap: 1.5rem;
  }
  
  .progress-bar-mini {
    width: 100%;
    max-width: none;
  }
  
  .start-review-btn-small {
    align-self: flex-start;
  }
}

@media (max-width: 768px) {
  .upload-page-container {
    padding: 1rem;
    min-height: auto;
  }
  
  .upload-page-container h2 {
    font-size: 1.75rem;
    margin-bottom: 2rem;
  }
  
  .drop-zone {
    padding: 1.5rem 1rem;
    min-height: 160px;
  }
  
  .drop-zone p {
    font-size: 1rem;
  }
  
  .drop-icon {
    width: 48px;
    height: 48px;
  }
  
  /* FIXED: Selected Files Mobile Styling */
  .selected-files-preview {
    margin: 1.5rem auto 0;
    padding: 1rem;
    max-height: 220px;
    width: 100%;
    max-width: none;
  }
  
  .files-header {
    flex-direction: column;
    gap: 0.75rem;
    align-items: center;
    text-align: center;
  }
  
  .files-header h4 {
    font-size: 0.9rem;
    text-align: center;
  }
  
  .clear-all-btn {
    width: -webkit-fit-content;
    width: fit-content;
    margin: 0 auto;
    padding: 0.375rem 0.625rem;
    font-size: 0.7rem;
  }
  
  .clear-all-btn svg {
    width: 14px;
    height: 14px;
  }
  
  /* FIXED: File Item Layout for Mobile */
  .file-item {
    min-height: 64px;
    height: auto;
    padding: 0.75rem;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
    box-sizing: border-box !important;
    gap: 0.75rem;
  }
  
  .file-info {
    flex: 1 1 !important;
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0.25rem !important;
  }
  
  .file-name {
    font-size: 0.8rem;
    font-weight: 500;
    color: #1f2937;
    color: var(--text-color);
    line-height: 1.3;
    /* Truncate long filenames with ellipsis */
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
  }
  
  .file-size {
    font-size: 0.7rem;
    color: #6b7280;
    color: var(--text-secondary);
    white-space: nowrap;
  }
  
  .remove-file-btn {
    width: 32px !important;
    height: 32px !important;
    flex-shrink: 0 !important;
    margin-left: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: none;
    border: 1px solid #e5e7eb;
    border: 1px solid var(--card-border);
    color: #6b7280;
    color: var(--text-secondary);
    cursor: pointer;
    border-radius: 6px;
    transition: all 0.2s ease;
  }
  
  .remove-file-btn:hover {
    color: #dc2626;
    background-color: rgba(220, 38, 38, 0.1);
    border-color: rgba(220, 38, 38, 0.3);
  }
  
  .remove-file-btn svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
  }
  
  /* HIDE RESULTS SECTION ENTIRELY ON MOBILE */
  .results-section {
    display: none;
  }
  
  /* Export modal mobile */
  .export-modal {
    margin: 1rem;
    max-width: none;
  }

  .export-modal-header,
  .export-modal-content {
    padding: 1.5rem;
  }

  .export-options {
    gap: 0.75rem;
  }

  .export-option-btn {
    flex-direction: column;
    text-align: center;
    padding: 1rem;
    gap: 0.75rem;
  }

  .export-option-icon {
    width: 40px;
    height: 40px;
  }

  .export-option-content h4 {
    font-size: 1rem;
  }

  .export-option-content p {
    font-size: 0.8rem;
  }
  
  /* Duplicate modal mobile */
  .duplicate-modal {
    margin: 1rem;
    max-width: none;
  }

  .duplicate-modal-header,
  .duplicate-modal-content,
  .duplicate-modal-footer {
    padding: 1rem;
  }

  .invoice-comparison {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .vs-indicator {
    order: -1;
  }

  .duplicate-modal-footer {
    flex-direction: column;
    gap: 1rem;
    align-items: stretch;
  }

  .bulk-actions {
    justify-content: center;
  }
  
  .results-header-spacious {
    flex-direction: column;
    align-items: stretch;
    gap: 1rem;
  }
  
  .upload-review-progress-spacious {
    justify-content: space-between;
  }
  
  .progress-info-mini {
    align-items: flex-start;
  }
  
  .progress-bar-mini {
    width: 100px;
  }
  
  .review-button .button-text {
    display: none;
  }
  
  .review-button {
    padding: 0.375rem;
    min-width: 32px;
    justify-content: center;
  }
  
  .status-icon {
    width: 16px;
    height: 16px;
  }
  
  .start-review-btn-small {
    font-size: 0.7rem;
    padding: 0.375rem 0.625rem;
  }
  
  /* Table responsive on mobile */
  .table-wrapper-spacious {
    margin: 0 -1rem;
    border-radius: 12px;
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
  }
  
  .tracker-table-spacious {
    min-width: 700px;
    width: auto;
    overflow: visible;
  }
  
  .tracker-table-spacious th,
  .tracker-table-spacious .data-cell {
    padding: 0.75rem 0.5rem;
    font-size: 0.75rem;
    white-space: nowrap;
  }
  
  .tracker-table-spacious .status-column,
  .tracker-table-spacious .action-column {
    width: 60px;
  }

  /* UploadPage table mobile styles */
  .upload-table-spacious {
    min-width: 700px;
    width: auto;
    overflow: visible;
  }
  
  .upload-table-spacious th,
  .upload-table-spacious .data-cell {
    padding: 0.75rem 0.5rem;
    font-size: 0.75rem;
    white-space: nowrap;
  }
  
  .upload-table-spacious .status-column,
  .upload-table-spacious .action-column {
    width: 60px;
  }
  
  .status-cell,
  .action-cell {
    padding: 0.75rem 0.25rem;
  }
  
  /* Info popup mobile */
  .info-popup {
    min-width: auto;
    width: 90vw;
    margin: 1rem;
  }
  
  .info-popup-header {
    padding: 1rem 1rem 0;
  }
  
  .info-popup-content {
    padding: 1rem;
  }
  
  .info-popup-title {
    font-size: 1rem;
  }
  
  .info-popup-content p {
    font-size: 0.9rem;
  }
}

@media (max-width: 480px) {
  .upload-page-container h2 {
    font-size: 1.5rem;
  }
  
  .drop-zone {
    padding: 1rem;
    min-height: 140px;
  }
  
  .drop-icon {
    width: 40px;
    height: 40px;
  }
  
  /* FIXED: Even smaller mobile file items */
  .file-item {
    min-height: 56px !important;
    height: auto !important;
    padding: 0.625rem !important;
    gap: 0.5rem !important;
  }
  
  .file-name {
    font-size: 0.75rem;
  }
  
  .file-size {
    font-size: 0.65rem;
  }
  
  .remove-file-btn {
    width: 28px !important;
    height: 28px !important;
  }
  
  .remove-file-btn svg {
    width: 14px;
    height: 14px;
  }
  
  .tracker-table-spacious {
    min-width: 600px;
  }
  
  .tracker-table-spacious th,
  .tracker-table-spacious .data-cell {
    padding: 0.5rem 0.25rem;
    font-size: 0.7rem;
  }

  /* UploadPage table smaller mobile styles */
  .upload-table-spacious {
    min-width: 600px;
  }
  
  .upload-table-spacious th,
  .upload-table-spacious .data-cell {
    padding: 0.5rem 0.25rem;
    font-size: 0.7rem;
  }
  
  .action-btn {
    min-width: 28px;
    height: 28px;
    padding: 0.375rem;
  }
  
  .action-btn svg {
    width: 12px;
    height: 12px;
  }
}

/* Basic Modal Styles for Export Warning */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

.modal-content {
  background: #ffffff;
  background: var(--primary-color);
  border-radius: 16px;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
  max-width: 500px;
  width: 90vw;
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
}

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem 2rem;
  border-bottom: 1px solid #e5e7eb;
  border-bottom: 1px solid var(--card-border);
}

.modal-header h3 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
}

.modal-close-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 8px;
  color: #6b7280;
  color: var(--text-secondary);
  transition: all 0.2s ease;
}

.modal-close-btn:hover {
  background: #f8fafc;
  background: var(--card-bg);
  color: #1f2937;
  color: var(--text-color);
}

.modal-body {
  padding: 2rem;
}

.modal-footer {
  padding: 1.5rem 2rem;
  border-top: 1px solid #e5e7eb;
  border-top: 1px solid var(--card-border);
}

.modal-actions-centered {
  display: flex;
  justify-content: center;
  gap: 0.75rem;
}

.modal-btn {
  padding: 0.75rem 1.5rem;
  border-radius: 8px;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  border: none;
  font-family: 'Inter', sans-serif;
}

.modal-btn-primary {
  background: #2979ff;
  background: var(--button-bg);
  color: white;
}

.modal-btn-primary:hover {
  background: #165ec9;
  background: var(--button-hover);
  transform: translateY(-1px);
}

.modal-btn-secondary {
  background: #f8fafc;
  background: var(--card-bg);
  color: #6b7280;
  color: var(--text-secondary);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
}

.modal-btn-secondary:hover {
  background: #ffffff;
  background: var(--primary-color);
  border-color: #2979ff;
  border-color: var(--accent-blue);
  color: #2979ff;
  color: var(--accent-blue);
}

/* Export Form Styles */
.export-form {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.form-group.toggle {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
}

.form-group label {
  font-size: 0.875rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
}

.form-group select {
  padding: 0.75rem 1rem;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-radius: 8px;
  background: #ffffff;
  background: var(--primary-color);
  color: #1f2937;
  color: var(--text-color);
  font-size: 0.875rem;
  font-family: 'Inter', sans-serif;
  transition: all 0.2s ease;
  -webkit-appearance: none;
          appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27 fill=%27none%27 stroke=%27currentColor%27 stroke-width=%272%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27%3e%3cpolyline points=%276,9 12,15 18,9%27%3e%3c/polyline%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 1rem;
  padding-right: 2.5rem;
}

.form-group select:focus {
  outline: none;
  border-color: #2979ff;
  border-color: var(--input-focus);
  box-shadow: 0 0 0 3px rgba(41, 121, 255, 0.1);
}

/* Toggle Switch Styles */
.switch {
  position: relative;
  display: inline-block;
  width: 50px;
  height: 24px;
}

.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  transition: .4s;
  border-radius: 24px;
}

.slider:before {
  position: absolute;
  content: "";
  height: 18px;
  width: 18px;
  left: 3px;
  bottom: 3px;
  background-color: white;
  transition: .4s;
  border-radius: 50%;
}

input:checked + .slider {
  background-color: #2979ff;
  background-color: var(--accent-blue);
}

input:checked + .slider:before {
  transform: translateX(26px);
}

/* File Type Radio Buttons */
.filetype-options {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.radio-btn {
  display: flex;
  align-items: center;
  padding: 0.75rem 1rem;
  border: 2px solid #e5e7eb;
  border: 2px solid var(--card-border);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
  background: #ffffff;
  background: var(--primary-color);
  flex: 1 1;
  min-width: 120px;
  justify-content: center;
}

.radio-btn:hover {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  background: rgba(41, 121, 255, 0.05);
}

.radio-btn.active {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  background: rgba(41, 121, 255, 0.1);
  color: #2979ff;
  color: var(--accent-blue);
}

.radio-btn input[type="radio"] {
  margin-right: 0.5rem;
}

.export-actions {
  display: flex;
  justify-content: center;
  margin-top: 1rem;
}

/* GENERAL MOBILE UTILITIES */
@media (max-width: 768px) {
  .table-wrapper-spacious::after {
    content: "← Scroll to see more →";
    display: block;
    text-align: center;
    font-size: 0.75rem;
    color: #6b7280;
    color: var(--text-secondary);
    padding: 0.5rem;
    background: rgba(41, 121, 255, 0.05);
    border-top: 1px solid #e5e7eb;
    border-top: 1px solid var(--card-border);
  }
  
  .table-wrapper-spacious::-webkit-scrollbar {
    height: 4px;
  }
  
  .table-wrapper-spacious::-webkit-scrollbar-track {
    background: #e5e7eb;
    background: var(--card-border);
  }
  
  .table-wrapper-spacious::-webkit-scrollbar-thumb {
    background: #2979ff;
    background: var(--accent-blue);
    border-radius: 2px;
  }
  
  /* Touch-friendly button sizes */
  button, .button, .btn {
    min-height: 44px;
    min-width: 44px;
  }
  
  .clickable-filename {
    padding: 0.5rem 0;
    display: inline-block;
  }
}

/* Desktop-only enhancements */
@media (min-width: 769px) {
  .table-wrapper-spacious:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
  }
}

/* Prevent horizontal overflow on mobile */
@media (max-width: 768px) {
  body {
    overflow-x: hidden;
  }
  
  * {
    max-width: 100%;
  }
  
  .upload-page-container {
    overflow-x: hidden;
  }
}
/* src/components/FileViewer.css */

.file-viewer-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: transparent;
  z-index: 1000;
  padding: 0;
  pointer-events: none; /* Allow clicks to pass through the overlay */
}

.file-viewer-modal {
  background: white;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3), 0 0 0 1px rgba(0, 0, 0, 0.1);
  position: absolute;
  pointer-events: auto; /* Re-enable pointer events for the modal itself */
  min-width: 300px;
  min-height: 200px;
  max-width: 90vw;
  max-height: 90vh;
}

.file-viewer-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid #e0e0e0;
  background: #f9f9f9;
  border-radius: 8px 8px 0 0;
  cursor: move; /* Indicate draggable area */
  -webkit-user-select: none;
          user-select: none; /* Prevent text selection while dragging */
  flex-shrink: 0;
}

.file-viewer-title {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
  color: #333;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1 1;
  margin-right: 16px;
}

.file-viewer-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.file-viewer-download {
  background: #007bff;
  color: white;
  border: none;
  border-radius: 4px;
  padding: 6px 10px;
  cursor: pointer;
  text-decoration: none;
  font-size: 14px;
  transition: background-color 0.2s;
  line-height: 1;
}

.file-viewer-download:hover {
  background: #0056b3;
  color: white;
  text-decoration: none;
}

.file-viewer-close {
  background: #dc3545;
  color: white;
  border: none;
  border-radius: 4px;
  padding: 6px 10px;
  cursor: pointer;
  font-size: 14px;
  font-weight: bold;
  transition: background-color 0.2s;
  line-height: 1;
}

.file-viewer-close:hover {
  background: #c82333;
}

.file-viewer-content {
  flex: 1 1;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  position: relative;
  background: #f8f9fa;
}

.file-viewer-image-container {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  position: relative;
  cursor: grab;
}

.file-viewer-image-container:active {
  cursor: grabbing;
}

.file-viewer-image-container.zoomed {
  cursor: move;
}

.file-viewer-image {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: 4px;
  transition: transform 0.2s ease;
  -webkit-user-select: none;
          user-select: none;
  pointer-events: none;
}

.file-viewer-pdf {
  width: 100%;
  height: 100%;
  border: none;
  border-radius: 0 0 8px 8px;
}

.file-viewer-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #666;
}

.loading-spinner {
  width: 32px;
  height: 32px;
  border: 3px solid #f3f3f3;
  border-top: 3px solid #007bff;
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-bottom: 12px;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

.file-viewer-error {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #dc3545;
  text-align: center;
  padding: 20px;
}

.error-close-btn {
  background: #dc3545;
  color: white;
  border: none;
  border-radius: 4px;
  padding: 8px 16px;
  cursor: pointer;
  margin-top: 12px;
  transition: background-color 0.2s;
}

.error-close-btn:hover {
  background: #c82333;
}

.file-viewer-unsupported {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #666;
  text-align: center;
  padding: 20px;
}

.download-link {
  background: #007bff;
  color: white;
  padding: 8px 16px;
  border-radius: 4px;
  text-decoration: none;
  margin-top: 12px;
  transition: background-color 0.2s;
}

.download-link:hover {
  background: #0056b3;
  color: white;
  text-decoration: none;
}

/* Navigation Controls */
.file-viewer-nav {
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  background: rgba(0, 0, 0, 0.8);
  padding: 8px 12px;
  border-radius: 20px;
  z-index: 10;
}

.nav-btn {
  background: rgba(255, 255, 255, 0.2);
  border: none;
  color: white;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  font-size: 14px;
}

.nav-btn:hover:not(:disabled) {
  background: rgba(255, 255, 255, 0.3);
  transform: scale(1.1);
}

.nav-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.nav-info {
  color: white;
  font-size: 12px;
  padding: 0 8px;
  display: flex;
  align-items: center;
  white-space: nowrap;
}

/* Zoom Controls */
.file-viewer-zoom {
  position: absolute;
  bottom: 16px;
  right: 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  background: rgba(0, 0, 0, 0.8);
  padding: 8px;
  border-radius: 8px;
  z-index: 10;
}

.zoom-btn {
  background: rgba(255, 255, 255, 0.2);
  border: none;
  color: white;
  width: 32px;
  height: 32px;
  border-radius: 4px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  font-size: 16px;
  font-weight: bold;
}

.zoom-btn:hover:not(:disabled) {
  background: rgba(255, 255, 255, 0.3);
}

.zoom-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.zoom-info {
  color: white;
  font-size: 10px;
  text-align: center;
  margin: 4px 0;
}

/* Resize handles */
.resize-handle {
  position: absolute;
  background: transparent;
}

.resize-handle-se {
  bottom: 0;
  right: 0;
  width: 20px;
  height: 20px;
  cursor: nw-resize;
}

.resize-handle-s {
  bottom: 0;
  left: 10px;
  right: 10px;
  height: 10px;
  cursor: s-resize;
}

.resize-handle-e {
  top: 10px;
  bottom: 10px;
  right: 0;
  width: 10px;
  cursor: e-resize;
}

.resize-handle-n {
  top: 0;
  left: 10px;
  right: 10px;
  height: 10px;
  cursor: n-resize;
}

.resize-handle-w {
  top: 10px;
  bottom: 10px;
  left: 0;
  width: 10px;
  cursor: w-resize;
}

.resize-handle-ne {
  top: 0;
  right: 0;
  width: 20px;
  height: 20px;
  cursor: ne-resize;
}

.resize-handle-nw {
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  cursor: nw-resize;
}

.resize-handle-sw {
  bottom: 0;
  left: 0;
  width: 20px;
  height: 20px;
  cursor: sw-resize;
}

/* Resize indicator in bottom-right corner */
.resize-indicator {
  position: absolute;
  bottom: 4px;
  right: 4px;
  width: 12px;
  height: 12px;
  background: linear-gradient(-45deg, transparent 0%, transparent 30%, #ccc 30%, #ccc 35%, transparent 35%, transparent 65%, #ccc 65%, #ccc 70%, transparent 70%);
  cursor: nw-resize;
  opacity: 0.6;
  transition: opacity 0.2s;
}

.file-viewer-modal:hover .resize-indicator {
  opacity: 1;
}

/* Clickable filename styles */
.clickable-filename {
  color: #007bff;
  cursor: pointer;
  text-decoration: underline;
  transition: color 0.2s;
}

.clickable-filename:hover {
  color: #0056b3;
}

/* Responsive design */
@media (max-width: 768px) {
  .file-viewer-overlay {
    padding: 10px;
  }
  
  .file-viewer-modal {
    max-width: calc(100vw - 20px);
    max-height: calc(100vh - 20px);
  }
  
  .file-viewer-header {
    padding: 10px 12px;
  }
  
  .file-viewer-title {
    font-size: 13px;
  }
  
  .file-viewer-download,
  .file-viewer-close {
    padding: 5px 8px;
    font-size: 13px;
  }
  
  .file-viewer-nav {
    bottom: 8px;
    gap: 4px;
    padding: 6px 8px;
  }
  
  .nav-btn {
    width: 28px;
    height: 28px;
    font-size: 12px;
  }
  
  .nav-info {
    font-size: 10px;
    padding: 0 4px;
  }
  
  .file-viewer-zoom {
    bottom: 8px;
    right: 8px;
    padding: 6px;
  }
  
  .zoom-btn {
    width: 28px;
    height: 28px;
    font-size: 14px;
  }
}

/* Enhanced mobile responsive fixes */
@media (max-width: 768px) {
  .file-viewer-overlay {
    padding: 0 !important;
  }
  
  .file-viewer-modal {
    border-radius: 8px !important;
    margin: 0 !important;
  }
  
  .file-viewer-header {
    padding: 12px !important;
    flex-wrap: nowrap;
    gap: 8px;
  }
  
  .file-viewer-title {
    font-size: 13px !important;
    word-break: break-all;
  }
  
  .file-viewer-close {
    position: relative !important;
    top: auto !important;
    right: auto !important;
  }
  
  .file-viewer-content {
    padding: 0 !important;
  }
  
  .file-viewer-pdf {
    border-radius: 0 0 8px 8px !important;
  }
  
  /* Hide resize handles on mobile */
  .resize-handle,
  .resize-indicator {
    display: none;
  }
}
/* src/components/ReviewPanel.css - Form-Based Review Layout - LEFT ALIGNED */

:root {
  --primary-color: #ffffff;
  --accent-blue: #2979ff;
  --text-color: #1f2937;
  --text-secondary: #6b7280;
  --card-bg: #f8fafc;
  --card-border: #e5e7eb;
  --button-bg: #2979ff;
  --button-hover: #165ec9;
  --input-focus: #2979ff;
  --success-color: #10b981;
  --warning-color: #f59e0b;
  --danger-color: #ef4444;
  --current-file-bg: rgba(41, 121, 255, 0.08);
  --current-file-border: #2979ff;
}

/* Full Screen Overlay */
.review-panel-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 1000;
  font-family: 'Inter', sans-serif;
  overflow: hidden;
}

/* Full Screen Panel */
.review-panel {
  width: 100vw;
  height: 100vh;
  background: #ffffff;
  background: var(--primary-color);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* Progress Bar - Fixed Height */
.review-progress-bar {
  height: 4px;
  background: #e5e7eb;
  background: var(--card-border);
  flex-shrink: 0;
}

.review-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, #10b981, #34d399);
  background: linear-gradient(90deg, var(--success-color), #34d399);
  transition: width 0.3s ease;
}

/* Main Content - Takes Remaining Space */
.review-panel-content {
  flex: 1 1;
  display: flex;
  min-height: 0;
  overflow: hidden;
}

/* Left Section - File Preview (Unchanged) */
.review-file-section {
  width: 50%;
  background: #ffffff;
  background: var(--primary-color);
  border-right: 1px solid #e5e7eb;
  border-right: 1px solid var(--card-border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* File Preview - Takes All Available Space with Controls */
.review-file-preview-inline {
  flex: 1 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: #fafbfc;
  min-height: 0;
  position: relative;
}

/* Zoom Controls - Vertical on Right Side */
.preview-zoom-controls {
  position: absolute;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  background: rgba(128, 128, 128, 0.9);
  padding: 8px 6px;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  z-index: 100;
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
  opacity: 0.9;
  transition: opacity 0.2s ease;
}

.preview-zoom-controls:hover {
  opacity: 1;
  background: rgba(128, 128, 128, 1);
}

/* Bottom Rotation Controls - Horizontal at Bottom Center */
.preview-bottom-rotation-controls {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 6px;
  background: rgba(128, 128, 128, 0.9);
  padding: 8px 6px;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  z-index: 100;
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
  opacity: 0.9;
  transition: opacity 0.2s ease;
}

.preview-bottom-rotation-controls:hover {
  opacity: 1;
  background: rgba(128, 128, 128, 1);
}

.preview-zoom-btn,
.preview-rotation-btn {
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: #1f2937;
  color: var(--text-color);
  padding: 4px;
  border-radius: 4px;
  cursor: pointer;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
}

.preview-zoom-btn:hover,
.preview-rotation-btn:hover {
  background: #ffffff !important;
  background: var(--primary-color) !important;
  color: #2979ff !important;
  color: var(--accent-blue) !important;
  border-color: #2979ff !important;
  border-color: var(--accent-blue) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(41, 121, 255, 0.1);
}

.preview-zoom-level {
  font-size: 0.75rem;
  font-weight: 600;
  color: white;
  text-align: center;
  padding: 2px 4px;
  border-radius: 3px;
  background: rgba(0, 0, 0, 0.3);
  min-width: 35px;
}

.preview-rotation-level {
  font-size: 0.75rem;
  font-weight: 600;
  color: white;
  text-align: center;
  padding: 2px 4px;
  border-radius: 3px;
  background: rgba(0, 0, 0, 0.3);
  min-width: 35px;
}

.file-preview-container {
  flex: 1 1;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0;
  background: #ffffff;
  background: var(--primary-color);
  box-shadow: none;
  overflow: hidden;
  margin: 0;
}

.file-preview-container.interactive {
  -webkit-user-select: none;
          user-select: none;
  touch-action: none;
}

.image-zoom-area {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.file-preview-image {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: 4px;
  transition: transform 0.1s ease-out;
  transform-origin: center center;
}

.file-preview-pdf {
  width: 100%;
  height: 100%;
  border: none;
  border-radius: 4px;
  pointer-events: auto;
  touch-action: none;
  -webkit-user-select: none;
          user-select: none;
}

.file-preview-loading,
.file-preview-error,
.file-preview-unsupported {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #6b7280;
  color: var(--text-secondary);
  text-align: center;
  gap: 12px;
}

.loading-spinner {
  width: 40px;
  height: 40px;
  border: 4px solid #f3f3f3;
  border-top: 4px solid #2979ff;
  border-top: 4px solid var(--accent-blue);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

.preview-download-link {
  color: #2979ff;
  color: var(--accent-blue);
  text-decoration: none;
  font-weight: 500;
  padding: 8px 16px;
  border: 1px solid #2979ff;
  border: 1px solid var(--accent-blue);
  border-radius: 6px;
  transition: all 0.2s ease;
}

.preview-download-link:hover {
  background: #2979ff;
  background: var(--accent-blue);
  color: white;
}

/* Right Section - Form View - LEFT ALIGNED */
.review-edit-section {
  width: 50%;
  display: flex;
  flex-direction: column;
  background: #ffffff;
  background: var(--primary-color);
  overflow: hidden;
}

.review-edit-header {
  height: 80px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 24px;
  border-bottom: 1px solid #e5e7eb;
  border-bottom: 1px solid var(--card-border);
  flex-shrink: 0;
}

.review-header-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start; /* LEFT ALIGN */
  text-align: left; /* LEFT ALIGN */
}

.review-header-content h2 {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 700;
  color: #1f2937;
  color: var(--text-color);
  text-align: left; /* LEFT ALIGN */
}

.review-progress {
  font-size: 0.875rem;
  color: #6b7280;
  color: var(--text-secondary);
  margin: 6px 0 0 0;
  font-weight: 500;
  text-align: left; /* LEFT ALIGN */
}

.changes-indicator {
  color: #f59e0b;
  color: var(--warning-color);
  font-weight: 600;
}

.review-header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.review-action-btn {
  background: none;
  border: none;
  color: #6b7280;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 8px;
  border-radius: 8px;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.review-action-btn.delete-btn:hover {
  background: rgba(220, 53, 69, 0.1);
  color: #dc3545;
}

.review-action-btn.close-btn:hover {
  background: rgba(220, 53, 69, 0.1);
  color: #dc3545;
}

/* Form Container - LEFT ALIGNED */
.review-form-container {
  flex: 1 1;
  overflow-y: auto;
  padding: 24px;
  text-align: left; /* LEFT ALIGN */
}

/* FIXED: Remove centering and add left alignment */
.review-form {
  width: 100%; /* Changed from max-width: 600px */
  margin: 0; /* Changed from margin: 0 auto */
  display: flex;
  flex-direction: column;
  gap: 24px;
  text-align: left; /* LEFT ALIGN */
  align-items: flex-start; /* LEFT ALIGN */
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%; /* Ensure full width */
  text-align: left; /* LEFT ALIGN */
  align-items: flex-start; /* LEFT ALIGN */
}

.form-label {
  font-size: 1rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
  margin-bottom: 4px;
  text-align: left; /* LEFT ALIGN */
  align-self: flex-start; /* LEFT ALIGN */
}

.form-input {
  width: 100%;
  padding: 16px 20px;
  border: 2px solid #e5e7eb;
  border: 2px solid var(--card-border);
  border-radius: 12px;
  font-size: 1rem;
  color: #1f2937;
  color: var(--text-color);
  background: #ffffff;
  background: var(--primary-color);
  transition: all 0.2s ease;
  font-family: 'Inter', sans-serif;
  min-height: 24px;
  text-align: left; /* LEFT ALIGN */
  box-sizing: border-box; /* Ensure proper sizing */
}

.form-input:focus {
  outline: none;
  border-color: #2979ff;
  border-color: var(--input-focus);
  box-shadow: 0 0 0 3px rgba(41, 121, 255, 0.1);
  background: #ffffff;
  background: var(--primary-color);
}

.form-input:hover:not(:focus) {
  border-color: #2979ff;
  border-color: var(--accent-blue);
}

.form-input::placeholder {
  color: #6b7280;
  color: var(--text-secondary);
  text-align: left; /* LEFT ALIGN */
}

/* Select dropdown specific styles */
.form-input select {
  cursor: pointer;
  /* Removed custom background image - using browser default arrow */
  padding-right: 16px; /* Minimal padding for the default arrow */
}

.form-input select:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  background-color: #f8fafc;
  background-color: var(--card-bg);
}

/* Help text styling */
.form-help {
  display: block;
  margin-top: 4px;
  font-size: 0.75rem;
  color: #6b7280;
  color: var(--text-secondary);
  font-style: italic;
}

/* Account Code Type-ahead Styles */
.account-code-typeahead {
  position: relative;
  width: 100%;
}

.account-code-suggestions {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: #ffffff;
  background: var(--primary-color);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-top: none;
  border-radius: 0 0 8px 8px;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
  max-height: 200px;
  overflow-y: auto;
  z-index: 1000;
}

.account-code-suggestion {
  padding: 0.75rem 1rem;
  cursor: pointer;
  border-bottom: 1px solid #e5e7eb;
  border-bottom: 1px solid var(--card-border);
  transition: background-color 0.2s ease;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.account-code-suggestion:hover {
  background-color: #f8fafc;
  background-color: var(--card-bg);
}

.account-code-suggestion:last-child {
  border-bottom: none;
}

.account-code-code {
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
  font-size: 0.875rem;
}

.account-code-name {
  color: #6b7280;
  color: var(--text-secondary);
  font-size: 0.75rem;
  font-style: italic;
}

/* Action Buttons Footer */
.review-actions {
  height: 80px;
  padding: 16px 24px;
  border-top: 1px solid #e5e7eb;
  border-top: 1px solid var(--card-border);
  background: #f8fafc;
  background: var(--card-bg);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}

.keyboard-shortcuts {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.7rem;
  color: #6b7280;
  color: var(--text-secondary);
  flex: 1 1;
  text-align: left; /* LEFT ALIGN */
}

.action-button-group {
  display: flex;
  align-items: center;
  gap: 12px;
}

.save-btn {
  border: none;
  padding: 12px 20px;
  border-radius: 8px;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: 'Inter', sans-serif;
  height: 44px;
  min-width: 140px;
}

.save-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.save-btn.secondary {
  background: #ffffff;
  background: var(--primary-color);
  color: #1f2937;
  color: var(--text-color);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
}

.save-btn.secondary:hover:not(:disabled) {
  background: #f8fafc;
  background: var(--card-bg);
  border-color: #2979ff;
  border-color: var(--accent-blue);
  color: #2979ff;
  color: var(--accent-blue);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(41, 121, 255, 0.1);
}

.save-btn.primary {
  background: #2979ff;
  background: var(--accent-blue);
  color: white;
  border: 1px solid #2979ff;
  border: 1px solid var(--accent-blue);
}

.save-btn.primary:hover:not(:disabled) {
  background: #165ec9;
  background: var(--button-hover);
  border-color: #165ec9;
  border-color: var(--button-hover);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(41, 121, 255, 0.2);
}

.save-btn.danger {
  background: #dc3545;
  color: white;
  border: 1px solid #dc3545;
}

.save-btn.danger:hover:not(:disabled) {
  background: #c82333;
  border-color: #c82333;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(220, 53, 69, 0.2);
}

/* Scrollbar Styling */
.review-form-container::-webkit-scrollbar {
  width: 6px;
}

.review-form-container::-webkit-scrollbar-track {
  background: #f8fafc;
  background: var(--card-bg);
}

.review-form-container::-webkit-scrollbar-thumb {
  background: #e5e7eb;
  background: var(--card-border);
  border-radius: 3px;
}

.review-form-container::-webkit-scrollbar-thumb:hover {
  background: #6b7280;
  background: var(--text-secondary);
}

/* Mobile - Stack Layout */
@media (max-width: 768px) {
  .review-panel-content {
    flex-direction: column;
  }
  
  .review-file-section {
    width: 100%;
    height: 40%;
    border-right: none;
    border-bottom: 1px solid #e5e7eb;
    border-bottom: 1px solid var(--card-border);
  }
  
  .review-edit-section {
    width: 100%;
    height: 60%;
  }
  
  .review-form {
    gap: 20px;
    width: 100%; /* Ensure full width on mobile */
    margin: 0; /* No centering on mobile */
  }
  
  .form-input {
    padding: 14px 16px;
    font-size: 0.9rem;
  }
  
  .action-button-group {
    flex-direction: column;
    gap: 8px;
    width: 100%;
  }
  
  .save-btn {
    width: 100%;
    min-width: auto;
  }
}

/* Additional left alignment fixes */
.review-edit-section *,
.review-form *,
.form-field * {
  text-align: left !important;
}

/* Override any centering that might be inherited */
.review-edit-section .centered,
.review-edit-section .text-center,
.review-form .centered,
.review-form .text-center {
  text-align: left !important;
}

/* Ensure flexbox items align left */
.review-edit-section .flex-center {
  justify-content: flex-start !important;
  align-items: flex-start !important;
}

/* Line Items Section Styles */
.line-items-section {
  margin-top: 20px;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-radius: 8px;
  overflow: hidden;
}

.line-items-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  background: #f8fafc;
  background: var(--card-bg);
  border-bottom: 1px solid #e5e7eb;
  border-bottom: 1px solid var(--card-border);
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.line-items-header:hover {
  background: #f1f5f9;
}

.line-items-toggle {
  background: none;
  border: none;
  font-size: 16px;
  color: #6b7280;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 4px;
  border-radius: 4px;
  transition: color 0.2s ease;
}

.line-items-toggle:hover {
  color: #1f2937;
  color: var(--text-color);
}

/* Line Items Table */
.line-items-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 12px;
  min-width: 800px; /* Increased minimum width to prevent text cutoff */
}

.line-items-container {
  overflow-x: auto; /* Enable horizontal scrolling */
  max-width: 100%;
  border-radius: 8px;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  background: #ffffff;
  background: var(--primary-color);
  padding: 16px;
  scrollbar-width: thin;
  scrollbar-color: #e5e7eb transparent;
  scrollbar-color: var(--card-border) transparent;
}

/* Custom scrollbar styling for webkit browsers */
.line-items-container::-webkit-scrollbar {
  height: 8px;
}

.line-items-container::-webkit-scrollbar-track {
  background: transparent;
}

.line-items-container::-webkit-scrollbar-thumb {
  background: #e5e7eb;
  background: var(--card-border);
  border-radius: 4px;
}

.line-items-container::-webkit-scrollbar-thumb:hover {
  background: #6b7280;
  background: var(--text-secondary);
}

.no-line-items {
  text-align: center;
  padding: 20px;
  color: #6b7280;
  color: var(--text-secondary);
  font-style: italic;
}

.line-items-header-row {
  display: grid;
  grid-template-columns: 3fr 1fr 1fr 1.5fr 1fr 80px; /* Adjusted column widths */
  grid-gap: 12px;
  gap: 12px; /* Increased gap for better spacing */
  padding: 8px 0;
  border-bottom: 1px solid #e5e7eb;
  border-bottom: 1px solid var(--card-border);
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
  font-size: 0.9rem;
  align-items: center;
}

.line-item-row {
  display: grid;
  grid-template-columns: 3fr 1fr 1fr 1.5fr 1fr 80px; /* Match header row */
  grid-gap: 12px;
  gap: 12px; /* Match header row gap */
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid rgba(229, 231, 235, 0.5);
}

/* Ensure grid items are properly contained */
.line-item-cell {
  min-width: 0; /* Allow grid items to shrink */
  overflow: hidden; /* Prevent content overflow */
}

.line-item-input {
  width: 100%; /* Ensure input takes full grid cell width */
  box-sizing: border-box;
  padding: 8px 12px;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-radius: 6px;
  font-size: 0.9rem;
  background: white;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  white-space: nowrap; /* Prevent text wrapping */
  overflow: hidden; /* Hide overflow */
  text-overflow: ellipsis; /* Show ellipsis for long text */
}

/* Special handling for Item Name column to show full text */
.line-item-row > div:first-child .line-item-input {
  white-space: normal; /* Allow text to wrap in Item Name column */
  min-height: 40px; /* Ensure enough height for wrapped text */
}

.line-item-input:focus {
  outline: none;
  border-color: #2979ff;
  border-color: var(--input-focus);
  box-shadow: 0 0 0 3px rgba(41, 121, 255, 0.1);
}

.line-item-input:hover:not(:focus) {
  border-color: #6b7280;
  border-color: var(--text-secondary);
}

.line-item-row:last-child {
  border-bottom: none;
}

.line-item-delete-btn {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #dc2626;
  padding: 6px;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.line-item-delete-btn:hover {
  background: #fee2e2;
  border-color: #fca5a5;
  transform: scale(1.05);
}

.add-line-item-btn {
  background: #f0f9ff;
  border: 1px solid #bae6fd;
  color: #2979ff;
  color: var(--accent-blue);
  padding: 10px 16px;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.9rem;
  font-weight: 500;
  margin-top: 12px;
}

.add-line-item-btn:hover {
  background: #e0f2fe;
  border-color: #7dd3fc;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(41, 121, 255, 0.1);
}

/* Mobile responsive for line items */
@media (max-width: 768px) {
  .line-items-header-row,
  .line-item-row {
    grid-template-columns: 1fr 80px 80px 80px 80px 50px;
    gap: 6px;
  }
  
  .line-item-input {
    padding: 6px 8px;
    font-size: 0.8rem;
  }
  
  .add-line-item-btn {
    padding: 8px 12px;
    font-size: 0.8rem;
  }
}
/* DuplicateDetectionModal.css */

.duplicate-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    padding: 1rem;
    /* Prevent background scrolling and movement */
    overflow: hidden;
  }
  
  /* Prevent body scroll when modal is open */
  body.modal-open {
    overflow: hidden;
    position: fixed;
    width: 100%;
    height: 100%;
  }
  
  .duplicate-modal {
    background: white;
    border-radius: 16px;
    width: 100%;
    max-width: 900px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
    font-family: 'Inter', sans-serif;
  }
  
  .duplicate-modal-header {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 1.5rem 2rem;
    border-bottom: 1px solid #e5e7eb;
  }
  
  .duplicate-modal-header h3 {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 600;
    color: #000000;
  }
  
  .close-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.5rem;
    border-radius: 8px;
    color: #6b7280;
    transition: all 0.2s ease;
  }
  
  .close-btn:hover {
    background: #f3f4f6;
    color: #374151;
  }
  
  .duplicate-modal-content {
    flex: 1 1;
    overflow-y: auto;
    padding: 1.5rem 2rem;
  }
  
  .duplicate-warning {
    margin: 0 0 1.5rem 0;
    padding: 1rem;
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 8px;
    color: #dc2626;
    font-weight: 500;
  }
  
  .duplicates-list {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
  }
  
  .duplicate-item {
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    overflow: hidden;
    background: #fafbfc;
  }
  
  .duplicate-details {
    padding: 1.5rem;
  }
  
  .duplicate-details h4 {
    margin: 0 0 1rem 0;
    font-size: 1.125rem;
    font-weight: 600;
    color: #374151;
  }
  
  .invoice-comparison {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    grid-gap: 1.5rem;
    gap: 1.5rem;
    align-items: center;
  }
  
  .invoice-info {
    background: white;
    padding: 1rem;
    border-radius: 8px;
    border: 1px solid #e5e7eb;
  }
  
  .invoice-info.existing {
    background: #f8fafc;
  }
  
  .info-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.5rem;
  }
  
  .info-row:last-child {
    margin-bottom: 0;
  }
  
  .label {
    font-weight: 600;
    color: #6b7280;
    font-size: 0.875rem;
  }
  
  .value {
    font-weight: 500;
    color: #374151;
    font-size: 0.875rem;
    word-break: break-word;
    text-align: right;
    max-width: 200px;
  }
  
  .issuer-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    cursor: help;
  }
  
  .created-date {
    font-size: 0.8rem;
    color: #6b7280;
    font-style: italic;
  }
  
  .vs-indicator {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    color: #dc2626;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
  }
  
  .duplicate-actions {
    display: flex;
    gap: 0.75rem;
    padding: 1rem 1.5rem;
    background: white;
    border-top: 1px solid #e5e7eb;
  }
  
  .action-btn {
    flex: 1 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    border: 2px solid transparent;
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 0.875rem;
    font-family: 'Inter', sans-serif;
  }
  
  .action-btn.keep {
    background: #f0f9ff;
    color: #0369a1;
    border-color: #e0f2fe;
  }
  
  .action-btn.keep:hover,
  .action-btn.keep.active {
    background: #0369a1;
    color: white;
    border-color: #0369a1;
  }
  
  .action-btn.delete {
    background: #fef2f2;
    color: #dc2626;
    border-color: #fecaca;
  }
  
  .action-btn.delete:hover,
  .action-btn.delete.active {
    background: #dc2626;
    color: white;
    border-color: #dc2626;
  }
  
  .duplicate-modal-footer {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 1.5rem 2rem;
    border-top: 1px solid #e5e7eb;
    background: #f9fafb;
  }
  
  .bulk-actions {
    display: flex;
    gap: 0.75rem;
    justify-content: center;
  }
  
  .bulk-btn {
    padding: 0.75rem 1rem;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    background: white;
    color: #374151;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 0.875rem;
    font-family: 'Inter', sans-serif;
  }
  
  .bulk-btn:hover {
    background: #f3f4f6;
    border-color: #9ca3af;
  }
  
  .bulk-btn.keep-all:hover {
    background: #dbeafe;
    border-color: #3b82f6;
    color: #1d4ed8;
  }
  
  .bulk-btn.delete-all:hover {
    background: #fee2e2;
    border-color: #ef4444;
    color: #dc2626;
  }
  
  .apply-btn {
    background: #2563eb;
    color: white;
    border: none;
    padding: 0.75rem 1.5rem;
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 0.875rem;
    font-family: 'Inter', sans-serif;
  }
  
  .apply-btn:hover:not(:disabled) {
    background: #1d4ed8;
  }
  
  .apply-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
  }
  
  /* Processing Overlay */
  .processing-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.9);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 10;
    border-radius: 16px;
  }
  
  .processing-spinner {
    width: 40px;
    height: 40px;
    border: 4px solid #e5e7eb;
    border-top: 4px solid #2563eb;
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin-bottom: 1rem;
  }
  
  .processing-overlay p {
    margin: 0;
    color: #374151;
    font-weight: 600;
    font-size: 1rem;
  }
  
  @keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
  }
  
  /* Disabled state styles */
  .action-btn:disabled,
  .bulk-btn:disabled,
  .close-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
  }
  
  .duplicate-modal {
    position: relative; /* For processing overlay positioning */
  }
  
  @media (max-width: 768px) {
    .duplicate-modal {
      margin: 1rem;
      max-width: none;
    }
  
    .duplicate-modal-header,
    .duplicate-modal-content,
    .duplicate-modal-footer {
      padding: 1rem;
    }
  
    .invoice-comparison {
      grid-template-columns: 1fr;
      gap: 1rem;
    }
  
    .vs-indicator {
      order: -1;
    }
  
    .duplicate-modal-footer {
      flex-direction: column;
      gap: 1rem;
      align-items: stretch;
    }
  
    .bulk-actions {
      justify-content: center;
    }
  }

/* View Image Button Styles */
.view-image-btn {
  background: #f3f4f6;
  border: 1px solid #d1d5db;
  border-radius: 6px;
  padding: 0.5rem 0.75rem;
  margin-top: 0.75rem;
  font-size: 0.75rem;
  color: #6b7280;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  transition: all 0.2s ease;
  font-family: 'Inter', sans-serif;
  width: -webkit-fit-content;
  width: fit-content;
}

.view-image-btn:hover {
  background: #e5e7eb;
  color: #374151;
  border-color: #9ca3af;
}

.view-image-btn svg {
  width: 14px;
  height: 14px;
}

/* Image Preview Overlay Styles */
.image-preview-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2000;
  padding: 2rem;
}

.image-preview-modal {
  background: white;
  border-radius: 12px;
  width: 100%;
  max-width: 95vw;
  max-height: 95vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 25px 50px rgba(0, 0, 0, 0.3);
  overflow: hidden;
}

.image-preview-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid #e5e7eb;
  background: #f9fafb;
  border-radius: 12px 12px 0 0;
}

.image-preview-header h4 {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  color: #374151;
  font-family: 'Inter', sans-serif;
}

.close-image-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 6px;
  color: #6b7280;
  transition: all 0.2s ease;
}

.close-image-btn:hover {
  background: #e5e7eb;
  color: #374151;
}

.image-preview-content {
  flex: 1 1;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 1.5rem;
  overflow: auto;
}

.preview-image {
  max-width: 100%;
  height: auto;
  width: auto;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  display: block;
}

.image-loading, .image-error {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 200px;
  color: #6b7280;
  font-family: 'Inter', sans-serif;
}

.loading-spinner {
  width: 32px;
  height: 32px;
  border: 3px solid #e5e7eb;
  border-top: 3px solid #3b82f6;
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-bottom: 1rem;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

.error-icon {
  font-size: 2rem;
  margin-bottom: 1rem;
}

/* Responsive adjustments for image preview */
@media (max-width: 768px) {
  .image-preview-overlay {
    padding: 1rem;
  }
  
  .image-preview-modal {
    max-width: 95vw;
    max-height: 95vh;
  }
  
  .image-preview-content {
    padding: 1rem;
  }
}
/* Replace your existing TrackerPage.css with this complete version */

:root {
  --primary-color: #ffffff;
  --accent-blue: #2979ff;
  --text-color: #1f2937;
  --text-secondary: #6b7280;
  --card-bg: #f8fafc;
  --card-border: #e5e7eb;
  --button-bg: #2979ff;
  --button-hover: #165ec9;
  --input-focus: #2979ff;
  --success-color: #10b981;
  --warning-color: #f59e0b;
}

body {
  font-family: 'Inter', sans-serif;
}

/* Main Wrapper */
.tracker-page-wrapper {
  max-width: 1400px;
  margin: 0 auto;
  padding: 2rem;
  font-family: 'Inter', sans-serif;
  background-color: #f8fafc;
  background-color: var(--card-bg);
  min-height: 100vh;
}

/* Header Section */
.tracker-header {
  background: #f8fafc;
  background: var(--card-bg);
  padding: 2rem 0 3rem;
  text-align: center;
  margin-bottom: 2rem;
}

.tracker-header h1 {
  font-size: 2.5rem;
  font-weight: 700;
  color: #1f2937;
  color: var(--text-color);
  margin: 0 0 1rem 0;
  letter-spacing: -0.02em;
}

.tracker-header p {
  font-size: 1.125rem;
  color: #6b7280;
  color: var(--text-secondary);
  margin: 0;
  font-weight: 500;
}

/* Progress Card - Updated for left alignment */
.tracker-progress-card {
  background: #ffffff;
  background: var(--primary-color);
  border-radius: 16px;
  padding: 2rem;
  margin-bottom: 2rem;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.04);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  position: relative;
  overflow: hidden;
}

.tracker-progress-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #2979ff, #64b5f6);
  background: linear-gradient(90deg, var(--accent-blue), #64b5f6);
}

.progress-content {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 2rem;
}

.progress-info {
  flex: 1 1; /* Take up available space */
  display: flex;
  flex-direction: column;
  align-items: flex-start; /* Left align everything */
  text-align: left !important; /* Force left alignment */
}

.progress-info h3 {
  font-size: 1.25rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
  margin: 0 0 0.5rem 0;
  text-align: left !important;
  align-self: flex-start;
  width: auto;
}

.progress-info p {
  font-size: 1rem;
  color: #6b7280;
  color: var(--text-secondary);
  margin: 0 0 1.5rem 0;
  text-align: left !important;
  align-self: flex-start;
  width: auto;
}

.progress-bar-large {
  width: 100%; /* Use full available width */
  max-width: 400px; /* But don't exceed 400px */
  height: 12px;
  background: #e5e7eb;
  background: var(--card-border);
  border-radius: 6px;
  overflow: hidden;
  align-self: flex-start; /* Align to left */
}

.progress-fill-large {
  height: 100%;
  background: linear-gradient(90deg, #2979ff, #64b5f6);
  background: linear-gradient(90deg, var(--accent-blue), #64b5f6);
  border-radius: 6px;
  transition: width 0.3s ease;
}

.start-review-btn-large {
  background: #2979ff;
  background: var(--button-bg);
  color: white;
  border: none;
  padding: 1rem 2rem;
  border-radius: 12px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  transition: all 0.2s ease;
  box-shadow: 0 4px 12px rgba(41, 121, 255, 0.2);
  font-family: 'Inter', sans-serif;
  flex-shrink: 0; /* Don't shrink the button */
}

.start-review-btn-large:hover {
  background: #165ec9;
  background: var(--button-hover);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(41, 121, 255, 0.3);
}

/* Filters Card */
.tracker-filters-card {
  background: #ffffff;
  background: var(--primary-color);
  border-radius: 16px;
  padding: 2rem;
  margin-bottom: 2rem;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.04);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 2rem;
  position: relative;
  overflow: hidden;
}

.tracker-filters-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #2979ff, #64b5f6);
  background: linear-gradient(90deg, var(--accent-blue), #64b5f6);
}

.filter-inputs-spacious {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.filter-group {
  display: flex;
  flex-direction: column;
}

.filter-group label {
  display: block;
  font-size: 0.875rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
  margin-bottom: 0.5rem;
}

.filter-group input {
  padding: 0.75rem 1rem;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-radius: 8px;
  font-size: 0.875rem;
  min-width: 160px;
  transition: all 0.2s ease;
  background: #ffffff;
  background: var(--primary-color);
  color: #1f2937;
  color: var(--text-color);
  font-family: 'Inter', sans-serif;
}

.filter-group input:focus {
  outline: none;
  border-color: #2979ff;
  border-color: var(--input-focus);
  box-shadow: 0 0 0 3px rgba(41, 121, 255, 0.1);
}

/* Export buttons container */
.export-buttons-container {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}

/* Adjust export button to align with start review button's center */
.export-button-spacious {
  background: #2979ff;
  background: var(--button-bg);
  color: white;
  border: none;
  padding: 1rem 2rem;
  border-radius: 12px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  transition: all 0.2s ease;
  box-shadow: 0 4px 12px rgba(41, 121, 255, 0.2);
  font-family: 'Inter', sans-serif;
  flex-shrink: 0;
  /* Align with the center of the Start Review Mode button */
  align-self: center;
  margin-bottom: 0; /* Remove margin since container handles it */
}

.export-test-button {
  background: #10b981;
  background: var(--success-color);
}

.export-test-button:hover:not(:disabled) {
  background: #059669;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(16, 185, 129, 0.3);
}

.export-button-spacious:hover:not(:disabled) {
  background: #165ec9;
  background: var(--button-hover);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(41, 121, 255, 0.3);
}

.export-button-spacious:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

/* Results Info */
.results-info-spacious {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
  background: #f8fafc;
  background: var(--card-bg);
  padding: 1rem 1.5rem;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
}

.results-summary span {
  font-size: 0.875rem;
  color: #6b7280;
  color: var(--text-secondary);
  font-weight: 500;
}

.active-filters {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  flex-wrap: wrap;
}

.filter-icon {
  color: #6b7280;
  color: var(--text-secondary);
  margin-right: 0.25rem;
}

.filter-tag {
  background: #ffffff;
  background: var(--primary-color);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  padding: 0.375rem 0.75rem;
  border-radius: 20px;
  font-size: 0.75rem;
  color: #6b7280;
  color: var(--text-secondary);
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  white-space: nowrap;
}

/* Legacy styles for backward compatibility */
.results-info-spacious span {
  font-size: 0.875rem;
  color: #6b7280;
  color: var(--text-secondary);
  font-weight: 500;
}

.status-filter {
  display: flex;
  gap: 1rem;
  align-items: center;
}

.status-filter span {
  font-size: 0.75rem;
  color: #6b7280;
  color: var(--text-secondary);
}

.status-select {
  padding: 0.5rem 2rem 0.5rem 0.75rem; /* Add more right padding for arrow space */
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-radius: 6px;
  font-size: 0.75rem;
  background: #ffffff;
  background: var(--primary-color);
  cursor: pointer;
  color: #1f2937;
  color: var(--text-color);
  font-family: 'Inter', sans-serif;
  background-image: url("data:image/svg+xml,%3csvg xmlns=%27http://www.w3.org/2000/svg%27 fill=%27none%27 viewBox=%270 0 20 20%27%3e%3cpath stroke=%27%236b7280%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27 stroke-width=%271.5%27 d=%27m6 8 4 4 4-4%27/%3e%3c/svg%3e");
  background-position: right 0.5rem center; /* Position arrow closer to left */
  background-repeat: no-repeat;
  background-size: 1rem;
  -webkit-appearance: none;
          appearance: none; /* Remove default arrow */
}

/* Spacious Table - Scrollable with fixed height for 8 rows */
.table-wrapper-spacious {
  background: #ffffff;
  background: var(--primary-color);
  border-radius: 16px;
  overflow: hidden; /* Keep hidden for tooltips */
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.04);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  margin-bottom: 2rem;
  position: relative;
  /* Enable horizontal scrolling for table */
  overflow-x: auto;
  overflow-y: hidden;
}

/* Add scrollable tbody container */
.table-wrapper-spacious .table-body-scroll {
  max-height: 480px; /* Height for 8 rows (8 * 60px per row) */
  overflow-y: auto;
  overflow-x: visible; /* Allow horizontal overflow to be handled by parent */
}

/* Custom scrollbar styling */
.table-wrapper-spacious .table-body-scroll::-webkit-scrollbar {
  width: 8px;
}

.table-wrapper-spacious .table-body-scroll::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 4px;
}

.table-wrapper-spacious .table-body-scroll::-webkit-scrollbar-thumb {
  background: #c1c1c1;
  border-radius: 4px;
}

.table-wrapper-spacious .table-body-scroll::-webkit-scrollbar-thumb:hover {
  background: #a8a8a8;
}

/* Horizontal scrollbar styling for table wrapper */
.table-wrapper-spacious::-webkit-scrollbar {
  height: 8px;
}

.table-wrapper-spacious::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 4px;
}

.table-wrapper-spacious::-webkit-scrollbar-thumb {
  background: #c1c1c1;
  border-radius: 4px;
}

.table-wrapper-spacious::-webkit-scrollbar-thumb:hover {
  background: #a8a8a8;
}

.tracker-table-spacious {
  width: 100%;
  min-width: 800px; /* Ensure table doesn't get too compressed */
  border-collapse: collapse;
}

.tracker-table-spacious thead tr {
  background: linear-gradient(135deg, #2979ff, #165ec9);
  background: linear-gradient(135deg, var(--accent-blue), #165ec9);
}

.tracker-table-spacious th {
  padding: 1.5rem 2rem;
  text-align: left;
  color: white;
  font-weight: 600;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: none;
}

.tracker-table-spacious .status-column {
  width: 100px;
  text-align: center;
}

.tracker-table-spacious .action-column {
  width: 100px;
  text-align: center;
}

.tracker-table-spacious tbody tr {
  transition: background-color 0.2s ease;
  border-bottom: 1px solid #f3f4f6;
}

.tracker-table-spacious tbody tr:nth-child(even) {
  background-color: #fafbfc;
}

.tracker-table-spacious tbody tr:hover {
  background-color: rgba(41, 121, 255, 0.02);
}

.tracker-table-spacious tbody tr:nth-child(even):hover {
  background-color: rgba(41, 121, 255, 0.02);
}

.tracker-table-spacious tbody tr:last-child {
  border-bottom: none;
}

/* Table Cells */
.status-cell {
  padding: 1.5rem 2rem;
  text-align: center;
}

.data-cell {
  padding: 1.5rem 2rem;
  color: #1f2937;
  color: var(--text-color);
  font-weight: 500;
  font-size: 0.875rem;
}

.action-cell {
  padding: 1.5rem 2rem;
  text-align: center;
}

/* Enhanced Status Indicator */
.status-indicator {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8rem;
  font-weight: 500;
  transition: all 0.2s ease;
}

.status-indicator svg {
  flex-shrink: 0;
  transition: transform 0.2s ease;
}

.status-indicator:hover svg {
  transform: scale(1.1);
}

.status-text {
  white-space: nowrap;
}

/* Platform-specific hover effects */
.enhanced-status[title*="Web"]:hover {
  color: #2979ff !important; /* Web blue */
}

.enhanced-status[title*="Email"]:hover {
  color: #1a73e8 !important; /* Email blue */
}

.enhanced-status[title*="Whatsapp"]:hover {
  color: #25d366 !important; /* WhatsApp green */
}

/* Status color variants */
.status-processed {
  color: #10b981; /* Green */
}

.status-queueing {
  color: #f59e0b; /* Orange */
}

.status-failed {
  color: #ef4444; /* Red - for future use */
}

/* Action Buttons */
.action-buttons {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  justify-content: center;
}

.action-btn {
  background: none;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  color: #6b7280;
  color: var(--text-secondary);
  padding: 0.5rem;
  border-radius: 6px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  min-width: 32px;
  height: 32px;
}

.tick-btn:hover {
  border-color: #10b981;
  border-color: var(--success-color);
  color: #10b981;
  color: var(--success-color);
  background: rgba(16, 185, 129, 0.05);
}

.edit-btn:hover {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  color: #2979ff;
  color: var(--accent-blue);
  background: rgba(41, 121, 255, 0.05);
}

.delete-btn {
  background-color: #fef2f2;
  color: #ef4444;
  border: 1px solid #fecaca;
}

.delete-btn:hover {
  background-color: #ef4444;
  color: white;
}

/* SIMPLIFIED: Only change the tick button when reviewed/edited */
.action-btn.reviewed-tick {
  background: #10b981 !important;
  background: var(--success-color) !important;
  border-color: #10b981 !important;
  border-color: var(--success-color) !important;
  color: white !important;
}

.action-btn.reviewed-tick:hover {
  background: #059669 !important;
  border-color: #059669 !important;
  color: white !important;
}

/* Remove all the previous green text styling for rows */
/* .reviewed-row, .edited-row classes removed */

/* Column Info Icons - Updated with proper info icon */
.column-header-with-info {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  justify-content: center;
}

.column-info-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.8); /* Slightly more transparent for better visibility */
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
}

.column-info-icon:hover {
  background: rgba(255, 255, 255, 0.25);
  color: rgba(255, 255, 255, 1);
  transform: scale(1.1);
}

.column-info-icon:active {
  transform: scale(0.95);
}

/* Info Popup Modal - Professional design */
.info-popup-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  animation: fadeIn 0.2s ease-out;
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
}

.info-popup {
  background: white;
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
  min-width: 400px;
  max-width: 90vw;
  animation: slideIn 0.3s ease-out;
  overflow: hidden;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
}

.info-popup-header {
  display: flex;
  justify-content: space-between;
  align-items: center; /* Center vertically */
  padding: 0.75rem 1.5rem; /* Reduced from 1rem to 0.75rem top/bottom */
  border-bottom: 1px solid #e5e7eb;
  border-bottom: 1px solid var(--card-border);
  background: #f8fafc;
  background: var(--card-bg);
}

.info-popup-title-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.info-popup-icon {
  color: #2979ff;
  color: var(--accent-blue);
  flex-shrink: 0;
}

.info-popup-title {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
  font-family: 'Inter', sans-serif;
}

.info-popup-close {
  background: none;
  border: none;
  color: #6b7280;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
}

.info-popup-close:hover {
  background: rgba(0, 0, 0, 0.1);
  color: #1f2937;
  color: var(--text-color);
}

.info-popup-content {
  padding: 1.5rem;
  background: white;
}

.info-popup-content p,
.info-popup-content div {
  margin: 0;
  color: #1f2937;
  color: var(--text-color);
  font-size: 1rem;
  line-height: 1.6;
  text-align: left; /* Left align for better readability */
  font-family: 'Inter', sans-serif;
}

@keyframes fadeIn {
  from { 
    opacity: 0; 
    -webkit-backdrop-filter: blur(0); 
            backdrop-filter: blur(0);
  }
  to { 
    opacity: 1;
    -webkit-backdrop-filter: blur(2px);
            backdrop-filter: blur(2px);
  }
}

@keyframes slideIn {
  from { 
    opacity: 0;
    transform: translateY(-20px) scale(0.95);
  }
  to { 
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Mobile responsive for info popup */
@media (max-width: 768px) {
  .info-popup {
    min-width: auto;
    width: 90vw;
    margin: 1rem;
  }
  
  .info-popup-header {
    padding: 1rem 1rem 0;
  }
  
  .info-popup-content {
    padding: 1rem;
  }
  
  .info-popup-title {
    font-size: 1rem;
  }
  
  .info-popup-content p {
    font-size: 0.9rem;
  }
}

.clickable-filename {
  color: #2979ff;
  color: var(--accent-blue);
  cursor: pointer;
  text-decoration: none; /* REMOVED underline */
  transition: color 0.2s ease;
  font-weight: 500;
}

.clickable-filename:hover {
  color: #165ec9;
  color: var(--button-hover);
  /* REMOVED text-decoration on hover */
}

/* Pagination */
.pagination-container-spacious {
  display: flex;
  justify-content: center;
  margin-top: 2rem;
}

.pagination {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

.pagination-btn {
  padding: 0.75rem 1rem;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  background: #ffffff;
  background: var(--primary-color);
  color: #1f2937;
  color: var(--text-color);
  border-radius: 8px;
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 500;
  transition: all 0.2s ease;
  min-width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Inter', sans-serif;
}

.pagination-btn:hover:not(.active) {
  background: rgba(41, 121, 255, 0.1);
  border-color: #2979ff;
  border-color: var(--accent-blue);
}

.pagination-btn.active {
  background: #2979ff;
  background: var(--accent-blue);
  color: white;
  border-color: #2979ff;
  border-color: var(--accent-blue);
}

.pagination-ellipsis {
  padding: 0.5rem 0.25rem;
  color: #6b7280;
  color: var(--text-secondary);
  font-size: 0.875rem;
  display: flex;
  align-items: center;
  height: 40px;
}

/* Empty State */
.empty-state {
  text-align: center !important;
  padding: 3rem 2rem;
  color: #6b7280;
  color: var(--text-secondary);
  vertical-align: middle;
}

.empty-state div {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
}

.empty-state svg {
  width: 64px;
  height: 64px;
  margin-bottom: 1rem;
  opacity: 0.5;
}

.empty-state h3 {
  font-size: 1.25rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
  margin-bottom: 0.5rem;
}

.empty-state p {
  font-size: 0.875rem;
  line-height: 1.5;
}

/* Empty state cell - spans all columns and centers content */
.empty-state-cell {
  text-align: center !important;
  vertical-align: middle !important;
  padding: 0 !important;
  border: none !important;
}

/* Empty state content - centered within the table cell */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 3rem 2rem;
  min-height: 200px;
  background: white;
  width: 100%;
}

/* Ensure empty state text is centered */
.empty-state h3,
.empty-state p {
  text-align: center !important;
  margin: 0 auto !important;
}

/* Ensure table takes full width */
.tracker-table-spacious {
  width: 100% !important;
}

/* Date Filter Buttons - Separate Box Style */
.date-filter-buttons {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  align-items: center;
}

.date-filter-btn {
  background: #ffffff;
  background: var(--primary-color);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  padding: 0.625rem 1rem;
  border-radius: 8px;
  font-size: 0.875rem;
  font-weight: 500;
  color: #1f2937;
  color: var(--text-color);
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: 'Inter', sans-serif;
  white-space: nowrap;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.date-filter-btn:hover {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  color: #2979ff;
  color: var(--accent-blue);
  box-shadow: 0 2px 8px rgba(41, 121, 255, 0.1);
  transform: translateY(-1px);
}

.date-filter-btn.active {
  background: #2979ff;
  background: var(--accent-blue);
  border-color: #2979ff;
  border-color: var(--accent-blue);
  color: white;
  box-shadow: 0 4px 12px rgba(41, 121, 255, 0.2);
}

.date-filter-btn.active:hover {
  background: #165ec9;
  background: var(--button-hover);
  border-color: #165ec9;
  border-color: var(--button-hover);
  color: white;
  transform: translateY(-1px);
}

/* New Filter Layout Styles */
.filter-row {
  display: flex;
  gap: 1.5rem;
  align-items: flex-end;
  flex-wrap: wrap;
  margin-bottom: 1rem;
  justify-content: space-between;
}

.filter-field {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-width: 140px;
}

.filter-field label {
  font-size: 0.75rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.filter-select {
  padding: 0.75rem;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  background: #ffffff;
  background: var(--primary-color);
  color: #1f2937;
  color: var(--text-color);
  border-radius: 8px;
  font-size: 0.875rem;
  cursor: pointer;
  transition: border-color 0.2s ease;
  min-width: 140px;
  font-family: 'Inter', sans-serif;
}

.filter-select:focus {
  outline: none;
  border-color: #2979ff;
  border-color: var(--input-focus);
  box-shadow: 0 0 0 3px rgba(41, 121, 255, 0.1);
}

.search-field {
  flex: 1 1;
  min-width: 250px;
  max-width: 400px;
}

.search-input {
  padding: 0.75rem;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  background: #ffffff;
  background: var(--primary-color);
  color: #1f2937;
  color: var(--text-color);
  border-radius: 8px;
  font-size: 0.875rem;
  transition: border-color 0.2s ease;
  font-family: 'Inter', sans-serif;
}

.search-input:focus {
  outline: none;
  border-color: #2979ff;
  border-color: var(--input-focus);
  box-shadow: 0 0 0 3px rgba(41, 121, 255, 0.1);
}

.search-input::placeholder {
  color: #6b7280;
  color: var(--text-secondary);
}

.right-side-controls {
  display: flex;
  gap: 1.5rem;
  align-items: flex-end;
  flex-shrink: 0;
}

.export-button-wrapper {
  display: flex;
  gap: 0.5rem;
  align-items: flex-end;
}

.export-button-primary {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: #2979ff;
  background: var(--button-bg);
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: background-color 0.2s ease;
  white-space: nowrap;
  font-family: 'Inter', sans-serif;
}

.export-button-primary:hover:not(:disabled) {
  background: #165ec9;
  background: var(--button-hover);
}

.export-button-primary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.export-button-secondary {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem;
  background: #f8fafc;
  background: var(--card-bg);
  color: #6b7280;
  color: var(--text-secondary);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.export-button-secondary:hover:not(:disabled) {
  background: #ffffff;
  background: var(--primary-color);
  border-color: #2979ff;
  border-color: var(--accent-blue);
  color: #2979ff;
  color: var(--accent-blue);
}

.export-button-secondary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.review-all-button {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: #10b981;
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
  font-family: 'Inter', sans-serif;
  box-shadow: 0 2px 4px rgba(16, 185, 129, 0.2);
}

.review-all-button:hover:not(:disabled) {
  background: #059669;
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(16, 185, 129, 0.3);
}

.review-all-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background: #9ca3af;
  box-shadow: none;
}

.review-all-button:disabled:hover {
  transform: none;
  box-shadow: none;
}

/* Custom Date Range Modal */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  -webkit-backdrop-filter: blur(4px);
          backdrop-filter: blur(4px);
}

.modal-content {
  background: #ffffff;
  background: var(--primary-color);
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
  min-width: 400px;
  max-width: 90vw;
  max-height: 90vh;
  overflow: hidden;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
}

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 2rem 0.5rem;
  border-bottom: 1px solid #e5e7eb;
  border-bottom: 1px solid var(--card-border);
}

.modal-header h3 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
}

.modal-close-btn {
  background: none;
  border: none;
  color: #6b7280;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 6px;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-close-btn:hover {
  background: rgba(0, 0, 0, 0.1);
  color: #1f2937;
  color: var(--text-color);
}

.modal-body {
  padding: 1.5rem 2rem;
}

.modal-date-inputs {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.modal-date-group {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.modal-date-group h4 {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
}

.modal-input-row {
  display: flex;
  gap: 1rem;
}

.modal-input-group {
  flex: 1 1;
  display: flex;
  flex-direction: column;
}

.modal-input-group label {
  font-size: 0.875rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
  margin-bottom: 0.5rem;
}

.modal-input-group input {
  padding: 0.75rem 1rem;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-radius: 8px;
  font-size: 0.875rem;
  background: #ffffff;
  background: var(--primary-color);
  color: #1f2937;
  color: var(--text-color);
  font-family: 'Inter', sans-serif;
  transition: all 0.2s ease;
}

.modal-input-group input:focus {
  outline: none;
  border-color: #2979ff;
  border-color: var(--input-focus);
  box-shadow: 0 0 0 3px rgba(41, 121, 255, 0.1);
}

.modal-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 2rem 1.5rem;
  border-top: 1px solid #e5e7eb;
  border-top: 1px solid var(--card-border);
}

.modal-actions {
  display: flex;
  gap: 0.75rem;
}

.modal-actions-centered {
  display: flex;
  justify-content: center;
  width: 100%;
}

.modal-btn {
  padding: 0.75rem 1.5rem;
  border-radius: 8px;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: 'Inter', sans-serif;
  border: none;
}

.modal-btn-primary {
  background: #2979ff;
  background: var(--button-bg);
  color: white;
  box-shadow: 0 4px 12px rgba(41, 121, 255, 0.2);
}

.modal-btn-primary:hover {
  background: #165ec9;
  background: var(--button-hover);
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(41, 121, 255, 0.3);
}

.modal-btn-cancel {
  background: #f8fafc;
  background: var(--card-bg);
  color: #6b7280;
  color: var(--text-secondary);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
}

.modal-btn-cancel:hover {
  background: rgba(0, 0, 0, 0.05);
  color: #1f2937;
  color: var(--text-color);
  border-color: #6b7280;
  border-color: var(--text-secondary);
}

.modal-btn-secondary {
  background: transparent;
  color: #dc2626;
  border: 1px solid #dc2626;
}

.modal-btn-secondary:hover {
  background: #dc2626;
  color: white;
}

/* Delete Modal Styles */
.delete-modal {
  max-width: 500px;
}

.delete-warning {
  text-align: center;
  padding: 1rem 0;
}

/* .delete-icon removed - no longer needed */

.delete-warning h4 {
  color: #1f2937;
  color: var(--text-color);
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0 0 1rem 0;
}

.delete-warning p {
  color: #6b7280;
  color: var(--text-secondary);
  font-size: 0.875rem;
  line-height: 1.5;
  margin: 0;
}

.modal-btn-danger {
  background: #ef4444;
  color: white;
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.2);
}

.modal-btn-danger:hover {
  background: #dc2626;
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(239, 68, 68, 0.3);
}

.modal-btn-danger:disabled {
  background: #fca5a5;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

/* Export Modal Styles */
.export-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 1rem;
  overflow: hidden;
}

.export-modal {
  background: white;
  border-radius: 16px;
  width: 100%;
  max-width: 600px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
  font-family: 'Inter', sans-serif;
  animation: slideIn 0.3s ease-out;
}

@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.export-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem 2rem;
  border-bottom: 1px solid #e5e7eb;
  border-bottom: 1px solid var(--card-border);
}

.export-modal-header h3 {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
}

.export-close-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 8px;
  color: #6b7280;
  color: var(--text-secondary);
  transition: all 0.2s ease;
}

.export-close-btn:hover {
  background: #f8fafc;
  background: var(--card-bg);
  color: #1f2937;
  color: var(--text-color);
}

.export-modal-content {
  padding: 2rem;
}

/* Export Form Styles */
.export-form {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.form-group label {
  font-size: 0.875rem;
  font-weight: 500;
  color: #1f2937;
  color: var(--text-color);
  margin-bottom: 0.25rem;
}

.form-group:has(.filetype-options) label {
  text-align: left;
}

.form-group select {
  padding: 0.75rem 1rem;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-radius: 8px;
  background: #ffffff;
  background: var(--primary-color);
  color: #1f2937;
  color: var(--text-color);
  font-size: 0.875rem;
  font-family: 'Inter', sans-serif;
  transition: all 0.2s ease;
  -webkit-appearance: none;
          appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27 fill=%27none%27 stroke=%27currentColor%27 stroke-width=%272%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27%3e%3cpolyline points=%276,9 12,15 18,9%27%3e%3c/polyline%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 1rem;
  padding-right: 2.5rem;
}

.form-group select:focus {
  outline: none;
  border-color: #2979ff;
  border-color: var(--input-focus);
  box-shadow: 0 0 0 3px rgba(41, 121, 255, 0.1);
}

/* Toggle Switch Styles */
.form-group.toggle {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
}

.switch {
  position: relative;
  display: inline-block;
  width: 50px;
  height: 24px;
}

.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  transition: 0.3s;
  border-radius: 24px;
}

.slider:before {
  position: absolute;
  content: "";
  height: 18px;
  width: 18px;
  left: 3px;
  bottom: 3px;
  background-color: white;
  transition: 0.3s;
  border-radius: 50%;
}

input:checked + .slider {
  background-color: #2979ff;
  background-color: var(--button-bg);
}

input:checked + .slider:before {
  transform: translateX(26px);
}

/* File Type Radio Options */
.filetype-options {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  justify-content: flex-start;
}

.radio-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1rem;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-radius: 8px;
  background: #ffffff;
  background: var(--primary-color);
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 0.875rem;
  font-weight: 500;
  color: #1f2937;
  color: var(--text-color);
  min-width: 120px;
  text-align: center;
  position: relative;
}

.radio-btn input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.radio-btn span {
  display: block;
  text-align: center;
  width: 100%;
}

.radio-btn:hover {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  background: rgba(41, 121, 255, 0.02);
}

.radio-btn.active {
  border-color: #2979ff;
  border-color: var(--button-bg);
  background: #2979ff;
  background: var(--button-bg);
  color: white;
}

.radio-btn input[type="radio"] {
  display: none;
}

/* Export Actions */
.export-actions {
  display: flex;
  justify-content: center;
  gap: 1rem;
  padding-top: 1rem;
  border-top: 1px solid #e5e7eb;
  border-top: 1px solid var(--card-border);
}

.export-description {
  margin: 0 0 2rem 0;
  color: #6b7280;
  color: var(--text-secondary);
  font-size: 1rem;
  line-height: 1.6;
}

.export-options {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.export-option-btn {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.5rem;
  border: 2px solid #e5e7eb;
  border: 2px solid var(--card-border);
  border-radius: 12px;
  background: #ffffff;
  background: var(--primary-color);
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: 'Inter', sans-serif;
  text-align: left;
}

.export-option-btn:hover:not(:disabled) {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  background: rgba(41, 121, 255, 0.02);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(41, 121, 255, 0.1);
}

.export-option-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

.export-option-btn.csv:hover:not(:disabled) {
  border-color: #10b981;
  border-color: var(--success-color);
  background: rgba(16, 185, 129, 0.02);
  box-shadow: 0 8px 24px rgba(16, 185, 129, 0.1);
}

.export-option-btn.xlsx:hover:not(:disabled) {
  border-color: #059669;
  background: rgba(5, 150, 105, 0.02);
  box-shadow: 0 8px 24px rgba(5, 150, 105, 0.1);
}

.export-option-btn.both:hover:not(:disabled) {
  border-color: #f59e0b;
  border-color: var(--warning-color);
  background: rgba(245, 158, 11, 0.02);
  box-shadow: 0 8px 24px rgba(245, 158, 11, 0.1);
}

.export-option-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: #f8fafc;
  background: var(--card-bg);
  flex-shrink: 0;
}

.export-option-btn.csv .export-option-icon {
  background: rgba(16, 185, 129, 0.1);
  color: #10b981;
  color: var(--success-color);
}

.export-option-btn.xlsx .export-option-icon {
  background: rgba(5, 150, 105, 0.1);
  color: #059669;
}

.export-option-btn.both .export-option-icon {
  background: rgba(245, 158, 11, 0.1);
  color: #f59e0b;
  color: var(--warning-color);
}

.export-option-content {
  flex: 1 1;
}

.export-option-content h4 {
  margin: 0 0 0.5rem 0;
  font-size: 1.125rem;
  font-weight: 600;
  color: #1f2937;
  color: var(--text-color);
}

.export-option-content p {
  margin: 0;
  font-size: 0.875rem;
  color: #6b7280;
  color: var(--text-secondary);
  line-height: 1.5;
}

.export-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 2rem;
  padding: 1rem;
  background: #f8fafc;
  background: var(--card-bg);
  border-radius: 8px;
  color: #6b7280;
  color: var(--text-secondary);
  font-weight: 500;
}

.export-spinner {
  width: 20px;
  height: 20px;
  border: 2px solid #e5e7eb;
  border: 2px solid var(--card-border);
  border-top: 2px solid #2979ff;
  border-top: 2px solid var(--accent-blue);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Mobile responsive adjustments */
@media (max-width: 1024px) {
  .progress-content {
    flex-direction: column;
    align-items: flex-start; /* Left align on mobile too */
    gap: 1.5rem;
  }
  
  .progress-bar-large {
    width: 100%;
    max-width: none; /* Allow full width on mobile */
  }
  
  .start-review-btn-large {
    align-self: flex-start; /* Left align button on mobile */
  }
}

/* Responsive Design */
@media (max-width: 1024px) {
  .tracker-page-wrapper {
    padding: 1rem;
  }
  
  .tracker-filters-card {
    flex-direction: column;
    align-items: stretch;
    gap: 1.5rem;
  }
  
  .export-button-spacious {
    align-self: flex-start;
  }
}

@media (max-width: 768px) {
  .tracker-header h1 {
    font-size: 2rem;
  }
  
  .filter-inputs-spacious {
    flex-direction: column;
    gap: 1rem;
  }
  
  .filter-group input {
    min-width: auto;
    width: 100%;
  }
  
  .results-info-spacious {
    flex-direction: column;
    align-items: stretch;
    gap: 1rem;
  }
  
  .table-wrapper-spacious {
    overflow-x: auto;
  }
  
  .tracker-table-spacious {
    min-width: 900px;
  }
  
  .tracker-table-spacious th,
  .data-cell {
    padding: 1rem 1.5rem;
    font-size: 0.8rem;
  }
  
  .status-cell,
  .action-cell {
    padding: 1rem 1rem;
  }
}

/* Selected Files Preview */
.selected-files-preview {
  margin-top: 2rem;
  padding: 1.5rem;
  background-color: #f8fafc;
  background-color: var(--card-bg);
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
  max-height: 280px;
  display: flex;
  flex-direction: column;
}

.files-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  flex-shrink: 0;
}

.files-header h4 {
  margin: 0;
  color: #1f2937;
  color: var(--text-color);
  font-size: 1rem;
  font-weight: 600;
}

.clear-all-btn {
  background: none;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  color: #6b7280;
  color: var(--text-secondary);
  padding: 0.5rem 0.75rem;
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.75rem;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 0.375rem;
  transition: all 0.2s ease;
  font-family: 'Inter', sans-serif;
}

.clear-all-btn:hover {
  border-color: #dc2626;
  color: #dc2626;
  background-color: rgba(220, 38, 38, 0.05);
}

.clear-all-btn:active {
  transform: scale(0.98);
}

.file-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  overflow-y: auto;
  flex: 1 1;
  padding-right: 0.5rem;
}

.file-list::-webkit-scrollbar {
  width: 6px;
}

.file-list::-webkit-scrollbar-track {
  background: #e5e7eb;
  background: var(--card-border);
  border-radius: 3px;
}

.file-list::-webkit-scrollbar-thumb {
  background: #6b7280;
  background: var(--text-secondary);
  border-radius: 3px;
}

.file-list::-webkit-scrollbar-thumb:hover {
  background: #2979ff;
  background: var(--accent-blue);
}

.file-list {
  scrollbar-width: thin;
  scrollbar-color: #6b7280 #e5e7eb;
  scrollbar-color: var(--text-secondary) var(--card-border);
}

.file-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1rem;
  background-color: #ffffff;
  background-color: var(--primary-color);
  border: 1px solid #e5e7eb;
  border: 1px solid var(--card-border);
  border-radius: 8px;
  transition: all 0.2s ease;
}

.file-item:hover {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  box-shadow: 0 2px 8px rgba(41, 121, 255, 0.1);
}

.file-info {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  flex: 1 1;
}

.file-name {
  font-weight: 500;
  color: #1f2937;
  color: var(--text-color);
  font-size: 0.875rem;
}

.file-size {
  font-size: 0.75rem;
  color: #6b7280;
  color: var(--text-secondary);
}

.remove-file-btn {
  background: none;
  border: none;
  color: #6b7280;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 4px;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.remove-file-btn:hover {
  color: #dc2626;
  background-color: rgba(220, 38, 38, 0.1);
}

.drop-zone.has-files {
  border-color: #2979ff;
  border-color: var(--accent-blue);
  background-color: rgba(41, 121, 255, 0.02);
}

/* Enhanced mobile responsiveness for TrackerPage */
@media (max-width: 768px) {
  .tracker-page-wrapper {
    padding: 1rem;
    min-height: auto;
  }
  
  .tracker-header {
    padding: 1.5rem 0 2rem;
    margin-bottom: 1.5rem;
  }
  
  .tracker-header h1 {
    font-size: 1.75rem;
  }
  
  .tracker-header p {
    font-size: 1rem;
  }
  
  .tracker-progress-card {
    padding: 1.5rem 1rem;
    margin-bottom: 1.5rem;
  }
  
  .progress-content {
    flex-direction: column;
    gap: 1.5rem;
  }
  
  .progress-info {
    text-align: left; /* Keep left aligned on mobile */
  }
  
  .progress-info h3,
  .progress-info p {
    text-align: left; /* Keep left aligned on mobile */
  }
  
  .progress-bar-large {
    width: 100%;
    height: 10px;
  }
  
  .start-review-btn-large {
    width: 100%;
    justify-content: center;
    padding: 0.875rem 1.5rem;
  }
  
  .tracker-filters-card {
    padding: 1.5rem 1rem;
    flex-direction: column;
    gap: 1.5rem;
    align-items: stretch;
  }
  
  .filter-inputs-spacious {
    flex-direction: column;
    gap: 1rem;
  }
  
  .filter-group input {
    min-width: auto;
    width: 100%;
  }
  
  .export-button-spacious {
    width: 100%;
    padding: 0.875rem 1.5rem;
  }
  
  .results-info-spacious {
    flex-direction: column;
    gap: 1rem;
    align-items: stretch;
    margin-bottom: 1rem;
    padding: 0 0.5rem;
  }
  
  .status-filter {
    justify-content: space-between;
  }
  
  .status-select {
    flex: 1 1;
    max-width: 200px;
  }
  
  .table-wrapper-spacious {
    margin: 0 -1rem;
    border-radius: 12px;
    overflow-x: auto; /* Keep horizontal scroll for mobile */
    overflow-y: visible; /* Allow vertical overflow for tooltips */
    -webkit-overflow-scrolling: touch;
  }
  
  .tracker-table-spacious {
    min-width: 700px;
    width: auto;
    overflow: visible; /* Allow overflow for tooltips on mobile */
  }
  
  .tracker-table-spacious th,
  .tracker-table-spacious .data-cell {
    padding: 0.75rem 0.5rem;
    font-size: 0.75rem;
    white-space: nowrap;
  }
  
  .tracker-table-spacious .status-column,
  .tracker-table-spacious .action-column {
    width: 60px;
  }
  
  .status-cell,
  .action-cell {
    padding: 0.75rem 0.25rem;
  }
  
  .pagination-container-spacious {
    margin: 1.5rem -1rem 0;
    padding: 0 1rem;
  }
  
  .pagination {
    gap: 0.25rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  
  .pagination-btn {
    padding: 0.5rem 0.75rem;
    font-size: 0.75rem;
    min-width: 32px;
    height: 32px;
  }
  
  .selected-files-preview {
    padding: 1rem;
    margin-top: 1.5rem;
    max-height: 220px;
  }
  
  .files-header {
    margin-bottom: 0.75rem;
  }
  
  .files-header h4 {
    font-size: 0.9rem;
  }
  
  .clear-all-btn {
    padding: 0.375rem 0.625rem;
    font-size: 0.7rem;
    gap: 0.25rem;
  }
  
  .clear-all-btn svg {
    width: 14px;
    height: 14px;
  }
  
  .file-item {
    padding: 0.625rem 0.75rem;
  }
  
  .file-name {
    font-size: 0.8rem;
  }
  
  .file-size {
    font-size: 0.7rem;
  }
  
  .remove-file-btn {
    padding: 0.375rem;
  }
  
  .file-list {
    padding-right: 0.25rem;
  }
  
  /* Date filter buttons mobile */
  .date-filter-buttons {
    gap: 0.5rem;
    justify-content: flex-start;
  }
  
  .date-filter-btn {
    padding: 0.5rem 0.75rem;
    font-size: 0.8rem;
    min-width: auto;
  }
  
  /* Modal responsive */
  .modal-content {
    min-width: auto;
    width: 95vw;
    margin: 1rem;
  }
  
  .modal-header,
  .modal-body,
  .modal-footer {
    padding-left: 1rem;
    padding-right: 1rem;
  }
  
  .modal-date-inputs {
    gap: 1.5rem;
  }
  
  .modal-input-row {
    flex-direction: column;
    gap: 0.75rem;
  }
  
  .modal-footer {
    flex-direction: column;
    gap: 1rem;
    align-items: stretch;
  }
  
  .modal-actions {
    width: 100%;
    justify-content: space-between;
  }
  
  .modal-actions-centered {
    width: 100%;
    justify-content: center;
  }
  
  .modal-btn {
    flex: 1 1;
  }
  
  /* Export modal mobile */
  .export-modal {
    margin: 1rem;
    max-width: none;
  }

  .export-modal-header,
  .export-modal-content {
    padding: 1.5rem;
  }

  .export-options {
    gap: 0.75rem;
  }

  .export-option-btn {
    flex-direction: column;
    text-align: center;
    padding: 1rem;
    gap: 0.75rem;
  }

  .export-option-icon {
    width: 40px;
    height: 40px;
  }

  .export-option-content h4 {
    font-size: 1rem;
  }

  .export-option-content p {
    font-size: 0.8rem;
  }

  /* Enhanced Status Indicator Mobile */
  .status-indicator {
    flex-direction: column;
    gap: 0.25rem;
    font-size: 0.7rem;
  }
  
  .status-indicator svg {
    width: 12px;
    height: 12px;
  }
  
  .status-text {
    display: none; /* Hide text on mobile, show only icon */
  }
  
  .action-buttons {
    flex-direction: column;
    gap: 0.25rem;
  }
  
  .action-btn {
    min-width: 28px;
    height: 28px;
    padding: 0.375rem;
  }
  
  .action-btn svg {
    width: 12px;
    height: 12px;
  }
}

@media (max-width: 480px) {
  .tracker-header h1 {
    font-size: 1.5rem;
  }
  
  .tracker-table-spacious {
    min-width: 600px;
  }
  
  .tracker-table-spacious th,
  .tracker-table-spacious .data-cell {
    padding: 0.5rem 0.25rem;
    font-size: 0.7rem;
  }
  
  .pagination-btn {
    padding: 0.375rem 0.5rem;
    font-size: 0.7rem;
    min-width: 28px;
    height: 28px;
  }
  
  .selected-files-preview {
    max-height: 200px;
  }
  
  .files-header {
    flex-direction: column;
    align-items: stretch;
    gap: 0.5rem;
  }
  
  .clear-all-btn {
    justify-content: center;
    width: 100%;
  }
  
  .file-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
  }
  
  .remove-file-btn {
    align-self: flex-end;
    margin-top: -2rem;
  }
  
  .progress-info h3 {
    font-size: 1.125rem;
  }

  .progress-info p {
    font-size: 0.9rem;
  }
  
  .date-filter-buttons {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    grid-gap: 0.5rem;
    gap: 0.5rem;
    width: 100%;
  }
  
  .date-filter-btn {
    padding: 0.625rem 0.5rem;
    font-size: 0.75rem;
    text-align: center;
    justify-content: center;
  }
}

/* GENERAL MOBILE UTILITIES */
@media (max-width: 768px) {
  .table-wrapper-spacious::after {
    content: "← Scroll to see more →";
    display: block;
    text-align: center;
    font-size: 0.75rem;
    color: #6b7280;
    color: var(--text-secondary);
    padding: 0.5rem;
    background: rgba(41, 121, 255, 0.05);
    border-top: 1px solid #e5e7eb;
    border-top: 1px solid var(--card-border);
  }
  
  .table-wrapper-spacious::-webkit-scrollbar {
    height: 4px;
  }
  
  .table-wrapper-spacious::-webkit-scrollbar-track {
    background: #e5e7eb;
    background: var(--card-border);
  }
  
  .table-wrapper-spacious::-webkit-scrollbar-thumb {
    background: #2979ff;
    background: var(--accent-blue);
    border-radius: 2px;
  }
}

/* Touch-friendly button sizes */
@media (max-width: 768px) {
  button, .button, .btn {
    min-height: 44px;
    min-width: 44px;
  }
  
  .clickable-filename {
    padding: 0.5rem 0;
    display: inline-block;
  }
}

/* Prevent horizontal overflow on mobile */
@media (max-width: 768px) {
  body {
    overflow-x: hidden;
  }
  
  * {
    max-width: 100%;
  }
  
  .upload-page-container,
  .tracker-page-wrapper {
    overflow-x: hidden;
  }
}
/* src/pages/AdminPanel.css - Modern Card-Based Design matching Settings Page */
.admin-panel {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2rem;
  font-family: 'Inter', sans-serif;
  background-color: var(--card-bg);
  min-height: 100vh;
}

.admin-header {
  background: var(--primary-color);
  border-radius: 16px;
  padding: 2rem;
  margin-bottom: 2rem;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.04);
  border: 1px solid var(--card-border);
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease;
}

.admin-header::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #f59e0b, #f97316);
}

.admin-header:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
}

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

.header-content h1 {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--text-color);
  margin: 0 0 0.5rem 0;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.header-content p {
  color: var(--text-secondary);
  margin: 0;
  font-size: 1.125rem;
  font-weight: 500;
}

.refresh-btn {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: white;
  border: none;
  padding: 0.875rem 1.75rem;
  border-radius: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  box-shadow: 0 4px 12px rgba(102, 126, 234, 0.3);
  font-size: 0.875rem;
}

.refresh-btn:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(102, 126, 234, 0.4);
}

.refresh-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

.admin-content {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.stats-section {
  background: var(--primary-color);
  border-radius: 16px;
  padding: 2rem;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.04);
  border: 1px solid var(--card-border);
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease;
}

.stats-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--accent-blue), #64b5f6);
}

.stats-section:nth-child(2)::before {
  background: linear-gradient(90deg, #ec4899, #8b5cf6);
}

.stats-section:nth-child(3)::before {
  background: linear-gradient(90deg, #10b981, #059669);
}

.stats-section:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
}

.stats-section h2 {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--text-color);
  margin: 0 0 1.5rem 0;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--card-border);
}

/* Counters Grid */
.counters-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  grid-gap: 1.5rem;
  gap: 1.5rem;
}

.counter-card {
  background: var(--background-color);
  border-radius: 12px;
  padding: 1.5rem;
  border: 1px solid var(--card-border);
  transition: all 0.3s ease;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.counter-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

.counter-card h3 {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text-color);
  margin: 0 0 1rem 0;
  text-align: center;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--card-border);
}

.counter-stats {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.stat-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.5rem 0;
}

.stat-label {
  font-weight: 500;
  color: var(--text-secondary);
}

.stat-value {
  font-weight: 600;
  color: var(--text-color);
  font-size: 1.1rem;
}

/* App Stats Grid */
.app-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  grid-gap: 1.5rem;
  gap: 1.5rem;
}

.app-stat-card {
  background: var(--background-color);
  border-radius: 12px;
  padding: 1.5rem;
  border: 1px solid var(--card-border);
  transition: all 0.3s ease;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.app-stat-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

.app-stat-card h3 {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--text-color);
  margin: 0 0 1rem 0;
  text-align: center;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--card-border);
}

.app-stats {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

/* Daily Stats Table */
.daily-stats-table {
  overflow-x: auto;
}

.daily-stats-table table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.daily-stats-table th,
.daily-stats-table td {
  padding: 0.75rem;
  text-align: left;
  border-bottom: 1px solid #e2e8f0;
  border-bottom: 1px solid var(--card-border, #e2e8f0);
}

.daily-stats-table th {
  background: var(--background-color);
  font-weight: 600;
  color: var(--text-color);
  position: -webkit-sticky;
  position: sticky;
  top: 0;
}

.daily-stats-table tr:hover {
  background: var(--background-color);
}

.daily-stats-table td {
  color: var(--text-secondary);
}

/* No Data State */
.no-data {
  text-align: center;
  padding: 3rem 2rem;
  color: var(--text-secondary);
}

.no-data p {
  font-size: 1.125rem;
  margin-bottom: 2rem;
}

.debug-info {
  background: var(--background-color);
  border-radius: 12px;
  padding: 1.5rem;
  text-align: left;
  max-width: 600px;
  margin: 0 auto;
  border: 1px solid var(--card-border);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.debug-info h4 {
  color: var(--text-color);
  margin: 0 0 1rem 0;
  font-size: 1.125rem;
}

.debug-info ul {
  margin: 0;
  padding-left: 1.5rem;
}

.debug-info li {
  margin-bottom: 0.5rem;
  line-height: 1.5;
}

.debug-info code {
  background: var(--card-border);
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  font-family: 'Monaco', 'Menlo', 'Ubuntu Mono', monospace;
  font-size: 0.875rem;
}

/* Error Message */
.error-message {
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 12px;
  padding: 1.5rem;
  color: #dc2626;
  box-shadow: 0 2px 8px rgba(220, 38, 38, 0.1);
}

.error-message p {
  margin: 0 0 1rem 0;
}

/* Responsive Design */
@media (max-width: 768px) {
  .admin-panel {
    padding: 1rem;
  }
  
  .admin-header {
    flex-direction: column;
    gap: 1rem;
    align-items: stretch;
  }
  
  .header-content {
    text-align: center;
  }
  
  .counters-grid,
  .app-stats-grid {
    grid-template-columns: 1fr;
  }
  
  .daily-stats-table {
    font-size: 0.8rem;
  }
  
  .daily-stats-table th,
  .daily-stats-table td {
    padding: 0.5rem;
  }
}
