/* Page-specific styles */

/* Home page */
body.page-home.home-intro-pending{
	overflow: hidden;
}

body.page-home .eyebrow{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--green-dark);
	margin-bottom: var(--sp-5);
}
body.page-home .eyebrow::before{
	content: '';
	width: 28px;
	height: 2px;
	background: var(--green);
	border-radius: 2px;
}
body.page-home .eyebrow--light{ color: var(--green-light); }
body.page-home .eyebrow--light::before{ background: var(--green); }
body.page-home .le-btn{
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 54px;
	padding: 0 30px;
	border-radius: var(--r-md);
	font-family: var(--font-body);
	font-size: 0.9375rem;
	font-weight: 600;
	letter-spacing: 0.01em;
	white-space: nowrap;
	cursor: pointer;
	overflow: hidden;
	border: 1px solid transparent;
	transition: background-color var(--dur) var(--ease),
	            color var(--dur) var(--ease),
	            border-color var(--dur) var(--ease),
	            box-shadow var(--dur) var(--ease),
	            transform var(--dur) var(--ease);
}
body.page-home .le-btn .lbl{
	display: inline-block;
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
body.page-home .le-btn .arr{
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%) translateX(-40px);
	opacity: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
	pointer-events: none;
}
body.page-home .le-btn:hover .lbl{ opacity: 0; transform: translateX(30px); }
body.page-home .le-btn:hover .arr{ opacity: 1; transform: translate(-50%, -50%) translateX(0); }
body.page-home .le-btn--primary{
	background: var(--green);
	color: var(--navy);
	border-color: var(--green);
	box-shadow: var(--sh-green);
}
body.page-home .le-btn--primary:hover{
	background: var(--green-dark);
	border-color: var(--green-dark);
	color: var(--white);
	box-shadow: var(--sh-green-lg);
	transform: translateY(-2px);
}
body.page-home .le-btn--secondary{
	background: transparent;
	color: var(--navy);
	border-color: var(--navy);
}
body.page-home .le-btn--secondary:hover{
	background: var(--navy);
	color: var(--white);
	transform: translateY(-2px);
}
body.page-home .on-dark .le-btn--secondary{ color: var(--white); border-color: rgba(255,255,255,0.4); }
body.page-home .on-dark .le-btn--secondary:hover{ background: var(--white); color: var(--navy); border-color: var(--white); }
body.page-home .le-btn--lg{ height: 60px; padding: 0 36px; font-size: 1rem; }
body.page-home .navbar{
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--sp-5) var(--sp-10);
	transition: background-color var(--dur) var(--ease),
	            backdrop-filter var(--dur) var(--ease),
	            box-shadow var(--dur) var(--ease),
	            opacity 0.8s var(--ease),
	            transform 0.8s var(--ease);
	opacity: 0;
	transform: translateY(-18px);
	pointer-events: none;
	animation: navReveal 0.8s var(--ease) 3.85s forwards;
}
body.page-home.home-intro-skip .navbar{
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
	animation: none;
}
@keyframes navReveal{
	from{ opacity: 0; transform: translateY(-18px); pointer-events: none; }
	to{ opacity: 1; transform: translateY(0); pointer-events: auto; }
}
body.page-home .navbar.is-transparent{ background: transparent; }
body.page-home .navbar.is-solid{
	background: rgba(255, 255, 255, 0.92);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-shadow: 0 1px 0 rgba(7, 31, 69, 0.06);
}
body.page-home .nav-logo{
	display: flex;
	align-items: center;
	flex-shrink: 0;
}
body.page-home .nav-logo img{
	display: block;
	height: 56px;
	width: auto;
}
body.page-home .nav-logo-light{ display: none; }
body.page-home .is-transparent .nav-logo-dark{ display: none; }
body.page-home .is-transparent .nav-logo-light{ display: block; }
body.page-home .is-solid .nav-logo-dark{ display: block; }
body.page-home .is-solid .nav-logo-light{ display: none; }
body.page-home .is-transparent .nav-link{ color: var(--white); }
body.page-home .is-solid .nav-link{ color: var(--navy); }
body.page-home .nav-links{ display: flex; align-items: center; gap: var(--sp-8); }
body.page-home .nav-link{
	position: relative;
	font-size: 0.9375rem;
	font-weight: 500;
	transition: color var(--dur) var(--ease);
}
body.page-home .nav-link::after{
	content: '';
	position: absolute;
	left: 0;
	bottom: -10px;
	width: 100%;
	height: 2px;
	border-radius: 999px;
	background: currentColor;
	transform: scaleX(0);
	transform-origin: left center;
	opacity: 0.85;
	transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
body.page-home .nav-link:hover{
	color: var(--green);
}
body.page-home .nav-link:hover::after, body.page-home .nav-link:focus-visible::after{
	transform: scaleX(1);
}
body.page-home .is-transparent .nav-link::after{ background: var(--green-light); }
body.page-home .is-solid .nav-link::after{ background: var(--green); }
body.page-home .nav-login{
	position: relative;
	padding-bottom: 18px;
	margin-bottom: -18px;
}
body.page-home .nav-login::after{
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	height: 24px;
}
body.page-home .nav-login-toggle{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	height: 52px;
	padding: 0 24px 0 26px;
	border-radius: 16px;
	font-size: 0.875rem;
	font-weight: 600;
	background: transparent;
	border: 1px solid;
	cursor: pointer;
	transition: color var(--dur) var(--ease),
	            border-color var(--dur) var(--ease),
	            background-color var(--dur) var(--ease),
	            box-shadow var(--dur) var(--ease),
	            transform var(--dur) var(--ease);
}
body.page-home .nav-login-toggle svg{
	width: 16px;
	height: 16px;
	transition: transform var(--dur) var(--ease);
}
body.page-home .nav-login.is-open .nav-login-toggle svg{ transform: rotate(180deg); }
body.page-home .is-transparent .nav-login-toggle{
	color: var(--white);
	border-color: rgba(255,255,255,0.22);
	background: linear-gradient(180deg, rgba(255,255,255,0.14) 0%, rgba(255,255,255,0.06) 100%);
	box-shadow: inset 0 1px 0 rgba(255,255,255,0.14);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}
body.page-home .is-transparent .nav-login-toggle:hover, body.page-home .is-transparent .nav-login.is-open .nav-login-toggle{
	background: linear-gradient(180deg, rgba(255,255,255,0.18) 0%, rgba(255,255,255,0.08) 100%);
	border-color: rgba(126,234,160,0.4);
	box-shadow: inset 0 1px 0 rgba(255,255,255,0.16), 0 16px 32px rgba(7,31,69,0.16);
}
body.page-home .is-solid .nav-login-toggle{
	color: var(--navy);
	border-color: rgba(7,31,69,0.12);
	background: linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(244,247,250,0.98) 100%);
	box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 8px 24px rgba(7,31,69,0.05);
}
body.page-home .is-solid .nav-login-toggle:hover, body.page-home .is-solid .nav-login.is-open .nav-login-toggle{
	background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(240,248,243,1) 100%);
	border-color: rgba(42,197,88,0.28);
	box-shadow: inset 0 1px 0 rgba(255,255,255,0.9), 0 14px 28px rgba(7,31,69,0.08);
}
body.page-home .nav-login-menu{
	position: absolute;
	top: calc(100% + 6px);
	right: 0;
	width: 320px;
	padding: 12px;
	border-radius: 22px;
	background:
		radial-gradient(120% 120% at 100% 0%, rgba(42,197,88,0.14) 0%, transparent 42%),
		linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(246,248,251,0.99) 100%);
	border: 1px solid rgba(7,31,69,0.09);
	box-shadow: 0 28px 70px rgba(7,31,69,0.18);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	opacity: 0;
	transform: translateY(10px);
	visibility: hidden;
	pointer-events: none;
	transition: opacity var(--dur) var(--ease),
	            transform var(--dur) var(--ease),
	            visibility 0s linear var(--dur);
}
body.page-home .nav-login-menu::before{
	content: '';
	position: absolute;
	top: -9px;
	right: 34px;
	width: 18px;
	height: 18px;
	background: rgba(255,255,255,0.98);
	border-top: 1px solid rgba(7,31,69,0.1);
	border-left: 1px solid rgba(7,31,69,0.1);
	transform: rotate(45deg);
}
body.page-home .nav-login.is-open .nav-login-menu{
	opacity: 1;
	transform: translateY(0);
	visibility: visible;
	pointer-events: auto;
	transition: opacity var(--dur) var(--ease),
	            transform var(--dur) var(--ease),
	            visibility 0s linear 0s;
}
body.page-home .portal-link{
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px 15px;
	border-radius: 18px;
	color: var(--navy);
	transition: background-color var(--dur) var(--ease),
	            transform var(--dur) var(--ease),
	            border-color var(--dur) var(--ease),
	            box-shadow var(--dur) var(--ease);
	border: 1px solid rgba(7,31,69,0.06);
	background: linear-gradient(180deg, rgba(255,255,255,0.95) 0%, rgba(249,250,252,1) 100%);
}
body.page-home .portal-link + .portal-link{
	margin-top: 8px;
}
body.page-home .portal-link:hover{
	background: linear-gradient(135deg, rgba(42,197,88,0.12) 0%, rgba(255,255,255,1) 100%);
	border-color: rgba(42,197,88,0.24);
	transform: translateY(-2px);
	box-shadow: 0 12px 24px rgba(7,31,69,0.08);
}
body.page-home .portal-icon{
	flex-shrink: 0;
	width: 46px;
	height: 46px;
	border-radius: 14px;
	display: grid;
	place-items: center;
	background: linear-gradient(180deg, rgba(42,197,88,0.16) 0%, rgba(42,197,88,0.08) 100%);
	border: 1px solid rgba(42,197,88,0.18);
	color: var(--navy);
}
body.page-home .portal-copy{
	display: flex;
	flex-direction: column;
	flex: 1;
}
body.page-home .portal-title{
	font-family: var(--font-display);
	font-size: 1.02rem;
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -0.01em;
}
body.page-home .portal-arrow{
	flex-shrink: 0;
	color: var(--navy-light);
	opacity: 0.72;
}
@media (max-width: 960px){
	body.page-home .nav-links{ gap: var(--sp-5); }
	body.page-home .nav-login-menu{
		width: min(360px, calc(100vw - 40px));
		right: -10px;
	}
}
body.page-home .hero{
	position: relative;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 140px var(--sp-10) var(--sp-20);
	overflow: hidden;
	isolation: isolate;
	color: var(--white);
}
body.page-home .hero-bg-photo{
	position: absolute;
	inset: 0;
	z-index: -3;
	background:
		linear-gradient(90deg, rgba(7,31,69,0.92) 0%, rgba(7,31,69,0.78) 28%, rgba(7,31,69,0.46) 56%, rgba(7,31,69,0.28) 100%),
		url('../assets/images/hero-family-bg.png') center right / cover no-repeat;
	opacity: 0;
	transform: scale(1.08);
	filter: saturate(0.92) contrast(1.02);
	animation: heroBgReveal 1.1s var(--ease) 1.15s forwards;
}
@keyframes heroBgReveal{
	from{ opacity: 0; transform: scale(1.08); }
	to{ opacity: 1; transform: scale(1); }
}
body.page-home .hero::before{
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(120% 80% at 82% 10%, rgba(42,197,88,0.18) 0%, transparent 48%),
		radial-gradient(120% 80% at 0% 100%, rgba(42,74,128,0.46) 0%, transparent 58%),
		linear-gradient(160deg, rgba(7,31,69,0.78) 0%, rgba(11,40,86,0.46) 55%, rgba(26,50,96,0.56) 100%);
	z-index: -2;
}
body.page-home.home-intro-pending .hero::before{
	background:
		radial-gradient(54% 42% at 50% 46%, rgba(42,197,88,0.12) 0%, transparent 62%),
		radial-gradient(64% 54% at 84% 14%, rgba(42,197,88,0.1) 0%, transparent 68%),
		radial-gradient(72% 58% at 18% 82%, rgba(42,74,128,0.42) 0%, transparent 72%),
		linear-gradient(150deg, rgba(7,31,69,0.98) 0%, rgba(10,41,82,0.96) 56%, rgba(17,86,94,0.9) 100%);
}
body.page-home .hero::after{
	content: '';
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.014) 0 1px, transparent 1px 18px);
	z-index: -1;
	pointer-events: none;
}
body.page-home.home-intro-pending .hero::after{
	background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.01) 0 1px, transparent 1px 22px);
}
body.page-home .hero-center-logo{
	position: absolute;
	top: 50%; left: 50%;
	transform: translate(-50%, -50%) scale(1);
	width: 240px;
	height: 240px;
	z-index: 1;
	opacity: 1;
	animation: heroLogoDock 1.3s var(--ease) 2.65s forwards;
}
body.page-home .hero-center-logo::before, body.page-home .hero-center-logo::after{
	content: '';
	position: absolute;
	left: 50%;
	top: 50%;
	border-radius: 50%;
	transform: translate(-50%, -50%);
	pointer-events: none;
}
body.page-home .hero-center-logo::before{
	width: 168px;
	height: 168px;
	background: radial-gradient(circle, rgba(42,197,88,0.24) 0%, rgba(42,74,128,0.2) 46%, transparent 74%);
	filter: blur(18px);
	opacity: 0;
	animation: heroGlowBurst 1.4s ease-out 0.95s forwards;
}
body.page-home .hero-center-logo::after{
	width: 228px;
	height: 228px;
	background: radial-gradient(circle, rgba(19,81,118,0.34) 0%, rgba(42,197,88,0.08) 44%, transparent 72%);
	filter: blur(22px);
	opacity: 0;
	animation: heroHaloBurst 1.8s ease-out 1.1s forwards;
}
body.page-home .hero-logo-mark{
	position: relative;
	width: 100%;
	height: 100%;
}
body.page-home .hero-logo-mark svg{
	width: 100%;
	height: 100%;
	overflow: visible;
	filter: drop-shadow(0 18px 40px rgba(7,31,69,0.28));
}
body.page-home .hero-logo-mark .logo-part-l, body.page-home .hero-logo-mark .logo-part-e, body.page-home .hero-logo-mark .logo-part-s{
	transform-box: fill-box;
	transform-origin: 50% 50%;
	will-change: transform, opacity, filter;
}
body.page-home .hero-logo-mark .logo-part-l{
	opacity: 0;
	filter: blur(22px);
	transform: translate(-1180px, -760px) rotate(-180deg) scale(8);
	animation: heroPieceL 2.15s cubic-bezier(0.16, 1, 0.3, 1) 0.2s forwards;
}
body.page-home .hero-logo-mark .logo-part-e{
	opacity: 0;
	filter: blur(22px);
	transform: translate(0, 1420px) rotate(180deg) scale(8);
	animation: heroPieceE 2.15s cubic-bezier(0.16, 1, 0.3, 1) 0.38s forwards;
}
body.page-home .hero-logo-mark .logo-part-s{
	opacity: 0;
	filter: blur(18px);
	transform: translate(1180px, -760px) rotate(270deg) scale(8);
	animation: heroPieceS 1.75s cubic-bezier(0.22, 1, 0.36, 1) 0.72s forwards;
}
@keyframes heroPieceL{
	0%{ opacity: 0; filter: blur(22px); transform: translate(-1180px, -760px) rotate(-180deg) scale(8); }
	72%{ opacity: 1; filter: blur(0); transform: translate(8px, -3px) rotate(3deg) scale(1.04); }
	100%{ opacity: 1; filter: blur(0); transform: translate(0, 0) rotate(0) scale(1); }
}
@keyframes heroPieceE{
	0%{ opacity: 0; filter: blur(22px); transform: translate(0, 1420px) rotate(180deg) scale(8); }
	72%{ opacity: 1; filter: blur(0); transform: translate(-6px, 4px) rotate(-2deg) scale(1.03); }
	100%{ opacity: 1; filter: blur(0); transform: translate(0, 0) rotate(0) scale(1); }
}
@keyframes heroPieceS{
	0%{ opacity: 0; filter: blur(18px); transform: translate(1180px, -760px) rotate(270deg) scale(8); }
	70%{ opacity: 1; filter: blur(0); transform: translate(-4px, 2px) rotate(-3deg) scale(1.08); }
	100%{ opacity: 1; filter: blur(0); transform: translate(0, 0) rotate(0) scale(1); }
}
@keyframes heroGlowBurst{
	0%{ opacity: 0.9; transform: translate(-50%, -50%) scale(0.4); }
	100%{ opacity: 0; transform: translate(-50%, -50%) scale(1.75); }
}
@keyframes heroHaloBurst{
	0%{ opacity: 0.46; transform: translate(-50%, -50%) scale(0.72); }
	100%{ opacity: 0; transform: translate(-50%, -50%) scale(1.5); }
}
@keyframes heroLogoDock{
	0%{
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%) scale(1);
	}
	100%{
		top: 41%;
		left: 84%;
		transform: translate(-50%, -50%) scale(0.72);
	}
}
body.page-home .hero-inner{
	position: relative;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: var(--sp-12);
	max-width: 1280px;
	margin: 0 auto;
	width: 100%;
	z-index: 2;
	opacity: 0;
	animation: fadeUp 1s var(--ease) 4s forwards;
}
body.page-home.home-intro-skip .hero-bg-photo{
	opacity: 1;
	transform: scale(1);
	animation: none;
}
body.page-home.home-intro-pending .hero-bg-photo{
	opacity: 0;
	transform: scale(1.08);
	animation: heroBgReveal 1.1s var(--ease) 1.15s forwards;
}
body.page-home.home-intro-skip .hero-center-logo{
	top: 41%;
	left: 84%;
	transform: translate(-50%, -50%) scale(0.72);
	animation: none;
}
body.page-home.home-intro-skip .hero-center-logo::before, body.page-home.home-intro-skip .hero-center-logo::after{
	opacity: 0.28;
	animation: none;
}
body.page-home.home-intro-skip .hero-inner{
	opacity: 1;
	transform: translateY(0);
	animation: none;
}
body.page-home.home-intro-skip .hero-logo-mark .logo-part-l, body.page-home.home-intro-skip .hero-logo-mark .logo-part-e, body.page-home.home-intro-skip .hero-logo-mark .logo-part-s{
	opacity: 1;
	filter: blur(0);
	transform: translate(0, 0) rotate(0) scale(1);
	animation: none;
}
@keyframes fadeUp{
	from{ opacity: 0; transform: translateY(30px); }
	to{ opacity: 1; transform: translateY(0); }
}
body.page-home .hero-copy{ max-width: 700px; }
body.page-home .hero-eyebrow{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 8px 16px;
	background: rgba(255,255,255,0.06);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: var(--r-pill);
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.85);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	margin-bottom: var(--sp-6);
}
body.page-home .hero-eyebrow::before{
	content: '';
	width: 6px; height: 6px;
	border-radius: 50%;
	background: var(--green);
	box-shadow: 0 0 10px var(--green);
	animation: pulse 2.4s var(--ease) infinite;
}
@keyframes pulse{
	0%, 100%{ opacity: 1; transform: scale(1); }
	50%{ opacity: 0.5; transform: scale(1.35); }
}
body.page-home .hero-title{
	font-family: var(--font-display);
	font-size: clamp(2.25rem, 4.5vw, 3.75rem);
	line-height: 1.1;
	font-weight: 700;
	color: var(--white);
	margin-bottom: var(--sp-8);
	text-wrap: balance;
}
body.page-home .hero-title em{
	font-style: italic;
	font-weight: 400;
	color: rgba(255,255,255,0.88);
}
body.page-home .hero-title span.accent{ color: var(--green); }
body.page-home .hero-ctas{ display: flex; gap: var(--sp-3); flex-wrap: wrap; }
body.page-home .hero-chips{
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
	flex-shrink: 0;
	pointer-events: none;
}
body.page-home .chip{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 12px 20px;
	background: rgba(255,255,255,0.06);
	border: 1px solid rgba(255,255,255,0.14);
	border-radius: var(--r-pill);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	color: var(--white);
	box-shadow: 0 16px 40px rgba(0,0,0,0.28);
	animation: chipFloat 7s var(--ease) infinite;
}
body.page-home .chip .v{
	font-family: var(--font-display);
	font-weight: 800;
	font-size: 1.1rem;
	color: var(--green-light);
}
body.page-home .chip .l{ font-size: 0.8125rem; font-weight: 500; color: rgba(255,255,255,0.85); }
body.page-home .chip:nth-child(1){ animation-delay: 0s; }
body.page-home .chip:nth-child(2){ align-self: flex-start; margin-left: 40px; animation-delay: -2.3s; }
body.page-home .chip:nth-child(3){ align-self: flex-end; animation-delay: -4.6s; }
@keyframes chipFloat{
	0%, 100%{ transform: translateY(0); }
	50%{ transform: translateY(-6px); }
}
@media (max-width: 860px){
	body.page-home .hero-chips{ display: none; }
	body.page-home .hero-bg-photo{
		background:
			linear-gradient(180deg, rgba(7,31,69,0.7) 0%, rgba(7,31,69,0.42) 38%, rgba(7,31,69,0.24) 100%),
			url('../assets/images/hero-family-bg.png') 62% center / cover no-repeat;
	}
	body.page-home .hero-center-logo{
		width: 152px;
		height: 152px;
		animation: heroLogoDockMobile 1.1s var(--ease) 2.65s forwards;
	}
	body.page-home .hero-logo-mark .logo-part-l{
		transform: translate(-460px, -320px) rotate(-100deg) scale(4.6);
		animation-name: heroPieceLMobile;
	}
	body.page-home .hero-logo-mark .logo-part-e{
		transform: translate(0, 540px) rotate(90deg) scale(4.6);
		animation-name: heroPieceEMobile;
	}
	body.page-home .hero-logo-mark .logo-part-s{
		transform: translate(460px, -320px) rotate(135deg) scale(4.6);
		animation-name: heroPieceSMobile;
	}
}
@keyframes heroPieceLMobile{
	0%{ opacity: 0; filter: blur(14px); transform: translate(-460px, -320px) rotate(-100deg) scale(4.6); }
	72%{ opacity: 1; filter: blur(0); transform: translate(6px, -3px) rotate(2deg) scale(1.04); }
	100%{ opacity: 1; filter: blur(0); transform: translate(0, 0) rotate(0) scale(1); }
}
@keyframes heroPieceEMobile{
	0%{ opacity: 0; filter: blur(14px); transform: translate(0, 540px) rotate(90deg) scale(4.6); }
	72%{ opacity: 1; filter: blur(0); transform: translate(-5px, 3px) rotate(-2deg) scale(1.03); }
	100%{ opacity: 1; filter: blur(0); transform: translate(0, 0) rotate(0) scale(1); }
}
@keyframes heroPieceSMobile{
	0%{ opacity: 0; filter: blur(12px); transform: translate(460px, -320px) rotate(135deg) scale(4.6); }
	72%{ opacity: 1; filter: blur(0); transform: translate(-3px, 2px) rotate(-3deg) scale(1.08); }
	100%{ opacity: 1; filter: blur(0); transform: translate(0, 0) rotate(0) scale(1); }
}
@keyframes heroLogoDockMobile{
	0%{
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%) scale(1);
		opacity: 1;
		visibility: visible;
	}
	64%{
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%) scale(0.98);
		opacity: 1;
		visibility: visible;
	}
	100%{
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%) scale(0.76);
		opacity: 0;
		visibility: hidden;
	}
}
body.page-home .values{
	position: relative;
	background: var(--off-white);
}
body.page-home .values-scroller{
	position: relative;
	height: 300vh; /* 3 phases pinned */
}
body.page-home .values-sticky{
	position: sticky;
	top: 0;
	height: 100vh;
	display: flex;
	align-items: center;
	overflow: hidden;
	background: var(--off-white);
}
body.page-home .values-inner{
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 40px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 30px;
	align-items: center;
}
/* LEFT — logo column */body.page-home .values-logo-col{
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
}
body.page-home .values-logo{
	width: 100%;
	max-width: 414px;
	aspect-ratio: 1;
	position: relative;
	transform: translate(-40px, 0) scale(0.9);
	filter: drop-shadow(0 20px 40px rgba(7, 31, 69, 0.08));
}
body.page-home .values-logo svg{
	width: 100%;
	height: 100%;
	overflow: visible;
}
/* Logo parts — independently styleable via GSAP (exact behavior from original) */body.page-home .values-logo .logo-part-l, body.page-home .values-logo .logo-part-e, body.page-home .values-logo .logo-part-s{
	transform-origin: 50% 50%;
	transform-box: fill-box;
	will-change: opacity, transform, filter;
	transition: opacity 0.5s var(--ease),
	            filter 0.5s var(--ease),
	            transform 0.5s var(--ease);
}
/* Default (initial) state = Phase 1 = L bright, E/S dim+blur */body.page-home .values-logo .logo-part-l{ opacity: 1;   filter: blur(0);    transform: scale(1.05); }
body.page-home .values-logo .logo-part-e{ opacity: 0.2; filter: blur(1.5px); transform: scale(1); }
body.page-home .values-logo .logo-part-s{ opacity: 0.2; filter: blur(1.5px); transform: scale(1); }
/* Phase 2 — E bright */body.page-home .values[data-phase="1"] .logo-part-l{ opacity: 0.2; filter: blur(1.5px); transform: scale(1); }
body.page-home .values[data-phase="1"] .logo-part-e{ opacity: 1;   filter: blur(0);    transform: scale(1.05); }
body.page-home .values[data-phase="1"] .logo-part-s{ opacity: 0.2; filter: blur(1.5px); transform: scale(1); }
/* Phase 3 — S bright */body.page-home .values[data-phase="2"] .logo-part-l{ opacity: 0.2; filter: blur(1.5px); transform: scale(1); }
body.page-home .values[data-phase="2"] .logo-part-e{ opacity: 0.2; filter: blur(1.5px); transform: scale(1); }
body.page-home .values[data-phase="2"] .logo-part-s{ opacity: 1;   filter: blur(0);    transform: scale(1.08); }
/* RIGHT — text column with stacked layers */body.page-home .values-text-col{
	position: relative;
	height: 400px;
}
body.page-home .values-panel{
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	opacity: 0;
	transform: translateY(40px);
	visibility: hidden;
	will-change: opacity, transform;
	transition: opacity 0.6s var(--ease),
	            transform 0.6s var(--ease),
	            visibility 0s linear 0.6s;
	pointer-events: none;
}
body.page-home .values-panel.active{
	opacity: 1;
	transform: translateY(0);
	visibility: visible;
	transition: opacity 0.6s var(--ease),
	            transform 0.6s var(--ease),
	            visibility 0s linear 0s;
	pointer-events: auto;
}
body.page-home .values-phase-label{
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: rgba(7, 31, 69, 0.5);
	margin-bottom: 12px;
}
body.page-home .values-phase-label::before{
	content: '';
	width: 30px;
	height: 1px;
	background: rgba(7, 31, 69, 0.2);
}
body.page-home .values-phase-title{
	font-family: var(--font-display);
	font-size: 42px;
	font-weight: 300;
	color: var(--navy);
	margin: 0 0 24px;
	line-height: 1.15;
	letter-spacing: -0.02em;
}
body.page-home .values-phase-details{
	list-style: none;
	padding: 0;
	margin: 0 0 30px;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
body.page-home .values-phase-details li{
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 15px;
	color: rgba(7, 31, 69, 0.8);
	line-height: 1.5;
}
body.page-home .values-phase-details li::before{
	content: '';
	flex-shrink: 0;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--green);
	box-shadow: 0 0 0 3px rgba(42, 197, 88, 0.18);
}
body.page-home .values-ctas{
	display: flex;
	gap: var(--sp-3);
	flex-wrap: wrap;
	margin-top: var(--sp-3);
}
/* Right-side progress dots */body.page-home .values-progress{
	position: absolute;
	right: var(--sp-10);
	top: 50%;
	transform: translateY(-50%);
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
	z-index: 3;
}
body.page-home .values-progress-dot{
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: rgba(7, 31, 69, 0.2);
	transition: all var(--dur) var(--ease);
	cursor: pointer;
}
body.page-home .values-progress-dot.active{
	background: var(--green);
	transform: scale(1.4);
	box-shadow: 0 0 0 5px rgba(42, 197, 88, 0.16);
}
@media (max-width: 1100px){ body.page-home .values-progress{ display: none; } }
@media (max-width: 960px){
	body.page-home .values-scroller{ height: auto; }
	body.page-home .values-sticky{ position: static; height: auto; padding: var(--sp-16) 0; }
	body.page-home .values-inner{ grid-template-columns: 1fr; gap: var(--sp-8); padding: 0 var(--sp-5); }
	body.page-home .values-logo{ width: 220px; height: 220px; }
	body.page-home .values-text-col{ height: auto; }
	body.page-home .values-panel{ position: relative; opacity: 1; transform: none; visibility: visible; pointer-events: auto; margin-bottom: var(--sp-8); }
}
body.page-home .services{
	padding: var(--sp-24) 0;
	background: var(--white);
}
body.page-home .services-head{
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: var(--sp-16);
	align-items: end;
	margin-bottom: var(--sp-16);
}
body.page-home .services-title{
	font-size: clamp(2rem, 3.6vw, 3rem);
	line-height: 1.08;
	max-width: 16ch;
}
body.page-home .services-title em{
	font-style: italic; font-weight: 600;
	color: var(--green-dark);
}
body.page-home .services-lede{
	color: var(--gray-dark);
	max-width: 50ch;
	line-height: 1.65;
	margin: 0;
}
body.page-home .services-head-right{
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--sp-5);
}
body.page-home .services-head-cta{ height: 48px; padding: 0 24px; font-size: 0.875rem; }
body.page-home .services-grid{
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sp-6);
}
body.page-home .solution{
	position: relative;
	padding: var(--sp-12);
	border-radius: var(--r-2xl);
	overflow: hidden;
	transition: transform var(--dur) var(--ease),
	            box-shadow var(--dur) var(--ease);
}
body.page-home .solution:hover{ transform: translateY(-4px); }
body.page-home .solution--dark{
	background: linear-gradient(155deg, var(--navy) 0%, var(--navy-mid) 100%);
	color: var(--white);
	box-shadow: var(--sh-lg);
}
body.page-home .solution--dark::before{
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(80% 60% at 100% 0%, rgba(42,197,88,0.18) 0%, transparent 55%);
	pointer-events: none;
}
body.page-home .solution--light{
	background: linear-gradient(160deg, #FFFFFF 0%, #F1F5F1 100%);
	border: 1px solid var(--border);
	box-shadow: var(--sh-md);
}
body.page-home .solution-head{
	display: flex;
	align-items: center;
	gap: var(--sp-5);
	margin-bottom: var(--sp-8);
	position: relative;
	z-index: 1;
}
body.page-home .solution-icon{
	width: 64px;
	height: 64px;
	border-radius: var(--r-lg);
	display: grid;
	place-items: center;
	font-size: 1.75rem;
}
body.page-home .solution--dark .solution-icon{
	background: rgba(126,234,160,0.14);
	border: 1px solid rgba(126,234,160,0.35);
	color: var(--green-light);
}
body.page-home .solution--light .solution-icon{
	background: rgba(42,197,88,0.12);
	border: 1px solid rgba(42,197,88,0.3);
	color: var(--green-dark);
}
body.page-home .solution-title{
	font-size: 1.75rem;
	font-weight: 700;
	color: inherit;
}
body.page-home .solution--dark .solution-title{ color: var(--white); }
body.page-home .solution-list{
	list-style: none;
	padding: 0; margin: 0;
	display: flex; flex-direction: column;
	gap: var(--sp-4);
	position: relative;
	z-index: 1;
}
body.page-home .solution-list li{
	display: flex;
	align-items: center;
	gap: var(--sp-4);
	padding: var(--sp-4) var(--sp-5);
	border-radius: var(--r-md);
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 1rem;
}
body.page-home .solution--dark .solution-list li{
	background: rgba(255,255,255,0.06);
	border: 1px solid rgba(255,255,255,0.1);
}
body.page-home .solution--light .solution-list li{
	background: var(--white);
	border: 1px solid var(--border);
}
body.page-home .solution-list li::before{
	content: '';
	flex-shrink: 0;
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--green);
	box-shadow: 0 0 0 4px rgba(42,197,88,0.18);
}
@media (max-width: 960px){
	body.page-home .services-head{ grid-template-columns: 1fr; }
	body.page-home .services-grid{ grid-template-columns: 1fr; }
}
body.page-home .journey{
	position: relative;
	background:
		radial-gradient(circle at 10% 20%, rgba(126,234,160,0.08) 0%, transparent 45%),
		radial-gradient(circle at 90% 80%, rgba(42,74,128,0.06) 0%, transparent 45%),
		linear-gradient(180deg, #F7F8FA 0%, #EEF1F6 100%);
}
body.page-home .journey-scroller{
	position: relative;
	height: 320vh;
}
body.page-home .journey-sticky{
	position: sticky;
	top: 0;
	height: 100vh;
	overflow: hidden;
	display: flex;
	align-items: center;
}
body.page-home .journey-inner{
	position: relative;
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 var(--sp-10);
	display: grid;
	grid-template-columns: minmax(0, 1.2fr) minmax(380px, 1fr);
	gap: var(--sp-16);
	align-items: stretch;
}
/* LEFT COLUMN — stories + years timeline beneath */body.page-home .journey-left{
	display: flex;
	flex-direction: column;
	gap: var(--sp-8);
	justify-content: center;
}
body.page-home .journey-stories{ position: relative; z-index: 2; }
body.page-home .journey-stories-head{
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
	margin-bottom: var(--sp-8);
}
body.page-home .journey-panels{
	position: relative;
	min-height: 360px;
}
body.page-home .journey-panel{
	position: absolute;
	inset: 0;
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.5s var(--ease), transform 0.5s var(--ease);
	pointer-events: none;
	padding-left: var(--sp-10);
	border-left: 2px solid rgba(7, 31, 69, 0.1);
}
body.page-home .journey-panel.active{
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}
body.page-home .journey-panel::before{
	content: '';
	position: absolute;
	left: -7px;
	top: 4px;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--green);
	box-shadow: 0 0 0 5px rgba(42, 197, 88, 0.16);
}
body.page-home .journey-panel-head{
	display: flex;
	align-items: center;
	gap: var(--sp-4);
	margin-bottom: var(--sp-5);
}
body.page-home .journey-chapter{
	display: inline-flex;
	align-items: center;
	padding: 6px 14px;
	background: rgba(42, 197, 88, 0.12);
	border: 1px solid rgba(42, 197, 88, 0.24);
	border-radius: var(--r-pill);
	color: var(--green-dark);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}
