/* ============================================================================ */
/* SwiftSpot Custom Styles                                                     */
/* Main custom stylesheet with global overrides and enhancements              */
/* ============================================================================ */

/* ============================================================================ */
/* CSS CUSTOM PROPERTIES (VARIABLES)                                           */
/* ============================================================================ */
:root {
  /* Color tokens */
  --color-primary-blue: #3b82f6;
  --color-primary-blue-hover: #60a5fa;
  --color-success-green: #22c55e;
  --color-error-red: #ef4444;
  --color-warning-yellow: #f59e0b;
  --color-info-cyan: #06b6d4;
  --color-gray-50: #f9fafb;
  --color-gray-100: #f3f4f6;
  --color-gray-200: #e5e7eb;
  --color-gray-300: #d1d5db;
  --color-gray-400: #9ca3af;
  --color-gray-500: #6b7280;
  --color-gray-600: #4b5563;
  --color-gray-700: #374151;
  --color-gray-800: #1f2937;
  --color-gray-900: #111827;
  
  /* Dark mode color overrides */
  --color-dark-bg: #111827;
  --color-dark-surface: #1f2937;
  --color-dark-border: #374151;
  --color-dark-text: #f9fafb;
  --color-dark-text-muted: #d1d5db;
  --color-dark-text-secondary: #9ca3af;
  
  /* Required label colors */
  --color-required-bg-light: #dbeafe;
  --color-required-text-light: #1e40af;
  --color-required-bg-dark: rgba(59, 130, 246, 0.15);
  --color-required-text-dark: #93c5fd;
  
  /* Spacing and sizing */
  --spacing-base: 1rem;
  --border-radius-base: 0.5rem;
  --border-radius-lg: 0.75rem;
  --border-radius-xl: 1rem;
  --border-radius-full: 9999px;
  --shadow-subtle: 0 1px 3px 0 rgba(0, 0, 0, 0.1);
  --shadow-medium: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
  --shadow-strong: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  --shadow-glow: 0 0 20px rgba(59, 130, 246, 0.4);
  --shadow-glow-purple: 0 0 20px rgba(147, 51, 234, 0.4);
  
  /* Typography */
  --font-size-xs: 0.75rem;
  --font-size-sm: 0.875rem;
  --font-size-base: 1rem;
  --font-size-lg: 1.125rem;
  --letter-spacing-wide: 0.025em;
  
  /* Transitions */
  --transition-fast: 0.15s ease;
  --transition-base: 0.2s ease;
  --transition-slow: 0.3s ease;
  --transition-bounce: 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  
  /* Gradients */
  --gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  --gradient-secondary: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);
  --gradient-success: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);
  --gradient-warm: linear-gradient(135deg, #fa709a 0%, #fee140 100%);
  --gradient-cool: linear-gradient(135deg, #a8edea 0%, #fed6e3 100%);
  
  /* Glass morphism effect */
  --glass-morphism: rgba(255, 255, 255, 0.1);
  
  /* Icon sizes */
  --icon-xs: 0.75rem;
  --icon-sm: 1rem;
  --icon-base: 1.25rem;
  --icon-lg: 1.5rem;
  --icon-xl: 2rem;
  --icon-2xl: 2.5rem;
  
  /* Z-index scale */
  --z-dropdown: 1000;
  --z-modal: 1040;
  --z-overlay: 1050;
  --z-tooltip: 1060;
  --z-toast: 9999;
  --z-max: 10000;
}

/* ============================================================================ */
/* DARK MODE THEME                                                             */
/* ============================================================================ */
html.dark {
  background-color: var(--color-dark-bg);
  color: var(--color-dark-text);
}

html.dark a {
  color: #bfdbfe;
}

html.dark a:hover {
  color: var(--color-primary-blue-hover) !important;
}

html.dark .map-container,
html.dark #mini-map {
  border-color: var(--color-primary-blue);
  box-shadow: none;
}

/* Dark mode form controls */
html.dark input,
html.dark select,
html.dark textarea {
  background-color: var(--color-dark-surface);
  color: var(--color-dark-text);
  border-color: var(--color-dark-border);
}

html.dark input::placeholder,
html.dark textarea::placeholder {
  color: var(--color-gray-400);
}

/* Dark mode utility class overrides */
html.dark .bg-white { background-color: var(--color-dark-surface) !important; }
html.dark .text-gray-800 { color: var(--color-dark-text) !important; }
html.dark .text-gray-600 { color: var(--color-dark-text-muted) !important; }
html.dark .text-gray-500 { color: var(--color-gray-400) !important; }
html.dark .border-gray-300 { border-color: var(--color-dark-border) !important; }

/* Remove shadows in dark mode for cleaner look */
html.dark .shadow-md,
html.dark .shadow-lg,
html.dark .shadow-xl {
  box-shadow: none !important;
}

/* ============================================================================ */
/* REQUIRED LABEL STYLING                                                      */
/* ============================================================================ */

/* Custom styling for "Required" labels with lighter blue shades */
.bg-blue-100.text-blue-800 {
  background-color: #dbeafe !important; /* Even lighter blue background */
  color: #1e40af !important; /* Slightly lighter blue text */
}

