/**
 * Mobile Menu Styles
 * Optimized CSS for mobile menu functionality
 */

/* Mobile Menu Panel Base Styles */
#mobile-menu-panel,
#sticky-mobile-menu-panel {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ffffff;
  z-index: 9999;
  display: none;
  transform: translateX(100%);
  transition: transform 0.3s ease-in-out;
  overflow: hidden;
  -webkit-overflow-scrolling: touch;
}

/* Adjust top position based on header height */
#mobile-menu-panel {
  top: 128px; /* h-32 = 8rem = 128px */
  bottom: 0;
}

#sticky-mobile-menu-panel {
  top: 80px; /* h-20 = 5rem = 80px */
  bottom: 0;
}

/* Menu Panel Open State */
#mobile-menu-panel.translate-x-0,
#sticky-mobile-menu-panel.translate-x-0 {
  transform: translateX(0);
}

/* Menu Panel Closed State */
#mobile-menu-panel.translate-x-full,
#sticky-mobile-menu-panel.translate-x-full {
  transform: translateX(100%);
}

/* Prevent body scroll when menu is open */
/* Note: JavaScript handles position:fixed and scroll position restoration */
body.menu-open {
  overflow: hidden !important;
}

/* Mobile Menu Content */
#mobile-menu-panel > div,
#sticky-mobile-menu-panel > div {
  min-height: calc(100vh - 128px);
  height: auto;
  overflow-y: auto;
  padding: 2rem 1.5rem;
  position: relative;
  z-index: 1;
  background-color: #ffffff;
}

#sticky-mobile-menu-panel > div {
  min-height: calc(100vh - 80px);
}

/* Mobile Menu Navigation Links */
#mobile-menu-panel nav,
#sticky-mobile-menu-panel nav {
  display: flex !important;
  flex-direction: column !important;
  gap: 1.5rem !important;
  width: 100% !important;
  opacity: 1 !important;
  visibility: visible !important;
}

#mobile-menu-panel nav a,
#sticky-mobile-menu-panel nav a {
  display: block !important;
  padding: 0.75rem 0 !important;
  font-size: 1.125rem !important;
  font-weight: 600 !important;
  color: #1b1b18 !important;
  text-decoration: none !important;
  border-bottom: 1px solid #e5e7eb !important;
  transition: color 0.2s ease-in-out;
  opacity: 1 !important;
  visibility: visible !important;
  position: relative !important;
  z-index: 10 !important;
}

/* Ensure Order Online button is visible */
#mobile-menu-panel nav div,
#sticky-mobile-menu-panel nav div {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
}

#mobile-menu-panel nav div a,
#sticky-mobile-menu-panel nav div a {
  display: inline-flex !important;
  opacity: 1 !important;
  visibility: visible !important;
}

#mobile-menu-panel nav a:hover,
#sticky-mobile-menu-panel nav a:hover {
  color: #937237;
}

/* Mobile Menu Toggle Button */
#mobile-menu-toggle,
#sticky-mobile-menu-toggle {
  position: relative;
  z-index: 50;
  padding: 0.5rem;
  background: transparent;
  border: none;
  cursor: pointer;
  transition: opacity 0.2s ease-in-out;
}

#mobile-menu-toggle:hover,
#sticky-mobile-menu-toggle:hover {
  opacity: 0.8;
}

#mobile-menu-toggle:focus,
#sticky-mobile-menu-toggle:focus {
  outline: 2px solid #937237;
  outline-offset: 2px;
}

/* Icon Visibility */
#mobile-menu-icon.hidden,
#sticky-mobile-menu-icon.hidden,
#mobile-menu-close.hidden,
#sticky-mobile-menu-close.hidden {
  display: none !important;
}

/* Desktop: Hide mobile menu panels */
@media (min-width: 768px) {
  #mobile-menu-panel,
  #sticky-mobile-menu-panel {
    display: none !important;
  }
  
  #mobile-menu-toggle,
  #sticky-mobile-menu-toggle {
    display: none;
  }
}

/* Smooth transitions */
@media (prefers-reduced-motion: no-preference) {
  #mobile-menu-panel,
  #sticky-mobile-menu-panel {
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
  #mobile-menu-panel,
  #sticky-mobile-menu-panel {
    transition: none;
  }
}
