/*
 * Eduval — Header / Navbar (desktop + mobile + sticky)
 */

nav.navbar.validnavs.navbar-box {
  position: relative;
  border-bottom: 0;
}


nav.navbar.validnavs .container.nav-box {
  width: 100% !important;
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
  box-sizing: border-box !important;
}

@media (max-width: 1229px) {
  nav.navbar.validnavs .container.nav-box {
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
}

body.eduval-wc-compact-header nav.navbar.validnavs.navbar-box,
body.eduval-wc-compact-header nav.navbar.validnavs.navbar-box.sticked {
  background: var(--white) !important;
  max-width: none !important;
  border-radius: 0 !important;
  box-shadow: 0px 2px 6px 0px rgba(38, 30, 80, 0.15) !important;
}

body.eduval-wc-compact-header nav.navbar.validnavs.navbar-box::after {
  background: color-mix(in srgb, var(--bg-blue) 10%, transparent);
}

@media (min-width: 992px) {
  body.eduval-wc-compact-header
    nav.navbar.validnavs.navbar-box:not(.sticked)
    .container.nav-box,
  body.eduval-wc-compact-header
    nav.navbar.validnavs.navbar-box.sticked
    .container.nav-box {
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }
}

nav.navbar.validnavs.navbar-box::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: rgba(255, 255, 255, 0.1);
  pointer-events: none;
}

.navbar-header a.logo img {
  max-height: 50px;
  width: auto;
}

.logo-text a.logo {
  color: var(--white);
  text-decoration: none;
  font-size: 24px;
  font-weight: 700;
}

.navbar-collapse ul.navbar-nav > li > a {
  color: #261e50 !important;
  font-weight: 700 !important;
  font-size: 1.4em !important;
  text-decoration: none !important;
  transition: all 0.3s ease;
}

.navbar-collapse ul.navbar-nav > li > a:hover {
  color: #e58431 !important;
  text-decoration: none !important;
}

.navbar-collapse ul.navbar-nav > li > a:active,
.navbar-collapse ul.navbar-nav > li > a:focus-visible {
  color: #e58431 !important;
  text-decoration: none !important;
}

.navbar-collapse ul.navbar-nav > li > a:focus:not(:focus-visible) {
  color: #261e50 !important;
  text-decoration: none !important;
  outline: none;
}

.navbar-collapse ul.navbar-nav > li.current-menu-item > a,
.navbar-collapse ul.navbar-nav > li.current_page_item > a,
.navbar-collapse ul.navbar-nav > li.current-menu-ancestor > a,
.navbar-collapse ul.navbar-nav > li.current_page_ancestor > a {
  color: #e58431 !important;
  text-decoration: none !important;
  border-bottom: 3px solid #e58431;
  padding-bottom: 4px;
}

/* CTA / Account buttons — só o <ul> principal (evita flex em linha no submenu da conta) */
.attr-right .attr-nav > ul {
  display: flex;
  align-items: center;
  gap: 12px;
  list-style: none;
  margin: 0;
  padding: 0;
}

nav.navbar.validnavs .attr-right .attr-nav li {
  margin: 0;
}

