/**
 * GrowProp Theme — Design system & global variables
 * Mobile-first, fluid, minimal. Brand: #F5CB5C (replaces #045BB3 site-wide), Inter.
 */

:root {
	/* Astra global color 1 — match brand */
	--ast-global-color-1: rgb(245, 203, 92);

	/* Brand — use #F5CB5C only; do not use #045BB3 */
	--gp-color-brand: #F5CB5C;
	--gp-color-brand-hover: #e6bc4a;
	--gp-color-brand-light: #fdf4d4;

	/* Buttons */
	--gp-button-bg: #F5CB5C;
	--gp-button-text: #000000;
	--gp-button-hover-bg: #e6bc4a;
	--gp-button-outline-border: #F5CB5C;
	--gp-button-outline-text: #000000;

	/* Neutrals */
	--gp-color-text: #1a1a1a;
	--gp-color-text-muted: #5c5c5c;
	--gp-color-bg: #F2F0E7;
	--gp-color-bg-alt: #e8e6dd;
	--gp-color-border: #e5e5e5;

	/* Typography */
	--gp-font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--gp-font-size-xs: clamp(0.75rem, 2vw, 0.8125rem);
	--gp-font-size-sm: clamp(0.875rem, 2.2vw, 0.9375rem);
	--gp-font-size-base: clamp(1rem, 2.5vw, 1.0625rem);
	--gp-font-size-lg: clamp(1.125rem, 2.8vw, 1.25rem);
	--gp-font-size-xl: clamp(1.25rem, 3vw, 1.5rem);
	--gp-font-size-2xl: clamp(1.5rem, 3.5vw, 1.875rem);
	--gp-font-size-3xl: clamp(1.875rem, 4vw, 2.25rem);
	--gp-font-size-hero: clamp(2rem, 5vw, 2.8rem);
	--gp-font-size-h2: clamp(1.5rem, 4vw, 2.25rem);
	/* Line-height: comfortable reading; headings get room to breathe without feeling loose */
	--gp-line-height-tight: 1.3;
	--gp-line-height-heading: 1.35;
	--gp-line-height-normal: 1.6;
	--gp-line-height-relaxed: 1.7;

	/* Spacing (fluid) */
	--gp-space-xs: clamp(0.25rem, 1vw, 0.5rem);
	--gp-space-sm: clamp(0.5rem, 2vw, 0.75rem);
	--gp-space-md: clamp(1rem, 3vw, 1.25rem);
	--gp-space-lg: clamp(1.5rem, 4vw, 2rem);
	--gp-space-xl: clamp(2rem, 5vw, 3rem);
	--gp-space-2xl: clamp(3rem, 7vw, 4.5rem);
	--gp-space-3xl: clamp(4rem, 10vw, 6rem);

	/* Layout — full width site */
	--gp-container-max: none;
	--gp-container-padding: clamp(1rem, 4vw, 2rem);
	--gp-section-padding-y: clamp(3rem, 8vw, 5rem);
	--gp-header-height: 4rem;

	/* Radius */
	--gp-radius-sm: 4px;
	--gp-radius-md: 8px;
	--gp-radius-lg: 12px;
	--gp-radius-full: 9999px;

	/* Transitions */
	--gp-transition: 0.2s ease;
	--gp-transition-slow: 0.3s ease;

	/* Focus (a11y) */
	--gp-focus-ring: 2px solid var(--gp-color-brand);
	--gp-focus-offset: 2px;
}

/* Smooth scroll for in-page anchor links (e.g. Bento CTA → hero) */
html {
	scroll-behavior: smooth;
	background-color: var(--gp-color-bg);
}

/* Base overrides for Astra */
body,
.site {
	font-family: var(--gp-font-family);
	font-size: var(--gp-font-size-base);
	line-height: var(--gp-line-height-normal);
	color: var(--gp-color-text);
	background-color: var(--gp-color-bg);
	overflow-x: hidden;
}

/* Mobile: ensure touch-friendly tap targets and no tiny text */
@media (max-width: 47.9375rem) {
	.gp-container {
		padding-inline: max(var(--gp-container-padding), 1rem);
	}
}