.dark .bg-blue-100.text-blue-800 {
  background-color: rgba(59, 130, 246, 0.15) !important; /* Very light blue background in dark mode */
  color: #93c5fd !important; /* Light blue text in dark mode */
}

/* Required label colors already defined in main :root section */

/* Apply to any element with both required label classes */
.required-label,
[class*="bg-blue-100"][class*="text-blue-800"] {
  background-color: var(--color-required-bg-light) !important;
  color: var(--color-required-text-light) !important;
}

.dark .required-label,
.dark [class*="bg-blue-100"][class*="text-blue-800"] {
  background-color: var(--color-required-bg-dark) !important;
  color: var(--color-required-text-dark) !important;
}

/* ============================================================================ */
/* STICKY PROGRESS BAR - NO GAPS                                               */
/* ============================================================================ */

/* Ensure progress bar is at the very top with no gaps */
#progress-bar {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Remove any default spacing from main content and form */
#mainContent {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

#wizardForm {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* ============================================================================ */
/* COMPONENT POSITIONING & LAYOUT                                              */
/* ============================================================================ */

/* Cookie Banner */
#cookie-banner {
  position: fixed !important;
  bottom: 0.5rem !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  z-index: var(--z-overlay) !important;
  max-width: 24rem !important;
}

#cookie-banner:not(.hidden) {
  display: block !important;
  visibility: visible !important;
}

/* Support Chat Widget */
#supportChatWidget {
  position: fixed !important;
  bottom: var(--spacing-base) !important;
  right: var(--spacing-base) !important;
  z-index: var(--z-overlay) !important;
  background: var(--gradient-primary);
  border-radius: var(--border-radius-full);
  box-shadow: var(--shadow-glow);
  transition: all var(--transition-base);
}

/* Progress bar for list spot form */
.progress-bar-container {
  width: 1.00%;
  margin-left: var(--spacing-base);
  margin-right: var(--spacing-base);
}

/* Chart containers for data visualization */
.chart-bar {
  height: 0.5rem;
  border-radius: var(--border-radius-base);
  transition: width var(--transition-base);
}

.chart-bar-blue { background-color: var(--color-primary-blue); }
.chart-bar-green { background-color: var(--color-success-green); }

/* Map container */
.map-full-height {
  height: 65vh;
  min-height: 400px;
  max-height: 650px;
  width: 100%;
  overflow: hidden;
}

/* ============================================================================ */
/* GOOGLE MAPS UI REMOVAL                                                      */
/* ============================================================================ */

/* Hide Google Maps branding, terms, and report elements - but preserve map functionality */
.gm-style-cc,
.gmnoprint a[target="_blank"],
.gm-bundled-control[data-control-width="40"][data-control-height="81"],
[title="Report errors in the road map or imagery to Google"],
a[href^="https://maps.google.com/maps"]:not([role]),
a[href^="https://www.google.com/maps"]:not([role]),
.gm-style .gm-style-iw-t::after,
.gm-style .gm-style-iw-tc::after {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* Hide Google logo and legal text specifically */
div[title="Click to see this area on Google Maps"],
a[title="Click to see this area on Google Maps"]:not([role]),
[aria-label="Google"]:not([role]):not([tabindex]),
[title="Google"]:not([role]):not([tabindex]) {
  display: none !important;
  opacity: 0 !important;
}

/* Hide Terms of Use and other legal elements */
.gm-style a[href*="google.com/help/terms_maps"],
.gm-style a[href*="google.com/intl/"][href*="/help/terms_maps"] {
  display: none !important;
}

/* Success modal icon */
.success-icon-large {
  font-size: 4rem;
}

/* ============================================================================ */
/* NAVIGATION ENHANCEMENTS                                                     */
/* ============================================================================ */

/* Modern navigation bar styling */
nav {
  backdrop-filter: blur(10px);
  background: rgba(255, 255, 255, 0.95);
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease;
}

html.dark nav {
  background: rgba(17, 24, 39, 0.95);
  border-bottom-color: rgba(255, 255, 255, 0.1);
}

/* Navigation container constraints */
nav .max-w-6xl {
  max-width: 72rem; /* 1152px - industry standard */
}

/* Logo enhancements */
nav .flex-shrink-0 a {
  transition: transform 0.2s ease;
}

nav .flex-shrink-0 a:hover {
  transform: scale(1.05);
}

/* Navigation link improvements */
nav a {
  position: relative;
  transition: all 0.2s ease;
}

nav a:hover {
  transform: translateY(-1px);
}

/* Active state enhancements */
nav a.border-blue-600 {
  border-bottom-width: 3px;
  font-weight: 600;
}

/* Dropdown improvements */
.dropdown-menu {
  backdrop-filter: blur(10px);
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(0, 0, 0, 0.1);
  box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}

html.dark .dropdown-menu {
  background: rgba(17, 24, 39, 0.98);
  border-color: rgba(255, 255, 255, 0.1);
}

/* User menu button styling */
#user-menu-button {
  display: flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  padding: 0.5rem !important;
  background-color: var(--color-gray-100) !important;
  border: 2px solid var(--color-gray-300) !important;
  transition: all var(--transition-base) !important;
  border-radius: var(--border-radius-base);
}

#user-menu-button:hover {
  background-color: var(--color-gray-200) !important;
  border-color: var(--color-primary-blue) !important;
  transform: scale(1.05) !important;
}

