/* ==========================================================================
   Custom Sticky Header (b16b80de) — modular sections
   ========================================================================== */

/* --------------------------------------------------------------------------
   0. Elementor shell — zero layout footprint (hero overlay)
   Hero inner container should use padding-top: 0 on the column holding this widget.
   -------------------------------------------------------------------------- */

.elementor-widget-custom_header_b16b80de,
.elementor-widget-custom_header_b16b80de .elementor-widget-container {
	height: 0;
	min-height: 0;
	margin: 0;
	padding: 0;
	overflow: visible;
}

.elementor-element:has( > .e-con-inner > .elementor-widget-custom_header_b16b80de:first-child ) .ch-b16b80de-wrapper,
.elementor-widget-custom_header_b16b80de:first-child .ch-b16b80de-wrapper {
	top: 0;
}

/* --------------------------------------------------------------------------
   1. Design tokens
   -------------------------------------------------------------------------- */

.ch-b16b80de-wrapper {
	--ch-offset-top: 25px;
	--ch-offset-top-scrolled: 12px;
	--ch-container-max-width: 1400px;
	--ch-container-width: 90%;
	--ch-header-height: 70px;
	--ch-radius: 50px;
	--ch-bg: #fff;
	--ch-shadow: 0 4px 15px rgba( 0, 0, 0, 0.05 );
	--ch-shadow-scrolled: 0 8px 24px rgba( 0, 0, 0, 0.12 );
	--ch-transition: 0.3s ease;
	--ch-z-header: 9999;
	--ch-z-mega: 10000;
	--ch-z-mobile-nav: 10001;
	--ch-nav-gap: 30px;
	--ch-text: #333;
	--ch-accent: #0073e6;
	--ch-accent-hover: #005bb5;
	--ch-mega-top: -9999px;
	--ch-mega-left: 0;
	--ch-admin-bar-offset: 0px;

	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 0;
	min-height: 0;
	margin: 0;
	padding: 0;
	z-index: var( --ch-z-header );
	overflow: visible;
	pointer-events: none;
}

.ch-b16b80de-wrapper > .ch-b16b80de-container {
	pointer-events: auto;
}

/* --------------------------------------------------------------------------
   2. FOUC / pre-init guards
   -------------------------------------------------------------------------- */

.ch-b16b80de-wrapper:not( .is-ready ) .ch-b16b80de-container,
.ch-b16b80de-wrapper:not( .is-ready ) .ch-b16b80de-mega-menu,
.ch-b16b80de-wrapper:not( .is-ready ) .ch-b16b80de-nav,
.ch-b16b80de-wrapper:not( .is-ready ) .ch-b16b80de-mobile-toggle-bar {
	transition: none !important;
}

.ch-b16b80de-wrapper:not( .is-ready ) .ch-b16b80de-mega-menu {
	opacity: 0 !important;
	visibility: hidden !important;
	pointer-events: none !important;
	transform: translateY( 8px ) !important;
}

.ch-b16b80de-wrapper:not( .is-ready ) .has-mega-menu:hover .ch-b16b80de-mega-menu,
.ch-b16b80de-wrapper:not( .is-ready ) .has-mega-menu:focus-within .ch-b16b80de-mega-menu {
	opacity: 0 !important;
	visibility: hidden !important;
	pointer-events: none !important;
}

.ch-b16b80de-wrapper:not( .is-ready ) .ch-b16b80de-nav-list {
	flex-direction: row;
}

.ch-b16b80de-mega-menu.is-mega-closed {
	opacity: 0 !important;
	visibility: hidden !important;
	pointer-events: none !important;
}

/* --------------------------------------------------------------------------
   3. Container — always fixed at viewport top
   -------------------------------------------------------------------------- */

.ch-b16b80de-container {
	position: fixed;
	top: calc( var( --ch-offset-top ) + var( --ch-admin-bar-offset ) );
	left: 50%;
	transform: translateX( -50% );
	width: var( --ch-container-width );
	max-width: var( --ch-container-max-width );
	min-height: var( --ch-header-height );
	box-sizing: border-box;
	background: var( --ch-bg );
	border-radius: var( --ch-radius );
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 10px 30px;
	box-shadow: var( --ch-shadow );
	transition:
		top var( --ch-transition ),
		box-shadow var( --ch-transition ),
		border-radius var( --ch-transition ),
		padding var( --ch-transition );
	overflow: visible;
}

