/* assets/css/menu-mobile.css */
/* --- Tokens de marca (ajusta si cambian tus colores) --- */
:root {
  --proaseo-purple: #4B0082;
  --proaseo-orange: #FF7F50;
  --proaseo-cream: #FBF4EC;
  --text-strong: #1f1142;
  --text-soft: rgba(31,17,66,.75);
  --shadow-xl: 0 20px 40px rgba(31,17,66,.18);
}

/* --- Navbar: ligero realce de fondo y sombra --- */
#navbar {
  background:
    linear-gradient(92deg, rgba(75,0,130,.06) 0%, rgba(255,127,80,.06) 100%),
    #fff;
  box-shadow: 0 2px 10px rgba(31,17,66,.06);
}

/* --- Botón hamburguesa: estilo “pill” y feedback --- */
#menu-btn {
  display: grid;
  place-items: center;
  width: 42px; height: 42px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(75,0,130,.07), rgba(255,127,80,.07));
  box-shadow: inset 0 0 0 1px rgba(31,17,66,.06);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
#menu-btn:active { transform: scale(.96); }
#menu-btn:focus-visible {
  outline: 3px solid rgba(75,0,130,.25);
  outline-offset: 2px;
}

/* Si usas 3 spans para el icono, anima a “X” (opcional) */
#menu-btn .bar {
  width: 18px; height: 2px; border-radius: 2px;
  background: linear-gradient(90deg, var(--proaseo-purple), var(--proaseo-orange));
  display: block; margin: 2.5px 0; transition: transform .26s ease, opacity .2s ease;
}
#menu-btn.is-open .bar:nth-child(1){ transform: translateY(4.5px) rotate(45deg); }
#menu-btn.is-open .bar:nth-child(2){ opacity: 0; }
#menu-btn.is-open .bar:nth-child(3){ transform: translateY(-4.5px) rotate(-45deg); }

/* --- Panel móvil (overlay + hoja) --- */
#mobile-menu {
  position: fixed; inset: 0;
  background: radial-gradient(1200px 600px at 85% -10%,
              rgba(255,127,80,.12), transparent 60%),
              radial-gradient(900px 500px at -10% -20%,
              rgba(75,0,130,.12), transparent 60%);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  padding-top: max(80px, env(safe-area-inset-top)); /* despeje bajo navbar */
  opacity: 0; transform: translateY(-8px); pointer-events: none;
  transition: opacity .28s ease, transform .28s ease;
  z-index: 4999;
}
#mobile-menu.open { opacity: 1; transform: translateY(0); pointer-events: auto; }

/* Hoja central con vidrio esmerilado */
#mobile-menu .sheet {
  max-width: 960px; margin: 0 auto;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(31,17,66,.09);
  border-radius: 20px 20px 28px 28px;
  box-shadow: var(--shadow-xl);
  padding: 18px clamp(16px, 4vw, 36px) clamp(18px, 6vh, 56px);
}

/* Lista de enlaces */
#mobile-menu ul {
  list-style: none; margin: 0; padding: 6px 0;
  display: grid; gap: 6px;
}
#mobile-menu li a {
  display: grid; align-items: center;
  grid-template-columns: 10px auto;
  gap: 14px;
  padding: 14px 10px;
  border-radius: 12px;
  color: var(--text-strong); font-weight: 600; letter-spacing: .1px;
  text-decoration: none;
  transition: background .18s ease, color .18s ease, transform .18s ease;
}
#mobile-menu li a::before {
  content: ""; align-self: stretch;
  border-radius: 99px;
  background: linear-gradient(180deg, var(--proaseo-purple), var(--proaseo-orange));
  opacity: .0; transform: scaleY(.3);
  transition: opacity .18s ease, transform .18s ease;
}
#mobile-menu li a:hover {
  background: linear-gradient(0deg, rgba(75,0,130,.06), rgba(255,127,80,.06));
  transform: translateX(2px);
}
#mobile-menu li a:hover::before { opacity: .9; transform: scaleY(1); }

#mobile-menu li a:focus-visible {
  outline: 3px solid rgba(75,0,130,.25);
  outline-offset: 2px;
}

/* Subtexto (si lo agregas debajo del link) */
#mobile-menu .sub {
  color: var(--text-soft); font-weight: 500; margin-top: -6px; margin-left: 24px;
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  #menu-btn, #mobile-menu { transition: none !important; }
  #mobile-menu li a, #menu-btn .bar { transition: none !important; }
}

/* Modo oscuro opcional (si alguna vez lo activas) */
@media (prefers-color-scheme: dark) {
  #mobile-menu .sheet {
    background: rgba(24,22,33,.72);
    border-color: rgba(255,255,255,.08);
  }
  #mobile-menu li a { color: #fff; }
  #navbar { background: linear-gradient(92deg, rgba(75,0,130,.22), rgba(255,127,80,.18)); }
}

/* --- Visibilidad por breakpoint --- */
#menu-btn { display: none; }               /* por defecto oculto */
#navbar .nav-desktop { display: none; }    /* por defecto oculto */

/* Mobile / Tablet (ancho < 1024px): muestra hamburguesa, oculta menú desktop */
@media (max-width: 1023px) {
  #menu-btn { display: grid; }             /* tu botón redondo sigue igual */
  #navbar .nav-desktop { display: none; }
}

/* Desktop (ancho >= 1024px): oculta hamburguesa y cualquier overlay móvil */
@media (min-width: 1024px) {
  #menu-btn { display: none !important; }
  #mobile-menu {
    display: none !important;
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translateY(-8px) !important;
  }
  body.menu-open { overflow: auto !important; }
  #navbar .nav-desktop { display: flex; }
}