/* Utility: container — full width with side padding only */
.gp-container {
	width: 100%;
	max-width: var(--gp-container-max);
	margin-inline: auto;
	padding-inline: var(--gp-container-padding);
}

/* Astra: full width layout (child theme override) */
.ast-container {
	max-width: none;
	width: 100%;
}

/* Buttons — min touch target 44px, aligned actions */
.gp-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--gp-space-sm);
	min-height: 2.75rem; /* 44px touch target */
	padding: var(--gp-space-sm) var(--gp-space-lg);
	font-family: var(--gp-font-family);
	font-size: var(--gp-font-size-base);
	font-weight: 600;
	line-height: var(--gp-line-height-tight);
	color: var(--gp-button-text);
	background-color: var(--gp-button-bg);
	border: none;
	border-radius: var(--gp-radius-md);
	cursor: pointer;
	text-decoration: none;
	transition: background-color var(--gp-transition), transform var(--gp-transition);
	-webkit-tap-highlight-color: transparent;
}

/* Section CTA alignment: one or more buttons, centered, consistent gap */
.gp-section-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: var(--gp-space-md);
	margin-top: var(--gp-space-lg);
}

.gp-btn:hover,
.gp-btn:focus,
.gp-btn:visited {
	color: var(--gp-button-text);
}

.gp-btn:hover {
	background-color: var(--gp-button-hover-bg);
}

.gp-btn:focus-visible {
	outline: var(--gp-focus-ring);
	outline-offset: var(--gp-focus-offset);
	color: var(--gp-button-text);
}

.gp-btn--large {
	min-height: 3rem;
	padding: var(--gp-space-md) var(--gp-space-xl);
	font-size: var(--gp-font-size-lg);
}

.gp-btn--outline {
	background-color: transparent;
	border: 2px solid var(--gp-button-outline-border);
	color: var(--gp-button-outline-text);
}

.gp-btn--outline:hover,
.gp-btn--outline:focus,
.gp-btn--outline:visited {
	color: var(--gp-button-outline-text);
}

.gp-btn--outline:hover {
	background-color: var(--gp-color-brand-light);
}

/* Get started dropdown — dark pill button + white panel (title + subtitle per item) */
.gp-get-started-dropdown {
	position: relative;
	display: inline-block;
}

.gp-get-started-dropdown__trigger {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--gp-space-sm);
	min-height: 2.75rem;
	padding: var(--gp-space-sm) var(--gp-space-lg);
	font-family: var(--gp-font-family);
	font-size: var(--gp-font-size-base);
	font-weight: 600;
	line-height: var(--gp-line-height-tight);
	color: var(--gp-button-text);
	background-color: var(--gp-color-brand);
	border: none;
	border-radius: var(--gp-radius-full);
	cursor: pointer;
	text-decoration: none;
	transition: background-color var(--gp-transition);
	-webkit-tap-highlight-color: transparent;
}

.gp-get-started-dropdown__trigger:hover {
	background-color: var(--gp-color-brand-hover);
	color: var(--gp-button-text);
}

.gp-get-started-dropdown__trigger:focus,
.gp-get-started-dropdown__trigger:active {
	background-color: var(--gp-color-brand);
	color: var(--gp-button-text);
}

.gp-get-started-dropdown__trigger:focus:hover,
.gp-get-started-dropdown__trigger:active:hover {
	background-color: var(--gp-color-brand-hover);
	color: var(--gp-button-text);
}

.gp-get-started-dropdown__trigger:focus-visible {
	outline: 2px solid var(--gp-color-brand);
	outline-offset: var(--gp-focus-offset);
}

.gp-get-started-dropdown__trigger-icon {
	display: inline-flex;
	flex-shrink: 0;
}

.gp-get-started-dropdown--large .gp-get-started-dropdown__trigger {
	min-height: 3rem;
	padding: var(--gp-space-md) var(--gp-space-xl);
	font-size: var(--gp-font-size-lg);
}

