/* =========================================================================
   Santé — Main navigation
   Desktop : frosted-glass pill, pinned inside a sticky site header.
   Mobile  : full-screen editorial overlay menu.
   Palette + type come from the Elementor Kit tokens (see style.css); every
   custom property below carries a hard fallback so the component is portable.
   ========================================================================= */

.sante-nav,
.sante-nav *,
.sante-nav *::before,
.sante-nav *::after {
	box-sizing: border-box;
}

/* Anchor navigation clears the sticky header. This offset drives the browser's
   own jump when landing on "/#section" — typing the URL, or following a menu
   anchor from a sub-page — and any same-page fragment link. The JS smooth
   scroll reads the very same token, so both paths land in exactly one spot. */
:root {
	--sante-anchor-offset: 100px;
}

html {
	scroll-padding-top: var(--sante-anchor-offset, 100px);
}

.sante-nav {
	--sn-navy:     var(--sante-primary,   #1B2A4A);
	--sn-navy-dk:  var(--sante-navy-dk,   #0F1B2D);
	--sn-brown:    var(--sante-secondary, #6B4536);
	--sn-gold:     var(--sante-gold,      #8D7D5B);
	--sn-tan:      var(--sante-tan,       #B0906F);
	--sn-rose:     var(--sante-rose,      #E8C7BB);
	--sn-cream:    var(--sante-cream-bg,  #FBF3EC);
	--sn-cream-2:  var(--sante-cream-wm,  #EFE6D5);
	--sn-slate:    var(--sante-slate,     #5B647C);
	--sn-accent:   var(--sante-accent,    #D62828);
	--sn-white:    var(--sante-white,     #FFFFFF);
	--sn-serif:    var(--sante-font-primary, "Cormorant Garamond", Georgia, serif);
	--sn-sans:     var(--sante-font-text,    "Manrope", system-ui, sans-serif);
	--sn-mono:     var(--sante-font-accent,  "Inter", system-ui, sans-serif);
	--sn-pill:     var(--sante-radius-pill,  100px);
	--sn-ease:     var(--sante-ease, cubic-bezier(0.4, 0, 0.2, 1));
	--sn-ease-out: cubic-bezier(0.16, 1, 0.3, 1);

	position: relative;
	display: inline-flex;
	font-family: var(--sn-sans);
	-webkit-font-smoothing: antialiased;
}

/* Overlay-only chrome — hidden while the desktop pill is shown. */
.sante-nav__head,
.sante-nav__eyebrow,
.sante-nav__foot,
.sante-nav__close,
.sante-nav__toggle,
.sante-nav__backdrop,
.sante-nav__watermark,
.sante-nav__glow,
.sante-nav__index,
.sante-nav__chevron {
	display: none;
}

/* -------------------------------------------------------------------------
   Sticky site header  (the "main menu sticky on desktop" requirement)
   The Elementor Pro header template is a direct child of <body>, so a plain
   sticky pins the whole bar — logo + pill — with no layout shift. A frosted
   background fades in only once the page is scrolled.
   ------------------------------------------------------------------------- */
header.elementor-location-header {
	position: -webkit-sticky;
	position: sticky;
	top: 0;
	z-index: 999;
	transition:
		background-color 0.45s var(--sante-ease, cubic-bezier(0.4, 0, 0.2, 1)),
		box-shadow 0.45s ease,
		-webkit-backdrop-filter 0.45s ease,
		backdrop-filter 0.45s ease;
}

.admin-bar header.elementor-location-header {
	top: 32px;
}

header.elementor-location-header.sante-header-stuck {
	background: rgba(251, 243, 236, 0.82);
	-webkit-backdrop-filter: blur(16px) saturate(1.2);
	backdrop-filter: blur(16px) saturate(1.2);
	box-shadow: 0 14px 44px -26px rgba(15, 27, 45, 0.5);
}

/* -------------------------------------------------------------------------
   Desktop — frosted-glass pill
   ------------------------------------------------------------------------- */
.sante-nav__bar {
	position: relative;
	display: inline-flex;
	align-items: center;
	padding: 6px;
	background: var(--sante-glass-bg, rgba(255, 255, 255, 0.60));
	border-radius: var(--sn-pill);
	outline: 1px solid var(--sante-glass-border, rgba(255, 255, 255, 0.25));
	outline-offset: -1px;
	-webkit-backdrop-filter: blur(var(--sante-glass-blur, 9px));
	backdrop-filter: blur(var(--sante-glass-blur, 9px));
}

.sante-nav__list {
	position: relative;
	isolation: isolate;
	display: flex;
	align-items: center;
	gap: 4px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.sante-nav__item {
	position: relative;
	z-index: 1;
	margin: 0;
	padding: 0;
}

.sante-nav__link {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 20px;
	border-radius: var(--sn-pill);
	color: var(--sn-brown);
	font-family: var(--sn-sans);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.2;
	white-space: nowrap;
	text-decoration: none;
	cursor: pointer;
	transition: color 0.35s var(--sn-ease);
}

.sante-nav__link:focus-visible {
	outline: 2px solid var(--sn-brown);
	outline-offset: 3px;
}

.sante-nav__item.is-marked .sante-nav__link,
.sante-nav__item.is-marked .sante-nav__sub-toggle {
	color: var(--sn-white);
}

.sante-nav__arrow {
	display: inline-block;
	width: 7px;
	height: 7px;
	margin-left: 2px;
	border-right: 1.6px solid currentColor;
	border-bottom: 1.6px solid currentColor;
	transform: translateY(-2px) rotate(45deg);
	transition: transform 0.3s var(--sn-ease);
}

.sante-nav__indicator {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 0;
	width: 0;
	height: 0;
	background: var(--sn-brown);
	border-radius: var(--sn-pill);
	opacity: 0;
	transform: translate3d(0, 0, 0);
	pointer-events: none;
	will-change: transform, width, height;
}

.sante-nav.is-ready .sante-nav__indicator {
	opacity: 1;
	transition:
		transform 0.4s var(--sn-ease),
		width 0.4s var(--sn-ease),
		height 0.4s var(--sn-ease),
		opacity 0.25s ease;
}

/* Hamburger bars — shared base, sized up on mobile. */
.sante-nav__burger {
	display: inline-flex;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	width: 22px;
}

.sante-nav__burger i {
	display: block;
	width: 100%;
	height: 2px;
	border-radius: 2px;
	background: var(--sn-cream);
	transform-origin: center;
	transition:
		transform 0.4s var(--sn-ease),
		opacity 0.25s ease,
		width 0.3s var(--sn-ease);
}

/* -------------------------------------------------------------------------
   Submenus — shared base
   One markup tree drives both breakpoints: a floating glass dropdown / mega
   panel on desktop, an inline accordion inside the overlay on mobile. These
   base rules are breakpoint-agnostic; the per-breakpoint behaviour lives in
   the matching media queries below.
   ------------------------------------------------------------------------- */
.sante-nav__row {
	position: relative;
	display: inline-flex;
	align-items: center;
}

.sante-nav__sub-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px;
	margin: 0;
	border: 0;
	background: transparent;
	color: var(--sn-brown);
	font: inherit;
	line-height: 0;
	cursor: pointer;
	-webkit-appearance: none;
	appearance: none;
}

.sante-nav__sub-toggle:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 3px;
	border-radius: 50%;
}

/* Accessible name for the icon-only trigger. */
.sante-nav__sub-toggle-text {
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	border: 0;
	overflow: hidden;
	white-space: nowrap;
	clip: rect(0 0 0 0);
	clip-path: inset(50%);
}

/* -------------------------------------------------------------------------
   Desktop — floating dropdown / mega-menu
   ------------------------------------------------------------------------- */
@media (min-width: 1025px) {

	.sante-nav__sub-toggle {
		margin-left: -12px;
	}

	.sante-nav__sub-toggle .sante-nav__arrow {
		margin: 0;
	}

	/* Nested toggles are mobile-only accordion triggers; the desktop panel
	   shows the whole tree at once. */
	.sante-nav__sub-toggle--nested {
		display: none;
	}

	.sante-nav__item:hover        > .sante-nav__row .sante-nav__sub-toggle .sante-nav__arrow,
	.sante-nav__item:focus-within > .sante-nav__row .sante-nav__sub-toggle .sante-nav__arrow,
	.sante-nav__item.is-expanded  > .sante-nav__row .sante-nav__sub-toggle .sante-nav__arrow {
		transform: translateY(0) rotate(-135deg);
	}

	/* ----- Top panel positioning + entrance ----- */
	.sante-nav__submenu {
		position: absolute;
		top: 100%;
		left: 50%;
		z-index: 60;
		padding-top: 16px; /* transparent bridge so the cursor can cross the gap */
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		transform: translate(-50%, 6px);
		transition:
			opacity 0.26s var(--sn-ease),
			transform 0.32s var(--sn-ease-out),
			visibility 0s linear 0.32s;
	}

	.sante-nav__submenu--list {
		left: 0;
		transform: translate(0, 6px);
	}

	/* JS flips these when a centered mega panel would overflow a viewport edge. */
	.sante-nav__submenu.is-flip-right {
		left: auto;
		right: 0;
		transform: translate(0, 6px);
	}

	.sante-nav__submenu.is-flip-left {
		left: 0;
		right: auto;
		transform: translate(0, 6px);
	}

	.sante-nav__item:hover        > .sante-nav__submenu,
	.sante-nav__item:focus-within > .sante-nav__submenu,
	.sante-nav__item.is-expanded  > .sante-nav__submenu {
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transform: translate(-50%, 0);
		transition:
			opacity 0.3s var(--sn-ease),
			transform 0.36s var(--sn-ease-out),
			visibility 0s;
	}

	.sante-nav__item:hover        > .sante-nav__submenu--list,
	.sante-nav__item:focus-within > .sante-nav__submenu--list,
	.sante-nav__item.is-expanded  > .sante-nav__submenu--list,
	.sante-nav__item:hover        > .sante-nav__submenu.is-flip-right,
	.sante-nav__item:focus-within > .sante-nav__submenu.is-flip-right,
	.sante-nav__item.is-expanded  > .sante-nav__submenu.is-flip-right,
	.sante-nav__item:hover        > .sante-nav__submenu.is-flip-left,
	.sante-nav__item:focus-within > .sante-nav__submenu.is-flip-left,
	.sante-nav__item.is-expanded  > .sante-nav__submenu.is-flip-left {
		transform: translate(0, 0);
	}

	/* Nested panels live inside an already-open parent: always laid out. */
	.sante-nav__submenu--nested {
		position: static;
		left: auto;
		right: auto;
		padding-top: 0;
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transform: none;
		transition: none;
	}

	/* ----- Glass card (top panel only) ----- */
	.sante-nav__submenu-inner {
		position: relative;
		margin: 0;
		list-style: none;
		background: rgba(251, 243, 236, 0.96);
		border: 1px solid rgba(141, 125, 91, 0.20);
		border-radius: 22px;
		-webkit-backdrop-filter: blur(22px) saturate(1.4);
		backdrop-filter: blur(22px) saturate(1.4);
		box-shadow:
			0 34px 70px -34px rgba(15, 27, 45, 0.50),
			0 12px 28px -20px rgba(15, 27, 45, 0.30);
	}

	/* Connector caret pointing back at the pill. */
	.sante-nav__submenu > .sante-nav__submenu-inner::before {
		content: "";
		position: absolute;
		top: -7px;
		left: 50%;
		width: 14px;
		height: 14px;
		margin-left: -7px;
		background: rgba(251, 243, 236, 0.96);
		border-top: 1px solid rgba(141, 125, 91, 0.20);
		border-left: 1px solid rgba(141, 125, 91, 0.20);
		border-radius: 4px 0 0 0;
		transform: rotate(45deg);
	}

	.sante-nav__submenu--list > .sante-nav__submenu-inner::before { left: 36px; }
	.sante-nav__submenu.is-flip-right > .sante-nav__submenu-inner::before { left: auto; right: 36px; margin-left: 0; }
	.sante-nav__submenu.is-flip-left > .sante-nav__submenu-inner::before { left: 36px; right: auto; margin-left: 0; }

	/* Nested panels are not cards — just grouped lists. */
	.sante-nav__submenu--nested > .sante-nav__submenu-inner {
		background: none;
		border: 0;
		border-radius: 0;
		padding: 0;
		-webkit-backdrop-filter: none;
		backdrop-filter: none;
		box-shadow: none;
	}

	.sante-nav__submenu--nested > .sante-nav__submenu-inner::before { content: none; }

	/* simple dropdown */
	.sante-nav__submenu--list > .sante-nav__submenu-inner {
		min-width: 264px;
		max-width: 330px;
		padding: 12px;
	}

	.sante-nav__submenu--cols > .sante-nav__submenu-inner {
		min-width: 430px;
		max-width: 470px;
		columns: 2;
		column-gap: 8px;
	}

	.sante-nav__submenu--cols .sante-nav__col--d2 {
		-webkit-column-break-inside: avoid;
		break-inside: avoid;
	}

	/* mega "sitemap" */
	.sante-nav__submenu--mega > .sante-nav__submenu-inner {
		display: grid;
		grid-template-columns: repeat(var(--sante-cols, 3), minmax(0, 1fr));
		gap: 4px 24px;
		width: min(calc(var(--sante-cols, 3) * 234px), calc(100vw - 40px));
		padding: 26px 28px;
	}

	.sante-nav__col {
		list-style: none;
		min-width: 0;
	}

	.sante-nav__subrow {
		position: relative;
		display: flex;
		align-items: flex-start;
	}

	/* ----- Links inside the panel ----- */
	.sante-nav__sublink {
		position: relative;
		flex: 1 1 auto;
		display: flex;
		flex-direction: column;
		gap: 1px;
		padding: 8px 12px;
		border-radius: 10px;
		color: var(--sn-navy);
		text-decoration: none;
		transition:
			background-color 0.22s var(--sn-ease),
			color 0.22s var(--sn-ease);
	}

	.sante-nav__sublink:hover,
	.sante-nav__sublink:focus-visible {
		background: rgba(141, 125, 91, 0.12);
		color: var(--sn-brown);
		outline: none;
	}

	.sante-nav__sublink-title {
		font-family: var(--sn-sans);
		font-size: 14.5px;
		font-weight: 600;
		line-height: 1.3;
		letter-spacing: 0.01em;
	}

	.sante-nav__sublink-desc {
		font-family: var(--sn-sans);
		font-size: 12px;
		font-weight: 500;
		line-height: 1.4;
		color: var(--sn-slate);
	}

	/* Column heads (depth-2 groups) — serif, with a short accent rule. */
	.sante-nav__sublink--head {
		gap: 3px;
		margin-bottom: 2px;
		padding: 6px 12px 11px;
	}

	.sante-nav__sublink--head .sante-nav__sublink-title {
		font-family: var(--sn-serif);
		font-size: 19px;
		letter-spacing: 0.01em;
		color: var(--sn-brown);
	}

	.sante-nav__col--d2 > .sante-nav__subrow > .sante-nav__sublink--head::after {
		content: "";
		position: absolute;
		left: 12px;
		bottom: 3px;
		width: 28px;
		height: 2px;
		background: linear-gradient(90deg, var(--sn-tan), rgba(176, 144, 111, 0));
		border-radius: 2px;
	}

	.sante-nav__sublink--head:hover,
	.sante-nav__sublink--head:focus-visible {
		background: transparent;
	}

	/* Leaf links (depth 3+) — dash that grows on hover. */
	.sante-nav__sublink--child {
		padding-left: 18px;
	}

	.sante-nav__sublink--child::before {
		content: "";
		position: absolute;
		left: 5px;
		top: 16px;
		width: 0;
		height: 1.5px;
		background: var(--sn-tan);
		transition: width 0.24s var(--sn-ease-out);
	}

	.sante-nav__sublink--child:hover::before,
	.sante-nav__sublink--child:focus-visible::before {
		width: 9px;
	}

	.sante-nav__col--d3 > .sante-nav__subrow .sante-nav__sublink-title {
		color: var(--sn-navy);
	}

	.sante-nav__sublist {
		margin: 0;
		padding: 0;
		list-style: none;
	}

	/* depth-4 nested under depth-3 — indented with a hairline rail */
	.sante-nav__col--d3 > .sante-nav__submenu--nested > .sante-nav__submenu-inner {
		margin: 1px 0 4px 17px;
		padding-left: 8px;
		border-left: 1px solid rgba(141, 125, 91, 0.22);
	}

	.sante-nav__col--d4 > .sante-nav__subrow .sante-nav__sublink {
		padding-top: 6px;
		padding-bottom: 6px;
	}

	.sante-nav__col--d4 > .sante-nav__subrow .sante-nav__sublink-title {
		font-weight: 500;
		font-size: 13px;
		color: var(--sn-slate);
	}
}

/* -------------------------------------------------------------------------
   Mobile — full-screen editorial overlay
   ------------------------------------------------------------------------- */
@media (max-width: 1024px) {

	.sante-nav__toggle,
	.sante-nav__close { display: inline-flex; }
	.sante-nav__head,
	.sante-nav__foot { display: flex; }
	.sante-nav__eyebrow,
	.sante-nav__watermark,
	.sante-nav__glow,
	.sante-nav__index { display: block; }
	.sante-nav__chevron { display: inline-block; }

	.sante-nav__indicator,
	.sante-nav__backdrop { display: none; }

	/* ----- Trigger ----- */
	.sante-nav__toggle {
		align-items: center;
		justify-content: center;
		width: 54px;
		height: 54px;
		padding: 0;
		margin: 0;
		-webkit-appearance: none;
		appearance: none;
		background: var(--sn-navy) !important;
		border: 0;
		border-radius: 50% !important;
		cursor: pointer;
		box-shadow:
			0 14px 30px -12px rgba(15, 27, 45, 0.5),
			inset 0 1px 0 rgba(255, 255, 255, 0.14);
		transition:
			transform 0.3s var(--sn-ease),
			box-shadow 0.3s var(--sn-ease),
			background-color 0.3s var(--sn-ease);
	}

	.sante-nav__toggle:hover { transform: translateY(-1px); }
	.sante-nav__toggle:active { transform: scale(0.95); }
	.sante-nav__toggle:focus-visible { outline: 2px solid var(--sn-navy); outline-offset: 3px; }

	/* burger → X */
	.sante-nav.is-open .sante-nav__burger i:nth-child(1) { transform: translateY(7px) rotate(45deg); }
	.sante-nav.is-open .sante-nav__burger i:nth-child(2) { opacity: 0; width: 0; }
	.sante-nav.is-open .sante-nav__burger i:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

	/* ----- Overlay panel ----- */
	.sante-nav__bar {
		position: fixed;
		inset: 0;
		z-index: 1100;
		display: flex;
		flex-direction: column;
		align-items: stretch;
		text-align: left;
		width: 100%;
		max-width: none;
		padding:
			calc(env(safe-area-inset-top, 0px) + 20px)
			clamp(22px, 6vw, 40px)
			calc(env(safe-area-inset-bottom, 0px) + 26px);
		background:
			radial-gradient(135% 90% at 100% -8%, rgba(232, 199, 187, 0.45), rgba(232, 199, 187, 0) 58%),
			radial-gradient(120% 80% at -20% 116%, rgba(141, 125, 91, 0.18), rgba(141, 125, 91, 0) 60%),
			linear-gradient(180deg, var(--sn-cream) 0%, var(--sn-cream-2) 100%);
		border-radius: 0;
		outline: 0;
		-webkit-backdrop-filter: none;
		backdrop-filter: none;
		overflow-x: hidden;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		opacity: 0;
		visibility: hidden;
		clip-path: circle(0% at calc(100% - 47px) calc(env(safe-area-inset-top, 0px) + 47px));
		transition:
			clip-path 0.6s var(--sn-ease-out),
			opacity 0.4s ease,
			visibility 0s linear 0.6s;
		will-change: clip-path, opacity;
	}

	.sante-nav.is-open .sante-nav__bar {
		opacity: 1;
		visibility: visible;
		clip-path: circle(150% at calc(100% - 47px) calc(env(safe-area-inset-top, 0px) + 47px));
		transition:
			clip-path 0.66s var(--sn-ease-out),
			opacity 0.3s ease,
			visibility 0s linear 0s;
	}

	.sante-nav__head,
	.sante-nav__eyebrow,
	.sante-nav__list,
	.sante-nav__foot {
		position: relative;
		z-index: 1;
	}

	/* ----- Head : logo + close ----- */
	.sante-nav__head {
		align-items: center;
		justify-content: space-between;
		gap: 16px;
		flex: 0 0 auto;
	}

	.sante-nav__logo {
		display: inline-flex;
		align-items: center;
	}

	.sante-nav__logo-img,
	.sante-nav__head .custom-logo,
	.sante-nav__head img {
		max-height: 62px;
		width: auto;
	}

	.sante-nav__logo-text {
		font-family: var(--sn-serif);
		font-size: 30px;
		font-weight: 600;
		letter-spacing: 0.12em;
		color: var(--sn-navy);
	}

	.sante-nav__close {
		position: relative;
		align-items: center;
		justify-content: center;
		width: 48px;
		height: 48px;
		flex: 0 0 auto;
		padding: 0;
		-webkit-appearance: none;
		appearance: none;
		border: 1px solid rgba(27, 42, 74, 0.18);
		border-radius: 50% !important;
		background: transparent !important;
		cursor: pointer;
		transition:
			background-color 0.3s var(--sn-ease),
			border-color 0.3s var(--sn-ease),
			transform 0.5s var(--sn-ease-out);
	}

	.sante-nav__close i {
		position: absolute;
		top: 50%;
		left: 50%;
		width: 17px;
		height: 1.8px;
		border-radius: 2px;
		background: var(--sn-navy);
		transition: background-color 0.3s var(--sn-ease);
	}

	.sante-nav__close i:nth-child(1) { transform: translate(-50%, -50%) rotate(45deg); }
	.sante-nav__close i:nth-child(2) { transform: translate(-50%, -50%) rotate(-45deg); }

	.sante-nav__close:hover,
	.sante-nav__close:active {
		background: var(--sn-navy) !important;
		border-color: var(--sn-navy);
		transform: rotate(90deg);
	}

	.sante-nav__close:hover i { background: var(--sn-cream); }
	.sante-nav__close:focus-visible { outline: 2px solid var(--sn-navy); outline-offset: 3px; }

	/* ----- Eyebrow ----- */
	.sante-nav__eyebrow {
		display: flex;
		align-items: center;
		gap: 12px;
		margin: clamp(22px, 5vh, 44px) 0 2px;
		flex: 0 0 auto;
		font-family: var(--sn-mono);
		font-size: 12px;
		font-weight: 600;
		letter-spacing: 0.24em;
		text-transform: uppercase;
		color: var(--sn-gold);
	}

	.sante-nav__eyebrow::before {
		content: "";
		width: 30px;
		height: 1px;
		background: currentColor;
		opacity: 0.55;
	}

	/* ----- List : editorial rows ----- */
	.sante-nav__list {
		flex: 1 1 auto;
		flex-direction: column;
		align-items: stretch;
		justify-content: center;
		gap: 0;
		isolation: auto;
	}

	.sante-nav__item {
		width: 100%;
		border-bottom: 1px solid rgba(27, 42, 74, 0.09);
		opacity: 0;
		transform: translateY(22px);
	}

	.sante-nav__item:last-of-type { border-bottom: 0; }

	.sante-nav__link {
		justify-content: flex-start;
		align-items: baseline;
		gap: 16px;
		width: 100%;
		padding: clamp(13px, 2.1vh, 20px) 4px;
		border-radius: 0;
		color: var(--sn-navy);
		transition:
			transform 0.4s var(--sn-ease-out),
			color 0.3s var(--sn-ease);
	}

	.sante-nav__index {
		flex: 0 0 auto;
		font-family: var(--sn-mono);
		font-size: 13px;
		font-weight: 600;
		letter-spacing: 0.04em;
		color: var(--sn-tan);
		transform: translateY(-0.5em);
		font-variant-numeric: tabular-nums;
		transition: color 0.3s var(--sn-ease);
	}

	.sante-nav__text {
		font-family: var(--sn-serif);
		font-size: clamp(30px, 8.4vw, 46px);
		font-weight: 600;
		line-height: 1;
		letter-spacing: 0.005em;
	}

	.sante-nav__chevron {
		margin-left: auto;
		align-self: center;
		width: 9px;
		height: 9px;
		border-right: 1.8px solid var(--sn-navy);
		border-top: 1.8px solid var(--sn-navy);
		transform: rotate(45deg) translate(-4px, 4px);
		opacity: 0;
		transition:
			transform 0.4s var(--sn-ease-out),
			opacity 0.3s var(--sn-ease);
	}

	/* ----- Submenu : nested accordion ----- */
	.sante-nav__row,
	.sante-nav__subrow {
		display: flex;
		align-items: center;
		width: 100%;
	}

	.sante-nav__row > .sante-nav__link,
	.sante-nav__subrow > .sante-nav__sublink {
		flex: 1 1 auto;
		min-width: 0;
	}

	/* Top-level circular toggle */
	.sante-nav__row > .sante-nav__sub-toggle {
		flex: 0 0 auto;
		width: 46px;
		height: 46px;
		padding: 0;
		color: var(--sn-navy);
		border: 1px solid rgba(27, 42, 74, 0.16);
		border-radius: 50%;
		background: transparent;
		transition:
			background-color 0.3s var(--sn-ease),
			border-color 0.3s var(--sn-ease),
			color 0.3s var(--sn-ease);
	}

	.sante-nav__item.is-expanded > .sante-nav__row > .sante-nav__sub-toggle {
		background: var(--sn-navy);
		border-color: var(--sn-navy);
		color: var(--sn-cream);
	}

	/* Nested (smaller) toggle for deeper levels */
	.sante-nav__sub-toggle--nested {
		flex: 0 0 auto;
		width: 40px;
		height: 40px;
		padding: 0;
		color: var(--sn-brown);
		border: 1px solid rgba(141, 125, 91, 0.30);
		border-radius: 50%;
		background: transparent;
		transition:
			background-color 0.3s var(--sn-ease),
			border-color 0.3s var(--sn-ease),
			color 0.3s var(--sn-ease);
	}

	.sante-nav__col.is-expanded > .sante-nav__subrow > .sante-nav__sub-toggle--nested {
		background: var(--sn-brown);
		border-color: var(--sn-brown);
		color: var(--sn-cream);
	}

	.sante-nav__sub-toggle .sante-nav__arrow {
		display: block;
		width: 10px;
		height: 10px;
		margin: 0;
		transform: translateY(-2px) rotate(45deg);
		transition: transform 0.35s var(--sn-ease-out);
	}

	.sante-nav__sub-toggle--nested .sante-nav__arrow {
		width: 8px;
		height: 8px;
	}

	.sante-nav__item.is-expanded > .sante-nav__row > .sante-nav__sub-toggle .sante-nav__arrow,
	.sante-nav__col.is-expanded > .sante-nav__subrow > .sante-nav__sub-toggle .sante-nav__arrow {
		transform: translateY(2px) rotate(-135deg);
	}

	/* grid-rows 0fr→1fr collapse — works at every nesting level */
	.sante-nav__submenu {
		display: grid;
		grid-template-rows: 0fr;
		transition: grid-template-rows 0.42s var(--sn-ease-out);
	}

	.sante-nav__item.is-expanded > .sante-nav__submenu,
	.sante-nav__col.is-expanded > .sante-nav__submenu {
		grid-template-rows: 1fr;
	}

	.sante-nav__submenu-inner {
		min-height: 0;
		overflow: hidden;
		display: block;
		margin: 0;
		padding: 0;
		list-style: none;
		max-width: none;
	}

	.sante-nav__submenu:not(.sante-nav__submenu--nested) > .sante-nav__submenu-inner {
		margin: 2px 0 6px 6px;
		padding: 2px 0 4px 16px;
		border-left: 1px solid rgba(27, 42, 74, 0.12);
	}

	.sante-nav__submenu--nested > .sante-nav__submenu-inner {
		margin: 0 0 4px 4px;
		padding: 2px 0 4px 14px;
		border-left: 1px solid rgba(141, 125, 91, 0.22);
	}

	.sante-nav__col {
		list-style: none;
		width: auto;
		border: 0;
		opacity: 1;
		transform: none;
	}

	.sante-nav__col--group { margin: 2px 0; }

	.sante-nav__sublink {
		display: flex;
		flex-direction: column;
		gap: 1px;
		padding: 8px 4px;
		text-decoration: none;
	}

	.sante-nav__sublink-title {
		font-family: var(--sn-serif);
		font-weight: 600;
		line-height: 1.15;
		color: var(--sn-navy);
		transition: color 0.3s var(--sn-ease);
	}

	.sante-nav__sublink--d2 .sante-nav__sublink-title { font-size: clamp(19px, 5vw, 24px); }
	.sante-nav__sublink--head .sante-nav__sublink-title { color: var(--sn-brown); }

	.sante-nav__sublink--d3 .sante-nav__sublink-title {
		font-size: clamp(16px, 4.2vw, 20px);
		font-weight: 500;
	}

	.sante-nav__sublink--d4 .sante-nav__sublink-title {
		font-family: var(--sn-sans);
		font-size: 15px;
		font-weight: 500;
		color: var(--sn-slate);
	}

	.sante-nav__sublink:hover .sante-nav__sublink-title,
	.sante-nav__sublink:active .sante-nav__sublink-title {
		color: var(--sn-accent);
	}

	.sante-nav__sublink-desc {
		font-family: var(--sn-sans);
		font-size: 12.5px;
		font-weight: 500;
		line-height: 1.4;
		color: var(--sn-slate);
	}

	/* the desktop pill paints the marked item white — force it navy on mobile */
	.sante-nav__item.is-marked .sante-nav__link,
	.sante-nav__item.is-marked .sante-nav__link .sante-nav__text {
		color: var(--sn-navy);
	}

	/* active + interaction */
	.sante-nav__item.is-active .sante-nav__index { color: var(--sn-accent); }

	.sante-nav__item.is-active .sante-nav__text {
		background-image: linear-gradient(var(--sn-gold), var(--sn-gold));
		background-repeat: no-repeat;
		background-position: 0 98%;
		background-size: 100% 2px;
		padding-bottom: 2px;
	}

	.sante-nav__item.is-active .sante-nav__chevron,
	.sante-nav__link:hover .sante-nav__chevron {
		opacity: 1;
		transform: rotate(45deg) translate(0, 0);
	}

	.sante-nav__link:hover { transform: translateX(8px); }
	.sante-nav__link:hover .sante-nav__index { color: var(--sn-accent); }
	.sante-nav__link:active { transform: translateX(8px) scale(0.99); }
	.sante-nav__link:focus-visible { outline: 2px solid var(--sn-navy); outline-offset: 4px; }

	/* ----- Foot : contact + CTA ----- */
	.sante-nav__foot {
		flex-direction: column;
		gap: 20px;
		flex: 0 0 auto;
		margin-top: clamp(20px, 4vh, 36px);
		padding-top: 22px;
		border-top: 1px solid rgba(27, 42, 74, 0.12);
	}

	.sante-nav__contact {
		display: flex;
		flex-wrap: wrap;
		gap: 16px 30px;
	}

	.sante-nav__phone,
	.sante-nav__address {
		display: flex;
		flex-direction: column;
		gap: 3px;
		text-decoration: none;
	}

	.sante-nav__contact-label {
		font-family: var(--sn-mono);
		font-size: 11px;
		font-weight: 600;
		letter-spacing: 0.16em;
		text-transform: uppercase;
		color: var(--sn-tan);
	}

	.sante-nav__phone .sante-nav__contact-value {
		font-family: var(--sn-sans);
		font-size: 19px;
		font-weight: 700;
		letter-spacing: 0.01em;
		color: var(--sn-navy);
		transition: color 0.3s var(--sn-ease);
	}

	.sante-nav__address .sante-nav__contact-value {
		font-family: var(--sn-sans);
		font-size: 14px;
		line-height: 1.5;
		color: var(--sn-slate);
		max-width: 24ch;
	}

	.sante-nav__phone:hover .sante-nav__contact-value { color: var(--sn-accent); }

	.sante-nav__cta {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		gap: 10px;
		padding: 18px 28px;
		background: var(--sn-accent);
		color: var(--sn-white);
		border-radius: var(--sn-pill);
		font-family: var(--sn-sans);
		font-size: 16px;
		font-weight: 600;
		letter-spacing: 0.03em;
		text-decoration: none;
		box-shadow: 0 16px 34px -14px rgba(214, 40, 40, 0.65);
		transition:
			transform 0.3s var(--sn-ease-out),
			box-shadow 0.3s var(--sn-ease);
	}

	.sante-nav__cta-arrow {
		width: 8px;
		height: 8px;
		border-right: 2px solid currentColor;
		border-top: 2px solid currentColor;
		transform: rotate(45deg);
		transition: transform 0.3s var(--sn-ease-out);
	}

	.sante-nav__cta:hover {
		transform: translateY(-2px);
		box-shadow: 0 22px 40px -14px rgba(214, 40, 40, 0.72);
	}

	.sante-nav__cta:hover .sante-nav__cta-arrow { transform: rotate(45deg) translate(2px, -2px); }
	.sante-nav__cta:focus-visible { outline: 2px solid var(--sn-navy); outline-offset: 3px; }

	/* ----- Decorative ----- */
	.sante-nav__watermark {
		position: absolute;
		right: clamp(-30px, -4vw, -10px);
		bottom: calc(env(safe-area-inset-bottom, 0px) + 6px);
		z-index: 0;
		margin: 0;
		font-family: var(--sn-serif);
		font-size: clamp(150px, 46vw, 300px);
		font-weight: 600;
		line-height: 0.7;
		letter-spacing: 0.01em;
		color: rgba(27, 42, 74, 0.045);
		white-space: nowrap;
		pointer-events: none;
		user-select: none;
	}

	.sante-nav__glow {
		position: absolute;
		top: -130px;
		right: -130px;
		z-index: 0;
		width: 330px;
		height: 330px;
		border-radius: 50%;
		background: radial-gradient(circle, rgba(232, 199, 187, 0.5), rgba(232, 199, 187, 0) 70%);
		pointer-events: none;
		filter: blur(6px);
	}

	/* ----- Entrance choreography ----- */
	.sante-nav__head,
	.sante-nav__eyebrow,
	.sante-nav__foot {
		opacity: 0;
		transform: translateY(14px);
	}

	.sante-nav.is-open .sante-nav__item {
		opacity: 1;
		transform: translateY(0);
		transition:
			opacity 0.5s var(--sn-ease-out),
			transform 0.55s var(--sn-ease-out);
		transition-delay: calc(var(--sante-i, 0) * 65ms + 170ms);
	}

	.sante-nav.is-open .sante-nav__head,
	.sante-nav.is-open .sante-nav__eyebrow,
	.sante-nav.is-open .sante-nav__foot {
		opacity: 1;
		transform: translateY(0);
		transition:
			opacity 0.5s var(--sn-ease-out),
			transform 0.5s var(--sn-ease-out);
	}

	.sante-nav.is-open .sante-nav__head { transition-delay: 0.12s; }
	.sante-nav.is-open .sante-nav__eyebrow { transition-delay: 0.18s; }
	.sante-nav.is-open .sante-nav__foot { transition-delay: 0.52s; }

	body.sante-nav-open { overflow: hidden; }
}

/* Legacy centring wrapper (only emitted when the shortcode is given sticky="1"). */
.sante-nav-sticky {
	position: -webkit-sticky;
	position: sticky;
	top: 16px;
	z-index: 999;
	display: flex;
	justify-content: center;
}

@media (prefers-reduced-motion: reduce) {
	.sante-nav *,
	.sante-nav__indicator,
	.sante-nav__bar,
	.sante-nav__item,
	.sante-nav__head,
	.sante-nav__eyebrow,
	.sante-nav__foot,
	.sante-nav__link,
	header.elementor-location-header {
		transition-duration: 0.01ms !important;
		transition-delay: 0ms !important;
	}

	.sante-nav__bar { clip-path: none !important; }
}

.listimg.subimg img {
	width: 300px;
	aspect-ratio: 1 / 1;
	object-fit: cover;
}