:root {
	--hh-container: 1200px;
	--hh-gutter: 20px;
	--hh-bg: #ffffff;
	--hh-muted: #f6f7fb;
	--hh-text: #0f172a;
	--hh-subtext: #475569;
	--hh-border: #e2e8f0;
	--hh-primary: #0b2a5b;
	--hh-accent: #ffb200;
	--hh-menu-hover: var(--hh-accent);
	--hh-menu-rows: 13;
	--hh-menu-row-h: 37px;
	--hh-radius: 12px;
	--hh-shadow: 0 12px 28px rgba(2, 6, 23, 0.12), 0 2px 10px rgba(2, 6, 23, 0.06);
}

* { box-sizing: border-box; }
body {
	margin: 0;
	font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
	color: var(--hh-text);
	background: var(--hh-bg);
	line-height: 1.55;
}
a { color: inherit; }
.container {
	width: min(var(--hh-container), calc(100% - (var(--hh-gutter) * 2)));
	margin-inline: auto;
}
.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;
}
.section { padding: 72px 0; }
.section:nth-of-type(even) { background: var(--hh-muted); }

h1, h2, h3 { line-height: 1.15; margin: 0 0 14px; }
h1 { font-size: clamp(32px, 4vw, 52px); letter-spacing: -0.02em; }
h2 { font-size: clamp(24px, 2.8vw, 36px); letter-spacing: -0.01em; }
h3 { font-size: 18px; }
p { margin: 0 0 14px; color: var(--hh-subtext); }
.lead { font-size: 18px; color: var(--hh-text); opacity: 0.9; }
.eyebrow { font-weight: 700; color: var(--hh-primary); letter-spacing: 0.08em; text-transform: uppercase; font-size: 12px; }

