/* Mobile drawer + hamburger toggle. */

.mobile-nav-toggle {
  color: var(--c-cream);
  display: none;
}
@media (max-width: 768px) {
  .mobile-nav-toggle { display: inline-flex; }
}

/* Drawer */
.mobile-drawer {
  position: fixed;
  inset: 0;
  z-index: 100;
  visibility: hidden;
  pointer-events: none;
}
.mobile-drawer[aria-hidden="false"] {
  visibility: visible;
  pointer-events: auto;
}

.mobile-drawer__scrim {
  position: absolute;
  inset: 0;
  background: rgba(28, 28, 28, .55);
  border: 0;
  cursor: pointer;
  opacity: 0;
  transition: opacity 250ms ease;
}
.mobile-drawer[aria-hidden="false"] .mobile-drawer__scrim { opacity: 1; }

.mobile-drawer__panel {
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: min(360px, 88vw);
  background: var(--c-cream);
  color: var(--c-charcoal);
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 280ms ease;
  overflow-y: auto;
}
.mobile-drawer[aria-hidden="false"] .mobile-drawer__panel { transform: translateX(0); }

.mobile-drawer__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--c-rule);
}
.mobile-drawer__close { color: var(--c-navy); }

.mobile-drawer__body {
  padding: var(--sp-5);
  flex: 1;
}

.mobile-nav__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.mobile-nav__list li { border-bottom: 1px solid var(--c-rule); }
.mobile-nav__list a {
  display: block;
  padding: var(--sp-4) 0;
  font-family: var(--ff-display);
  font-size: var(--fs-h4);
  font-weight: 600;
  letter-spacing: var(--ls-display);
  color: var(--c-navy);
  text-decoration: none;
}
.mobile-nav__list a:hover, .mobile-nav__list a:focus-visible { color: var(--c-red); }
.mobile-nav__list ul {
  list-style: none;
  padding: 0 0 var(--sp-3) var(--sp-4);
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.mobile-nav__list ul a {
  font-family: var(--ff-ui);
  font-size: var(--fs-small);
  text-transform: uppercase;
  letter-spacing: var(--ls-ui);
  padding: var(--sp-2) 0;
}

.mobile-drawer__foot {
  padding: var(--sp-5);
  border-top: 1px solid var(--c-rule);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

/* Lock body scroll while drawer open (set via JS too as fallback). */
body.has-drawer-open { overflow: hidden; }
