/* Top floating navbar — full-width content, pill nav on desktop */

:root {
  --top-nav-float-gap: max(0.5rem, env(safe-area-inset-top, 0px));
  --top-nav-contact-height: 2.15rem;
  --top-nav-primary-height: 4.5rem;
  --top-nav-secondary-height: 0px;
  --top-nav-shell-height: calc(
    var(--top-nav-contact-height) + var(--top-nav-primary-height)
  );
  --top-nav-pill-pad-y: 0.9rem;
  --top-nav-pill-inner: 2.35rem;
  --top-nav-pill-height: calc(var(--top-nav-pill-pad-y) + var(--top-nav-pill-inner));
  --top-nav-gap-below: 0;
  --top-nav-offset: var(--top-nav-shell-height);
  /* legacy alias */
  --top-nav-bar-height: var(--top-nav-primary-height);
  --top-nav-mobile-height: calc(
    var(--top-nav-contact-height) + var(--top-nav-primary-height) + var(--top-nav-float-gap)
  );
  /* JustFoodForDogs-inspired palette */
  --top-nav-font: "Avenir LT Std", sans-serif;
  --top-nav-brand-teal: #003b49;
  --top-nav-brand-teal-hover: #002a33;
  --top-nav-utility-bg: #003b49;
  --top-nav-bar-bg: #ffffff;
  --top-nav-ink: #003b49;
  --top-nav-muted: rgba(0, 59, 73, 0.62);
  --top-nav-border: rgba(0, 59, 73, 0.12);
  --top-nav-accent: #003b49;
  --top-nav-dark: var(--top-nav-bar-bg);
  --top-nav-dark-secondary: var(--top-nav-bar-bg);
  --top-nav-cta-radius: 0.375rem;
  --top-nav-logo-height: 3.35rem;
}

nav.navbar {
  border: none;
  box-shadow: none;
}

/* —— Base: fixed top strip (mobile/tablet) —— */
nav.navbar.navbar--top-float:not(.navbar--two-tier) {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  padding: 0;
  z-index: 1044;
  background: #ffffff !important;
  background-image: none !important;
  box-shadow: 0 1px 0 rgba(162, 222, 216, 0.35);
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
}

nav.navbar.navbar--top-float.scrolled {
  background: #ffffff !important;
  background-image: none !important;
  box-shadow: 0 2px 12px rgba(74, 143, 132, 0.08);
}

body:has(.navbar--top-float:not(.navbar--two-tier)) {
  padding-left: 0;
  /* padding-top: var(--top-nav-mobile-height); */
  overflow-x: clip;
  max-width: 100%;
}

nav.navbar.navbar--top-float:not(.navbar--two-tier) .navbar-topbar {
  width: 100%;
  margin: 0;
  padding: var(--top-nav-float-gap) 0.85rem 0.65rem !important;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  box-shadow: none;
}

.top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .navbar-topbar {
  width: auto !important;
  max-width: none;
  flex: 0 0 auto;
  margin: 0;
  padding: 0 !important;
  justify-content: flex-start;
}

nav.navbar.navbar--top-float .navbar-top-float__inner {
  width: 100%;
}

nav.navbar.navbar--top-float .navbar-topbar__brand {
  margin: 0;
  padding: 0;
  max-width: calc(100% - 3rem);
}

nav.navbar.navbar--top-float .navbar-topbar__brand.site-brand--jffd {
  max-width: none;
}

nav.navbar.navbar--top-float .navbar-toggler {
  display: none !important;
}

nav.navbar.navbar--top-float:not(.navbar--two-tier) .top-nav-menu,
nav.navbar.navbar--top-float:not(.navbar--two-tier) .top-nav-links {
  display: none !important;
}

/* —— Mobile / tablet: single-row top bar (legacy float nav only) —— */
@media (max-width: 1199.98px) {
  nav.navbar.navbar--top-float:not(.navbar--two-tier) .navbar-top-float__inner {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    min-height: calc(2.85rem + var(--top-nav-float-gap));
    padding:
      var(--top-nav-float-gap)
      max(0.85rem, env(safe-area-inset-right, 0px))
      0.65rem
      max(0.85rem, env(safe-area-inset-left, 0px));
    box-sizing: border-box;
  }

  nav.navbar.navbar--top-float:not(.navbar--two-tier) .navbar-topbar {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: auto;
    max-width: min(12rem, calc(100% - 7.5rem));
    padding: 0 !important;
    margin: 0;
    justify-content: center;
    pointer-events: none;
    z-index: 1;
  }

  nav.navbar.navbar--top-float:not(.navbar--two-tier) .navbar-topbar__brand,
  nav.navbar.navbar--top-float:not(.navbar--two-tier) .navbar-topbar__brand a {
    pointer-events: auto;
  }

  nav.navbar.navbar--top-float:not(.navbar--two-tier) .navbar-topbar__brand {
    max-width: 100%;
    margin: 0 auto;
  }

  nav.navbar.navbar--top-float .top-nav-actions {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin: 0 0 0 auto;
    flex-shrink: 0;
  }

  nav.navbar.navbar--top-float .top-nav-social {
    display: none !important;
  }

  nav.navbar.navbar--top-float .top-nav-book-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2rem;
    padding: 0.38rem 0.72rem;
    border-radius: var(--top-nav-cta-radius);
    border: 1px solid #5a9e94;
    background: linear-gradient(145deg, #7ec9bf 0%, #5a9e94 58%, #4a8f84 100%);
    color: #fff !important;
    font-family: var(--ds-font-nav, 'Avenir LT Std', sans-serif);
    font-size: 0.58rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    text-decoration: none !important;
    white-space: nowrap;
    line-height: 1.2;
    box-shadow: 0 3px 12px rgba(74, 143, 132, 0.22);
    transition: filter 0.18s ease, box-shadow 0.18s ease;
  }

  nav.navbar.navbar--top-float .top-nav-book-cta:hover,
  nav.navbar.navbar--top-float .top-nav-book-cta:focus-visible {
    color: #fff !important;
    filter: brightness(1.03);
    box-shadow: 0 4px 14px rgba(74, 143, 132, 0.28);
  }
}