body.page-home .journey-year{
	font-family: var(--font-display);
	font-weight: 700;
	color: var(--navy-light);
	font-size: 0.875rem;
	letter-spacing: 0.08em;
}
body.page-home .journey-ptitle{
	font-size: clamp(1.75rem, 2.8vw, 2.25rem);
	line-height: 1.1;
	margin-bottom: var(--sp-5);
}
body.page-home .journey-pbody{
	color: var(--gray-dark);
	line-height: 1.75;
	font-size: 1.0625rem;
	white-space: pre-line;
	max-width: 56ch;
}
/* Years timeline (now under stories) */body.page-home .journey-years{
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: var(--sp-4);
	padding: var(--sp-5) var(--sp-6);
	background: var(--white);
	border: 1px solid var(--border);
	border-radius: var(--r-xl);
	box-shadow: var(--sh-soft);
	position: relative;
	margin-left: var(--sp-10);
	max-width: 560px;
}
body.page-home .journey-years::before{
	content: '';
	position: absolute;
	left: var(--sp-6);
	right: var(--sp-6);
	top: calc(var(--sp-5) + 5px);
	height: 2px;
	background: rgba(7, 31, 69, 0.08);
	z-index: 0;
}
body.page-home .journey-years-fill{
	position: absolute;
	left: var(--sp-6);
	right: var(--sp-6);
	top: calc(var(--sp-5) + 5px);
	height: 2px;
	transform: scaleX(var(--fill, 0));
	transform-origin: left center;
	background: linear-gradient(90deg, var(--green) 0%, var(--navy) 100%);
	z-index: 1;
	transition: transform 0.5s var(--ease);
}
body.page-home .journey-year-marker{
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--sp-2);
	cursor: pointer;
	position: relative;
	z-index: 2;
	flex: 1;
}
body.page-home .journey-year-dot{
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--white);
	border: 2px solid rgba(7, 31, 69, 0.25);
	transition: all var(--dur) var(--ease);
}
body.page-home .journey-year-marker.active .journey-year-dot{
	background: var(--green);
	border-color: var(--green);
	box-shadow: 0 0 0 5px rgba(42, 197, 88, 0.16);
	transform: scale(1.2);
}
body.page-home .journey-year-label{
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 700;
	color: var(--gray);
	letter-spacing: 0.02em;
	transition: color var(--dur) var(--ease);
}
body.page-home .journey-year-marker.active .journey-year-label{
	color: var(--navy);
}
/* RIGHT COLUMN — metrics on top + large tree filling rest */body.page-home .journey-right{
	display: flex;
	flex-direction: column;
	gap: var(--sp-5);
	height: 100%;
	max-height: 78vh;
}
body.page-home .journey-metrics{
	flex-shrink: 0;
	display: flex;
	justify-content: space-around;
	gap: var(--sp-6);
	padding: var(--sp-5) var(--sp-6);
	background: var(--white);
	border: 1px solid var(--border);
	border-radius: var(--r-xl);
	box-shadow: var(--sh-soft);
}
body.page-home .journey-metric{
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--sp-1);
	text-align: center;
}
body.page-home .journey-metric-big{
	font-family: var(--font-display);
	font-size: clamp(2.75rem, 5vw, 3.75rem);
	font-weight: 800;
	line-height: 0.9;
	letter-spacing: -0.03em;
	background: linear-gradient(135deg, var(--navy) 0%, var(--green-dark) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}
body.page-home .journey-metric-label{
	font-family: var(--font-display);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--gray);
}
/* Tree — now fills remaining vertical space */body.page-home .journey-tree-viz{
	flex: 1;
	width: 100%;
	position: relative;
	display: grid;
	place-items: center;
	overflow: hidden;
	border-radius: var(--r-2xl);
	background:
		radial-gradient(120% 90% at 50% 100%, rgba(42, 197, 88, 0.08) 0%, transparent 60%),
		linear-gradient(180deg, #FFFFFF 0%, #F1F5F1 100%);
	border: 1px solid var(--border);
	box-shadow: var(--sh-soft);
	min-height: 320px;
}
body.page-home .journey-tree-viz svg{
	width: 94%;
	height: 94%;
	overflow: visible;
}
/* Organic tree stages */body.page-home .tree-trunk-org{
	transform-origin: 260px 450px;
	transform: scaleY(0.1);
	opacity: 0.4;
	transition: transform 1.2s var(--ease), opacity 0.8s ease;
}
body.page-home .tree-trunk-org.s1, body.page-home .tree-trunk-org.s2{ transform: scaleY(1); opacity: 1; }
body.page-home .tree-branches-org{
	opacity: 0;
	transform-origin: 260px 300px;
	transform: scale(0.5);
	transition: opacity 0.9s ease, transform 0.9s var(--ease);
}
body.page-home .tree-branches-org.s1, body.page-home .tree-branches-org.s2{ opacity: 1; transform: scale(1); }
body.page-home .tree-foliage-org{
	opacity: 0;
	transform-origin: 260px 220px;
	transform: scale(0.28);
	transition: opacity 1.1s ease, transform 1.25s var(--ease), filter 1.1s ease;
	filter: saturate(0.9);
}
body.page-home .tree-foliage-org.s1{
	opacity: 0.92;
	transform: scale(0.62);
	filter: saturate(0.98);
}
body.page-home .tree-foliage-org.s2{
	opacity: 1;
	transform: scale(1);
	filter: saturate(1.08);
}
body.page-home .tree-foliage-org .tree-leaf{
	transform-box: fill-box;
	transform-origin: center;
	transition: opacity 1.1s ease, transform 1.25s var(--ease);
}
body.page-home .tree-foliage-org .tree-leaf--mid,
body.page-home .tree-foliage-org .tree-leaf--outer,
body.page-home .tree-foliage-org .tree-leaf--glow{
	opacity: 0;
}
body.page-home .tree-foliage-org.s1 .tree-leaf--core{
	transform: scale(0.78);
}
body.page-home .tree-foliage-org.s1 .tree-leaf--mid{
	opacity: 1;
	transform: scale(0.82);
}
body.page-home .tree-foliage-org.s1 .tree-leaf--outer,
body.page-home .tree-foliage-org.s1 .tree-leaf--glow{
	opacity: 0.18;
	transform: scale(0.7);
}
body.page-home .tree-foliage-org.s2 .tree-leaf--core,
body.page-home .tree-foliage-org.s2 .tree-leaf--mid,
body.page-home .tree-foliage-org.s2 .tree-leaf--outer,
body.page-home .tree-foliage-org.s2 .tree-leaf--glow{
	opacity: 1;
	transform: scale(1);
}
body.page-home .tree-fruits-org{
	opacity: 0;
	transform-origin: 260px 240px;
	transform: translateY(10px) scale(0.7);
	transition: opacity 0.8s ease 0.18s, transform 0.95s var(--ease) 0.18s;
}
body.page-home .tree-foliage-org.s2 .tree-fruits-org{
	opacity: 1;
	transform: translateY(0) scale(1);
}
body.page-home .tree-seed-org{
	transform-origin: 260px 450px;
	animation: seedSway 5s var(--ease) infinite;
}
@keyframes seedSway{
	0%, 100%{ transform: rotate(-1deg); }
	50%{ transform: rotate(1.5deg); }
}
@media (max-width: 1024px){
	body.page-home .journey-scroller{ height: auto; }
	body.page-home .journey-sticky{ position: static; height: auto; padding: var(--sp-16) 0; }
	body.page-home .journey-inner{ grid-template-columns: 1fr; gap: var(--sp-10); }
	body.page-home .journey-right{ max-height: none; order: -1; }
	body.page-home .journey-tree-viz{ min-height: 280px; max-height: 340px; }
	body.page-home .journey-panel{ position: relative; opacity: 1; transform: none; pointer-events: auto; margin-bottom: var(--sp-8); }
	body.page-home .journey-panels{ min-height: auto; }
	body.page-home .journey-years{ margin-left: 0; max-width: none; }
}
body.page-home .team{
	padding: var(--sp-24) 0 var(--sp-20);
	background: var(--white);
}
body.page-home .team-layout{
	display: grid;
	grid-template-columns: 1fr 1.3fr;
	gap: var(--sp-12);
	align-items: flex-start;
}
body.page-home .team-copy-col{ padding-top: var(--sp-3); }
body.page-home .team-title{
	font-size: clamp(2rem, 3.4vw, 2.75rem);
	line-height: 1.08;
	margin-bottom: var(--sp-5);
}
body.page-home .team-lede{
	color: var(--gray-dark);
	max-width: 42ch;
	line-height: 1.65;
	margin-bottom: var(--sp-8);
}
body.page-home .team-ctas{ display: flex; gap: var(--sp-3); flex-wrap: wrap; }
body.page-home .team-portraits{
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sp-6);
}
body.page-home .team-member-card{ display: flex; flex-direction: column; }
body.page-home .team-portrait{
	aspect-ratio: 3/4;
	width: 100%;
	border-radius: var(--r-xl);
	margin-bottom: var(--sp-4);
	overflow: hidden;
	background: linear-gradient(160deg, #E8ECF1 0%, #D7DEE8 100%);
	display: grid;
	place-items: center;
}
body.page-home .team-portrait svg{ width: 50%; height: 50%; opacity: 0.6; color: var(--navy-light); }
body.page-home .team-portrait img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center top;
	display: block;
	transition: transform var(--dur) var(--ease);
}
body.page-home .team-member-card:hover .team-portrait img{
	transform: scale(1.03);
}
body.page-home .team-member-name{
	font-family: var(--font-display);
	font-size: 1.375rem;
	font-weight: 700;
	color: var(--navy);
	margin-bottom: 4px;
}
body.page-home .team-member-role{
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	color: var(--gray);
	text-transform: uppercase;
}
@media (max-width: 960px){
	body.page-home .team-layout{ grid-template-columns: 1fr; }
}
body.page-home .sixbox{
	padding: var(--sp-24) 0;
	background: var(--off-white);
}
body.page-home .sixbox-grid{
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	grid-template-rows: auto auto;
	gap: var(--sp-5);
}
body.page-home .sx-tile{
	border-radius: var(--r-xl);
	padding: var(--sp-8);
	border: 1px solid var(--border);
	background: var(--white);
	display: flex;
	flex-direction: column;
	min-height: 260px;
}
body.page-home .sx-tile--hero{
	background:
		radial-gradient(80% 60% at 100% 0%, rgba(126,234,160,0.18) 0%, transparent 55%),
		linear-gradient(155deg, var(--navy) 0%, var(--navy-mid) 100%);
	color: var(--white);
	border-color: var(--navy);
	justify-content: space-between;
}
body.page-home .sx-tile--hero h3{
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 2.4vw, 2rem);
	line-height: 1.15;
	color: var(--white);
	margin-bottom: var(--sp-8);
}
body.page-home .sx-tile--hero .sx-pill{
	display: inline-flex;
	align-items: center;
	padding: 6px 14px;
	background: rgba(255,255,255,0.12);
	border: 1px solid rgba(255,255,255,0.2);
	border-radius: var(--r-pill);
	color: var(--white);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	width: fit-content;
	margin-bottom: var(--sp-4);
}
body.page-home .sx-tile--chart{
	grid-row: span 2;
	background: linear-gradient(180deg, #D0EDB1 0%, #BDDF9D 100%);
	border-color: rgba(42,197,88,0.3);
}
body.page-home .sx-tile--chart p{
	font-weight: 500;
	color: var(--navy);
	line-height: 1.5;
	font-size: 1rem;
	margin-bottom: var(--sp-8);
}
body.page-home .chart-bars{
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	height: 180px;
	margin-top: auto;
}
body.page-home .chart-bar-col{ width: 28%; text-align: center; }
body.page-home .chart-bar{
	background: var(--navy);
	border-radius: 4px;
	margin-bottom: var(--sp-2);
	position: relative;
	min-height: 50px;
}
body.page-home .chart-bar-pct{
	position: absolute;
	top: -28px;
	left: 50%;
	transform: translateX(-50%);
	font-family: var(--font-display);
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--navy);
}
body.page-home .chart-bar-year{
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--navy);
}
body.page-home .sx-icon-tile{ padding: var(--sp-8); }
body.page-home .sx-icon{
	width: 50px;
	height: 50px;
	background: var(--white);
	border: 1px solid var(--border);
	border-radius: 50%;
	display: grid;
	place-items: center;
	margin-bottom: var(--sp-5);
	color: var(--navy-mid);
	box-shadow: var(--sh-soft);
}
body.page-home .sx-icon-tile h3{
	font-family: var(--font-display);
	font-size: 1.25rem;
	color: var(--navy);
	margin-bottom: var(--sp-3);
}
body.page-home .sx-icon-tile p{
	color: var(--gray-dark);
	font-size: 0.9375rem;
	line-height: 1.6;
}
body.page-home .sx-tile--img{
	padding: 0;
	overflow: hidden;
	position: relative;
	background: linear-gradient(135deg, var(--navy-mid), var(--navy));
	min-height: 260px;
}
body.page-home .sx-tile--img::after{
	content: 'Professional advisory';
	position: absolute;
	bottom: 0; left: 0; right: 0;
	padding: var(--sp-5) var(--sp-6);
	color: var(--white);
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 0.9375rem;
	background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.6) 100%);
}
@media (max-width: 960px){
	body.page-home .sixbox-grid{ grid-template-columns: 1fr 1fr; }
	body.page-home .sx-tile--chart{ grid-row: auto; }
}
@media (max-width: 600px){
	body.page-home .sixbox-grid{ grid-template-columns: 1fr; }
}
body.page-home .cta{
	position: relative;
	padding: var(--sp-20) var(--sp-10);
	overflow: hidden;
	isolation: isolate;
	color: var(--white);
}
body.page-home .cta::before{
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(120% 80% at 85% 0%, rgba(42,197,88,0.32) 0%, transparent 55%),
		radial-gradient(120% 80% at 0% 100%, rgba(42,74,128,0.55) 0%, transparent 60%),
		linear-gradient(155deg, var(--navy) 0%, #0B2856 60%, var(--navy-mid) 100%);
	z-index: -2;
}
body.page-home .cta::after{
	content: '';
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.03) 0 1px, transparent 1px 14px);
	z-index: -1;
}
body.page-home .cta-inner{
	max-width: 1280px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sp-8);
	flex-wrap: wrap;
}
body.page-home .cta-copy{
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
	flex: 1 1 auto;
	min-width: 280px;
}
body.page-home .cta-title{
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	line-height: 1.15;
	font-weight: 700;
	color: var(--white);
	margin: 0;
	letter-spacing: -0.02em;
}
body.page-home .cta-desc{
	font-size: 0.9375rem;
	line-height: 1.55;
	color: rgba(255,255,255,0.75);
	margin: 0;
}
body.page-home .cta-actions{ flex-shrink: 0; }
@media (max-width: 768px){
	body.page-home .cta{ padding: var(--sp-16) var(--sp-5); }
	body.page-home .cta-inner{ flex-direction: column; text-align: center; align-items: center; }
}
body.page-home .footer{
	background: var(--navy);
	color: rgba(255,255,255,0.72);
	padding: var(--sp-24) var(--sp-10) var(--sp-10);
}
body.page-home .footer-inner{
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: var(--sp-12);
	padding-bottom: var(--sp-12);
	border-bottom: 1px solid rgba(255,255,255,0.1);
}
body.page-home .footer-brand{ max-width: 320px; }
body.page-home .footer-logo{
	display: flex;
	align-items: center;
	gap: 10px;
	font-family: var(--font-display);
	font-weight: 800;
	color: var(--white);
	font-size: 1.375rem;
	margin-bottom: var(--sp-4);
}
body.page-home .footer-tagline{ color: var(--white); font-weight: 500; margin-bottom: var(--sp-3); }
body.page-home .footer-arn{
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.6);
	margin-bottom: var(--sp-5);
}
body.page-home .footer-social{ display: flex; gap: var(--sp-3); }
body.page-home .footer-social a{
	display: grid;
	place-items: center;
	width: 36px; height: 36px;
	border-radius: 50%;
	background: rgba(255,255,255,0.06);
	color: rgba(255,255,255,0.72);
	transition: all var(--dur) var(--ease);
}
body.page-home .footer-social a:hover{
	background: var(--green);
	color: var(--navy);
	transform: translateY(-2px);
}
body.page-home .footer-col h4{
	color: var(--white);
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin-bottom: var(--sp-5);
}
body.page-home .footer-col-body{ display: flex; flex-direction: column; gap: var(--sp-3); }
body.page-home .footer-link{
	color: rgba(255,255,255,0.72);
	font-size: 0.9375rem;
	transition: color var(--dur) var(--ease);
}
body.page-home .footer-link:hover{ color: var(--green-light); }
body.page-home .footer-bottom{
	max-width: 1280px;
	margin: 0 auto;
	padding-top: var(--sp-6);
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--sp-4);
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.55);
}
body.page-home .footer-bottom-links{ display: flex; gap: var(--sp-6); }
body.page-home .footer-bottom-links a{ transition: color var(--dur) var(--ease); }
body.page-home .footer-bottom-links a:hover{ color: var(--green-light); }
@media (max-width: 960px){
	body.page-home .footer-inner{ grid-template-columns: 1fr 1fr; gap: var(--sp-8); }
}
@media (max-width: 580px){
	body.page-home .footer-inner{ grid-template-columns: 1fr; }
}

/* /about */
body.page-about *, body.page-about *::before, body.page-about *::after{ box-sizing: border-box; }
body.page-about, body.page-about{ margin: 0; padding: 0; }
body.page-about{
	font-family: var(--font-body);
	color: var(--gray-dark);
	background: var(--off-white);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	overflow-x: clip;
}
body.page-about a{ color: inherit; text-decoration: none; }
body.page-about img, body.page-about svg{ display: block; max-width: 100%; }
body.page-about h1, body.page-about h2, body.page-about h3, body.page-about h4, body.page-about h5, body.page-about p{ margin: 0; }
body.page-about h1, body.page-about h2, body.page-about h3, body.page-about h4{
	font-family: var(--font-display);
	color: var(--navy);
	letter-spacing: -0.02em;
	line-height: 1.08;
}
body.page-about .container{
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 var(--sp-10);
}
body.page-about .eyebrow{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--green-dark);
}
body.page-about .eyebrow::before{
	content: "";
	width: 28px;
	height: 2px;
	background: var(--green);
	border-radius: 99px;
}
body.page-about .eyebrow--light{ color: var(--green-light); }
body.page-about .breadcrumb{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.62);
}
body.page-about .breadcrumb a{ color: inherit; transition: color var(--dur) var(--ease); }
body.page-about .breadcrumb a:hover{ color: var(--green-light); }
body.page-about .breadcrumb .current{ color: var(--green-light); }
body.page-about .le-btn{
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 54px;
	padding: 0 30px;
	border-radius: var(--r-md);
	font-size: 0.9375rem;
	font-weight: 600;
	border: 1px solid transparent;
	cursor: pointer;
	overflow: hidden;
	white-space: nowrap;
	transition: background-color var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
body.page-about .le-btn .lbl{ transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease); }
body.page-about .le-btn .arr{
	position: absolute;
	left: 50%;
	top: 50%;
	opacity: 0;
	transform: translate(-50%, -50%) translateX(-40px);
	transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
body.page-about .le-btn:hover .lbl{ opacity: 0; transform: translateX(30px); }
body.page-about .le-btn:hover .arr{ opacity: 1; transform: translate(-50%, -50%) translateX(0); }
body.page-about .le-btn--primary{
	background: var(--green);
	color: var(--navy);
	box-shadow: var(--sh-green);
}
body.page-about .le-btn--primary:hover{
	background: var(--green-dark);
	color: var(--white);
	transform: translateY(-2px);
}
body.page-about .le-btn--secondary{
	background: transparent;
	color: var(--white);
	border-color: rgba(255,255,255,0.28);
}
body.page-about .le-btn--secondary:hover{
	background: var(--white);
	color: var(--navy);
	border-color: var(--white);
	transform: translateY(-2px);
}
body.page-about .le-btn--lg{ height: 60px; padding: 0 36px; font-size: 1rem; }
body.page-about .navbar{
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--sp-5) var(--sp-10);
	transition: background-color var(--dur) var(--ease), backdrop-filter var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
body.page-about .navbar.is-transparent{ background: transparent; }
body.page-about .navbar.is-solid{
	background: rgba(255,255,255,0.92);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-shadow: 0 1px 0 rgba(7,31,69,0.06);
}
body.page-about .nav-logo{ display: flex; align-items: center; }
body.page-about .nav-logo img{ height: 56px; width: auto; }
body.page-about .nav-logo-light{ display: none; }
body.page-about .is-transparent .nav-logo-dark{ display: none; }
body.page-about .is-transparent .nav-logo-light{ display: block; }
body.page-about .is-solid .nav-logo-dark{ display: block; }
body.page-about .is-solid .nav-logo-light{ display: none; }
body.page-about .nav-links{ display: flex; align-items: center; gap: var(--sp-8); }
body.page-about .nav-link{
	position: relative;
	font-size: 0.9375rem;
	font-weight: 500;
	transition: color var(--dur) var(--ease);
}
body.page-about .is-transparent .nav-link{ color: var(--white); }
body.page-about .is-solid .nav-link{ color: var(--navy); }
body.page-about .nav-link::after{
	content: "";
	position: absolute;
	left: 0;
	bottom: -10px;
	width: 100%;
	height: 2px;
	border-radius: 99px;
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform var(--dur) var(--ease);
}
body.page-about .is-transparent .nav-link::after{ background: var(--green-light); }
body.page-about .is-solid .nav-link::after{ background: var(--green); }
body.page-about .nav-link:hover, body.page-about .nav-link.is-active{ color: var(--green); }
body.page-about .nav-link:hover::after, body.page-about .nav-link.is-active::after{ transform: scaleX(1); }
body.page-about .nav-login{
	position: relative;
	padding-bottom: 18px;
	margin-bottom: -18px;
}
body.page-about .nav-login::after{
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	height: 24px;
}
body.page-about .nav-login-toggle{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	height: 52px;
	padding: 0 24px 0 26px;
	border-radius: 16px;
	font-size: 0.875rem;
	font-weight: 600;
	background: transparent;
	border: 1px solid;
	cursor: pointer;
	transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease), background-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
body.page-about .nav-login-toggle svg{ width: 16px; height: 16px; transition: transform var(--dur) var(--ease); }
body.page-about .nav-login.is-open .nav-login-toggle svg{ transform: rotate(180deg); }
body.page-about .is-transparent .nav-login-toggle{
	color: var(--white);
	border-color: rgba(255,255,255,0.22);
	background: linear-gradient(180deg, rgba(255,255,255,0.14) 0%, rgba(255,255,255,0.06) 100%);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}
body.page-about .is-solid .nav-login-toggle{
	color: var(--navy);
	border-color: rgba(7,31,69,0.12);
	background: linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(244,247,250,0.98) 100%);
	box-shadow: 0 8px 24px rgba(7,31,69,0.05);
}
body.page-about .nav-login-menu{
	position: absolute;
	top: calc(100% + 6px);
	right: 0;
	width: 320px;
	padding: 12px;
	border-radius: 22px;
	background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(246,248,251,0.99) 100%);
	border: 1px solid rgba(7,31,69,0.09);
	box-shadow: 0 28px 70px rgba(7,31,69,0.18);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	opacity: 0;
	transform: translateY(10px);
	visibility: hidden;
	pointer-events: none;
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear var(--dur);
}
body.page-about .nav-login-menu::before{
	content: "";
	position: absolute;
	top: -9px;
	right: 34px;
	width: 18px;
	height: 18px;
	background: rgba(255,255,255,0.98);
	border-top: 1px solid rgba(7,31,69,0.1);
	border-left: 1px solid rgba(7,31,69,0.1);
	transform: rotate(45deg);
}
body.page-about .nav-login.is-open .nav-login-menu{
	opacity: 1;
	transform: translateY(0);
	visibility: visible;
	pointer-events: auto;
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear 0s;
}
body.page-about .portal-link{
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px 15px;
	border-radius: 18px;
	color: var(--navy);
	background: linear-gradient(180deg, rgba(255,255,255,0.95) 0%, rgba(249,250,252,1) 100%);
	border: 1px solid rgba(7,31,69,0.06);
	transition: background-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
body.page-about .portal-link + .portal-link{ margin-top: 8px; }
body.page-about .portal-link:hover{
	background: linear-gradient(135deg, rgba(42,197,88,0.12) 0%, rgba(255,255,255,1) 100%);
	transform: translateY(-2px);
	box-shadow: 0 12px 24px rgba(7,31,69,0.08);
}
body.page-about .portal-icon{
	width: 46px;
	height: 46px;
	border-radius: 14px;
	display: grid;
	place-items: center;
	background: linear-gradient(180deg, rgba(42,197,88,0.16) 0%, rgba(42,197,88,0.08) 100%);
	border: 1px solid rgba(42,197,88,0.18);
}
body.page-about .portal-copy{ flex: 1; }
body.page-about .portal-title{ font-family: var(--font-display); font-size: 1.02rem; font-weight: 700; }
body.page-about .portal-arrow{ opacity: 0.72; }
body.page-about .page-top{
	padding: 132px 0 28px;
	background:
		radial-gradient(90% 120% at 82% 0%, rgba(42,197,88,0.18) 0%, transparent 44%),
		radial-gradient(100% 100% at 0% 100%, rgba(42,74,128,0.38) 0%, transparent 58%),
		linear-gradient(150deg, #071F45 0%, #0D2A56 58%, #123E65 100%);
	border-bottom: 1px solid rgba(255,255,255,0.08);
}
body.page-about .page-top-inner{
	display: flex;
	flex-direction: column;
	gap: 10px;
}
body.page-about .page-heading{
	font-size: clamp(1.9rem, 3.2vw, 2.7rem);
	color: var(--white);
}
body.page-about .page-subcopy{
	max-width: 520px;
	color: rgba(255,255,255,0.76);
	font-size: 0.98rem;
}
body.page-about .about-intro{
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1.08fr) minmax(360px, 0.92fr);
	gap: clamp(28px, 4vw, 54px);
	align-items: stretch;
	padding: clamp(30px, 4vw, 48px);
	border-radius: 44px;
	background:
		radial-gradient(80% 80% at 100% 0%, rgba(42,197,88,0.08) 0%, transparent 56%),
		radial-gradient(90% 90% at 0% 100%, rgba(42,74,128,0.06) 0%, transparent 60%),
		linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(247,248,250,0.98) 100%);
	border: 1px solid rgba(7,31,69,0.08);
	box-shadow: 0 26px 80px rgba(7,31,69,0.12);
	overflow: hidden;
}
body.page-about .about-intro::before{
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(115deg, rgba(255,255,255,0.52) 0%, transparent 26%),
		repeating-linear-gradient(-45deg, rgba(7,31,69,0.025) 0 1px, transparent 1px 22px);
	pointer-events: none;
}
body.page-about .about-intro::after{
	content: "";
	position: absolute;
	width: 300px;
	height: 300px;
	right: -90px;
	top: -90px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(42,197,88,0.14) 0%, rgba(42,197,88,0.02) 62%, transparent 72%);
	filter: blur(12px);
	pointer-events: none;
}
body.page-about .about-copy{
	display: grid;
	gap: var(--sp-6);
	position: relative;
	z-index: 1;
}
body.page-about .about-image{
	position: relative;
	overflow: hidden;
	border-radius: 34px;
	min-height: 600px;
	border: 1px solid rgba(7,31,69,0.08);
	background: #071F45;
	box-shadow: 0 24px 58px rgba(7,31,69,0.14);
	z-index: 1;
}
body.page-about .about-image::before{
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(7,31,69,0.02) 0%, rgba(7,31,69,0.16) 100%);
	pointer-events: none;
	z-index: 1;
}
body.page-about .about-image::after{
	content: "";
	position: absolute;
	inset: 18px;
	border-radius: 24px;
	border: 1px solid rgba(255,255,255,0.55);
	pointer-events: none;
	z-index: 2;
}
body.page-about .about-image img{
	width: 100%;
	height: 100%;
	min-height: 600px;
	display: block;
	object-fit: cover;
	object-position: center;
}
body.page-about .about-tagline{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--navy-light);
	white-space: nowrap;
	line-height: 1.45;
}
body.page-about .about-tagline::before{
	content: "";
	width: 28px;
	height: 2px;
	border-radius: 99px;
	background: var(--green);
}
body.page-about .about-heading{
	font-size: clamp(1.85rem, 3.6vw, 3.1rem);
	line-height: 1.02;
	max-width: 12ch;
	color: var(--navy);
	margin-top: 10px;
}
body.page-about .about-heading em{
	font-style: italic;
	font-weight: 400;
	color: var(--navy-light);
}
body.page-about .about-top-copy{
	max-width: 60ch;
	color: #4C5873;
	font-size: 1.02rem;
	line-height: 1.84;
	padding-top: 18px;
	margin-top: 20px;
	border-top: 1px solid rgba(7,31,69,0.12);
}
body.page-about .about-top-copy p + p{
	margin-top: 16px;
}
body.page-about .about-copy{
	display: grid;
	gap: 22px;
}
body.page-about .about-copy .story-card{
	padding: 0;
}
body.page-about .about-copy .mission-grid{
	margin-top: 6px;
}
body.page-about .visual-card, body.page-about .visual-tile{
	position: relative;
	overflow: hidden;
	border-radius: 32px;
	border: 1px solid rgba(255,255,255,0.12);
	background:
		linear-gradient(180deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0.02) 100%),
		linear-gradient(135deg, rgba(42,197,88,0.12) 0%, rgba(255,255,255,0.02) 100%);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	box-shadow: 0 24px 60px rgba(7,31,69,0.18);
}
body.page-about .visual-card{
	aspect-ratio: 0.95;
	padding: 0;
}
body.page-about .visual-card::before{
	content: "Image Placeholder";
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	color: rgba(255,255,255,0.38);
	font-family: var(--font-display);
	font-size: 1rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}
body.page-about .visual-stack{
	display: grid;
	gap: 18px;
}
body.page-about .visual-tile{
	min-height: 200px;
	padding: 20px;
}
body.page-about .visual-tile::before{
	content: "Image Placeholder";
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	color: rgba(255,255,255,0.34);
	font-family: var(--font-display);
	font-size: 0.88rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}