/* Só o link directo (convidado); evita estilizar entradas do submenu autenticado */
nav.navbar.validnavs .attr-right .attr-nav li.account-link:not(.eduval-account-dropdown) > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  width: 44px;
  height: 44px;
  padding: 0;
  box-sizing: border-box;
  border-radius: 999px;
  color: var(--bg-blue) !important;
  text-decoration: none;
  background: linear-gradient(
    180deg,
    #fff 0%,
    color-mix(in srgb, var(--bg-blue-secondary) 35%, #fff) 100%
  );
  border: 1px solid color-mix(in srgb, var(--bg-blue) 14%, #e2e8f0);
  box-shadow: 0 1px 2px rgba(38, 30, 80, 0.06);
  transition:
    color 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    transform 0.2s ease;
  margin-top: 0;
}

nav.navbar.validnavs
  .attr-right
  .attr-nav
  li.account-link:not(.eduval-account-dropdown)
  > a:hover,
nav.navbar.validnavs
  .attr-right
  .attr-nav
  li.account-link:not(.eduval-account-dropdown)
  > a:focus-visible {
  color: var(--eduval-header-btn-bg) !important;
  transform: translateY(-2px);
  outline: none !important;
}

nav.navbar.validnavs
  .attr-right
  .attr-nav
  li.account-link:not(.eduval-account-dropdown)
  > a:focus:not(:focus-visible),
nav.navbar.validnavs
  .attr-right
  .attr-nav
  li.account-link:not(.eduval-account-dropdown)
  > a:active {
  color: var(--eduval-header-btn-bg) !important;
  outline: none !important;
  box-shadow: none !important;
}

nav.navbar.validnavs
  .attr-right
  .attr-nav
  li.account-link:not(.eduval-account-dropdown)
  > a
  i {
  font-size: 1.375rem;
  line-height: 1;
}

nav.navbar.validnavs .attr-right .attr-nav li.account-link {
  display: flex;
  align-items: center;
}

/* Minha conta — dropdown (autenticado) */
nav.navbar.validnavs .attr-right .attr-nav li.account-link.eduval-account-dropdown {
  position: relative;
}

.eduval-account-dropdown__wrap {
  position: relative;
  display: flex;
  align-items: center;
}

/* Chip do utilizador: ícone + seta num só bloco visual */
.eduval-account-dropdown__trigger {
  display: inline-flex;
  align-items: center;
  gap: 0;
  border-radius: 999px;
}

.eduval-account-dropdown__trigger--chip {
  gap: 2px;
  padding: 3px 4px 3px 10px;
  min-height: 44px;
  box-sizing: border-box;
  background: linear-gradient(
    180deg,
    #fff 0%,
    color-mix(in srgb, var(--bg-blue-secondary) 40%, #fff) 100%
  );
  border: 1px solid color-mix(in srgb, var(--bg-blue) 16%, #e2e8f0);
  box-shadow:
    0 1px 2px rgba(38, 30, 80, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.eduval-account-dropdown__trigger--chip:hover {
  border-color: color-mix(in srgb, var(--bg-blue) 28%, #cbd5e1);
  box-shadow: 0 2px 8px rgba(38, 30, 80, 0.08);
}

nav.navbar.validnavs
  .attr-right
  .attr-nav
  li.account-link
  .eduval-account-dropdown__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px 0 0;
  color: var(--bg-blue) !important;
  text-decoration: none;
  transition: color 0.2s ease;
}

nav.navbar.validnavs
  .attr-right
  .attr-nav
  li.account-link
  .eduval-account-dropdown__icon:hover,
nav.navbar.validnavs
  .attr-right
  .attr-nav
  li.account-link
  .eduval-account-dropdown__icon:focus-visible {
  color: var(--eduval-header-btn-bg) !important;
  outline: none !important;
}

nav.navbar.validnavs
  .attr-right
  .attr-nav
  li.account-link
  .eduval-account-dropdown__icon
  i {
  font-size: 1.375rem;
  line-height: 1;
}

.eduval-account-dropdown__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0 8px 0 4px;
  min-width: 32px;
  min-height: 36px;
  border: 0;
  background: transparent;
  color: var(--bg-blue) !important;
  cursor: pointer;
  border-radius: 999px;
  transition:
    color 0.2s ease,
    background 0.2s ease;
  line-height: 1;
}

.eduval-account-dropdown__toggle i {
  font-size: 11px;
  opacity: 0.92;
  transition: transform 0.22s ease;
}

.eduval-account-dropdown__wrap:has(.eduval-account-dropdown__panel.is-open)
  .eduval-account-dropdown__toggle
  i {
  transform: rotate(180deg);
}

/* Chip “activo” quando o painel está aberto */
.eduval-account-dropdown__wrap:has(.eduval-account-dropdown__panel.is-open)
  .eduval-account-dropdown__trigger--chip {
  border-color: color-mix(in srgb, var(--bg-blue) 32%, #cbd5e1);
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--bg-blue) 10%, transparent),
    0 2px 10px rgba(38, 30, 80, 0.1);
}

.eduval-account-dropdown__toggle:hover,
.eduval-account-dropdown__toggle:focus-visible {
  color: var(--eduval-header-btn-bg) !important;
  background: color-mix(in srgb, var(--bg-blue) 10%, transparent);
  outline: none !important;
}

/* Painel: cartão compacto, cabeçalho de marca integrado */
.eduval-account-dropdown__panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: min(252px, calc(100vw - 24px));
  max-height: min(85vh, 520px);
  overflow-x: hidden;
  overflow-y: auto;
  padding: 0;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--bg-blue) 14%, #e2e8f0);
  border-radius: 14px;
  box-shadow:
    0 24px 48px -12px rgba(38, 30, 80, 0.2),
    0 12px 24px -8px rgba(38, 30, 80, 0.1),
    0 0 0 1px rgba(38, 30, 80, 0.04);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px) scale(0.98);
  transform-origin: top right;
  pointer-events: none;
  transition:
    opacity 0.2s ease,
    visibility 0.2s ease,
    transform 0.22s cubic-bezier(0.2, 0.8, 0.2, 1);
  z-index: 10060;
}