@media (max-width: 359px) {
  nav.navbar.navbar--top-float .top-nav-actions {
    display: none !important;
  }

  nav.navbar.navbar--top-float:not(.navbar--two-tier) .navbar-topbar {
    position: static;
    transform: none;
    max-width: 100%;
    width: 100%;
    pointer-events: auto;
  }

  nav.navbar.navbar--top-float .navbar-top-float__inner {
    justify-content: center;
  }
}

/* —— Nav links (shared) —— */
.navbar .nav-item .nav-link.active {
  background: transparent !important;
  color: #4a8f84 !important;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-color: rgba(162, 222, 216, 0.95);
}

.navbar .nav-link:hover,
.navbar .nav-link:focus-visible:not(.top-nav-book-cta):not(.top-nav-social__link) {
  background: transparent !important;
  color: #4a8f84 !important;
}

/* Kill legacy style.css black pill on top-float nav (hover/focus/active) */
nav.navbar.navbar--top-float .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link),
nav.navbar.navbar--top-float .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):hover,
nav.navbar.navbar--top-float .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):focus,
nav.navbar.navbar--top-float .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):focus-visible,
nav.navbar.navbar--top-float .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link).active {
  background: transparent !important;
  color: var(--top-nav-accent, #4a8f84) !important;
  text-transform: none;
}

nav.navbar.navbar--top-float .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link).active {
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-color: rgba(162, 222, 216, 0.95);
}

nav.navbar.navbar--top-float .nav-link--dropdown-toggle:hover,
nav.navbar.navbar--top-float .nav-link--dropdown-toggle:focus,
nav.navbar.navbar--top-float .nav-link--dropdown-toggle:focus-visible {
  background: rgba(162, 222, 216, 0.15) !important;
  color: var(--top-nav-accent, #4a8f84) !important;
}

body:has(.hero-split) nav.navbar.navbar--top-float:not(.scrolled) .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link),
body:has(.hero-split) nav.navbar.navbar--top-float:not(.scrolled) .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):hover,
body:has(.hero-split) nav.navbar.navbar--top-float:not(.scrolled) .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):focus,
body:has(.hero-split) nav.navbar.navbar--top-float:not(.scrolled) .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):focus-visible {
  color: var(--top-nav-ink, #1a1416) !important;
  background: transparent !important;
}

body:has(.hero-split) nav.navbar.navbar--top-float:not(.scrolled) .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link).active,
body:has(.hero-split) nav.navbar.navbar--top-float:not(.scrolled) .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):hover,
body:has(.hero-split) nav.navbar.navbar--top-float:not(.scrolled) .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):focus-visible {
  color: var(--top-nav-accent, #4a8f84) !important;
}

body:has(.hero-split) nav.navbar:not(.scrolled) a.navbar-brand,
body:has(.hero-split) nav.navbar:not(.scrolled) .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link) {
  color: #1a1a1a !important;
}

body:has(.hero-split) nav.navbar:not(.scrolled) .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link).active {
  background: transparent !important;
  color: #4a8f84 !important;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-color: rgba(162, 222, 216, 0.95);
}

body:has(.hero-split) nav.navbar:not(.scrolled) .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):hover,
body:has(.hero-split) nav.navbar:not(.scrolled) .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):focus-visible {
  color: #4a8f84 !important;
  background: transparent !important;
}

body:has(.hero-split) nav.navbar:not(.scrolled) .top-nav-book-cta,
body:has(.hero-split) nav.navbar:not(.scrolled) .top-nav-book-cta:hover,
body:has(.hero-split) nav.navbar:not(.scrolled) .top-nav-book-cta:focus-visible {
  color: #fff !important;
}