/* Default: panel opens below (e.g. header) */
.gp-get-started-dropdown__panel {
	position: absolute;
	top: 100%;
	bottom: auto;
	left: auto;
	right: 0;
	z-index: 100;
	margin-top: var(--gp-space-xs);
	min-width: 260px;
	background: #fff;
	border-radius: var(--gp-radius-lg);
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12);
	padding: var(--gp-space-sm) 0;
	overflow: hidden;
}

/* Footer: panel opens above the button */
.gp-footer__cta .gp-get-started-dropdown__panel {
	top: auto;
	bottom: 100%;
	margin-top: 0;
	margin-bottom: var(--gp-space-xs);
}

.gp-get-started-dropdown__panel[hidden] {
	display: none;
}

.gp-get-started-dropdown.is-open .gp-get-started-dropdown__panel {
	display: block;
}

.gp-get-started-dropdown__item {
	display: block;
	padding: var(--gp-space-md) var(--gp-space-lg);
	color: var(--gp-color-text);
	text-decoration: none;
	transition: background-color var(--gp-transition);
}

.gp-get-started-dropdown__item:hover {
	background-color: var(--gp-color-bg-alt);
}

.gp-get-started-dropdown__item:focus {
	outline: none;
}

.gp-get-started-dropdown__item:focus-visible {
	outline: var(--gp-focus-ring);
	outline-offset: -2px;
}

.gp-get-started-dropdown__item-title {
	display: block;
	font-weight: 600;
	font-size: var(--gp-font-size-base);
	color: var(--gp-color-text);
}

.gp-get-started-dropdown__item-subtitle {
	display: block;
	font-size: var(--gp-font-size-sm);
	color: var(--gp-color-text-muted);
	margin-top: 0.15em;
}

/* Footer Get started dropdown — mobile friendly */
@media (max-width: 47.9375rem) {
	.gp-footer__cta .gp-get-started-dropdown,
	.gp-get-started-dropdown--large.gp-get-started-dropdown {
		display: block;
		width: 100%;
	}
	.gp-footer__cta .gp-get-started-dropdown__trigger,
	.gp-get-started-dropdown--large .gp-get-started-dropdown__trigger {
		width: 100%;
		min-height: 3rem;
		padding: var(--gp-space-md) var(--gp-space-lg);
		font-size: var(--gp-font-size-base);
		justify-content: center;
		-webkit-tap-highlight-color: transparent;
		touch-action: manipulation;
	}
	.gp-footer__cta .gp-get-started-dropdown__panel,
	.gp-get-started-dropdown--large .gp-get-started-dropdown__panel {
		left: 0;
		right: 0;
		bottom: 100%;
		top: auto;
		width: 100%;
		min-width: 0;
		max-width: none;
		margin-top: 0;
		margin-bottom: var(--gp-space-sm);
		box-sizing: border-box;
	}
	.gp-footer__cta .gp-get-started-dropdown__item,
	.gp-get-started-dropdown--large .gp-get-started-dropdown__item {
		padding: var(--gp-space-lg) var(--gp-space-lg);
		min-height: 3.5rem;
		display: flex;
		flex-direction: column;
		justify-content: center;
		box-sizing: border-box;
	}
	.gp-footer__cta .gp-get-started-dropdown__item-title,
	.gp-get-started-dropdown--large .gp-get-started-dropdown__item-title {
		font-size: var(--gp-font-size-base);
	}
	.gp-footer__cta .gp-get-started-dropdown__item-subtitle,
	.gp-get-started-dropdown--large .gp-get-started-dropdown__item-subtitle {
		font-size: var(--gp-font-size-sm);
		margin-top: 0.2em;
	}
}

/* Prevent layout shift: reserve space for images */
.gp-img-wrap {
	position: relative;
	overflow: hidden;
	background-color: var(--gp-color-bg-alt);
}

.gp-img-wrap--ratio-16-9 { aspect-ratio: 16 / 9; }
.gp-img-wrap--ratio-4-3 { aspect-ratio: 4 / 3; }
.gp-img-wrap--ratio-1-1 { aspect-ratio: 1 / 1; }

.gp-img-wrap img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Lazy-loaded image placeholder (no shift) */
img[data-src].gp-lazy {
	opacity: 0;
	transition: opacity var(--gp-transition-slow);
}

