/* Mobile Menu Modal - Optimized & Best Practices */
/* Este arquivo contém todas as regras específicas do modal do menu mobile */
/* Separado do CSS principal para melhor organização e manutenibilidade */

/* Reset and base styles */
.mobile-menu {
  /* Use fixed positioning for full viewport coverage - CORRIGE O PROBLEMA DO position: absolute */
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  
  /* Proper z-index hierarchy - Garante que o modal apareça acima de tudo */
  z-index: 9999 !important;
  
  /* Modern backdrop styling - Efeito de blur moderno */
  background: rgba(0, 0, 0, 0.6) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
  
  /* Initial hidden state - Estado inicial invisível */
  opacity: 0 !important;
  visibility: hidden !important;
  
  /* Smooth transitions - Transições suaves */
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  
  /* Flexbox for perfect centering - Centralização perfeita sem cálculos manuais */
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  
  /* Safe area padding for mobile devices - Suporte a dispositivos com notch */
  padding: max(1rem, env(safe-area-inset-top)) 1rem max(1rem, env(safe-area-inset-bottom)) 1rem !important;
}

/* Active state */
.mobile-menu.active {
  opacity: 1 !important;
  visibility: visible !important;
}

/* Modal content container */
.mobile-menu .mobile-nav-links {
  /* Modern glass morphism */
  background: rgba(255, 255, 255, 0.98) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  
  /* Rounded corners */
  border-radius: 1.5rem !important;
  
  /* Proper spacing */
  padding: 2rem 1.5rem !important;
  
  /* Responsive width */
  width: 100% !important;
  max-width: 380px !important;
  
  /* Height constraints */
  max-height: calc(100vh - 2rem) !important;
  max-height: calc(100dvh - 2rem) !important; /* Dynamic viewport height */
  
  /* Scrollable content */
  overflow-y: auto !important;
  
  /* Modern shadow */
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25) !important;
  
  /* Subtle border */
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  
  /* Initial transform for animation */
  transform: scale(0.95) translateY(20px) !important;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* Active state animation */
.mobile-menu.active .mobile-nav-links {
  transform: scale(1) translateY(0) !important;
}