.dark #user-menu-button {
  background-color: var(--color-gray-700) !important;
  border-color: var(--color-gray-600) !important;
}

.dark #user-menu-button:hover {
  background-color: var(--color-gray-600) !important;
  border-color: var(--color-primary-blue) !important;
}

/* Avatar visibility fix */
#user-menu-button .h-8.w-8,
#user-menu-button .h-10.w-10 {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Mobile menu improvements */
#mobile-menu {
  backdrop-filter: blur(10px);
  background: rgba(255, 255, 255, 0.98);
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

html.dark #mobile-menu {
  background: rgba(17, 24, 39, 0.98);
  border-top-color: rgba(255, 255, 255, 0.1);
}

/* Mobile menu item enhancements */
#mobile-menu a {
  transition: all 0.2s ease;
}

#mobile-menu a:hover {
  transform: translateX(4px);
}

/* Theme toggle improvements */
#theme-toggle,
#theme-toggle-mobile {
  position: relative;
  overflow: hidden;
}

#theme-toggle::before,
#theme-toggle-mobile::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, #3b82f6, #8b5cf6);
  border-radius: inherit;
  opacity: 0;
  transition: opacity 0.2s ease;
}

#theme-toggle:hover::before,
#theme-toggle-mobile:hover::before {
  opacity: 0.1;
}

/* Responsive improvements */
@media (max-width: 768px) {
  nav .max-w-6xl {
    max-width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
  }
  
  nav .flex-shrink-0 img {
    height: 2rem;
  }
}

/* Focus states for accessibility */
nav button:focus,
nav a:focus {
  outline: 2px solid #3b82f6;
  outline-offset: 2px;
}

/* Smooth transitions for all interactive elements */
nav * {
  transition: all 0.2s ease;
}

/* ============================================================================ */
/* ICON SIZE SYSTEM                                                            */
/* Comprehensive solution for consistent icon sizing across the application    */
/* ============================================================================ */

/* Icon size classes using CSS custom properties */

/* Universal icon sizing utility */
.icon-size-override {
  width: var(--size) !important;
  height: var(--size) !important;
  min-width: var(--size) !important;
  min-height: var(--size) !important;
  max-width: var(--size) !important;
  max-height: var(--size) !important;
}

/* Specific Tailwind class overrides for SVG elements */
svg.w-3.h-3, svg.w-3, svg.h-3 { --size: var(--icon-xs); }
svg.w-4.h-4, svg.w-4, svg.h-4 { --size: var(--icon-sm); }
svg.w-5.h-5, svg.w-5, svg.h-5 { --size: var(--icon-base); }
svg.w-6.h-6, svg.w-6, svg.h-6 { --size: var(--icon-lg); }
svg.w-8.h-8, svg.w-8, svg.h-8 { --size: var(--icon-xl); }
svg.w-10.h-10, svg.w-10, svg.h-10 { --size: var(--icon-2xl); }

/* Apply the override using the custom property */
svg[class*="w-"][class*="h-"] {
  width: var(--size, inherit) !important;
  height: var(--size, inherit) !important;
  min-width: var(--size, inherit) !important;
  min-height: var(--size, inherit) !important;
  max-width: var(--size, inherit) !important;
  max-height: var(--size, inherit) !important;
}

/* Utility class overrides for non-SVG elements */
.w-3 { width: var(--icon-xs) !important; }
.h-3 { height: var(--icon-xs) !important; }
.w-4 { width: var(--icon-sm) !important; }
.h-4 { height: var(--icon-sm) !important; }
.w-5 { width: var(--icon-base) !important; }
.h-5 { height: var(--icon-base) !important; }
.w-6 { width: var(--icon-lg) !important; }
.h-6 { height: var(--icon-lg) !important; }
.w-8 { width: var(--icon-xl) !important; }
.h-8 { height: var(--icon-xl) !important; }
.w-10 { width: var(--icon-2xl) !important; }
.h-10 { height: var(--icon-2xl) !important; }

/* Reset for unspecified SVGs */
svg:not([width]):not([height]):not([class*="w-"]):not([class*="h-"]) {
  width: auto !important;
  height: auto !important;
}

/* Specific override for satellite button icon and positioning */
#map-type-btn {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  z-index: 10000 !important;
  pointer-events: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

#map-type-btn svg {
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  min-height: 20px !important;
  max-width: 20px !important;
  max-height: 20px !important;
}

/* Ensure map container allows absolute positioning */
#map {
  position: relative !important;
  overflow: visible !important;
}

/* Prevent Google Maps controls from interfering */
#map .gm-style {
  position: relative !important;
}

#map .gm-control-active {
  z-index: 999 !important;
}

/* Specific override for Location & Photos heading icon */
.wizard-step header h2 svg {
  width: 16px !important;
  height: 16px !important;
  min-width: 16px !important;
  min-height: 16px !important;
  max-width: 16px !important;
  max-height: 16px !important;
}

/* Navigation specific icon inheritance */
.dropdown-button svg,
nav svg,
#user-menu-button svg {
  width: inherit !important;
  height: inherit !important;
}

/* Checkbox sizing (ensure it doesn't affect SVGs) */
input[type="checkbox"]:not(svg) {
  width: 16px !important;
  height: 16px !important;
}

