/* ===========================
   BOTÓN SOLICITAR DEMO
   =========================== */
#navmenu .btn-demo {
  background-color: #ef382b !important;   /* siempre rojo */
  color: #fff !important;
  font-weight: 600;
  font-size: 14px;
  padding: 10px 20px;
  border-radius: 999px;                   /* estilo píldora */
  text-decoration: none !important;
  transition: background-color 0.25s ease, box-shadow 0.25s ease;
  border: none !important;
  line-height: 1;
  white-space: nowrap;
  box-shadow: none !important;
  cursor: pointer;
  position: relative;
  z-index: 10001;                         /* por encima del fondo del nav */
}

/* Forzar a que nunca herede el background gris del header/nav */
#navmenu .btn-demo,
body.mobile-nav-active #navmenu .btn-demo,
#navmenu.navmenu-active .btn-demo {
  background-color: #ef382b !important;   /* rojo puro */
}

/* Hover */
#navmenu .btn-demo:hover {
  background-color: #d32f2f !important;
  box-shadow: 0 2px 10px rgba(0,0,0,.12);
}

/* Active / click */
#navmenu .btn-demo:active {
  background-color: #b71c1c !important;
  box-shadow: 0 1px 6px rgba(0,0,0,.12);
  transform: none !important;
}

/* ===========================
   NAV DESKTOP (>=992px)
   =========================== */
@media (min-width: 992px) {
  #navmenu {
    display: flex;
    align-items: center;
    gap: 16px;
    background: transparent !important;   /* header limpio */
  }

  #navmenu > ul {
    display: flex;
    align-items: center;
    flex: 1;
    margin: 0;
    padding: 0;
    list-style: none;
  }
}

/* ===========================
   NAV MOBILE (<992px)
   =========================== */
@media (max-width: 991px) {
  :root { --header-h: 70px; }

  #navmenu {
    display: flex;
    align-items: center;
    gap: 10px;
    position: relative;
    z-index: 1000;
    background: transparent !important;   /* evita bloque gris */
  }

  #navmenu > ul {
    display: none;
    flex: 1 1 auto;
    margin: 0;
    padding: 0;
    list-style: none;
  }

  #navmenu .btn-demo {
    order: 1;
    align-self: center;
    margin-left: auto;
    margin-right: 8px;
  }

  #navmenu .mobile-nav-toggle {
    order: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    line-height: 1;
    height: 36px;
    width: 36px;
  }

  body.mobile-nav-active #navmenu > ul,
  #navmenu.navmenu-active > ul {
    display: block;
    position: fixed;
    top: var(--header-h);
    left: 0;
    right: 0;
    bottom: 0;
    background: #fff;
    z-index: 9999;
    overflow-y: auto;
    padding: 16px 20px 24px;
    box-shadow: 0 6px 18px rgba(0,0,0,.12);
  }

  body.mobile-nav-active #navmenu::before,
  #navmenu.navmenu-active::before {
    content: "";
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.35);
    z-index: 9990;
  }

  body.mobile-nav-active,
  #navmenu.navmenu-active {
    overflow: hidden;
  }

  body.mobile-nav-active #navmenu .btn-demo,
  #navmenu.navmenu-active .btn-demo {
    display: block;
    margin: 16px auto 0;
    text-align: center;
    max-width: 220px;
  }
}

/* ===========================
   Ajuste CTA en mobile abierto
   =========================== */
@media (max-width: 991px) {
  /* Cuando el menú está abierto, corre el botón un poco a la izquierda */
  body.mobile-nav-active #navmenu .btn-demo,
  #navmenu.navmenu-active .btn-demo {
    margin-right: 48px;   /* empuja el botón a la izquierda */
  }
}