/* —— Desktop: floating pill navbar —— */
@media (min-width: 1200px) {
  body:has(.navbar--top-float:not(.navbar--two-tier)) {
    padding-left: 0;
    padding-top: var(--top-nav-offset);
    overflow-x: clip;
  }

  /* Home — tuck hero directly under the floating pill */
  body:has(.navbar--top-float):has(.hero-split--home):not(:has(.hero-split--booking)) {
    padding-top: 0;
  }

  body:has(.navbar--top-float):has(.hero-split--home):not(:has(.hero-split--booking)) #site-main,
  body:has(.navbar--top-float):has(.hero-split--home):not(:has(.hero-split--booking)) #spa-home-prerender,
  body:has(.navbar--top-float):has(.hero-split--home):not(:has(.hero-split--booking)) #app {
    margin-top: 0;
    padding-top: 0;
  }

  body:has(.navbar--top-float):has(.hero-split--home):not(:has(.hero-split--booking)) .hero-split--home.hero_sec.hero-split {
    margin-top: 0;
  }

  nav.navbar.navbar--top-float {
    top: var(--top-nav-float-gap);
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    width: min(calc(100% - 1.5rem), 88rem);
    height: auto;
    min-height: var(--top-nav-pill-inner);
    z-index: 1030;
    display: block;
    padding: 0.45rem 0.55rem 0.45rem 0.7rem;
    background: #ffffff !important;
    background-image: none !important;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border: 1px solid rgba(162, 222, 216, 0.5);
    border-radius: 999px;
    overflow: visible;
    box-shadow: 0 4px 24px rgba(74, 143, 132, 0.08);
    transition:
      background 0.22s ease,
      box-shadow 0.22s ease,
      border-color 0.22s ease;
  }

  nav.navbar.navbar--top-float:not(.navbar--two-tier) .navbar-top-float__inner {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 0.75rem;
    width: 100%;
    min-width: 0;
  }

  nav.navbar.navbar--top-float:not(.navbar--two-tier) .navbar-topbar {
    grid-column: 1;
    flex: 0 0 auto;
    width: auto;
    padding: 0 !important;
    margin: 0;
    justify-content: flex-start;
  }

  nav.navbar.navbar--top-float:not(.navbar--two-tier) .navbar-topbar__brand {
    max-width: none;
    margin-right: 0;
  }

  nav.navbar.navbar--top-float:not(.navbar--two-tier) .navbar-topbar__brand.site-brand--nav:not(.site-brand--jffd) {
    gap: 0.42rem;
    align-items: center;
    min-width: 0;
  }

  nav.navbar.navbar--top-float:not(.navbar--two-tier) .navbar-topbar__brand.site-brand--jffd.site-brand--nav {
    flex-shrink: 0;
    min-width: auto;
    max-width: none;
  }

  nav.navbar.navbar--top-float:not(.navbar--two-tier) .navbar-topbar__brand .site-brand__mark-img {
    width: 2.15rem !important;
    height: auto !important;
    flex-shrink: 0;
    align-self: center;
  }

  nav.navbar.navbar--top-float:not(.navbar--two-tier) .top-nav-links {
    grid-column: 2;
    display: flex !important;
    align-items: center;
    justify-content: center;
    min-width: 0;
    padding: 0;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
  }

  nav.navbar.navbar--top-float .top-nav-menu {
    display: none !important;
  }

  nav.navbar.navbar--top-float:not(.navbar--two-tier) .top-nav-actions {
    grid-column: 3;
    display: flex;
    align-items: center;
    flex: 0 0 auto;
    gap: 0.45rem;
    margin: 0;
    padding: 0;
    border-left: none;
  }

  nav.navbar.navbar--top-float .navbar-nav {
    display: flex !important;
    flex: 0 1 auto;
    flex-direction: row !important;
    align-items: center;
    justify-content: center;
    flex-wrap: nowrap;
    gap: 0.2rem;
    margin: 0 !important;
    padding: 0;
    min-width: 0;
    width: auto;
    max-width: 100%;
    border-top: none;
    overflow: visible;
  }

  nav.navbar.navbar--top-float.scrolled {
    background: #ffffff !important;
    background-image: none !important;
    box-shadow: 0 6px 28px rgba(74, 143, 132, 0.1);
    border-color: rgba(162, 222, 216, 0.55);
  }

  nav.navbar.navbar--top-float .sidebar-nav-label {
    display: none !important;
  }

  nav.navbar.navbar--top-float .nav-item {
    flex: 0 0 auto;
    width: auto;
    position: relative;
  }

  nav.navbar.navbar--top-float .nav-item--services {
    display: inline-flex;
    align-items: center;
    gap: 0;
  }

  nav.navbar.navbar--top-float .nav-link {
    display: inline-flex !important;
    align-items: center;
    width: auto;
    padding: 0.4rem 0.62rem !important;
    margin: 0 !important;
    border-radius: 999px;
    border: 1px solid transparent;
    text-align: center;
    font-family: var(--ds-font-nav, 'Avenir LT Std', sans-serif);
    font-size: 0.74rem !important;
    font-weight: 500;
    letter-spacing: 0.01em;
    line-height: 1.2;
    white-space: nowrap;
    color: var(--top-nav-ink) !important;
    text-transform: none;
    transition:
      background 0.18s ease,
      color 0.18s ease,
      border-color 0.18s ease,
      box-shadow 0.18s ease;
  }

  nav.navbar.navbar--top-float .nav-item .nav-link.active {
    background: transparent !important;
    border-color: transparent !important;
    color: var(--top-nav-accent) !important;
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 4px;
    text-decoration-color: rgba(162, 222, 216, 0.95);
    box-shadow: none;
  }

  nav.navbar.navbar--top-float .nav-link:hover,
  nav.navbar.navbar--top-float .nav-link:focus-visible {
    background: transparent !important;
    border-color: transparent !important;
    color: var(--top-nav-accent) !important;
  }

  nav.navbar.navbar--top-float .nav-item--dropdown > .nav-link--trigger {
    gap: 0.35rem;
    padding-right: 0.35rem !important;
  }

  nav.navbar.navbar--top-float .nav-item--services > .nav-link--services-link {
    padding-right: 0.25rem !important;
  }

  nav.navbar.navbar--top-float .nav-item--services > .nav-link--dropdown-toggle {
    min-width: 1.45rem;
    padding-left: 0.2rem !important;
    padding-right: 0.45rem !important;
    margin-left: -0.2rem !important;
    cursor: pointer;
    justify-content: center;
  }

  nav.navbar.navbar--top-float .nav-link--trigger__label {
    max-width: 8.5rem;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  nav.navbar.navbar--top-float .nav-link--trigger {
    appearance: none;
    -webkit-appearance: none;
    background: transparent;
    border: 1px solid transparent;
    font: inherit;
  }

  nav.navbar.navbar--top-float a.nav-link--trigger {
    appearance: auto;
    -webkit-appearance: auto;
  }

  nav.navbar.navbar--top-float .nav-link--trigger__chev {
    width: 0.55rem;
    height: 0.55rem;
    opacity: 0.55;
    transition: transform 0.18s ease, opacity 0.18s ease;
  }

  nav.navbar.navbar--top-float .nav-item--dropdown:hover .nav-link--trigger__chev,
  nav.navbar.navbar--top-float .nav-item--dropdown:focus-within .nav-link--trigger__chev,
  nav.navbar.navbar--top-float .nav-item--dropdown.is-open .nav-link--trigger__chev {
    transform: rotate(180deg);
    opacity: 0.85;
  }

  nav.navbar.navbar--top-float .top-nav-dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 0.45rem);
    left: 50%;
    transform: translateX(-50%);
    min-width: 12.5rem;
    margin: 0;
    padding: 0.45rem;
    list-style: none;
    flex-direction: column;
    gap: 0.1rem;
    background: #ffffff;
    border: 1px solid rgba(162, 222, 216, 0.45);
    border-radius: 0.9rem;
    box-shadow: 0 12px 32px rgba(74, 143, 132, 0.12);
    z-index: 1060;
  }

  nav.navbar.navbar--top-float .top-nav-dropdown__head {
    padding: 0.2rem 0.55rem 0.35rem;
    font-family: var(--ds-font-nav, 'Avenir LT Std', sans-serif);
    font-size: 0.58rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--top-nav-muted);
    list-style: none;
  }

  nav.navbar.navbar--top-float .nav-item--dropdown:hover .top-nav-dropdown,
  nav.navbar.navbar--top-float .nav-item--dropdown:focus-within .top-nav-dropdown,
  nav.navbar.navbar--top-float .nav-item--dropdown.is-open .top-nav-dropdown {
    display: flex;
  }

  nav.navbar.navbar--top-float .top-nav-dropdown > li:not(.top-nav-dropdown__head) {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  nav.navbar.navbar--top-float .top-nav-dropdown .nav-link {
    width: 100%;
    justify-content: flex-start;
    text-align: left;
    font-size: 0.76rem !important;
    padding: 0.48rem 0.7rem !important;
    border-radius: 0.6rem;
    text-transform: none;
  }

  nav.navbar.navbar--top-float .top-nav-dropdown .nav-link.active {
    background: rgba(162, 222, 216, 0.25) !important;
    border-color: transparent !important;
    color: var(--top-nav-accent) !important;
    text-decoration: none;
  }

  nav.navbar.navbar--top-float {
    overflow: visible;
  }

  nav.navbar.navbar--top-float .navbar-top-float__inner {
    overflow: visible;
  }

  nav.navbar.navbar--top-float .top-nav-book-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.15rem;
    padding: 0.45rem 0.95rem;
    border-radius: var(--top-nav-cta-radius);
    border: 1px solid #5a9e94;
    background: linear-gradient(145deg, #7ec9bf 0%, #5a9e94 58%, #4a8f84 100%);
    color: #fff !important;
    font-family: var(--ds-font-nav, 'Avenir LT Std', sans-serif);
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none !important;
    white-space: nowrap;
    line-height: 1.2;
    box-shadow: 0 4px 14px rgba(74, 143, 132, 0.22);
    transition:
      transform 0.18s ease,
      box-shadow 0.18s ease,
      filter 0.18s ease;
  }

  nav.navbar.navbar--top-float .top-nav-book-cta:hover,
  nav.navbar.navbar--top-float .top-nav-book-cta:focus-visible {
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(74, 143, 132, 0.28);
    filter: brightness(1.02);
  }

  nav.navbar.navbar--top-float .top-nav-social {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    background: transparent;
  }

  nav.navbar.navbar--top-float .top-nav-social__link {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 2.1rem !important;
    height: 2.1rem;
    padding: 0 !important;
    border-radius: 999px;
    border: 1px solid rgba(162, 222, 216, 0.55);
    background: #ffffff !important;
    color: var(--top-nav-ink) !important;
    text-decoration: none !important;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
  }

  nav.navbar.navbar--top-float .top-nav-social__link i {
    font-size: 0.85rem !important;
    line-height: 1;
    color: inherit !important;
  }

  nav.navbar.navbar--top-float .top-nav-social__link:hover,
  nav.navbar.navbar--top-float .top-nav-social__link:focus-visible {
    background: rgba(162, 222, 216, 0.2) !important;
    color: #4a8f84 !important;
    border-color: rgba(162, 222, 216, 0.85);
  }

  body:has(.navbar--top-float) .membership-float-badge {
    left: 1rem;
    max-width: min(360px, calc(100vw - 2rem));
  }
}