.eduval-account-dropdown__panel.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

@media (prefers-reduced-motion: reduce) {
  .eduval-account-dropdown__panel,
  .eduval-account-dropdown__panel.is-open {
    transform: none;
    transition: opacity 0.15s ease, visibility 0.15s ease;
  }
}

.eduval-account-dropdown__head {
  margin: 0;
  padding: 15px 16px 16px;
  background: linear-gradient(
    135deg,
    #261e50 0%,
    #352b62 48%,
    #2d2654 100%
  );
  border: none;
  box-shadow: inset 0 -1px 0 rgba(255, 255, 255, 0.07);
}

.eduval-account-dropdown__head-title {
  display: block;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.9);
  line-height: 1.25;
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.12);
}

/* Lista sempre em coluna (defesa contra .attr-nav ul { display:flex } em temas antigos) */
nav.navbar.validnavs .attr-right .attr-nav .eduval-account-dropdown__list,
.eduval-account-dropdown__list {
  list-style: none;
  margin: 0;
  padding: 10px 10px 14px;
  display: flex !important;
  flex-direction: column !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
  gap: 4px !important;
  width: 100% !important;
  box-sizing: border-box;
}

/* Garantir respiro no painel mesmo com regras genéricas sobre ul */
nav.navbar.validnavs.navbar-box
  .attr-right
  .attr-nav
  .eduval-account-dropdown__panel
  .eduval-account-dropdown__list {
  padding: 10px 10px 14px !important;
  gap: 4px !important;
}

/* Itens da lista: ganhar a .attr-nav li { display:inline-block } (validnavs.css) */
nav.navbar.validnavs.navbar-box
  .attr-right
  .attr-nav
  .eduval-account-dropdown__panel
  .eduval-account-dropdown__list
  > li.eduval-account-dropdown__item {
  margin: 0;
  width: 100%;
  display: block !important;
}

.eduval-account-dropdown__item {
  margin: 0;
  width: 100%;
  display: block;
}

/*
 * Links do painel: validnavs aplica .navbar .attr-right .attr-nav li a { padding:30px 0 }
 * e .validnavs a:hover { background:transparent !important } — sem especificidade maior,
 * o dropdown parece “igual” ao resto da barra.
 */
nav.navbar.validnavs.navbar-box
  .attr-right
  .attr-nav
  .eduval-account-dropdown__panel
  a.eduval-account-dropdown__link {
  display: block !important;
  width: 100%;
  box-sizing: border-box;
  margin: 0;
  padding: 11px 14px 11px 12px !important;
  border-radius: 7px;
  border-left: 3px solid transparent;
  font-weight: 500 !important;
  font-size: 0.8125rem;
  color: #1e293b;
  text-decoration: none !important;
  line-height: 1.4 !important;
  letter-spacing: -0.01em;
  text-transform: none !important;
  background: transparent !important;
  transition:
    background 0.14s ease,
    color 0.14s ease,
    border-color 0.14s ease,
    padding-left 0.14s ease;
}