.spot-type-checkbox {
  width: 16px !important;
  height: 16px !important;
}

/* ============================================================================ */
/* ENHANCED PHONE INPUT SYSTEM                                                 */
/* ============================================================================ */

.phone-input-wrapper {
  position: relative;
}

#country-dropdown {
  box-shadow: var(--shadow-medium);
  border: 1px solid var(--color-gray-200);
  backdrop-filter: blur(10px);
}

.dark #country-dropdown {
  border-color: var(--color-gray-600);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3);
}

.country-option:hover {
  background-color: var(--color-gray-100) !important;
}

.dark .country-option:hover {
  background-color: var(--color-gray-700) !important;
}

/* Structured phone number input */
#phone_number {
  font-family: 'Courier New', monospace;
  letter-spacing: 0.5px;
  font-size: 16px;
}

#phone_number::placeholder {
  color: var(--color-gray-400);
  font-family: 'Courier New', monospace;
  letter-spacing: 0.5px;
}

.dark #phone_number::placeholder {
  color: var(--color-gray-500);
}

/* Focus indicators for accessibility */
#country-selector-btn:focus {
  outline: 2px solid var(--color-primary-blue);
  outline-offset: 2px;
}

#country-search:focus {
  box-shadow: 0 0 0 2px var(--color-primary-blue);
}

/* ============================================================================ */
/* ACCESSIBILITY ENHANCEMENTS                                                  */
/* ============================================================================ */

/* Screen reader only content */
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* Avatar visibility fix */
.rounded-full img,
.rounded-full div {
  display: block !important;
  visibility: visible !important;
}

/* ============================================================================ */
/* IMAGE OVERLAY FIXES                                                         */
/* Prevents Chrome/Edge image overlays (Lens, Visual Search, etc.)             */
/* ============================================================================ */

img::before,
img::after {
  content: none !important;
  display: none !important;
}

[jsname][role="button"],
div[aria-label="Visual search"] {
  display: none !important;
}

/* ============================================================================ */
/* RESPONSIVE DESIGN                                                           */
/* ============================================================================ */

/* Mobile optimizations */
@media (max-width: 640px) {
  /* Cookie banner responsive */
  #cookie-banner {
    left: var(--spacing-base) !important;
    right: var(--spacing-base) !important;
    transform: none !important;
    max-width: none !important;
  }
  
  /* Support chat positioning */
  #supportChatWidget {
    bottom: var(--spacing-base) !important;
    right: var(--spacing-base) !important;
  }
  
  /* Phone input responsive */
  #country-dropdown {
    width: 100vw;
    left: -1rem;
    max-width: calc(100vw - 2rem);
  }
  
  .phone-input-wrapper {
    flex-direction: column;
  }
  
  .phone-input-wrapper > div:first-child {
    border-radius: var(--border-radius-base) var(--border-radius-base) 0 0;
    border-bottom: 0;
  }
  
  .phone-input-wrapper input[type="tel"] {
    border-radius: 0 0 var(--border-radius-base) var(--border-radius-base);
    border-top: 0;
  }
  
  /* Ensure address autocomplete input is not affected by phone styles */
  #autocomplete {
    border: 1px solid #d1d5db !important;
    border-radius: 0.5rem !important;
  }
}

/* Tablet and up navigation */
@media (max-width: 768px) {
  #user-menu-button {
    padding: 0.75rem !important;
    border-width: 2px !important;
  }
}

/* ============================================================================ */
/* UTILITY CLASSES                                                             */
/* ============================================================================ */

/* Position utilities - DISABLED: conflicts with debugging display:none */
/* .relative .dropdown-menu.show,
.relative .dropdown-menu.active,
.relative .dropdown-menu.opacity-100,
.relative .dropdown-menu.visible {
  position: absolute !important;
  top: 100% !important;
  left: 0 !important;
  margin-top: 0.5rem !important;
} */

/* Enhanced focus states */
.focus-enhanced:focus {
  outline: 2px solid var(--color-primary-blue);
  outline-offset: 2px;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

/* Smooth transitions for interactive elements */
.transition-smooth {
  transition: all var(--transition-base);
}

.transition-smooth:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-medium);
}

/* Loading states */
.loading-pulse {
  animation: loading-pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

@keyframes loading-pulse {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: 0.8;
    transform: scale(1.02);
  }
}

/* ============================================================================ */
/* COMPONENT-SPECIFIC STYLES                                                   */
/* ============================================================================ */

/* Success indicator states */
.success-state {
  background-color: var(--color-success-green);
  color: white;
  border-color: var(--color-success-green);
}

/* Interactive button enhancements */
.btn-enhanced {
  position: relative;
  transition: all var(--transition-base);
}

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

.btn-enhanced.loading {
  background-color: var(--color-success-green);
  color: white;
  border-color: var(--color-success-green);
}

/* Modal fade effects */
.modal-fade-out {
  animation: fadeOut 0.3s ease-in-out;
}

/* Notification animations */
.notification-slide-in {
  animation: slideInFromRight 0.3s ease-out;
}

.notification-slide-out {
  animation: slideOutToRight 0.3s ease-in;
}

