/* =========================================================
   style.menu.css
   Dedicated menu styling for autheme2025
   ========================================================= */

/* ========== Base Layout ========== */
.menu-bar .container {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 16px;
  box-sizing: border-box;
}

.main-navigation {
  grid-column: span 12;
  text-align: center;
}

/* Reset WP defaults */
.main-navigation ul,
.main-navigation li {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Primary menu horizontal (desktop/tablet) */
.main-navigation ul {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 32px;
}

/* Top-level links */
.main-navigation ul li a {
  display: block;
  text-decoration: none;
  color: var(--text-color, #333);
  font-weight: 500;
  font-size: 16px;
  padding: 8px 0;
  line-height: 1;
  transition: color 0.3s ease;
}

.main-navigation ul li a:hover,
.main-navigation ul li.current-menu-item a {
  color: var(--primary-color, #b30000);
}

/* ========== Submenus ========== */
.main-navigation ul li ul {
  display: none;
  position: absolute;
  background: #fff;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  padding: 8px 0;
  margin-top: 8px;
  z-index: 999;
  flex-direction: column; /* force vertical */
}

.main-navigation ul li:hover > ul,
.main-navigation ul li:focus-within > ul {
  display: flex;
}

.main-navigation ul li ul li {
  width: 200px;
}

.main-navigation ul li ul li a {
  padding: 8px 16px;
  font-size: 14px;
  font-weight: 400;
  color: #333;
}

.main-navigation ul li ul li a:hover {
  background: #f5f5f5;
}

/* ========== Mobile ========== */
.mobile-navigation {
  grid-column: span 12;
  text-align: right;
  display: none; /* hidden on desktop */
}

.menu-toggle {
  background: none;
  border: 1px solid var(--border-color, #ddd);
  padding: 8px 12px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 16px;
}

.mobile-menu-content {
  display: none;
  background: #fff;
  padding: 16px;
  border-top: 1px solid #eee;
}

.mobile-menu-content ul,
.mobile-menu-content li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.mobile-menu-content ul {
  display: flex;
  flex-direction: column; /* vertical stack */
  gap: 8px;
}

.mobile-menu-content li a {
  display: block;
  padding: 8px 0;
  text-decoration: none;
  color: #333;
  font-size: 16px;
}

/* ========== Responsive Rules ========== */
@media (max-width: 991px) {
  /* Hide desktop menu */
  .main-navigation {
    display: none;
  }
  /* Show mobile nav */
  .mobile-navigation {
    display: block;
  }
}

/* Expanded state (toggled with JS) */
.mobile-menu-content[aria-hidden="false"] {
  display: block;
}