/* —— Two-tier dark shell (contact bar + primary + secondary) —— */
.top-nav-shell {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1044;
  width: 100%;
  font-family: "Avenir LT Std", sans-serif !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.top-nav-contact-bar {
  background: var(--top-nav-utility-bg);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.top-nav-contact-bar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: min(100%, 88rem);
  min-height: var(--top-nav-contact-height);
  margin: 0 auto;
  padding: 0.35rem max(1rem, env(safe-area-inset-right, 0px)) 0.35rem max(1rem, env(safe-area-inset-left, 0px));
  box-sizing: border-box;
}

.top-nav-contact-bar__links {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 0.35rem 1.15rem;
}

.top-nav-contact-bar__social {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  flex-shrink: 0;
}

.top-nav-contact-bar__link {
  display: inline-flex;
  align-items: center;
  gap: 0.38rem;
  font-family: var(--top-nav-font);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #fff !important;
  text-decoration: none;
  white-space: nowrap;
  transition: opacity 0.18s ease;
}

.top-nav-contact-bar__link:hover,
.top-nav-contact-bar__link:focus-visible {
  opacity: 0.86;
  color: #fff !important;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.top-nav-contact-bar__link i {
  font-size: 0.62rem;
  opacity: 0.92;
}

.top-nav-contact-bar .top-nav-social__link {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 1.65rem !important;
  height: 1.65rem;
  padding: 0 !important;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(255, 255, 255, 0.08) !important;
  color: #fff !important;
  text-decoration: none !important;
  transition: background 0.18s ease, border-color 0.18s ease;
}

.top-nav-contact-bar .top-nav-social__link:hover,
.top-nav-contact-bar .top-nav-social__link:focus-visible {
  background: rgba(255, 255, 255, 0.18) !important;
  border-color: rgba(255, 255, 255, 0.55);
  color: #fff !important;
}

.top-nav-contact-bar .top-nav-social__link i {
  font-size: 0.78rem !important;
  color: inherit !important;
}

.top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier {
  position: relative;
  top: auto;
  left: auto;
  right: auto;
  transform: none;
  width: 100%;
  min-height: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  overflow: visible;
  background: transparent !important;
  box-shadow: none !important;
}

.top-nav-tier {
  width: 100%;
}

.top-nav-tier--primary {
  background: var(--top-nav-bar-bg);
  border-bottom: 1px solid var(--top-nav-border);
  box-shadow: 0 1px 0 rgba(0, 59, 73, 0.06);
}

.top-nav-tier__inner {
  display: flex;
  align-items: center;
  width: min(100%, 88rem);
  min-height: var(--top-nav-primary-height);
  margin: 0 auto;
  padding: 0 max(1rem, env(safe-area-inset-right, 0px)) 0 max(1rem, env(safe-area-inset-left, 0px));
  box-sizing: border-box;
}

.top-nav-shell .top-nav-tier--primary .top-nav-tier__inner {
  display: flex;
  align-items: center;
  gap: clamp(1rem, 2.5vw, 2.25rem);
}

.top-nav-shell .top-nav-tier--primary .navbar-topbar {
  flex: 0 0 auto;
  grid-column: auto;
  width: auto;
  padding: 0 !important;
  margin: 0;
  justify-content: flex-start;
  display: flex;
  align-items: center;
  align-self: center;
}

.top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .top-nav-links {
  flex: 1 1 auto;
  grid-column: auto;
  align-items: center;
  justify-content: center;
  min-width: 0;
  width: auto;
  padding: 0;
  background: transparent !important;
}

.top-nav-shell .top-nav-tier--primary .top-nav-actions {
  flex: 0 0 auto;
  grid-column: auto;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin: 0 0 0 auto;
}

.top-nav-shell .top-nav-book-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.75rem;
  padding: 0.75rem 1.35rem;
  border-radius: var(--top-nav-cta-radius);
  border: none;
  background: var(--top-nav-brand-teal) !important;
  color: #fff !important;
  font-family: var(--top-nav-font);
  font-size: 1.125rem;
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: none;
  text-decoration: none !important;
  white-space: nowrap;
  line-height: 1;
  box-shadow: none !important;
  transition: background 0.18s ease;
}