@keyframes slideInFromRight {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes slideOutToRight {
  from {
    transform: translateX(0);
    opacity: 1;
  }
  to {
    transform: translateX(100%);
    opacity: 0;
  }
}

/* ============================================================================ */
/* DARK MODE ANIMATIONS                                                        */
/* ============================================================================ */

/* Dark mode toggle button animations */
#theme-toggle {
  transition: all var(--transition-base);
  position: relative;
}

#theme-toggle:hover {
  transform: scale(1.1);
  background-color: rgba(59, 130, 246, 0.1);
  border-radius: 50%;
}

#theme-toggle:active {
  transform: scale(0.95);
}

/* Dark mode icon animations */
.dark-mode-icon {
  display: inline-block;
  transition: all var(--transition-base);
  font-size: 1.2rem;
}

#theme-toggle:hover .dark-mode-icon {
  transform: rotate(15deg) scale(1.1);
}

/* Page-wide dark mode transition animation */
html {
  transition: background-color var(--transition-slow) ease-in-out;
}

html.dark-mode-transitioning * {
  transition: background-color var(--transition-slow) ease-in-out, 
              color var(--transition-slow) ease-in-out, 
              border-color var(--transition-slow) ease-in-out !important;
}

/* Toggle animation feedback - ripple effect */
@keyframes ripple-effect {
  0% {
    transform: scale(0);
    opacity: 1;
  }
  100% {
    transform: scale(4);
    opacity: 0;
  }
}

#theme-toggle::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 5px;
  height: 5px;
  background: rgba(59, 130, 246, 0.6);
  opacity: 0;
  border-radius: 100%;
  transform: scale(1) translate(-50%, -50%);
  transform-origin: 50% 50%;
}

#theme-toggle.animate-ripple::after {
  animation: ripple-effect 0.6s linear;
}

/* Smooth fade-in animation for mode switching */
@keyframes fade-in-dark {
  from {
    background-color: #f9fafb;
    color: #111827;
  }
  to {
    background-color: #111827;
    color: #f9fafb;
  }
}

@keyframes fade-in-light {
  from {
    background-color: #111827;
    color: #f9fafb;
  }
  to {
    background-color: #f9fafb;
    color: #111827;
  }
}

html.animate-to-dark {
  animation: fade-in-dark var(--transition-slow) ease-in-out;
}

html.animate-to-light {
  animation: fade-in-light var(--transition-slow) ease-in-out;
}

/* Enhanced toggle button styling */
#theme-toggle {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.1), rgba(147, 51, 234, 0.1));
  border: 2px solid transparent;
  background-clip: padding-box;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

html.dark #theme-toggle {
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.2), rgba(245, 158, 11, 0.2));
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

/* Visual feedback during toggle */
.theme-switching {
  pointer-events: none;
}

.theme-switching #theme-toggle {
  animation: pulse 0.6s ease-in-out;
}

@keyframes pulse {
  0%, 100% {
    transform: scale(1);
    opacity: 1;
  }
  50% {
    transform: scale(1.15);
    opacity: 0.8;
  }
}

/* ============================================================================ */
/* SwiftSpot Enhanced Custom Styles - UI Polish Edition                        */
/* Comprehensive custom stylesheet with modern design enhancements             */
/* ============================================================================ */

/* ============================================================================ */
/* SWIFTSPOT CUSTOM STYLES                                                     */
/* ============================================================================ */
/* 
 * Custom CSS for SwiftSpot parking application
 * Includes: Variables, Dark mode, Components, Utilities, and Responsive styles
 * Last cleaned: December 2024
 */

/* ============================================================================ */
/* CSS CUSTOM PROPERTIES (VARIABLES)                                           */
/* ============================================================================ */

/* Enhanced button base styles */
button, .btn {
  font-weight: 500;
  transition: all var(--transition-base);
  cursor: pointer;
  border-radius: var(--border-radius-base);
  position: relative;
  overflow: hidden;
}

button:hover, .btn:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-lg);
}

button:active, .btn:active {
  transform: translateY(0);
}

/* Enhanced card styles */
.card-enhanced {
  background: white;
  border-radius: var(--border-radius-xl);
  box-shadow: var(--shadow-base);
  border: 1px solid var(--color-gray-200);
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}

.card-enhanced::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--gradient-primary);
  opacity: 0;
  transition: opacity var(--transition-base);
}

.card-enhanced:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-xl);
}

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

html.dark .card-enhanced {
  background: var(--color-dark-surface);
  border-color: var(--color-dark-border);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.2);
}

/* Enhanced input styles */
.input-enhanced {
  background: white;
  border: 2px solid var(--color-gray-200);
  border-radius: var(--border-radius-base);
  padding: 0.75rem 1rem;
  font-size: var(--font-size-base);
  transition: all var(--transition-base);
  width: 100%;
}

.input-enhanced:focus {
  border-color: var(--color-primary-blue);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
  background: var(--color-gray-50);
}

.input-enhanced::placeholder {
  color: var(--color-gray-400);
}

html.dark .input-enhanced {
  background: var(--color-dark-surface);
  border-color: var(--color-dark-border);
  color: var(--color-dark-text);
}

html.dark .input-enhanced:focus {
  background: var(--color-dark-bg-secondary);
  border-color: var(--color-primary-blue);
}

/* Enhanced gradient text */
.gradient-text {
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: inline-block;
}

/* Enhanced glass morphism effect */
.glass-morphism {
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: var(--border-radius-xl);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
}

