/**
 * Navegación móvil compartida: apilado sobre FAB, scroll del panel, drawer.
 * Carga este archivo después del <style> principal de cada página.
 */

/*
 * Logo de marca (nexel-logo.svg). Escala al estilo de sitios B2B/SaaS:
 * wordmark ~24–30px en barra de 64px (enlaces ~14px), pie ligeramente mayor.
 */
.nav-logo img {
  height: clamp(24px, 2.85vw, 30px);
  width: auto;
  max-width: min(200px, 48vw);
  max-height: 30px;
  display: block;
  flex-shrink: 0;
  object-fit: contain;
  object-position: left center;
}

footer .footer-brand img {
  height: clamp(28px, 3.25vw, 34px);
  width: auto;
  max-width: min(220px, 72vw);
  max-height: 34px;
  display: block;
  object-fit: contain;
  object-position: left center;
}

/* Sin touch-action global: evita que iOS deje de hacer scroll al panel */
body.nexel-nav-open {
  overflow: hidden;
}

/* Encima del widget Crisp (~998) y tweaks (999), debajo del modal contacto (10000) */
body.nexel-nav-open #navbar {
  z-index: 2000;
}

body.nexel-nav-open #tweaks-panel {
  visibility: hidden;
  pointer-events: none;
}

@media (max-width: 900px) {
  /*
   * Barra: con .nav-menu fijo el flujo solo deja logo + hamburguesa;
   * sin space-between el icono queda pegado al logo.
   * backdrop-filter en el <nav> hace que el hijo fixed use el nav (64px) como
   * containing block: el cajón queda aplastado. El blur va al ::before.
   */
  nav#navbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    max-width: 100%;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  nav#navbar.scrolled {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  nav#navbar::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    -webkit-backdrop-filter: blur(24px) saturate(1.6);
    backdrop-filter: blur(24px) saturate(1.6);
  }
  html[data-page="home"] nav#navbar::before {
    -webkit-backdrop-filter: blur(20px) saturate(1.4);
    backdrop-filter: blur(20px) saturate(1.4);
  }
  html[data-page="home"] nav#navbar.scrolled::before {
    -webkit-backdrop-filter: blur(24px) saturate(1.6);
    backdrop-filter: blur(24px) saturate(1.6);
  }
  nav#navbar > .nav-logo,
  nav#navbar > .nav-burger {
    position: relative;
    z-index: 1;
  }
  nav#navbar > .nav-menu {
    z-index: 1;
  }
  .nav-logo,
  .nav-burger {
    flex-shrink: 0;
  }
  .nav-burger {
    display: flex;
  }
  .nav-menu {
    position: fixed;
    inset: 64px 0 0 0;
    z-index: 1;
    margin: 0;
    padding: 24px max(20px, env(safe-area-inset-left)) max(32px, env(safe-area-inset-bottom)) max(20px, env(safe-area-inset-right));
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    background: rgba(6, 7, 16, 0.98);
    backdrop-filter: blur(20px) saturate(1.4);
    -webkit-backdrop-filter: blur(20px) saturate(1.4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 24px 48px rgba(0, 0, 0, 0.45);
    transform: translateX(100%);
    visibility: hidden;
    pointer-events: none;
    transition: transform 0.3s ease, visibility 0.3s;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
  }
  nav.nav-open .nav-menu {
    transform: translateX(0);
    visibility: visible;
    pointer-events: auto;
  }
  .nav-links {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
  }
  .nav-links a {
    padding: 16px 0;
    font-size: 16px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  }
  .nav-right {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    margin-top: 20px;
    padding-top: 8px;
  }
  .nav-lang {
    align-self: flex-start;
  }
  .btn-demo {
    width: 100%;
    text-align: center;
    padding: 12px 20px;
  }
}

@media (prefers-reduced-motion: reduce) {
  @media (max-width: 900px) {
    .nav-menu {
      transition: none;
    }
  }
}
