@layer components {

  .nav {
    position: fixed;
    inset: 0 0 auto 0;
    z-index: 50;
    padding: 24px var(--pad-x);
    display: flex;
    justify-content: stretch;
    align-items: flex-start;
    mix-blend-mode: normal;
    transform: translate3d(0, 0, 0);
    transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    pointer-events: none;
  }
  .nav > * {
    pointer-events: auto;
  }
  .nav.nav--hidden {
    transform: translate3d(0, -100%, 0);
    pointer-events: none;
  }
  .nav.nav--hidden > * {
    pointer-events: none;
  }

  @media (min-width: 901px) {
    body.nav--frost-on :is(.canvas, .photo-carousel) > *:not([aria-hidden]):not(.nav-frost-exempt) {
      --_cy: calc(var(--pill-cy) + var(--scroll-y) - var(--el-doc-top, 9999px));
      -webkit-mask-image: radial-gradient(
        ellipse var(--pill-rx) var(--pill-ry) at var(--pill-cx) var(--_cy),
        transparent 0%,
        transparent 28%,
        black 92%
      );
      mask-image: radial-gradient(
        ellipse var(--pill-rx) var(--pill-ry) at var(--pill-cx) var(--_cy),
        transparent 0%,
        transparent 28%,
        black 92%
      );
    }

    body.nav--frost-on .canvas.cta-cards > *:not([aria-hidden]) {
      -webkit-mask-image: none;
      mask-image: none;
    }
  }

  .nav-content-frost {
    display: none;
  }

  .nav__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 24px;
    min-width: 0;
    transition:
      width var(--motion-standard),
      max-width var(--motion-standard),
      padding 0.35s ease,
      border-radius 0.35s ease,
      background 0.35s ease,
      box-shadow 0.35s ease;
  }
  .nav.nav--compact {
    justify-content: flex-end;
    align-items: flex-start;
    overflow: visible;
  }
  .nav.nav--compact .nav__inner {
    width: auto;
    max-width: calc(100vw - 2 * var(--pad-x));
    justify-content: flex-end;
    flex-wrap: nowrap;
    overflow: visible;
    padding: 14px 22px 14px 20px;
    border-radius: var(--radius-pill);
    background: var(--canvas);
    border: none;
    box-shadow: none;
    gap: 32px;
  }
  .nav__logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
    overflow: visible;
    flex-shrink: 0;
    transform-origin: center center;
    transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
    color: var(--ink-muted);
  }
  .nav__logo:focus-visible {
    transform: scale(1.05);
  }
  @media (hover: hover) {
    .nav__logo:hover {
      transform: scale(1.05);
    }
  }
  .logo-mark {
    display: block;
    width: auto;
    flex-shrink: 0;
  }
  .nav__logo .logo-mark:not(.logo-x) {
    height: 26px;
    width: auto;
    max-width: min(72vw, 420px);
  }
  .nav__logo .logo-x {
    display: none;
    height: 22px;
    width: auto;
    max-width: none;
    overflow: visible;
    flex-shrink: 0;
    align-self: center;
    color: var(--accent-em);
  }
  .logo-mark path {
    fill: currentColor;
  }
  .nav.nav--compact .nav__logo .logo-mark:not(.logo-x) {
    display: none;
  }
  .nav.nav--compact .nav__logo .logo-x {
    display: block;
  }
  .nav.nav--compact .nav__logo {
    color: var(--ink-muted);
  }

  .nav__menu {
    display: flex;
    align-items: center;
    gap: 44px;
    flex-shrink: 0;
  }
  .nav.nav--compact .nav__menu {
    gap: 1rem;
  }

  .nav a.nav__link,
  .nav a.nav__drawer-link {
    text-decoration: none;
    text-underline-offset: 0;
  }

  .nav__link {
    font-size: var(--fs-ui);
    font-weight: 500;
    color: var(--ink-soft);
    transition: color 0.3s ease;
    line-height: 1.35;
    letter-spacing: -0.005em;
  }
  .nav.nav--compact .nav__link {
    color: var(--brand-ink);
  }
  .nav__link.is-active {
    color: var(--accent);
  }
  .nav.nav--compact .nav__link.is-active {
    color: var(--accent);
  }
  @media (hover: hover) {
    .nav__link:hover {
      color: var(--accent);
    }
    .nav.nav--compact .nav__link:hover {
      color: var(--accent);
    }
  }

  .nav__hamburger {
    display: none;
    position: relative;
    width: 28px;
    height: 18px;
    padding: 0;
    flex-shrink: 0;
    color: var(--brand-ink);
  }
  .nav.nav--compact .nav__hamburger {
    color: var(--brand-ink);
  }
  .nav__hamburger span {
    position: absolute;
    left: auto;
    right: 0;
    height: 2px;
    border-radius: 1px;
    background: currentColor;
    transform-origin: right center;
    transition:
      transform 0.32s cubic-bezier(0.4, 0, 0.2, 1),
      opacity 0.22s ease,
      top 0.32s cubic-bezier(0.4, 0, 0.2, 1),
      width 0.26s cubic-bezier(0.4, 0, 0.2, 1);
  }
  .nav__hamburger span:nth-child(1) {
    top: 0;
    width: 58%;
  }
  .nav__hamburger span:nth-child(2) {
    top: 8px;
    width: 82%;
  }
  .nav__hamburger span:nth-child(3) {
    top: 16px;
    width: 100%;
  }
  .nav__hamburger[aria-expanded="true"] span:nth-child(1) {
    top: 8px;
    width: 100%;
    transform-origin: center;
    transform: rotate(45deg);
  }
  .nav__hamburger[aria-expanded="true"] span:nth-child(2) {
    opacity: 0;
    transform: scaleX(0);
  }
  .nav__hamburger[aria-expanded="true"] span:nth-child(3) {
    top: 8px;
    width: 100%;
    transform-origin: center;
    transform: rotate(-45deg);
  }

  .nav__drawer {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 55;
    pointer-events: none;
  }
  .nav__drawer-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(14, 23, 38, 0.18);
    opacity: 0;
    transition: opacity 0.28s ease;
    cursor: pointer;
  }
  .nav__drawer-panel {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(100%, 380px);
    padding: calc(140px + env(safe-area-inset-top, 0px)) var(--pad-x) 48px;
    padding-left: 32px;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0;
    text-align: right;
    background: var(--blue-mist);
    box-shadow: -16px 0 48px rgba(14, 23, 38, 0.12);
    transform: translateX(100%);
    transition: transform 0.34s cubic-bezier(0.4, 0, 0.2, 1);
  }
  .nav__drawer-main {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    width: 100%;
  }
  .nav__drawer-footer {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    width: 100%;
    margin-top: auto;
  }
  .nav__drawer-main .nav__drawer-link {
    font-family: var(--body);
  }
  .nav__drawer-footer .nav__drawer-link {
    font-family: var(--sans);
    font-size: var(--fs-ui);
    letter-spacing: -0.005em;
    padding-block: clamp(14px, 3.5vw, 20px);
  }
  .nav__drawer-link {
    position: relative;
    font-size: var(--fs-ui-lg);
    font-weight: 500;
    letter-spacing: -0.02em;
    color: var(--ink);
    line-height: 1.2;
    align-self: stretch;
    text-align: right;
    padding-block: clamp(20px, 5vw, 28px);
    transition: color 0.2s ease;
  }
  .nav__drawer-main .nav__drawer-link + .nav__drawer-link::before,
  .nav__drawer-footer .nav__drawer-link + .nav__drawer-link::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: min(100%, 50vw);
    height: 1px;
    background: var(--hairline);
  }
  .nav__drawer-link:focus-visible,
  .nav__drawer-link.is-active {
    color: var(--accent);
  }
  @media (hover: hover) {
    .nav__drawer-link:hover {
      color: var(--accent);
    }
  }
  .nav__drawer.nav__drawer--open {
    pointer-events: auto;
  }
  .nav__drawer.nav__drawer--open .nav__drawer-backdrop {
    opacity: 1;
  }
  .nav__drawer.nav__drawer--open .nav__drawer-panel {
    transform: translateX(0);
  }
  body.is-mobile-menu-open {
    overflow: hidden;
  }

  @media (max-width: 900px) {
    .nav__logo .logo-mark:not(.logo-x) {
      height: 21px;
      max-width: min(64vw, 340px);
    }
    .nav__logo .logo-x {
      height: 18px;
    }

    .nav.nav--menu-open .nav__logo .logo-mark:not(.logo-x) {
      display: block;
    }
    .nav.nav--menu-open .nav__logo .logo-x {
      display: none;
    }
    .nav.nav--menu-open .nav__logo {
      color: var(--accent-em);
    }
    .nav.nav--menu-open .nav__hamburger {
      color: var(--brand-ink);
    }

    .nav__menu {
      display: none;
    }
    .nav__hamburger {
      display: block;
    }
    .nav__drawer {
      display: block;
    }
    .nav.nav--menu-open {
      z-index: 60;
    }
    .nav.nav--menu-open.nav--chrome-locked .nav__inner {
      width: 0;
      height: 0;
      min-height: 0;
      overflow: visible;
      padding: 0;
      margin: 0;
      background: transparent;
      border: none;
      box-shadow: none;
      gap: 0;
    }
    .nav.nav--menu-open.nav--chrome-locked .nav__hamburger,
    .nav.nav--menu-open.nav--chrome-locked .nav__logo {
      position: fixed;
      top: var(--nav-chrome-center);
      transform: translateY(-50%);
      z-index: 61;
    }
    .nav.nav--menu-open.nav--chrome-locked .nav__hamburger {
      right: var(--nav-hamburger-right);
    }
    .nav.nav--menu-open.nav--chrome-locked .nav__logo {
      left: var(--nav-hamburger-right);
      display: inline-flex;
      align-items: center;
      justify-content: flex-start;
    }
    @media (hover: hover) {
      .nav.nav--menu-open.nav--chrome-locked .nav__logo:hover {
        transform: translateY(-50%) scale(1.05);
      }
    }
    .nav.nav--menu-open.nav--chrome-locked .nav__logo:focus-visible {
      transform: translateY(-50%) scale(1.05);
    }

    .nav__drawer-panel {
      width: 100%;
      max-width: none;
      padding-left: var(--pad-x);
      padding-right: var(--nav-drawer-inline-end, var(--pad-x));
      background: linear-gradient(
        to top,
        var(--blue-mist) 0%,
        color-mix(in srgb, var(--blue-mist) 45%, #ffffff) 42%,
        #ffffff 100%
      );
      box-shadow: none;
    }
    .nav__drawer-main .nav__drawer-link {
      font-size: clamp(22px, 1.35vw + 16px, 28px);
    }

    .nav.nav--compact .nav__inner {
      gap: 18px;
      padding: 12px 18px 12px 16px;
    }
  }
}
