/* ==========================================================================
   Mobile Menu Component
   Slide-in drawer navigation for mobile devices
   ========================================================================== */

/* Menu Header */
.mobile-menu-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-md);
  border-bottom: 2px solid var(--parchment-dark);
}

.mobile-menu-title {
  font-family: var(--font-heading);
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--warm-grey-dark);
  margin: 0;
}

.mobile-menu-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  background: transparent;
  border: none;
  cursor: pointer;
  transition: transform 0.15s ease;
}

.mobile-menu-close:active {
  transform: scale(0.95);
}

.mobile-menu-close-icon {
  width: 24px;
  height: 24px;
  display: block;
}

/* Menu Items Container */
.mobile-menu-items {
  display: flex;
  flex-direction: column;
  padding: var(--space-sm) 0;
}

/* Individual Menu Item */
.mobile-menu-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  min-height: 56px;
  padding: var(--space-sm) var(--space-md);
  background: transparent;
  border: none;
  border-left: 3px solid transparent;
  font-family: var(--font-ui);
  font-size: 1rem;
  font-weight: 500;
  color: var(--warm-grey-dark);
  text-decoration: none;
  text-align: left;
  cursor: pointer;
  transition: all 0.15s ease;
}

.mobile-menu-item:hover {
  background-color: var(--parchment-dark);
}

.mobile-menu-item:active {
  transform: scale(0.98);
}

/* Current session item with accent color */
.mobile-menu-item--current-session {
  border-left-color: var(--campaign-accent-color, var(--warm-grey));
  font-weight: 600;
}

/* Menu Item Icon */
.mobile-menu-item-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  display: block;
}
