/*
 * DO NOT EDIT THIS FILE.
 * See the following change record for more information,
 * https://www.drupal.org/node/3084859
 * @preserve
 */

/**
 * @file
 * Nav Primary.
 */

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

.primary-nav__menu-item {
  margin-block-end: var(--sp0-5);
}

.primary-nav__menu-item:last-child {
  margin-block-end: 0;
}

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

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

.primary-nav__menu-link {
  flex-grow: 1;
  -webkit-text-decoration: none;
  text-decoration: none;
  color: var(--color-text-neutral-loud);
  font-size: 1.75rem;
  font-weight: bold;
  line-height: var(--sp2);
}

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

.primary-nav__menu-link:focus {
  outline: auto 2px var(--color--primary-50);
  outline-offset: 2px;
}

.primary-nav__menu-link--nolink {
  padding-block: var(--sp0-5);
  padding-inline-start: 0;
  padding-inline-end: 0;
  color: var(--color-text-neutral-soft);
  font-weight: normal;
}

.primary-nav__menu-link--button {
  position: relative;
  padding-block: 0;
  padding-inline-start: 0;
  padding-inline-end: 0;
  cursor: pointer;
  text-align: start;
  border: 0;
  background: transparent;

  /* Plus icon for mobile navigation. */
}

.primary-nav__menu-link--button.primary-nav__menu-link--has-children {
  padding-inline-end: var(--sp3); /* Ensure text does not overlap icon. */
}

.primary-nav__menu-link--button.primary-nav__menu-link--has-children::before,
.primary-nav__menu-link--button.primary-nav__menu-link--has-children::after {
  position: absolute;
  inset-inline-end: 0.5625rem;
/*  inset-block-start: calc(var(--sp0-5) + 1.0625rem);*/
  inset-block-start: calc(var(--sp0-5, 0.5625rem) + 1.0625rem);
  width: 1.125rem;
  height: 0;
  content: "";
  /* Intentionally not using CSS logical properties. */
  border-top: solid 3px var(--color--primary-50);
}

.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;
}

.primary-nav__menu-link-inner {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding-block: var(--sp0-5);
  padding-inline-start: 0;
  padding-inline-end: 0;
}

.primary-nav__menu-link-inner::after {
  position: absolute;
  inset-block-end: 0;
  inset-inline-start: 0;
  width: 100%;
  height: 0;
  content: "";
  transition: transform 0.2s;
  transform: scaleX(0);
  transform-origin: left;
  /* Intentionally not using CSS logical properties. */
  border-top: solid 5px var(--color--primary-50);
}

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

/*
  Top level specific styles.
*/

.primary-nav__menu--level-1 {
  margin-block: 0;
  margin-inline-start: 0;
  margin-inline-end: 0;
  padding-block: 0;
  padding-inline-start: 0;
  padding-inline-end: 0;
}

.primary-nav__menu-link--level-1 {
/*  letter-spacing: -1;*/
    margin: auto;
    line-height: 18px !important;
    /* margin-left: 5px; */
    text-align: center;
    font-weight: 500;
}

/*
  Secondary menu specific styles.
*/

.primary-nav__menu--level-2 {
  /* visibility: hidden;
  overflow: hidden;
  flex-basis: 100%;
  max-height: 0; */
  margin-block: 0;
  margin-inline-start: calc(-1 * var(--sp));
  padding-inline-start: var(--sp2-5);
  transition:
    opacity 0.2s,
    visibility 0.2s,
    max-height 0.2s;
  /* opacity: 0; */
  border-inline-start: solid var(--sp) var(--color--primary-50);
}

.primary-nav__menu--level-2.is-active-menu-parent {
  visibility: visible;
  max-height: none;
  margin-block-start: var(--sp1-5);
  opacity: 1;
}

@media (min-width: 43.75rem) {
  .primary-nav__menu--level-2 {
    margin-inline-start: calc(-1 * var(--sp3));
    padding-inline-start: var(--sp3);
  }
}