.top-nav-book-cta__label--short {
  display: none;
}

.top-nav-shell .top-nav-book-cta:hover,
.top-nav-shell .top-nav-book-cta:focus-visible {
  color: #fff !important;
  background: var(--top-nav-brand-teal-hover) !important;
  transform: none;
}

.top-nav-shell .top-nav-tier--primary .top-nav-social {
  display: none !important;
}

.top-nav-shell .top-nav-links {
  align-items: center;
  width: auto;
  flex: 1 1 auto;
  min-width: 0;
  padding: 0;
  background: transparent !important;
}

.top-nav-shell .navbar-nav {
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  flex-wrap: nowrap;
  gap: clamp(0.85rem, 1.8vw, 1.75rem);
  margin: 0 !important;
  padding: 0;
  width: auto;
  max-width: 100%;
  overflow-x: auto;
  scrollbar-width: none;
}

.top-nav-shell .navbar-nav::-webkit-scrollbar {
  display: none;
}

.top-nav-shell .nav-item {
  flex: 0 0 auto;
  position: relative;
}

.top-nav-shell .nav-link {
  display: inline-flex !important;
  align-items: center;
  padding: 0.35rem 0 !important;
  margin: 0 !important;
  border-radius: 0;
  border: none;
  font-family: var(--top-nav-font);
  font-size: 1.25rem !important;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: none;
  line-height: 1;
  white-space: nowrap;
  color: var(--top-nav-brand-teal) !important;
  background: transparent !important;
  text-decoration: none !important;
  transition: color 0.18s ease;
}

