.navbar {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  min-height: var(--navbar-height);
  padding: var(--navbar-padding-y) var(--navbar-padding-x);
  background-color: var(--navbar-bg);
  box-shadow: var(--shadow-md);
  z-index: 9999;
}

.navbar-brand {
  display: flex;
  align-items: center;
  z-index: 10;
}

.navbar-brand a {
  display: flex;
  align-items: center;
  text-decoration: none;
}

.navbar-brand img {
  width: 200px;
  height: auto;
}

.navbar-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-sm);
  color: var(--color-body);
  z-index: 10;
  transition: color 0.2s ease;
}

.navbar-toggle:hover {
  color: var(--color-primary-hover);
}

.navbar-toggle svg {
  width: 24px;
  height: 24px;
  display: block;
  transition: transform 0.3s ease;
}

.navbar-toggle.is-active svg {
  transform: rotate(90deg);
}

.navbar-menu {
  display: flex;
  align-items: center;
}

.navbar-menu ul {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  list-style: none;
  margin: 0;
  padding: 0;
}

.navbar-menu li {
  display: flex;
  align-items: center;
}

.navbar-menu a {
  color: var(--color-body);
  font-size: var(--font-size-base);
  font-weight: var(--font-normal);
  text-decoration: none;
  padding: var(--space-sm) var(--space-md);
  position: relative;
  transition: color 0.3s ease;
}

.navbar-menu a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 2px;
  background-color: var(--color-primary-hover);
  transition: width 0.3s ease;
}

.navbar-menu a:hover {
  color: var(--color-primary-hover);
}

.navbar-menu a:hover::after {
  width: 100%;
}

/* CTA buttons: mismo tamaño, alineación y transiciones */
.navbar-menu li.nav-cta > a,
.navbar-menu li.nav-cta-outline > a,
.navbar-menu li.nav-cta-pago > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  min-height: 2.5rem;
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-md);
  font-weight: var(--font-medium);
  box-shadow: none;
  transform: translateY(0);
  transition:
    background-color 0.2s ease,
    color 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    transform 0.2s ease;
}

.navbar-menu li.nav-cta > a::after,
.navbar-menu li.nav-cta-outline > a::after,
.navbar-menu li.nav-cta-pago > a::after {
  display: none;
}

.navbar-menu li.nav-cta > a {
  background-color: var(--color-primary);
  color: #ffffff;
}

.navbar-menu li.nav-cta > a:hover {
  background-color: var(--color-primary-hover);
  color: #ffffff;
  box-shadow: 0 4px 14px rgba(37, 99, 235, 0.35);
  transform: translateY(-1px);
}

.navbar-menu li.nav-cta > a:active {
  transform: translateY(0);
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.28);
}

.navbar-menu li.nav-cta-outline > a {
  border: 1.5px solid var(--color-primary);
  color: var(--color-primary);
  background-color: transparent;
}

.navbar-menu li.nav-cta-outline > a:hover {
  background-color: var(--color-primary);
  color: #ffffff;
  border-color: var(--color-primary);
  box-shadow: 0 4px 14px rgba(37, 99, 235, 0.3);
  transform: translateY(-1px);
}

.navbar-menu li.nav-cta-outline > a:active {
  transform: translateY(0);
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.22);
}

/* Fondo = footer (.section-dark); mismos efectos que Matricúlate */
.navbar-menu li.nav-cta-pago > a {
  background-color: var(--color-heading);
  color: #ffffff;
}

.navbar-menu li.nav-cta-pago > a:hover {
  background-color: var(--color-heading-hover);
  color: #ffffff;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.45);
  transform: translateY(-1px);
}

.navbar-menu li.nav-cta-pago > a:active {
  transform: translateY(0);
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.35);
}

.navbar-menu li.nav-cta > a:focus-visible,
.navbar-menu li.nav-cta-outline > a:focus-visible,
.navbar-menu li.nav-cta-pago > a:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* Active nav item styles */
.navbar-menu li.current-menu-item > a,
.navbar-menu li.current_page_item > a,
.navbar-menu li.active > a,
.navbar-menu a.active {
  font-weight: var(--font-medium);
}

.navbar-menu li.current-menu-item > a::after,
.navbar-menu li.current_page_item > a::after,
.navbar-menu li.active > a::after,
.navbar-menu a.active::after {
  width: 100%;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .navbar {
    padding: var(--navbar-padding-y) var(--space-md);
    flex-wrap: wrap;
  }

  .navbar-brand img {
    width: 150px;
  }

  .navbar-toggle {
    display: block;
  }

  .navbar-menu {
    display: none;
    width: 100%;
    order: 3;
    margin-top: var(--space-md);
    padding: var(--space-lg) 0;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
    opacity: 0;
    transform: translateY(-10px);
    transition: opacity 0.3s ease, transform 0.3s ease;
  }

  .navbar-menu.is-active {
    display: flex;
    opacity: 1;
    transform: translateY(0);
  }

  .navbar-menu ul {
    flex-direction: column;
    width: 100%;
    gap: var(--space-sm);
    align-items: center;
    padding: 0 var(--space-md);
  }

  .navbar-menu li {
    width: 100%;
    justify-content: center;
    opacity: 0;
    transform: translateY(-5px);
    transition: opacity 0.3s ease, transform 0.3s ease;
  }

  .navbar-menu.is-active li {
    opacity: 1;
    transform: translateY(0);
  }

  .navbar-menu.is-active li:nth-child(1) { transition-delay: 0.05s; }
  .navbar-menu.is-active li:nth-child(2) { transition-delay: 0.1s; }
  .navbar-menu.is-active li:nth-child(3) { transition-delay: 0.15s; }
  .navbar-menu.is-active li:nth-child(4) { transition-delay: 0.2s; }
  .navbar-menu.is-active li:nth-child(5) { transition-delay: 0.25s; }
  .navbar-menu.is-active li:nth-child(6) { transition-delay: 0.3s; }
  .navbar-menu.is-active li:nth-child(7) { transition-delay: 0.35s; }

  .navbar-menu li:not(.nav-cta):not(.nav-cta-outline):not(.nav-cta-pago) > a {
    display: inline-block;
    width: auto;
    text-align: center;
    padding: var(--space-sm) var(--space-md);
  }

  .navbar-menu li:not(.nav-cta):not(.nav-cta-outline):not(.nav-cta-pago) > a::after {
    height: 1px;
    bottom: 2px;
    max-width: 140px;
  }

  .navbar-menu li.nav-cta > a,
  .navbar-menu li.nav-cta-outline > a,
  .navbar-menu li.nav-cta-pago > a {
    display: block;
    width: min(100%, 20rem);
    margin: 0 auto;
    text-align: center;
    padding: var(--space-sm) var(--space-lg);
  }

  .navbar-menu a::after {
    bottom: var(--space-sm);
  }

  .navbar-menu li:not(.nav-cta):not(.nav-cta-outline):not(.nav-cta-pago) > a:hover {
    background-color: transparent;
  }
}