body.page-about .visual-tile--metric{
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	background:
		radial-gradient(100% 100% at 100% 0%, rgba(42,197,88,0.2) 0%, transparent 48%),
		linear-gradient(160deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.02) 100%);
}
body.page-about .visual-tile--metric::before{ content: none; }
body.page-about .visual-metric{
	font-family: var(--font-display);
	font-size: 2.8rem;
	font-weight: 800;
	color: var(--white);
	line-height: 1;
}
body.page-about .visual-label{
	margin-top: 8px;
	font-size: 0.9rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.72);
}
body.page-about .section{
	padding: var(--sp-24) 0;
}
body.page-about .section-head{
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
	gap: var(--sp-10);
	align-items: end;
	margin-bottom: var(--sp-12);
}
body.page-about .section-title{
	margin-top: var(--sp-4);
	font-size: clamp(2rem, 4vw, 3.35rem);
}
body.page-about .section-title em{
	font-style: italic;
	font-weight: 400;
	color: var(--navy-light);
}
body.page-about .section-copy{
	font-size: 1rem;
	color: var(--gray-dark);
}
body.page-about .story-wrap{
	display: grid;
	gap: var(--sp-6);
}
body.page-about .story-card{
	padding: 0;
	border-radius: 0;
	background: transparent;
	border: 0;
	box-shadow: none;
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
	position: relative;
	overflow: hidden;
}
body.page-about .story-card h3{
	font-size: 1.45rem;
	margin-bottom: var(--sp-4);
}
body.page-about .story-card p{
	color: #4C5873;
	line-height: 1.74;
}
body.page-about .mission-grid{
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
}
body.page-about .mission-card{
	padding: 30px;
	border-radius: 30px;
	background:
		radial-gradient(90% 110% at 100% 0%, rgba(42,197,88,0.12) 0%, transparent 52%),
		linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(243,247,251,1) 100%);
	border: 1px solid rgba(7,31,69,0.08);
	box-shadow: 0 16px 34px rgba(7,31,69,0.08);
	position: relative;
	overflow: hidden;
}
body.page-about .mission-card::before{
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 3px;
	background: linear-gradient(90deg, rgba(42,197,88,0.95) 0%, rgba(42,74,128,0.2) 100%);
}
body.page-about .mission-card h4{
	font-size: 1.2rem;
	margin-bottom: 12px;
}
body.page-about .mission-card p{
	color: #51607D;
}
body.page-about .journey{
	position: relative;
	background:
		radial-gradient(circle at 10% 20%, rgba(126,234,160,0.08) 0%, transparent 45%),
		radial-gradient(circle at 90% 80%, rgba(42,74,128,0.06) 0%, transparent 45%),
		linear-gradient(180deg, #F7F8FA 0%, #EEF1F6 100%);
}
body.page-about .journey-scroller{
	position: relative;
	height: 320vh;
}
body.page-about .journey-sticky{
	position: sticky;
	top: 0;
	height: 100vh;
	overflow: hidden;
	display: flex;
	align-items: center;
}
body.page-about .journey-inner{
	position: relative;
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 var(--sp-10);
	display: grid;
	grid-template-columns: minmax(0, 1.2fr) minmax(380px, 1fr);
	gap: var(--sp-16);
	align-items: stretch;
}
body.page-about .journey-left{
	display: flex;
	flex-direction: column;
	gap: var(--sp-8);
	justify-content: center;
}
body.page-about .journey-stories{ position: relative; z-index: 2; }
body.page-about .journey-stories-head{
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
	margin-bottom: var(--sp-8);
}
body.page-about .journey-panels{
	position: relative;
	min-height: 360px;
}
body.page-about .journey-panel{
	position: absolute;
	inset: 0;
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.5s var(--ease), transform 0.5s var(--ease);
	pointer-events: none;
	padding-left: var(--sp-10);
	border-left: 2px solid rgba(7, 31, 69, 0.1);
}
body.page-about .journey-panel.active{
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}
body.page-about .journey-panel::before{
	content: '';
	position: absolute;
	left: -7px;
	top: 4px;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--green);
	box-shadow: 0 0 0 5px rgba(42, 197, 88, 0.16);
}
body.page-about .journey-panel-head{ display: flex; align-items: center; gap: var(--sp-4); margin-bottom: var(--sp-5); }
body.page-about .journey-chapter{
	display: inline-flex;
	align-items: center;
	padding: 6px 14px;
	background: rgba(42, 197, 88, 0.12);
	border: 1px solid rgba(42, 197, 88, 0.24);
	border-radius: var(--r-pill);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--green-dark);
}
body.page-about .journey-year{
	font-family: var(--font-display);
	font-weight: 700;
	color: var(--navy-light);
	font-size: 0.875rem;
	letter-spacing: 0.08em;
}
body.page-about .journey-ptitle{
	font-size: clamp(1.75rem, 2.8vw, 2.25rem);
	line-height: 1.1;
	margin-bottom: var(--sp-5);
}
body.page-about .journey-pbody{
	color: var(--gray-dark);
	line-height: 1.75;
	font-size: 1.0625rem;
	white-space: pre-line;
	max-width: 56ch;
}
body.page-about .journey-years{
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: var(--sp-4);
	padding: var(--sp-5) var(--sp-6);
	background: var(--white);
	border: 1px solid var(--border);
	border-radius: var(--r-xl);
	box-shadow: var(--sh-soft);
	position: relative;
	margin-left: var(--sp-10);
	max-width: 560px;
}
body.page-about .journey-years::before{
	content: '';
	position: absolute;
	left: var(--sp-6);
	right: var(--sp-6);
	top: calc(var(--sp-5) + 5px);
	height: 2px;
	background: rgba(7, 31, 69, 0.08);
	z-index: 0;
}
body.page-about .journey-years-fill{
	position: absolute;
	left: var(--sp-6);
	right: var(--sp-6);
	top: calc(var(--sp-5) + 5px);
	height: 2px;
	transform: scaleX(var(--fill, 0));
	transform-origin: left center;
	background: linear-gradient(90deg, var(--green) 0%, var(--navy) 100%);
	z-index: 1;
	transition: transform 0.5s var(--ease);
}
body.page-about .journey-year-marker{
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--sp-2);
	cursor: pointer;
	position: relative;
	z-index: 2;
	flex: 1;
}
body.page-about .journey-year-dot{
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--white);
	border: 2px solid rgba(7, 31, 69, 0.25);
	transition: all 260ms var(--ease);
}
body.page-about .journey-year-marker.active .journey-year-dot{
	background: var(--green);
	border-color: var(--green);
	box-shadow: 0 0 0 5px rgba(42, 197, 88, 0.16);
	transform: scale(1.2);
}
body.page-about .journey-year-label{
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 700;
	color: var(--gray);
	letter-spacing: 0.02em;
	transition: color 260ms var(--ease);
}
body.page-about .journey-year-marker.active .journey-year-label{ color: var(--navy); }
body.page-about .journey-right{
	display: flex;
	flex-direction: column;
	gap: var(--sp-5);
	height: 100%;
	max-height: 78vh;
}
body.page-about .journey-metrics{
	flex-shrink: 0;
	display: flex;
	justify-content: space-around;
	gap: var(--sp-6);
	padding: var(--sp-6) var(--sp-5);
	background: var(--white);
	border: 1px solid var(--border);
	border-radius: var(--r-xl);
	box-shadow: var(--sh-soft);
}
body.page-about .journey-metric{
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--sp-1);
	text-align: center;
}
body.page-about .journey-metric-big{
	font-family: var(--font-display);
	font-size: clamp(2.75rem, 5vw, 3.75rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 0.9;
	background: linear-gradient(135deg, var(--navy) 0%, var(--green-dark) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}
body.page-about .journey-metric-label{
	font-family: var(--font-display);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--gray);
}
body.page-about .journey-tree-viz{
	flex: 1;
	width: 100%;
	position: relative;
	display: grid;
	place-items: center;
	overflow: hidden;
	border-radius: var(--r-2xl);
	background:
		radial-gradient(120% 90% at 50% 100%, rgba(42, 197, 88, 0.08) 0%, transparent 60%),
		linear-gradient(180deg, #FFFFFF 0%, #F1F5F1 100%);
	border: 1px solid var(--border);
	box-shadow: var(--sh-soft);
	min-height: 320px;
}
body.page-about .journey-tree-viz svg{
	width: 94%;
	height: 94%;
	overflow: visible;
}
body.page-about .tree-trunk-org{
	transform-origin: 260px 450px;
	transform: scaleY(0.1);
	opacity: 0.4;
	transition: transform 1.2s var(--ease), opacity 0.8s ease;
}
body.page-about .tree-trunk-org.s1, body.page-about .tree-trunk-org.s2{ transform: scaleY(1); opacity: 1; }
body.page-about .tree-branches-org{
	opacity: 0;
	transform-origin: 260px 300px;
	transform: scale(0.5);
	transition: opacity 0.9s ease, transform 0.9s var(--ease);
}
body.page-about .tree-branches-org.s1, body.page-about .tree-branches-org.s2{ opacity: 1; transform: scale(1); }
body.page-about .tree-foliage-org{
	opacity: 0;
	transform-origin: 260px 220px;
	transform: scale(0.28);
	transition: opacity 1.1s ease, transform 1.25s var(--ease), filter 1.1s ease;
	filter: saturate(0.9);
}
body.page-about .tree-foliage-org.s1{
	opacity: 0.92;
	transform: scale(0.62);
	filter: saturate(0.98);
}
body.page-about .tree-foliage-org.s2{
	opacity: 1;
	transform: scale(1);
	filter: saturate(1.08);
}
body.page-about .tree-foliage-org .tree-leaf{
	transform-box: fill-box;
	transform-origin: center;
	transition: opacity 1.1s ease, transform 1.25s var(--ease);
}
body.page-about .tree-foliage-org .tree-leaf--mid,
body.page-about .tree-foliage-org .tree-leaf--outer,
body.page-about .tree-foliage-org .tree-leaf--glow{
	opacity: 0;
}
body.page-about .tree-foliage-org.s1 .tree-leaf--core{
	transform: scale(0.78);
}
body.page-about .tree-foliage-org.s1 .tree-leaf--mid{
	opacity: 1;
	transform: scale(0.82);
}
body.page-about .tree-foliage-org.s1 .tree-leaf--outer,
body.page-about .tree-foliage-org.s1 .tree-leaf--glow{
	opacity: 0.18;
	transform: scale(0.7);
}
body.page-about .tree-foliage-org.s2 .tree-leaf--core,
body.page-about .tree-foliage-org.s2 .tree-leaf--mid,
body.page-about .tree-foliage-org.s2 .tree-leaf--outer,
body.page-about .tree-foliage-org.s2 .tree-leaf--glow{
	opacity: 1;
	transform: scale(1);
}
body.page-about .tree-fruits-org{
	opacity: 0;
	transform-origin: 260px 240px;
	transform: translateY(10px) scale(0.7);
	transition: opacity 0.8s ease 0.18s, transform 0.95s var(--ease) 0.18s;
}
body.page-about .tree-foliage-org.s2 .tree-fruits-org{
	opacity: 1;
	transform: translateY(0) scale(1);
}
body.page-about .tree-seed-org{
	transform-origin: 260px 450px;
	animation: seedSway 5s var(--ease) infinite;
}
@keyframes seedSway{
	0%, 100%{ transform: rotate(-1deg); }
	50%{ transform: rotate(1.5deg); }
}
body.page-about .team-alt{
	background: var(--white);
}
body.page-about .team-wrap{ display: grid; gap: var(--sp-10); }
body.page-about .team-head{
	display: grid;
	gap: 10px;
	margin-bottom: var(--sp-8);
}
body.page-about .team-grid{
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--sp-6);
}
body.page-about .team-card{
	position: relative;
}
body.page-about .team-photo{
	aspect-ratio: 4 / 4.8;
	border-radius: 22px;
	background:
		linear-gradient(180deg, rgba(42,197,88,0.12) 0%, rgba(42,74,128,0.08) 100%),
		linear-gradient(135deg, #EFF4FB 0%, #E4ECF7 100%);
	border: 1px solid rgba(7,31,69,0.06);
	display: grid;
	place-items: center;
	color: var(--navy-light);
	margin-bottom: 18px;
	position: relative;
	overflow: hidden;
}
body.page-about .team-photo::before{
	content: "Portrait Placeholder";
	font-family: var(--font-display);
	font-size: 0.9rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	opacity: 0.68;
}
body.page-about .team-photo:has(img)::before{
	display: none;
}
body.page-about .team-photo img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center top;
	display: block;
	filter: grayscale(1) contrast(1.04);
	transition: filter var(--dur) var(--ease), transform 500ms var(--ease);
}
body.page-about .team-card:hover .team-photo img{
	filter: grayscale(0) contrast(1);
	transform: scale(1.03);
}
body.page-about .team-overlay{
	position: absolute;
	inset: 0;
	padding: 18px 18px 22px;
	border-radius: 22px;
	background: linear-gradient(0deg, rgba(9,29,67,0.62) 0%, rgba(20,54,108,0.2) 42%, rgba(20,54,108,0) 72%);
	display: flex;
	align-items: flex-end;
	justify-content: flex-start;
	opacity: 0;
	transform: translateY(8px);
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
body.page-about .team-card:hover .team-overlay{
	opacity: 1;
	transform: translateY(0);
}
body.page-about .team-overlay a{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	background: transparent;
	color: var(--white);
	transition: color var(--dur) var(--ease), transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
body.page-about .team-overlay a:hover{
	color: var(--white);
	transform: scale(1.08);
}
body.page-about .team-overlay a svg{
	width: 22px;
	height: 22px;
}
body.page-about .team-name{
	font-size: 1.3rem;
	margin-bottom: 0;
}
body.page-about .team-role{
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--green-dark);
}
body.page-about .cta{
	position: relative;
	padding: var(--sp-20) var(--sp-10);
	overflow: hidden;
	isolation: isolate;
	color: var(--white);
}
body.page-about .cta::before{
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(120% 80% at 85% 0%, rgba(42,197,88,0.32) 0%, transparent 55%),
		radial-gradient(120% 80% at 0% 100%, rgba(42,74,128,0.55) 0%, transparent 60%),
		linear-gradient(155deg, var(--navy) 0%, #0B2856 60%, var(--navy-mid) 100%);
	z-index: -2;
}
body.page-about .cta::after{
	content: '';
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.03) 0 1px, transparent 1px 14px);
	z-index: -1;
}
body.page-about .cta-inner{
	max-width: 1280px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sp-8);
	flex-wrap: wrap;
}
body.page-about .cta-copy{
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
	flex: 1 1 auto;
	min-width: 280px;
}
body.page-about .cta-title{
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	line-height: 1.15;
	font-weight: 700;
	color: var(--white);
	letter-spacing: -0.02em;
}
body.page-about .cta-desc{
	font-size: 0.9375rem;
	line-height: 1.55;
	color: rgba(255,255,255,0.75);
}
body.page-about .cta-actions{ flex-shrink: 0; }
body.page-about .footer{
	background: var(--navy);
	color: rgba(255,255,255,0.72);
	padding: var(--sp-24) var(--sp-10) var(--sp-10);
}
body.page-about .footer-inner{
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: var(--sp-12);
	padding-bottom: var(--sp-12);
	border-bottom: 1px solid rgba(255,255,255,0.1);
}
body.page-about .footer-brand{ max-width: 320px; }
body.page-about .footer-logo{
	display: flex;
	align-items: center;
	gap: 10px;
	font-family: var(--font-display);
	font-weight: 800;
	color: var(--white);
	font-size: 1.375rem;
	margin-bottom: var(--sp-4);
}
body.page-about .footer-tagline{ color: var(--white); font-weight: 500; margin-bottom: var(--sp-3); }
body.page-about .footer-arn{
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.6);
	margin-bottom: var(--sp-5);
}
body.page-about .footer-col h4{
	color: var(--white);
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin-bottom: var(--sp-5);
}
body.page-about .footer-col-body{ display: flex; flex-direction: column; gap: var(--sp-3); }
body.page-about .footer-link{
	color: rgba(255,255,255,0.72);
	font-size: 0.9375rem;
	transition: color var(--dur) var(--ease);
}
body.page-about .footer-link:hover{ color: var(--green-light); }
body.page-about .footer-social{ display: flex; gap: var(--sp-3); }
body.page-about .footer-social a{
	display: grid;
	place-items: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(255,255,255,0.06);
	color: rgba(255,255,255,0.72);
	transition: all var(--dur) var(--ease);
}
body.page-about .footer-social a:hover{
	background: var(--green);
	color: var(--navy);
	transform: translateY(-2px);
}
body.page-about .footer-bottom{
	max-width: 1280px;
	margin: 0 auto;
	padding-top: var(--sp-6);
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--sp-4);
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.55);
}
body.page-about .footer-bottom-links{ display: flex; gap: var(--sp-6); }
body.page-about .footer-bottom-links a{ transition: color var(--dur) var(--ease); }
body.page-about .footer-bottom-links a:hover{ color: var(--green-light); }
@media (max-width: 1100px){
	body.page-about .about-intro, body.page-about .story-wrap, body.page-about .team-wrap, body.page-about .footer-inner, body.page-about .section-head{
		grid-template-columns: 1fr;
	}
	body.page-about .team-intro{
		position: relative;
		top: auto;
	}
	body.page-about .journey-scroller{ height: auto; }
	body.page-about .journey-sticky{ position: static; height: auto; padding: var(--sp-16) 0; }
	body.page-about .journey-inner{ grid-template-columns: 1fr; gap: var(--sp-10); }
	body.page-about .journey-right{ max-height: none; order: -1; }
	body.page-about .journey-tree-viz{ min-height: 280px; max-height: 340px; }
	body.page-about .journey-panel{ position: relative; opacity: 1; transform: none; pointer-events: auto; margin-bottom: var(--sp-8); }
	body.page-about .journey-panels{ min-height: auto; }
	body.page-about .journey-years{ margin-left: 0; max-width: none; }
}
@media (max-width: 960px){
	body.page-about .container, body.page-about .footer{
		padding-left: var(--sp-5);
		padding-right: var(--sp-5);
	}
	body.page-about .nav-links{ gap: var(--sp-5); }
	body.page-about .nav-login-menu{
		width: min(360px, calc(100vw - 40px));
		right: -10px;
	}
}
@media (max-width: 760px){
	body.page-about .navbar{ padding: 18px 20px; }
	body.page-about .nav-links{ gap: 14px; }
	body.page-about .nav-link{ font-size: 0.875rem; }
	body.page-about .nav-logo img{ height: 48px; }
	body.page-about .page-top{ padding-top: 120px; padding-bottom: 22px; }
	body.page-about .mission-grid{ grid-template-columns: 1fr; }
	body.page-about .team-grid{
		grid-template-columns: 1fr;
	}
	body.page-about .cta{ padding: var(--sp-16) var(--sp-5); }
	body.page-about .cta-inner{
		flex-direction: column;
		text-align: center;
		align-items: center;
	}
}
@media (max-width: 620px){
	body.page-about .navbar{ align-items: flex-start; }
	body.page-about .nav-links{
		flex-wrap: wrap;
		justify-content: flex-end;
		row-gap: 10px;
	}
	body.page-about .nav-login{
		width: 100%;
		display: flex;
		justify-content: flex-end;
	}
}


/* /services */
body.page-services *, body.page-services *::before, body.page-services *::after{ box-sizing: border-box; }
body.page-services, body.page-services{ margin: 0; padding: 0; }
body.page-services{
	font-family: var(--font-body);
	color: var(--gray-dark);
	background: var(--off-white);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	overflow-x: clip;
}
body.page-services a{ color: inherit; text-decoration: none; }
body.page-services img, body.page-services svg{ display: block; max-width: 100%; }
body.page-services h1, body.page-services h2, body.page-services h3, body.page-services h4, body.page-services h5, body.page-services p{ margin: 0; }
body.page-services h1, body.page-services h2, body.page-services h3, body.page-services h4{
	font-family: var(--font-display);
	color: var(--navy);
	letter-spacing: -0.02em;
	line-height: 1.08;
}
body.page-services .container{
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 var(--sp-10);
}
body.page-services .eyebrow{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--green-dark);
}
body.page-services .eyebrow::before{
	content: "";
	width: 28px;
	height: 2px;
	background: var(--green);
	border-radius: 99px;
}
body.page-services .eyebrow--light{ color: var(--green-light); }
body.page-services .breadcrumb{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.62);
}
body.page-services .breadcrumb a{
	color: inherit;
	transition: color var(--dur) var(--ease);
}
body.page-services .breadcrumb a:hover{
	color: var(--green-light);
}
body.page-services .breadcrumb .current{
	color: var(--green-light);
}
body.page-services .le-btn{
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 54px;
	padding: 0 30px;
	border-radius: var(--r-md);
	font-size: 0.9375rem;
	font-weight: 600;
	border: 1px solid transparent;
	cursor: pointer;
	overflow: hidden;
	white-space: nowrap;
	transition: background-color var(--dur) var(--ease),
		color var(--dur) var(--ease),
		border-color var(--dur) var(--ease),
		box-shadow var(--dur) var(--ease),
		transform var(--dur) var(--ease);
}
body.page-services .le-btn .lbl{
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
body.page-services .le-btn .arr{
	position: absolute;
	left: 50%;
	top: 50%;
	opacity: 0;
	transform: translate(-50%, -50%) translateX(-40px);
	transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
body.page-services .le-btn:hover .lbl{ opacity: 0; transform: translateX(30px); }
body.page-services .le-btn:hover .arr{ opacity: 1; transform: translate(-50%, -50%) translateX(0); }
body.page-services .le-btn--primary{
	background: var(--green);
	color: var(--navy);
	box-shadow: var(--sh-green);
}
body.page-services .le-btn--primary:hover{
	background: var(--green-dark);
	color: var(--white);
	transform: translateY(-2px);
}
body.page-services .le-btn--secondary{
	background: transparent;
	color: var(--navy);
	border-color: rgba(7,31,69,0.2);
}
body.page-services .le-btn--secondary:hover{
	background: var(--navy);
	border-color: var(--navy);
	color: var(--white);
	transform: translateY(-2px);
}
body.page-services .on-dark .le-btn--secondary{
	color: var(--white);
	border-color: rgba(255,255,255,0.28);
}
body.page-services .on-dark .le-btn--secondary:hover{
	background: var(--white);
	color: var(--navy);
	border-color: var(--white);
}
body.page-services .navbar{
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--sp-5) var(--sp-10);
	transition: background-color var(--dur) var(--ease),
		backdrop-filter var(--dur) var(--ease),
		box-shadow var(--dur) var(--ease);
}
body.page-services .navbar.is-transparent{ background: transparent; }
body.page-services .navbar.is-solid{
	background: rgba(255,255,255,0.92);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-shadow: 0 1px 0 rgba(7,31,69,0.06);
}
body.page-services .nav-logo{ display: flex; align-items: center; }
body.page-services .nav-logo img{ height: 56px; width: auto; }
body.page-services .nav-logo-light{ display: none; }
body.page-services .is-transparent .nav-logo-dark{ display: none; }
body.page-services .is-transparent .nav-logo-light{ display: block; }
body.page-services .is-solid .nav-logo-dark{ display: block; }
body.page-services .is-solid .nav-logo-light{ display: none; }
body.page-services .nav-links{ display: flex; align-items: center; gap: var(--sp-8); }
body.page-services .nav-link{
	position: relative;
	font-size: 0.9375rem;
	font-weight: 500;
	transition: color var(--dur) var(--ease);
}
body.page-services .is-transparent .nav-link{ color: var(--white); }
body.page-services .is-solid .nav-link{ color: var(--navy); }
body.page-services .nav-link::after{
	content: "";
	position: absolute;
	left: 0;
	bottom: -10px;
	width: 100%;
	height: 2px;
	border-radius: 99px;
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform var(--dur) var(--ease);
}
body.page-services .is-transparent .nav-link::after{ background: var(--green-light); }
body.page-services .is-solid .nav-link::after{ background: var(--green); }
body.page-services .nav-link:hover, body.page-services .nav-link.is-active{ color: var(--green); }
body.page-services .nav-link:hover::after, body.page-services .nav-link.is-active::after{ transform: scaleX(1); }
body.page-services .nav-login{
	position: relative;
	padding-bottom: 18px;
	margin-bottom: -18px;
}
body.page-services .nav-login::after{
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	height: 24px;
}
body.page-services .nav-login-toggle{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	height: 52px;
	padding: 0 24px 0 26px;
	border-radius: 16px;
	font-size: 0.875rem;
	font-weight: 600;
	background: transparent;
	border: 1px solid;
	cursor: pointer;
	transition: color var(--dur) var(--ease),
		border-color var(--dur) var(--ease),
		background-color var(--dur) var(--ease),
		box-shadow var(--dur) var(--ease);
}
body.page-services .nav-login-toggle svg{
	width: 16px;
	height: 16px;
	transition: transform var(--dur) var(--ease);
}
body.page-services .nav-login.is-open .nav-login-toggle svg{ transform: rotate(180deg); }
body.page-services .is-transparent .nav-login-toggle{
	color: var(--white);
	border-color: rgba(255,255,255,0.22);
	background: linear-gradient(180deg, rgba(255,255,255,0.14) 0%, rgba(255,255,255,0.06) 100%);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}
body.page-services .is-solid .nav-login-toggle{
	color: var(--navy);
	border-color: rgba(7,31,69,0.12);
	background: linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(244,247,250,0.98) 100%);
	box-shadow: 0 8px 24px rgba(7,31,69,0.05);
}
body.page-services .nav-login-menu{
	position: absolute;
	top: calc(100% + 6px);
	right: 0;
	width: 320px;
	padding: 12px;
	border-radius: 22px;
	background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(246,248,251,0.99) 100%);
	border: 1px solid rgba(7,31,69,0.09);
	box-shadow: 0 28px 70px rgba(7,31,69,0.18);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	opacity: 0;
	transform: translateY(10px);
	visibility: hidden;
	pointer-events: none;
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear var(--dur);
}
body.page-services .nav-login-menu::before{
	content: "";
	position: absolute;
	top: -9px;
	right: 34px;
	width: 18px;
	height: 18px;
	background: rgba(255,255,255,0.98);
	border-top: 1px solid rgba(7,31,69,0.1);
	border-left: 1px solid rgba(7,31,69,0.1);
	transform: rotate(45deg);
}
body.page-services .nav-login.is-open .nav-login-menu{
	opacity: 1;
	transform: translateY(0);
	visibility: visible;
	pointer-events: auto;
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear 0s;
}
body.page-services .portal-link{
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px 15px;
	border-radius: 18px;
	color: var(--navy);
	background: linear-gradient(180deg, rgba(255,255,255,0.95) 0%, rgba(249,250,252,1) 100%);
	border: 1px solid rgba(7,31,69,0.06);
	transition: background-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
body.page-services .portal-link + .portal-link{ margin-top: 8px; }
body.page-services .portal-link:hover{
	background: linear-gradient(135deg, rgba(42,197,88,0.12) 0%, rgba(255,255,255,1) 100%);
	transform: translateY(-2px);
	box-shadow: 0 12px 24px rgba(7,31,69,0.08);
}
body.page-services .portal-icon{
	width: 46px;
	height: 46px;
	border-radius: 14px;
	display: grid;
	place-items: center;
	background: linear-gradient(180deg, rgba(42,197,88,0.16) 0%, rgba(42,197,88,0.08) 100%);
	border: 1px solid rgba(42,197,88,0.18);
}
body.page-services .portal-copy{ flex: 1; }
body.page-services .portal-title{
	font-family: var(--font-display);
	font-size: 1.02rem;
	font-weight: 700;
}
body.page-services .portal-arrow{ opacity: 0.72; }
body.page-services .page-hero{
	position: relative;
	padding: 170px 0 112px;
	background:
		radial-gradient(90% 120% at 80% 0%, rgba(42,197,88,0.18) 0%, transparent 46%),
		radial-gradient(100% 100% at 0% 100%, rgba(42,74,128,0.45) 0%, transparent 56%),
		linear-gradient(150deg, #071F45 0%, #102E5B 56%, #174B61 100%);
	color: var(--white);
	overflow: hidden;
}
body.page-services .page-hero::before{
	content: "";
	position: absolute;
	right: -100px;
	top: 90px;
	width: 420px;
	height: 420px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(42,197,88,0.2) 0%, rgba(42,74,128,0.12) 36%, transparent 72%);
	filter: blur(14px);
	opacity: 0.9;
}
body.page-services .page-hero::after{
	content: "";
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.02) 0 1px, transparent 1px 18px);
	pointer-events: none;
}
body.page-services .page-hero-grid{
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
	gap: var(--sp-12);
	align-items: center;
}
body.page-services .page-title{
	margin-top: var(--sp-5);
	font-size: clamp(2.5rem, 5vw, 4.5rem);
	color: var(--white);
}
body.page-services .page-title em{
	font-style: italic;
	font-weight: 400;
	color: rgba(255,255,255,0.78);
}
body.page-services .page-lede{
	margin-top: var(--sp-6);
	max-width: 720px;
	font-size: 1.05rem;
	color: rgba(255,255,255,0.76);
}
body.page-services .page-hero-actions{
	margin-top: var(--sp-8);
	display: flex;
	gap: var(--sp-4);
	flex-wrap: wrap;
}
body.page-services .page-hero-note{
	margin-top: var(--sp-5);
	font-size: 0.92rem;
	color: rgba(255,255,255,0.62);
}
body.page-services .hero-stat-panel{
	padding: 28px;
	border-radius: 28px;
	background: linear-gradient(180deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.06) 100%);
	border: 1px solid rgba(255,255,255,0.14);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	box-shadow: 0 24px 44px rgba(0,0,0,0.2);
}
body.page-services .hero-stat-list{
	margin-top: var(--sp-5);
	display: grid;
	gap: 12px;
}
body.page-services .hero-stat-item{
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 16px;
	border-radius: 18px;
	background: rgba(255,255,255,0.07);
	border: 1px solid rgba(255,255,255,0.08);
}
body.page-services .hero-stat-icon{
	width: 44px;
	height: 44px;
	border-radius: 14px;
	display: grid;
	place-items: center;
	background: linear-gradient(180deg, rgba(42,197,88,0.18) 0%, rgba(255,255,255,0.08) 100%);
	color: var(--green-light);
}
body.page-services .hero-stat-text{
	font-size: 0.94rem;
	color: rgba(255,255,255,0.82);
}
body.page-services .hero-stat-kicker{
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--green-light);
}
body.page-services .hero-stat-panel h2{
	margin-top: var(--sp-4);
	font-size: 2rem;
	color: var(--white);
}
body.page-services .hero-stat-panel p{
	margin-top: var(--sp-4);
	color: rgba(255,255,255,0.76);
}
body.page-services .section{
	padding: var(--sp-24) 0;
}
body.page-services .section-alt{
	background:
		radial-gradient(80% 100% at 100% 0%, rgba(42,197,88,0.08) 0%, transparent 48%),
		var(--white);
}
body.page-services .section-head{
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
	gap: var(--sp-10);
	align-items: end;
	margin-bottom: var(--sp-12);
}
body.page-services .section-title{
	margin-top: var(--sp-4);
	font-size: clamp(2rem, 4vw, 3.35rem);
}
body.page-services .section-title em{
	font-style: italic;
	font-weight: 400;
	color: var(--navy-light);
}
body.page-services .section-head-main{
	display: block;
}
body.page-services .section-copy{
	font-size: 1rem;
	color: var(--gray-dark);
}
body.page-services .blueprint-grid{
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--sp-6);
}
body.page-services .blueprint-card{
	position: relative;
	padding: 32px;
	border-radius: 28px;
	background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(247,248,250,1) 100%);
	border: 1px solid rgba(7,31,69,0.08);
	box-shadow: var(--sh-soft);
	overflow: hidden;
	transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