img.gp-lazy-loaded {
	opacity: 1;
}

/* Section spacing */
.gp-section {
	padding-block: var(--gp-section-padding-y);
}

.gp-section--alt {
	background-color: var(--gp-color-bg-alt);
}

/* Headings */
.gp-heading-hero {
	font-size: var(--gp-font-size-hero);
	font-weight: 700;
	line-height: var(--gp-line-height-heading);
	letter-spacing: -0.02em;
	color: var(--gp-color-text);
	margin: 0 0 var(--gp-space-md);
}

.gp-heading-section {
	font-size: var(--gp-font-size-2xl);
	font-weight: 700;
	line-height: var(--gp-line-height-heading);
	margin: 0 0 var(--gp-space-md);
	color: var(--gp-color-text);
}

.gp-heading-card {
	font-size: var(--gp-font-size-lg);
	font-weight: 600;
	line-height: var(--gp-line-height-heading);
	margin: 0 0 var(--gp-space-xs);
	color: var(--gp-color-text);
}

.gp-text-lead {
	font-size: var(--gp-font-size-lg);
	line-height: var(--gp-line-height-relaxed);
	color: var(--gp-color-text-muted);
	margin: 0 0 var(--gp-space-lg);
	max-width: 36em;
}

/* Hero: centered layout, two-line headline + step + form (reference style) */
/* Full viewport width so content centers in browser, not in a narrow column */
.gp-hero.gp-hero--centered {
	position: relative;
	width: 100vw;
	margin-inline: calc(-50vw + 50%);
	text-align: center;
	padding-top: var(--gp-space-2xl);
	padding-bottom: var(--gp-space-2xl);
	overflow: hidden;
}

.gp-hero__bg {
	position: absolute;
	inset: 0;
	background: var(--gp-color-bg);
	opacity: 1;
	pointer-events: none;
}

.gp-hero__bg::before {
	content: '';
	position: absolute;
	top: -20%;
	left: -10%;
	width: 80%;
	height: 80%;
	background: radial-gradient(ellipse 80% 50% at 50% 50%, rgba(0, 0, 0, 0.02) 0%, transparent 70%);
	border-radius: 50%;
}

.gp-hero__bg::after {
	content: '';
	position: absolute;
	top: 10%;
	right: -15%;
	width: 60%;
	height: 60%;
	background: radial-gradient(ellipse 60% 40% at 50% 50%, rgba(0, 0, 0, 0.015) 0%, transparent 70%);
	border-radius: 50%;
}

.gp-hero__container {
	position: relative;
	width: 100%;
	max-width: none;
	margin-inline: auto;
	/* Minimal side padding so hero block sits centered in viewport */
	padding-inline: clamp(1rem, 2vw, 1.25rem);
}

.gp-hero__content {
	max-width: 36rem;
	margin: 0 auto;
}

.gp-hero.gp-hero--centered .gp-heading-hero {
	display: block;
	margin-bottom: var(--gp-space-sm);
}

.gp-hero__line1,
.gp-hero__line2 {
	display: block;
}

.gp-hero__line2 {
	margin-top: 0.1em;
}

.gp-hero__highlight {
	color: var(--gp-color-brand);
}

.gp-hero__step {
	font-size: var(--gp-font-size-base);
	color: var(--gp-color-text-muted);
	margin: 0 0 var(--gp-space-lg);
	font-weight: 500;
}

.gp-hero__email-form {
	display: flex;
	flex-wrap: wrap;
	gap: var(--gp-space-sm);
	align-items: center;
	justify-content: center;
	max-width: 28rem;
	margin: 0 auto var(--gp-space-md);
}

.gp-hero__email-input {
	flex: 1 1 14rem;
	min-width: 0;
	min-height: 3rem;
	padding: 0 var(--gp-space-md);
	font-family: var(--gp-font-family);
	font-size: var(--gp-font-size-base);
	border: 2px solid var(--gp-color-border);
	border-radius: var(--gp-radius-md);
	background: var(--gp-color-bg);
	color: var(--gp-color-text);
	transition: border-color var(--gp-transition);
}

.gp-hero__email-input::placeholder {
	color: var(--gp-color-text-muted);
}