.ch-b16b80de-wrapper.is-scrolled .ch-b16b80de-container {
	top: calc( var( --ch-offset-top-scrolled ) + var( --ch-admin-bar-offset ) );
	box-shadow: var( --ch-shadow-scrolled );
}

/* WordPress admin bar (desktop). */
.admin-bar .ch-b16b80de-wrapper {
	--ch-admin-bar-offset: 32px;
}

@media ( max-width: 782px ) {
	.admin-bar .ch-b16b80de-wrapper {
		--ch-admin-bar-offset: 46px;
	}
}

/* --------------------------------------------------------------------------
   4. Logo
   -------------------------------------------------------------------------- */

.ch-b16b80de-logo {
	flex-shrink: 0;
	line-height: 0;
}

.ch-b16b80de-logo a {
	display: block;
}

.ch-b16b80de-logo a:focus-visible {
	outline: 2px solid var( --ch-accent );
	outline-offset: 4px;
	border-radius: 4px;
}

.ch-b16b80de-logo img {
	max-height: 50px;
	width: auto;
	height: auto;
	display: block;
}

/* --------------------------------------------------------------------------
   5. Navigation
   -------------------------------------------------------------------------- */

.ch-b16b80de-nav {
	margin-left: auto;
	flex-shrink: 1;
	min-width: 0;
}

.ch-b16b80de-nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	gap: var( --ch-nav-gap );
}

.ch-b16b80de-nav-item {
	position: static;
}

.ch-b16b80de-nav-link {
	text-decoration: none;
	color: var( --ch-text );
	font-size: 16px;
	font-weight: 500;
	text-transform: uppercase;
	display: flex;
	align-items: center;
	gap: 5px;
	transition: color var( --ch-transition );
	white-space: nowrap;
}

.ch-b16b80de-nav-link:hover,
.ch-b16b80de-nav-link:focus-visible {
	color: var( --ch-accent );
}

.ch-b16b80de-nav-link:focus-visible {
	outline: 2px solid var( --ch-accent );
	outline-offset: 2px;
	border-radius: 4px;
}

.ch-b16b80de-caret {
	font-size: 12px;
	line-height: 1;
	transition: transform var( --ch-transition );
}

.has-mega-menu.is-mega-open > .ch-b16b80de-nav-link .ch-b16b80de-caret {
	transform: rotate( 180deg );
}

/* --------------------------------------------------------------------------
   6. CTA
   -------------------------------------------------------------------------- */

.ch-b16b80de-cta-btn {
	background: var( --ch-accent );
	color: #fff;
	padding: 10px 24px;
	border-radius: 30px;
}

.ch-b16b80de-cta-btn:hover,
.ch-b16b80de-cta-btn:focus-visible {
	background: var( --ch-accent-hover );
	color: #fff;
}

/* --------------------------------------------------------------------------
   7. Mega menu (desktop: fixed, per-menu coordinates via CSS vars)
   -------------------------------------------------------------------------- */

.has-mega-menu {
	position: static;
}

.ch-b16b80de-mega-menu {
	position: fixed;
	top: var( --ch-mega-top, -9999px );
	left: var( --ch-mega-left, 0 );
	width: min( 600px, calc( 100vw - 32px ) );
	box-sizing: border-box;
	background: var( --ch-bg );
	border-radius: 8px;
	box-shadow: 0 10px 30px rgba( 0, 0, 0, 0.1 );
	display: flex;
	padding: 30px;
	gap: 40px;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateY( 8px );
	transition:
		opacity var( --ch-transition ),
		visibility var( --ch-transition ),
		transform var( --ch-transition );
	z-index: var( --ch-z-mega );
	max-height: calc( 100dvh - var( --ch-mega-top, 0px ) - 16px );
	overflow-x: hidden;
	overflow-y: auto;
	overscroll-behavior: contain;
	-webkit-overflow-scrolling: touch;
}

.ch-b16b80de-mega-menu.is-measuring {
	opacity: 0 !important;
	visibility: hidden !important;
	pointer-events: none !important;
}

/* Invisible hover bridge spanning the gap between trigger and panel,
   so the cursor never "leaves" the menu while crossing it. */