body.page-services .blueprint-card::before{
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 4px;
	background: linear-gradient(90deg, rgba(42,197,88,0.9) 0%, rgba(42,74,128,0.34) 100%);
}
body.page-services .blueprint-card::after{
	content: "";
	position: absolute;
	right: -28px;
	top: -28px;
	width: 120px;
	height: 120px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(42,197,88,0.08) 0%, transparent 70%);
}
body.page-services .blueprint-card:hover{
	transform: translateY(-4px);
	box-shadow: var(--sh-md);
	border-color: rgba(42,197,88,0.18);
}
body.page-services .blueprint-step{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 14px;
	background: linear-gradient(135deg, rgba(42,197,88,0.18) 0%, rgba(42,74,128,0.12) 100%);
	color: var(--navy);
	font-family: var(--font-display);
	font-weight: 800;
	margin-bottom: var(--sp-5);
}
body.page-services .blueprint-icon{
	width: 52px;
	height: 52px;
	border-radius: 16px;
	display: grid;
	place-items: center;
	margin-bottom: var(--sp-5);
	background: linear-gradient(180deg, rgba(42,197,88,0.16) 0%, rgba(42,74,128,0.08) 100%);
	border: 1px solid rgba(42,197,88,0.14);
	color: var(--navy);
}
body.page-services .blueprint-card h3{
	font-size: 1.3rem;
	margin-bottom: var(--sp-4);
}
body.page-services .blueprint-card p{
	color: var(--gray-dark);
}
body.page-services .solutions-shell{
	display: grid;
	gap: var(--sp-8);
}
body.page-services .solution-band{
	display: block;
	padding: 34px;
	border-radius: 32px;
	overflow: hidden;
	position: relative;
}
body.page-services .solution-band--dark{
	background:
		radial-gradient(80% 120% at 100% 0%, rgba(42,197,88,0.18) 0%, transparent 45%),
		linear-gradient(145deg, #071F45 0%, #12305E 100%);
	color: var(--white);
}
body.page-services .solution-band--light{
	background:
		radial-gradient(90% 120% at 100% 0%, rgba(42,197,88,0.12) 0%, transparent 48%),
		linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(243,247,251,1) 100%);
	border: 1px solid rgba(7,31,69,0.08);
	box-shadow: var(--sh-soft);
}
body.page-services .solution-band::after{
	content: "";
	position: absolute;
	right: -60px;
	top: -60px;
	width: 220px;
	height: 220px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(42,197,88,0.12) 0%, transparent 72%);
	pointer-events: none;
}
body.page-services .solution-cards{
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: var(--sp-5);
}
body.page-services .solution-cards--three{
	grid-template-columns: repeat(3, minmax(0, 1fr));
}
body.page-services .solution-cards--four{
	grid-template-columns: repeat(4, minmax(0, 1fr));
}
body.page-services .service-card{
	padding: 26px;
	border-radius: 24px;
	position: relative;
	transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
body.page-services .solution-band--dark .service-card{
	background: rgba(255,255,255,0.08);
	border: 1px solid rgba(255,255,255,0.1);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}
body.page-services .solution-band--light .service-card{
	background: rgba(255,255,255,0.82);
	border: 1px solid rgba(7,31,69,0.08);
}
body.page-services .service-card:hover{
	transform: translateY(-4px);
}
body.page-services .solution-band--dark .service-card:hover{
	box-shadow: 0 22px 34px rgba(0,0,0,0.18);
	border-color: rgba(126,234,160,0.24);
}
body.page-services .solution-band--light .service-card:hover{
	box-shadow: var(--sh-md);
	border-color: rgba(42,197,88,0.18);
}
body.page-services .service-icon{
	width: 64px;
	height: 64px;
	border-radius: 18px;
	display: grid;
	place-items: center;
	margin-bottom: var(--sp-5);
}
body.page-services .service-icon svg{
	width: 28px;
	height: 28px;
}
body.page-services .solution-band--dark .service-icon{
	background: linear-gradient(180deg, rgba(42,197,88,0.18) 0%, rgba(255,255,255,0.08) 100%);
}
body.page-services .solution-band--light .service-icon{
	background: linear-gradient(180deg, rgba(42,197,88,0.16) 0%, rgba(42,74,128,0.08) 100%);
}
body.page-services .service-card h4{
	font-size: 1.2rem;
	color: inherit;
}
body.page-services .service-card p{
	margin-top: var(--sp-4);
	color: inherit;
	opacity: 0.82;
}
body.page-services .cta{
	position: relative;
	padding: var(--sp-20) var(--sp-10);
	overflow: hidden;
	isolation: isolate;
	color: var(--white);
}
body.page-services .cta::before{
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(120% 80% at 85% 0%, rgba(42,197,88,0.32) 0%, transparent 55%),
		radial-gradient(120% 80% at 0% 100%, rgba(42,74,128,0.55) 0%, transparent 60%),
		linear-gradient(155deg, var(--navy) 0%, #0B2856 60%, var(--navy-mid) 100%);
	z-index: -2;
}
body.page-services .cta::after{
	content: '';
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.03) 0 1px, transparent 1px 14px);
	z-index: -1;
}
body.page-services .cta-inner{
	max-width: 1280px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sp-8);
	flex-wrap: wrap;
}
body.page-services .cta-copy{
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
	flex: 1 1 auto;
	min-width: 280px;
}
body.page-services .cta-title{
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	line-height: 1.15;
	font-weight: 700;
	color: var(--white);
	margin: 0;
	letter-spacing: -0.02em;
}
body.page-services .cta-desc{
	font-size: 0.9375rem;
	line-height: 1.55;
	color: rgba(255,255,255,0.75);
	margin: 0;
}
body.page-services .cta-actions{ flex-shrink: 0; }
body.page-services .footer{
	background: var(--navy);
	color: rgba(255,255,255,0.72);
	padding: var(--sp-24) var(--sp-10) var(--sp-10);
}
body.page-services .footer-inner{
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: var(--sp-12);
	padding-bottom: var(--sp-12);
	border-bottom: 1px solid rgba(255,255,255,0.1);
}
body.page-services .footer-brand{ max-width: 320px; }
body.page-services .footer-logo{
	display: flex;
	align-items: center;
	gap: 10px;
	font-family: var(--font-display);
	font-weight: 800;
	color: var(--white);
	font-size: 1.375rem;
	margin-bottom: var(--sp-4);
}
body.page-services .footer-tagline{ color: var(--white); font-weight: 500; margin-bottom: var(--sp-3); }
body.page-services .footer-arn{
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.6);
	margin-bottom: var(--sp-5);
}
body.page-services .footer-col h4{
	color: var(--white);
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin-bottom: var(--sp-5);
}
body.page-services .footer-col-body{
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
}
body.page-services .footer-link{
	color: rgba(255,255,255,0.72);
	font-size: 0.9375rem;
	transition: color var(--dur) var(--ease);
}
body.page-services .footer-link:hover{ color: var(--green-light); }
body.page-services .footer-social{ display: flex; gap: var(--sp-3); }
body.page-services .footer-social a{
	display: grid;
	place-items: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(255,255,255,0.06);
	color: rgba(255,255,255,0.72);
	transition: all var(--dur) var(--ease);
}
body.page-services .footer-social a:hover{
	background: var(--green);
	color: var(--navy);
	transform: translateY(-2px);
}
body.page-services .footer-bottom{
	max-width: 1280px;
	margin: 0 auto;
	padding-top: var(--sp-6);
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--sp-4);
	color: rgba(255,255,255,0.55);
	font-size: 0.8125rem;
}
body.page-services .footer-bottom-links{
	display: flex;
	gap: var(--sp-6);
}
body.page-services .footer-bottom-links a{ transition: color var(--dur) var(--ease); }
body.page-services .footer-bottom-links a:hover{ color: var(--green-light); }
@media (max-width: 1100px){
	body.page-services .page-hero-grid, body.page-services .section-head, body.page-services .footer-inner{
		grid-template-columns: 1fr;
	}
	body.page-services .blueprint-grid, body.page-services .solution-cards{
		grid-template-columns: 1fr;
	}
}
@media (max-width: 960px){
	body.page-services .container, body.page-services .footer{
		padding-left: var(--sp-5);
		padding-right: var(--sp-5);
	}
	body.page-services .nav-links{
		gap: var(--sp-5);
	}
	body.page-services .nav-login-menu{
		width: min(360px, calc(100vw - 40px));
		right: -10px;
	}
}
@media (max-width: 760px){
	body.page-services .navbar{
		padding: 18px 20px;
	}
	body.page-services .nav-links{
		gap: 14px;
	}
	body.page-services .nav-link{
		font-size: 0.875rem;
	}
	body.page-services .nav-logo img{
		height: 48px;
	}
	body.page-services .page-hero{
		padding-top: 150px;
		padding-bottom: 84px;
	}
	body.page-services .section-head-main{
		align-items: flex-start;
	}
	body.page-services .hero-stat-panel, body.page-services .blueprint-card, body.page-services .solution-band{
		padding: 24px;
	}
	body.page-services .cta{ padding: var(--sp-16) var(--sp-5); }
	body.page-services .cta-inner{ flex-direction: column; text-align: center; align-items: center; }
}
@media (max-width: 620px){
	body.page-services .navbar{
		align-items: flex-start;
	}
	body.page-services .nav-links{
		flex-wrap: wrap;
		justify-content: flex-end;
		row-gap: 10px;
	}
	body.page-services .nav-login{
		width: 100%;
		display: flex;
		justify-content: flex-end;
	}
}


/* /careers */
body.page-careers *, body.page-careers *::before, body.page-careers *::after{ box-sizing: border-box; }
body.page-careers, body.page-careers{ margin: 0; padding: 0; }
body.page-careers{
	font-family: var(--font-body);
	color: var(--gray-dark);
	background: var(--off-white);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	overflow-x: clip;
}
body.page-careers a{ color: inherit; text-decoration: none; }
body.page-careers img, body.page-careers svg{ display: block; max-width: 100%; }
body.page-careers h1, body.page-careers h2, body.page-careers h3, body.page-careers h4, body.page-careers h5, body.page-careers p{ margin: 0; }
body.page-careers h1, body.page-careers h2, body.page-careers h3, body.page-careers h4{
	font-family: var(--font-display);
	color: var(--navy);
	letter-spacing: -0.02em;
	line-height: 1.08;
}
body.page-careers .container{
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 var(--sp-10);
}
body.page-careers .eyebrow{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--green-dark);
}
body.page-careers .eyebrow::before{
	content: "";
	width: 28px;
	height: 2px;
	background: var(--green);
	border-radius: 99px;
}
body.page-careers .eyebrow--light{ color: var(--green-light); }
body.page-careers .le-btn{
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 54px;
	padding: 0 30px;
	border-radius: var(--r-md);
	font-size: 0.9375rem;
	font-weight: 600;
	border: 1px solid transparent;
	cursor: pointer;
	overflow: hidden;
	white-space: nowrap;
	transition: background-color var(--dur) var(--ease),
		color var(--dur) var(--ease),
		border-color var(--dur) var(--ease),
		box-shadow var(--dur) var(--ease),
		transform var(--dur) var(--ease);
}
body.page-careers .le-btn .lbl{
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
body.page-careers .le-btn .arr{
	position: absolute;
	left: 50%;
	top: 50%;
	opacity: 0;
	transform: translate(-50%, -50%) translateX(-40px);
	transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
body.page-careers .le-btn:hover .lbl{ opacity: 0; transform: translateX(30px); }
body.page-careers .le-btn:hover .arr{ opacity: 1; transform: translate(-50%, -50%) translateX(0); }
body.page-careers .le-btn--primary{
	background: var(--green);
	color: var(--navy);
	box-shadow: var(--sh-green);
}
body.page-careers .le-btn--primary:hover{
	background: var(--green-dark);
	color: var(--white);
	transform: translateY(-2px);
}
body.page-careers .le-btn--secondary{
	background: transparent;
	color: var(--navy);
	border-color: rgba(7,31,69,0.2);
}
body.page-careers .le-btn--secondary:hover{
	background: var(--navy);
	border-color: var(--navy);
	color: var(--white);
	transform: translateY(-2px);
}
body.page-careers .le-btn--lg{ height: 60px; padding: 0 36px; font-size: 1rem; }
body.page-careers .navbar{
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--sp-5) var(--sp-10);
	transition: background-color var(--dur) var(--ease),
		backdrop-filter var(--dur) var(--ease),
		box-shadow var(--dur) var(--ease);
}
body.page-careers .navbar.is-transparent{ background: transparent; }
body.page-careers .navbar.is-solid{
	background: rgba(255,255,255,0.92);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-shadow: 0 1px 0 rgba(7,31,69,0.06);
}
body.page-careers .nav-logo{ display: flex; align-items: center; }
body.page-careers .nav-logo img{ height: 56px; width: auto; }
body.page-careers .nav-logo-light{ display: none; }
body.page-careers .is-transparent .nav-logo-dark{ display: none; }
body.page-careers .is-transparent .nav-logo-light{ display: block; }
body.page-careers .is-solid .nav-logo-dark{ display: block; }
body.page-careers .is-solid .nav-logo-light{ display: none; }
body.page-careers .nav-links{ display: flex; align-items: center; gap: var(--sp-8); }
body.page-careers .nav-link{
	position: relative;
	font-size: 0.9375rem;
	font-weight: 500;
	transition: color var(--dur) var(--ease);
}
body.page-careers .is-transparent .nav-link{ color: var(--white); }
body.page-careers .is-solid .nav-link{ color: var(--navy); }
body.page-careers .nav-link::after{
	content: "";
	position: absolute;
	left: 0;
	bottom: -10px;
	width: 100%;
	height: 2px;
	border-radius: 99px;
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform var(--dur) var(--ease);
}
body.page-careers .is-transparent .nav-link::after{ background: var(--green-light); }
body.page-careers .is-solid .nav-link::after{ background: var(--green); }
body.page-careers .nav-link:hover, body.page-careers .nav-link.is-active{ color: var(--green); }
body.page-careers .nav-link:hover::after, body.page-careers .nav-link.is-active::after{ transform: scaleX(1); }
body.page-careers .nav-login{
	position: relative;
	padding-bottom: 18px;
	margin-bottom: -18px;
}
body.page-careers .nav-login::after{
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	height: 24px;
}
body.page-careers .nav-login-toggle{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	height: 52px;
	padding: 0 24px 0 26px;
	border-radius: 16px;
	font-size: 0.875rem;
	font-weight: 600;
	background: transparent;
	border: 1px solid;
	cursor: pointer;
	transition: color var(--dur) var(--ease),
		border-color var(--dur) var(--ease),
		background-color var(--dur) var(--ease),
		box-shadow var(--dur) var(--ease);
}
body.page-careers .nav-login-toggle svg{
	width: 16px;
	height: 16px;
	transition: transform var(--dur) var(--ease);
}
body.page-careers .nav-login.is-open .nav-login-toggle svg{ transform: rotate(180deg); }
body.page-careers .is-transparent .nav-login-toggle{
	color: var(--white);
	border-color: rgba(255,255,255,0.22);
	background: linear-gradient(180deg, rgba(255,255,255,0.14) 0%, rgba(255,255,255,0.06) 100%);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}
body.page-careers .is-solid .nav-login-toggle{
	color: var(--navy);
	border-color: rgba(7,31,69,0.12);
	background: linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(244,247,250,0.98) 100%);
	box-shadow: 0 8px 24px rgba(7,31,69,0.05);
}
body.page-careers .nav-login-menu{
	position: absolute;
	top: calc(100% + 6px);
	right: 0;
	width: 320px;
	padding: 12px;
	border-radius: 22px;
	background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(246,248,251,0.99) 100%);
	border: 1px solid rgba(7,31,69,0.09);
	box-shadow: 0 28px 70px rgba(7,31,69,0.18);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	opacity: 0;
	transform: translateY(10px);
	visibility: hidden;
	pointer-events: none;
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear var(--dur);
}
body.page-careers .nav-login-menu::before{
	content: "";
	position: absolute;
	top: -9px;
	right: 34px;
	width: 18px;
	height: 18px;
	background: rgba(255,255,255,0.98);
	border-top: 1px solid rgba(7,31,69,0.1);
	border-left: 1px solid rgba(7,31,69,0.1);
	transform: rotate(45deg);
}
body.page-careers .nav-login.is-open .nav-login-menu{
	opacity: 1;
	transform: translateY(0);
	visibility: visible;
	pointer-events: auto;
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear 0s;
}
body.page-careers .portal-link{
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px 15px;
	border-radius: 18px;
	color: var(--navy);
	background: linear-gradient(180deg, rgba(255,255,255,0.95) 0%, rgba(249,250,252,1) 100%);
	border: 1px solid rgba(7,31,69,0.06);
	transition: background-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
body.page-careers .portal-link + .portal-link{ margin-top: 8px; }
body.page-careers .portal-link:hover{
	background: linear-gradient(135deg, rgba(42,197,88,0.12) 0%, rgba(255,255,255,1) 100%);
	transform: translateY(-2px);
	box-shadow: 0 12px 24px rgba(7,31,69,0.08);
}
body.page-careers .portal-icon{
	width: 46px;
	height: 46px;
	border-radius: 14px;
	display: grid;
	place-items: center;
	background: linear-gradient(180deg, rgba(42,197,88,0.16) 0%, rgba(42,197,88,0.08) 100%);
	border: 1px solid rgba(42,197,88,0.18);
}
body.page-careers .portal-copy{ flex: 1; }
body.page-careers .portal-title{
	font-family: var(--font-display);
	font-size: 1.02rem;
	font-weight: 700;
}
body.page-careers .portal-arrow{ opacity: 0.72; }
body.page-careers .page-top{
	padding: 132px 0 28px;
	background:
		radial-gradient(90% 120% at 82% 0%, rgba(42,197,88,0.18) 0%, transparent 44%),
		radial-gradient(100% 100% at 0% 100%, rgba(42,74,128,0.38) 0%, transparent 58%),
		linear-gradient(150deg, #071F45 0%, #0D2A56 58%, #123E65 100%);
	border-bottom: 1px solid rgba(255,255,255,0.08);
}
body.page-careers .page-top-inner{
	display: flex;
	flex-direction: column;
	gap: 10px;
}
body.page-careers .breadcrumb{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.62);
}
body.page-careers .breadcrumb a{
	color: inherit;
	transition: color var(--dur) var(--ease);
}
body.page-careers .breadcrumb a:hover{
	color: var(--green-light);
}
body.page-careers .breadcrumb .current{
	color: var(--green-light);
}
body.page-careers .page-heading{
	font-size: clamp(1.9rem, 3.2vw, 2.7rem);
	color: var(--white);
}
body.page-careers .career-intro{
	padding-top: 34px;
}
body.page-careers .career-layout{
	display: grid;
	grid-template-columns: minmax(0, 1fr) 350px;
	gap: 36px;
	align-items: start;
}
body.page-careers .career-stack{
	display: grid;
	gap: 22px;
}
body.page-careers .career-block{
	padding: 30px;
	border-radius: 28px;
	background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(247,248,250,1) 100%);
	border: 1px solid rgba(7,31,69,0.08);
	box-shadow: var(--sh-soft);
	position: relative;
	overflow: hidden;
}
body.page-careers .career-block-head{
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 18px;
}
body.page-careers .career-block-icon{
	width: 58px;
	height: 58px;
	margin-bottom: 0;
	border-radius: 18px;
	display: grid;
	place-items: center;
	background: linear-gradient(180deg, rgba(42,197,88,0.16) 0%, rgba(42,74,128,0.08) 100%);
	color: var(--navy);
	border: 1px solid rgba(42,197,88,0.16);
}
body.page-careers .career-block-icon svg{
	width: 28px;
	height: 28px;
}
body.page-careers .career-block::before{
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 3px;
	background: linear-gradient(90deg, rgba(42,197,88,0.85) 0%, rgba(42,74,128,0.22) 100%);
}
body.page-careers .career-block p{
	color: var(--gray-dark);
	font-size: 1rem;
}
body.page-careers .career-block-title{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 0;
	font-family: var(--font-display);
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--navy);
	letter-spacing: -0.01em;
}
body.page-careers .career-block-title::before{
	content: "";
	width: 18px;
	height: 2px;
	border-radius: 99px;
	background: var(--green);
}
body.page-careers .bullet-list{
	margin: 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 15px;
}
body.page-careers .bullet-list li{
	display: flex;
	align-items: flex-start;
	gap: 14px;
	color: var(--gray-dark);
	font-size: 0.995rem;
}
body.page-careers .bullet-list li::before{
	content: "";
	flex-shrink: 0;
	width: 12px;
	height: 12px;
	margin-top: 7px;
	border-radius: 50%;
	background: var(--green);
	box-shadow: 0 0 0 6px rgba(42,197,88,0.12);
}
body.page-careers .opportunity-panel{
	position: sticky;
	top: 96px;
	padding: 34px 30px;
	min-height: calc(100vh - 128px);
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	border-radius: 30px;
	background:
		radial-gradient(110% 120% at 100% 0%, rgba(42,197,88,0.22) 0%, transparent 46%),
		radial-gradient(120% 100% at 0% 100%, rgba(42,74,128,0.3) 0%, transparent 58%),
		linear-gradient(165deg, #071F45 0%, #0F2F5E 68%, #155067 100%);
	border: 1px solid rgba(255,255,255,0.08);
	box-shadow: 0 28px 60px rgba(7,31,69,0.18);
}
body.page-careers .opportunity-panel h3{
	font-size: clamp(1.6rem, 3vw, 2.2rem);
	line-height: 1.1;
	color: var(--white);
}
body.page-careers .opportunity-status{
	margin-top: 10px;
	font-family: var(--font-display);
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--green-light);
}
body.page-careers .opportunity-panel p{
	margin-top: 14px;
	color: rgba(255,255,255,0.76);
}
body.page-careers .section{
	padding: var(--sp-24) 0;
}
body.page-careers .section-alt{
	background:
		radial-gradient(80% 100% at 100% 0%, rgba(42,197,88,0.08) 0%, transparent 48%),
		var(--white);
}
body.page-careers .section-head{
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
	gap: var(--sp-10);
	align-items: end;
	margin-bottom: var(--sp-12);
}
body.page-careers .section-title{
	margin-top: var(--sp-4);
	font-size: clamp(2rem, 4vw, 3.35rem);
}
body.page-careers .section-title em{
	font-style: italic;
	font-weight: 400;
	color: var(--navy-light);
}
body.page-careers .section-copy{
	font-size: 1rem;
	color: var(--gray-dark);
}
body.page-careers .culture-grid, body.page-careers .fit-grid, body.page-careers .benefits-grid{
	display: grid;
	gap: var(--sp-6);
}
body.page-careers .culture-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
body.page-careers .fit-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
body.page-careers .benefits-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
body.page-careers .career-card{
	padding: 30px;
	border-radius: 28px;
	background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(247,248,250,1) 100%);
	border: 1px solid rgba(7,31,69,0.08);
	box-shadow: var(--sh-soft);
	transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
body.page-careers .career-card:hover{
	transform: translateY(-4px);
	box-shadow: var(--sh-md);
	border-color: rgba(42,197,88,0.18);
}
body.page-careers .career-card--dark{
	background:
		radial-gradient(80% 120% at 100% 0%, rgba(42,197,88,0.16) 0%, transparent 48%),
		linear-gradient(145deg, #071F45 0%, #12305E 100%);
	border-color: rgba(255,255,255,0.08);
	color: var(--white);
}
body.page-careers .career-card--dark h3, body.page-careers .career-card--dark p{ color: inherit; }
body.page-careers .career-icon{
	width: 64px;
	height: 64px;
	border-radius: 18px;
	display: grid;
	place-items: center;
	margin-bottom: var(--sp-5);
}
body.page-careers .career-card .career-icon{
	background: linear-gradient(180deg, rgba(42,197,88,0.16) 0%, rgba(42,74,128,0.08) 100%);
	color: var(--navy);
}
body.page-careers .career-card--dark .career-icon{
	background: linear-gradient(180deg, rgba(42,197,88,0.18) 0%, rgba(255,255,255,0.08) 100%);
	color: var(--green-light);
}
body.page-careers .career-icon svg{
	width: 28px;
	height: 28px;
}
body.page-careers .career-card h3{
	font-size: 1.28rem;
	margin-bottom: var(--sp-4);
}
body.page-careers .career-card p{
	color: var(--gray-dark);
}
body.page-careers .openings-panel{
	padding: 36px;
	border-radius: 32px;
	background:
		radial-gradient(90% 120% at 100% 0%, rgba(42,197,88,0.14) 0%, transparent 50%),
		linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(243,247,251,1) 100%);
	border: 1px solid rgba(7,31,69,0.08);
	box-shadow: var(--sh-soft);
}
body.page-careers .opening-badge{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 16px;
	border-radius: var(--r-pill);
	font-size: 0.76rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--green-dark);
	background: rgba(42,197,88,0.12);
	border: 1px solid rgba(42,197,88,0.18);
}
body.page-careers .openings-panel h3{
	margin-top: var(--sp-5);
	font-size: clamp(1.8rem, 3vw, 2.6rem);
}
body.page-careers .openings-panel p{
	margin-top: var(--sp-4);
	max-width: 760px;
}
body.page-careers .cta{
	position: relative;
	padding: var(--sp-20) var(--sp-10);
	overflow: hidden;
	isolation: isolate;
	color: var(--white);
}
body.page-careers .cta::before{
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(120% 80% at 85% 0%, rgba(42,197,88,0.32) 0%, transparent 55%),
		radial-gradient(120% 80% at 0% 100%, rgba(42,74,128,0.55) 0%, transparent 60%),
		linear-gradient(155deg, var(--navy) 0%, #0B2856 60%, var(--navy-mid) 100%);
	z-index: -2;
}
body.page-careers .cta::after{
	content: '';
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.03) 0 1px, transparent 1px 14px);
	z-index: -1;
}
body.page-careers .cta-inner{
	max-width: 1280px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sp-8);
	flex-wrap: wrap;
}
body.page-careers .cta-copy{
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
	flex: 1 1 auto;
	min-width: 280px;
}
body.page-careers .cta-title{
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	line-height: 1.15;
	font-weight: 700;
	color: var(--white);
	margin: 0;
	letter-spacing: -0.02em;
}
body.page-careers .cta-desc{
	font-size: 0.9375rem;
	line-height: 1.55;
	color: rgba(255,255,255,0.75);
	margin: 0;
}
body.page-careers .cta-actions{ flex-shrink: 0; }
body.page-careers .footer{
	background: var(--navy);
	color: rgba(255,255,255,0.72);
	padding: var(--sp-24) var(--sp-10) var(--sp-10);
}
body.page-careers .footer-inner{
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: var(--sp-12);
	padding-bottom: var(--sp-12);
	border-bottom: 1px solid rgba(255,255,255,0.1);
}
body.page-careers .footer-brand{ max-width: 320px; }
body.page-careers .footer-logo{
	display: flex;
	align-items: center;
	gap: 10px;
	font-family: var(--font-display);
	font-weight: 800;
	color: var(--white);
	font-size: 1.375rem;
	margin-bottom: var(--sp-4);
}
body.page-careers .footer-tagline{ color: var(--white); font-weight: 500; margin-bottom: var(--sp-3); }
body.page-careers .footer-arn{
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.6);
	margin-bottom: var(--sp-5);
}
body.page-careers .footer-col h4{
	color: var(--white);
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin-bottom: var(--sp-5);
}
body.page-careers .footer-col-body{
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
}
body.page-careers .footer-link{
	color: rgba(255,255,255,0.72);
	font-size: 0.9375rem;
	transition: color var(--dur) var(--ease);
}
body.page-careers .footer-link:hover{ color: var(--green-light); }
body.page-careers .footer-social{ display: flex; gap: var(--sp-3); }
body.page-careers .footer-social a{
	display: grid;
	place-items: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(255,255,255,0.06);
	color: rgba(255,255,255,0.72);
	transition: all var(--dur) var(--ease);
}
body.page-careers .footer-social a:hover{
	background: var(--green);
	color: var(--navy);
	transform: translateY(-2px);
}
body.page-careers .footer-bottom{
	max-width: 1280px;
	margin: 0 auto;
	padding-top: var(--sp-6);
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--sp-4);
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.55);
}
body.page-careers .footer-bottom-links{ display: flex; gap: var(--sp-6); }
body.page-careers .footer-bottom-links a{ transition: color var(--dur) var(--ease); }
body.page-careers .footer-bottom-links a:hover{ color: var(--green-light); }
@media (max-width: 1100px){
	body.page-careers .section-head, body.page-careers .footer-inner, body.page-careers .career-layout{
		grid-template-columns: 1fr;
	}
	body.page-careers .culture-grid, body.page-careers .fit-grid, body.page-careers .benefits-grid{
		grid-template-columns: 1fr;
	}
	body.page-careers .opportunity-panel{
		position: relative;
		top: auto;
		min-height: auto;
	}
}
@media (max-width: 960px){
	body.page-careers .container, body.page-careers .footer{
		padding-left: var(--sp-5);
		padding-right: var(--sp-5);
	}
	body.page-careers .nav-links{ gap: var(--sp-5); }
	body.page-careers .nav-login-menu{
		width: min(360px, calc(100vw - 40px));
		right: -10px;
	}
}
@media (max-width: 760px){
	body.page-careers .navbar{ padding: 18px 20px; }
	body.page-careers .nav-links{ gap: 14px; }
	body.page-careers .nav-link{ font-size: 0.875rem; }
	body.page-careers .nav-logo img{ height: 48px; }
	body.page-careers .page-top{ padding-top: 120px; padding-bottom: 22px; }
	body.page-careers .opportunity-panel{ order: 1; }
	body.page-careers .career-stack{ order: 2; }
	body.page-careers .cta{ padding: var(--sp-16) var(--sp-5); }
	body.page-careers .cta-inner{ flex-direction: column; text-align: center; align-items: center; }
	body.page-careers .career-block, body.page-careers .opportunity-panel{ padding: 24px; }
}
@media (max-width: 620px){
	body.page-careers .navbar{ align-items: flex-start; }
	body.page-careers .nav-links{
		flex-wrap: wrap;
		justify-content: flex-end;
		row-gap: 10px;
	}
	body.page-careers .nav-login{
		width: 100%;
		display: flex;
		justify-content: flex-end;
	}
}