.gp-hero__email-input:focus {
	outline: none;
	border-color: var(--gp-color-brand);
	box-shadow: 0 0 0 3px var(--gp-color-brand-light);
}

.gp-hero__email-btn {
	flex-shrink: 0;
	min-height: 3rem;
	padding: 0 var(--gp-space-xl);
	font-size: var(--gp-font-size-base);
	font-weight: 600;
	background: var(--gp-color-brand);
	color: var(--gp-button-text);
	border: none;
	border-radius: var(--gp-radius-md);
}

.gp-hero__email-btn:hover {
	background: var(--gp-color-brand-hover);
	color: var(--gp-button-text);
}

.gp-hero__hint {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: var(--gp-font-size-sm);
	color: var(--gp-color-text);
	margin: 0;
}

.gp-hero__hint-icon {
	color: var(--gp-color-brand);
	display: inline-flex;
}

@media (max-width: 47.9375rem) {
	.gp-hero.gp-hero--centered {
		padding-top: var(--gp-space-xl);
		padding-bottom: var(--gp-space-xl);
	}
	.gp-hero__email-form {
		flex-direction: column;
		align-items: stretch;
		max-width: none;
	}
	.gp-hero__email-btn {
		width: 100%;
	}
}

.gp-text-body {
	font-size: var(--gp-font-size-base);
	line-height: var(--gp-line-height-relaxed);
	color: var(--gp-color-text-muted);
	margin: 0;
}

/* Card (conversion blocks) */
.gp-card {
	background: var(--gp-color-bg);
	border: 1px solid var(--gp-color-border);
	border-radius: var(--gp-radius-lg);
	padding: var(--gp-space-lg);
	transition: box-shadow var(--gp-transition), border-color var(--gp-transition);
}

.gp-card:hover {
	border-color: var(--gp-color-brand);
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

/* Skip link (a11y) */
.gp-skip-link {
	position: absolute;
	top: -100%;
	left: var(--gp-container-padding);
	z-index: 100000;
	padding: var(--gp-space-sm) var(--gp-space-md);
	background: var(--gp-color-brand);
	color: var(--gp-button-text);
	font-weight: 600;
	text-decoration: none;
	border-radius: var(--gp-radius-sm);
	transition: top var(--gp-transition);
}

.gp-skip-link:focus {
	top: var(--gp-space-md);
	outline: var(--gp-focus-ring);
	outline-offset: var(--gp-focus-offset);
}

/* Screen reader only */
/* Icons (inline SVG) */
/* Font Awesome icons — scale with font-size */
.gp-icon {
	display: inline-block;
	font-size: 1.5rem;
	vertical-align: middle;
	flex-shrink: 0;
	color: inherit;
	line-height: 1;
}

.gp-icon--brand {
	color: var(--gp-color-brand);
}

.gp-icon--lg {
	font-size: 2rem;
}

.gp-icon--xl {
	font-size: 2.5rem;
}

.gp-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;
}

/* --- Header (reusable) --- */
.gp-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	height: var(--gp-header-height);
	background: var(--gp-color-bg);
	border: 3px solid var(--gp-color-border);
}

.gp-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 100%;
	gap: var(--gp-space-lg);
}

.gp-header__actions {
	display: flex;
	align-items: center;
	gap: var(--gp-space-md);
	margin-left: auto;
}

.gp-header__global-link {
	color: var(--gp-color-text);
	font-size: var(--gp-font-size-sm);
	font-weight: 500;
	text-decoration: none;
	transition: color var(--gp-transition);
}

.gp-header__global-link:hover,
.gp-header__global-link:focus-visible,
.gp-header__global-link:visited {
	color: var(--gp-color-text);
}

.gp-header__global-link:focus-visible {
	outline: var(--gp-focus-ring);
	outline-offset: var(--gp-focus-offset);
}

.gp-header__actions .gp-btn {
	font-size: var(--gp-font-size-sm);
	padding: var(--gp-space-xs) var(--gp-space-md);
	min-height: 2.25rem;
}

