/* =========================================================
   JSC COMPONENT CONTRACT
   File: jsc-nav.css
   Layer: Navigation System
   Version: 3.5

   Notes:
   - Mobile nav panel is fixed/hidden by default.
   - Desktop hides mobile panel and custom toggle explicitly.
   - Avoids fractional desktop breakpoint split.
   - Removes translateZ compositing from panel inner.
========================================================= */


/* =========================================================
   0) LOCAL NAV TOKENS
========================================================= */

/* #region LOCAL NAV TOKENS */

:root {
  --jsc-nav-top-desktop: calc(var(--jsc-box-5xl) + var(--jsc-space-md));
  --jsc-nav-top-tablet: calc(var(--jsc-box-4xl) + var(--jsc-space-md));
  --jsc-nav-top-tablet-scrolled: calc(68px + var(--jsc-space-md));
  --jsc-nav-top-mobile: calc(var(--jsc-box-4xl) + var(--jsc-space-xl));
  --jsc-nav-top-mobile-scrolled: calc(var(--jsc-box-4xl) + var(--jsc-space-xl));
  --jsc-header-blur: 12px;
}

/* #endregion LOCAL NAV TOKENS */


/* =========================================================
   1) BASE INTERACTION + PANEL SAFETY
========================================================= */

/* #region BASE INTERACTION + PANEL SAFETY */

header.jsc-header a[href],
header.jsc-header a[href] *,
header.jsc-header button,
header.jsc-header button * {
  cursor: pointer;
}

header.jsc-header .jsc-nav__menu a::before,
header.jsc-header .jsc-nav__menu a::after,
header.jsc-header .jsc-nav__toggle-btn::before,
header.jsc-header .jsc-nav__toggle-btn::after,
header.jsc-header .jsc-nav__overlay {
  pointer-events: none;
}

/* Keep the custom mobile panel out of document flow by default.
   This is the important Safari fix. */
header.jsc-header .jsc-nav__panel {
  position: fixed !important;
  top: var(--jsc-header-current-height, 88px) !important;
  left: 0 !important;
  right: 0 !important;
  z-index: var(--jsc-z-panel) !important;

  display: flex !important;
  justify-content: flex-start !important;
  width: 100%;
  height: auto;
  max-height: calc(100vh - var(--jsc-header-current-height, 88px));
  overflow: auto;

  padding-inline: var(--jsc-space-md);

  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(var(--jsc-space-sm, 12px)) scale(0.985);

  transition:
    top var(--jsc-med) var(--jsc-ease),
    opacity 260ms ease,
    visibility 260ms ease,
    transform 260ms ease;
}