/* Header */
.site-header { position: sticky; top: 0; z-index: 20; background: rgba(255, 255, 255, 0.92); backdrop-filter: blur(10px); border-bottom: 1px solid var(--hh-border); }
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 12px 0; }
.brand a { text-decoration: none; font-weight: 800; letter-spacing: -0.02em; }
.brand-logo { display: block; height: 40px; width: auto; }
.nav-toggle {
	display: none;
	width: 42px;
	height: 42px;
	border: 1px solid var(--hh-border);
	background: white;
	cursor: pointer;
	padding: 0;
}
.nav-toggle-bars {
	display: block;
	width: 18px;
	height: 2px;
	background: var(--hh-text);
	box-shadow: 0 -6px 0 var(--hh-text), 0 6px 0 var(--hh-text);
}
.site-nav { display: flex; align-items: center; gap: 18px; flex: 1; justify-content: flex-end; }
.menu { list-style: none; display: flex; gap: 22px; padding: 0; margin: 0; flex-wrap: nowrap; align-items: center; }
.site-nav .menu > ul { list-style: none; display: flex; gap: 22px; padding: 0; margin: 0; flex-wrap: nowrap; align-items: center; }
.menu > li > a,
.site-nav .menu > ul > li > a { text-decoration: none; padding: 10px 8px; border-radius: 0; color: #0f172a; font-weight: 600; font-size: 15px; letter-spacing: 0.02em; text-transform: uppercase; white-space: nowrap; }
.menu > li > a:hover {
	background: transparent;
	color: var(--hh-menu-hover);
}
.menu > li.current-menu-item > a,
.menu > li.current-menu-ancestor > a,
.menu > li.current_page_item > a,
.menu > li.current_page_ancestor > a { background: rgba(11, 42, 91, 0.10); color: var(--hh-primary); }

.menu-item-no-link > a {
	cursor: default;
}

.menu-item-no-link > a:hover {
	color: var(--hh-menu-hover);
}

/* Dropdown (desktop) — simple popup + deep menus stacked in one column */
.menu li { position: relative; }
.menu li ul {
	margin: 0;
	list-style: none;
}

@media (min-width: 769px) {
	.site-header { position: sticky; z-index: 50; }
	.nav-toggle { display: none; }

	/* Default: small popup dropdown */
	.menu li > .sub-menu {
		position: absolute;
		left: 0;
		top: calc(100% - 2px);
		min-width: 220px;
		max-width: 280px;
		background: #fff;
		border: 1px solid var(--hh-border);
		box-shadow: var(--hh-shadow);
		padding: 8px 0;
		display: none;
		z-index: 40;
	}

	.menu li:hover > .sub-menu,
	.menu li.is-dropdown-open > .sub-menu {
		display: block;
	}

	.menu li > .sub-menu a {
		display: block;
		padding: 9px 14px;
		font-weight: 400;
		font-size: 15px;
		color: #0f172a;
		text-transform: none;
		text-decoration: none;
		letter-spacing: 0;
		white-space: normal;
		line-height: 1.35;
	}

	.menu > li:not(:has(> .sub-menu > .menu-item-has-children)) > .sub-menu a:hover {
		background: transparent;
		color: var(--hh-menu-hover);
		text-decoration: none;
	}

	/* Nested flyout — simple dropdowns only (not deep menus like SERVICE) */
	.menu > li:not(:has(> .sub-menu > .menu-item-has-children)) > .sub-menu > li > .sub-menu {
		left: calc(100% - 4px);
		top: -8px;
		min-width: 220px;
		max-width: 280px;
	}

	/* Deep menu (e.g. SERVICE): 13 rows/column, overflow flows right */
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu {
		left: 0;
		right: auto;
		width: max-content;
		max-width: min(96vw, 1200px);
		display: none;
		padding: 8px 0;
		grid-template-rows: repeat(var(--hh-menu-rows), minmax(var(--hh-menu-row-h), auto));
		grid-auto-flow: column;
		grid-auto-columns: var(--hh-menu-col-width, max-content);
		gap: 0 28px;
		align-items: start;
	}

	.menu > li:has(> .sub-menu > .menu-item-has-children):hover > .sub-menu,
	.menu > li:has(> .sub-menu > .menu-item-has-children).is-dropdown-open > .sub-menu {
		display: grid;
	}

	/* Flatten nested ul/li so every link is one grid row */
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu li,
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu ul.sub-menu {
		display: contents;
	}

	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu a {
		display: block;
		padding: 9px 16px;
		font-weight: 400;
		font-size: 15px;
		color: #0f172a;
		text-transform: none;
		text-decoration: none;
		letter-spacing: 0;
		line-height: 1.35;
		white-space: nowrap;
		min-height: var(--hh-menu-row-h);
		box-sizing: border-box;
	}

	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu > li.menu-item-has-children > a,
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu li.menu-item-has-children > a,
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu .menu-item-nav-parent > a {
		font-size: 17px;
		font-weight: 600;
		color: var(--hh-primary);
	}

	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu li li > a,
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu .menu-item-nav-child > a {
		padding-left: 32px;
		font-size: 15px;
		font-weight: 400;
		color: #1a1a1a;
		line-height: 1.4;
	}

	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu li li li > a {
		padding-left: 40px;
		font-weight: 400;
		font-size: 15px;
		color: #1a1a1a;
	}

	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu li.menu-item-has-children > a:hover {
		color: var(--hh-primary);
	}

	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu li li > a:hover {
		color: #1a1a1a;
	}

	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu a:hover {
		background: transparent !important;
		text-decoration: none !important;
	}

	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu > li.menu-item-has-children.current-menu-item > a,
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu > li.menu-item-has-children.current_page_item > a,
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu > li.menu-item-has-children.current-menu-ancestor > a,
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu > li.menu-item-has-children.current_page_ancestor > a,
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu li.menu-item-has-children.current-menu-ancestor > a {
		background: transparent;
		color: var(--hh-primary);
		font-weight: 700;
	}

	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu li li.current-menu-item > a,
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu li li.current_page_item > a,
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu li li.current-menu-ancestor > a,
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu li li.current_page_ancestor > a,
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu .menu-item-nav-child.current-menu-item > a,
	.menu > li:has(> .sub-menu > .menu-item-has-children) > .sub-menu .menu-item-nav-child.current_page_item > a {
		background: transparent;
		color: #1a1a1a;
		font-weight: 600;
	}
}

@media (max-width: 768px) {
	.menu li ul {
		position: static;
		box-shadow: none;
		display: none;
		padding: 0 0 0 14px;
		border-left: 2px solid rgba(11, 42, 91, 0.12);
		margin-top: 4px;
	}

	.menu li.is-open > ul,
	.menu li.is-open ul {
		display: block;
	}

	.menu li ul li a {
		display: block;
		padding: 8px 10px;
		text-transform: none;
		font-size: 15px;
		white-space: normal;
		text-decoration: none;
	}

	/* BIM dropdown: parent pillars blue, child pages black */
	.menu > li.menu-item-has-children > ul > li.menu-item-has-children > a,
	.menu > li.menu-item-has-children > ul > li.menu-item-nav-parent > a {
		color: var(--hh-primary);
		font-weight: 600;
		font-size: 16px;
	}

	.menu > li.menu-item-has-children > ul ul > li > a,
	.menu > li.menu-item-has-children > ul > li.menu-item-nav-child > a {
		color: #1a1a1a;
		font-weight: 400;
		font-size: 15px;
		padding-left: 24px;
	}

	.menu > li.menu-item-has-children > ul > li.menu-item-has-children.current-menu-item > a,
	.menu > li.menu-item-has-children > ul > li.menu-item-has-children.current_page_item > a,
	.menu > li.menu-item-has-children > ul > li.menu-item-has-children.current-menu-ancestor > a,
	.menu > li.menu-item-has-children > ul > li.menu-item-has-children.current_page_ancestor > a {
		color: var(--hh-primary);
		font-weight: 700;
	}

	.menu > li.menu-item-has-children > ul ul > li.current-menu-item > a,
	.menu > li.menu-item-has-children > ul ul > li.current_page_item > a {
		color: #1a1a1a;
		font-weight: 600;
	}

	.menu li ul li a:hover {
		background: transparent;
	}

	.menu > li > a:hover {
		background: transparent;
		color: var(--hh-menu-hover);
	}
}

/* Pre-footer CTA (site-wide) */
.site-pre-footer-cta {
	padding: 48px 0;
	background: #1a3055;
	color: #fff;
	text-align: center;
}

.site-pre-footer-cta-inner {
	max-width: 900px;
}

.site-pre-footer-cta-title {
	margin: 0 0 14px;
	font-size: clamp(24px, 3vw, 34px);
	line-height: 1.35;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.02em;
}

.site-pre-footer-cta-subtitle {
	margin: 0 0 28px;
	font-size: clamp(15px, 2vw, 18px);
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.92);
}