.gp-header__logo {
	display: flex;
	align-items: center;
	text-decoration: none;
	color: var(--gp-color-text);
	font-weight: 700;
	font-size: var(--gp-font-size-lg);
}

.gp-header__logo:focus-visible {
	outline: var(--gp-focus-ring);
	outline-offset: var(--gp-focus-offset);
}

.gp-header__logo img,
.gp-header__logo .gp-header__logo-img {
	max-height: 2.5rem;
	width: auto;
	height: auto;
	display: block;
}

.gp-header__nav {
	display: none;
}

/* Burger: only on mobile; hidden on desktop/laptop */
.gp-header__toggle {
	display: none;
}

@media (max-width: 47.9375rem) {
	.gp-header__toggle {
		display: flex;
	}
}

@media (min-width: 48rem) {
	.gp-header__nav {
		display: block;
	}
	.gp-header__toggle {
		display: none;
	}
	.gp-header__actions-mobile {
		display: none;
	}
}

.gp-header__menu {
	display: flex;
	align-items: center;
	gap: var(--gp-space-xl);
	list-style: none;
	margin: 0;
	padding: 0;
}

.gp-header__menu a {
	color: var(--gp-color-text-muted);
	text-decoration: none;
	font-weight: 500;
	font-size: var(--gp-font-size-sm);
	transition: color var(--gp-transition);
}

.gp-header__menu a:hover,
.gp-header__menu a:focus-visible {
	color: var(--gp-color-text);
}

.gp-header__menu .current-menu-item > a {
	font-weight: 700;
	color: var(--gp-color-text);
}

/* Parent items: show arrow when a submenu exists */
.gp-header__menu .menu-item-has-children > a {
	display: inline-flex;
	align-items: center;
	gap: 0.35em;
}

.gp-header__menu .menu-item-has-children > a::after {
	content: "";
	flex-shrink: 0;
	width: 0;
	height: 0;
	margin-top: 0.15em;
	border-left: 0.28em solid transparent;
	border-right: 0.28em solid transparent;
	border-top: 0.32em solid currentColor;
	opacity: 0.65;
	transition: opacity var(--gp-transition), border-top-color var(--gp-transition);
}

.gp-header__menu .menu-item-has-children > a:hover::after,
.gp-header__menu .menu-item-has-children > a:focus-visible::after {
	opacity: 0.9;
}

/* Primary nav: nested items from Appearance → Menus (depth 1 omitted these in PHP) */
.gp-header__menu li {
	position: relative;
}

.gp-header__menu .sub-menu {
	list-style: none;
	margin: 0;
	padding: 0;
}

@media (min-width: 48rem) {
	.gp-header__menu .sub-menu {
		position: absolute;
		top: 100%;
		left: 0;
		min-width: 12rem;
		padding: var(--gp-space-sm) 0;
		background: var(--gp-color-bg);
		border: 1px solid var(--gp-color-border);
		border-radius: var(--gp-radius-md);
		box-shadow: 0 0.5rem 1.5rem rgba(15, 23, 42, 0.08);
		z-index: 200;
		opacity: 0;
		visibility: hidden;
		transform: translateY(0.25rem);
		transition:
			opacity var(--gp-transition),
			visibility var(--gp-transition),
			transform var(--gp-transition);
	}

	.gp-header__menu .sub-menu a {
		display: block;
		padding: var(--gp-space-xs) var(--gp-space-md);
	}

	/* Flyout row: right chevron instead of down */
	.gp-header__menu .sub-menu .menu-item-has-children > a {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: var(--gp-space-sm);
	}

	.gp-header__menu .sub-menu .menu-item-has-children > a::after {
		margin-top: 0;
		border: none;
		width: 0.35em;
		height: 0.35em;
		border-top: 2px solid currentColor;
		border-right: 2px solid currentColor;
		transform: rotate(45deg);
		opacity: 0.55;
	}

	.gp-header__menu li:hover > .sub-menu,
	.gp-header__menu li:focus-within > .sub-menu {
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
	}

	.gp-header__menu .sub-menu .sub-menu {
		top: 0;
		left: 100%;
		margin-left: 0.125rem;
	}
}