nav.navbar.validnavs.navbar-box
  .attr-right
  .attr-nav
  .eduval-account-dropdown__panel
  a.eduval-account-dropdown__link:hover {
  padding-left: 17px !important;
  background: color-mix(in srgb, var(--bg-blue) 6%, #f8fafc) !important;
  color: var(--bg-blue);
  border-left-color: var(--bg-blue, #261e50);
}

nav.navbar.validnavs.navbar-box
  .attr-right
  .attr-nav
  .eduval-account-dropdown__panel
  a.eduval-account-dropdown__link:focus-visible {
  padding-left: 17px !important;
  background: color-mix(in srgb, var(--bg-blue) 6%, #f8fafc) !important;
  color: var(--bg-blue);
  border-left-color: var(--bg-blue, #261e50);
  outline: 2px solid color-mix(in srgb, var(--bg-blue) 28%, transparent);
  outline-offset: 1px;
}

.eduval-account-dropdown__item--logout {
  margin: 4px 4px 0;
  padding: 10px 0 2px;
  border-top: 1px solid #eef2f6;
}

nav.navbar.validnavs.navbar-box
  .attr-right
  .attr-nav
  .eduval-account-dropdown__panel
  .eduval-account-dropdown__item--logout
  a.eduval-account-dropdown__link {
  color: #c2410c;
  font-weight: 600 !important;
}

nav.navbar.validnavs.navbar-box
  .attr-right
  .attr-nav
  .eduval-account-dropdown__panel
  .eduval-account-dropdown__item--logout
  a.eduval-account-dropdown__link:hover,
nav.navbar.validnavs.navbar-box
  .attr-right
  .attr-nav
  .eduval-account-dropdown__panel
  .eduval-account-dropdown__item--logout
  a.eduval-account-dropdown__link:focus-visible {
  background: color-mix(in srgb, var(--bg-blue) 6%, #f8fafc) !important;
  color: #9a3412;
  border-left-color: var(--bg-blue, #261e50);
}

nav.navbar.validnavs .attr-right .attr-nav li.admin-link {
  display: flex;
  align-items: center;
}

nav.navbar.validnavs .attr-right .attr-nav li.admin-link a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: auto;
  min-width: 0;
  color: var(--bg-blue) !important;
  text-decoration: none;
  transition: all 0.3s ease;
  margin-top: 0;
  padding: 0 2px;
  opacity: 0.65;
}

nav.navbar.validnavs .attr-right .attr-nav li.admin-link a:hover,
nav.navbar.validnavs .attr-right .attr-nav li.admin-link a:focus-visible {
  color: var(--eduval-header-btn-bg) !important;
  transform: translateY(-2px);
  opacity: 1;
  outline: none !important;
}

nav.navbar.validnavs .attr-right .attr-nav li.admin-link a i {
  font-size: 17px;
  line-height: 1;
}

nav.navbar.validnavs .attr-right .attr-nav li.button a {
  display: inline-block;
  padding: 12px 30px !important;
  background: var(--eduval-header-btn-bg) !important;
  color: var(--eduval-header-btn-text) !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  text-transform: uppercase;
  border-radius: 5px !important;
  border: solid var(--eduval-header-btn-border) !important;
  border-width: var(--eduval-header-btn-border-width) !important;
  border-style: solid !important;
  text-decoration: none;
  transition: all 0.3s ease;
  outline: none !important;
}

nav.navbar.validnavs .attr-right .attr-nav li.button a:hover {
  background: var(--eduval-header-btn-hover-bg) !important;
  color: var(--eduval-header-btn-hover-text) !important;
  border-color: var(--eduval-header-btn-hover-border) !important;
  border-width: var(--eduval-header-btn-hover-border-width) !important;
  transform: translateY(-2px);
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15);
}

nav.navbar.validnavs .attr-right .attr-nav li.button a::after {
  background-color: var(--eduval-header-btn-hover-bg) !important;
}

nav.navbar.validnavs .attr-right .attr-nav li.button a:active,
nav.navbar.validnavs .attr-right .attr-nav li.button a:focus-visible {
  background: var(--eduval-header-btn-active-bg) !important;
  color: var(--eduval-header-btn-active-text) !important;
  border-color: var(--eduval-header-btn-active-border) !important;
  border-width: var(--eduval-header-btn-active-border-width) !important;
  outline: none !important;
  box-shadow: none !important;
}

nav.navbar.validnavs
  .attr-right
  .attr-nav
  li.button
  a:focus:not(:focus-visible) {
  background: var(--eduval-header-btn-bg) !important;
  color: var(--eduval-header-btn-text) !important;
  border-color: var(--eduval-header-btn-border) !important;
  border-width: var(--eduval-header-btn-border-width) !important;
  outline: none;
  box-shadow: none !important;
}

/* Tablet: reduce menu font-size + CTA */
@media (min-width: 992px) and (max-width: 1199px) {
  .navbar-collapse ul.navbar-nav > li > a {
    font-size: 1em !important;
  }

  nav.navbar.validnavs .attr-right .attr-nav > ul {
    gap: 8px;
  }

  nav.navbar.validnavs
    .attr-right
    .attr-nav
    li.account-link:not(.eduval-account-dropdown)
    > a {
    width: 42px;
    height: 42px;
    min-width: 42px;
    min-height: 42px;
  }

  nav.navbar.validnavs .attr-right .attr-nav li.admin-link a i {
    font-size: 15px;
  }

  nav.navbar.validnavs .attr-right .attr-nav li.button a {
    padding: 10px 18px !important;
    font-size: 12px !important;
  }
}

/* Desktop: card visual lives on the nav itself (wider than content) */
@media (min-width: 992px) {
  nav.navbar.validnavs.navbar-box:not(.sticked) {
    max-width: 1320px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    background: linear-gradient(0deg, var(--white) 0%, #ecf0f3 100%) !important;
    border-radius: 10px !important;
    box-shadow: 0px 0 67px 0 rgb(109 117 143 / 13%) !important;
  }

  nav.navbar.validnavs.navbar-box.sticked {
    max-width: none !important;
    background: rgba(255, 255, 255, 0.85) !important;
    border-radius: 0 !important;
    box-shadow: 0px 1px 3px 0px rgba(18, 20, 32, 0.1) !important;
  }

  nav.navbar.validnavs.navbar-box:not(.sticked) .container.nav-box {
    box-sizing: border-box;
    background: transparent !important;
    box-shadow: none !important;
    border-radius: 0 !important;
  }

  nav.navbar.validnavs.navbar-box.sticked .container.nav-box {
    border: 0;
    border-radius: 0;
    background: transparent !important;
    box-shadow: none !important;
  }

  nav.navbar.validnavs .container.nav-box {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
  }

  nav.navbar.validnavs ul.nav > li > a {
    font-size: 1.15rem !important;
  }

  .logged-in nav.navbar.validnavs.navbar-box {
    top: 30px !important;
  }

  .navbar-header {
    flex: 0 0 auto;
    float: none !important;
    padding-right: 0 !important;
    position: static !important;
    width: auto !important;
  }

  .navbar-header .logo {
    position: static !important;
  }

  .navbar-collapse {
    flex: 1 1 auto;
    float: none !important;
    display: flex !important;
    justify-content: center !important;
  }

  .navbar-collapse.collapse {
    display: flex !important;
  }

  .navbar-collapse .desktop-menu-wrapper {
    display: flex !important;
    flex: 1 1 auto;
    justify-content: center;
  }

  .navbar-collapse .mobile-menu-wrapper {
    display: none !important;
  }

  .attr-right {
    flex: 0 0 auto;
    float: none !important;
    margin-left: 20px !important;
  }
}

/* Desktop: hide toggle buttons */
@media (min-width: 992px) {
  nav.navbar.validnavs .navbar-toggle,
  nav.navbar.validnavs .navbar-header .navbar-toggle-open,
  nav.navbar.validnavs .navbar-collapse .navbar-toggle-close {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
    position: absolute !important;
    pointer-events: none !important;
  }

  nav.navbar.validnavs .navbar-header {
    padding-right: 0 !important;
    position: static !important;
  }
}

/* Mobile Menu */
@media (max-width: 991px) {
  nav.navbar.validnavs {
    background: rgba(255, 255, 255, 0.96) !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06) !important;
  }

  nav.navbar.validnavs.navbar-sticky.sticked,
  nav.navbar.validnavs.navbar-box.navbar-sticky.sticked {
    position: fixed !important;
    top: 0 !important;
  }

  nav.navbar.validnavs .navbar-header .logo-text a.logo {
    color: var(--bg-blue) !important;
  }

  nav.navbar.validnavs {
    min-height: 70px !important;
    z-index: 9999 !important;
  }

  nav.navbar.validnavs.sticked,
  nav.navbar.validnavs.navbar-box.sticked {
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    background: rgba(255, 255, 255, 0.96) !important;
  }

  nav.navbar.validnavs.sticked .navbar-header .logo-text a.logo {
    color: var(--bg-blue) !important;
  }

  nav.navbar.validnavs.sticked::before {
    backdrop-filter: none !important;
  }

  nav.navbar.validnavs .container.nav-box {
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 15px !important;
    min-height: 70px !important;
  }

  nav.navbar.validnavs .navbar-header {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    position: relative !important;
  }

  nav.navbar.validnavs .navbar-header .logo {
    order: 1 !important;
    flex: 0 0 auto !important;
    display: block !important;
    margin: 0 !important;
    z-index: 1 !important;
    position: relative !important;
  }

  nav.navbar.validnavs .navbar-header .logo img {
    max-height: 55px !important;
    height: auto !important;
    width: auto !important;
  }

  nav.navbar.validnavs .navbar-header .logo-text a.logo {
    font-size: 26px !important;
  }

  nav.navbar.validnavs .navbar-collapse .mobile-menu-logo .navbar-toggle-close {
    display: none !important;
    position: absolute !important;
    top: 50% !important;
    right: 0 !important;
    transform: translateY(-50%) !important;
    width: 46px !important;
    height: 46px !important;
    background: var(--bg-blue) !important;
    border: none !important;
    border-radius: 10px !important;
    outline: none !important;
    box-shadow: none !important;
    cursor: pointer !important;
    z-index: 100002 !important;
    padding: 0 !important;
    margin: 0 !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }

  body.menu-opened
    nav.navbar.validnavs
    .navbar-collapse.show
    .mobile-menu-logo
    .navbar-toggle-close {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }

  nav.navbar.validnavs
    .navbar-collapse
    .mobile-menu-logo
    .navbar-toggle-close:hover {
    background: var(--color-primary) !important;
  }

  nav.navbar.validnavs
    .navbar-collapse
    .mobile-menu-logo
    .navbar-toggle-close::before,
  nav.navbar.validnavs
    .navbar-collapse
    .mobile-menu-logo
    .navbar-toggle-close::after {
    content: "" !important;
    display: block !important;
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    width: 24px !important;
    height: 3px !important;
    background: var(--white) !important;
    transition: all 0.3s ease !important;
  }

  nav.navbar.validnavs
    .navbar-collapse
    .mobile-menu-logo
    .navbar-toggle-close::before {
    transform: translate(-50%, -50%) rotate(45deg) !important;
  }

  nav.navbar.validnavs
    .navbar-collapse
    .mobile-menu-logo
    .navbar-toggle-close::after {
    transform: translate(-50%, -50%) rotate(-45deg) !important;
  }

  nav.navbar.validnavs
    .navbar-collapse
    .mobile-menu-logo
    .navbar-toggle-close:hover::before,
  nav.navbar.validnavs
    .navbar-collapse
    .mobile-menu-logo
    .navbar-toggle-close:hover::after {
    background: var(--white) !important;
  }

  nav.navbar.validnavs .navbar-header .navbar-toggle::before,
  nav.navbar.validnavs .navbar-header .navbar-toggle::after {
    display: none !important;
    content: none !important;
  }

  nav.navbar.validnavs .navbar-collapse {
    display: none !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 100vh !important;
    max-height: 100vh !important;
    background: color-mix(
      in srgb,
      var(--color-primary) 10%,
      var(--white) 90%
    ) !important;
    z-index: 100000 !important;
    padding: 26px 18px !important;
    overflow-y: auto !important;
    box-sizing: border-box !important;
  }

  nav.navbar.validnavs .navbar-collapse ul.nav {
    padding-left: 0 !important;
    margin-left: 0 !important;
  }

  nav.navbar.validnavs .navbar-collapse:not(.show) {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
  }

  nav.navbar.validnavs .navbar-collapse.show {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  body.menu-opened nav.navbar.validnavs .navbar-collapse.show {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  nav.navbar.validnavs .navbar-collapse.collapse-mobile:not(.show) {
    display: none !important;
    visibility: hidden !important;
  }

  nav.navbar.validnavs.mobile-sidenav .navbar-collapse ul.nav > li > a {
    color: var(--bg-blue) !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    padding: 15px 0 !important;
    border-bottom: 1px solid color-mix(in srgb, var(--bg-blue) 14%, transparent) !important;
    display: block !important;
    width: 100% !important;
    position: relative !important;
    padding-left: 28px !important;
  }

  nav.navbar.validnavs.mobile-sidenav .navbar-collapse ul.nav > li > a::before {
    content: "\f105" !important;
    font-family: "Font Awesome 6 Free" !important;
    font-weight: 900 !important;
    position: absolute !important;
    left: 0 !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 16px !important;
    line-height: 1 !important;
    color: currentColor !important;
    opacity: 0.9 !important;
    pointer-events: none !important;
  }

  nav.navbar.validnavs.mobile-sidenav .navbar-collapse ul.nav > li > a:hover {
    color: var(--color-secondary) !important;
    background: transparent !important;
  }

  nav.navbar.validnavs .navbar-collapse.show ul.nav > li {
    display: block !important;
    width: 100% !important;
  }

  nav.navbar.validnavs .navbar-collapse.show ul.nav > li > a {
    color: var(--bg-blue) !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    padding: 15px 0 !important;
    border-bottom: 1px solid color-mix(in srgb, var(--bg-blue) 14%, transparent) !important;
    display: block !important;
    position: relative !important;
    padding-left: 28px !important;
  }

  nav.navbar.validnavs .navbar-collapse.show ul.nav > li > a::before {
    content: "\f105" !important;
    font-family: "Font Awesome 6 Free" !important;
    font-weight: 900 !important;
    position: absolute !important;
    left: 0 !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 16px !important;
    line-height: 1 !important;
    color: currentColor !important;
    opacity: 0.9 !important;
    pointer-events: none !important;
  }

  nav.navbar.validnavs .navbar-collapse.show ul.nav > li > a:hover {
    color: var(--color-secondary) !important;
  }

  nav.navbar.validnavs .navbar-collapse .desktop-menu-wrapper {
    display: none !important;
  }

  nav.navbar.validnavs .navbar-collapse .mobile-menu-wrapper {
    display: block !important;
    width: 100% !important;
  }

  nav.navbar.validnavs .navbar-collapse .mobile-menu-wrapper ul.dropdown-menu {
    position: static !important;
    display: none !important;
    float: none !important;
    width: 100% !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding-left: 14px !important;
    margin: 0 !important;
  }

  nav.navbar.validnavs
    .navbar-collapse
    .mobile-menu-wrapper
    li.dropdown.show
    > ul.dropdown-menu {
    display: block !important;
  }

  nav.navbar.validnavs
    .navbar-collapse
    .mobile-menu-wrapper
    ul.dropdown-menu
    li
    a {
    color: color-mix(in srgb, var(--bg-blue) 78%, transparent) !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    padding: 12px 0 !important;
    border-bottom: 1px dashed
      color-mix(in srgb, var(--bg-blue) 16%, transparent) !important;
    position: relative !important;
    padding-left: 26px !important;
  }

  nav.navbar.validnavs
    .navbar-collapse
    .mobile-menu-wrapper
    ul.dropdown-menu
    li
    a::before {
    content: "\f111" !important;
    font-family: "Font Awesome 6 Free" !important;
    font-weight: 900 !important;
    position: absolute !important;
    left: 0 !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 7px !important;
    line-height: 1 !important;
    color: currentColor !important;
    opacity: 0.65 !important;
    pointer-events: none !important;
  }

  nav.navbar.validnavs
    .navbar-collapse
    .mobile-menu-wrapper
    ul.dropdown-menu
    li
    a:hover {
    color: var(--color-secondary) !important;
    padding-left: 8px !important;
  }

  nav.navbar.validnavs
    .navbar-collapse
    .mobile-menu-wrapper
    li.dropdown
    > a::after {
    content: "\f107" !important;
    font-family: "Font Awesome 6 Free" !important;
    font-weight: 900 !important;
    float: right !important;
    transition: transform 0.3s ease !important;
  }

  nav.navbar.validnavs
    .navbar-collapse
    .mobile-menu-wrapper
    li.dropdown.show
    > a::after {
    transform: rotate(180deg) !important;
  }

  nav.navbar.validnavs .navbar-collapse .mobile-menu-logo {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-bottom: 30px !important;
    padding: 30px 20px !important;
    min-height: auto !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 100003 !important;
    background: color-mix(
      in srgb,
      var(--color-primary) 10%,
      var(--white) 90%
    ) !important;
  }

  nav.navbar.validnavs .navbar-collapse .mobile-menu-logo .logo {
    display: inline-block !important;
    width: auto !important;
    text-align: center !important;
    flex-shrink: 0 !important;
  }

  nav.navbar.validnavs .navbar-collapse .mobile-menu-logo .logo img {
    max-height: 128px !important;
    width: auto !important;
    height: auto !important;
    display: block !important;
  }

  nav.navbar.validnavs .navbar-collapse ul.nav {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  /* Layout logo + ícones é definido no bloco mobile seguinte (~1320). */

  nav.navbar.validnavs .overlay-screen {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 100vh !important;
    background: rgba(0, 0, 0, 0.5) !important;
    z-index: 99999 !important;
    display: none !important;
  }

  nav.navbar.validnavs .overlay-screen.opened {
    display: block !important;
  }
}

/* Admin Bar: fully hidden via show_admin_bar(false) — safety reset */
html.admin-bar,
body.admin-bar {
  margin-top: 0 !important;
}

#wpadminbar {
  display: none !important;
}

nav.navbar.validnavs.sticked {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

nav.navbar.validnavs.navbar-box.sticked {
  top: 0 !important;
}

/* WooCommerce compact header (always fixed on desktop) */
@media (min-width: 992px) {
  body.eduval-wc-compact-header nav.navbar.validnavs.navbar-box {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    top: 0 !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    z-index: 9999 !important;
    background: rgba(255, 255, 255, 0.85) !important;
    box-shadow: 0px 1px 3px 0px rgba(18, 20, 32, 0.14) !important;
    animation: none !important;
  }

  body.eduval-wc-compact-header nav.navbar.validnavs.navbar-box::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    backdrop-filter: blur(10px);
    z-index: -1;
    pointer-events: none;
  }

  body.eduval-wc-compact-header
    nav.navbar.validnavs.navbar-box
    .container.nav-box {
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
    border-radius: 0 !important;
  }
}

@media (max-width: 991px) {
  body.eduval-wc-compact-header nav.navbar.validnavs,
  body.eduval-wc-compact-header nav.navbar.validnavs.navbar-box {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    top: 0 !important;
    z-index: 9999 !important;
    background: rgba(255, 255, 255, 0.96) !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06) !important;
    min-height: 70px !important;
  }

  body.eduval-wc-compact-header nav.navbar.validnavs .navbar-header .logo-text a.logo {
    color: var(--bg-blue) !important;
  }

  body.eduval-wc-compact-header nav.navbar.validnavs::before {
    backdrop-filter: none !important;
  }
}

/* Mobile: logótipo à esquerda, ícones à direita; sem hamburger visível (menu no footer app). */
@media (max-width: 991px) {
  nav.navbar.validnavs .attr-right {
    display: block !important;
    flex: 0 0 auto !important;
    margin-left: 0 !important;
  }

  nav.navbar.validnavs .attr-right .attr-nav > ul {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 10px !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  nav.navbar.validnavs .attr-right .attr-nav li.button {
    display: none !important;
  }

  /* Mesmo inset horizontal: alinhar com .container.nav-box (15px em <992) */
  nav.navbar.validnavs .container.nav-box {
    justify-content: space-between !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
    padding-left: 15px !important;
    padding-right: 15px !important;
  }

  nav.navbar.validnavs .navbar-header {
    position: relative !important;
    width: auto !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    justify-content: flex-start !important;
    align-items: center !important;
    gap: 0 !important;
    padding-right: 0 !important;
    max-width: none !important;
  }

  nav.navbar.validnavs .navbar-header .logo,
  nav.navbar.validnavs .navbar-header .logo-text {
    margin-left: 0 !important;
    margin-right: 0 !important;
    order: 0 !important;
  }

  /*
   * Botão real para validnavs + eduval-mobile-bottom-nav.js (.click()).
   * Fora do fluxo: não ocupa espaço nem desequilibra o logo vs ícones.
   */
  nav.navbar.validnavs .navbar-header .navbar-toggle-open {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    min-width: 0 !important;
    min-height: 0 !important;
    margin: -1px !important;
    padding: 0 !important;
    overflow: hidden !important;
    clip-path: inset(50%) !important;
    white-space: nowrap !important;
    border: 0 !important;
    opacity: 0 !important;
    left: 0 !important;
    top: 0 !important;
    right: auto !important;
    transform: none !important;
    flex: 0 0 0 !important;
    order: -1 !important;
    z-index: -1 !important;
    display: block !important;
    visibility: visible !important;
    pointer-events: auto !important;
    background: transparent !important;
    font-size: 0 !important;
    line-height: 0 !important;
    color: transparent !important;
    cursor: pointer !important;
    box-shadow: none !important;
    border-radius: 0 !important;
  }

  nav.navbar.validnavs .navbar-header .navbar-toggle-open::before,
  nav.navbar.validnavs .navbar-header .navbar-toggle-open::after {
    display: none !important;
    content: none !important;
  }
}