html.jsc-nav-open header.jsc-header .jsc-nav__panel {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

header.jsc-header .jsc-nav__overlay {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

html.jsc-nav-open header.jsc-header .jsc-nav__overlay {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* Elementor’s built-in hamburger is not used. */
header.jsc-header .elementor-menu-toggle {
  display: none !important;
}

/* #endregion BASE INTERACTION + PANEL SAFETY */


/* =========================================================
   2) DESKTOP NAV
========================================================= */

/* #region DESKTOP NAV */

@media (min-width: 1200px) {
  header.jsc-header .jsc-nav.jsc-nav--desktop {
    justify-self: center;
  }

  header.jsc-header .jsc-nav__menu--desktop ul {
    display: flex;
    align-items: center;
    gap: 44px;
  }

  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop a {
    position: relative;
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
    padding: 0 var(--jsc-space-md);
    color: var(--jsc-link);
    font-size: 18px;
    font-weight: 400;
    letter-spacing: 0.04em;
    line-height: 1.4;
    text-decoration: none;
    opacity: var(--jsc-o-88);
    transition:
      opacity var(--jsc-fast) ease,
      letter-spacing var(--jsc-med) ease,
      color var(--jsc-fast) ease;
  }

  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop a:hover,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop a:focus-visible {
    color: var(--jsc-link-hover);
  }

  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop a:hover,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop a:focus-visible,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop a.current-menu-item,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop .current-menu-item > a,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop .current-menu-ancestor > a,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop .current_page_item > a {
    opacity: 1;
    letter-spacing: 0.02em;
  }

  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop a.current-menu-item,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop .current-menu-item > a,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop .current-menu-ancestor > a,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop .current_page_item > a {
    color: var(--jsc-link-active);
  }

  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop a:focus-visible {
    outline: var(--jsc-outline-w) solid var(--jsc-text-on-light);
    outline-offset: 3px;
    border-radius: var(--jsc-radius-2xs, 2px);
  }

  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop a::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: calc(var(--jsc-rule-offset-tight) * 1);
    width: var(--jsc-space-xl);
    height: var(--jsc-rule-hairline);
    background: var(--jsc-text-on-light);
    opacity: 0;
    pointer-events: none;
    transform: translateX(-50%) scaleX(0);
    transform-origin: center center;
    transition:
      transform var(--jsc-slow) cubic-bezier(0.4, 0, 0.2, 1),
      opacity var(--jsc-fast) ease;
  }

  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop a:hover::after,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop a:focus-visible::after,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop .current-menu-item > a::after,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop .current-menu-ancestor > a::after,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--desktop .current_page_item > a::after {
    opacity: 1;
    transform: translateX(-50%) scaleX(1);
  }

  header.jsc-header.jsc-scrolled .jsc-nav__menu.jsc-nav__menu--desktop a {
    opacity: 0.94;
  }

  header.jsc-header.jsc-scrolled .jsc-nav__menu.jsc-nav__menu--desktop a::after {
    background: var(--jsc-text-on-light);
  }

  /* Desktop does not use custom mobile toggle/panel. */
  header.jsc-header .jsc-header__toggle,
  header.jsc-header .jsc-nav__panel,
  header.jsc-header .jsc-nav__overlay {
    display: none !important;
  }
}

/* #endregion DESKTOP NAV */


/* =========================================================
   3) SHARED HEADER ALIGNMENT + SCROLL EFFECTS
========================================================= */

/* #region SHARED HEADER ALIGNMENT + SCROLL EFFECTS */

header.jsc-header .jsc-header__logo,
header.jsc-header .jsc-nav__menu--desktop a,
header.jsc-header .jsc-cta-btn a.elementor-button,
header.jsc-header .jsc-header__toggle {
  transform-origin: center;
  transition:
    transform 180ms ease,
    opacity 180ms ease,
    filter 180ms ease;
}

header.jsc-header.jsc-scrolled .jsc-header__logo {
  transform: scale(0.97);
}

header.jsc-header.jsc-scrolled .jsc-cta-btn a.elementor-button {
  transform: scale(0.96);
}

header.jsc-header.jsc-scrolled .jsc-header__toggle {
  transform: scale(0.96);
}

header.jsc-header .jsc-header__inner .jsc-header__left {
  justify-self: start;
  padding-left: var(--jsc-space-sm);
}

header.jsc-header .jsc-header__inner .jsc-header__right {
  justify-self: end;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

/* #endregion SHARED HEADER ALIGNMENT + SCROLL EFFECTS */


/* =========================================================
   4) MENU OPEN STATE
========================================================= */

/* #region MENU OPEN STATE */

html.jsc-nav-open header.jsc-header {
  background: var(--jsc-surface-header);
  -webkit-backdrop-filter: blur(var(--jsc-header-blur));
  backdrop-filter: blur(var(--jsc-header-blur));
}

html.jsc-nav-open header.jsc-header::after {
  opacity: 1;
}

html.jsc-nav-open header.jsc-header .jsc-header__inner.e-con {
  padding-top: var(--jsc-space-xs);
  padding-bottom: var(--jsc-space-xs);
}

/* #endregion MENU OPEN STATE */


/* =========================================================
   5) TOGGLE GLYPH
========================================================= */

/* #region TOGGLE GLYPH */

header.jsc-header .jsc-nav__glyph {
  position: relative;
  display: inline-block;
  width: var(--jsc-icon-md);
  height: var(--jsc-icon-tight);
  transition:
    width var(--jsc-med) var(--jsc-ease),
    height var(--jsc-med) var(--jsc-ease);
}

header.jsc-header .jsc-nav__glyph span {
  position: absolute;
  left: 0;
  width: 100%;
  height: var(--jsc-stroke-regular);
  background: currentcolor;
  border-radius: var(--jsc-radius-pill);
  transform-origin: 50% 50%;
  transition:
    transform var(--jsc-med) var(--jsc-ease),
    opacity var(--jsc-med) var(--jsc-ease),
    width var(--jsc-med) var(--jsc-ease),
    height var(--jsc-med) var(--jsc-ease),
    top var(--jsc-med) var(--jsc-ease);
}

header.jsc-header .jsc-nav__glyph span:first-child {
  top: 0;
}

header.jsc-header .jsc-nav__glyph span:last-child {
  top: 100%;
  width: 88%;
  transform: translateY(-100%);
}

html.jsc-nav-open header.jsc-header .jsc-nav__glyph span {
  top: 50%;
  width: 100%;
  height: 1.5px;
}

html.jsc-nav-open header.jsc-header .jsc-nav__glyph span:first-child {
  transform: translateY(-50%) rotate(45deg);
}

html.jsc-nav-open header.jsc-header .jsc-nav__glyph span:last-child {
  transform: translateY(-50%) rotate(-45deg);
}

/* #endregion TOGGLE GLYPH */


/* =========================================================
   6) TABLET / MOBILE NAV
========================================================= */

/* #region TABLET / MOBILE NAV */

@media (max-width: 1199px) {
  body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: var(--jsc-z-overlay);
    background: linear-gradient(
      to bottom,
      var(--jsc-overlay-soft),
      rgb(var(--jsc-rgb-mirage) / var(--jsc-o-28))
    );
    -webkit-backdrop-filter: blur(2px);
    backdrop-filter: blur(2px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 220ms ease;
  }

  html.jsc-nav-open body::before {
    opacity: 1;
    pointer-events: auto;
  }

  header.jsc-header .jsc-nav.jsc-nav--desktop {
    display: none !important;
  }

  header.jsc-header .jsc-nav__panel {
    top: var(--jsc-nav-top-tablet) !important;
    padding-inline: var(--jsc-space-md);
  }

  header.jsc-header.jsc-scrolled .jsc-nav__panel {
    top: var(--jsc-nav-top-tablet-scrolled) !important;
  }

  header.jsc-header .jsc-nav__panel-inner {
    position: relative;
    z-index: calc(var(--jsc-z-panel) + 1);
    width: min(360px, 100%);
    max-width: 360px;
    margin: 0;
    padding: 18px;
    justify-content: center;
    overflow: hidden;
    background: var(--jsc-surface-panel);
    -webkit-backdrop-filter: blur(var(--jsc-header-blur));
    backdrop-filter: blur(var(--jsc-header-blur));
    border: 1px solid var(--jsc-divider);
    border-radius: var(--jsc-radius-md);
    box-shadow:
      0 18px 55px var(--jsc-shadow-deep),
      0 0 0 1px var(--jsc-shadow-inset) inset;
    transform: none;
  }

  html.jsc-nav-open header.jsc-header {
    box-shadow: 0 8px 24px var(--jsc-shadow-soft);
  }

  header.jsc-header .elementor-nav-menu--dropdown-tablet .elementor-nav-menu--main {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }

  header.jsc-header .jsc-nav__menu.jsc-nav__menu--mobile li {
    width: 100%;
  }

  header.jsc-header .jsc-nav__menu.jsc-nav__menu--mobile li + li {
    margin-top: 18px;
  }

  header.jsc-header .jsc-nav__menu.jsc-nav__menu--mobile a {
    display: block;
    width: 100%;
    padding: var(--jsc-space-sm) 14px;
    color: var(--jsc-text-strong);
    font-size: clamp(20px, 3.8vw, 24px);
    line-height: 1.6;
    text-decoration: none;
    border-radius: var(--jsc-radius-sm);
    opacity: 1;
    transform: none;
    transition:
      background var(--jsc-fast) ease,
      color var(--jsc-fast) ease,
      transform var(--jsc-med) var(--jsc-ease);
  }

  header.jsc-header .jsc-nav__menu.jsc-nav__menu--mobile a:hover,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--mobile a:focus-visible {
    color: var(--jsc-text-strong);
    background: var(--jsc-divider);
    outline: none;
    transform: translateX(2px);
  }

  header.jsc-header .jsc-nav__menu.jsc-nav__menu--mobile .current-menu-item > a,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--mobile .current-menu-ancestor > a,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--mobile .current_page_item > a {
    color: var(--jsc-text-strong);
    background: var(--jsc-divider);
    box-shadow: inset 0 0 2px var(--jsc-accent);
    transform: none;
  }

  header.jsc-header .jsc-nav__menu.jsc-nav__menu--mobile a::before,
  header.jsc-header .jsc-nav__menu.jsc-nav__menu--mobile a::after {
    content: none !important;
  }

  header.jsc-header .jsc-header__left {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-start;
    gap: var(--jsc-space-sm);
  }

  header.jsc-header .jsc-header__toggle {
    position: relative;
    z-index: calc(var(--jsc-z-panel) + 2);
    display: inline-flex;
    flex: 0 0 auto;
    align-items: center;
    justify-content: center;
    align-self: center;
    width: var(--jsc-box-xl);
    min-width: var(--jsc-box-xl);
  }

  header.jsc-header .jsc-nav__toggle-btn {
    appearance: none;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--jsc-box-lg);
    height: var(--jsc-box-lg);
    margin: 0;
    padding: 0;
    color: var(--jsc-text-on-light);
    line-height: 0;
    background: transparent;
    border: 0;
    border-radius: var(--jsc-radius-pill);
    cursor: pointer;
    transform: translateY(-2px);
    transition:
      background var(--jsc-fast) ease,
      width var(--jsc-med) var(--jsc-ease),
      height var(--jsc-med) var(--jsc-ease),
      transform var(--jsc-med) var(--jsc-ease);
  }

  header.jsc-header .jsc-nav__toggle-btn:hover,
  header.jsc-header .jsc-nav__toggle-btn:focus-visible {
    background: var(--jsc-accent);
    outline: var(--jsc-outline-w) solid var(--jsc-focus-strong);
    outline-offset: 3px;
  }

  header.jsc-header .jsc-nav__toggle-btn::after {
    content: "";
    position: absolute;
    inset: -6px;
    border-radius: var(--jsc-radius-pill);
    pointer-events: none;
    opacity: 0;
    transform: scale(0.98);
    box-shadow:
      0 0 0 1px rgb(var(--jsc-rgb-sandwisp) / var(--jsc-o-50)),
      0 0 0 4px rgb(var(--jsc-rgb-sandwisp) / var(--jsc-o-15));
    transition:
      opacity var(--jsc-fast) ease,
      inset var(--jsc-med) var(--jsc-ease),
      transform var(--jsc-slow) var(--jsc-ease);
  }

  header.jsc-header .jsc-nav__toggle-btn:hover::after,
  header.jsc-header .jsc-nav__toggle-btn:focus-visible::after {
    opacity: 1;
    transform: scale(1);
  }

  header.jsc-header::before,
  header.jsc-header::after,
  header.jsc-header .elementor-background-overlay {
    pointer-events: none !important;
  }

  .jsc-nav a:focus-visible {
    outline: 2px solid #D4B15A;
    outline-offset: 3px;
  }

  header.jsc-header.jsc-scrolled .jsc-nav__toggle-btn {
    width: 34px;
    height: 34px;
    transform: translateY(-1px);
  }

  header.jsc-header.jsc-scrolled .jsc-nav__toggle-btn::after {
    inset: -5px;
  }

  header.jsc-header.jsc-scrolled .jsc-nav__glyph {
    width: var(--jsc-icon-sm);
    height: var(--jsc-icon-compact);
  }

  header.jsc-header.jsc-scrolled .jsc-nav__glyph span {
    height: 1.2px;
  }

  header.jsc-header.jsc-scrolled .jsc-nav__glyph span:last-child {
    top: 100%;
    transform: translateY(-100%);
  }

  html.jsc-nav-open header.jsc-header.jsc-scrolled .jsc-nav__glyph {
    width: 18px;
    height: 12px;
  }

  html.jsc-nav-open header.jsc-header.jsc-scrolled .jsc-nav__glyph span {
    top: 50%;
    width: 100%;
    height: 1.5px;
  }

  html.jsc-nav-open header.jsc-header.jsc-scrolled .jsc-nav__glyph span:first-child {
    transform: translateY(-50%) rotate(45deg);
  }

  html.jsc-nav-open header.jsc-header.jsc-scrolled .jsc-nav__glyph span:last-child {
    transform: translateY(-50%) rotate(-45deg);
  }
}

/* #endregion TABLET / MOBILE NAV */


/* =========================================================
   7) MOBILE OVERRIDES
========================================================= */

/* #region MOBILE OVERRIDES */

@media (max-width: 767px) {
  header.jsc-header .jsc-nav__panel {
    top: var(--jsc-nav-top-mobile) !important;
    padding-inline: var(--jsc-space-sm);
  }

  header.jsc-header.jsc-scrolled .jsc-nav__panel {
    top: var(--jsc-nav-top-mobile-scrolled) !important;
  }

  header.jsc-header .jsc-nav__panel-inner {
    width: min(340px, 100%);
    max-width: 340px;
    padding: 15px;
    border-radius: 18px;
    -webkit-backdrop-filter: blur(22px);
    backdrop-filter: blur(22px);
  }
}

/* #endregion MOBILE OVERRIDES */


/* =========================================================
   IDX NAV OPEN STACKING FIX
   Header/search shell stays in flow, but sits above overlay.
========================================================= */

/* Overlay behind the open nav/header */
html.jsc-nav-open body::before {
  z-index: 8000 !important;
}

/* IDX shell remains in normal flow, but creates a higher stacking context */
html.jsc-nav-open body.page-id-403 .jsc-idx-fixed-shell,
html.jsc-nav-open body.page-id-2147 .jsc-idx-fixed-shell {
  position: relative !important;
  z-index: 9000 !important;
  overflow: visible !important;
}

/* Inner wrapper must also allow the menu to show */
html.jsc-nav-open body.page-id-403 .jsc-idx-fixed-shell__inner,
html.jsc-nav-open body.page-id-2147 .jsc-idx-fixed-shell__inner {
  position: relative !important;
  z-index: 9001 !important;
  overflow: visible !important;
}

/* Header stays above the overlay */
html.jsc-nav-open body.page-id-403 header.elementor-location-header,
html.jsc-nav-open body.page-id-2147 header.elementor-location-header,
html.jsc-nav-open body.page-id-403 header.jsc-header,
html.jsc-nav-open body.page-id-2147 header.jsc-header {
  position: relative !important;
  z-index: 9002 !important;
  overflow: visible !important;
}

/* Open nav panel above everything in the shell */
html.jsc-nav-open body.page-id-403 header.jsc-header .jsc-nav__panel,
html.jsc-nav-open body.page-id-2147 header.jsc-header .jsc-nav__panel {
  position: fixed !important;
  top: var(--jsc-header-current-height, 84px) !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 9100 !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  overflow: visible !important;
}

/* Panel content above panel shell */
html.jsc-nav-open body.page-id-403 header.jsc-header .jsc-nav__panel-inner,
html.jsc-nav-open body.page-id-2147 header.jsc-header .jsc-nav__panel-inner {
  position: relative !important;
  z-index: 9101 !important;
}

/* =========================================================
   8) REDUCED MOTION
========================================================= */

/* #region REDUCED MOTION */

@media (prefers-reduced-motion: reduce) {
  header.jsc-header .jsc-nav__panel,
  header.jsc-header .jsc-nav__overlay,
  header.jsc-header .jsc-nav__panel *,
  header.jsc-header .jsc-nav__glyph,
  header.jsc-header .jsc-nav__glyph span,
  header.jsc-header .jsc-nav__toggle-btn {
    transition: none !important;
    animation: none !important;
  }
}

/* #endregion REDUCED MOTION */