/**
 * Site header — sticky white bar: logo / primary nav / phone CTA.
 * Mirrors Elementor header template 2005.
 */

.site-header {
	position: sticky;
	top: 0;
	z-index: 9999;
	background: var(--color-white);
	border-bottom: 1px solid var(--color-border);
	transition: box-shadow var(--transition-normal);
}
.site-header.is-stuck { box-shadow: var(--shadow-header); }

.site-header__inner {
	max-width: none;            /* full width */
	margin: 0;
	min-height: var(--header-height);
	padding: 0 80px;            /* only 80px left/right */
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--spacing-md);
}

/* Logo */
.site-header__logo { flex: 0 0 auto; display: flex; align-items: center; }
.site-header__logo img,
.site-header__logo .custom-logo { width: 229.79px; height: 76.2px; max-width: 100%; object-fit: contain; }

/* Primary navigation */
.primary-nav { flex: 1 1 auto; display: flex; justify-content: center; }
.primary-nav .nav-menu {
	display: flex;
	align-items: center;
	gap: 2rem;
	margin: 0;
}
.primary-nav .nav-menu > li { position: relative; margin: 0; }
.primary-nav .nav-menu a {
	font-family: var(--font-secondary);
	font-size: 18px;
	font-weight: var(--font-weight-normal);
	color: var(--color-tint);
	padding: 0.6rem 0;
	position: relative;
	display: inline-block;
}
/* Slide underline on hover (Elementor "slide" animation) */
.primary-nav .nav-menu > li > a::after {
	content: "";
	position: absolute;
	left: 0; bottom: 0;
	width: 0; height: 1px;
	background: var(--color-cta);
	transition: width var(--transition-normal);
}
.primary-nav .nav-menu > li > a:hover::after,
.primary-nav .nav-menu > li.current-menu-item > a::after { width: 100%; }
.primary-nav .nav-menu a:hover,
.primary-nav .nav-menu .current-menu-item > a { color: var(--color-cta); }

/* Dropdowns */
.primary-nav .sub-menu {
	position: absolute;
	top: 100%; left: 0;
	min-width: 220px;
	background: #FFF7F1;
	box-shadow: 0 20px 30px 0 rgba(0, 0, 0, 0.1);
	border-radius: var(--radius-sm);
	padding: 0.5rem 0;
	opacity: 0; visibility: hidden;
	transform: translateY(10px);
	transition: all var(--transition-normal);
	z-index: 10;
}
.primary-nav li:hover > .sub-menu,
.primary-nav li:focus-within > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.primary-nav .sub-menu li { margin: 0; }
.primary-nav .sub-menu a {
	display: block;
	padding: 0.65rem 1.25rem;
	color: #848484;
	border-bottom: 1px solid rgba(132, 132, 132, 0.15);
}
.primary-nav .sub-menu a:hover { color: #011640; }
.submenu-toggle { display: none; }

/* Phone CTA button in header */
.site-header__cta { flex: 0 0 auto; display: flex; justify-content: flex-end; }
.btn--phone {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	font-size: 17px;
	font-weight: var(--font-weight-normal);
	color: var(--color-cta);
	background: var(--color-white);
	border: 1px solid var(--color-cta);
	border-radius: var(--radius-md);
	padding: 12px 20px 10px;
	transition: all var(--transition-normal);
}
.btn--phone:hover { background: var(--color-cta); color: var(--color-white); }
.btn--phone svg { width: 16px; height: 16px; }

/* Hamburger */
.nav-toggle {
	display: none;
	width: 44px; height: 44px;
	align-items: center; justify-content: center;
	color: var(--color-tint);
}
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after {
	content: "";
	display: block;
	width: 26px; height: 2px;
	background: currentColor;
	transition: transform var(--transition-normal), opacity var(--transition-normal);
}
.nav-toggle span { position: relative; }
.nav-toggle span::before { position: absolute; top: -8px; }
.nav-toggle span::after { position: absolute; top: 8px; }
.nav-toggle[aria-expanded="true"] span { background: transparent; }
.nav-toggle[aria-expanded="true"] span::before { transform: translateY(8px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span::after { transform: translateY(-8px) rotate(-45deg); }
