/* ============================================================
   mobile-menu.css — Estilos consolidados del menú móvil

   Consolidación de includes/mobile-menu-fix.php y mobile-menu-styles.php.
   Antes: ~3 KB de CSS inline en cada pageview (12 páginas).
   Ahora: un solo archivo cacheable con Cache-Control: immutable 1 año.

   Nota: los !important se conservan para garantizar que el drawer
   funcione aunque CSS de terceros lo intente sobrescribir.
============================================================ */

/* ── Drawer del menú móvil ────────────────────────────────────── */
.mob-nav {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: min(280px, 85vw) !important;
  background: #fff !important;
  z-index: 999999 !important;
  box-shadow: -2px 0 20px rgba(0, 0, 0, 0.12) !important;
  padding: 12px 0 32px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  transform: translateX(100%) !important;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  display: block !important;
  will-change: transform !important;
  min-height: 100vh !important;
}

.mob-nav:not([hidden]) {
  display: block !important;
  transform: translateX(0) !important;
  pointer-events: auto !important;
}

.mob-nav[hidden] {
  display: none !important;
  transform: translateX(100%) !important;
  pointer-events: none !important;
}

/* ── Overlay de fondo ─────────────────────────────────────────── */
.mob-nav-overlay {
  display: none !important;
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0, 0, 0, 0.3) !important;
  z-index: 999998 !important;
  opacity: 0 !important;
  transition: opacity 0.3s !important;
  cursor: pointer !important;
  pointer-events: none !important;
}

.mob-nav-overlay.active {
  display: block !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}

/* ── Contenedores padres: evitar clipping del drawer ─────────── */
html,
body {
  overflow-x: visible !important;
  overflow: visible !important;
}

header,
main,
footer {
  overflow: visible !important;
}

header {
  z-index: 1000 !important;
}

/* ── Botón hamburguesa ────────────────────────────────────────── */
.mobile-menu-btn {
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  padding: 3px !important;
  border-radius: 4px !important;
  color: #1a0e35 !important;
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background-color 0.2s !important;
}

.mobile-menu-btn:hover {
  background: rgba(124, 58, 237, 0.1) !important;
}

.mobile-menu-btn svg {
  width: 20px !important;
  height: 20px !important;
  stroke: currentColor !important;
  stroke-width: 2.5 !important;
  fill: none !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

/* ── Breakpoints ──────────────────────────────────────────────── */
@media (max-width: 1279px) {
  .desktop-nav { display: none !important; }
  .mobile-menu-btn { display: flex !important; }
}

@media (min-width: 1280px) {
  .mobile-menu-btn { display: none !important; }
  .mob-nav { display: none !important; }
  .mob-nav-overlay { display: none !important; }
}