.ch-b16b80de-mega-menu::before {
	content: '';
	position: absolute;
	top: -14px;
	left: 0;
	right: 0;
	height: 14px;
}

.has-mega-menu.is-mega-open .ch-b16b80de-mega-menu:not( .is-mega-closed ),
.has-mega-menu:focus-within .ch-b16b80de-mega-menu:not( .is-mega-closed ) {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY( 0 );
}

@media ( hover: hover ) and ( pointer: fine ) {
	.has-mega-menu:hover .ch-b16b80de-mega-menu:not( .is-mega-closed ) {
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transform: translateY( 0 );
	}
}

.ch-b16b80de-mega-col {
	flex: 1;
	min-width: 0;
}

.ch-b16b80de-mega-col-left {
	border-right: 1px solid #eee;
	padding-right: 20px;
}

.ch-b16b80de-mega-heading {
	font-size: 14px;
	color: #888;
	margin: 0 0 20px;
	text-transform: uppercase;
}

.ch-b16b80de-mega-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.ch-b16b80de-mega-list a {
	text-decoration: none;
	color: #444;
	font-size: 15px;
	transition: color 0.2s;
	display: flex;
	align-items: center;
	gap: 10px;
}

.ch-b16b80de-mega-list a:hover,
.ch-b16b80de-mega-list a:focus-visible {
	color: var( --ch-accent );
}

.ch-b16b80de-mega-list a:focus-visible {
	outline: 2px solid var( --ch-accent );
	outline-offset: 2px;
	border-radius: 4px;
}

.ch-b16b80de-mega-countries {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px 15px;
}

.ch-b16b80de-flag {
	width: 24px;
	height: 16px;
	object-fit: cover;
	border-radius: 2px;
	flex-shrink: 0;
}

/* --------------------------------------------------------------------------
   8. Mobile toggle
   -------------------------------------------------------------------------- */

.ch-b16b80de-container .ch-b16b80de-mobile-toggle {
	display: none !important;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 0;
	width: 44px;
	height: 44px;
	padding: 0;
	margin: 0;
	border: 0;
	background: transparent;
	cursor: pointer;
	flex-shrink: 0;
	border-radius: 4px;
}

.ch-b16b80de-mobile-toggle:focus-visible {
	outline: 2px solid var( --ch-accent );
	outline-offset: 2px;
}

.ch-b16b80de-mobile-toggle-bar {
	display: block;
	width: 25px;
	height: 3px;
	margin: 0;
	background: var( --ch-text );
	border-radius: 2px;
	transition:
		transform var( --ch-transition ),
		opacity var( --ch-transition );
}

.ch-b16b80de-wrapper.is-nav-open .ch-b16b80de-mobile-toggle-bar:nth-child( 2 ) {
	transform: translateY( 8px ) rotate( 45deg );
}

.ch-b16b80de-wrapper.is-nav-open .ch-b16b80de-mobile-toggle-bar:nth-child( 3 ) {
	opacity: 0;
}

.ch-b16b80de-wrapper.is-nav-open .ch-b16b80de-mobile-toggle-bar:nth-child( 4 ) {
	transform: translateY( -8px ) rotate( -45deg );
}

.ch-b16b80de-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect( 0, 0, 0, 0 );
	white-space: nowrap;
	border: 0;
}

/* --------------------------------------------------------------------------
   9. Mobile layout
   -------------------------------------------------------------------------- */

