/* ━━━ Mobile Menu — Leyana Sun ━━━ */
/* Accessible, fast, no JS framework. */

/* Hamburger button — desktop hidden, mobile visible */
.mobile-menu-toggle {
  display: none;
  background: none;
  border: none;
  padding: 8px;
  cursor: pointer;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  z-index: 200;
  position: relative;
}

.mobile-menu-toggle span,
.mobile-menu-toggle span::before,
.mobile-menu-toggle span::after {
  display: block;
  width: 24px;
  height: 2px;
  background-color: #6B0D13;
  transition: transform 0.25s ease, opacity 0.25s ease;
  position: relative;
}

.mobile-menu-toggle span::before,
.mobile-menu-toggle span::after {
  content: '';
  position: absolute;
  left: 0;
}

.mobile-menu-toggle span::before { top: -8px; }
.mobile-menu-toggle span::after { top: 8px; }

/* Hamburger → X when open */
.mobile-menu-toggle[aria-expanded="true"] span { background-color: transparent; }
.mobile-menu-toggle[aria-expanded="true"] span::before {
  top: 0;
  transform: rotate(45deg);
  background-color: #F8F2E6;
}
.mobile-menu-toggle[aria-expanded="true"] span::after {
  top: 0;
  transform: rotate(-45deg);
  background-color: #F8F2E6;
}

/* Mobile menu overlay */
.mobile-menu-overlay {
  position: fixed;
  inset: 0;
  background: linear-gradient(135deg, #3A0A10 0%, #6B0D13 100%);
  z-index: 150;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s;
}

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

.mobile-menu-overlay nav {
  display: flex;
  flex-direction: column;
  gap: 12px;
  text-align: center;
  margin-bottom: 48px;
}

.mobile-menu-overlay nav a {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 32px;
  color: #F8F2E6;
  text-decoration: none;
  padding: 14px 28px;
  display: block;
  font-weight: 500;
  transition: color 0.2s, transform 0.2s;
  letter-spacing: -0.01em;
}

.mobile-menu-overlay nav a:hover,
.mobile-menu-overlay nav a:focus {
  color: #B89657;
  transform: translateX(4px);
}

.mobile-menu-overlay nav a em {
  font-style: italic;
  color: #B89657;
}

.mobile-menu-overlay .menu-divider {
  width: 60px;
  height: 1px;
  background: rgba(184, 150, 87, 0.4);
  margin: 12px auto;
}

.mobile-menu-overlay .menu-cta {
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #B89657;
  border: 1px solid #B89657;
  padding: 14px 32px;
  margin-top: 8px;
  font-family: 'Inter', sans-serif;
}

.mobile-menu-overlay .menu-cta:hover {
  background: #B89657;
  color: #3A0A10;
  transform: none;
}

.mobile-menu-overlay .menu-footer {
  margin-top: 24px;
  font-size: 12px;
  color: rgba(248, 242, 230, 0.6);
  text-align: center;
  font-style: italic;
  font-family: 'Cormorant Garamond', serif;
}

.mobile-menu-overlay .menu-footer a {
  color: #B89657;
  font-size: 12px;
  padding: 4px 8px;
  font-style: normal;
  font-family: 'Inter', sans-serif;
  letter-spacing: 0.05em;
}

/* Lock body scroll when menu open */
body.menu-open {
  overflow: hidden;
}

/* Show hamburger only on mobile */
@media (max-width: 720px) {
  .mobile-menu-toggle {
    display: flex;
  }
}