/* /contact */
body.page-contact *, body.page-contact *::before, body.page-contact *::after{ box-sizing: border-box; }
body.page-contact, body.page-contact{ margin: 0; padding: 0; }
body.page-contact{
	font-family: var(--font-body);
	color: var(--gray-dark);
	background: var(--off-white);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	overflow-x: clip;
}
body.page-contact a{ color: inherit; text-decoration: none; }
body.page-contact img, body.page-contact svg{ display: block; max-width: 100%; }
body.page-contact h1, body.page-contact h2, body.page-contact h3, body.page-contact h4, body.page-contact h5, body.page-contact p{ margin: 0; }
body.page-contact h1, body.page-contact h2, body.page-contact h3, body.page-contact h4{
	font-family: var(--font-display);
	color: var(--navy);
	letter-spacing: -0.02em;
	line-height: 1.08;
}
body.page-contact .container{
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 var(--sp-10);
}
body.page-contact .le-btn{
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 54px;
	padding: 0 30px;
	border-radius: var(--r-md);
	font-size: 0.9375rem;
	font-weight: 600;
	border: 1px solid transparent;
	cursor: pointer;
	overflow: hidden;
	white-space: nowrap;
	transition: background-color var(--dur) var(--ease),
		color var(--dur) var(--ease),
		border-color var(--dur) var(--ease),
		box-shadow var(--dur) var(--ease),
		transform var(--dur) var(--ease);
}
body.page-contact .le-btn .lbl{
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
body.page-contact .le-btn .arr{
	position: absolute;
	left: 50%;
	top: 50%;
	opacity: 0;
	transform: translate(-50%, -50%) translateX(-40px);
	transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
body.page-contact .le-btn:hover .lbl{ opacity: 0; transform: translateX(30px); }
body.page-contact .le-btn:hover .arr{ opacity: 1; transform: translate(-50%, -50%) translateX(0); }
body.page-contact .le-btn--primary{
	background: var(--green);
	color: var(--navy);
	box-shadow: var(--sh-green);
}
body.page-contact .le-btn--primary:hover{
	background: var(--green-dark);
	color: var(--white);
	transform: translateY(-2px);
}
body.page-contact .navbar{
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--sp-5) var(--sp-10);
	transition: background-color var(--dur) var(--ease),
		backdrop-filter var(--dur) var(--ease),
		box-shadow var(--dur) var(--ease);
}
body.page-contact .navbar.is-transparent{ background: transparent; }
body.page-contact .navbar.is-solid{
	background: rgba(255,255,255,0.92);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-shadow: 0 1px 0 rgba(7,31,69,0.06);
}
body.page-contact .nav-logo{ display: flex; align-items: center; }
body.page-contact .nav-logo img{ height: 56px; width: auto; }
body.page-contact .nav-logo-light{ display: none; }
body.page-contact .is-transparent .nav-logo-dark{ display: none; }
body.page-contact .is-transparent .nav-logo-light{ display: block; }
body.page-contact .is-solid .nav-logo-dark{ display: block; }
body.page-contact .is-solid .nav-logo-light{ display: none; }
body.page-contact .nav-links{ display: flex; align-items: center; gap: var(--sp-8); }
body.page-contact .nav-link{
	position: relative;
	font-size: 0.9375rem;
	font-weight: 500;
	transition: color var(--dur) var(--ease);
}
body.page-contact .is-transparent .nav-link{ color: var(--white); }
body.page-contact .is-solid .nav-link{ color: var(--navy); }
body.page-contact .nav-link::after{
	content: "";
	position: absolute;
	left: 0;
	bottom: -10px;
	width: 100%;
	height: 2px;
	border-radius: 99px;
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform var(--dur) var(--ease);
}
body.page-contact .is-transparent .nav-link::after{ background: var(--green-light); }
body.page-contact .is-solid .nav-link::after{ background: var(--green); }
body.page-contact .nav-link:hover, body.page-contact .nav-link.is-active{ color: var(--green); }
body.page-contact .nav-link:hover::after, body.page-contact .nav-link.is-active::after{ transform: scaleX(1); }
body.page-contact .nav-login{
	position: relative;
	padding-bottom: 18px;
	margin-bottom: -18px;
}
body.page-contact .nav-login::after{
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	height: 24px;
}
body.page-contact .nav-login-toggle{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	height: 52px;
	padding: 0 24px 0 26px;
	border-radius: 16px;
	font-size: 0.875rem;
	font-weight: 600;
	background: transparent;
	border: 1px solid;
	cursor: pointer;
	transition: color var(--dur) var(--ease),
		border-color var(--dur) var(--ease),
		background-color var(--dur) var(--ease),
		box-shadow var(--dur) var(--ease);
}
body.page-contact .nav-login-toggle svg{
	width: 16px;
	height: 16px;
	transition: transform var(--dur) var(--ease);
}
body.page-contact .nav-login.is-open .nav-login-toggle svg{ transform: rotate(180deg); }
body.page-contact .is-transparent .nav-login-toggle{
	color: var(--white);
	border-color: rgba(255,255,255,0.22);
	background: linear-gradient(180deg, rgba(255,255,255,0.14) 0%, rgba(255,255,255,0.06) 100%);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}
body.page-contact .is-solid .nav-login-toggle{
	color: var(--navy);
	border-color: rgba(7,31,69,0.12);
	background: linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(244,247,250,0.98) 100%);
	box-shadow: 0 8px 24px rgba(7,31,69,0.05);
}
body.page-contact .nav-login-menu{
	position: absolute;
	top: calc(100% + 6px);
	right: 0;
	width: 320px;
	padding: 12px;
	border-radius: 22px;
	background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(246,248,251,0.99) 100%);
	border: 1px solid rgba(7,31,69,0.09);
	box-shadow: 0 28px 70px rgba(7,31,69,0.18);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	opacity: 0;
	transform: translateY(10px);
	visibility: hidden;
	pointer-events: none;
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear var(--dur);
}
body.page-contact .nav-login-menu::before{
	content: "";
	position: absolute;
	top: -9px;
	right: 34px;
	width: 18px;
	height: 18px;
	background: rgba(255,255,255,0.98);
	border-top: 1px solid rgba(7,31,69,0.1);
	border-left: 1px solid rgba(7,31,69,0.1);
	transform: rotate(45deg);
}
body.page-contact .nav-login.is-open .nav-login-menu{
	opacity: 1;
	transform: translateY(0);
	visibility: visible;
	pointer-events: auto;
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear 0s;
}
body.page-contact .portal-link{
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px 15px;
	border-radius: 18px;
	color: var(--navy);
	background: linear-gradient(180deg, rgba(255,255,255,0.95) 0%, rgba(249,250,252,1) 100%);
	border: 1px solid rgba(7,31,69,0.06);
	transition: background-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
body.page-contact .portal-link + .portal-link{ margin-top: 8px; }
body.page-contact .portal-link:hover{
	background: linear-gradient(135deg, rgba(42,197,88,0.12) 0%, rgba(255,255,255,1) 100%);
	transform: translateY(-2px);
	box-shadow: 0 12px 24px rgba(7,31,69,0.08);
}
body.page-contact .portal-icon{
	width: 46px;
	height: 46px;
	border-radius: 14px;
	display: grid;
	place-items: center;
	background: linear-gradient(180deg, rgba(42,197,88,0.16) 0%, rgba(42,197,88,0.08) 100%);
	border: 1px solid rgba(42,197,88,0.18);
}
body.page-contact .portal-copy{ flex: 1; }
body.page-contact .portal-title{
	font-family: var(--font-display);
	font-size: 1.02rem;
	font-weight: 700;
}
body.page-contact .portal-arrow{ opacity: 0.72; }
body.page-contact .page-top{
	padding: 132px 0 28px;
	background:
		radial-gradient(90% 120% at 82% 0%, rgba(42,197,88,0.18) 0%, transparent 44%),
		radial-gradient(100% 100% at 0% 100%, rgba(42,74,128,0.38) 0%, transparent 58%),
		linear-gradient(150deg, #071F45 0%, #0D2A56 58%, #123E65 100%);
	border-bottom: 1px solid rgba(255,255,255,0.08);
}
body.page-contact .page-top-inner{
	display: flex;
	flex-direction: column;
	gap: 10px;
}
body.page-contact .breadcrumb{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.62);
}
body.page-contact .breadcrumb a{
	color: inherit;
	transition: color var(--dur) var(--ease);
}
body.page-contact .breadcrumb a:hover{ color: var(--green-light); }
body.page-contact .breadcrumb .current{ color: var(--green-light); }
body.page-contact .page-heading{
	font-size: clamp(1.9rem, 3.2vw, 2.7rem);
	color: var(--white);
}
body.page-contact .section{
	padding: 56px 0 var(--sp-24);
}
body.page-contact .contact-layout{
	display: grid;
	grid-template-columns: minmax(320px, 0.9fr) minmax(0, 1.1fr);
	gap: var(--sp-10);
	align-items: start;
}
body.page-contact .contact-panel{
	padding: 34px 32px;
	border-radius: 32px;
	background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(247,248,250,1) 100%);
	border: 1px solid rgba(7,31,69,0.08);
	box-shadow: var(--sh-soft);
	position: relative;
	overflow: hidden;
}
body.page-contact .contact-panel::before{
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 3px;
	background: linear-gradient(90deg, rgba(42,197,88,0.85) 0%, rgba(42,74,128,0.22) 100%);
}
body.page-contact .contact-panel h2{
	font-size: 1.7rem;
	margin-bottom: var(--sp-4);
	color: var(--navy);
}
body.page-contact .contact-panel p{
	color: var(--gray-dark);
}
body.page-contact .contact-stack{
	display: grid;
	gap: 14px;
	margin-top: var(--sp-8);
}
body.page-contact .contact-item{
	display: grid;
	grid-template-columns: 56px minmax(0, 1fr);
	gap: 16px;
	align-items: start;
	padding: 16px;
	border-radius: 22px;
	background: rgba(255,255,255,0.72);
	border: 1px solid rgba(7,31,69,0.06);
}
body.page-contact .contact-icon{
	width: 56px;
	height: 56px;
	border-radius: 16px;
	display: grid;
	place-items: center;
	background: linear-gradient(180deg, rgba(42,197,88,0.16) 0%, rgba(42,74,128,0.08) 100%);
	border: 1px solid rgba(42,197,88,0.16);
	color: var(--navy);
}
body.page-contact .contact-copy h3{
	font-size: 1.02rem;
	margin-bottom: 6px;
	color: var(--navy);
}
body.page-contact .contact-copy a, body.page-contact .contact-copy span{
	color: var(--gray-dark);
	font-size: 0.97rem;
}
body.page-contact .contact-copy a:hover{ color: var(--green-dark); }
body.page-contact .contact-form{
	padding: 38px 36px;
	border-radius: 32px;
	background:
		radial-gradient(90% 120% at 100% 0%, rgba(42,197,88,0.18) 0%, transparent 42%),
		radial-gradient(120% 100% at 0% 100%, rgba(42,74,128,0.34) 0%, transparent 58%),
		linear-gradient(165deg, #0A264F 0%, #123767 68%, #1B4F80 100%);
	border: 1px solid rgba(255,255,255,0.08);
	box-shadow: 0 28px 60px rgba(7,31,69,0.12);
	position: relative;
	overflow: hidden;
}
body.page-contact .contact-form::before{
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 4px;
	background: linear-gradient(90deg, rgba(42,197,88,0.8) 0%, rgba(42,74,128,0.18) 100%);
}
body.page-contact .contact-form h2{
	font-size: 1.85rem;
	margin-bottom: var(--sp-3);
	color: var(--white);
}
body.page-contact .contact-form p{
	color: rgba(255,255,255,0.78);
	margin-bottom: 30px;
	max-width: 460px;
}
body.page-contact .form-grid{
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
}
body.page-contact .field{
	display: flex;
	flex-direction: column;
	gap: 8px;
}
body.page-contact .field--full{
	grid-column: 1 / -1;
}
body.page-contact .field label{
	font-size: 0.88rem;
	font-weight: 600;
	color: rgba(255,255,255,0.84);
}
body.page-contact .field-required{
	color: var(--green-light);
	font-weight: 700;
}
body.page-contact .field input, body.page-contact .field textarea{
	width: 100%;
	border: 1px solid rgba(255,255,255,0.14);
	border-radius: 18px;
	padding: 16px 18px;
	font: inherit;
	color: var(--white);
	background: rgba(255,255,255,0.08);
	transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
body.page-contact .field input::placeholder, body.page-contact .field textarea::placeholder{
	color: rgba(255,255,255,0.5);
}
body.page-contact .field input:focus, body.page-contact .field textarea:focus{
	outline: none;
	border-color: rgba(126,234,160,0.78);
	box-shadow: 0 0 0 4px rgba(126,234,160,0.14);
}
body.page-contact .field button[disabled]{
	cursor: wait;
	opacity: 0.72;
	transform: none;
}
body.page-contact .field button[disabled] .lbl{
	opacity: 1;
	transform: none;
}
body.page-contact .field button[disabled] .arr{
	opacity: 0;
}
body.page-contact .field textarea{
	min-height: 168px;
	resize: vertical;
}
body.page-contact .field--hidden{
	position: absolute;
	left: -9999px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
}
body.page-contact .field input[aria-invalid="true"],
body.page-contact .field textarea[aria-invalid="true"]{
	border-color: rgba(255,125,125,0.78);
	box-shadow: 0 0 0 4px rgba(255,125,125,0.14);
}
body.page-contact .field-error{
	display: block;
	min-height: 1.2em;
	margin-top: 7px;
	font-size: 0.82rem;
	line-height: 1.25;
	color: rgba(255,186,186,0.96);
}
body.page-contact .form-status{
	margin-top: 16px;
	font-size: 0.95rem;
	font-weight: 500;
	color: rgba(126,234,160,0.92);
	min-height: 1.35em;
}
body.page-contact .form-status.is-error{
	color: rgba(255,186,186,0.96);
}
body.page-contact .footer{
	background: var(--navy);
	color: rgba(255,255,255,0.72);
	padding: var(--sp-24) var(--sp-10) var(--sp-10);
}
body.page-contact .footer-inner{
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: var(--sp-12);
	padding-bottom: var(--sp-12);
	border-bottom: 1px solid rgba(255,255,255,0.1);
}
body.page-contact .footer-brand{ max-width: 320px; }
body.page-contact .footer-logo{
	display: flex;
	align-items: center;
	gap: 10px;
	font-family: var(--font-display);
	font-weight: 800;
	color: var(--white);
	font-size: 1.375rem;
	margin-bottom: var(--sp-4);
}
body.page-contact .footer-tagline{ color: var(--white); font-weight: 500; margin-bottom: var(--sp-3); }
body.page-contact .footer-arn{
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.6);
	margin-bottom: var(--sp-5);
}
body.page-contact .footer-col h4{
	color: var(--white);
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin-bottom: var(--sp-5);
}
body.page-contact .footer-col-body{
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
}
body.page-contact .footer-link{
	color: rgba(255,255,255,0.72);
	font-size: 0.9375rem;
	transition: color var(--dur) var(--ease);
}
body.page-contact .footer-link:hover{ color: var(--green-light); }
body.page-contact .footer-social{ display: flex; gap: var(--sp-3); }
body.page-contact .footer-social a{
	display: grid;
	place-items: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(255,255,255,0.06);
	color: rgba(255,255,255,0.72);
	transition: all var(--dur) var(--ease);
}
body.page-contact .footer-social a:hover{
	background: var(--green);
	color: var(--navy);
	transform: translateY(-2px);
}
body.page-contact .footer-bottom{
	max-width: 1280px;
	margin: 0 auto;
	padding-top: var(--sp-6);
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--sp-4);
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.55);
}
body.page-contact .footer-bottom-links{ display: flex; gap: var(--sp-6); }
body.page-contact .footer-bottom-links a{ transition: color var(--dur) var(--ease); }
body.page-contact .footer-bottom-links a:hover{ color: var(--green-light); }
@media (max-width: 1100px){
	body.page-contact .contact-layout, body.page-contact .footer-inner{
		grid-template-columns: 1fr;
	}
}
@media (max-width: 960px){
	body.page-contact .container, body.page-contact .footer{
		padding-left: var(--sp-5);
		padding-right: var(--sp-5);
	}
	body.page-contact .nav-links{ gap: var(--sp-5); }
	body.page-contact .nav-login-menu{
		width: min(360px, calc(100vw - 40px));
		right: -10px;
	}
}
@media (max-width: 760px){
	body.page-contact .navbar{ padding: 18px 20px; }
	body.page-contact .nav-links{ gap: 14px; }
	body.page-contact .nav-link{ font-size: 0.875rem; }
	body.page-contact .nav-logo img{ height: 48px; }
	body.page-contact .page-top{ padding-top: 120px; padding-bottom: 22px; }
	body.page-contact .contact-form{ order: 1; }
	body.page-contact .contact-panel{ order: 2; }
	body.page-contact .form-grid{ grid-template-columns: 1fr; }
	body.page-contact .contact-panel, body.page-contact .contact-form{ padding: 24px; }
}
@media (max-width: 620px){
	body.page-contact .navbar{ align-items: flex-start; }
	body.page-contact .nav-links{
		flex-wrap: wrap;
		justify-content: flex-end;
		row-gap: 10px;
	}
	body.page-contact .nav-login{
		width: 100%;
		display: flex;
		justify-content: flex-end;
	}
}


/* /policies/disclosure */
body.page-policy.page-disclosure *, body.page-policy.page-disclosure *::before, body.page-policy.page-disclosure *::after{ box-sizing: border-box; }
body.page-policy.page-disclosure, body.page-policy.page-disclosure{ margin: 0; padding: 0; }
body.page-policy.page-disclosure{
	font-family: var(--font-body);
	color: var(--gray-dark);
	background: var(--off-white);
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
	overflow-x: clip;
}
body.page-policy.page-disclosure a{ color: inherit; text-decoration: none; }
body.page-policy.page-disclosure img, body.page-policy.page-disclosure svg{ display: block; max-width: 100%; }
body.page-policy.page-disclosure h1, body.page-policy.page-disclosure h2, body.page-policy.page-disclosure h3, body.page-policy.page-disclosure h4, body.page-policy.page-disclosure p{ margin: 0; }
body.page-policy.page-disclosure h1, body.page-policy.page-disclosure h2, body.page-policy.page-disclosure h3, body.page-policy.page-disclosure h4{
	font-family: var(--font-display);
	color: var(--navy);
	letter-spacing: -0.02em;
	line-height: 1.08;
}
body.page-policy.page-disclosure .container{
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 var(--sp-10);
}
body.page-policy.page-disclosure .navbar{
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--sp-5) var(--sp-10);
	transition: background-color var(--dur) var(--ease), backdrop-filter var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
body.page-policy.page-disclosure .navbar.is-transparent{ background: transparent; }
body.page-policy.page-disclosure .navbar.is-solid{
	background: rgba(255,255,255,0.92);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-shadow: 0 1px 0 rgba(7,31,69,0.06);
}
body.page-policy.page-disclosure .nav-logo{ display: flex; align-items: center; }
body.page-policy.page-disclosure .nav-logo img{ height: 56px; width: auto; }
body.page-policy.page-disclosure .nav-logo-light{ display: none; }
body.page-policy.page-disclosure .is-transparent .nav-logo-dark{ display: none; }
body.page-policy.page-disclosure .is-transparent .nav-logo-light{ display: block; }
body.page-policy.page-disclosure .is-solid .nav-logo-dark{ display: block; }
body.page-policy.page-disclosure .is-solid .nav-logo-light{ display: none; }
body.page-policy.page-disclosure .nav-links{ display: flex; align-items: center; gap: var(--sp-8); }
body.page-policy.page-disclosure .nav-link{
	position: relative;
	font-size: 0.9375rem;
	font-weight: 500;
	transition: color var(--dur) var(--ease);
}
body.page-policy.page-disclosure .is-transparent .nav-link{ color: var(--white); }
body.page-policy.page-disclosure .is-solid .nav-link{ color: var(--navy); }
body.page-policy.page-disclosure .nav-link::after{
	content: "";
	position: absolute;
	left: 0;
	bottom: -10px;
	width: 100%;
	height: 2px;
	border-radius: 99px;
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform var(--dur) var(--ease);
}
body.page-policy.page-disclosure .is-transparent .nav-link::after{ background: var(--green-light); }
body.page-policy.page-disclosure .is-solid .nav-link::after{ background: var(--green); }
body.page-policy.page-disclosure .nav-link:hover, body.page-policy.page-disclosure .nav-link.is-active{ color: var(--green); }
body.page-policy.page-disclosure .nav-link:hover::after, body.page-policy.page-disclosure .nav-link.is-active::after{ transform: scaleX(1); }
body.page-policy.page-disclosure .nav-login{
	position: relative;
	padding-bottom: 18px;
	margin-bottom: -18px;
}
body.page-policy.page-disclosure .nav-login::after{
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	height: 24px;
}
body.page-policy.page-disclosure .nav-login-toggle{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	height: 52px;
	padding: 0 24px 0 26px;
	border-radius: 16px;
	font-size: 0.875rem;
	font-weight: 600;
	background: transparent;
	border: 1px solid;
	cursor: pointer;
	transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease), background-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
body.page-policy.page-disclosure .nav-login-toggle svg{
	width: 16px;
	height: 16px;
	transition: transform var(--dur) var(--ease);
}
body.page-policy.page-disclosure .nav-login.is-open .nav-login-toggle svg{ transform: rotate(180deg); }
body.page-policy.page-disclosure .is-transparent .nav-login-toggle{
	color: var(--white);
	border-color: rgba(255,255,255,0.22);
	background: linear-gradient(180deg, rgba(255,255,255,0.14) 0%, rgba(255,255,255,0.06) 100%);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}
body.page-policy.page-disclosure .is-solid .nav-login-toggle{
	color: var(--navy);
	border-color: rgba(7,31,69,0.12);
	background: linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(244,247,250,0.98) 100%);
	box-shadow: 0 8px 24px rgba(7,31,69,0.05);
}
body.page-policy.page-disclosure .nav-login-menu{
	position: absolute;
	top: calc(100% + 6px);
	right: 0;
	width: 320px;
	padding: 12px;
	border-radius: 22px;
	background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(246,248,251,0.99) 100%);
	border: 1px solid rgba(7,31,69,0.09);
	box-shadow: 0 28px 70px rgba(7,31,69,0.18);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	opacity: 0;
	transform: translateY(10px);
	visibility: hidden;
	pointer-events: none;
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear var(--dur);
}
body.page-policy.page-disclosure .nav-login-menu::before{
	content: "";
	position: absolute;
	top: -9px;
	right: 34px;
	width: 18px;
	height: 18px;
	background: rgba(255,255,255,0.98);
	border-top: 1px solid rgba(7,31,69,0.1);
	border-left: 1px solid rgba(7,31,69,0.1);
	transform: rotate(45deg);
}
body.page-policy.page-disclosure .nav-login.is-open .nav-login-menu{
	opacity: 1;
	transform: translateY(0);
	visibility: visible;
	pointer-events: auto;
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear 0s;
}
body.page-policy.page-disclosure .portal-link{
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px 15px;
	border-radius: 18px;
	color: var(--navy);
	background: linear-gradient(180deg, rgba(255,255,255,0.95) 0%, rgba(249,250,252,1) 100%);
	border: 1px solid rgba(7,31,69,0.06);
	transition: background-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
body.page-policy.page-disclosure .portal-link + .portal-link{ margin-top: 8px; }
body.page-policy.page-disclosure .portal-link:hover{
	background: linear-gradient(135deg, rgba(42,197,88,0.12) 0%, rgba(255,255,255,1) 100%);
	transform: translateY(-2px);
	box-shadow: 0 12px 24px rgba(7,31,69,0.08);
}
body.page-policy.page-disclosure .portal-icon{
	width: 46px;
	height: 46px;
	border-radius: 14px;
	display: grid;
	place-items: center;
	background: linear-gradient(180deg, rgba(42,197,88,0.16) 0%, rgba(42,197,88,0.08) 100%);
	border: 1px solid rgba(42,197,88,0.18);
}
body.page-policy.page-disclosure .portal-copy{ flex: 1; }
body.page-policy.page-disclosure .portal-title{
	font-family: var(--font-display);
	font-size: 1.02rem;
	font-weight: 700;
}
body.page-policy.page-disclosure .portal-arrow{ opacity: 0.72; }
body.page-policy.page-disclosure .page-top{
	padding: 132px 0 28px;
	background:
		radial-gradient(90% 120% at 82% 0%, rgba(42,197,88,0.18) 0%, transparent 44%),
		radial-gradient(100% 100% at 0% 100%, rgba(42,74,128,0.38) 0%, transparent 58%),
		linear-gradient(150deg, #071F45 0%, #0D2A56 58%, #123E65 100%);
	border-bottom: 1px solid rgba(255,255,255,0.08);
}
body.page-policy.page-disclosure .page-top-inner{
	display: flex;
	flex-direction: column;
	gap: 10px;
}
body.page-policy.page-disclosure .breadcrumb{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.62);
}
body.page-policy.page-disclosure .breadcrumb a{ color: inherit; transition: color var(--dur) var(--ease); }
body.page-policy.page-disclosure .breadcrumb a:hover{ color: var(--green-light); }
body.page-policy.page-disclosure .breadcrumb .current{ color: var(--green-light); }
body.page-policy.page-disclosure .page-heading{
	font-size: clamp(1.9rem, 3.2vw, 2.7rem);
	color: var(--white);
}
body.page-policy.page-disclosure .page-subcopy{
	max-width: 760px;
	color: rgba(255,255,255,0.76);
	font-size: 0.98rem;
}
body.page-policy.page-disclosure .section{
	padding: 56px 0 var(--sp-24);
}
body.page-policy.page-disclosure .policy-layout{
	display: grid;
	grid-template-columns: 280px minmax(0, 1fr);
	gap: var(--sp-10);
	align-items: start;
}
body.page-policy.page-disclosure .policy-side{
	position: sticky;
	top: 96px;
	padding: 26px;
	border-radius: 28px;
	background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(247,248,250,1) 100%);
	border: 1px solid rgba(7,31,69,0.08);
	box-shadow: var(--sh-soft);
}
body.page-policy.page-disclosure .policy-side h3{
	font-size: 1.05rem;
	margin-bottom: 14px;
}
body.page-policy.page-disclosure .policy-side a{
	display: block;
	padding: 12px 14px;
	border-radius: 14px;
	font-size: 0.95rem;
	color: var(--gray-dark);
	transition: background-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
body.page-policy.page-disclosure .policy-side a:hover, body.page-policy.page-disclosure .policy-side a.is-active{
	background: rgba(42,197,88,0.1);
	color: var(--navy);
}
body.page-policy.page-disclosure .policy-card{
	padding: 34px 32px;
	border-radius: 32px;
	background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(247,248,250,1) 100%);
	border: 1px solid rgba(7,31,69,0.08);
	box-shadow: var(--sh-md);
}
body.page-policy.page-disclosure .policy-intro{
	padding: 22px 22px 0;
	margin: -6px -6px 28px;
}
body.page-policy.page-disclosure .policy-intro p + p{
	margin-top: 14px;
}
body.page-policy.page-disclosure .policy-section + .policy-section{
	margin-top: 34px;
	padding-top: 34px;
	border-top: 1px solid rgba(7,31,69,0.08);
}
body.page-policy.page-disclosure .policy-section h2{
	font-size: 1.5rem;
	margin-bottom: 16px;
}
body.page-policy.page-disclosure .policy-section p + p, body.page-policy.page-disclosure .policy-section p + ul, body.page-policy.page-disclosure .policy-section p + .table-wrap, body.page-policy.page-disclosure .policy-section ul + p, body.page-policy.page-disclosure .policy-section ul + .table-wrap, body.page-policy.page-disclosure .policy-section .table-wrap + p{
	margin-top: 16px;
}
body.page-policy.page-disclosure .policy-section ul{
	margin: 0;
	padding-left: 20px;
	color: var(--gray-dark);
}
body.page-policy.page-disclosure .policy-note{
	padding: 20px 22px;
	border-radius: 22px;
	background: rgba(42,197,88,0.08);
	border: 1px solid rgba(42,197,88,0.14);
}
body.page-policy.page-disclosure .table-wrap{
	overflow: auto;
	border-radius: 22px;
	border: 1px solid rgba(7,31,69,0.08);
}
body.page-policy.page-disclosure table{
	width: 100%;
	border-collapse: collapse;
	min-width: 640px;
	background: var(--white);
}
body.page-policy.page-disclosure th, body.page-policy.page-disclosure td{
	padding: 14px 16px;
	text-align: left;
	font-size: 0.94rem;
	border-bottom: 1px solid rgba(7,31,69,0.08);
}
body.page-policy.page-disclosure th{
	background: #EEF3FA;
	color: var(--navy);
	font-family: var(--font-display);
	font-weight: 700;
}
body.page-policy.page-disclosure tr:last-child td{ border-bottom: 0; }
body.page-policy.page-disclosure .footer{
	background: var(--navy);
	color: rgba(255,255,255,0.72);
	padding: var(--sp-24) var(--sp-10) var(--sp-10);
}
body.page-policy.page-disclosure .footer-inner{
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: var(--sp-12);
	padding-bottom: var(--sp-12);
	border-bottom: 1px solid rgba(255,255,255,0.1);
}
body.page-policy.page-disclosure .footer-brand{ max-width: 320px; }
body.page-policy.page-disclosure .footer-logo{
	display: flex;
	align-items: center;
	gap: 10px;
	font-family: var(--font-display);
	font-weight: 800;
	color: var(--white);
	font-size: 1.375rem;
	margin-bottom: var(--sp-4);
}
body.page-policy.page-disclosure .footer-tagline{ color: var(--white); font-weight: 500; margin-bottom: var(--sp-3); }
body.page-policy.page-disclosure .footer-arn{
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.6);
	margin-bottom: var(--sp-5);
}
body.page-policy.page-disclosure .footer-col h4{
	color: var(--white);
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin-bottom: var(--sp-5);
}
body.page-policy.page-disclosure .footer-col-body{
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
}
body.page-policy.page-disclosure .footer-link{
	color: rgba(255,255,255,0.72);
	font-size: 0.9375rem;
	transition: color var(--dur) var(--ease);
}
body.page-policy.page-disclosure .footer-link:hover{ color: var(--green-light); }
body.page-policy.page-disclosure .footer-social{ display: flex; gap: var(--sp-3); }
body.page-policy.page-disclosure .footer-social a{
	display: grid;
	place-items: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(255,255,255,0.06);
	color: rgba(255,255,255,0.72);
	transition: all var(--dur) var(--ease);
}
body.page-policy.page-disclosure .footer-social a:hover{
	background: var(--green);
	color: var(--navy);
	transform: translateY(-2px);
}
body.page-policy.page-disclosure .footer-bottom{
	max-width: 1280px;
	margin: 0 auto;
	padding-top: var(--sp-6);
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--sp-4);
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.55);
}
body.page-policy.page-disclosure .footer-bottom-links{ display: flex; gap: var(--sp-6); }
body.page-policy.page-disclosure .footer-bottom-links a{ transition: color var(--dur) var(--ease); }
body.page-policy.page-disclosure .footer-bottom-links a:hover{ color: var(--green-light); }
@media (max-width: 1100px){
	body.page-policy.page-disclosure .policy-layout, body.page-policy.page-disclosure .footer-inner{
		grid-template-columns: 1fr;
	}
	body.page-policy.page-disclosure .policy-side{
		position: relative;
		top: auto;
	}
}
@media (max-width: 960px){
	body.page-policy.page-disclosure .container, body.page-policy.page-disclosure .footer{
		padding-left: var(--sp-5);
		padding-right: var(--sp-5);
	}
	body.page-policy.page-disclosure .nav-links{ gap: var(--sp-5); }
	body.page-policy.page-disclosure .nav-login-menu{
		width: min(360px, calc(100vw - 40px));
		right: -10px;
	}
}
@media (max-width: 760px){
	body.page-policy.page-disclosure .navbar{ padding: 18px 20px; }
	body.page-policy.page-disclosure .nav-links{ gap: 14px; }
	body.page-policy.page-disclosure .nav-link{ font-size: 0.875rem; }
	body.page-policy.page-disclosure .nav-logo img{ height: 48px; }
	body.page-policy.page-disclosure .page-top{ padding-top: 120px; padding-bottom: 22px; }
	body.page-policy.page-disclosure .policy-card, body.page-policy.page-disclosure .policy-side{ padding: 24px; }
}
@media (max-width: 620px){
	body.page-policy.page-disclosure .navbar{ align-items: flex-start; }
	body.page-policy.page-disclosure .nav-links{
		flex-wrap: wrap;
		justify-content: flex-end;
		row-gap: 10px;
	}
	body.page-policy.page-disclosure .nav-login{
		width: 100%;
		display: flex;
		justify-content: flex-end;
	}
}


/* /policies/faq */
body.page-policy.page-faq *, body.page-policy.page-faq *::before, body.page-policy.page-faq *::after{ box-sizing: border-box; }
body.page-policy.page-faq, body.page-policy.page-faq{ margin: 0; padding: 0; }
body.page-policy.page-faq{
	font-family: var(--font-body);
	color: var(--gray-dark);
	background: var(--off-white);
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
	overflow-x: clip;
}
body.page-policy.page-faq a{ color: inherit; text-decoration: none; }
body.page-policy.page-faq img, body.page-policy.page-faq svg{ display: block; max-width: 100%; }
body.page-policy.page-faq h1, body.page-policy.page-faq h2, body.page-policy.page-faq h3, body.page-policy.page-faq h4, body.page-policy.page-faq p{ margin: 0; }
body.page-policy.page-faq h1, body.page-policy.page-faq h2, body.page-policy.page-faq h3, body.page-policy.page-faq h4{
	font-family: var(--font-display);
	color: var(--navy);
	letter-spacing: -0.02em;
	line-height: 1.08;
}
body.page-policy.page-faq .container{
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 var(--sp-10);
}
body.page-policy.page-faq .navbar{
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--sp-5) var(--sp-10);
	transition: background-color var(--dur) var(--ease), backdrop-filter var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
body.page-policy.page-faq .navbar.is-transparent{ background: transparent; }
body.page-policy.page-faq .navbar.is-solid{
	background: rgba(255,255,255,0.92);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-shadow: 0 1px 0 rgba(7,31,69,0.06);
}
body.page-policy.page-faq .nav-logo{ display: flex; align-items: center; }
body.page-policy.page-faq .nav-logo img{ height: 56px; width: auto; }
body.page-policy.page-faq .nav-logo-light{ display: none; }
body.page-policy.page-faq .is-transparent .nav-logo-dark{ display: none; }
body.page-policy.page-faq .is-transparent .nav-logo-light{ display: block; }
body.page-policy.page-faq .is-solid .nav-logo-dark{ display: block; }
body.page-policy.page-faq .is-solid .nav-logo-light{ display: none; }
body.page-policy.page-faq .nav-links{ display: flex; align-items: center; gap: var(--sp-8); }
body.page-policy.page-faq .nav-link{
	position: relative;
	font-size: 0.9375rem;
	font-weight: 500;
	transition: color var(--dur) var(--ease);
}
body.page-policy.page-faq .is-transparent .nav-link{ color: var(--white); }
body.page-policy.page-faq .is-solid .nav-link{ color: var(--navy); }
body.page-policy.page-faq .nav-link::after{
	content: "";
	position: absolute;
	left: 0;
	bottom: -10px;
	width: 100%;
	height: 2px;
	border-radius: 99px;
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform var(--dur) var(--ease);
}
body.page-policy.page-faq .is-transparent .nav-link::after{ background: var(--green-light); }
body.page-policy.page-faq .is-solid .nav-link::after{ background: var(--green); }
body.page-policy.page-faq .nav-link:hover, body.page-policy.page-faq .nav-link.is-active{ color: var(--green); }
body.page-policy.page-faq .nav-link:hover::after, body.page-policy.page-faq .nav-link.is-active::after{ transform: scaleX(1); }
body.page-policy.page-faq .nav-login{
	position: relative;
	padding-bottom: 18px;
	margin-bottom: -18px;
}
body.page-policy.page-faq .nav-login::after{
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	height: 24px;
}
body.page-policy.page-faq .nav-login-toggle{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	height: 52px;
	padding: 0 24px 0 26px;
	border-radius: 16px;
	font-size: 0.875rem;
	font-weight: 600;
	background: transparent;
	border: 1px solid;
	cursor: pointer;
	transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease), background-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
body.page-policy.page-faq .nav-login-toggle svg{
	width: 16px;
	height: 16px;
	transition: transform var(--dur) var(--ease);
}
body.page-policy.page-faq .nav-login.is-open .nav-login-toggle svg{ transform: rotate(180deg); }
body.page-policy.page-faq .is-transparent .nav-login-toggle{
	color: var(--white);
	border-color: rgba(255,255,255,0.22);
	background: linear-gradient(180deg, rgba(255,255,255,0.14) 0%, rgba(255,255,255,0.06) 100%);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}
