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

@import "../../base/media-queries.pcss.css";

body:not(.is-always-mobile-nav) {
  @media (--nav) {
    & .primary-nav__menu-item {
      flex-wrap: nowrap; /* Ensure that sub navigation toggle button doesn't wrap underneath link. */

      &.primary-nav__menu-item--has-children {
        & .primary-nav__menu-link--link,
        & .primary-nav__menu-link--nolink {
          flex-basis: auto;
        }

        /* Remove hover state if submenu exists. */
        & .primary-nav__menu-link--level-1 .primary-nav__menu-link-inner::after {
          content: none;
        }
      }
    }

    & .primary-nav__menu-link {
      letter-spacing: 0.02em;
      font-size: 16px;
      line-height: var(--sp1-5);

      &:focus {
        position: relative;
        outline: 0;

        &::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: 4px;
        }
      }
    }

    & .primary-nav__menu-link--button {
      &.primary-nav__menu-link--has-children {
        overflow: visible; /* Necessary to view icon in IE11 */
        padding-inline-end: 9px;

        &:focus::before {
          width: calc(100% + var(--sp1-5));
          content: "";
        }

        &::before {
          content: none;
        }

        /* Chevron icon for desktop navigation. */
        &::after {
          position: absolute;
          inset-block-start: 50%;
          inset-inline-start: calc(100% - 3px);
          width: 8px;
          height: 8px;
          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;
        }

        &[aria-expanded="true"]::after {
          opacity: 1;
        }
      }
    }

    & .primary-nav__menu-link-inner {
      padding-block: var(--sp2);
      padding-inline-start: 0;
      padding-inline-end: 0;

      &::after {
        transform-origin: center;
        border-top-width: var(--sp0-5);
      }
    }

    & .primary-nav__menu--level-1 {
      display: flex;
      align-items: stretch;
      margin-inline-end: var(--sp);
    }

    & .primary-nav__menu-item--level-1 {
      position: relative; /* Anchor secondary menu */
      display: flex;
      align-items: center;
      width: max-content;
      max-width: 200px;
      margin-block: 0;
      margin-inline-start: 0;
      margin-inline-end: 0;

      &:not(:last-child) {
        margin-inline-end: var(--sp2);
      }
    }

    & .primary-nav__menu--level-2 {
      position: absolute;
      z-index: 105; /* Appear above search container. */
      top: calc(100% - (0.5 * var(--sp)));
      left: 50%;
      visibility: hidden;
      overflow: auto;
      width: 250px;
      /* 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));
      margin-block-start: 0;
      margin-inline-start: 0;
      padding-block: calc(3 * var(--sp));
      padding-inline-start: var(--sp2);
      padding-inline-end: var(--sp2);
      transition: none;
      transform: translate(-50%, -20px);
      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);

      &.is-active-menu-parent {
        visibility: visible;
        margin-block-start: 0;
        transform: translate(-50%, 0);
        opacity: 1;
      }
    }

    & .primary-nav__menu-link--level-2 {
      display: block;

      &:focus::before {
        top: 0;
        left: calc(var(--sp0-5) * -1);
        height: 100%;
        transform: none;
      }

      & .primary-nav__menu-link-inner {
        padding-block: var(--sp0-5);
        padding-inline-start: 0;
        padding-inline-end: 0;

        &::after {
          transform-origin: left; /* LTR */
          border-top-width: 3px;

          &:dir(rtl) {
            transform-origin: right;
          }
        }
      }
    }

    /**
     * Arrow is placed outside of submenu because the submenu has the
     * `overflow: hidden` CSS rule applied.
     */
    & .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%, -20px);
      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;

      &.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).
     */
    & .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));
    }
  }
}

/*
 * Only apply transition styles to menu when JS is loaded. This
 * works around https://bugs.chromium.org/p/chromium/issues/detail?id=332189
 */
html.js body:not(.is-always-mobile-nav) {
  @media (--nav) {
    & .primary-nav__menu--level-2,
    & .primary-nav__menu-🥕 {
      transition: visibility 0.2s, transform 0.2s, opacity 0.2s;
    }
  }
}