.top-nav-shell .nav-item .nav-link.active {
  color: var(--top-nav-brand-teal) !important;
  font-weight: 800;
  text-decoration: none !important;
  background: transparent !important;
}

.top-nav-shell .nav-link:hover,
.top-nav-shell .nav-link:focus-visible:not(.top-nav-book-cta):not(.top-nav-social__link) {
  color: var(--top-nav-brand-teal-hover) !important;
  background: transparent !important;
  opacity: 1;
  text-decoration: none !important;
}

.top-nav-shell .nav-item--services {
  display: inline-flex;
  align-items: center;
}

.top-nav-shell .nav-item--services > .nav-link--services-link {
  padding-right: 0.15rem !important;
}

.top-nav-shell .nav-link--dropdown-toggle {
  min-width: auto;
  padding-left: 0.1rem !important;
  padding-right: 0 !important;
  margin-left: -0.15rem !important;
  cursor: pointer;
}

.top-nav-shell .nav-link--trigger__chev {
  width: 0.55rem;
  height: 0.55rem;
  margin-left: 0.2rem;
  opacity: 0.75;
  transition: transform 0.18s ease;
}

.top-nav-shell .nav-item--dropdown:hover .nav-link--trigger__chev,
.top-nav-shell .nav-item--dropdown:focus-within .nav-link--trigger__chev,
.top-nav-shell .nav-item--dropdown.is-open .nav-link--trigger__chev {
  transform: rotate(180deg);
}

.top-nav-shell .top-nav-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 0.35rem);
  left: 0;
  transform: none;
  min-width: 13rem;
  margin: 0;
  padding: 0.45rem;
  list-style: none;
  flex-direction: column;
  gap: 0.08rem;
  background: #fff;
  border: 1px solid rgba(0, 59, 73, 0.12);
  border-radius: 0.75rem;
  box-shadow: 0 14px 36px rgba(0, 59, 73, 0.12);
  z-index: 1060;
}

.top-nav-shell .top-nav-dropdown__head {
  padding: 0.2rem 0.55rem 0.35rem;
  font-size: 0.56rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--top-nav-muted);
  list-style: none;
}

.top-nav-shell .nav-item--dropdown:hover .top-nav-dropdown,
.top-nav-shell .nav-item--dropdown:focus-within .top-nav-dropdown,
.top-nav-shell .nav-item--dropdown.is-open .top-nav-dropdown {
  display: flex;
}