html.dark .glass-morphism {
  background: rgba(15, 23, 42, 0.3);
  border-color: rgba(255, 255, 255, 0.1);
}

/* ============================================================================ */
/* ENHANCED ANIMATIONS                                                         */
/* ============================================================================ */

/* Fade in animations */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

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

@keyframes fadeInLeft {
  from { opacity: 0; transform: translateX(-30px); }
  to { opacity: 1; transform: translateX(0); }
}

@keyframes fadeInRight {
  from { opacity: 0; transform: translateX(30px); }
  to { opacity: 1; transform: translateX(0); }
}

/* Scale animations */
@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.9); }
  to { opacity: 1; transform: scale(1); }
}

@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.05); }
}

/* Bounce animation */
@keyframes bounce {
  0%, 20%, 53%, 80%, 100% { transform: translate3d(0,0,0); }
  40%, 43% { transform: translate3d(0, -30px, 0); }
  70% { transform: translate3d(0, -15px, 0); }
  90% { transform: translate3d(0, -4px, 0); }
}

/* Shimmer loading animation */
@keyframes shimmer {
  0% { background-position: -200px 0; }
  100% { background-position: calc(200px + 100%) 0; }
}

.shimmer {
  background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
  background-size: 200px 100%;
  animation: shimmer 1.5s infinite;
}

html.dark .shimmer {
  background: linear-gradient(90deg, #374151 25%, #4b5563 50%, #374151 75%);
  background-size: 200px 100%;
}

/* Utility animation classes */
.animate-fade-in { animation: fadeIn 0.6s ease-out; }
.animate-fade-in-down { animation: fadeInDown 0.6s ease-out; }
.animate-fade-in-left { animation: fadeInLeft 0.6s ease-out; }
.animate-fade-in-right { animation: fadeInRight 0.6s ease-out; }
.animate-scale-in { animation: scaleIn 0.6s ease-out; }
.animate-pulse-slow { animation: pulse 2s infinite; }
.animate-bounce-slow { animation: bounce 2s infinite; }

/* Animation delays */
.animate-delay-100 { animation-delay: 100ms; }
.animate-delay-200 { animation-delay: 200ms; }
.animate-delay-300 { animation-delay: 300ms; }
.animate-delay-500 { animation-delay: 500ms; }
.animate-delay-700 { animation-delay: 700ms; }
.animate-delay-1000 { animation-delay: 1000ms; }

/* ============================================================================ */
/* ENHANCED COMPONENT STYLES                                                   */
/* ============================================================================ */

/* Enhanced navigation */
nav {
  backdrop-filter: blur(10px);
  background: rgba(255, 255, 255, 0.95);
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease;
}

html.dark nav {
  background: rgba(17, 24, 39, 0.95);
  border-bottom-color: rgba(255, 255, 255, 0.1);
}

/* Enhanced dropdown menus - DISABLED: conflicts with debugging display:none */
/* .dropdown-menu.show,
.dropdown-menu.active,
.dropdown-menu.opacity-100,
.dropdown-menu.visible {
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-xl);
  padding: 0.5rem;
  margin-top: 0.5rem;
  transition: all var(--transition-base);
  transform-origin: top;
} */

/* html.dark .dropdown-menu.show,
html.dark .dropdown-menu.active,
html.dark .dropdown-menu.opacity-100,
html.dark .dropdown-menu.visible {
  background: rgba(30, 41, 59, 0.95);
  border-color: rgba(255, 255, 255, 0.1);
} */

/* .dropdown-menu.show a,
.dropdown-menu.active a,
.dropdown-menu.opacity-100 a,
.dropdown-menu.visible a {
  border-radius: var(--border-radius-base);
  padding: 0.75rem 1rem;
  transition: all var(--transition-base);
  display: flex;
  align-items: center;
  gap: 0.5rem;
} */

/* .dropdown-menu.show a:hover,
.dropdown-menu.active a:hover,
.dropdown-menu.opacity-100 a:hover,
.dropdown-menu.visible a:hover {
  background: var(--color-primary-blue);
  color: white;
  transform: translateX(4px);
} */

/* Enhanced buttons */
.btn-primary {
  background: var(--gradient-primary);
  color: white;
  border: none;
  padding: 0.75rem 1.5rem;
  border-radius: var(--border-radius-base);
  font-weight: 600;
  font-size: var(--font-size-base);
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}

.btn-primary::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 var(--transition-slow);
}

.btn-primary:hover::before {
  left: 100%;
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-glow);
}

.btn-secondary {
  background: white;
  color: var(--color-primary-blue);
  border: 2px solid var(--color-primary-blue);
  padding: 0.75rem 1.5rem;
  border-radius: var(--border-radius-base);
  font-weight: 600;
  transition: all var(--transition-base);
}

.btn-secondary:hover {
  background: var(--color-primary-blue);
  color: white;
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

/* Enhanced form styling */
.form-group {
  margin-bottom: 1.5rem;
}

.form-label {
  font-weight: 600;
  color: var(--color-gray-700);
  margin-bottom: 0.5rem;
  display: block;
}

html.dark .form-label {
  color: var(--color-dark-text-muted);
}

/* Enhanced toast notifications */
.toast {
  background: white;
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--color-gray-200);
  padding: 1rem 1.5rem;
  margin-bottom: 0.5rem;
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(10px);
  animation: slideInFromRight 0.3s ease-out;
}