@media (max-width: 47.9375rem) {
	.gp-header__menu .sub-menu {
		margin-top: var(--gp-space-xs);
		padding-left: var(--gp-space-md);
		border-left: 2px solid var(--gp-color-border);
	}

	.gp-header__menu .sub-menu a {
		padding: var(--gp-space-xs) 0;
		font-size: var(--gp-font-size-sm);
	}
}

.gp-header__toggle {
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	width: 2.5rem;
	height: 2.5rem;
	padding: 0;
	background: none;
	border: none;
	cursor: pointer;
	-webkit-tap-highlight-color: transparent;
}

.gp-header__toggle-bar {
	display: block;
	width: 100%;
	height: 2px;
	background: var(--gp-color-text);
	border-radius: var(--gp-radius-full);
	transition: transform var(--gp-transition);
}

.gp-header__toggle[aria-expanded="true"] .gp-header__toggle-bar:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.gp-header__toggle[aria-expanded="true"] .gp-header__toggle-bar:nth-child(2) {
	opacity: 0;
}

.gp-header__toggle[aria-expanded="true"] .gp-header__toggle-bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

@media (max-width: 47.9375rem) {
	.gp-header__nav.is-open {
		display: block;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: var(--gp-color-bg);
		border-bottom: 1px solid var(--gp-color-border);
		padding: var(--gp-space-md) var(--gp-container-padding);
	}
	.gp-header__menu {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--gp-space-sm);
	}
	.gp-header__actions {
		display: none;
	}
	.gp-header__actions-mobile {
		margin-top: var(--gp-space-lg);
		padding-top: var(--gp-space-lg);
		border-top: 1px solid var(--gp-color-border);
		display: flex;
		flex-direction: column;
		gap: var(--gp-space-sm);
		align-items: stretch;
	}
	.gp-header__actions-mobile-link {
		display: block;
		padding: var(--gp-space-sm) 0;
		font-weight: 500;
		font-size: var(--gp-font-size-base);
		color: var(--gp-color-text);
		text-decoration: none;
	}
	.gp-header__actions-mobile-link:hover,
	.gp-header__actions-mobile-link:focus-visible {
		color: var(--gp-color-brand);
	}
	.gp-header__actions-mobile .gp-get-started-dropdown {
		width: 100%;
	}
	.gp-header__actions-mobile .gp-get-started-dropdown__trigger {
		width: 100%;
		justify-content: center;
		min-height: 2.75rem;
	}
}

/* --- Footer (reusable) — minimal, page background only, no banded stripes --- */
.gp-footer {
	background: transparent;
	border-top: 1px solid var(--gp-color-border);
	padding: var(--gp-space-xl) 0 var(--gp-space-md);
}

.gp-footer__inner {
	display: flex;
	flex-direction: column;
	gap: var(--gp-space-lg);
}

.gp-footer__top {
	display: grid;
	gap: var(--gp-space-lg);
}

@media (min-width: 48rem) {
	.gp-footer__top {
		grid-template-columns: 1fr auto auto;
		align-items: start;
		gap: var(--gp-space-xl);
	}
}

.gp-footer__logo {
	display: inline-block;
	font-weight: 700;
	font-size: var(--gp-font-size-lg);
	color: var(--gp-color-text);
	text-decoration: none;
}

.gp-footer__logo:focus-visible {
	outline: var(--gp-focus-ring);
	outline-offset: var(--gp-focus-offset);
}

.gp-footer__logo img,
.gp-footer__logo .gp-footer__logo-img {
	max-height: 2.5rem;
	width: auto;
	height: auto;
	display: block;
}

.gp-footer__tagline {
	margin-top: var(--gp-space-xs);
	max-width: 20em;
}

.gp-footer__bottom {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--gp-space-md);
	padding-top: var(--gp-space-md);
	margin-top: var(--gp-space-sm);
	border-top: 1px solid var(--gp-color-border);
}

.gp-footer__copy {
	margin: 0;
}

.gp-footer__menu {
	display: flex;
	flex-wrap: wrap;
	column-gap: var(--gp-space-md);
	row-gap: var(--gp-space-xs);
	list-style: none;
	margin: 0;
	padding: 0;
}