/*
 * 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 {
  font-size: 1rem;
  font-weight: normal;
  line-height: var(--sp);
}

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;
}



/* nav primary button css */

/*
 * DO NOT EDIT THIS FILE.
 * See the following change record for more information,
 * https://www.drupal.org/node/3084859
 * @preserve
 */

/**
 * @file
 * Button that expands second level nav when clicked.
 */

 .primary-nav__button-toggle {
  position: relative;
  overflow: hidden;
  width: var(--sp2);
  height: var(--sp2);
  margin-block-start: var(--sp0-5); /* Visually align button with menu link text. */
  padding-block: 0;
  padding-inline-start: 0;
  padding-inline-end: 0;
  cursor: pointer;
  text-indent: -62.4375rem;
  border: 0;
  background: transparent;
  -webkit-appearance: none;
}

.primary-nav__button-toggle:focus {
  outline: auto 2px var(--color--primary-50);
  outline-offset: 2px;
}

.primary-nav__button-toggle .icon--menu-toggle {
  position: absolute;
  /* stylelint-disable csstools/use-logical */
  top: 50%;
  left: 50%;
  /* stylelint-enable csstools/use-logical */
  width: 1rem;
  height: 1rem;
  transition: background-color 0.2s;
  transform: translate(-50%, -50%);
  border-radius: 2px;
}

.primary-nav__button-toggle .icon--menu-toggle::before,
.primary-nav__button-toggle .icon--menu-toggle::after {
  position: absolute;
  /* stylelint-disable csstools/use-logical */
  top: 50%;
  left: 50%;
  /* stylelint-enable csstools/use-logical */
  width: var(--sp);
  height: 0;
  content: "";
  transform: translate(-50%, -50%);
  /* Intentionally not using CSS logical properties. */
  border-top: solid 3px var(--color--primary-50);
}

.primary-nav__button-toggle .icon--menu-toggle::after {
  transition: opacity 0.2s;
  transform: translate(-50%, -50%) rotate(90deg);
}

.primary-nav__button-toggle[aria-expanded="true"] .icon--menu-toggle::after {
  opacity: 0;
}

/* aria-hidden attribute is removed by JS. Button is non-functional
     until JS is enabled.
  */

.primary-nav__button-toggle[aria-hidden="true"] {
  pointer-events: none;
}

@media (min-width: 75rem) {
  body:not(.is-always-mobile-nav) .primary-nav__button-toggle {
    flex-shrink: 0;
    align-self: stretch;
/*    width: calc(var(--sp2) + 0.5rem);*/
    width: calc(var(--sp2, 2.25rem) + 0.5rem);
    height: auto;
    margin-block-start: 0;
    margin-inline-end: calc(-1 * var(--sp2));
  }

  body:not(.is-always-mobile-nav) .primary-nav__button-toggle:focus {
    border: 0;
    outline: 0;
  }

  body:not(.is-always-mobile-nav) .primary-nav__button-toggle:focus .icon--menu-toggle {
    border: solid 2px var(--color--primary-40);
  }

  body:not(.is-always-mobile-nav) .primary-nav__button-toggle:active {
    /* Necessary for Safari. */
    color: currentColor;
  }

  body:not(.is-always-mobile-nav) .primary-nav__button-toggle[aria-expanded="true"] .icon--menu-toggle::after {
    opacity: 0.8;
  }

  body:not(.is-always-mobile-nav) .primary-nav__button-toggle .icon--menu-toggle {
    inset-inline-start: 0.1875rem;
    width: 1.125rem;
    transform: translateY(-50%);
    border-radius: 0.25rem;
    background-color: var(--color--white);
  }

  body:not(.is-always-mobile-nav) .primary-nav__button-toggle .icon--menu-toggle::before {
    content: none;
  }

  body:not(.is-always-mobile-nav) .primary-nav__button-toggle .icon--menu-toggle::after {
    /* stylelint-disable csstools/use-logical */
    top: calc(50% - 2px);
    left: 0.1875rem;
    /* stylelint-enable csstools/use-logical */
    width: 0.5rem;
    height: 0.5rem;
    content: "";
    transform: translateY(-50%) rotate(45deg);
    opacity: 0.8;
    /* Intentionally not using CSS logical properties. */
    border-top: none;
    border-right: solid 2px currentColor;
    border-bottom: solid 2px currentColor;
    background: transparent;
  }
}