.site-pre-footer-cta-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 28px 40px;
}

.site-pre-footer-cta-primary,
.site-pre-footer-cta-secondary {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 12px 22px;
	border: 2px solid #fff;
	border-radius: 0;
	background: transparent;
	color: #fff;
	font-size: clamp(15px, 2vw, 16px);
	font-weight: 700;
	text-decoration: none;
	letter-spacing: 0.02em;
	transition: background 0.2s ease, color 0.2s ease;
}

.site-pre-footer-cta-primary:hover,
.site-pre-footer-cta-primary:focus-visible,
.site-pre-footer-cta-secondary:hover,
.site-pre-footer-cta-secondary:focus-visible {
	background: #fff;
	color: #0b2a5b;
	text-decoration: none;
}

/* Footer — navy/charcoal, 4 columns */
.site-footer {
	background: #1e2a3a;
	color: rgba(255, 255, 255, 0.88);
	position: relative;
	overflow: hidden;
}

.site-footer::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: min(55%, 520px);
	height: 100%;
	opacity: 0.35;
	background:
		radial-gradient(circle at 70% 20%, rgba(59, 130, 246, 0.25) 0, transparent 45%),
		linear-gradient(135deg, transparent 40%, rgba(59, 130, 246, 0.08) 100%);
	pointer-events: none;
}