.top-nav-shell .top-nav-dropdown .nav-link {
  width: 100%;
  justify-content: flex-start;
  text-align: left;
  font-family: var(--top-nav-font);
  font-size: 1rem !important;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: none;
  padding: 0.48rem 0.7rem !important;
  border-radius: 0.5rem;
  color: var(--top-nav-brand-teal) !important;
}

.top-nav-shell .top-nav-dropdown .nav-link.active,
.top-nav-shell .top-nav-dropdown .nav-link:hover {
  background: rgba(0, 59, 73, 0.06) !important;
  color: var(--top-nav-brand-teal-hover) !important;
}

body:has(.top-nav-shell) {
  padding-top: var(--top-nav-offset);
}

body:has(.top-nav-shell) nav.navbar.navbar--top-float {
  position: relative;
  top: auto;
  left: auto;
  right: auto;
  transform: none;
  width: 100%;
  background: transparent !important;
  box-shadow: none !important;
}

@media (min-width: 1200px) {
  body:has(.top-nav-shell):has(.navbar--top-float) {
    padding-top: var(--top-nav-offset);
  }

  body:has(.top-nav-shell):has(.navbar--top-float):has(.hero-split--home):not(:has(.hero-split--booking)) {
    padding-top: var(--top-nav-offset);
  }

  body:has(.top-nav-shell):has(.navbar--top-float):has(.hero-split--home):not(:has(.hero-split--booking)) #site-main,
  body:has(.top-nav-shell):has(.navbar--top-float):has(.hero-split--home):not(:has(.hero-split--booking)) #spa-home-prerender,
  body:has(.top-nav-shell):has(.navbar--top-float):has(.hero-split--home):not(:has(.hero-split--booking)) #app {
    margin-top: 0;
    padding-top: 0;
  }
}

@media (max-width: 1199.98px) {
  :root {
    --top-nav-shell-height: calc(var(--top-nav-contact-height) + var(--top-nav-primary-height));
    --top-nav-offset: var(--top-nav-shell-height);
  }

  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .top-nav-links,
  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .navbar-collapse.top-nav-links {
    display: none !important;
    visibility: hidden !important;
    width: 0 !important;
    min-width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    pointer-events: none !important;
    flex: 0 0 0 !important;
  }

  .top-nav-shell .top-nav-links {
    display: none !important;
  }

  .top-nav-contact-bar__link span {
    font-size: 0.62rem;
  }

  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .top-nav-tier__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
    position: relative;
    min-height: calc(2.85rem + var(--top-nav-float-gap));
    padding-top: var(--top-nav-float-gap);
    padding-bottom: 0.65rem;
    padding-left: max(0.85rem, env(safe-area-inset-left, 0px));
    padding-right: max(0.85rem, env(safe-area-inset-right, 0px));
    box-sizing: border-box;
  }

  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .navbar-topbar {
    position: static !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    flex: 1 1 auto;
    flex-shrink: 1;
    min-width: 0;
    max-width: calc(100% - 6.5rem);
    justify-content: flex-start !important;
    align-items: center;
    pointer-events: auto;
    z-index: auto;
    margin: 0;
    width: auto;
    padding: 0 !important;
  }

  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .navbar-topbar__brand,
  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .navbar-topbar__brand a {
    margin: 0;
    max-width: 100%;
    justify-content: flex-start;
  }

  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .navbar-topbar__brand.site-brand--jffd {
    flex-shrink: 0;
    min-width: auto;
  }

  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .top-nav-actions {
    flex: 0 0 auto;
    margin-left: auto;
  }

  .top-nav-shell .top-nav-tier--primary .top-nav-social {
    display: none !important;
  }

  .top-nav-contact-bar__social {
    display: flex !important;
  }

  .top-nav-book-cta__label--short {
    display: none;
  }

  .top-nav-shell .top-nav-book-cta {
    min-height: 2.35rem;
    padding: 0.55rem 0.9rem;
    font-size: 0.875rem;
    font-weight: 800;
    background: var(--top-nav-brand-teal) !important;
    color: #fff !important;
    border: none !important;
    box-shadow: none !important;
  }
}

@media (max-width: 520px) {
  .top-nav-book-cta__label--full {
    display: none;
  }

  .top-nav-book-cta__label--short {
    display: inline;
  }

  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .navbar-topbar {
    max-width: calc(100% - 4.75rem);
  }

  .top-nav-shell .top-nav-book-cta {
    padding: 0.55rem 0.75rem;
    font-size: 0.8rem;
  }
}