body.page-policy.page-faq .is-solid .nav-login-toggle{
	color: var(--navy);
	border-color: rgba(7,31,69,0.12);
	background: linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(244,247,250,0.98) 100%);
	box-shadow: 0 8px 24px rgba(7,31,69,0.05);
}
body.page-policy.page-faq .nav-login-menu{
	position: absolute;
	top: calc(100% + 6px);
	right: 0;
	width: 320px;
	padding: 12px;
	border-radius: 22px;
	background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(246,248,251,0.99) 100%);
	border: 1px solid rgba(7,31,69,0.09);
	box-shadow: 0 28px 70px rgba(7,31,69,0.18);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	opacity: 0;
	transform: translateY(10px);
	visibility: hidden;
	pointer-events: none;
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear var(--dur);
}
body.page-policy.page-faq .nav-login-menu::before{
	content: "";
	position: absolute;
	top: -9px;
	right: 34px;
	width: 18px;
	height: 18px;
	background: rgba(255,255,255,0.98);
	border-top: 1px solid rgba(7,31,69,0.1);
	border-left: 1px solid rgba(7,31,69,0.1);
	transform: rotate(45deg);
}
body.page-policy.page-faq .nav-login.is-open .nav-login-menu{
	opacity: 1;
	transform: translateY(0);
	visibility: visible;
	pointer-events: auto;
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear 0s;
}
body.page-policy.page-faq .portal-link{
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px 15px;
	border-radius: 18px;
	color: var(--navy);
	background: linear-gradient(180deg, rgba(255,255,255,0.95) 0%, rgba(249,250,252,1) 100%);
	border: 1px solid rgba(7,31,69,0.06);
	transition: background-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
body.page-policy.page-faq .portal-link + .portal-link{ margin-top: 8px; }
body.page-policy.page-faq .portal-link:hover{
	background: linear-gradient(135deg, rgba(42,197,88,0.12) 0%, rgba(255,255,255,1) 100%);
	transform: translateY(-2px);
	box-shadow: 0 12px 24px rgba(7,31,69,0.08);
}
body.page-policy.page-faq .portal-icon{
	width: 46px;
	height: 46px;
	border-radius: 14px;
	display: grid;
	place-items: center;
	background: linear-gradient(180deg, rgba(42,197,88,0.16) 0%, rgba(42,197,88,0.08) 100%);
	border: 1px solid rgba(42,197,88,0.18);
}
body.page-policy.page-faq .portal-copy{ flex: 1; }
body.page-policy.page-faq .portal-title{
	font-family: var(--font-display);
	font-size: 1.02rem;
	font-weight: 700;
}
body.page-policy.page-faq .portal-arrow{ opacity: 0.72; }
body.page-policy.page-faq .page-top{
	padding: 132px 0 28px;
	background:
		radial-gradient(90% 120% at 82% 0%, rgba(42,197,88,0.18) 0%, transparent 44%),
		radial-gradient(100% 100% at 0% 100%, rgba(42,74,128,0.38) 0%, transparent 58%),
		linear-gradient(150deg, #071F45 0%, #0D2A56 58%, #123E65 100%);
	border-bottom: 1px solid rgba(255,255,255,0.08);
}
body.page-policy.page-faq .page-top-inner{
	display: flex;
	flex-direction: column;
	gap: 10px;
}
body.page-policy.page-faq .breadcrumb{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.62);
}
body.page-policy.page-faq .breadcrumb a{ color: inherit; transition: color var(--dur) var(--ease); }
body.page-policy.page-faq .breadcrumb a:hover{ color: var(--green-light); }
body.page-policy.page-faq .breadcrumb .current{ color: var(--green-light); }
body.page-policy.page-faq .page-heading{
	font-size: clamp(1.9rem, 3.2vw, 2.7rem);
	color: var(--white);
}
body.page-policy.page-faq .page-subcopy{
	max-width: 860px;
	color: rgba(255,255,255,0.76);
	font-size: 0.98rem;
}
body.page-policy.page-faq .section{
	padding: 56px 0 var(--sp-24);
}
body.page-policy.page-faq .faq-layout{
	display: grid;
	grid-template-columns: 280px minmax(0, 1fr);
	gap: var(--sp-10);
	align-items: start;
}
body.page-policy.page-faq .faq-side{
	position: sticky;
	top: 96px;
	padding: 26px;
	border-radius: 28px;
	background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(247,248,250,1) 100%);
	border: 1px solid rgba(7,31,69,0.08);
	box-shadow: var(--sh-soft);
}
body.page-policy.page-faq .faq-side h3{
	font-size: 1.05rem;
	margin-bottom: 14px;
}
body.page-policy.page-faq .faq-side a{
	display: block;
	padding: 12px 14px;
	border-radius: 14px;
	font-size: 0.95rem;
	color: var(--gray-dark);
	transition: background-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
body.page-policy.page-faq .faq-side a:hover, body.page-policy.page-faq .faq-side a.is-active{
	background: rgba(42,197,88,0.1);
	color: var(--navy);
}
body.page-policy.page-faq .faq-content{
	display: grid;
	gap: 22px;
}
body.page-policy.page-faq .faq-intro, body.page-policy.page-faq .faq-category{
	padding: 32px;
	border-radius: 32px;
	background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(247,248,250,1) 100%);
	border: 1px solid rgba(7,31,69,0.08);
	box-shadow: var(--sh-md);
}
body.page-policy.page-faq .faq-intro p + p{
	margin-top: 14px;
}
body.page-policy.page-faq .faq-category-title{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 1.45rem;
	margin-bottom: 22px;
}
body.page-policy.page-faq .faq-category-title::before{
	content: "";
	width: 22px;
	height: 2px;
	border-radius: 99px;
	background: var(--green);
}
body.page-policy.page-faq .faq-item + .faq-item{
	margin-top: 20px;
	padding-top: 20px;
	border-top: 1px solid rgba(7,31,69,0.08);
}
body.page-policy.page-faq .faq-question{
	font-size: 1.08rem;
	margin-bottom: 12px;
}
body.page-policy.page-faq .faq-answer p + p, body.page-policy.page-faq .faq-answer p + ul, body.page-policy.page-faq .faq-answer ul + p{
	margin-top: 12px;
}
body.page-policy.page-faq .faq-answer ul{
	margin: 0;
	padding-left: 20px;
}
body.page-policy.page-faq .quote-block{
	padding: 20px 22px;
	border-radius: 24px;
	background: rgba(42,197,88,0.08);
	border: 1px solid rgba(42,197,88,0.14);
}
body.page-policy.page-faq .footer{
	background: var(--navy);
	color: rgba(255,255,255,0.72);
	padding: var(--sp-24) var(--sp-10) var(--sp-10);
}
body.page-policy.page-faq .footer-inner{
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: var(--sp-12);
	padding-bottom: var(--sp-12);
	border-bottom: 1px solid rgba(255,255,255,0.1);
}
body.page-policy.page-faq .footer-brand{ max-width: 320px; }
body.page-policy.page-faq .footer-logo{
	display: flex;
	align-items: center;
	gap: 10px;
	font-family: var(--font-display);
	font-weight: 800;
	color: var(--white);
	font-size: 1.375rem;
	margin-bottom: var(--sp-4);
}
body.page-policy.page-faq .footer-tagline{ color: var(--white); font-weight: 500; margin-bottom: var(--sp-3); }
body.page-policy.page-faq .footer-arn{
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.6);
	margin-bottom: var(--sp-5);
}
body.page-policy.page-faq .footer-col h4{
	color: var(--white);
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin-bottom: var(--sp-5);
}
body.page-policy.page-faq .footer-col-body{
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
}
body.page-policy.page-faq .footer-link{
	color: rgba(255,255,255,0.72);
	font-size: 0.9375rem;
	transition: color var(--dur) var(--ease);
}
body.page-policy.page-faq .footer-link:hover{ color: var(--green-light); }
body.page-policy.page-faq .footer-social{ display: flex; gap: var(--sp-3); }
body.page-policy.page-faq .footer-social a{
	display: grid;
	place-items: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(255,255,255,0.06);
	color: rgba(255,255,255,0.72);
	transition: all var(--dur) var(--ease);
}
body.page-policy.page-faq .footer-social a:hover{
	background: var(--green);
	color: var(--navy);
	transform: translateY(-2px);
}
body.page-policy.page-faq .footer-bottom{
	max-width: 1280px;
	margin: 0 auto;
	padding-top: var(--sp-6);
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--sp-4);
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.55);
}
body.page-policy.page-faq .footer-bottom-links{ display: flex; gap: var(--sp-6); }
body.page-policy.page-faq .footer-bottom-links a{ transition: color var(--dur) var(--ease); }
body.page-policy.page-faq .footer-bottom-links a:hover{ color: var(--green-light); }
@media (max-width: 1100px){
	body.page-policy.page-faq .faq-layout, body.page-policy.page-faq .footer-inner{
		grid-template-columns: 1fr;
	}
	body.page-policy.page-faq .faq-side{
		position: relative;
		top: auto;
	}
}
@media (max-width: 960px){
	body.page-policy.page-faq .container, body.page-policy.page-faq .footer{
		padding-left: var(--sp-5);
		padding-right: var(--sp-5);
	}
	body.page-policy.page-faq .nav-links{ gap: var(--sp-5); }
	body.page-policy.page-faq .nav-login-menu{
		width: min(360px, calc(100vw - 40px));
		right: -10px;
	}
}
@media (max-width: 760px){
	body.page-policy.page-faq .navbar{ padding: 18px 20px; }
	body.page-policy.page-faq .nav-links{ gap: 14px; }
	body.page-policy.page-faq .nav-link{ font-size: 0.875rem; }
	body.page-policy.page-faq .nav-logo img{ height: 48px; }
	body.page-policy.page-faq .page-top{ padding-top: 120px; padding-bottom: 22px; }
	body.page-policy.page-faq .faq-intro, body.page-policy.page-faq .faq-category, body.page-policy.page-faq .faq-side{ padding: 24px; }
}
@media (max-width: 620px){
	body.page-policy.page-faq .navbar{ align-items: flex-start; }
	body.page-policy.page-faq .nav-links{
		flex-wrap: wrap;
		justify-content: flex-end;
		row-gap: 10px;
	}
	body.page-policy.page-faq .nav-login{
		width: 100%;
		display: flex;
		justify-content: flex-end;
	}
}


/* /policies/privacy-policy */
body.page-policy.page-privacy *, body.page-policy.page-privacy *::before, body.page-policy.page-privacy *::after{ box-sizing: border-box; }
body.page-policy.page-privacy, body.page-policy.page-privacy{ margin: 0; padding: 0; }
body.page-policy.page-privacy{ font-family: var(--font-body); color: var(--gray-dark); background: var(--off-white); line-height: 1.7; -webkit-font-smoothing: antialiased; overflow-x: clip; }
body.page-policy.page-privacy a{ color: inherit; text-decoration: none; }
body.page-policy.page-privacy img, body.page-policy.page-privacy svg{ display: block; max-width: 100%; }
body.page-policy.page-privacy h1, body.page-policy.page-privacy h2, body.page-policy.page-privacy h3, body.page-policy.page-privacy h4, body.page-policy.page-privacy p{ margin: 0; }
body.page-policy.page-privacy h1, body.page-policy.page-privacy h2, body.page-policy.page-privacy h3, body.page-policy.page-privacy h4{ font-family: var(--font-display); color: var(--navy); letter-spacing: -0.02em; line-height: 1.08; }
body.page-policy.page-privacy .container{ max-width: 1280px; margin: 0 auto; padding: 0 var(--sp-10); }
body.page-policy.page-privacy .navbar{ position: fixed; top: 0; left: 0; right: 0; z-index: 100; display: flex; align-items: center; justify-content: space-between; padding: var(--sp-5) var(--sp-10); transition: background-color var(--dur) var(--ease), backdrop-filter var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
body.page-policy.page-privacy .navbar.is-transparent{ background: transparent; }
body.page-policy.page-privacy .navbar.is-solid{ background: rgba(255,255,255,0.92); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); box-shadow: 0 1px 0 rgba(7,31,69,0.06); }
body.page-policy.page-privacy .nav-logo{ display: flex; align-items: center; }
body.page-policy.page-privacy .nav-logo img{ height: 56px; width: auto; }
body.page-policy.page-privacy .nav-logo-light{ display: none; }
body.page-policy.page-privacy .is-transparent .nav-logo-dark{ display: none; }
body.page-policy.page-privacy .is-transparent .nav-logo-light{ display: block; }
body.page-policy.page-privacy .is-solid .nav-logo-dark{ display: block; }
body.page-policy.page-privacy .is-solid .nav-logo-light{ display: none; }
body.page-policy.page-privacy .nav-links{ display: flex; align-items: center; gap: var(--sp-8); }
body.page-policy.page-privacy .nav-link{ position: relative; font-size: 0.9375rem; font-weight: 500; transition: color var(--dur) var(--ease); }
body.page-policy.page-privacy .is-transparent .nav-link{ color: var(--white); }
body.page-policy.page-privacy .is-solid .nav-link{ color: var(--navy); }
body.page-policy.page-privacy .nav-link::after{ content: ""; position: absolute; left: 0; bottom: -10px; width: 100%; height: 2px; border-radius: 99px; transform: scaleX(0); transform-origin: left center; transition: transform var(--dur) var(--ease); }
body.page-policy.page-privacy .is-transparent .nav-link::after{ background: var(--green-light); }
body.page-policy.page-privacy .is-solid .nav-link::after{ background: var(--green); }
body.page-policy.page-privacy .nav-link:hover, body.page-policy.page-privacy .nav-link.is-active{ color: var(--green); }
body.page-policy.page-privacy .nav-link:hover::after, body.page-policy.page-privacy .nav-link.is-active::after{ transform: scaleX(1); }
body.page-policy.page-privacy .nav-login{ position: relative; padding-bottom: 18px; margin-bottom: -18px; }
body.page-policy.page-privacy .nav-login::after{ content: ""; position: absolute; left: 0; right: 0; top: 100%; height: 24px; }
body.page-policy.page-privacy .nav-login-toggle{ display: inline-flex; align-items: center; justify-content: center; gap: 8px; height: 52px; padding: 0 24px 0 26px; border-radius: 16px; font-size: 0.875rem; font-weight: 600; background: transparent; border: 1px solid; cursor: pointer; transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease), background-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
body.page-policy.page-privacy .nav-login-toggle svg{ width: 16px; height: 16px; transition: transform var(--dur) var(--ease); }
body.page-policy.page-privacy .nav-login.is-open .nav-login-toggle svg{ transform: rotate(180deg); }
body.page-policy.page-privacy .is-transparent .nav-login-toggle{ color: var(--white); border-color: rgba(255,255,255,0.22); background: linear-gradient(180deg, rgba(255,255,255,0.14) 0%, rgba(255,255,255,0.06) 100%); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); }
body.page-policy.page-privacy .is-solid .nav-login-toggle{ color: var(--navy); border-color: rgba(7,31,69,0.12); background: linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(244,247,250,0.98) 100%); box-shadow: 0 8px 24px rgba(7,31,69,0.05); }
body.page-policy.page-privacy .nav-login-menu{ position: absolute; top: calc(100% + 6px); right: 0; width: 320px; padding: 12px; border-radius: 22px; background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(246,248,251,0.99) 100%); border: 1px solid rgba(7,31,69,0.09); box-shadow: 0 28px 70px rgba(7,31,69,0.18); backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px); opacity: 0; transform: translateY(10px); visibility: hidden; pointer-events: none; transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear var(--dur); }
body.page-policy.page-privacy .nav-login-menu::before{ content: ""; position: absolute; top: -9px; right: 34px; width: 18px; height: 18px; background: rgba(255,255,255,0.98); border-top: 1px solid rgba(7,31,69,0.1); border-left: 1px solid rgba(7,31,69,0.1); transform: rotate(45deg); }
body.page-policy.page-privacy .nav-login.is-open .nav-login-menu{ opacity: 1; transform: translateY(0); visibility: visible; pointer-events: auto; transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear 0s; }
body.page-policy.page-privacy .portal-link{ display: flex; align-items: center; gap: 14px; padding: 16px 15px; border-radius: 18px; color: var(--navy); background: linear-gradient(180deg, rgba(255,255,255,0.95) 0%, rgba(249,250,252,1) 100%); border: 1px solid rgba(7,31,69,0.06); transition: background-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
body.page-policy.page-privacy .portal-link + .portal-link{ margin-top: 8px; }
body.page-policy.page-privacy .portal-link:hover{ background: linear-gradient(135deg, rgba(42,197,88,0.12) 0%, rgba(255,255,255,1) 100%); transform: translateY(-2px); box-shadow: 0 12px 24px rgba(7,31,69,0.08); }
body.page-policy.page-privacy .portal-icon{ width: 46px; height: 46px; border-radius: 14px; display: grid; place-items: center; background: linear-gradient(180deg, rgba(42,197,88,0.16) 0%, rgba(42,197,88,0.08) 100%); border: 1px solid rgba(42,197,88,0.18); }
body.page-policy.page-privacy .portal-copy{ flex: 1; }
body.page-policy.page-privacy .portal-title{ font-family: var(--font-display); font-size: 1.02rem; font-weight: 700; }
body.page-policy.page-privacy .portal-arrow{ opacity: 0.72; }
body.page-policy.page-privacy .page-top{ padding: 132px 0 28px; background: radial-gradient(90% 120% at 82% 0%, rgba(42,197,88,0.18) 0%, transparent 44%), radial-gradient(100% 100% at 0% 100%, rgba(42,74,128,0.38) 0%, transparent 58%), linear-gradient(150deg, #071F45 0%, #0D2A56 58%, #123E65 100%); border-bottom: 1px solid rgba(255,255,255,0.08); }
body.page-policy.page-privacy .page-top-inner{ display: flex; flex-direction: column; gap: 10px; }
body.page-policy.page-privacy .breadcrumb{ display: inline-flex; align-items: center; gap: 10px; font-size: 0.78rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(255,255,255,0.62); }
body.page-policy.page-privacy .breadcrumb a{ color: inherit; transition: color var(--dur) var(--ease); }
body.page-policy.page-privacy .breadcrumb a:hover{ color: var(--green-light); }
body.page-policy.page-privacy .breadcrumb .current{ color: var(--green-light); }
body.page-policy.page-privacy .page-heading{ font-size: clamp(1.9rem, 3.2vw, 2.7rem); color: var(--white); }
body.page-policy.page-privacy .page-subcopy{ max-width: 780px; color: rgba(255,255,255,0.76); font-size: 0.98rem; }
body.page-policy.page-privacy .section{ padding: 56px 0 var(--sp-24); }
body.page-policy.page-privacy .policy-layout{ display: grid; grid-template-columns: 280px minmax(0, 1fr); gap: var(--sp-10); align-items: start; }
body.page-policy.page-privacy .policy-side{ position: sticky; top: 96px; padding: 26px; border-radius: 28px; background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(247,248,250,1) 100%); border: 1px solid rgba(7,31,69,0.08); box-shadow: var(--sh-soft); }
body.page-policy.page-privacy .policy-side h3{ font-size: 1.05rem; margin-bottom: 14px; }
body.page-policy.page-privacy .policy-side a{ display: block; padding: 12px 14px; border-radius: 14px; font-size: 0.95rem; color: var(--gray-dark); transition: background-color var(--dur) var(--ease), color var(--dur) var(--ease); }
body.page-policy.page-privacy .policy-side a:hover, body.page-policy.page-privacy .policy-side a.is-active{ background: rgba(42,197,88,0.1); color: var(--navy); }
body.page-policy.page-privacy .policy-card{ padding: 34px 32px; border-radius: 32px; background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(247,248,250,1) 100%); border: 1px solid rgba(7,31,69,0.08); box-shadow: var(--sh-md); }
body.page-policy.page-privacy .policy-section + .policy-section{ margin-top: 34px; padding-top: 34px; border-top: 1px solid rgba(7,31,69,0.08); }
body.page-policy.page-privacy .policy-section h2{ font-size: 1.5rem; margin-bottom: 16px; }
body.page-policy.page-privacy .policy-section p + p, body.page-policy.page-privacy .policy-section p + ul, body.page-policy.page-privacy .policy-section ul + p, body.page-policy.page-privacy .policy-section p + .policy-note{ margin-top: 16px; }
body.page-policy.page-privacy .policy-section ul{ margin: 0; padding-left: 20px; }
body.page-policy.page-privacy .policy-note{ padding: 20px 22px; border-radius: 22px; background: rgba(42,197,88,0.08); border: 1px solid rgba(42,197,88,0.14); }
body.page-policy.page-privacy .footer{ background: var(--navy); color: rgba(255,255,255,0.72); padding: var(--sp-24) var(--sp-10) var(--sp-10); }
body.page-policy.page-privacy .footer-inner{ max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--sp-12); padding-bottom: var(--sp-12); border-bottom: 1px solid rgba(255,255,255,0.1); }
body.page-policy.page-privacy .footer-brand{ max-width: 320px; }
body.page-policy.page-privacy .footer-logo{ display: flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 800; color: var(--white); font-size: 1.375rem; margin-bottom: var(--sp-4); }
body.page-policy.page-privacy .footer-tagline{ color: var(--white); font-weight: 500; margin-bottom: var(--sp-3); }
body.page-policy.page-privacy .footer-arn{ font-size: 0.8125rem; color: rgba(255,255,255,0.6); margin-bottom: var(--sp-5); }
body.page-policy.page-privacy .footer-col h4{ color: var(--white); font-size: 0.875rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--sp-5); }
body.page-policy.page-privacy .footer-col-body{ display: flex; flex-direction: column; gap: var(--sp-3); }
body.page-policy.page-privacy .footer-link{ color: rgba(255,255,255,0.72); font-size: 0.9375rem; transition: color var(--dur) var(--ease); }
body.page-policy.page-privacy .footer-link:hover{ color: var(--green-light); }
body.page-policy.page-privacy .footer-social{ display: flex; gap: var(--sp-3); }
body.page-policy.page-privacy .footer-social a{ display: grid; place-items: center; width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.72); transition: all var(--dur) var(--ease); }
body.page-policy.page-privacy .footer-social a:hover{ background: var(--green); color: var(--navy); transform: translateY(-2px); }
body.page-policy.page-privacy .footer-bottom{ max-width: 1280px; margin: 0 auto; padding-top: var(--sp-6); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--sp-4); font-size: 0.8125rem; color: rgba(255,255,255,0.55); }
body.page-policy.page-privacy .footer-bottom-links{ display: flex; gap: var(--sp-6); }
body.page-policy.page-privacy .footer-bottom-links a{ transition: color var(--dur) var(--ease); }
body.page-policy.page-privacy .footer-bottom-links a:hover{ color: var(--green-light); }
@media (max-width: 1100px){ body.page-policy.page-privacy .policy-layout, body.page-policy.page-privacy .footer-inner{ grid-template-columns: 1fr; } body.page-policy.page-privacy .policy-side{ position: relative; top: auto; } }
@media (max-width: 960px){ body.page-policy.page-privacy .container, body.page-policy.page-privacy .footer{ padding-left: var(--sp-5); padding-right: var(--sp-5); } body.page-policy.page-privacy .nav-links{ gap: var(--sp-5); } body.page-policy.page-privacy .nav-login-menu{ width: min(360px, calc(100vw - 40px)); right: -10px; } }
@media (max-width: 760px){ body.page-policy.page-privacy .navbar{ padding: 18px 20px; } body.page-policy.page-privacy .nav-links{ gap: 14px; } body.page-policy.page-privacy .nav-link{ font-size: 0.875rem; } body.page-policy.page-privacy .nav-logo img{ height: 48px; } body.page-policy.page-privacy .page-top{ padding-top: 120px; padding-bottom: 22px; } body.page-policy.page-privacy .policy-card, body.page-policy.page-privacy .policy-side{ padding: 24px; } }
@media (max-width: 620px){ body.page-policy.page-privacy .navbar{ align-items: flex-start; } body.page-policy.page-privacy .nav-links{ flex-wrap: wrap; justify-content: flex-end; row-gap: 10px; } body.page-policy.page-privacy .nav-login{ width: 100%; display: flex; justify-content: flex-end; } }


/* /policies/terms-of-service */
body.page-policy.page-terms *, body.page-policy.page-terms *::before, body.page-policy.page-terms *::after{ box-sizing: border-box; }
body.page-policy.page-terms, body.page-policy.page-terms{ margin: 0; padding: 0; }
body.page-policy.page-terms{ font-family: var(--font-body); color: var(--gray-dark); background: var(--off-white); line-height: 1.7; -webkit-font-smoothing: antialiased; overflow-x: clip; }
body.page-policy.page-terms a{ color: inherit; text-decoration: none; }
body.page-policy.page-terms img, body.page-policy.page-terms svg{ display: block; max-width: 100%; }
body.page-policy.page-terms h1, body.page-policy.page-terms h2, body.page-policy.page-terms h3, body.page-policy.page-terms h4, body.page-policy.page-terms p{ margin: 0; }
body.page-policy.page-terms h1, body.page-policy.page-terms h2, body.page-policy.page-terms h3, body.page-policy.page-terms h4{ font-family: var(--font-display); color: var(--navy); letter-spacing: -0.02em; line-height: 1.08; }
body.page-policy.page-terms .container{ max-width: 1280px; margin: 0 auto; padding: 0 var(--sp-10); }
body.page-policy.page-terms .navbar{ position: fixed; top: 0; left: 0; right: 0; z-index: 100; display: flex; align-items: center; justify-content: space-between; padding: var(--sp-5) var(--sp-10); transition: background-color var(--dur) var(--ease), backdrop-filter var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
body.page-policy.page-terms .navbar.is-transparent{ background: transparent; }
body.page-policy.page-terms .navbar.is-solid{ background: rgba(255,255,255,0.92); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); box-shadow: 0 1px 0 rgba(7,31,69,0.06); }
body.page-policy.page-terms .nav-logo{ display: flex; align-items: center; }
body.page-policy.page-terms .nav-logo img{ height: 56px; width: auto; }
body.page-policy.page-terms .nav-logo-light{ display: none; }
body.page-policy.page-terms .is-transparent .nav-logo-dark{ display: none; }
body.page-policy.page-terms .is-transparent .nav-logo-light{ display: block; }
body.page-policy.page-terms .is-solid .nav-logo-dark{ display: block; }
body.page-policy.page-terms .is-solid .nav-logo-light{ display: none; }
body.page-policy.page-terms .nav-links{ display: flex; align-items: center; gap: var(--sp-8); }
body.page-policy.page-terms .nav-link{ position: relative; font-size: 0.9375rem; font-weight: 500; transition: color var(--dur) var(--ease); }
body.page-policy.page-terms .is-transparent .nav-link{ color: var(--white); }
body.page-policy.page-terms .is-solid .nav-link{ color: var(--navy); }
body.page-policy.page-terms .nav-link::after{ content: ""; position: absolute; left: 0; bottom: -10px; width: 100%; height: 2px; border-radius: 99px; transform: scaleX(0); transform-origin: left center; transition: transform var(--dur) var(--ease); }
body.page-policy.page-terms .is-transparent .nav-link::after{ background: var(--green-light); }
body.page-policy.page-terms .is-solid .nav-link::after{ background: var(--green); }
body.page-policy.page-terms .nav-link:hover, body.page-policy.page-terms .nav-link.is-active{ color: var(--green); }
body.page-policy.page-terms .nav-link:hover::after, body.page-policy.page-terms .nav-link.is-active::after{ transform: scaleX(1); }
body.page-policy.page-terms .nav-login{ position: relative; padding-bottom: 18px; margin-bottom: -18px; }
body.page-policy.page-terms .nav-login::after{ content: ""; position: absolute; left: 0; right: 0; top: 100%; height: 24px; }
body.page-policy.page-terms .nav-login-toggle{ display: inline-flex; align-items: center; justify-content: center; gap: 8px; height: 52px; padding: 0 24px 0 26px; border-radius: 16px; font-size: 0.875rem; font-weight: 600; background: transparent; border: 1px solid; cursor: pointer; transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease), background-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
body.page-policy.page-terms .nav-login-toggle svg{ width: 16px; height: 16px; transition: transform var(--dur) var(--ease); }
body.page-policy.page-terms .nav-login.is-open .nav-login-toggle svg{ transform: rotate(180deg); }
body.page-policy.page-terms .is-transparent .nav-login-toggle{ color: var(--white); border-color: rgba(255,255,255,0.22); background: linear-gradient(180deg, rgba(255,255,255,0.14) 0%, rgba(255,255,255,0.06) 100%); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); }
body.page-policy.page-terms .is-solid .nav-login-toggle{ color: var(--navy); border-color: rgba(7,31,69,0.12); background: linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(244,247,250,0.98) 100%); box-shadow: 0 8px 24px rgba(7,31,69,0.05); }
body.page-policy.page-terms .nav-login-menu{ position: absolute; top: calc(100% + 6px); right: 0; width: 320px; padding: 12px; border-radius: 22px; background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(246,248,251,0.99) 100%); border: 1px solid rgba(7,31,69,0.09); box-shadow: 0 28px 70px rgba(7,31,69,0.18); backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px); opacity: 0; transform: translateY(10px); visibility: hidden; pointer-events: none; transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear var(--dur); }
body.page-policy.page-terms .nav-login-menu::before{ content: ""; position: absolute; top: -9px; right: 34px; width: 18px; height: 18px; background: rgba(255,255,255,0.98); border-top: 1px solid rgba(7,31,69,0.1); border-left: 1px solid rgba(7,31,69,0.1); transform: rotate(45deg); }
body.page-policy.page-terms .nav-login.is-open .nav-login-menu{ opacity: 1; transform: translateY(0); visibility: visible; pointer-events: auto; transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear 0s; }
body.page-policy.page-terms .portal-link{ display: flex; align-items: center; gap: 14px; padding: 16px 15px; border-radius: 18px; color: var(--navy); background: linear-gradient(180deg, rgba(255,255,255,0.95) 0%, rgba(249,250,252,1) 100%); border: 1px solid rgba(7,31,69,0.06); transition: background-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
body.page-policy.page-terms .portal-link + .portal-link{ margin-top: 8px; }
body.page-policy.page-terms .portal-link:hover{ background: linear-gradient(135deg, rgba(42,197,88,0.12) 0%, rgba(255,255,255,1) 100%); transform: translateY(-2px); box-shadow: 0 12px 24px rgba(7,31,69,0.08); }
body.page-policy.page-terms .portal-icon{ width: 46px; height: 46px; border-radius: 14px; display: grid; place-items: center; background: linear-gradient(180deg, rgba(42,197,88,0.16) 0%, rgba(42,197,88,0.08) 100%); border: 1px solid rgba(42,197,88,0.18); }
body.page-policy.page-terms .portal-copy{ flex: 1; }
body.page-policy.page-terms .portal-title{ font-family: var(--font-display); font-size: 1.02rem; font-weight: 700; }
body.page-policy.page-terms .portal-arrow{ opacity: 0.72; }
body.page-policy.page-terms .page-top{ padding: 132px 0 28px; background: radial-gradient(90% 120% at 82% 0%, rgba(42,197,88,0.18) 0%, transparent 44%), radial-gradient(100% 100% at 0% 100%, rgba(42,74,128,0.38) 0%, transparent 58%), linear-gradient(150deg, #071F45 0%, #0D2A56 58%, #123E65 100%); border-bottom: 1px solid rgba(255,255,255,0.08); }
body.page-policy.page-terms .page-top-inner{ display: flex; flex-direction: column; gap: 10px; }
body.page-policy.page-terms .breadcrumb{ display: inline-flex; align-items: center; gap: 10px; font-size: 0.78rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(255,255,255,0.62); }
body.page-policy.page-terms .breadcrumb a{ color: inherit; transition: color var(--dur) var(--ease); }
body.page-policy.page-terms .breadcrumb a:hover{ color: var(--green-light); }
body.page-policy.page-terms .breadcrumb .current{ color: var(--green-light); }
body.page-policy.page-terms .page-heading{ font-size: clamp(1.9rem, 3.2vw, 2.7rem); color: var(--white); }
body.page-policy.page-terms .page-subcopy{ max-width: 780px; color: rgba(255,255,255,0.76); font-size: 0.98rem; }
body.page-policy.page-terms .section{ padding: 56px 0 var(--sp-24); }
body.page-policy.page-terms .policy-layout{ display: grid; grid-template-columns: 280px minmax(0, 1fr); gap: var(--sp-10); align-items: start; }
body.page-policy.page-terms .policy-side{ position: sticky; top: 96px; padding: 26px; border-radius: 28px; background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(247,248,250,1) 100%); border: 1px solid rgba(7,31,69,0.08); box-shadow: var(--sh-soft); }
body.page-policy.page-terms .policy-side h3{ font-size: 1.05rem; margin-bottom: 14px; }
body.page-policy.page-terms .policy-side a{ display: block; padding: 12px 14px; border-radius: 14px; font-size: 0.95rem; color: var(--gray-dark); transition: background-color var(--dur) var(--ease), color var(--dur) var(--ease); }
body.page-policy.page-terms .policy-side a:hover, body.page-policy.page-terms .policy-side a.is-active{ background: rgba(42,197,88,0.1); color: var(--navy); }
body.page-policy.page-terms .policy-card{ padding: 34px 32px; border-radius: 32px; background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(247,248,250,1) 100%); border: 1px solid rgba(7,31,69,0.08); box-shadow: var(--sh-md); }
body.page-policy.page-terms .policy-section + .policy-section{ margin-top: 34px; padding-top: 34px; border-top: 1px solid rgba(7,31,69,0.08); }
body.page-policy.page-terms .policy-section h2{ font-size: 1.5rem; margin-bottom: 16px; }
body.page-policy.page-terms .policy-section p + p, body.page-policy.page-terms .policy-section p + ul, body.page-policy.page-terms .policy-section ul + p, body.page-policy.page-terms .policy-section p + .policy-note{ margin-top: 16px; }
body.page-policy.page-terms .policy-section ul{ margin: 0; padding-left: 20px; }
body.page-policy.page-terms .policy-note{ padding: 20px 22px; border-radius: 22px; background: rgba(42,197,88,0.08); border: 1px solid rgba(42,197,88,0.14); }
body.page-policy.page-terms .footer{ background: var(--navy); color: rgba(255,255,255,0.72); padding: var(--sp-24) var(--sp-10) var(--sp-10); }
body.page-policy.page-terms .footer-inner{ max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--sp-12); padding-bottom: var(--sp-12); border-bottom: 1px solid rgba(255,255,255,0.1); }
body.page-policy.page-terms .footer-brand{ max-width: 320px; }
body.page-policy.page-terms .footer-logo{ display: flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 800; color: var(--white); font-size: 1.375rem; margin-bottom: var(--sp-4); }
body.page-policy.page-terms .footer-tagline{ color: var(--white); font-weight: 500; margin-bottom: var(--sp-3); }
body.page-policy.page-terms .footer-arn{ font-size: 0.8125rem; color: rgba(255,255,255,0.6); margin-bottom: var(--sp-5); }
body.page-policy.page-terms .footer-col h4{ color: var(--white); font-size: 0.875rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--sp-5); }
body.page-policy.page-terms .footer-col-body{ display: flex; flex-direction: column; gap: var(--sp-3); }
body.page-policy.page-terms .footer-link{ color: rgba(255,255,255,0.72); font-size: 0.9375rem; transition: color var(--dur) var(--ease); }
body.page-policy.page-terms .footer-link:hover{ color: var(--green-light); }
body.page-policy.page-terms .footer-social{ display: flex; gap: var(--sp-3); }
body.page-policy.page-terms .footer-social a{ display: grid; place-items: center; width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.72); transition: all var(--dur) var(--ease); }
body.page-policy.page-terms .footer-social a:hover{ background: var(--green); color: var(--navy); transform: translateY(-2px); }
body.page-policy.page-terms .footer-bottom{ max-width: 1280px; margin: 0 auto; padding-top: var(--sp-6); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--sp-4); font-size: 0.8125rem; color: rgba(255,255,255,0.55); }
body.page-policy.page-terms .footer-bottom-links{ display: flex; gap: var(--sp-6); }
body.page-policy.page-terms .footer-bottom-links a{ transition: color var(--dur) var(--ease); }
body.page-policy.page-terms .footer-bottom-links a:hover{ color: var(--green-light); }
@media (max-width: 1100px){ body.page-policy.page-terms .policy-layout, body.page-policy.page-terms .footer-inner{ grid-template-columns: 1fr; } body.page-policy.page-terms .policy-side{ position: relative; top: auto; } }
@media (max-width: 960px){ body.page-policy.page-terms .container, body.page-policy.page-terms .footer{ padding-left: var(--sp-5); padding-right: var(--sp-5); } body.page-policy.page-terms .nav-links{ gap: var(--sp-5); } body.page-policy.page-terms .nav-login-menu{ width: min(360px, calc(100vw - 40px)); right: -10px; } }
@media (max-width: 760px){ body.page-policy.page-terms .navbar{ padding: 18px 20px; } body.page-policy.page-terms .nav-links{ gap: 14px; } body.page-policy.page-terms .nav-link{ font-size: 0.875rem; } body.page-policy.page-terms .nav-logo img{ height: 48px; } body.page-policy.page-terms .page-top{ padding-top: 120px; padding-bottom: 22px; } body.page-policy.page-terms .policy-card, body.page-policy.page-terms .policy-side{ padding: 24px; } }
@media (max-width: 620px){ body.page-policy.page-terms .navbar{ align-items: flex-start; } body.page-policy.page-terms .nav-links{ flex-wrap: wrap; justify-content: flex-end; row-gap: 10px; } body.page-policy.page-terms .nav-login{ width: 100%; display: flex; justify-content: flex-end; } }
body.page-home .logo-mark-svg { overflow: visible; }
body.page-home .hero-cta-shell { display: inline-block; }
body.page-home .chip-icon { color: var(--green-light); }
body.page-home .sx-contact-btn { width: fit-content; height: 44px; padding: 0 22px; font-size: 0.875rem; }
body.page-home .chart-bar--45 { height: 45%; }
body.page-home .chart-bar--60 { height: 60%; }
body.page-home .chart-bar--80 { height: 80%; }
body.page-about .journey-years-fill { --fill: 0; }
body.page-careers .career-copy-spaced { margin-top: 16px; }
body.page-services .page-lede-strong { color: var(--white); font-weight: 700; }
body.page-home .journey-years-fill { --fill: 0; }
body.page-policy.page-disclosure .policy-card {
  overflow: hidden;
}
body.page-policy.page-disclosure .policy-section {
  min-width: 0;
}
body.page-policy.page-disclosure .policy-section a,
body.page-policy.page-disclosure .policy-note a {
  color: var(--navy-light);
  text-decoration: underline;
  text-underline-offset: 2px;
  overflow-wrap: anywhere;
}
body.page-policy.page-disclosure .table-wrap {
  background: #fff;
}
body.page-policy.page-disclosure table {
  min-width: 680px;
  font-size: 0.95rem;
}
@media (max-width: 760px) {
  body.page-policy.page-disclosure .policy-card {
    padding: 24px 20px;
  }
  body.page-policy.page-disclosure .policy-intro {
    padding: 18px 18px 0;
    margin: -2px -2px 24px;
  }
  body.page-policy.page-disclosure .policy-section h2 {
    font-size: 1.28rem;
  }
  body.page-policy.page-disclosure table {
    min-width: 620px;
    font-size: 0.9rem;
  }
}