.footer-main {
	position: relative;
	z-index: 1;
	padding: 44px 0 36px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.footer-columns {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 28px;
}

.footer-col {
	padding-right: 16px;
	border-right: 1px solid rgba(255, 255, 255, 0.08);
}

.footer-col:last-child {
	border-right: 0;
	padding-right: 0;
}

.footer-col-head {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 14px;
	padding-bottom: 10px;
	border-bottom: 2px solid #3b82f6;
}

.footer-col-icon {
	display: inline-flex;
	width: 28px;
	height: 28px;
	color: #60a5fa;
	flex: 0 0 auto;
}

.footer-col-icon svg {
	width: 28px;
	height: 28px;
	display: block;
}

.footer-col-title {
	margin: 0;
	font-size: 17px;
	font-weight: 800;
	color: #fff;
	line-height: 1.2;
}

.footer-col-intro {
	margin-bottom: 14px;
	padding-bottom: 14px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.footer-col-intro p {
	margin: 0 0 6px;
	font-size: 14px;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.78);
}

.footer-col-intro p:first-child {
	font-weight: 700;
	color: rgba(255, 255, 255, 0.92);
}

.footer-links {
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-links li {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	margin: 0 0 10px;
	padding-bottom: 10px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.footer-links li:last-child {
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: 0;
}

.footer-links a {
	flex: 1;
	color: rgba(255, 255, 255, 0.72);
	text-decoration: none;
	font-size: 14px;
	line-height: 1.45;
}

.footer-links a:hover {
	color: #e6b422;
	text-decoration: none;
}

.footer-link-arrow {
	flex: 0 0 auto;
	color: rgba(255, 255, 255, 0.35);
	font-size: 16px;
	line-height: 1;
}

.footer-bottom {
	position: relative;
	z-index: 1;
	padding: 16px 0 20px;
	background: #151d28;
}

.footer-bottom-inner {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
}

.footer-bottom-left {
	flex: 1;
	min-width: 240px;
}

.footer-copyright {
	margin: 0 0 6px;
	font-size: 13px;
	color: rgba(255, 255, 255, 0.75);
	line-height: 1.5;
}

.footer-credit {
	margin: 0;
	font-size: 12px;
	color: rgba(255, 255, 255, 0.55);
	line-height: 1.5;
}

.footer-legal {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
	font-size: 13px;
}

.footer-legal a {
	color: rgba(255, 255, 255, 0.72);
	text-decoration: none;
}

.footer-legal a:hover {
	color: #e6b422;
	text-decoration: underline;
}

.footer-legal-sep {
	color: rgba(255, 255, 255, 0.35);
}

/* Responsive (global) */
@media (max-width: 768px) {
	.site-nav { position: fixed; inset: 70px 16px auto 16px; background: white; border: 1px solid var(--hh-border); border-radius: var(--hh-radius); padding: 14px; flex-direction: column; align-items: stretch; box-shadow: var(--hh-shadow); display: none; max-height: calc(100vh - 90px); overflow-y: auto; }
	.site-nav.is-open { display: flex; }
	.menu { flex-direction: column; gap: 6px; align-items: stretch; }
	.nav-toggle { display: inline-grid; place-items: center; }

	.site-pre-footer-cta {
		padding: 36px 0;
	}

	.site-pre-footer-cta-actions {
		flex-direction: column;
		gap: 18px;
	}

	.footer-columns {
		grid-template-columns: 1fr;
		gap: 28px;
	}

	.footer-col {
		padding-right: 0;
		border-right: 0;
		padding-bottom: 24px;
		border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	}

	.footer-col:last-child {
		padding-bottom: 0;
		border-bottom: 0;
	}

	.footer-bottom-inner {
		flex-direction: column;
		align-items: flex-start;
	}
}