/* nav primary wide */

/*
 * DO NOT EDIT THIS FILE.
 * See the following change record for more information,
 * https://www.drupal.org/node/3084859
 * @preserve
 */

/**
 * @file
 * Nav Primary (wide widths).
 */

 @media (min-width: 75rem) {
  body:not(.is-always-mobile-nav) .primary-nav__menu-item {
    flex-wrap: nowrap; /* Ensure that sub navigation toggle button doesn't wrap underneath link. */
  }
  body:not(.is-always-mobile-nav) .primary-nav__menu-item.primary-nav_submenu .primary-nav__menu-link--link,
  body:not(.is-always-mobile-nav) .primary-nav__menu-item.primary-nav_submenu .primary-nav__menu-link--nolink {
    flex-basis: auto;
  }

  /* Remove hover state if submenu exists. */
  body:not(.is-always-mobile-nav) .primary-nav__menu-item.primary-nav_submenu .primary-nav__menu-link--level-1 .primary-nav__menu-link-inner::after {
    content: none;
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-link {
    letter-spacing: 0.02em;
    font-size: 1rem;
    line-height: var(--sp1-5);
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-link:focus {
    position: relative;
    outline: 0;
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-link:focus::before {
    position: absolute;
    top: 50%;
    left: 50%;
    width: calc(100% + var(--sp));
    height: var(--sp3);
    content: "";
    transform: translate(-50%, -50%);
    border: solid 2px var(--color--primary-50);
    border-radius: 0.25rem;
  }
  body:not(.is-always-mobile-nav) .primary-nav__menu-link--button.primary-nav__menu-link--has-children {
    overflow: visible; /* Necessary to view icon in IE11 */
    padding-inline-end: 0.5625rem;
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-link--button.primary-nav__menu-link--has-children:focus::before {
    width: calc(100% + var(--sp1-5));
    content: "";
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-link--button.primary-nav__menu-link--has-children::before {
    content: none;
  }

  /* Chevron icon for desktop navigation. */
  body:not(.is-always-mobile-nav) .primary-nav__menu-link--button.primary-nav__menu-link--has-children::after {
    position: absolute;
    inset-block-start: 50%;
    inset-inline-start: calc(100% - 0.1875rem);
    width: 0.5rem;
    height: 0.5rem;
    margin-block-start: -2px;
    transform: translateY(-50%) rotate(45deg);
    /* Intentionally not using CSS logical properties. */
    border-top: 0;
    border-right: solid 2px currentColor;
    border-bottom: solid 2px currentColor;
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-link--button.primary-nav__menu-link--has-children[aria-expanded="true"]::after {
    opacity: 1;
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-link-inner {
    padding-block: var(--sp2);
    padding-inline-start: 0;
    padding-inline-end: 0;
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-link-inner::after {
    transform-origin: center;
    border-top-width: var(--sp0-5);
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu--level-1 {
    display: flex;
    align-items: stretch;
    margin-inline-end: var(--sp);
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-item--level-1 {
    position: relative; /* Anchor secondary menu */
    display: flex;
    align-items: center;
    width: max-content;
    max-width: 12.5rem;
    margin-block: 0;
    margin-inline-start: 0;
    margin-inline-end: 0;
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-item--level-1:not(:last-child) {
    margin-inline-end: var(--sp2);
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu--level-2 {
    position: absolute;
    z-index: 105; /* Appear above search container. */
    top: calc(100% - var(--sp0-5));
    left: 50%;
    /* visibility: hidden; */
    overflow: auto;
    width: 15.625rem;
    /* Ensure that long level-2 menus will never overflow viewport (focused
       * elements should always be in viewport per accessibility guidelines). */
/*    max-height: calc(100vh - var(--site-header-height-wide) - var(--drupal-displace-offset-top, 0px) - var(--drupal-displace-offset-bottom, 0px) - var(--sp));*/
    max-height: calc(100vh - var(--site-header-height-wide, 6rem) - var(--drupal-displace-offset-top, 0px) - var(--drupal-displace-offset-bottom, 0px) - var(--sp, 1.125rem));
    margin-block-start: 0;
    margin-inline-start: 0;
    padding-block: var(--sp3);
    padding-inline-start: var(--sp2);
    padding-inline-end: var(--sp2);
    transition: none;
    transform: translate(-50%, -1.25rem);
    /* opacity: 0; */
    /* Intentionally not using CSS logical properties. */
    border-top: solid var(--color--primary-50) var(--sp0-5);
    border-right: solid 1px transparent; /* Transparent borders useful for Windows High Contrast mode. */
    border-bottom: solid 1px transparent;
    border-left: solid 1px transparent;
    border-radius: 0 0 2px 2px;
    background: var(--color--white);
    box-shadow: 0 1px 36px rgba(0, 0, 0, 0.08);
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu--level-2.is-active-menu-parent {
    visibility: visible;
    margin-block-start: 0;
    transform: translate(-50%, 0);
    opacity: 1;
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-link--level-2 {
    display: block;
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-link--level-2:focus::before {
    top: 0;
    left: calc(var(--sp0-5) * -1);
    height: 100%;
    transform: none;
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-link--level-2 .primary-nav__menu-link-inner {
    padding-block: var(--sp0-5);
    padding-inline-start: 0;
    padding-inline-end: 0;
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-link--level-2 .primary-nav__menu-link-inner::after {
    transform-origin: left; /* LTR */
    border-top-width: 3px;
  }

  [dir="rtl"] body:not(.is-always-mobile-nav) .primary-nav__menu-link--level-2 .primary-nav__menu-link-inner::after {
    transform-origin: right;
  }

  /**
     * Arrow is placed outside of submenu because the submenu has the
     * `overflow: hidden` CSS rule applied.
     */
  body:not(.is-always-mobile-nav) .primary-nav__menu-ðŸ¥• {
    position: absolute;
    z-index: 105; /* Match level 2 menus. */
    top: calc(100% - var(--sp));
    left: 50%;
    visibility: hidden;
    width: 0;
    height: 0;
    transform: translate(-50%, -1.25rem);
    opacity: 0;
    /* Intentionally not using CSS logical properties. */
    border-right: solid 10px transparent;
    border-bottom: solid 10px var(--color--primary-50);
    border-left: solid 10px transparent;
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu-ðŸ¥•.is-active-menu-parent {
    visibility: visible;
    transform: translate(-50%, 0);
    opacity: 1;
  }

  /**
     * When ensuring that long menus don't overflow viewport, we can give a
     * little extra room when the toolbar is fixed (and is shorter).
     */
  body:not(.is-always-mobile-nav) .is-fixed .primary-nav__menu--level-2 {
/*    max-height: calc(100vh - var(--site-header-height-wide) - var(--drupal-displace-offset-top, 0px) - var(--drupal-displace-offset-bottom, 0px) - var(--sp) + var(--sp4));*/
    max-height: calc(100vh - var(--site-header-height-wide, 6rem) - var(--drupal-displace-offset-top, 0px) - var(--drupal-displace-offset-bottom, 0px) - var(--sp, 1.125rem) + var(--sp4, 4.5rem));
  }
}

/*
 * Only apply transition styles to menu when JS is loaded. This
 * works around https://bugs.chromium.org/p/chromium/issues/detail?id=332189
 */

@media (min-width: 75rem) {
  html.js body:not(.is-always-mobile-nav) .primary-nav__menu--level-2,
  html.js body:not(.is-always-mobile-nav) .primary-nav__menu-ðŸ¥• {
    transition:
      visibility 0.2s,
      transform 0.2s,
      opacity 0.2s;
  }
}