/* Menu header indicator */
.mobile-menu .mobile-nav-links::before {
  content: '' !important;
  display: block !important;
  width: 40px !important;
  height: 4px !important;
  background: linear-gradient(90deg, #54723c, #2dd4bf) !important;
  border-radius: 2px !important;
  margin: 0 auto 1.5rem auto !important;
}

/* Navigation menu list */
.mobile-menu .mobile-nav-menu {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.5rem !important;
  list-style: none !important;
  margin: 0 0 1.5rem 0 !important;
  padding: 0 !important;
}

/* Menu items */
.mobile-menu .mobile-nav-menu li {
  margin: 0 !important;
}

/* Menu links */
.mobile-menu .mobile-nav-menu a {
  display: block !important;
  padding: 0.875rem 1.25rem !important;
  color: #374151 !important;
  text-decoration: none !important;
  border-radius: 0.875rem !important;
  background: rgba(84, 114, 60, 0.05) !important;
  border: 1px solid rgba(84, 114, 60, 0.1) !important;
  font-weight: 500 !important;
  font-size: 1rem !important;
  text-align: center !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  
  /* Initial animation state */
  opacity: 0 !important;
  transform: translateY(15px) !important;
  
  /* Prevent text selection on touch */
  -webkit-user-select: none !important;
  user-select: none !important;
  
  /* Touch optimization */
  -webkit-tap-highlight-color: transparent !important;
}

/* Active menu animation */
.mobile-menu.active .mobile-nav-menu a {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* Hover and focus states */
.mobile-menu .mobile-nav-menu a:hover,
.mobile-menu .mobile-nav-menu a:focus,
.mobile-menu .mobile-nav-menu a.active {
  background: linear-gradient(135deg, rgba(84, 114, 60, 0.1), rgba(45, 212, 191, 0.1)) !important;
  color: #54723c !important;
  border-color: rgba(84, 114, 60, 0.3) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 25px rgba(84, 114, 60, 0.15) !important;
}

/* CTA Button */
.mobile-cta-button {
  display: block !important;
  width: 100% !important;
  padding: 1rem 1.25rem !important;
  background: linear-gradient(135deg, #54723c, #2dd4bf) !important;
  color: white !important;
  text-align: center !important;
  border-radius: 0.875rem !important;
  font-weight: 600 !important;
  font-size: 1rem !important;
  text-decoration: none !important;
  border: none !important;
  
  /* Animation */
  opacity: 0 !important;
  transform: translateY(15px) !important;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
  
  /* Modern shadow */
  box-shadow: 0 8px 25px rgba(84, 114, 60, 0.3) !important;
  
  /* Touch optimization */
  -webkit-tap-highlight-color: transparent !important;
}

/* CTA Button active animation */
.mobile-menu.active .mobile-cta-button {
  opacity: 1 !important;
  transform: translateY(0) !important;
  transition-delay: 0.3s !important;
}

/* CTA Button hover */
.mobile-cta-button:hover,
.mobile-cta-button:focus {
  background: linear-gradient(135deg, #445a31, #14b8a6) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 35px rgba(84, 114, 60, 0.4) !important;
}

/* Sequential animation delays */
.mobile-menu.active .mobile-nav-menu a:nth-child(1) { transition-delay: 0.1s !important; }
.mobile-menu.active .mobile-nav-menu a:nth-child(2) { transition-delay: 0.15s !important; }
.mobile-menu.active .mobile-nav-menu a:nth-child(3) { transition-delay: 0.2s !important; }
.mobile-menu.active .mobile-nav-menu a:nth-child(4) { transition-delay: 0.25s !important; }
.mobile-menu.active .mobile-nav-menu a:nth-child(5) { transition-delay: 0.3s !important; }

/* Body scroll lock */
body.mobile-menu-open {
  overflow: hidden !important;
  position: fixed !important;
  width: 100% !important;
  height: 100% !important;
}

/* Mobile menu button z-index */
#mobile-menu-button {
  z-index: 10000 !important;
  position: relative !important;
}

/* Responsive adjustments */
@media (max-width: 480px) {
  .mobile-menu {
    padding: 0.75rem !important;
  }
  
  .mobile-menu .mobile-nav-links {
    padding: 1.5rem 1.25rem !important;
    border-radius: 1.25rem !important;
    max-height: calc(100vh - 1.5rem) !important;
    max-height: calc(100dvh - 1.5rem) !important;
  }
  
  .mobile-menu .mobile-nav-menu a {
    padding: 0.75rem 1rem !important;
    font-size: 0.95rem !important;
  }
  
  .mobile-cta-button {
    padding: 0.875rem 1rem !important;
    font-size: 0.95rem !important;
  }
}

/* Landscape mobile optimization */
@media (max-height: 600px) and (orientation: landscape) {
  .mobile-menu .mobile-nav-links {
    padding: 1rem 1.25rem !important;
    max-height: calc(100vh - 1rem) !important;
    max-height: calc(100dvh - 1rem) !important;
  }
  
  .mobile-menu .mobile-nav-links::before {
    margin-bottom: 1rem !important;
  }
  
  .mobile-menu .mobile-nav-menu {
    gap: 0.375rem !important;
    margin-bottom: 1rem !important;
  }
  
  .mobile-menu .mobile-nav-menu a {
    padding: 0.625rem 1rem !important;
    font-size: 0.9rem !important;
  }
  
  .mobile-cta-button {
    padding: 0.75rem 1rem !important;
    font-size: 0.9rem !important;
  }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
  .mobile-menu {
    background: rgba(0, 0, 0, 0.8) !important;
  }
  
  .mobile-menu .mobile-nav-links {
    background: white !important;
    border: 2px solid #000 !important;
  }
  
  .mobile-menu .mobile-nav-menu a {
    border: 1px solid #54723c !important;
  }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
  .mobile-menu,
  .mobile-menu .mobile-nav-links,
  .mobile-menu .mobile-nav-menu a,
  .mobile-cta-button {
    transition: none !important;
    animation: none !important;
  }
  
  .mobile-menu.active .mobile-nav-menu a,
  .mobile-menu.active .mobile-cta-button {
    transition-delay: 0s !important;
  }
}

/* Focus management for accessibility */
.mobile-menu:focus-within .mobile-nav-links {
  outline: 2px solid #54723c !important;
  outline-offset: 2px !important;
}

/* Ensure proper stacking context */
.mobile-menu * {
  position: relative !important;
}

/* Prevent content shift */
.mobile-menu .mobile-nav-menu a,
.mobile-cta-button {
  will-change: transform, opacity !important;
}

/* Performance optimization */
.mobile-menu {
  contain: layout style paint !important;
}