/**
 * @file
 * Primary navigation at normal widths.
 */

/** General **/
.primary-nav__menu {
  flex-wrap: wrap;
  list-style: none;
}

.primary-nav__menu-item {
  margin-bottom: 1rem;
  min-height: 1.5rem;
}

.primary-nav__menu-item:last-child {
  margin-bottom: 0;
  display: flex;
}

[dir] .primary-nav li:last-child {
  margin-bottom: 0;
  display: flex;
}

.primary-nav__menu-item.primary-nav__menu-item--has-children {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

/** Top level of menu **/

.primary-nav__menu-item.primary-nav__menu-item--has-children
  :is(.primary-nav__menu-link--link, .primary-nav__menu-link--nolink) {
  /* Ensure that long text doesn't make the mobile expand button wrap. */
  flex-basis: calc(100% - 3.375rem);
}

.primary-nav__menu-link {
  flex-grow: 1;
  text-decoration: none;
  color: #0d1214;
  font-size: 1.3rem;
  font-weight: bold;
}

.primary-nav__menu-link:hover {
  color: inherit;
}

/** Focus draws a box around the item **/
.primary-nav__menu-link:focus {
  outline: auto 2px var(--laurier-gold);
  outline-offset: 2px;
}

[dir="ltr"] .primary-nav__menu-link--nolink {
  padding-left: 0;
  padding-right: 0;
}

[dir="rtl"] .primary-nav__menu-link--nolink {
  padding-right: 0;
  padding-left: 0;
}

.primary-nav__menu-link--nolink {
  padding: 0.5625rem 0;
  color: var(--laurier-purple);
  font-weight: normal;
}

[dir="ltr"] .primary-nav__menu-link--button {
  padding-left: 0;
  padding-right: 0;
  text-align: left;
}

[dir="rtl"] .primary-nav__menu-link--button {
  padding-right: 0;
  padding-left: 0;
  text-align: right;
}

.primary-nav__menu-link--button {
  position: relative;
  padding-top: 0;
  padding-bottom: 0;
  cursor: pointer;
  border: 0;
  background: transparent;

  /* Plus icon for mobile navigation. */
}

[dir="ltr"]
  .primary-nav__menu-link--button.primary-nav__menu-link--has-children {
  padding-right: 3.375rem;
}

[dir="rtl"]
  .primary-nav__menu-link--button.primary-nav__menu-link--has-children {
  padding-left: 3.375rem;
}

.primary-nav__menu-link--button.primary-nav__menu-link--has-children {
  /* Ensure text does not overlap icon. */
  /* Ensure text does not overlap icon. */
}

[dir="ltr"]
  .primary-nav__menu-link--button.primary-nav__menu-link--has-children:is(
    :before,
    :after
  ) {
  right: 0.5625rem;
}

[dir="rtl"]
  .primary-nav__menu-link--button.primary-nav__menu-link--has-children:is(
    :before,
    :after
  ) {
  left: 0.5625rem;
}

.primary-nav__menu-link--button.primary-nav__menu-link--has-children:is(
    :before,
    :after
  ) {
  position: absolute;
  top: 1.625rem; /* Visually align button with menu link text. */
  box-sizing: content-box;
  width: 1.125rem;
  height: 0;
  content: "";
  /* Intentionally not using CSS logical properties. */
  border-top: solid 3px var(--laurier-gold);
}

.primary-nav__menu-link--button.primary-nav__menu-link--has-children:after {
  transition: opacity 0.2s;
  transform: rotate(90deg);
}

.primary-nav__menu-link--button.primary-nav__menu-link--has-children[aria-expanded="true"]:after {
  opacity: 0;
}

[dir="ltr"] .primary-nav__menu-link-inner {
  padding-left: 0;
}

[dir="rtl"] .primary-nav__menu-link-inner {
  padding-right: 0;
}

[dir="ltr"] .primary-nav__menu-link-inner {
  padding-right: 0;
}

[dir="rtl"] .primary-nav__menu-link-inner {
  padding-left: 0;
}

.primary-nav__menu-link-inner {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 0 0 0 0.3rem;
}

[dir="ltr"] .primary-nav__menu-link-inner:after {
  left: 0;
}

[dir="rtl"] .primary-nav__menu-link-inner:after {
  right: 0;
}

/** span.primary-nav__menu-link-inner */
.primary-nav__menu-link-inner:after {
  position: absolute;
  bottom: -5px;
  box-sizing: content-box;
  width: 100%;
  height: 0;
  content: "";
  transition: transform 0.2s;
  transform: scaleX(0);
  transform-origin: left;
  /* Intentionally not using CSS logical properties. */
  border-top: solid 2px var(--laurier-gold);
}

.primary-nav__menu-link:hover .primary-nav__menu-link-inner:after {
  transform: scaleX(1);
}

/** Top level specific styles. **/

[dir="ltr"] .primary-nav__menu--level-1 {
  margin-left: 0;
}

[dir="rtl"] .primary-nav__menu--level-1 {
  margin-right: 0;
}

[dir="ltr"] .primary-nav__menu--level-1 {
  margin-right: 0;
}

[dir="rtl"] .primary-nav__menu--level-1 {
  margin-left: 0;
}

[dir="ltr"] .primary-nav__menu--level-1 {
  padding-left: 0;
}

[dir="rtl"] .primary-nav__menu--level-1 {
  padding-right: 0;
}

[dir="ltr"] .primary-nav__menu--level-1 {
  padding-right: 0;
}

[dir="rtl"] .primary-nav__menu--level-1 {
  padding-left: 0;
}

.primary-nav__menu--level-1 {
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
}

.primary-nav__menu-link--level-1 {
  position: relative;
  display: flex;
}

.header-nav:not(.is-active) .primary-nav__menu-link--level-1 {
  color: var(--white);
}

.header-nav.is-active .primary-nav__menu-link--level-1 {
  color: var(--laurier-purple);
}

/** Secondary menu specific styles. **/

[dir="ltr"] .primary-nav__menu--level-2 {
  margin-left: -1.125rem;
}

[dir="rtl"] .primary-nav__menu--level-2 {
  margin-right: -1.125rem;
}

[dir="ltr"] .primary-nav__menu--level-2 {
  padding-left: 2.8125rem;
}

[dir="rtl"] .primary-nav__menu--level-2 {
  padding-right: 2.8125rem;
}

.primary-nav__menu--level-2 {
  visibility: hidden;
  overflow: hidden;
  flex-basis: 100%;
  max-height: 0;
  margin-top: 0;
  margin-bottom: 0;
  transition: opacity 0.4s, visibility 0.4s, max-height 0.4s;
  opacity: 0;
}
.primary-nav__menu--level-2.is-active-menu-parent {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-content: flex-start;
  align-items: flex-start;
  text-align: left;
  visibility: visible;
  max-height: none;
  margin-top: 1.6875rem;
  opacity: 1;
}

@media (min-width: 43.75rem) {
  .header-nav.is-active .primary-nav__menu-link--level-2 {
    padding-left: 2rem;
  }

  [dir="ltr"] .primary-nav__menu--level-2 {
    margin-left: -3.375rem;
  }

  [dir="rtl"] .primary-nav__menu--level-2 {
    margin-right: -3.375rem;
  }

  [dir="ltr"] .primary-nav__menu--level-2 {
    padding-left: 3.375rem;
  }

  [dir="rtl"] .primary-nav__menu--level-2 {
    padding-right: 3.375rem;
  }
}

/*
 * Olivero doesn't officially support nested tertiary submenus, but this
 * ensures that it doesn't break all the way.
 *
 * @see https://www.drupal.org/project/drupal/issues/3221399
 */

.primary-nav__menu--level-2 .primary-nav__menu-item--has-children {
  display: block;
}

.primary-nav__menu-link--level-2 {
  background-color: var(--white);
  color: var(--laurier-purple);
  font-size: 1rem;
  font-weight: normal;
  line-height: 1rem;
}
.primary-nav__menu-link--level-2:is(:hover, :focus) {
  color: var(--laurier-red);
}

html:not(.js) .primary-nav__menu--level-2 {
  visibility: visible;
  max-height: none;
  opacity: 1;
}

[dir="rtl"] .primary-nav__menu-link-inner:after {
  transform-origin: right;
}