@media (max-width: 420px) {
  .top-nav-contact-bar__links {
    gap: 0.25rem 0.65rem;
  }

  .top-nav-contact-bar__link span {
    max-width: 9.5rem;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .top-nav-contact-bar__inner {
    gap: 0.45rem;
  }
}

@media (min-width: 1200px) {
  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier {
    top: auto;
    left: auto;
    right: auto;
    transform: none;
    width: 100%;
    min-height: 0;
    padding: 0;
    border: none;
    border-radius: 0;
    background: transparent !important;
    box-shadow: none !important;
  }

  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .navbar-top-float__inner {
    display: flex !important;
    align-items: center;
    justify-content: flex-start;
    gap: clamp(1rem, 2vw, 1.75rem);
    width: 100%;
    min-width: 0;
  }

  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .navbar-topbar {
    flex: 0 0 auto !important;
    flex-shrink: 0;
    width: auto !important;
    max-width: none;
    min-width: auto;
    justify-content: flex-start !important;
    padding: 0 !important;
  }

  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .top-nav-links,
  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .navbar-collapse.top-nav-links {
    display: flex !important;
    flex: 1 1 auto;
    min-width: 0;
    justify-content: center;
    visibility: visible !important;
    height: auto !important;
    overflow: visible !important;
  }

  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .top-nav-actions {
    flex: 0 0 auto;
    margin-left: auto;
  }

  .top-nav-shell .nav-link {
    font-size: 1.05rem !important;
    font-weight: 500;
    letter-spacing: 0.02em;
    padding: 0.35rem 0.5rem !important;
  }

  .top-nav-shell .nav-item .nav-link.active {
    font-weight: 800;
  }

  .top-nav-shell .navbar-nav {
    justify-content: center;
    width: 100%;
    max-width: none;
    margin: 0 !important;
    gap: clamp(0.5rem, 1.2vw, 1.25rem);
  }

  .top-nav-shell nav.navbar.navbar--top-float .navbar-topbar__brand.site-brand--jffd.site-brand--nav {
    flex-shrink: 0;
    min-width: auto;
    max-width: none;
  }

  .top-nav-shell nav.navbar.navbar--top-float .navbar-topbar__brand.site-brand--jffd .site-brand__mark-img {
    width: 2.65rem !important;
    height: auto !important;
    flex-shrink: 0;
  }

  .top-nav-shell .top-nav-tier__inner {
    padding-left: max(1.25rem, env(safe-area-inset-left, 0px));
    padding-right: max(1.25rem, env(safe-area-inset-right, 0px));
  }

  .top-nav-shell .top-nav-book-cta {
    min-height: 2.5rem;
    padding: 0.65rem 1.15rem;
    font-size: 1rem !important;
  }
}

@media (max-width: 359px) {
  .top-nav-shell .top-nav-tier--primary .top-nav-actions {
    display: none !important;
  }

  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .navbar-topbar {
    position: static !important;
    transform: none !important;
    width: auto;
    max-width: 100%;
    pointer-events: auto;
    justify-content: flex-start !important;
  }

  .top-nav-shell nav.navbar.navbar--top-float.navbar--two-tier .top-nav-tier--primary .top-nav-tier__inner {
    justify-content: space-between;
  }
}

/* Kill legacy mint-teal nav rules inside JFFD shell */
.top-nav-shell nav.navbar.navbar--top-float .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link),
.top-nav-shell nav.navbar.navbar--top-float .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):hover,
.top-nav-shell nav.navbar.navbar--top-float .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):focus,
.top-nav-shell nav.navbar.navbar--top-float .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):focus-visible,
.top-nav-shell nav.navbar.navbar--top-float .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link).active,
.top-nav-shell .navbar .nav-item .nav-link.active,
.top-nav-shell .navbar .nav-link:hover,
.top-nav-shell .navbar .nav-link:focus-visible:not(.top-nav-book-cta):not(.top-nav-social__link) {
  color: var(--top-nav-brand-teal, #003b49) !important;
  background: transparent !important;
  text-decoration: none !important;
  text-transform: none;
  font-family: "Avenir LT Std", sans-serif !important;
}

.top-nav-shell nav.navbar.navbar--top-float .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link).active {
  font-weight: 800;
}

body:has(.top-nav-shell) nav.navbar.navbar--top-float .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link),
body:has(.top-nav-shell) nav.navbar:not(.scrolled) .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link),
body:has(.top-nav-shell):has(.hero-split) nav.navbar.navbar--top-float:not(.scrolled) .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link),
body:has(.top-nav-shell):has(.hero-split) nav.navbar:not(.scrolled) .nav-item .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link).active,
body:has(.top-nav-shell):has(.hero-split) nav.navbar:not(.scrolled) .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):hover,
body:has(.top-nav-shell):has(.hero-split) nav.navbar:not(.scrolled) .nav-link:not(.top-nav-book-cta):not(.top-nav-social__link):focus-visible {
  color: var(--top-nav-brand-teal, #003b49) !important;
  background: transparent !important;
  text-decoration: none !important;
}

.top-nav-shell nav.navbar.navbar--top-float .nav-link--dropdown-toggle:hover,
.top-nav-shell nav.navbar.navbar--top-float .nav-link--dropdown-toggle:focus,
.top-nav-shell nav.navbar.navbar--top-float .nav-link--dropdown-toggle:focus-visible {
  background: transparent !important;
  color: var(--top-nav-brand-teal-hover, #002a33) !important;
  font-family: "Avenir LT Std", sans-serif !important;
}