.gp-footer__menu a {
	color: var(--gp-color-text-muted);
	text-decoration: none;
	font-size: var(--gp-font-size-sm);
}

.gp-footer__menu a:hover {
	color: var(--gp-color-text);
}

.gp-footer__menu .sub-menu {
	list-style: none;
	margin: var(--gp-space-xs) 0 0;
	padding: 0 0 0 var(--gp-space-md);
}

.gp-footer__menu .sub-menu a {
	font-size: var(--gp-font-size-sm);
}

/* Footer mega (sitemap + copyright / social) — same surface as page, no extra fills */
.gp-footer-mega {
	background: transparent;
	margin-top: var(--gp-space-md);
}

.gp-footer-mega__inner {
	width: 100%;
	margin-inline: auto;
	padding-inline: var(--gp-container-padding);
	box-sizing: border-box;
}

.gp-footer-mega__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	column-gap: var(--gp-space-md);
	row-gap: var(--gp-space-lg);
	padding-block: var(--gp-space-md) var(--gp-space-sm);
}

@media (min-width: 48rem) {
	.gp-footer-mega__grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		column-gap: var(--gp-space-lg);
		row-gap: var(--gp-space-xl);
		padding-block: var(--gp-space-lg) var(--gp-space-sm);
	}
}

.gp-footer-mega__heading {
	margin: 0 0 var(--gp-space-sm);
	font-size: var(--gp-font-size-xs);
	font-weight: 600;
	line-height: var(--gp-line-height-tight);
	color: var(--gp-color-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.gp-footer-mega__list {
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: var(--gp-font-size-sm);
	font-weight: 500;
}

.gp-footer-mega__item {
	margin-bottom: var(--gp-space-sm);
}

.gp-footer-mega__item:last-child {
	margin-bottom: 0;
}

/* Flat mega nav: grid gaps only — avoid row-gap + item margin stacking */
.gp-footer-mega__list--flat.gp-footer-mega__grid {
	column-gap: var(--gp-space-sm);
	row-gap: var(--gp-space-xs);
	padding-block: var(--gp-space-sm) var(--gp-space-xs);
}

@media (min-width: 48rem) {
	.gp-footer-mega__list--flat.gp-footer-mega__grid {
		column-gap: var(--gp-space-md);
		row-gap: var(--gp-space-sm);
		padding-block: var(--gp-space-md) var(--gp-space-xs);
	}
}

.gp-footer-mega__list--flat .gp-footer-mega__item {
	margin-bottom: 0;
}

.gp-footer-mega__link {
	color: var(--gp-color-text-muted);
	text-decoration: none;
	transition: color var(--gp-transition), text-decoration var(--gp-transition);
}

.gp-footer-mega__link:hover,
.gp-footer-mega__link:focus-visible {
	color: var(--gp-color-text);
	text-decoration: underline;
}

.gp-footer-mega__link:focus-visible {
	outline: var(--gp-focus-ring);
	outline-offset: var(--gp-focus-offset);
}

.gp-footer-mega__sub {
	padding: var(--gp-space-lg) 0 0;
	margin-top: 0;
	background: transparent;
	border: none;
}

.gp-footer-mega__copy {
	margin: 0;
	font-size: var(--gp-font-size-xs);
	text-align: center;
	color: var(--gp-color-text-muted);
}

@media (min-width: 48rem) {
	.gp-footer-mega__copy {
		text-align: left;
	}
}

.gp-footer-mega__copy-link {
	color: inherit;
	font-weight: 600;
	text-decoration: none;
}

.gp-footer-mega__copy-link:hover,
.gp-footer-mega__copy-link:focus-visible {
	text-decoration: underline;
}

.gp-footer__inner--after-mega {
	padding-top: var(--gp-space-sm);
	padding-bottom: var(--gp-space-md);
}

.gp-footer__bottom--menu-only {
	padding-top: var(--gp-space-sm);
	margin-top: 0;
	border-top: 1px solid var(--gp-color-border);
}

.gp-footer__bottom--portal-fallback {
	margin-top: var(--gp-space-md);
	padding-top: var(--gp-space-md);
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}