/* Shared UI normalization */
body.page-about .section,
body.page-services .section,
body.page-careers .section,
body.page-contact .section,
body.page-policy.page-disclosure .section,
body.page-policy.page-faq .section,
body.page-policy.page-privacy .section,
body.page-policy.page-terms .section{
	padding: var(--section-space-tight) 0 var(--section-space);
}

body.page-about .page-heading,
body.page-careers .page-heading,
body.page-contact .page-heading,
body.page-policy.page-disclosure .page-heading,
body.page-policy.page-faq .page-heading,
body.page-policy.page-privacy .page-heading,
body.page-policy.page-terms .page-heading,
body.page-services .page-title{
	font-size: var(--title-lg);
	line-height: 1.08;
	letter-spacing: -0.02em;
}

body.page-services .page-lede,
body.page-about .section-copy,
body.page-services .section-copy,
body.page-careers .section-copy,
body.page-contact .contact-panel p,
body.page-contact .contact-form p,
body.page-policy .page-subcopy{
	font-size: var(--copy-lg);
	line-height: 1.72;
}

body.page-about .section-head,
body.page-services .section-head,
body.page-careers .section-head{
	align-items: end;
	gap: var(--sp-6);
}

body.page-about .section-title,
body.page-services .section-title,
body.page-careers .section-title{
	font-size: var(--title-xl);
	line-height: 1.08;
}

body.page-home .le-btn,
body.page-about .le-btn,
body.page-services .le-btn,
body.page-careers .le-btn,
body.page-contact .le-btn{
	transition: background-color var(--dur) var(--ease),
	            color var(--dur) var(--ease),
	            border-color var(--dur) var(--ease),
	            box-shadow 0.35s var(--ease),
	            transform 0.35s var(--ease);
}

body.page-home .le-btn:hover,
body.page-about .le-btn:hover,
body.page-services .le-btn:hover,
body.page-careers .le-btn:hover,
body.page-contact .le-btn:hover{
	transform: translateY(-2px);
}

body.page-home .solution,
body.page-home .sx-tile,
body.page-about .mission-card,
body.page-services .hero-stat-panel,
body.page-services .blueprint-card,
body.page-services .service-card,
body.page-careers .career-block,
body.page-careers .opportunity-panel,
body.page-contact .contact-panel,
body.page-contact .contact-form,
body.page-policy.page-disclosure .policy-card,
body.page-policy.page-disclosure .policy-side,
body.page-policy.page-faq .faq-card,
body.page-policy.page-faq .faq-side,
body.page-policy.page-privacy .policy-card,
body.page-policy.page-privacy .policy-side,
body.page-policy.page-terms .policy-card,
body.page-policy.page-terms .policy-side{
	transition: transform 0.35s var(--ease), box-shadow 0.35s var(--ease), border-color 0.35s var(--ease), background-color 0.35s var(--ease);
}

body.page-home .solution:hover,
body.page-home .sx-tile:hover,
body.page-about .mission-card:hover,
body.page-services .hero-stat-panel:hover,
body.page-services .blueprint-card:hover,
body.page-services .service-card:hover,
body.page-careers .career-block:hover,
body.page-careers .opportunity-panel:hover,
body.page-contact .contact-panel:hover,
body.page-contact .contact-form:hover,
body.page-policy.page-disclosure .policy-card:hover,
body.page-policy.page-disclosure .policy-side:hover,
body.page-policy.page-faq .faq-card:hover,
body.page-policy.page-faq .faq-side:hover,
body.page-policy.page-privacy .policy-card:hover,
body.page-policy.page-privacy .policy-side:hover,
body.page-policy.page-terms .policy-card:hover,
body.page-policy.page-terms .policy-side:hover{
	transform: translateY(-4px);
	box-shadow: var(--sh-md);
}

body.page-home .solution:hover,
body.page-home .sx-tile:hover,
body.page-about .mission-card:hover,
body.page-services .hero-stat-panel:hover,
body.page-services .blueprint-card:hover,
body.page-services .service-card:hover,
body.page-careers .career-block:hover,
body.page-careers .opportunity-panel:hover,
body.page-contact .contact-panel:hover,
body.page-contact .contact-form:hover,
body.page-policy.page-disclosure .policy-card:hover,
body.page-policy.page-disclosure .policy-side:hover,
body.page-policy.page-faq .faq-card:hover,
body.page-policy.page-faq .faq-side:hover,
body.page-policy.page-privacy .policy-card:hover,
body.page-policy.page-privacy .policy-side:hover,
body.page-policy.page-terms .policy-card:hover,
body.page-policy.page-terms .policy-side:hover{
	border-color: rgba(42,197,88,0.16);
}

body.page-contact .contact-panel,
body.page-contact .contact-form,
body.page-policy.page-disclosure .policy-card,
body.page-policy.page-disclosure .policy-side,
body.page-policy.page-privacy .policy-card,
body.page-policy.page-privacy .policy-side,
body.page-policy.page-terms .policy-card,
body.page-policy.page-terms .policy-side{
	border: 1px solid var(--surface-border);
}

body.page-about .story-card p,
body.page-about .mission-card p,
body.page-services .blueprint-card p,
body.page-services .service-card p,
body.page-careers .career-block p,
body.page-careers .opportunity-panel p,
body.page-contact .contact-copy,
body.page-policy .policy-section p,
body.page-policy .policy-section li{
	line-height: 1.72;
}

body.page-about .mission-card h4,
body.page-services .blueprint-card h3,
body.page-services .service-card h4,
body.page-careers .career-block-title,
body.page-careers .opportunity-panel h3,
body.page-contact .contact-panel h2,
body.page-contact .contact-form h2,
body.page-policy .policy-section h2{
	line-height: 1.15;
	letter-spacing: -0.02em;
}

@media (max-width: 900px){
	body.page-about .section,
	body.page-services .section,
	body.page-careers .section,
	body.page-contact .section,
	body.page-policy.page-disclosure .section,
	body.page-policy.page-faq .section,
	body.page-policy.page-privacy .section,
	body.page-policy.page-terms .section{
		padding: 72px 0;
	}

	body.page-about .section-head,
	body.page-services .section-head,
	body.page-careers .section-head{
		gap: var(--sp-5);
	}
}

/* Responsive hardening */
body.page-home .hero-copy,
body.page-home .hero-chips,
body.page-home .services-copy,
body.page-home .team-copy,
body.page-about .about-copy,
body.page-about .about-image,
body.page-services .page-hero-grid > *,
body.page-services .section-head > *,
body.page-careers .career-layout > *,
body.page-contact .contact-layout > *,
body.page-policy .policy-layout > *{
	min-width: 0;
}

body.page-home .hero-title,
body.page-services .page-title,
body.page-about .about-heading,
body.page-about .section-title,
body.page-services .section-title,
body.page-careers .page-heading,
body.page-contact .page-heading,
body.page-policy .page-heading{
	overflow-wrap: anywhere;
}