.toast::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--gradient-primary);
}

.toast.success::before { background: var(--color-success-green); }
.toast.error::before { background: var(--color-error-red); }
.toast.warning::before { background: var(--color-warning-yellow); }
.toast.info::before { background: var(--color-info-cyan); }

html.dark .toast {
  background: var(--color-dark-surface);
  border-color: var(--color-dark-border);
  color: var(--color-dark-text);
}

/* Enhanced loading states */
.loading-skeleton {
  background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
  background-size: 200px 100%;
  animation: shimmer 1.5s infinite;
  border-radius: var(--border-radius-base);
}

html.dark .loading-skeleton {
  background: linear-gradient(90deg, #374151 25%, #4b5563 50%, #374151 75%);
  background-size: 200px 100%;
}

/* Enhanced modal styling */
.modal-backdrop {
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
  transition: all var(--transition-base);
}

.modal {
  background: white;
  border-radius: var(--border-radius-xl);
  box-shadow: var(--shadow-2xl);
  border: 1px solid var(--color-gray-200);
  transform: scale(0.95);
  transition: all var(--transition-base);
}

.modal.show {
  transform: scale(1);
}

html.dark .modal {
  background: var(--color-dark-surface);
  border-color: var(--color-dark-border);
}

/* ============================================================================ */
/* EXISTING STYLES - PRESERVED AND ENHANCED                                   */
/* ============================================================================ */

/* Required label styling - enhanced */
.bg-blue-100.text-blue-800 {
  background: linear-gradient(135deg, #dbeafe, #bfdbfe) !important;
  color: #1e40af !important;
  border-radius: var(--border-radius-base);
  padding: 0.25rem 0.5rem;
  font-weight: 600;
  font-size: var(--font-size-xs);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  border: 1px solid #93c5fd;
}

.dark .bg-blue-100.text-blue-800 {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.2), rgba(59, 130, 246, 0.1)) !important;
  color: #93c5fd !important;
  border-color: rgba(147, 197, 253, 0.3);
}

/* Progress bar - enhanced */
#progress-bar {
  background: var(--gradient-primary);
  height: 4px;
  border-radius: var(--border-radius-full);
  transition: width var(--transition-base);
  position: relative;
  overflow: hidden;
}

#progress-bar::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  animation: shimmer 2s infinite;
}

/* Component positioning - enhanced */
#cookie-banner {
  background: var(--glass-morphism);
  border-radius: var(--border-radius-xl);
  border: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: var(--shadow-xl);
  backdrop-filter: blur(10px);
}

#supportChatWidget {
  background: var(--gradient-primary);
  border-radius: var(--border-radius-full);
  box-shadow: var(--shadow-glow);
  transition: all var(--transition-base);
}

/* Enhanced chart styling */
.chart-bar {
  border-radius: var(--border-radius-base);
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}

.chart-bar::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  transition: left var(--transition-slow);
}

.chart-bar:hover::after {
  left: 100%;
}

/* Enhanced map styling */
.map-full-height {
  border-radius: var(--border-radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--color-gray-200);
  transition: all var(--transition-base);
}

.map-full-height:hover {
  box-shadow: var(--shadow-xl);
}

html.dark .map-full-height {
  border-color: var(--color-dark-border);
}

/* Enhanced navigation - preserved functionality */
#user-menu-button {
  background: var(--glass-morphism) !important;
  border: 2px solid rgba(255, 255, 255, 0.2) !important;
  border-radius: var(--border-radius-base) !important;
  transition: all var(--transition-base) !important;
  backdrop-filter: blur(10px) !important;
}

#user-menu-button:hover {
  transform: scale(1.05) !important;
  box-shadow: var(--shadow-glow) !important;
  border-color: var(--color-primary-blue) !important;
}

html.dark #user-menu-button {
  background: rgba(30, 41, 59, 0.7) !important;
  border-color: rgba(255, 255, 255, 0.1) !important;
}

/* Enhanced theme toggle */
#theme-toggle {
  background: var(--glass-morphism);
  border-radius: var(--border-radius-full);
  padding: 0.5rem;
  transition: all var(--transition-bounce);
  position: relative;
  overflow: hidden;
}

#theme-toggle::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--gradient-primary);
  border-radius: var(--border-radius-full);
  opacity: 0;
  transition: opacity var(--transition-base);
}

#theme-toggle:hover::before {
  opacity: 0.1;
}

#theme-toggle:hover {
  transform: scale(1.1) rotate(15deg);
  box-shadow: var(--shadow-glow);
}

.dark-mode-icon {
  font-size: 1.25rem;
  transition: all var(--transition-bounce);
  position: relative;
  z-index: 1;
}

/* Enhanced dark mode transitions */
html.dark-mode-transitioning * {
  transition: background-color var(--transition-slow), color var(--transition-slow), border-color var(--transition-slow) !important;
}

/* Enhanced styles while preserving existing functionality */

/* ============================================================================ */
/* RESPONSIVE ENHANCEMENTS                                                     */
/* ============================================================================ */