@media ( max-width: 1024px ) {
	.ch-b16b80de-wrapper {
		--ch-offset-top: 0;
		--ch-offset-top-scrolled: 0;
		--ch-container-width: 100%;
		--ch-radius: 0;
		height: 0;
		min-height: 0;
	}

	.ch-b16b80de-container {
		top: var( --ch-admin-bar-offset );
		padding: 15px 20px;
		border-radius: 0;
	}

	.ch-b16b80de-wrapper.is-scrolled .ch-b16b80de-container {
		top: var( --ch-admin-bar-offset );
		box-shadow: var( --ch-shadow-scrolled );
	}

	.ch-b16b80de-container .ch-b16b80de-mobile-toggle {
		display: flex !important;
	}

	.ch-b16b80de-mobile-toggle-bar {
		margin: 3px 0;
	}

	.ch-b16b80de-nav {
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		width: 100%;
		background: var( --ch-bg );
		box-shadow: 0 10px 20px rgba( 0, 0, 0, 0.1 );
		max-height: 0;
		overflow: hidden;
		opacity: 0;
		visibility: hidden;
		transition:
			max-height var( --ch-transition ),
			opacity var( --ch-transition ),
			visibility var( --ch-transition );
		z-index: var( --ch-z-mobile-nav );
	}

	.ch-b16b80de-wrapper.is-nav-open .ch-b16b80de-nav {
		max-height: calc( 100dvh - var( --ch-header-height ) - var( --ch-admin-bar-offset ) );
		overflow-x: hidden;
		overflow-y: auto;
		opacity: 1;
		visibility: visible;
		-webkit-overflow-scrolling: touch;
		overscroll-behavior: contain;
	}

	.ch-b16b80de-nav-list {
		flex-direction: column;
		align-items: center;
		text-align: center;
		padding: 20px;
		width: 100%;
		gap: 15px;
	}

	.ch-b16b80de-nav-link {
		white-space: normal;
		justify-content: center;
		min-height: 44px;
	}

	.ch-b16b80de-mega-menu {
		position: static;
		top: auto;
		left: auto;
		width: 100%;
		max-width: 100%;
		max-height: 0;
		transform: none;
		box-shadow: none;
		flex-direction: column;
		padding: 0;
		margin-top: 0;
		overflow: hidden;
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		transition:
			max-height var( --ch-transition ),
			opacity var( --ch-transition ),
			visibility var( --ch-transition );
	}

	/* Closed state must not reserve layout space (menu is in normal flow
	   on mobile, unlike the fixed-position desktop panel). */
	.ch-b16b80de-mega-menu.is-mega-closed {
		max-height: 0 !important;
		padding: 0 !important;
	}

	/* Hover bridge is desktop-only. */
	.ch-b16b80de-mega-menu::before {
		display: none;
	}

	.has-mega-menu.is-mega-open .ch-b16b80de-mega-menu:not( .is-mega-closed ) {
		padding: 15px 0 0;
		max-height: 2000px;
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
	}

	/* Mobile is tap-driven only: neutralize the desktop hover /
	   focus-within reveal rules so focus on the tapped trigger cannot
	   force the accordion open or closed. */
	.has-mega-menu:hover .ch-b16b80de-mega-menu.is-mega-closed,
	.has-mega-menu:focus-within .ch-b16b80de-mega-menu.is-mega-closed {
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
	}

	.ch-b16b80de-mega-col-left {
		border-right: none;
		border-bottom: 1px solid #eee;
		padding-right: 0;
		padding-bottom: 20px;
		text-align: center;
	}

	.ch-b16b80de-mega-list {
		align-items: center;
	}

	.ch-b16b80de-mega-countries {
		grid-template-columns: 1fr;
		justify-items: center;
	}
}

/* --------------------------------------------------------------------------
   10. Utilities
   -------------------------------------------------------------------------- */

body.ch-b16b80de-nav-locked {
	overflow: hidden;
}

/* Elementor: fully collapse the container chain holding the header so it
   reserves no vertical space above the hero. The fixed header floats over
   the hero with --ch-offset-top (20px ≈ 1.25em) clearance from its top edge.
   Includes .e-con / .e-con-inner (flex container padding) and the theme
   <header> wrapper that hosts the Elementor header template. */
.elementor:has( .ch-b16b80de-wrapper ),
.elementor-element:has( .ch-b16b80de-wrapper ),
.e-con:has( .ch-b16b80de-wrapper ),
.e-con-inner:has( .ch-b16b80de-wrapper ),
header:has( .ch-b16b80de-wrapper ),
.elementor-location-header:has( .ch-b16b80de-wrapper ) {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	margin-top: 0 !important;
	margin-bottom: 0 !important;
	min-height: 0 !important;
	height: auto !important;
	overflow: visible !important;
}

@media ( prefers-reduced-motion: reduce ) {
	.ch-b16b80de-wrapper *,
	.ch-b16b80de-wrapper *::before,
	.ch-b16b80de-wrapper *::after {
		transition-duration: 0.01ms !important;
		animation-duration: 0.01ms !important;
	}
}