@media (max-width: 1100px){
	body.page-home .hero-inner{
		flex-direction: column;
		align-items: flex-start;
	}
	body.page-home .hero-chips{
		width: 100%;
		flex-direction: row;
		flex-wrap: wrap;
		gap: var(--sp-3);
	}
	body.page-home .chip,
	body.page-home .chip:nth-child(2),
	body.page-home .chip:nth-child(3){
		align-self: auto;
		margin-left: 0;
	}
	body.page-home .team-grid,
	body.page-about .team-grid{
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 900px){
	body.page-home .hero{
		padding: 128px var(--sp-5) 72px;
	}
	body.page-home .hero-center-logo{
		width: 190px;
		height: 190px;
	}
	body.page-home.home-intro-skip .hero-center-logo{
		top: 36%;
		left: 80%;
		transform: translate(-50%, -50%) scale(0.62);
	}
	body.page-home .hero-title{
		font-size: clamp(2rem, 10vw, 3rem);
	}
	body.page-home .hero-ctas{
		width: 100%;
	}
	body.page-home .hero-ctas .le-btn{
		flex: 1 1 220px;
	}
	body.page-home .journey-metrics,
	body.page-about .journey-metrics{
		flex-wrap: wrap;
		justify-content: flex-start;
	}
	body.page-about .about-intro,
	body.page-services .page-hero-grid,
	body.page-contact .contact-layout{
		grid-template-columns: 1fr;
	}
	body.page-services .blueprint-grid{
		grid-template-columns: 1fr;
	}
	body.page-services .solution-cards--three,
	body.page-services .solution-cards--four{
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	body.page-contact .contact-item{
		grid-template-columns: 48px minmax(0, 1fr);
	}
	body.page-contact .contact-icon{
		width: 48px;
		height: 48px;
	}
}

@media (max-width: 700px){
	body.page-home .services-grid,
	body.page-home .team-grid,
	body.page-about .team-grid,
	body.page-services .solution-cards--three,
	body.page-services .solution-cards--four{
		grid-template-columns: 1fr;
	}
	body.page-services .service-card,
	body.page-services .blueprint-card,
	body.page-careers .career-block,
	body.page-careers .opportunity-panel,
	body.page-contact .contact-panel,
	body.page-contact .contact-form,
	body.page-policy.page-disclosure .policy-card,
	body.page-policy.page-disclosure .policy-side,
	body.page-policy.page-privacy .policy-card,
	body.page-policy.page-privacy .policy-side,
	body.page-policy.page-terms .policy-card,
	body.page-policy.page-terms .policy-side{
		padding: 24px 20px;
	}
}

@media (max-width: 560px){
	body.page-home .le-btn,
	body.page-home .le-btn--lg,
	body.page-about .le-btn,
	body.page-about .le-btn--lg,
	body.page-services .le-btn,
	body.page-services .le-btn--lg,
	body.page-careers .le-btn,
	body.page-careers .le-btn--lg,
	body.page-contact .le-btn,
	body.page-contact .le-btn--lg{
		height: auto;
		min-height: 52px;
		padding: 14px 20px;
		white-space: normal;
		line-height: 1.35;
	}
	body.page-home .hero{
		padding: 118px 20px 64px;
	}
	body.page-home .hero-center-logo{
		width: 150px;
		height: 150px;
	}
	body.page-home.home-intro-skip .hero-center-logo{
		top: 33%;
		left: 76%;
		transform: translate(-50%, -50%) scale(0.54);
	}
	body.page-home .hero-chips{
		flex-direction: column;
		align-items: stretch;
	}
	body.page-home .chip{
		width: 100%;
		justify-content: flex-start;
	}
	body.page-home .values-inner,
	body.page-home .journey-inner,
	body.page-about .journey-inner{
		padding-inline: 20px;
	}
	body.page-home .journey-years,
	body.page-about .journey-years{
		margin-left: 0;
		padding-inline: 18px;
	}
	body.page-home .journey-panel,
	body.page-about .journey-panel{
		padding-left: 22px;
	}
	body.page-services .page-hero{
		padding-top: 136px;
		padding-bottom: 72px;
	}
	body.page-services .page-hero-actions,
	body.page-careers .cta-actions,
	body.page-home .cta-actions,
	body.page-services .cta-actions,
	body.page-contact .field--full .le-btn{
		width: 100%;
	}
	body.page-services .page-hero-actions .le-btn,
	body.page-home .hero-ctas .le-btn,
	body.page-careers .cta-actions .le-btn,
	body.page-home .cta-actions .le-btn,
	body.page-services .cta-actions .le-btn,
	body.page-contact .field--full .le-btn{
		width: 100%;
	}
	body.page-careers .career-block-head{
		align-items: flex-start;
		gap: 12px;
	}
	body.page-contact .contact-item{
		grid-template-columns: 1fr;
	}
	body.page-contact .contact-icon{
		margin-bottom: 2px;
	}
	body.page-policy .policy-layout,
	body.page-policy.page-privacy .policy-layout,
	body.page-policy.page-terms .policy-layout{
		grid-template-columns: 1fr;
	}
	body.page-policy .table-wrap{
		margin-inline: -4px;
	}
}

@media (max-width: 680px){
	body.page-home .nav-toggle,
	body.page-about .nav-toggle,
	body.page-services .nav-toggle,
	body.page-careers .nav-toggle,
	body.page-contact .nav-toggle,
	body.page-policy.page-disclosure .nav-toggle,
	body.page-policy.page-faq .nav-toggle,
	body.page-policy.page-privacy .nav-toggle,
	body.page-policy.page-terms .nav-toggle{
		display: inline-flex;
	}

	body.page-home .nav-links,
	body.page-about .nav-links,
	body.page-services .nav-links,
	body.page-careers .nav-links,
	body.page-contact .nav-links,
	body.page-policy.page-disclosure .nav-links,
	body.page-policy.page-faq .nav-links,
	body.page-policy.page-privacy .nav-links,
	body.page-policy.page-terms .nav-links{
		position: absolute;
		top: calc(100% + 12px);
		left: 20px;
		right: 20px;
		width: auto;
		display: none;
		flex-direction: column;
		align-items: stretch;
		justify-content: flex-start;
		gap: 12px;
		padding: 18px;
		border-radius: 24px;
		background: rgba(255,255,255,0.98);
		border: 1px solid rgba(7,31,69,0.08);
		box-shadow: 0 24px 48px rgba(7,31,69,0.14);
	}

	body.page-home .nav-links.is-open,
	body.page-about .nav-links.is-open,
	body.page-services .nav-links.is-open,
	body.page-careers .nav-links.is-open,
	body.page-contact .nav-links.is-open,
	body.page-policy.page-disclosure .nav-links.is-open,
	body.page-policy.page-faq .nav-links.is-open,
	body.page-policy.page-privacy .nav-links.is-open,
	body.page-policy.page-terms .nav-links.is-open{
		display: flex;
	}

	body.page-home .nav-link,
	body.page-about .nav-link,
	body.page-services .nav-link,
	body.page-careers .nav-link,
	body.page-contact .nav-link,
	body.page-policy.page-disclosure .nav-link,
	body.page-policy.page-faq .nav-link,
	body.page-policy.page-privacy .nav-link,
	body.page-policy.page-terms .nav-link{
		font-size: 0.95rem;
		color: var(--navy) !important;
	}

	body.page-home .nav-login,
	body.page-about .nav-login,
	body.page-services .nav-login,
	body.page-careers .nav-login,
	body.page-contact .nav-login,
	body.page-policy.page-disclosure .nav-login,
	body.page-policy.page-faq .nav-login,
	body.page-policy.page-privacy .nav-login,
	body.page-policy.page-terms .nav-login{
		width: 100%;
		padding-bottom: 0;
		margin-bottom: 0;
	}

	body.page-home .nav-login-toggle,
	body.page-about .nav-login-toggle,
	body.page-services .nav-login-toggle,
	body.page-careers .nav-login-toggle,
	body.page-contact .nav-login-toggle,
	body.page-policy.page-disclosure .nav-login-toggle,
	body.page-policy.page-faq .nav-login-toggle,
	body.page-policy.page-privacy .nav-login-toggle,
	body.page-policy.page-terms .nav-login-toggle{
		width: 100%;
		justify-content: space-between;
		color: var(--navy) !important;
		border-color: rgba(7,31,69,0.1) !important;
		background: rgba(247,248,250,1) !important;
		box-shadow: none !important;
	}
}

body.page-home .journey-tree-viz,
body.page-about .journey-tree-viz{
	background:
		radial-gradient(80% 52% at 50% 100%, rgba(42,197,88,0.12) 0%, transparent 62%),
		linear-gradient(180deg, #FFFFFF 0%, #F5F8F3 56%, #EEF5EA 100%);
}

body.page-home .tree-trunk-org,
body.page-about .tree-trunk-org,
body.page-home .tree-branches-org,
body.page-about .tree-branches-org,
body.page-home .tree-foliage-org,
body.page-about .tree-foliage-org,
body.page-home .tree-mature-org,
body.page-about .tree-mature-org,
body.page-home .tree-mature-fruits,
body.page-about .tree-mature-fruits,
body.page-home .tree-sapling-focus,
body.page-about .tree-sapling-focus{
	transform-box: fill-box;
	transform-origin: center bottom;
	will-change: opacity, transform, filter;
}

body.page-home .tree-trunk-org,
body.page-about .tree-trunk-org,
body.page-home .tree-branches-org,
body.page-about .tree-branches-org,
body.page-home .tree-foliage-org,
body.page-about .tree-foliage-org,
body.page-home .tree-mature-org,
body.page-about .tree-mature-org,
body.page-home .tree-fruits-org,
body.page-about .tree-fruits-org,
body.page-home .tree-fruit-mark,
body.page-about .tree-fruit-mark,
body.page-home .tree-seed-org,
body.page-about .tree-seed-org{
	opacity: 0;
	pointer-events: none;
}

body.page-home .tree-sapling-focus,
body.page-about .tree-sapling-focus{
	opacity: 1;
	transform: translateY(0) scale(0.9);
	filter: drop-shadow(0 12px 12px rgba(42,197,88,0.16));
	transition: opacity 0.55s ease, transform 0.75s var(--ease), filter 0.55s ease;
}

body.page-home .journey-tree-viz[data-tree-stage="1"] .tree-sapling-focus,
body.page-about .journey-tree-viz[data-tree-stage="1"] .tree-sapling-focus,
body.page-home .journey-tree-viz[data-tree-stage="2"] .tree-sapling-focus,
body.page-about .journey-tree-viz[data-tree-stage="2"] .tree-sapling-focus{
	opacity: 0;
	transform: translateY(18px) scale(0.86);
	filter: none;
}

body.page-home .tree-trunk-org,
body.page-about .tree-trunk-org{
	transform: translateY(12px) scale(0.66, 0.7);
	transition: opacity 0.7s ease, transform 0.9s var(--ease), filter 0.7s ease;
}

body.page-home .tree-branches-org,
body.page-about .tree-branches-org{
	transform: translateY(14px) scale(0.72);
	transition: opacity 0.7s ease 0.08s, transform 0.95s var(--ease) 0.08s;
}

body.page-home .tree-foliage-org,
body.page-about .tree-foliage-org{
	transform: translateY(16px) scale(0.76);
	filter: saturate(0.98);
	transition: opacity 0.75s ease 0.12s, transform 1s var(--ease) 0.12s, filter 0.75s ease;
}

body.page-home .tree-trunk-org.s1,
body.page-about .tree-trunk-org.s1,
body.page-home .tree-branches-org.s1,
body.page-about .tree-branches-org.s1,
body.page-home .tree-foliage-org.s1,
body.page-about .tree-foliage-org.s1{
	opacity: 1;
	transform: translateY(0) scale(0.86);
	filter: saturate(1.02);
}

body.page-home .tree-trunk-org.s2,
body.page-about .tree-trunk-org.s2,
body.page-home .tree-branches-org.s2,
body.page-about .tree-branches-org.s2{
	opacity: 1;
	transform: translateY(0) scale(0.92);
	filter: saturate(1.08);
}

body.page-home .tree-foliage-org.s2,
body.page-about .tree-foliage-org.s2{
	opacity: 0;
	transform: translateY(0) scale(0.92);
	filter: saturate(1.08);
}

body.page-home .tree-mature-org,
body.page-about .tree-mature-org{
	transform: translateY(12px) scale(0.82);
	filter: saturate(1.08) drop-shadow(0 18px 18px rgba(25,92,42,0.08));
	transition: opacity 0.78s ease 0.08s, transform 1.05s var(--ease) 0.08s, filter 0.85s ease;
}

body.page-home .journey-tree-viz[data-tree-stage="2"] .tree-mature-org,
body.page-about .journey-tree-viz[data-tree-stage="2"] .tree-mature-org{
	opacity: 1;
	transform: translateY(0) scale(0.92);
}

body.page-home .tree-mature-fruits,
body.page-about .tree-mature-fruits{
	transform: translateY(8px) scale(0.86);
	opacity: 0;
	transition: opacity 0.7s ease 0.42s, transform 0.9s var(--ease) 0.42s;
}

body.page-home .journey-tree-viz[data-tree-stage="2"] .tree-mature-fruits,
body.page-about .journey-tree-viz[data-tree-stage="2"] .tree-mature-fruits{
	opacity: 1;
	transform: translateY(0) scale(1);
}

body.page-home .journey-sticky,
body.page-about .journey-sticky{
	min-height: 100svh;
	height: auto;
	overflow: visible;
	padding: clamp(64px, 7vh, 96px) 0;
}

body.page-home .journey-inner,
body.page-about .journey-inner{
	align-items: center;
}

body.page-home .journey-right,
body.page-about .journey-right{
	height: 100%;
	max-height: none;
	min-height: 0;
	justify-content: center;
}

body.page-home .journey-panels,
body.page-about .journey-panels{
	min-height: clamp(300px, 44vh, 390px);
}

body.page-home .journey-tree-viz,
body.page-about .journey-tree-viz{
	--tree-gap: clamp(14px, 2.4vh, 24px);
	position: relative;
	flex: 1 1 auto;
	height: auto;
	min-height: clamp(300px, 38vh, 440px);
	max-height: none;
	overflow: hidden;
	padding: 0;
}

body.page-home .journey-tree-viz svg,
body.page-about .journey-tree-viz svg{
	position: absolute;
	left: 50%;
	bottom: var(--tree-gap);
	width: clamp(260px, 72%, 520px);
	height: auto;
	max-height: calc(100% - (var(--tree-gap) * 2));
	transform: translateX(-50%);
	transform-origin: center bottom;
}

@media (max-height: 760px) and (min-width: 1025px){
	body.page-home .journey-sticky,
	body.page-about .journey-sticky{
		padding: 58px 0;
	}

	body.page-home .journey-inner,
	body.page-about .journey-inner{
		gap: var(--sp-10);
	}

	body.page-home .journey-stories-head,
	body.page-about .journey-stories-head{
		margin-bottom: var(--sp-5);
	}

	body.page-home .journey-panels,
	body.page-about .journey-panels{
		min-height: 285px;
	}

	body.page-home .journey-pbody,
	body.page-about .journey-pbody{
		font-size: 0.98rem;
		line-height: 1.62;
	}

	body.page-home .journey-tree-viz,
	body.page-about .journey-tree-viz{
		--tree-gap: 16px;
		min-height: clamp(260px, 35vh, 360px);
	}

	body.page-home .journey-tree-viz svg,
	body.page-about .journey-tree-viz svg{
		width: clamp(220px, 58%, 360px);
	}
}

@media (max-width: 1024px){
	body.page-home .journey-sticky,
	body.page-about .journey-sticky{
		min-height: 0;
		padding: var(--sp-16) 0;
	}

	body.page-home .journey-right,
	body.page-about .journey-right{
		width: 100%;
		height: auto;
	}

	body.page-home .journey-tree-viz,
	body.page-about .journey-tree-viz{
		--tree-gap: 16px;
		flex: 0 0 auto;
		height: clamp(300px, 58vw, 460px);
		min-height: 300px;
	}

	body.page-home .journey-tree-viz svg,
	body.page-about .journey-tree-viz svg{
		width: clamp(260px, 72%, 430px);
	}
}

@media (max-width: 560px){
	body.page-home .journey-sticky,
	body.page-about .journey-sticky{
		padding: 48px 0;
	}

	body.page-home .journey-tree-viz,
	body.page-about .journey-tree-viz{
		--tree-gap: 14px;
		flex: 0 0 auto;
		height: clamp(280px, 82vw, 380px);
		min-height: 280px;
	}

	body.page-home .journey-tree-viz svg,
	body.page-about .journey-tree-viz svg{
		width: clamp(230px, 78%, 330px);
	}

	body.page-home .journey-metrics,
	body.page-about .journey-metrics{
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 12px;
		padding: 16px;
	}
}
/* Home phone-only finishing touches */
@media (max-width: 760px){
	body.page-home .hero-bg-photo{
		background:
			linear-gradient(180deg, rgba(7,31,69,0.72) 0%, rgba(7,31,69,0.48) 38%, rgba(7,31,69,0.28) 100%),
			url('../assets/images/hero-family-bg.png') 68% center / cover no-repeat;
	}

	body.page-home .hero-cta-shell{
		display: none;
	}

	body.page-home .hero-ctas .le-btn{
		flex: 0 1 auto;
		width: auto;
	}

	body.page-home.home-intro-skip .hero-center-logo{
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%) scale(0.72);
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
	}

	body.page-home.home-intro-skip .hero-center-logo::before,
	body.page-home.home-intro-skip .hero-center-logo::after{
		opacity: 0;
	}

	body.page-home .team-portraits{
		grid-template-columns: 1fr;
		justify-content: stretch;
	}

	body.page-about .about-image{
		display: none;
	}
}

/* Home Journey mobile pinned layout */
@media (max-width: 760px){
	body.page-home .journey-scroller{
		height: 320svh;
	}

	body.page-home .journey-sticky{
		position: sticky;
		top: 0;
		height: 100svh;
		min-height: 100svh;
		padding: 92px 20px 22px;
		overflow: hidden;
		align-items: stretch;
		background:
			radial-gradient(circle at 50% 28%, rgba(42,197,88,0.08) 0%, transparent 44%),
			linear-gradient(180deg, #F7F8FA 0%, #EEF1F6 100%);
	}

	body.page-home .journey-inner{
		width: 100%;
		height: 100%;
		max-width: 420px;
		margin: 0 auto;
		padding: 0;
		display: grid;
		grid-template-columns: 1fr;
		grid-template-rows: auto clamp(210px, 37svh, 310px) minmax(205px, 1fr) auto;
		gap: 12px;
		align-items: stretch;
	}

	body.page-home .journey-left,
	body.page-home .journey-stories{
		display: contents;
	}

	body.page-home .journey-stories-head{
		grid-row: 1;
		display: flex;
		align-items: center;
		justify-content: flex-start;
		margin: 0;
	}

	body.page-home .journey-stories-head .eyebrow{
		font-size: 0.72rem;
		letter-spacing: 0.12em;
	}

	body.page-home .journey-right{
		grid-row: 2;
		order: 0;
		width: 100%;
		height: 100%;
		max-height: none;
		display: block;
	}

	body.page-home .journey-metrics{
		display: none;
	}

	body.page-home .journey-tree-viz{
		width: 100%;
		height: 100%;
		min-height: 0;
		max-height: none;
		border-radius: 0 0 28px 28px;
		box-shadow: 0 20px 42px rgba(7,31,69,0.08);
	}

	body.page-home .journey-tree-viz svg{
		width: min(94%, 330px);
		height: 94%;
	}

	body.page-home .journey-panels{
		grid-row: 3;
		position: relative;
		width: 100%;
		min-height: 0;
	}

	body.page-home .journey-panel{
		position: absolute;
		inset: 0;
		padding: 0;
		border-left: 0;
		margin: 0;
		opacity: 0;
		transform: translateY(18px);
		pointer-events: none;
		display: flex;
		flex-direction: column;
		justify-content: center;
		text-align: left;
	}

	body.page-home .journey-panel.active{
		opacity: 1;
		transform: translateY(0);
		pointer-events: auto;
	}

	body.page-home .journey-panel::before{
		display: none;
	}

	body.page-home .journey-panel-head{
		justify-content: flex-start;
		gap: 14px;
		margin-bottom: 18px;
	}

	body.page-home .journey-chapter{
		padding: 7px 14px;
		font-size: 0.68rem;
	}

	body.page-home .journey-year{
		font-size: 0.82rem;
	}

	body.page-home .journey-ptitle{
		font-size: clamp(1.55rem, 7vw, 2rem);
		line-height: 1.1;
		margin-bottom: 16px;
	}

	body.page-home .journey-pbody{
		max-width: 33ch;
		font-size: 0.96rem;
		line-height: 1.58;
		color: var(--navy);
	}

	body.page-home .journey-years{
		grid-row: 4;
		width: 100%;
		max-width: none;
		margin: 0;
		padding: 18px 20px 16px;
		border-radius: 22px;
	}
}

@media (max-width: 420px){
	body.page-home .journey-sticky{
		padding: 86px 20px 20px;
	}

	body.page-home .journey-inner{
		grid-template-rows: auto clamp(190px, 34svh, 270px) minmax(205px, 1fr) auto;
		gap: 10px;
	}

	body.page-home .journey-tree-viz svg{
		width: min(90%, 290px);
	}

	body.page-home .journey-panel-head{
		margin-bottom: 14px;
	}

	body.page-home .journey-ptitle{
		font-size: clamp(1.42rem, 6.4vw, 1.75rem);
		margin-bottom: 12px;
	}

	body.page-home .journey-pbody{
		font-size: 0.9rem;
		line-height: 1.52;
	}

	body.page-home .journey-years{
		padding: 16px 18px 14px;
	}
}

/* Home Journey mobile polish */
@media (max-width: 760px){
	body.page-home .journey-inner{
		grid-template-rows: auto auto clamp(190px, 33svh, 285px) minmax(215px, 1fr) auto;
		justify-items: stretch;
	}

	body.page-home .journey-stories-head{
		justify-content: flex-start;
		text-align: left;
		width: 100%;
	}

	body.page-home .journey-right{
		display: contents;
	}

	body.page-home .journey-metrics{
		grid-row: 2;
		width: 100%;
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 10px;
		padding: 12px 14px;
		border-radius: 18px;
	}

	body.page-home .journey-metric-big{
		font-size: clamp(1.8rem, 8vw, 2.35rem);
	}

	body.page-home .journey-metric-label{
		font-size: 0.62rem;
		line-height: 1.2;
	}

	body.page-home .journey-tree-viz{
		grid-row: 3;
	}

	body.page-home .journey-panels{
		grid-row: 4;
	}

	body.page-home .journey-years{
		grid-row: 5;
	}

	body.page-home .journey-panel,
	body.page-home .journey-pbody{
		width: 100%;
		max-width: none;
	}
}

@media (max-width: 420px){
	body.page-home .journey-inner{
		grid-template-rows: auto auto clamp(160px, 28svh, 220px) minmax(230px, 1fr) auto;
	}

	body.page-home .journey-metrics{
		padding: 10px 12px;
	}

	body.page-home .journey-metric-big{
		font-size: 1.7rem;
	}
}

/* Shared Home/About mobile Journey alignment */
@media (max-width: 760px){
	:is(body.page-home, body.page-about) .journey-scroller{
		height: 320svh;
	}

	:is(body.page-home, body.page-about) .journey-sticky{
		position: sticky;
		top: 0;
		height: 100svh;
		min-height: 100svh;
		padding: 92px 20px 22px;
		overflow: hidden;
		align-items: stretch;
		background:
			radial-gradient(circle at 50% 28%, rgba(42,197,88,0.08) 0%, transparent 44%),
			linear-gradient(180deg, #F7F8FA 0%, #EEF1F6 100%);
	}

	:is(body.page-home, body.page-about) .journey-inner{
		width: 100%;
		height: 100%;
		max-width: 420px;
		margin: 0 auto;
		padding: 0;
		display: grid;
		grid-template-columns: 1fr;
		grid-template-rows: auto auto clamp(190px, 33svh, 285px) minmax(215px, 1fr) auto;
		gap: 12px;
		align-items: stretch;
		justify-items: stretch;
	}

	:is(body.page-home, body.page-about) .journey-left,
	:is(body.page-home, body.page-about) .journey-stories{
		display: contents;
	}

	:is(body.page-home, body.page-about) .journey-stories-head{
		grid-row: 1;
		width: 100%;
		display: flex;
		align-items: center;
		justify-content: flex-start;
		text-align: left;
		margin: 0;
	}

	:is(body.page-home, body.page-about) .journey-stories-head .eyebrow{
		align-self: flex-start;
		font-size: 0.72rem;
		letter-spacing: 0.12em;
	}

	:is(body.page-home, body.page-about) .journey-right{
		display: contents;
	}

	:is(body.page-home, body.page-about) .journey-metrics{
		grid-row: 2;
		width: 100%;
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 16px;
		padding: 16px 20px 14px;
		border-radius: 18px;
	}

	:is(body.page-home, body.page-about) .journey-metric{
		gap: 7px;
	}

	:is(body.page-home, body.page-about) .journey-metric-big{
		font-size: clamp(1.8rem, 8vw, 2.35rem);
		line-height: 1;
	}

	:is(body.page-home, body.page-about) .journey-metric-label{
		font-size: 0.62rem;
		line-height: 1.2;
	}

	:is(body.page-home, body.page-about) .journey-tree-viz{
		grid-row: 3;
		width: 100%;
		height: 100%;
		min-height: 0;
		max-height: none;
		border-radius: 0 0 28px 28px;
		box-shadow: 0 20px 42px rgba(7,31,69,0.08);
	}

	:is(body.page-home, body.page-about) .journey-tree-viz svg{
		width: min(94%, 330px);
		height: 94%;
	}

	:is(body.page-home, body.page-about) .journey-panels{
		grid-row: 4;
		position: relative;
		width: 100%;
		min-height: 0;
	}

	:is(body.page-home, body.page-about) .journey-panel{
		position: absolute;
		inset: 0;
		padding: 0;
		border-left: 0;
		margin: 0;
		opacity: 0;
		transform: translateY(18px);
		pointer-events: none;
		display: flex;
		flex-direction: column;
		justify-content: center;
		text-align: left;
	}

	:is(body.page-home, body.page-about) .journey-panel.active{
		opacity: 1;
		transform: translateY(0);
		pointer-events: auto;
	}

	:is(body.page-home, body.page-about) .journey-panel::before{
		display: none;
	}

	:is(body.page-home, body.page-about) .journey-panel-head{
		justify-content: flex-start;
		gap: 14px;
		margin-bottom: 18px;
	}

	:is(body.page-home, body.page-about) .journey-chapter{
		padding: 7px 14px;
		font-size: 0.68rem;
	}

	:is(body.page-home, body.page-about) .journey-year{
		font-size: 0.82rem;
	}

	:is(body.page-home, body.page-about) .journey-ptitle{
		font-size: clamp(1.55rem, 7vw, 2rem);
		line-height: 1.1;
		margin-bottom: 16px;
	}

	:is(body.page-home, body.page-about) .journey-pbody{
		width: 100%;
		max-width: none;
		font-size: 0.96rem;
		line-height: 1.58;
		color: var(--navy);
	}

	:is(body.page-home, body.page-about) .journey-years{
		grid-row: 5;
		width: 100%;
		max-width: none;
		margin: 0;
		padding: 18px 20px 16px;
		border-radius: 22px;
	}

	body.page-home .team{
		padding-left: 0;
		padding-right: 0;
	}

	body.page-home .team > .container{
		width: min(1280px, calc(100% - 40px));
	}

	body.page-home .team-layout{
		gap: var(--sp-8);
	}
}

@media (max-width: 420px){
	:is(body.page-home, body.page-about) .journey-sticky{
		padding: 86px 20px 20px;
	}

	:is(body.page-home, body.page-about) .journey-inner{
		grid-template-rows: auto auto clamp(175px, 30svh, 235px) minmax(215px, 1fr) auto;
	}

	:is(body.page-home, body.page-about) .journey-metrics{
		gap: 12px;
		padding: 14px 16px 12px;
	}

	:is(body.page-home, body.page-about) .journey-metric{
		gap: 6px;
	}

	:is(body.page-home, body.page-about) .journey-metric-big{
		font-size: 1.7rem;
	}

	:is(body.page-home, body.page-about) .journey-tree-viz svg{
		width: min(90%, 290px);
	}

	:is(body.page-home, body.page-about) .journey-panel-head{
		margin-bottom: 14px;
	}

	:is(body.page-home, body.page-about) .journey-ptitle{
		font-size: clamp(1.42rem, 6.4vw, 1.75rem);
		margin-bottom: 12px;
	}

	:is(body.page-home, body.page-about) .journey-pbody{
		font-size: 0.9rem;
		line-height: 1.52;
	}

	:is(body.page-home, body.page-about) .journey-years{
		padding: 16px 18px 14px;
	}
}

/* Home Values mobile pinned layout */
@media (max-width: 760px){
	body.page-home .values-scroller{
		height: 300svh;
	}

	body.page-home .values-sticky{
		position: sticky;
		top: 0;
		height: 100svh;
		min-height: 100svh;
		padding: 92px 20px 30px;
		overflow: hidden;
		align-items: stretch;
		background:
			radial-gradient(circle at 50% 28%, rgba(42,197,88,0.08) 0%, transparent 48%),
			linear-gradient(180deg, #F8FAFC 0%, #F0F3F7 100%);
	}

	body.page-home .values-inner{
		width: 100%;
		height: 100%;
		max-width: 420px;
		margin: 0 auto;
		padding: 0;
		display: grid;
		grid-template-columns: 1fr;
		grid-template-rows: clamp(285px, 48svh, 390px) minmax(280px, 1fr);
		gap: 22px;
		align-items: stretch;
		justify-items: stretch;
		text-align: left;
	}

	body.page-home .values-logo-col{
		width: 100%;
		height: 100%;
		display: flex;
		align-items: center;
		justify-content: center;
	}

	body.page-home .values-logo{
		width: min(86%, 324px);
		max-width: none;
		height: auto;
		transform: none;
		filter: drop-shadow(0 26px 42px rgba(7,31,69,0.08));
	}

	body.page-home .values-text-col{
		position: relative;
		width: 100%;
		height: 100%;
		min-height: 0;
	}

	body.page-home .values-panel{
		position: absolute;
		inset: 0;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: flex-start;
		width: 100%;
		margin: 0;
		padding: 0;
		opacity: 0;
		transform: translateY(18px);
		visibility: hidden;
		pointer-events: none;
		text-align: left;
	}

	body.page-home .values-panel.active{
		opacity: 1;
		transform: translateY(0);
		visibility: visible;
		pointer-events: auto;
	}

	body.page-home .values-phase-label{
		justify-content: flex-start;
		margin-bottom: 16px;
		font-size: 0.72rem;
		letter-spacing: 0.14em;
	}

	body.page-home .values-phase-title{
		width: 100%;
		max-width: none;
		font-size: clamp(2rem, 9.2vw, 2.7rem);
		line-height: 1.08;
		margin-bottom: 22px;
		letter-spacing: -0.02em;
	}

	body.page-home .values-phase-details{
		width: 100%;
		margin-bottom: 24px;
		gap: 14px;
		align-items: flex-start;
	}

	body.page-home .values-phase-details li{
		align-items: flex-start;
		justify-content: flex-start;
		font-size: 0.98rem;
		line-height: 1.5;
	}

	body.page-home .values-phase-details li::before{
		margin-top: 0.62em;
	}

	body.page-home .values-ctas{
		width: 100%;
		justify-content: flex-start;
		gap: 10px;
		margin-top: 8px;
	}

	body.page-home .values-ctas .le-btn{
		flex: 1 1 0;
		min-width: 0;
		padding-inline: 16px;
		white-space: nowrap;
	}
}

@media (max-width: 420px){
	body.page-home .values-sticky{
		padding: 86px 20px 24px;
	}

	body.page-home .values-inner{
		grid-template-rows: clamp(245px, 42svh, 320px) minmax(300px, 1fr);
		gap: 18px;
	}

	body.page-home .values-logo{
		width: min(86%, 288px);
	}

	body.page-home .values-phase-title{
		font-size: clamp(1.86rem, 8.4vw, 2.3rem);
		margin-bottom: 18px;
	}

	body.page-home .values-phase-details{
		gap: 12px;
		margin-bottom: 20px;
	}

	body.page-home .values-phase-details li{
		font-size: 0.9rem;
		line-height: 1.45;
	}

	body.page-home .values-ctas .le-btn{
		font-size: 0.82rem;
		padding-inline: 12px;
	}
}

/* Footer mobile polish */
@media (max-width: 760px){
	.footer{
		padding: 56px 20px 24px;
	}

	.footer-inner{
		grid-template-columns: 1fr;
		gap: 34px;
		padding-bottom: 34px;
	}

	.footer-brand{
		max-width: none;
	}

	.footer-logo{
		font-size: 1.25rem;
	}

	.footer-tagline,
	.footer-arn{
		max-width: 32ch;
	}

	.footer-col h4{
		margin-bottom: 12px;
	}

	.footer-col-body{
		gap: 10px;
	}

	.footer-bottom{
		align-items: flex-start;
		gap: 14px;
		padding-top: 20px;
	}

	.footer-bottom-links{
		flex-wrap: wrap;
		gap: 14px;
	}
}

/* Tablet responsive parity */
@media (min-width: 761px) and (max-width: 1024px){
	body.page-home .hero-bg-photo{
		background:
			linear-gradient(90deg, rgba(7,31,69,0.74) 0%, rgba(7,31,69,0.5) 42%, rgba(7,31,69,0.22) 100%),
			url('../assets/images/hero-family-bg.png') 66% center / cover no-repeat;
	}

	body.page-home .hero-cta-shell{
		display: none;
	}

	body.page-home .values-scroller{
		height: 300svh;
	}

	body.page-home .values-sticky{
		position: sticky;
		top: 0;
		height: 100svh;
		min-height: 100svh;
		padding: 104px 32px 42px;
		overflow: hidden;
		align-items: stretch;
		background:
			radial-gradient(circle at 50% 28%, rgba(42,197,88,0.08) 0%, transparent 48%),
			linear-gradient(180deg, #F8FAFC 0%, #F0F3F7 100%);
	}

	body.page-home .values-inner{
		width: 100%;
		height: 100%;
		max-width: 720px;
		margin: 0 auto;
		padding: 0;
		display: grid;
		grid-template-columns: 1fr;
		grid-template-rows: clamp(330px, 44svh, 450px) minmax(280px, 1fr);
		gap: 28px;
		align-items: stretch;
		justify-items: stretch;
		text-align: left;
	}

	body.page-home .values-logo-col{
		width: 100%;
		height: 100%;
		display: flex;
		align-items: center;
		justify-content: center;
	}

	body.page-home .values-logo{
		width: min(68%, 414px);
		max-width: none;
		height: auto;
		transform: none;
	}

	body.page-home .values-text-col{
		position: relative;
		width: 100%;
		height: 100%;
		min-height: 0;
	}

	body.page-home .values-panel{
		position: absolute;
		inset: 0;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: flex-start;
		margin: 0;
		padding: 0;
		opacity: 0;
		transform: translateY(18px);
		visibility: hidden;
		pointer-events: none;
		text-align: left;
	}

	body.page-home .values-panel.active{
		opacity: 1;
		transform: translateY(0);
		visibility: visible;
		pointer-events: auto;
	}

	body.page-home .values-phase-title{
		width: 100%;
		max-width: none;
		font-size: clamp(2.35rem, 5.4vw, 3.35rem);
		line-height: 1.08;
		margin-bottom: 24px;
	}

	body.page-home .values-phase-details{
		width: 100%;
		gap: 14px;
		align-items: flex-start;
	}

	body.page-home .values-phase-details li{
		align-items: flex-start;
		justify-content: flex-start;
		font-size: 1rem;
		line-height: 1.5;
	}

	:is(body.page-home, body.page-about) .journey-scroller{
		height: 320svh;
	}

	:is(body.page-home, body.page-about) .journey-sticky{
		position: sticky;
		top: 0;
		height: 100svh;
		min-height: 100svh;
		padding: 104px 32px 34px;
		overflow: hidden;
		align-items: stretch;
		background:
			radial-gradient(circle at 50% 28%, rgba(42,197,88,0.08) 0%, transparent 44%),
			linear-gradient(180deg, #F7F8FA 0%, #EEF1F6 100%);
	}

	:is(body.page-home, body.page-about) .journey-inner{
		width: 100%;
		height: 100%;
		max-width: 720px;
		margin: 0 auto;
		padding: 0;
		display: grid;
		grid-template-columns: 1fr;
		grid-template-rows: auto auto clamp(260px, 34svh, 360px) minmax(230px, 1fr) auto;
		gap: 16px;
		align-items: stretch;
		justify-items: stretch;
	}

	:is(body.page-home, body.page-about) .journey-left,
	:is(body.page-home, body.page-about) .journey-stories{
		display: contents;
	}

	:is(body.page-home, body.page-about) .journey-stories-head{
		grid-row: 1;
		width: 100%;
		display: flex;
		justify-content: flex-start;
		text-align: left;
		margin: 0;
	}

	:is(body.page-home, body.page-about) .journey-right{
		display: contents;
	}

	:is(body.page-home, body.page-about) .journey-metrics{
		grid-row: 2;
		width: 100%;
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 18px;
		padding: 18px 24px 16px;
		border-radius: 20px;
	}

	:is(body.page-home, body.page-about) .journey-tree-viz{
		grid-row: 3;
		width: 100%;
		height: 100%;
		min-height: 0;
		max-height: none;
	}

	:is(body.page-home, body.page-about) .journey-panels{
		grid-row: 4;
		position: relative;
		width: 100%;
		min-height: 0;
	}

	:is(body.page-home, body.page-about) .journey-panel{
		position: absolute;
		inset: 0;
		padding: 0;
		border-left: 0;
		margin: 0;
		opacity: 0;
		transform: translateY(18px);
		pointer-events: none;
		display: flex;
		flex-direction: column;
		justify-content: center;
		text-align: left;
	}

	:is(body.page-home, body.page-about) .journey-panel.active{
		opacity: 1;
		transform: translateY(0);
		pointer-events: auto;
	}

	:is(body.page-home, body.page-about) .journey-panel::before{
		display: none;
	}

	:is(body.page-home, body.page-about) .journey-years{
		grid-row: 5;
		width: 100%;
		max-width: none;
		margin: 0;
	}

	body.page-about .about-image{
		display: none;
	}

	body.page-contact .contact-form{
		order: 1;
	}

	body.page-contact .contact-panel{
		order: 2;
	}

	body.page-careers .opportunity-panel{
		order: 1;
	}

	body.page-careers .career-stack{
		order: 2;
	}

	body.page-home .team > .container{
		width: min(1280px, calc(100% - 64px));
	}

	body.page-home .team-portraits{
		grid-template-columns: 1fr 1fr;
		justify-content: stretch;
	}

	body.page-home .services-grid{
		grid-template-columns: 1fr 1fr;
	}

	.footer{
		padding: 64px 32px 28px;
	}

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

	.footer-brand{
		max-width: none;
	}

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

/* Site-wide section gutter normalization */
:is(
	body.page-home,
	body.page-about,
	body.page-services,
	body.page-careers,
	body.page-contact,
	body.page-policy
){
	--site-gutter: clamp(24px, 4vw, 40px);
}

:is(
	body.page-home,
	body.page-about,
	body.page-services,
	body.page-careers,
	body.page-contact,
	body.page-policy
) .container{
	width: min(1280px, calc(100% - (var(--site-gutter) * 2)));
	padding-left: 0;
	padding-right: 0;
}

:is(
	body.page-home,
	body.page-about,
	body.page-services,
	body.page-careers,
	body.page-contact,
	body.page-policy
) :is(.footer, .cta){
	padding-left: var(--site-gutter);
	padding-right: var(--site-gutter);
}

body.page-home .hero,
body.page-home .journey-inner,
body.page-about .journey-inner{
	padding-left: var(--site-gutter);
	padding-right: var(--site-gutter);
}

body.page-home .values-inner{
	padding-left: var(--site-gutter);
	padding-right: var(--site-gutter);
}

@media (min-width: 761px) and (max-width: 1024px){
	:is(
		body.page-home,
		body.page-about,
		body.page-services,
		body.page-careers,
		body.page-contact,
		body.page-policy
	){
		--site-gutter: 32px;
	}
}

@media (max-width: 760px){
	:is(
		body.page-home,
		body.page-about,
		body.page-services,
		body.page-careers,
		body.page-contact,
		body.page-policy
	){
		--site-gutter: 20px;
	}

	body.page-home .values-sticky,
	:is(body.page-home, body.page-about) .journey-sticky{
		padding-left: var(--site-gutter);
		padding-right: var(--site-gutter);
	}

	body.page-home .values-inner,
	body.page-home .journey-inner,
	body.page-about .journey-inner{
		padding-left: 0;
		padding-right: 0;
	}
}

/* Tablet and phone side-drawer navigation */
@media (max-width: 1024px){
	body.nav-drawer-open{
		overflow: hidden;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .navbar{
		align-items: center;
		padding: 18px var(--site-gutter, 20px);
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .navbar.nav-open,
	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .navbar.nav-open.is-transparent{
		background: rgba(255,255,255,0.96);
		backdrop-filter: blur(16px);
		-webkit-backdrop-filter: blur(16px);
		box-shadow: 0 1px 0 rgba(7,31,69,0.08);
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .navbar.nav-open .nav-logo-dark{
		display: block;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .navbar.nav-open .nav-logo-light{
		display: none;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-logo img{
		height: 48px;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-toggle{
		display: inline-flex;
		position: relative;
		z-index: 130;
		color: var(--navy);
		border-color: rgba(7,31,69,0.1);
		background: rgba(255,255,255,0.9);
		box-shadow: 0 10px 26px rgba(7,31,69,0.08);
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .navbar.is-transparent:not(.nav-open) .nav-toggle{
		color: var(--navy);
		border-color: rgba(7,31,69,0.08);
		background: rgba(255,255,255,0.86);
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-links{
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		left: auto;
		width: min(390px, calc(100vw - 32px));
		height: 100svh;
		display: flex;
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		padding: 98px 22px 24px;
		background:
			radial-gradient(circle at 100% 0%, rgba(42,197,88,0.12) 0%, transparent 38%),
			linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(247,249,252,1) 100%);
		border-left: 1px solid rgba(7,31,69,0.08);
		box-shadow: -28px 0 70px rgba(7,31,69,0.2);
		overflow-y: auto;
		transform: translateX(110%);
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		transition: transform 320ms var(--ease), opacity 260ms var(--ease), visibility 0s linear 320ms;
		z-index: 120;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-links.is-open{
		transform: translateX(0);
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transition-delay: 0s;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-link{
		display: flex;
		align-items: center;
		align-self: flex-start;
		min-height: 48px;
		width: min(260px, 100%);
		padding: 0 4px;
		border-bottom: 1px solid rgba(7,31,69,0.08);
		color: var(--navy) !important;
		font-size: 1.02rem;
		font-weight: 700;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-link::after{
		display: none;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-link.is-active{
		color: var(--green-dark) !important;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-login{
		width: 100%;
		margin: 28px 0 0;
		padding: 22px 0 0;
		border-top: 1px solid rgba(7,31,69,0.1);
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-login::before{
		content: "Login";
		display: block;
		margin-bottom: 12px;
		font-family: var(--font-display);
		font-size: 0.78rem;
		font-weight: 800;
		letter-spacing: 0.12em;
		text-transform: uppercase;
		color: rgba(7,31,69,0.54);
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-login::after{
		display: none;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-login-toggle{
		display: none;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-login-menu{
		position: static;
		width: 100%;
		padding: 0;
		border: 0;
		border-radius: 0;
		background: transparent;
		box-shadow: none;
		backdrop-filter: none;
		-webkit-backdrop-filter: none;
		opacity: 1;
		visibility: visible;
		transform: none;
		pointer-events: auto;
		display: grid;
		gap: 10px;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-login-menu::before{
		display: none;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .portal-link{
		display: grid;
		grid-template-columns: 42px 1fr 18px;
		align-items: center;
		gap: 12px;
		padding: 13px 14px;
		border-radius: 16px;
		background: rgba(255,255,255,0.78);
		border: 1px solid rgba(7,31,69,0.08);
		color: var(--navy);
		box-shadow: 0 10px 24px rgba(7,31,69,0.05);
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .portal-link + .portal-link{
		margin-top: 0;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .portal-icon{
		width: 42px;
		height: 42px;
		border-radius: 13px;
	}
}

@media (max-width: 420px){
	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-links{
		width: calc(100vw - 24px);
		padding-inline: 18px;
	}
}

@media (min-width: 761px) and (max-width: 1024px){
	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-links{
		padding-top: 120px;
		justify-content: flex-start;
	}
}

@media (max-width: 1024px){
	body.page-home .values-panel[data-idx="2"] .values-ctas{
		display: none;
	}
}

@media (max-width: 1024px){
	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-login{
		display: block !important;
		justify-content: initial !important;
		align-items: initial !important;
		width: 100% !important;
		max-width: none !important;
		margin: 28px 0 0 !important;
		padding: 22px 0 0 !important;
		border-top: 1px solid rgba(7,31,69,0.1);
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-login-menu{
		width: 100% !important;
		max-width: none !important;
		margin: 0 !important;
		right: auto !important;
		left: auto !important;
		display: grid !important;
		gap: 12px !important;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .portal-link{
		width: 100%;
		margin: 0 !important;
		grid-template-columns: 44px minmax(0, 1fr) 18px;
		padding: 14px 16px;
	}
}

@media (max-width: 760px){
	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-links{
		width: calc(100vw - 28px) !important;
		padding: 104px 20px 26px !important;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-link{
		width: 100%;
		max-width: none;
		padding-left: 2px;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact, body.page-policy) .nav-login::before{
		margin-left: 0;
	}
}

/* Journey final responsive alignment */
@media (min-width: 1025px){
	:is(body.page-home, body.page-about) .journey-stories-head{
		display: flex;
	}

	:is(body.page-home, body.page-about) .journey-metrics{
		display: flex;
	}

	:is(body.page-home, body.page-about) .journey-sticky{
		padding-top: clamp(56px, 6vh, 78px);
		padding-bottom: clamp(56px, 6vh, 78px);
	}

	:is(body.page-home, body.page-about) .journey-left{
		gap: 28px;
	}

	:is(body.page-home, body.page-about) .journey-right{
		gap: 0;
		justify-content: center;
	}

	:is(body.page-home, body.page-about) .journey-tree-viz{
		flex: 0 0 auto;
		height: clamp(380px, 52vh, 500px);
		min-height: 0;
		max-height: none;
	}

	:is(body.page-home, body.page-about) .journey-panels{
		min-height: clamp(300px, 38vh, 360px);
	}

	:is(body.page-home, body.page-about) .journey-years{
		margin-top: 0;
	}
}

@media (min-width: 761px) and (max-width: 1024px){
	:is(body.page-home, body.page-about) .journey-stories-head{
		display: flex;
		grid-row: 1;
		margin: 0;
	}

	:is(body.page-home, body.page-about) .journey-metrics{
		display: grid;
		grid-row: 2;
		grid-template-columns: 1fr 1fr;
		gap: 18px;
	}

	:is(body.page-home, body.page-about) .journey-sticky{
		top: -150px;
		padding: 104px var(--site-gutter, 32px) 34px;
	}

	:is(body.page-home, body.page-about) .journey-inner{
		max-width: 720px;
		grid-template-rows: auto auto 340px minmax(230px, 1fr) auto;
		gap: 22px;
	}

	:is(body.page-home, body.page-about) .journey-tree-viz{
		grid-row: 3;
		height: 340px;
		min-height: 340px;
		max-height: 340px;
	}

	:is(body.page-home, body.page-about) .journey-panels{
		grid-row: 4;
	}

	:is(body.page-home, body.page-about) .journey-years{
		grid-row: 5;
	}

	:is(body.page-home, body.page-about) .journey-years{
		position: relative;
		height: 88px;
		padding: 20px 28px 14px;
		align-self: end;
		align-items: flex-start;
		border-radius: 20px;
	}

	:is(body.page-home, body.page-about) .journey-years::before,
	:is(body.page-home, body.page-about) .journey-years-fill{
		left: 28px;
		right: 28px;
		top: 28px;
	}

	:is(body.page-home, body.page-about) .journey-year-marker{
		gap: 9px;
		min-width: 44px;
	}

	:is(body.page-home, body.page-about) .journey-year-dot{
		width: 11px;
		height: 11px;
	}

	:is(body.page-home, body.page-about) .journey-year-marker.active .journey-year-dot{
		transform: scale(1.18);
		box-shadow: 0 0 0 5px rgba(42,197,88,0.16);
	}

	:is(body.page-home, body.page-about) .journey-year-label{
		font-size: 0.95rem;
		line-height: 1;
	}
}

@media (max-width: 760px){
	:is(body.page-home, body.page-about) .journey-stories-head{
		display: flex;
		grid-row: 1;
		margin: 0;
	}

	:is(body.page-home, body.page-about) .journey-metrics{
		display: grid;
		grid-row: 2;
		grid-template-columns: 1fr 1fr;
		gap: 12px;
	}

	:is(body.page-home, body.page-about) .journey-sticky{
		top: -148px;
		padding: 92px var(--site-gutter, 20px) 22px;
	}

	:is(body.page-home, body.page-about) .journey-inner{
		max-width: 420px;
		grid-template-rows: auto auto 260px minmax(255px, 1fr) auto;
		gap: 18px;
	}

	:is(body.page-home, body.page-about) .journey-tree-viz{
		grid-row: 3;
		height: 260px;
		min-height: 260px;
		max-height: 260px;
		border-radius: 0 0 28px 28px;
	}

	:is(body.page-home, body.page-about) .journey-tree-viz svg{
		width: min(88%, 300px);
		height: 92%;
	}

	:is(body.page-home, body.page-about) .journey-panels{
		grid-row: 4;
	}

	:is(body.page-home, body.page-about) .journey-years{
		grid-row: 5;
	}
}

@media (max-width: 420px){
	:is(body.page-home, body.page-about) .journey-inner{
		grid-template-rows: auto auto 230px minmax(265px, 1fr) auto;
		gap: 16px;
	}

	:is(body.page-home, body.page-about) .journey-tree-viz{
		height: 230px;
		min-height: 230px;
		max-height: 230px;
	}

	:is(body.page-home, body.page-about) .journey-tree-viz svg{
		width: min(86%, 270px);
		height: 90%;
	}
}

/* Final responsive rhythm and sticky-section pass */
@media (min-width: 761px) and (max-width: 1024px){
	:is(
		body.page-about,
		body.page-services,
		body.page-careers,
		body.page-contact,
		body.page-policy
	) :is(.page-top, .page-hero){
		padding-top: 124px;
		padding-bottom: 42px;
	}

	:is(
		body.page-about,
		body.page-services,
		body.page-careers,
		body.page-contact,
		body.page-policy
	) .section,
	body.page-home :is(.services, .team, .sixbox),
	body.page-services :is(.solution-band),
	body.page-about .team-alt{
		padding-top: 76px;
		padding-bottom: 76px;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact) .cta{
		padding-top: 68px;
		padding-bottom: 68px;
	}

	:is(body.page-home, body.page-about) .journey-scroller{
		height: 320svh;
	}

	:is(body.page-home, body.page-about) .journey-sticky{
		--journey-header-clearance: 92px;
		--journey-before-tree: 230px;
		--journey-sticky-offset: calc(var(--journey-before-tree) - var(--journey-header-clearance));
		position: sticky !important;
		top: calc(var(--journey-header-clearance) - var(--journey-before-tree)) !important;
		height: calc(100svh + var(--journey-sticky-offset));
		min-height: calc(100svh + var(--journey-sticky-offset));
		padding: var(--journey-header-clearance) var(--site-gutter, 32px) 34px;
		overflow: hidden;
		align-items: stretch;
	}

	:is(body.page-home, body.page-about) .journey-inner{
		max-width: 720px;
		height: 100%;
		grid-template-rows: 20px 82px 340px minmax(0, 1fr) 88px;
		gap: 14px;
	}

	:is(body.page-home, body.page-about) .journey-stories-head{
		height: 20px;
		min-height: 0;
		align-items: center;
	}

	:is(body.page-home, body.page-about) .journey-metrics{
		height: 82px;
		min-height: 0;
		padding: 12px 18px;
		align-items: center;
	}

	:is(body.page-home, body.page-about) .journey-tree-viz{
		height: 340px;
		min-height: 340px;
		max-height: 340px;
	}

	:is(body.page-home, body.page-about) .journey-panels{
		min-height: 0;
		height: 100%;
		overflow: hidden;
	}

	:is(body.page-home, body.page-about) .journey-panel{
		justify-content: center;
		overflow: hidden;
	}

	:is(body.page-home, body.page-about) .journey-pbody{
		line-height: 1.48;
	}
}

@media (max-width: 760px){
	:is(
		body.page-about,
		body.page-services,
		body.page-careers,
		body.page-contact,
		body.page-policy
	) :is(.page-top, .page-hero){
		padding-top: 104px;
		padding-bottom: 34px;
	}

	:is(
		body.page-about,
		body.page-services,
		body.page-careers,
		body.page-contact,
		body.page-policy
	) .section,
	body.page-home :is(.services, .team, .sixbox),
	body.page-services :is(.solution-band),
	body.page-about .team-alt{
		padding-top: 56px;
		padding-bottom: 56px;
	}

	:is(body.page-home, body.page-about, body.page-services, body.page-careers, body.page-contact) .cta{
		padding-top: 56px;
		padding-bottom: 56px;
	}

	:is(body.page-home, body.page-about) .journey-scroller{
		height: 320svh;
	}

	:is(body.page-home, body.page-about) .journey-sticky{
		--journey-header-clearance: 84px;
		--journey-before-tree: 204px;
		--journey-sticky-offset: calc(var(--journey-before-tree) - var(--journey-header-clearance));
		position: sticky !important;
		top: calc(var(--journey-header-clearance) - var(--journey-before-tree)) !important;
		height: calc(100svh + var(--journey-sticky-offset));
		min-height: calc(100svh + var(--journey-sticky-offset));
		padding: var(--journey-header-clearance) var(--site-gutter, 20px) 22px;
		overflow: hidden;
		align-items: stretch;
	}

	:is(body.page-home, body.page-about) .journey-inner{
		max-width: 420px;
		height: 100%;
		grid-template-rows: 18px 72px 260px minmax(0, 1fr) 76px;
		gap: 12px;
	}

	:is(body.page-home, body.page-about) .journey-stories-head{
		height: 18px;
		min-height: 0;
		align-items: center;
	}

	:is(body.page-home, body.page-about) .journey-stories-head .eyebrow{
		font-size: 0.7rem;
		line-height: 1;
	}

	:is(body.page-home, body.page-about) .journey-metrics{
		height: 72px;
		min-height: 0;
		padding: 10px 14px;
		align-items: center;
	}

	:is(body.page-home, body.page-about) .journey-metric-big{
		font-size: 1.62rem;
		line-height: 0.92;
	}

	:is(body.page-home, body.page-about) .journey-metric-label{
		font-size: 0.62rem;
		line-height: 1;
	}

	:is(body.page-home, body.page-about) .journey-tree-viz{
		height: 260px;
		min-height: 260px;
		max-height: 260px;
	}

	:is(body.page-home, body.page-about) .journey-panels{
		min-height: 0;
		height: 100%;
		overflow: hidden;
	}

	:is(body.page-home, body.page-about) .journey-panel{
		justify-content: center;
		overflow: hidden;
	}

	:is(body.page-home, body.page-about) .journey-panel-head{
		margin-bottom: 10px;
	}

	:is(body.page-home, body.page-about) .journey-ptitle{
		margin-bottom: 10px;
	}

	:is(body.page-home, body.page-about) .journey-pbody{
		line-height: 1.42;
	}

	:is(body.page-home, body.page-about) .journey-years{
		padding: 14px 18px 12px;
		align-self: stretch;
	}

	:is(body.page-home, body.page-about) .journey-years{
		position: relative;
		height: 76px;
		padding: 15px 22px 10px;
		align-self: end;
		align-items: flex-start;
		border-radius: 18px;
	}

	:is(body.page-home, body.page-about) .journey-years::before,
	:is(body.page-home, body.page-about) .journey-years-fill{
		left: 22px;
		right: 22px;
		top: 22px;
	}

	:is(body.page-home, body.page-about) .journey-year-marker{
		gap: 8px;
		min-width: 42px;
	}

	:is(body.page-home, body.page-about) .journey-year-dot{
		width: 10px;
		height: 10px;
		border-width: 2px;
	}

	:is(body.page-home, body.page-about) .journey-year-marker.active .journey-year-dot{
		transform: scale(1.18);
		box-shadow: 0 0 0 5px rgba(42,197,88,0.16);
	}

	:is(body.page-home, body.page-about) .journey-year-label{
		font-size: 0.88rem;
		line-height: 1;
	}
}

@media (max-width: 420px){
	:is(body.page-home, body.page-about) .journey-sticky{
		--journey-before-tree: 196px;
	}

	:is(body.page-home, body.page-about) .journey-inner{
		grid-template-rows: 18px 68px 230px minmax(0, 1fr) 72px;
		gap: 10px;
	}

	:is(body.page-home, body.page-about) .journey-metrics{
		height: 68px;
		padding: 9px 12px;
	}

	:is(body.page-home, body.page-about) .journey-tree-viz{
		height: 230px;
		min-height: 230px;
		max-height: 230px;
	}

	:is(body.page-home, body.page-about) .journey-years{
		padding: 12px 16px 10px;
	}

	:is(body.page-home, body.page-about) .journey-years{
		height: 72px;
		padding: 14px 20px 9px;
	}

	:is(body.page-home, body.page-about) .journey-years::before,
	:is(body.page-home, body.page-about) .journey-years-fill{
		left: 20px;
		right: 20px;
		top: 21px;
	}

	:is(body.page-home, body.page-about) .journey-year-label{
		font-size: 0.84rem;
	}
}

/* Final mobile drawer column fix */
@media (max-width: 1024px){
	:is(
		body.page-home,
		body.page-about,
		body.page-services,
		body.page-careers,
		body.page-contact,
		body.page-policy
	) .nav-links{
		display: flex !important;
		flex-direction: column !important;
		flex-wrap: nowrap !important;
		align-items: stretch !important;
		justify-content: flex-start !important;
		row-gap: 0 !important;
	}

	:is(
		body.page-home,
		body.page-about,
		body.page-services,
		body.page-careers,
		body.page-contact,
		body.page-policy
	) .nav-login{
		display: block !important;
		flex: 0 0 auto !important;
		width: 100% !important;
		margin: 28px 0 0 !important;
		padding: 22px 0 0 !important;
	}

	:is(
		body.page-home,
		body.page-about,
		body.page-services,
		body.page-careers,
		body.page-contact,
		body.page-policy
	) .nav-login-menu{
		display: grid !important;
		width: 100% !important;
		gap: 12px !important;
	}
}