@media (max-width: 640px) {
  .card-enhanced {
    border-radius: var(--border-radius-lg);
    margin: 0.5rem;
  }
  
  .btn-primary, .btn-secondary {
    width: 100%;
    padding: 1rem;
    font-size: var(--font-size-lg);
  }
  
  .modal {
    margin: 1rem;
    border-radius: var(--border-radius-lg);
  }
  
  .toast {
    margin: 0.5rem;
    border-radius: var(--border-radius-base);
  }
}

@media (max-width: 768px) {
  .glass-morphism {
    backdrop-filter: blur(5px);
  }
  
  nav {
    backdrop-filter: blur(5px);
  }
  
  /* .dropdown-menu.show,
  .dropdown-menu.active,
  .dropdown-menu.opacity-100,
  .dropdown-menu.visible {
    backdrop-filter: blur(5px);
  } */
}

/* ============================================================================ */
/* UTILITY CLASSES                                                            */
/* ============================================================================ */

/* Custom scale utilities for subtle animations */
.scale-102 {
  transform: scale(1.02);
}

.hover\:scale-102:hover {
  transform: scale(1.02);
}

.text-gradient-primary { 
  background: var(--gradient-primary); 
  -webkit-background-clip: text; 
  background-clip: text; 
  -webkit-text-fill-color: transparent; 
  color: transparent;
}
.text-gradient-secondary { 
  background: var(--gradient-secondary); 
  -webkit-background-clip: text; 
  background-clip: text; 
  -webkit-text-fill-color: transparent; 
  color: transparent;
}
.bg-gradient-primary { background: var(--gradient-primary); }
.bg-gradient-secondary { background: var(--gradient-secondary); }
.bg-gradient-success { background: var(--gradient-success); }
.bg-gradient-warm { background: var(--gradient-warm); }
.bg-gradient-cool { background: var(--gradient-cool); }

.shadow-glow { box-shadow: var(--shadow-glow); }
.shadow-glow-purple { box-shadow: var(--shadow-glow-purple); }

.border-gradient {
  border: 2px solid transparent;
  background: linear-gradient(white, white) padding-box, var(--gradient-primary) border-box;
}

html.dark .border-gradient {
  background: linear-gradient(var(--color-dark-surface), var(--color-dark-surface)) padding-box, var(--gradient-primary) border-box;
}

.hover-lift {
  transition: transform var(--transition-base);
}

.hover-lift:hover {
  transform: translateY(-4px);
}

.hover-scale {
  transition: transform var(--transition-base);
}

.hover-scale:hover {
  transform: scale(1.05);
}

.hover-glow {
  transition: box-shadow var(--transition-base);
}

.hover-glow:hover {
  box-shadow: var(--shadow-glow);
}

/* End of enhanced styles */

/* ============================================================================ */
/* DROPDOWN SYSTEM - Industry Standard Hover Behavior */
/* ============================================================================ */

/* Base dropdown state - hidden by default */
.dropdown-menu {
  opacity: 0;
  visibility: hidden;
  transform: scale(0.95) translateY(-8px);
  transition: opacity 0.15s ease-out, visibility 0.15s ease-out, transform 0.15s ease-out;
  pointer-events: none;
  transform-origin: top center;
}

/* Dropdown state when container has .open class */
.dropdown-container.open .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: scale(1) translateY(0);
  pointer-events: auto;
}

/* Dropdown arrow rotation with smooth transition */
.dropdown-arrow {
  transition: transform 0.2s ease-out;
}

.dropdown-container.open .dropdown-arrow {
  transform: rotate(180deg);
}

/* Invisible bridge styling */
.dropdown-bridge {
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  height: 8px;
  background: transparent;
  z-index: 49;
  pointer-events: auto;
}

/* Enhanced dropdown menu styling */
.dropdown-menu {
  background: rgba(255, 255, 255, 0.98);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 12px;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}

html.dark .dropdown-menu {
  background: rgba(31, 41, 55, 0.98);
  border-color: rgba(255, 255, 255, 0.1);
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.3), 0 10px 10px -5px rgba(0, 0, 0, 0.2);
}

/* Dropdown menu items with enhanced hover effects */
.dropdown-menu a {
  transition: all 0.15s ease-out;
  border-radius: 8px;
  margin: 2px 4px;
}

.dropdown-menu a:hover {
  background: rgba(59, 130, 246, 0.1);
  color: #1e40af;
  transform: translateX(4px);
}

html.dark .dropdown-menu a:hover {
  background: rgba(59, 130, 246, 0.2);
  color: #60a5fa;
}

/* Mobile menu - separate from dropdown system */
#mobile-menu {
  opacity: 0;
  visibility: hidden;
  transform: translateY(-100%);
  transition: opacity 0.3s, visibility 0.3s, transform 0.3s;
}

#mobile-menu.open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* ============================================================================ */
/* MODAL ANIMATIONS                                                             */
/* ============================================================================ */

@keyframes modal-slide-in {
  from {
    opacity: 0;
    transform: scale(0.95) translateY(-10px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

@keyframes modal-slide-out {
  from {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
  to {
    opacity: 0;
    transform: scale(0.95) translateY(-10px);
  }
}

.animate-modal-slide-in {
  animation: modal-slide-in 0.2s ease-out;
}

.animate-modal-slide-out {
  animation: modal-slide-out 0.2s ease-in;
}

