/*
 * CSS Cascade Layers — predictable specificity for the theme.
 * Order: reset (lowest) → theme → blocks → patterns → utilities (highest).
 * theme.json output already lands in the theme layer via the `wp` cascade.
 */

@layer reset, theme, blocks, patterns, utilities;

@layer reset {
	*,
	*::before,
	*::after {
		box-sizing: border-box;
	}

	html {
		-webkit-text-size-adjust: 100%;
		text-rendering: optimizeLegibility;
	}

	body {
		margin: 0;
		-webkit-font-smoothing: antialiased;
		-moz-osx-font-smoothing: grayscale;
	}

	img,
	picture,
	video,
	svg {
		display: block;
		max-width: 100%;
	}
}

@layer theme {
	/* WCAG 2.2 AA: visible focus ring on every interactive element. */
	:where(a, button, input, select, textarea, summary, [tabindex]:not([tabindex="-1"])):focus-visible {
		outline: 2px solid var(--wp--preset--color--amber-400);
		outline-offset: 2px;
		border-radius: 0.25rem;
	}

	/* Skip-link — visually hidden until focused. */
	.skip-link {
		position: absolute;
		left: -9999px;
		top: 1rem;
		z-index: 9999;
		background: var(--wp--preset--color--amber-400);
		color: var(--wp--preset--color--navy-950);
		padding: 0.5rem 1rem;
		font-weight: 600;
		border-radius: 0.5rem;
		text-decoration: none;
	}
	.skip-link:focus {
		left: 1rem;
	}

	/* Body baseline */
	html,
	body {
		background: var(--wp--preset--color--slate-900);
		color: var(--wp--preset--color--white);
	}

	:where([id]) {
		scroll-margin-top: 6rem;
	}

	/* Blueprint grid hero overlay */
	.blueprint-grid {
		background-image:
			linear-gradient(to right, rgb(6 182 212 / 0.03) 1px, transparent 1px),
			linear-gradient(to bottom, rgb(6 182 212 / 0.03) 1px, transparent 1px);
		background-size: 40px 40px;
	}

	/* @view-transition opt-in (progressive enhancement; only browsers that support it react) */
	@view-transition {
		navigation: auto;
	}
}

@layer patterns {
	/*
	 * Sticky, translucent header.
	 * The inner .site-header is declared position:sticky in the template,
	 * but wp:template-part wraps it in an outer <header> of equal height,
	 * which scopes the sticky range to zero. Pin the outer wrapper to the
	 * viewport so the visual header (inner) stays on screen while scrolling.
	 */
	.wp-site-blocks > header {
		position: sticky;
		top: 0;
		z-index: 50;
	}

	/* Thin contact strip above the main nav. */
	.site-topbar {
		background:
			linear-gradient(90deg, rgba(255, 184, 77, 0.10), transparent 32%, rgba(29, 79, 154, 0.15)),
			var(--wp--preset--color--navy-950);
		border-bottom: 1px solid var(--wp--preset--color--white-alpha-15);
		font-size: 0.8rem;
	}

	.site-topbar__inner {
		max-width: 1280px;
		margin: 0 auto;
		padding: 0.4rem var(--wp--preset--spacing--40);
		display: flex;
		justify-content: space-between;
		align-items: center;
		gap: 1rem;
	}

	.site-topbar__proof,
	.site-topbar__links {
		display: flex;
		align-items: center;
		gap: 1rem;
	}

	.site-topbar__proof {
		color: var(--wp--preset--color--white-alpha-65);
		font-weight: 600;
	}

	.topbar-link {
		display: inline-flex;
		align-items: center;
		gap: 0.4rem;
		color: var(--wp--preset--color--white-alpha-65);
		text-decoration: none;
		transition: color 0.15s ease;
	}

	.topbar-link:hover,
	.topbar-link:focus-visible {
		color: var(--wp--preset--color--amber-400);
	}

	.site-header {
		background: var(--wp--preset--color--navy-900-alpha-85);
		-webkit-backdrop-filter: blur(20px) saturate(140%);
		backdrop-filter: blur(20px) saturate(140%);
		z-index: 50;
	}

	/* Site logo sizing: keep header compact (~48px logo height). */
	.site-header .wp-block-site-logo img {
		height: 48px;
		width: auto;
	}

	/* Header actions row spacing. */
	.site-header__actions {
		gap: var(--wp--preset--spacing--30);
	}

	/* Sign-In submenu opens on hover; keep nav text muted, white on hover. */
	.site-header .wp-block-navigation .wp-block-navigation-item__content {
		color: var(--wp--preset--color--white-alpha-65);
		transition: color 0.2s ease;
	}
	.site-header .wp-block-navigation .wp-block-navigation-item__content:hover,
	.site-header .wp-block-navigation .wp-block-navigation-item__content:focus-visible {
		color: var(--wp--preset--color--white);
	}

	main a:not(.wp-block-button__link) {
		text-decoration: underline;
		text-decoration-thickness: 0.08em;
		text-underline-offset: 0.18em;
	}

	.wp-site-blocks > footer.wp-block-template-part {
		margin-block-start: 0;
		margin-block-end: 0;
		background: var(--wp--preset--color--navy-900);
	}

	.wpconsent-cookie-policy {
		margin-top: var(--wp--preset--spacing--50);
		padding: clamp(1.25rem, 3vw, 2rem);
		background: var(--wp--preset--color--navy-950);
		color: var(--wp--preset--color--white-alpha-92);
		border: 1px solid var(--wp--preset--color--white-alpha-15);
		overflow-x: auto;
	}

	.wpconsent-cookie-policy :where(h2, h3) {
		color: var(--wp--preset--color--white);
		margin: 0 0 0.75rem;
	}

	.wpconsent-cookie-policy h3 {
		margin-top: var(--wp--preset--spacing--50);
	}

	.wpconsent-cookie-policy p {
		color: var(--wp--preset--color--white-alpha-92);
		max-width: 72ch;
	}

	.wpconsent-cookie-policy table {
		width: 100%;
		min-width: 48rem;
		margin: var(--wp--preset--spacing--30) 0 var(--wp--preset--spacing--50);
		border-collapse: collapse;
		background: rgb(255 255 255 / 0.03);
		color: var(--wp--preset--color--white-alpha-92);
	}

	.wpconsent-cookie-policy :where(th, td) {
		padding: 0.95rem 1rem;
		border: 1px solid var(--wp--preset--color--white-alpha-15);
		color: var(--wp--preset--color--white-alpha-92);
		text-align: left;
		vertical-align: top;
	}

	.wpconsent-cookie-policy th {
		background: rgb(255 255 255 / 0.06);
		color: var(--wp--preset--color--white);
		font-weight: 700;
	}

	.wpconsent-cookie-policy td:first-child {
		font-family: var(--wp--preset--font-family--mono);
		color: var(--wp--preset--color--white);
	}

	/* Footer column labels: small, mono, high-contrast. */
	.site-footer__heading {
		font-family: var(--wp--preset--font-family--mono);
		font-size: 0.625rem;
		font-weight: 500;
		text-transform: uppercase;
		letter-spacing: 0;
		color: var(--wp--preset--color--white-alpha-65);
		margin: 0 0 1.25rem;
	}

	.site-footer .wp-block-list {
		list-style: none;
		padding: 0;
		margin: 0;
	}
	.site-footer .wp-block-list li + li {
		margin-top: 0.75rem;
	}
	.site-footer .wp-block-list a {
		color: var(--wp--preset--color--white-alpha-65);
		font-size: 0.8125rem;
		text-decoration: none;
		transition: color 0.2s ease;
	}
	.site-footer .wp-block-list a:hover,
	.site-footer .wp-block-list a:focus-visible {
		color: var(--wp--preset--color--white);
		text-decoration: none;
	}

	/* "24/7 Service" pulse indicator. */
	.service-pulse {
		display: inline-flex;
		align-items: center;
		gap: 0.4rem;
		font-family: var(--wp--preset--font-family--mono);
		font-size: 0.625rem;
		color: var(--wp--preset--color--white-alpha-65);
	}
	.service-pulse::before {
		content: "";
		display: inline-block;
		width: 0.4rem;
		height: 0.4rem;
		border-radius: 9999px;
		background: var(--wp--preset--color--amber-400);
	}
	@media (prefers-reduced-motion: no-preference) {
		.service-pulse::before {
			animation: service-pulse 2s ease-in-out infinite;
		}
		@keyframes service-pulse {
			0%, 100% { opacity: 1;   transform: scale(1); }
			50%      { opacity: 0.4; transform: scale(0.8); }
		}
	}

	/* Footer bottom bar: copyright + Privacy + Terms. */
	.site-footer__legal {
		font-family: var(--wp--preset--font-family--mono);
		font-size: 0.6875rem;
		color: var(--wp--preset--color--white-alpha-65);
	}
	.site-footer__legal a {
		color: var(--wp--preset--color--white-alpha-65);
		text-decoration: none;
	}
	.site-footer__legal a:hover,
	.site-footer__legal a:focus-visible {
		color: var(--wp--preset--color--white);
		text-decoration: underline;
	}

	/* Visually-hidden helper for screen-reader-only headings if needed. */
	.sr-only {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip: rect(0 0 0 0);
		white-space: nowrap;
		border: 0;
	}

	/* Accessible form baseline used by rate, contact, and careers patterns. */
	.caravanlogistics-form {
		max-width: 760px;
		margin: 0 auto;
		border: 1px solid rgba(255, 255, 255, 0.12);
		border-radius: 0.5rem;
		padding: 1.25rem;
		background: rgba(255, 255, 255, 0.025);
	}
	.caravanlogistics-form__grid {
		display: grid;
		grid-template-columns: 1fr;
		gap: 1rem;
	}
	@media (min-width: 700px) {
		.caravanlogistics-form__grid {
			grid-template-columns: repeat(2, minmax(0, 1fr));
		}
	}
	.caravanlogistics-form label {
		display: block;
		color: var(--wp--preset--color--white);
		font-weight: 700;
		margin-bottom: 0.4rem;
	}
	.caravanlogistics-form input,
	.caravanlogistics-form select,
	.caravanlogistics-form textarea {
		width: 100%;
		min-height: 2.75rem;
		border: 1px solid rgba(255, 255, 255, 0.18);
		border-radius: 0.375rem;
		background: rgba(255, 255, 255, 0.06);
		color: var(--wp--preset--color--white);
		padding: 0.7rem 0.8rem;
		font: inherit;
		transition: border-color 0.2s ease, background-color 0.2s ease;
	}
	.caravanlogistics-form input:focus-visible,
	.caravanlogistics-form select:focus-visible,
	.caravanlogistics-form textarea:focus-visible {
		outline: 2px solid var(--wp--preset--color--amber-400);
		outline-offset: 2px;
		border-color: var(--wp--preset--color--amber-400);
	}
	.caravanlogistics-form textarea {
		min-height: 8rem;
		resize: vertical;
	}
	.caravanlogistics-form__full {
		grid-column: 1 / -1;
	}
	.caravanlogistics-form__help {
		color: var(--wp--preset--color--white-alpha-65);
		font-size: var(--wp--preset--font-size--sm);
		margin-top: 0.35rem;
	}
	.caravanlogistics-form__submit {
		margin-top: 1rem;
		border: 0;
		border-radius: 0.5rem;
		background: var(--wp--preset--color--amber-400);
		color: var(--wp--preset--color--navy-950);
		font-weight: 800;
		padding: 0.85rem 1.2rem;
		cursor: pointer;
	}
	.caravanlogistics-form__submit:hover,
	.caravanlogistics-form__submit:focus-visible {
		background: var(--wp--preset--color--amber-300);
	}
}

@layer utilities {
	.opacity-0 { opacity: 0; }
	.delay-100 { animation-delay: 0.1s; }
	.delay-200 { animation-delay: 0.2s; }
	.delay-300 { animation-delay: 0.3s; }
	.delay-400 { animation-delay: 0.4s; }
	.delay-500 { animation-delay: 0.5s; }
	.delay-700 { animation-delay: 0.7s; }
	.delay-900 { animation-delay: 0.9s; }

	.font-mono { font-family: var(--wp--preset--font-family--mono); }
}

/* Flagship visual pass: unlayered so it outranks WordPress global resets. */
:root {
	--caravan-ease: cubic-bezier(0.22, 1, 0.36, 1);
	--caravan-ink: var(--wp--preset--color--ink-900);
	--caravan-paper: var(--wp--preset--color--paper-50);
	--caravan-line: rgba(7, 17, 31, 0.14);
	--caravan-logo-blue: rgb(29 79 154);
}

html {
	scroll-behavior: smooth;
}

body {
	background:
		linear-gradient(180deg, #06101e 0%, #07111f 42rem, #f5f8fb 42rem);
}

main {
	overflow: clip;
}

.site-footer--dispatch-index {
	background:
		linear-gradient(90deg, rgba(255, 184, 77, 0.08), transparent 36%, rgba(29, 79, 154, 0.16)),
		var(--wp--preset--color--navy-900) !important;
	border-bottom: 5px solid var(--wp--preset--color--amber-500);
}

.site-footer__dispatch-top {
	display: grid;
	grid-template-columns: auto minmax(16rem, 1fr) auto;
	gap: 1.65rem;
	align-items: center;
	padding-bottom: 1.4rem;
	border-bottom: 1px solid var(--wp--preset--color--white-alpha-15);
}

.site-footer__brand {
	display: inline-flex;
	align-items: center;
	color: var(--wp--preset--color--white);
	text-decoration: none;
}

.site-footer__brand img {
	width: 14.25rem;
	height: auto;
	object-fit: contain;
}

.site-footer__proof {
	max-width: 36rem;
	color: var(--wp--preset--color--white-alpha-65);
}

.site-footer__proof p {
	margin: 0;
	font-size: 0.9rem;
	line-height: 1.55;
}

.site-footer__proof .service-pulse {
	margin-top: 0.75rem;
}

.site-footer__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 0.65rem;
}

.caravanlogistics-footer-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 2.75rem;
	padding: 0.72rem 1rem;
	border: 2px solid rgb(248 207 98);
	border-radius: 0.5rem;
	background: var(--caravan-logo-blue);
	color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 800;
	line-height: 1;
	text-decoration: none;
	box-shadow: inset 0 -3px 0 rgba(0, 0, 0, 0.2);
	transition:
		background-color 220ms var(--caravan-ease),
		border-color 220ms var(--caravan-ease),
		color 220ms var(--caravan-ease),
		transform 220ms var(--caravan-ease);
}

.caravanlogistics-footer-button:hover,
.caravanlogistics-footer-button:focus-visible {
	background: var(--wp--preset--color--navy-500);
	color: var(--wp--preset--color--white);
	text-decoration: none;
	transform: translateY(-1px);
}

.caravanlogistics-footer-button--secondary {
	border-width: 1px;
	border-color: rgba(255, 184, 77, 0.54);
	background: rgba(255, 255, 255, 0.04);
	color: var(--wp--preset--color--amber-300);
	box-shadow: none;
}

.caravanlogistics-footer-button--secondary:hover,
.caravanlogistics-footer-button--secondary:focus-visible {
	border-color: var(--wp--preset--color--amber-400-alpha-75);
	background: rgba(255, 184, 77, 0.12);
	color: var(--wp--preset--color--amber-300);
}

.site-footer__dispatch-grid {
	display: grid;
	grid-template-columns: 1.12fr 1fr 1fr 1.1fr 0.9fr 1.25fr;
	gap: clamp(1.25rem, 2.5vw, 2rem);
	padding-top: 1.5rem;
}

.site-footer__section .site-footer__heading {
	margin: 0 0 0.9rem;
	padding-bottom: 0.55rem;
	border-bottom: 1px solid var(--wp--preset--color--white-alpha-15);
	color: var(--wp--preset--color--white-alpha-65);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.75rem;
	font-weight: 800;
	line-height: 1.1;
	text-transform: uppercase;
}

.site-footer__coded-list li {
	display: grid;
	grid-template-columns: 1.55rem minmax(0, 1fr);
	gap: 0.45rem;
	align-items: baseline;
}

.site-footer__coded-list li::before {
	content: attr(data-code);
	color: var(--wp--preset--color--amber-400-alpha-75);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.68rem;
	font-weight: 800;
	line-height: 1;
}

.site-footer--dispatch-index .wp-block-list li + li {
	margin-top: 0.58rem;
}

.site-footer--dispatch-index .wp-block-list a,
.site-footer--dispatch-index .site-footer__legal a {
	color: var(--wp--preset--color--amber-400);
	font-size: 0.83rem;
	font-weight: 560;
	text-decoration: none;
}

.site-footer--dispatch-index .wp-block-list a:hover,
.site-footer--dispatch-index .wp-block-list a:focus-visible,
.site-footer--dispatch-index .site-footer__legal a:hover,
.site-footer--dispatch-index .site-footer__legal a:focus-visible {
	color: var(--wp--preset--color--amber-300);
	text-decoration: none;
}

.site-footer__contact p {
	margin: 0.85rem 0 0;
	color: var(--wp--preset--color--white-alpha-65);
	font-size: 0.82rem;
	line-height: 1.55;
}

.site-footer--dispatch-index .site-footer__legal {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 1.6rem;
	padding-top: 1.15rem;
	border-top: 1px solid var(--wp--preset--color--white-alpha-15);
	color: var(--wp--preset--color--white-alpha-65);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.72rem;
}

.site-footer--dispatch-index .site-footer__legal p {
	margin: 0;
}

.site-footer__legal-links {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 1.4rem;
}

/* Agency credit — plain text, restrained. MELD set with logotype letterspacing. */
.site-footer__credit {
	color: var(--wp--preset--color--white-alpha-35);
	margin-left: 0.15rem;
	white-space: nowrap;
}

.site-footer__credit-name {
	letter-spacing: 0.08em;
	font-weight: 600;
	color: var(--wp--preset--color--white-alpha-65);
}

/* Designations & accreditations band — sits between the brand row and nav grid. */
.site-footer__accreditations {
	padding: 1.4rem 0;
	border-bottom: 1px solid var(--wp--preset--color--white-alpha-15);
}

.site-footer__accreditations-label {
	margin: 0 0 0.9rem;
	color: var(--wp--preset--color--white-alpha-65);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.75rem;
	font-weight: 800;
	line-height: 1.1;
	text-transform: uppercase;
}

.site-footer__accreditations-list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

/* White chip — keeps every logo legible on the navy footer regardless of its
   own colours (the Best Managed mark is black text on transparency). */
.site-footer__accreditation {
	display: flex;
	align-items: center;
	padding: 0.5rem 0.9rem;
	background: #fff;
	border-radius: 0.5rem;
}

.site-footer__accreditation img {
	display: block;
	height: 2.4rem;
	width: auto;
	object-fit: contain;
}

.site-header {
	box-shadow: var(--wp--preset--shadow--header);
	background:
		linear-gradient(90deg, rgba(255, 184, 77, 0.06), transparent 32%, rgba(29, 79, 154, 0.12)),
		var(--wp--preset--color--navy-900-alpha-85) !important;
	border-bottom: 5px solid var(--wp--preset--color--amber-500) !important;
}

.site-header > .wp-block-group {
	gap: 1.55rem;
}

.site-header > .wp-block-group > .wp-block-navigation {
	flex: 1 1 auto;
	min-width: 0;
}

.site-brand {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 0.65rem;
	min-height: 2.75rem;
	padding-right: 1.5rem;
	color: var(--wp--preset--color--white);
	text-decoration: none;
}

.site-brand::after {
	content: "";
	position: absolute;
	right: 0;
	top: 18%;
	width: 1px;
	height: 64%;
	background: linear-gradient(180deg, transparent, rgba(255, 184, 77, 0.82), transparent);
}

.site-brand img {
	width: 14.4rem;
	height: auto;
	object-fit: contain;
}

.site-brand:hover,
.site-brand:focus-visible {
	color: var(--wp--preset--color--white);
	text-decoration: none;
}

.site-header .wp-block-navigation__container {
	width: 100%;
	justify-content: space-between;
	column-gap: clamp(1.25rem, 3vw, 3.75rem);
	row-gap: 0.4rem;
}

.site-header .wp-block-navigation .wp-block-navigation-item__content {
	color: rgba(255, 255, 255, 0.8);
	font-size: 0.95rem;
	font-weight: 650;
}

.site-header__actions {
	flex: 0 0 auto;
	gap: 0.7rem;
}

.caravanlogistics-header-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 2.75rem;
	padding: 0.72rem 1rem;
	border: 1px solid rgba(255, 184, 77, 0.54);
	border-radius: 0.5rem;
	background: rgba(255, 255, 255, 0.04);
	color: var(--wp--preset--color--amber-300);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 800;
	line-height: 1;
	text-decoration: none;
	transition:
		background-color 220ms var(--caravan-ease),
		border-color 220ms var(--caravan-ease),
		color 220ms var(--caravan-ease),
		transform 220ms var(--caravan-ease);
}

.caravanlogistics-header-link:hover,
.caravanlogistics-header-link:focus-visible {
	border-color: var(--wp--preset--color--amber-400-alpha-75);
	background: rgba(255, 184, 77, 0.12);
	color: var(--wp--preset--color--amber-300);
	text-decoration: none;
	transform: translateY(-1px);
}

.site-header .wp-block-button__link {
	border: 2px solid rgb(248 207 98);
	background: var(--caravan-logo-blue);
	color: var(--wp--preset--color--white);
	box-shadow: inset 0 -3px 0 rgba(0, 0, 0, 0.2);
}

.site-header .wp-block-button__link:hover,
.site-header .wp-block-button__link:focus-visible {
	background: var(--wp--preset--color--navy-500);
	color: var(--wp--preset--color--white);
}

.wp-block-button__link,
.caravanlogistics-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.55rem;
	min-height: 2.75rem;
	border-radius: 0.5rem;
	text-decoration: none;
	transition:
		background-color 220ms var(--caravan-ease),
		border-color 220ms var(--caravan-ease),
		color 220ms var(--caravan-ease),
		transform 220ms var(--caravan-ease),
		box-shadow 220ms var(--caravan-ease);
}

.wp-block-button__link:hover,
.wp-block-button__link:focus-visible,
.caravanlogistics-button:hover,
.caravanlogistics-button:focus-visible {
	text-decoration: none;
	transform: translateY(-1px);
}

.wp-block-button__link:active,
.caravanlogistics-button:active {
	transform: translateY(0) scale(0.99);
}

.caravanlogistics-button {
	border: 1px solid transparent;
	padding: 0.72rem 1.05rem;
	font-weight: 800;
	line-height: 1;
}

.caravanlogistics-button--primary {
	background: var(--wp--preset--color--amber-400);
	color: var(--wp--preset--color--navy-950);
	box-shadow: 0 16px 34px rgba(255, 184, 77, 0.2);
}

.caravanlogistics-button--primary:hover,
.caravanlogistics-button--primary:focus-visible {
	background: var(--wp--preset--color--amber-300);
	color: var(--wp--preset--color--navy-950);
}

.caravanlogistics-button--secondary {
	border-color: rgba(255, 255, 255, 0.34);
	background: rgba(255, 255, 255, 0.08);
	color: var(--wp--preset--color--white);
}

.caravanlogistics-button--secondary:hover,
.caravanlogistics-button--secondary:focus-visible {
	border-color: rgba(255, 255, 255, 0.58);
	background: rgba(255, 255, 255, 0.14);
	color: var(--wp--preset--color--white);
}

.caravanlogistics-button--quiet {
	border-color: var(--wp--preset--color--amber-400-alpha-45);
	background: rgba(255, 184, 77, 0.08);
	color: var(--wp--preset--color--amber-300);
}

.caravanlogistics-button--quiet:hover,
.caravanlogistics-button--quiet:focus-visible {
	border-color: var(--wp--preset--color--amber-400-alpha-75);
	background: rgba(255, 184, 77, 0.14);
	color: var(--wp--preset--color--amber-300);
}

.caravanlogistics-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: 1.65rem;
}

.caravanlogistics-kicker {
	margin: 0 0 0.9rem;
	color: var(--wp--preset--color--amber-400);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
}

.caravanlogistics-section__inner {
	width: min(100%, 1280px);
	margin-inline: auto;
	padding-inline: 1.5rem;
}

.caravanlogistics-section__header {
	max-width: 54rem;
}

.caravanlogistics-section__header h2,
.caravanlogistics-proof__content h2,
.caravanlogistics-system__intro h2,
.caravanlogistics-cta__content h2 {
	margin: 0;
	font-size: var(--wp--preset--font-size--5-xl);
	line-height: 1.04;
	text-wrap: balance;
}

.caravanlogistics-section__header p,
.caravanlogistics-proof__content > p,
.caravanlogistics-system__intro p,
.caravanlogistics-cta__content p {
	max-width: 43rem;
	color: var(--wp--preset--color--ink-900-alpha-72);
	font-size: var(--wp--preset--font-size--lg);
	line-height: 1.65;
}

.caravanlogistics-hero {
	position: relative;
	display: flex;
	align-items: flex-end;
	min-height: 88svh;
	padding: 7rem 1.5rem 2.5rem;
	overflow: hidden;
	background: var(--caravan-ink);
	color: var(--wp--preset--color--white);
}

.caravanlogistics-hero__photo,
.caravanlogistics-hero__scrim {
	position: absolute;
	inset: 0;
}

.caravanlogistics-hero__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center 42%;
}

.caravanlogistics-hero__scrim {
	background:
		linear-gradient(90deg, rgba(4, 9, 15, 0.96) 0%, rgba(4, 9, 15, 0.78) 43%, rgba(4, 9, 15, 0.24) 100%),
		linear-gradient(180deg, rgba(4, 9, 15, 0.38) 0%, rgba(4, 9, 15, 0.94) 100%);
}

.caravanlogistics-hero__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(17rem, 22rem);
	gap: 2rem;
	align-items: end;
	width: min(100%, 1280px);
	margin-inline: auto;
}

.caravanlogistics-hero__copy {
	max-width: 48rem;
}

.caravanlogistics-hero h1 {
	margin: 0;
	max-width: 13ch;
	color: var(--wp--preset--color--white);
	font-size: 4.6rem;
	font-weight: 900;
	line-height: 0.96;
	text-wrap: balance;
}

.caravanlogistics-hero__lede {
	max-width: 42rem;
	margin: 1.35rem 0 0;
	color: rgba(255, 255, 255, 0.78);
	font-size: var(--wp--preset--font-size--lg);
	line-height: 1.7;
}

.caravanlogistics-hero__ops {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.7rem;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 0.5rem;
	padding: 0.7rem;
	background: rgba(6, 16, 30, 0.78);
	box-shadow: var(--wp--preset--shadow--hero);
}

.caravanlogistics-hero__ops div {
	border-radius: 0.375rem;
	padding: 0.95rem;
	background: rgba(255, 255, 255, 0.055);
}

.caravanlogistics-hero__ops strong {
	display: block;
	color: var(--wp--preset--color--white);
	font-family: var(--wp--preset--font-family--mono);
	font-size: var(--wp--preset--font-size--2-xl);
	font-variant-numeric: tabular-nums;
	line-height: 1;
}

.caravanlogistics-hero__ops span {
	display: block;
	margin-top: 0.4rem;
	color: rgba(255, 255, 255, 0.68);
	font-size: var(--wp--preset--font-size--xs);
	line-height: 1.45;
}

.caravanlogistics-proof {
	display: grid;
	grid-template-columns: minmax(0, 0.92fr) minmax(20rem, 0.78fr);
	align-items: stretch;
	background: var(--caravan-paper);
	color: var(--caravan-ink);
}

.caravanlogistics-proof__media {
	min-height: 34rem;
	background: var(--wp--preset--color--navy-900);
}

.caravanlogistics-proof__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.caravanlogistics-proof__content {
	align-self: center;
	padding: 5rem 2.5rem;
}

.caravanlogistics-proof__list {
	display: grid;
	gap: 0.85rem;
	margin: 2rem 0 0;
	padding: 0;
	list-style: none;
}

.caravanlogistics-proof__list li {
	border: 1px solid var(--caravan-line);
	border-radius: 0.5rem;
	padding: 1rem;
	background: rgba(255, 255, 255, 0.74);
}

.caravanlogistics-proof__list strong,
.caravanlogistics-system__steps strong {
	display: block;
	color: var(--caravan-ink);
	font-size: var(--wp--preset--font-size--lg);
	line-height: 1.2;
}

.caravanlogistics-proof__list span {
	display: block;
	margin-top: 0.35rem;
	color: var(--wp--preset--color--ink-900-alpha-72);
	line-height: 1.55;
}

.caravanlogistics-system {
	padding: 5.5rem 0;
	background:
		linear-gradient(180deg, #06101e 0%, #07111f 100%);
	color: var(--wp--preset--color--white);
}

.caravanlogistics-system__intro {
	max-width: 56rem;
}

.caravanlogistics-system__intro p {
	color: rgba(255, 255, 255, 0.68);
}

.caravanlogistics-system__layout {
	display: grid;
	grid-template-columns: minmax(18rem, 0.72fr) minmax(0, 1fr);
	gap: 1.4rem;
	align-items: stretch;
	margin-top: 2.25rem;
}

.caravanlogistics-system__image {
	overflow: hidden;
	border-radius: 0.5rem;
	background: var(--wp--preset--color--navy-900);
}

.caravanlogistics-system__image img {
	width: 100%;
	height: 100%;
	min-height: 28rem;
	object-fit: cover;
}

.caravanlogistics-system__steps {
	display: grid;
	gap: 0.85rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.caravanlogistics-system__steps li {
	position: relative;
	border: 1px solid rgba(255, 255, 255, 0.13);
	border-radius: 0.5rem;
	padding: 1.2rem 1.2rem 1.2rem 5.1rem;
	background: rgba(255, 255, 255, 0.045);
}

.caravanlogistics-system__steps span {
	position: absolute;
	left: 1rem;
	top: 1.2rem;
	color: var(--wp--preset--color--amber-400);
	font-family: var(--wp--preset--font-family--mono);
	font-weight: 800;
}

.caravanlogistics-system__steps strong {
	color: var(--wp--preset--color--white);
}

.caravanlogistics-system__steps p {
	margin: 0.45rem 0 0;
	color: rgba(255, 255, 255, 0.68);
	line-height: 1.6;
}

.caravanlogistics-services {
	padding: 5.5rem 0 6rem;
	background: var(--caravan-paper);
	color: var(--caravan-ink);
}

.caravanlogistics-services__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
	margin-top: 2rem;
}

.caravanlogistics-service-card {
	position: relative;
	display: flex;
	min-height: 19rem;
	flex-direction: column;
	justify-content: flex-end;
	overflow: hidden;
	border: 1px solid var(--caravan-line);
	border-radius: 0.5rem;
	padding: 1.2rem;
	background: #ffffff;
	color: var(--caravan-ink);
	text-decoration: none;
	box-shadow: var(--wp--preset--shadow--popover);
	transition:
		border-color 240ms var(--caravan-ease),
		box-shadow 240ms var(--caravan-ease),
		transform 240ms var(--caravan-ease);
}

.caravanlogistics-service-card--wide {
	grid-column: span 2;
}

.caravanlogistics-service-card img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 640ms var(--caravan-ease);
}

.caravanlogistics-service-card:has(img)::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(180deg, rgba(4, 9, 15, 0.08) 0%, rgba(4, 9, 15, 0.88) 100%);
}

.caravanlogistics-service-card span,
.caravanlogistics-service-card h3,
.caravanlogistics-service-card p {
	position: relative;
	z-index: 2;
}

.caravanlogistics-service-card span {
	color: var(--wp--preset--color--amber-700);
	font-family: var(--wp--preset--font-family--mono);
	font-size: var(--wp--preset--font-size--xs);
	font-weight: 800;
	text-transform: uppercase;
}

.caravanlogistics-service-card:has(img) span {
	color: var(--wp--preset--color--amber-300);
}

.caravanlogistics-service-card h3 {
	margin: 0.45rem 0 0;
	max-width: 32rem;
	color: inherit;
	font-size: var(--wp--preset--font-size--2-xl);
	line-height: 1.1;
	text-wrap: balance;
}

.caravanlogistics-service-card p {
	max-width: 32rem;
	margin: 0.7rem 0 0;
	color: var(--wp--preset--color--ink-900-alpha-72);
	line-height: 1.5;
}

.caravanlogistics-service-card:has(img) {
	color: var(--wp--preset--color--white);
	background: var(--wp--preset--color--navy-900);
}

.caravanlogistics-service-card:has(img) p {
	color: rgba(255, 255, 255, 0.76);
}

.caravanlogistics-service-card:hover,
.caravanlogistics-service-card:focus-visible {
	border-color: var(--wp--preset--color--amber-400-alpha-75);
	color: var(--caravan-ink);
	text-decoration: none;
	transform: translateY(-3px);
	box-shadow: var(--wp--preset--shadow--popover-hover);
}

.caravanlogistics-service-card:has(img):hover,
.caravanlogistics-service-card:has(img):focus-visible {
	color: var(--wp--preset--color--white);
}

.caravanlogistics-service-card:hover img,
.caravanlogistics-service-card:focus-visible img {
	transform: scale(1.035);
}

#accessibility-commitment {
	position: relative;
	background:
		linear-gradient(135deg, #0f2040 0%, #06101e 64%);
}

#accessibility-commitment > .wp-block-group {
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 0.5rem;
	padding: 2rem;
	background: rgba(255, 255, 255, 0.04);
}

#accessibility-commitment .wp-block-column {
	border-top: 1px solid rgba(255, 255, 255, 0.14);
	padding-top: 1rem;
}

.caravanlogistics-cta {
	position: relative;
	min-height: 30rem;
	overflow: hidden;
	display: flex;
	align-items: center;
	padding: 4rem 1.5rem;
	background: var(--wp--preset--color--navy-950);
	color: var(--wp--preset--color--white);
}

.caravanlogistics-cta > img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	opacity: 0.55;
}

.caravanlogistics-cta::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(4, 9, 15, 0.94) 0%, rgba(4, 9, 15, 0.66) 50%, rgba(4, 9, 15, 0.2) 100%);
}

.caravanlogistics-cta__content {
	position: relative;
	z-index: 1;
	width: min(100%, 1280px);
	margin-inline: auto;
}

.caravanlogistics-cta__content p {
	color: rgba(255, 255, 255, 0.74);
}

.caravanlogistics-careers-page {
	background:
		linear-gradient(180deg, #06101e 0%, #07111f 44rem, #f5f8fb 44rem, #f5f8fb 100%);
	color: var(--wp--preset--color--white);
}

.caravanlogistics-careers-hero {
	display: grid;
	grid-template-columns: minmax(0, 0.92fr) minmax(20rem, 0.78fr);
	gap: 2rem;
	align-items: stretch;
	width: min(100%, 1280px);
	margin-inline: auto;
	padding: 7rem 1.5rem 4rem;
}

.caravanlogistics-careers-hero__copy {
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-height: 32rem;
}

.caravanlogistics-careers-hero h1 {
	max-width: 11ch;
	margin: 0;
	color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--6-xl);
	font-weight: 900;
	line-height: 0.98;
	text-wrap: balance;
}

.caravanlogistics-careers-hero__lede {
	max-width: 45rem;
	margin: 1.4rem 0 0;
	color: rgba(255, 255, 255, 0.76);
	font-size: var(--wp--preset--font-size--lg);
	line-height: 1.7;
}

.caravanlogistics-careers-hero__media {
	position: relative;
	overflow: hidden;
	min-height: 32rem;
	margin: 0;
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 0.5rem;
	background: var(--wp--preset--color--navy-900);
	box-shadow: var(--wp--preset--shadow--hero);
}

.caravanlogistics-careers-hero__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(4, 9, 15, 0.02) 0%, rgba(4, 9, 15, 0.54) 100%);
}

.caravanlogistics-careers-hero__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.caravanlogistics-careers-story {
	display: grid;
	grid-template-columns: minmax(0, 0.84fr) minmax(20rem, 0.76fr);
	gap: 2rem;
	width: min(100%, 1280px);
	margin-inline: auto;
	padding: 4.5rem 1.5rem;
	color: var(--caravan-ink);
}

.caravanlogistics-careers-story h2 {
	max-width: 13ch;
	margin: 0;
	color: var(--caravan-ink);
	font-size: var(--wp--preset--font-size--5-xl);
	font-weight: 900;
	line-height: 1.02;
	text-wrap: balance;
}

.caravanlogistics-careers-story p,
.caravanlogistics-careers-opportunities__note {
	margin: 0;
	color: var(--wp--preset--color--ink-900-alpha-72);
	font-size: var(--wp--preset--font-size--lg);
	line-height: 1.68;
}

.caravanlogistics-careers-story__intro p {
	margin-top: 1.3rem;
}

.caravanlogistics-careers-story__body {
	display: grid;
	align-content: center;
	gap: 1.15rem;
}

.caravanlogistics-careers-reasons {
	padding: 5rem 1.5rem 5.5rem;
	background: var(--wp--preset--color--ink-900);
	color: var(--wp--preset--color--white);
}

.caravanlogistics-careers-reasons > * {
	width: min(100%, 1280px);
	margin-inline: auto;
}

.caravanlogistics-careers-reasons h2 {
	color: var(--wp--preset--color--white);
}

.caravanlogistics-careers-reasons .caravanlogistics-kicker {
	color: var(--wp--preset--color--amber-400);
}

.caravanlogistics-careers-reasons__list {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 0.85rem;
	margin: 2rem auto 0;
	padding: 0;
	list-style: none;
}

.caravanlogistics-careers-reasons__list li {
	display: flex;
	min-height: 8rem;
	align-items: flex-end;
	border: 1px solid rgba(255, 255, 255, 0.13);
	border-radius: 0.5rem;
	padding: 1rem;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.06) 0%, rgba(255, 255, 255, 0.025) 100%);
	color: rgba(255, 255, 255, 0.86);
	font-weight: 700;
	line-height: 1.35;
}

.caravanlogistics-careers-opportunities {
	width: min(100%, 1280px);
	margin-inline: auto;
	padding: 5rem 1.5rem;
	color: var(--caravan-ink);
}

.caravanlogistics-careers-opportunities h2 {
	color: var(--caravan-ink);
}

.caravanlogistics-careers-opportunities__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 1rem;
	margin-top: 2rem;
}

.caravanlogistics-careers-opportunity {
	position: relative;
	display: flex;
	min-height: 18rem;
	flex-direction: column;
	justify-content: space-between;
	overflow: hidden;
	border: 1px solid var(--caravan-line);
	border-radius: 0.5rem;
	padding: 1.15rem;
	background: #ffffff;
	color: var(--caravan-ink);
	text-decoration: none;
	box-shadow: var(--wp--preset--shadow--popover);
	transition:
		border-color 240ms var(--caravan-ease),
		box-shadow 240ms var(--caravan-ease),
		color 240ms var(--caravan-ease),
		transform 240ms var(--caravan-ease);
}

.caravanlogistics-careers-opportunity::after {
	content: "→";
	position: absolute;
	right: 1.1rem;
	bottom: 1rem;
	color: var(--wp--preset--color--amber-900);
	font-weight: 900;
}

.caravanlogistics-careers-opportunity span {
	color: var(--wp--preset--color--amber-900);
	font-family: var(--wp--preset--font-family--mono);
	font-size: var(--wp--preset--font-size--xs);
	font-weight: 800;
	text-transform: uppercase;
}

.caravanlogistics-careers-opportunity strong {
	display: block;
	padding-right: 1.4rem;
	color: inherit;
	font-size: var(--wp--preset--font-size--xl);
	line-height: 1.14;
	text-wrap: balance;
}

.caravanlogistics-careers-opportunity--drive {
	grid-column: span 2;
	background:
		linear-gradient(180deg, rgba(4, 9, 15, 0.16) 0%, rgba(4, 9, 15, 0.86) 100%),
		url("/wp-content/themes/caravanlogistics-wp/assets/images/cvgp-volvo-banner.jpg") center / cover;
	color: var(--wp--preset--color--white);
}

.caravanlogistics-careers-opportunity--drive span,
.caravanlogistics-careers-opportunity--drive::after {
	color: var(--wp--preset--color--amber-300);
}

.caravanlogistics-careers-opportunity--contact {
	grid-column: span 4;
	min-height: 10rem;
	background: var(--wp--preset--color--navy-900);
	color: var(--wp--preset--color--white);
}

.caravanlogistics-careers-opportunity--contact span,
.caravanlogistics-careers-opportunity--contact::after {
	color: var(--wp--preset--color--amber-300);
}

.caravanlogistics-careers-opportunity--contact strong {
	max-width: 52rem;
}

.caravanlogistics-careers-opportunity:hover,
.caravanlogistics-careers-opportunity:focus-visible {
	border-color: var(--wp--preset--color--amber-400-alpha-75);
	color: var(--caravan-ink);
	text-decoration: none;
	transform: translateY(-3px);
	box-shadow: var(--wp--preset--shadow--popover-hover);
}

.caravanlogistics-careers-opportunity--drive:hover,
.caravanlogistics-careers-opportunity--drive:focus-visible,
.caravanlogistics-careers-opportunity--contact:hover,
.caravanlogistics-careers-opportunity--contact:focus-visible {
	color: var(--wp--preset--color--white);
}

.caravanlogistics-careers-opportunities__note {
	max-width: 58rem;
	margin-top: 1.5rem;
	font-size: var(--wp--preset--font-size--base);
}

main a:not(.wp-block-button__link):not(.caravanlogistics-button):not(.caravanlogistics-service-card) {
	text-decoration-line: underline;
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.18em;
}

.caravanlogistics-service-card,
.caravanlogistics-careers-opportunity,
.caravanlogistics-button {
	text-decoration: none !important;
}

@media (prefers-reduced-motion: no-preference) {
	.caravanlogistics-hero__copy,
	.caravanlogistics-hero__ops {
		animation: caravan-rise 760ms var(--caravan-ease) both;
	}

	.caravanlogistics-hero__ops {
		animation-delay: 120ms;
	}

	@keyframes caravan-rise {
		from {
			transform: translateY(20px);
		}
		to {
			transform: translateY(0);
		}
	}
}

@media (max-width: 1080px) {
	.site-topbar__proof {
		display: none;
	}

	.site-topbar__inner {
		justify-content: flex-end;
	}

	.site-brand img {
		width: 11rem;
	}

	.site-header__actions .wp-block-navigation {
		display: none;
	}

	.site-footer__dispatch-top {
		grid-template-columns: 1fr;
		align-items: start;
	}

	.site-footer__actions {
		justify-content: flex-start;
	}

	.site-footer__dispatch-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.site-footer__contact {
		grid-column: span 2;
	}

	.caravanlogistics-hero__inner,
	.caravanlogistics-proof,
	.caravanlogistics-system__layout,
	.caravanlogistics-careers-hero,
	.caravanlogistics-careers-story {
		grid-template-columns: 1fr;
	}

	.caravanlogistics-hero__ops {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.caravanlogistics-proof__media,
	.caravanlogistics-system__image img {
		min-height: 22rem;
	}

	.caravanlogistics-services__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.caravanlogistics-careers-reasons__list,
	.caravanlogistics-careers-opportunities__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.caravanlogistics-careers-opportunity--contact {
		grid-column: span 2;
	}

	.caravanlogistics-service-card--wide {
		grid-column: span 2;
	}
}

@media (max-width: 720px) {
	.site-topbar__inner {
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.site-topbar__links {
		width: 100%;
		justify-content: space-between;
	}

	.site-header {
		padding-left: 1rem !important;
		padding-right: 1rem !important;
	}

	.site-header > .wp-block-group {
		gap: 0.65rem;
	}

	.site-brand {
		padding-right: 0;
	}

	.site-brand::after {
		display: none;
	}

	.site-brand img {
		width: 7.75rem;
	}

	.site-header__actions {
		gap: 0.45rem;
	}

	.caravanlogistics-header-link,
	.site-header .wp-block-button__link {
		min-height: 2.4rem;
		padding: 0.55rem 0.72rem;
		font-size: 0.78rem;
	}

	.site-footer--dispatch-index {
		padding: 2rem 1rem 1.5rem !important;
	}

	.site-footer__brand img {
		width: 11rem;
	}

	.site-footer__accreditations-list {
		gap: 0.5rem;
	}

	.site-footer__accreditation img {
		height: 2rem;
	}

	.site-footer__dispatch-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 1.15rem;
	}

	.site-footer__contact {
		grid-column: span 2;
	}

	.site-footer__section .site-footer__heading {
		margin-bottom: 0.7rem;
	}

	.site-footer--dispatch-index .site-footer__legal {
		align-items: flex-start;
		flex-direction: column;
	}

	.site-footer__legal-links {
		justify-content: flex-start;
	}

	/* Mobile header order: logo, Track/Get a Rate, hamburger.
	 * Brand stays first; push the actions group ahead of the primary nav. */
	.site-header > .wp-block-group > .site-brand          { order: 1; }
	.site-header > .wp-block-group > .site-header__actions { order: 2; }
	.site-header > .wp-block-group > .wp-block-navigation  { order: 3; }

	.site-header > .wp-block-group > .wp-block-navigation {
		flex: 0 0 auto;
	}

	.site-header .wp-block-navigation__container {
		width: auto;
		justify-content: flex-start;
		column-gap: var(--wp--preset--spacing--10);
	}

	.site-header .wp-block-navigation:not(.has-background) .wp-block-navigation__responsive-container.is-menu-open {
		background: var(--wp--preset--color--navy-900);
		color: var(--wp--preset--color--white);
		padding: 1.2rem;
	}

	.caravanlogistics-hero {
		min-height: auto;
		padding: 6rem 1rem 2rem;
	}

	.caravanlogistics-hero__photo img {
		object-position: 62% 50%;
	}

	.caravanlogistics-hero__scrim {
		background:
			linear-gradient(180deg, rgba(4, 9, 15, 0.68) 0%, rgba(4, 9, 15, 0.97) 64%),
			linear-gradient(90deg, rgba(4, 9, 15, 0.52), rgba(4, 9, 15, 0.52));
	}

	.caravanlogistics-hero h1,
	.caravanlogistics-careers-hero h1,
	.caravanlogistics-section__header h2,
	.caravanlogistics-proof__content h2,
	.caravanlogistics-careers-story h2,
	.caravanlogistics-system__intro h2,
	.caravanlogistics-cta__content h2 {
		font-size: 2.5rem;
		line-height: 1.04;
	}

	.caravanlogistics-hero__ops,
	.caravanlogistics-services__grid,
	.caravanlogistics-careers-reasons__list,
	.caravanlogistics-careers-opportunities__grid {
		grid-template-columns: 1fr;
	}

	.caravanlogistics-service-card--wide,
	.caravanlogistics-careers-opportunity--drive,
	.caravanlogistics-careers-opportunity--contact {
		grid-column: span 1;
	}

	.caravanlogistics-service-card,
	.caravanlogistics-careers-opportunity {
		min-height: 16rem;
	}

	.caravanlogistics-careers-reasons__list li {
		min-height: 6.5rem;
	}

	.caravanlogistics-proof__content,
	.caravanlogistics-system,
	.caravanlogistics-services,
	.caravanlogistics-careers-reasons,
	.caravanlogistics-careers-opportunities {
		padding-top: 3rem;
		padding-bottom: 3.5rem;
	}

	.caravanlogistics-proof__content {
		padding-left: 1.5rem;
		padding-right: 1.5rem;
	}

	.caravanlogistics-careers-hero {
		gap: 1.25rem;
		padding: 5.5rem 1rem 3rem;
	}

	.caravanlogistics-careers-hero__copy {
		min-height: auto;
	}

	.caravanlogistics-careers-hero__media {
		min-height: 18rem;
	}

	.caravanlogistics-careers-story {
		padding: 3rem 1rem;
	}

	.caravanlogistics-careers-story p,
	.caravanlogistics-careers-hero__lede {
		font-size: var(--wp--preset--font-size--base);
	}

	.caravanlogistics-system__steps li {
		padding-left: 1rem;
	}

	.caravanlogistics-system__steps span {
		position: static;
		display: block;
		margin-bottom: 0.5rem;
	}

	.caravanlogistics-actions {
		flex-direction: column;
		align-items: stretch;
	}

	.caravanlogistics-button,
	.wp-block-button__link {
		width: 100%;
	}
}

/* =========================================================================
 * /about/ — landing page + 7 sub-page sections
 * Built on existing tokens (navy/amber/white-alpha) and existing components
 * (.caravanlogistics-hero, .caravanlogistics-kicker, .caravanlogistics-button).
 * ========================================================================= */

/* Section container — shared by every about section */
.about-body,
.about-intro,
.about-index,
.about-services-grid,
.about-locations,
.about-timeline,
.about-pullquote,
.about-leaders,
.about-commitments,
.about-causes,
.about-techgrid,
.about-certs {
	padding: clamp(3.5rem, 7vw, 5.5rem) 1.5rem;
}

.about-body__inner,
.about-intro__inner,
.about-index__inner,
.about-services-grid__inner,
.about-locations__inner,
.about-timeline__inner,
.about-pullquote__inner,
.about-leaders__inner,
.about-commitments__inner,
.about-causes__inner,
.about-techgrid__inner,
.about-certs__inner,
.about-stats-strip__inner,
.about-subnav__inner {
	width: min(100%, 1280px);
	margin-inline: auto;
}

/* Sub-page hero — shorter than homepage hero, no ops sidebar by default */
.caravanlogistics-hero.about-subhero {
	min-height: 60svh;
	padding-top: 6rem;
	padding-bottom: 3rem;
}

.caravanlogistics-hero.about-subhero .caravanlogistics-hero__inner {
	grid-template-columns: minmax(0, 1fr);
}

.caravanlogistics-hero.about-subhero h1 {
	font-size: clamp(2.4rem, 4.6vw, 4rem);
	max-width: 22ch;
}

/* History hero — oversized 1997 background numeral instead of photo */
.about-subhero--numeral {
	background:
		radial-gradient(ellipse 80% 70% at 20% 0%, rgba(245, 166, 35, 0.07) 0%, transparent 70%),
		linear-gradient(180deg, #07091a 0%, #0a1628 100%);
}

.about-numeral {
	position: absolute;
	inset: auto -5% -8% auto;
	z-index: 0;
	color: rgba(245, 166, 35, 0.06);
	font-family: var(--wp--preset--font-family--mono);
	font-size: clamp(16rem, 38vw, 38rem);
	font-weight: 900;
	font-variant-numeric: tabular-nums;
	line-height: 0.85;
	letter-spacing: -0.04em;
	pointer-events: none;
	user-select: none;
}

/* ---- Sub-navigation (every /about/* page) ---- */
.about-subnav {
	position: sticky;
	top: 3.6rem;
	z-index: 5;
	border-bottom: 1px solid var(--wp--preset--color--white-alpha-15);
	background: rgba(6, 16, 30, 0.78);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.about-subnav__inner {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	padding: 0.75rem 1.5rem;
	overflow-x: auto;
	scrollbar-width: thin;
}

.about-subnav__home {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	flex-shrink: 0;
	padding: 0.5rem 0.75rem 0.5rem 0.5rem;
	border-radius: 0.375rem;
	color: var(--wp--preset--color--white-alpha-65);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	text-decoration: none;
	transition: color 220ms var(--caravan-ease);
}

.about-subnav__home:hover,
.about-subnav__home:focus-visible {
	color: var(--wp--preset--color--amber-300);
	text-decoration: none;
}

.about-subnav__list {
	display: flex;
	gap: 0.25rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.about-subnav__item a {
	display: inline-flex;
	align-items: center;
	min-height: 2.5rem;
	padding: 0.5rem 0.9rem;
	border-bottom: 2px solid transparent;
	color: var(--wp--preset--color--white-alpha-65);
	font-size: 0.85rem;
	font-weight: 600;
	letter-spacing: 0.01em;
	text-decoration: none;
	transition:
		color 220ms var(--caravan-ease),
		border-color 220ms var(--caravan-ease);
	white-space: nowrap;
}

.about-subnav__item a:hover,
.about-subnav__item a:focus-visible {
	color: var(--wp--preset--color--white);
	text-decoration: none;
}

.about-subnav__item.is-current a {
	color: var(--wp--preset--color--amber-300);
	border-bottom-color: var(--wp--preset--color--amber-400);
}

/* ---- Stats strip (landing + environmental + awards) ---- */
.about-stats-strip {
	padding: clamp(2.5rem, 5vw, 3.5rem) 1.5rem;
	background: var(--wp--preset--color--navy-800);
	border-top: 1px solid var(--wp--preset--color--white-alpha-15);
	border-bottom: 1px solid var(--wp--preset--color--white-alpha-15);
}

.about-stats-strip--inverse {
	background:
		linear-gradient(180deg, var(--wp--preset--color--navy-900) 0%, var(--wp--preset--color--navy-950) 100%);
}

.about-stats-strip__inner {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
	gap: 1.5rem;
	align-items: end;
}

.about-stat {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	padding: 0.5rem 0;
	border-top: 1px solid var(--wp--preset--color--white-alpha-15);
}

.about-stat strong {
	color: var(--wp--preset--color--white);
	font-family: var(--wp--preset--font-family--inter);
	font-size: clamp(2.4rem, 4.8vw, 3.8rem);
	font-weight: 900;
	font-variant-numeric: tabular-nums;
	letter-spacing: -0.02em;
	line-height: 0.95;
}

.about-stat strong em {
	color: var(--wp--preset--color--amber-400);
	font-style: normal;
	font-weight: 700;
}

.about-stat span {
	color: var(--wp--preset--color--white-alpha-65);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.74rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

/* ---- Landing — intro pillars ---- */
.about-intro__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
	gap: clamp(2rem, 4vw, 3.5rem);
	align-items: start;
}

.about-intro h2 {
	margin: 0 0 1.25rem;
	font-size: var(--wp--preset--font-size--5-xl);
	font-weight: 800;
	line-height: 1.04;
	text-wrap: balance;
}

.about-intro__copy p {
	max-width: 38rem;
	margin: 1rem 0 0;
	color: var(--wp--preset--color--white-alpha-65);
	font-size: var(--wp--preset--font-size--lg);
	line-height: 1.7;
}

.about-intro__pillars {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.about-intro__pillars li {
	position: relative;
	padding: 1.4rem 1.2rem 1.2rem;
	border: 1px solid var(--wp--preset--color--white-alpha-15);
	border-radius: 0.5rem;
	background: rgba(255, 255, 255, 0.025);
}

.about-intro__num {
	display: block;
	margin-bottom: 0.75rem;
	color: var(--wp--preset--color--amber-400);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.06em;
}

.about-intro__pillars strong {
	display: block;
	margin-bottom: 0.4rem;
	color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 700;
	line-height: 1.2;
}

.about-intro__pillars p {
	margin: 0;
	color: var(--wp--preset--color--white-alpha-65);
	font-size: 0.94rem;
	line-height: 1.55;
}

/* ---- Landing — 7-card section index ---- */
.about-index__header {
	max-width: 48rem;
	margin-bottom: 2.5rem;
}

.about-index__header h2 {
	margin: 0 0 0.75rem;
	font-size: var(--wp--preset--font-size--5-xl);
	font-weight: 800;
	line-height: 1.04;
	text-wrap: balance;
}

.about-index__header p {
	margin: 0;
	color: var(--wp--preset--color--white-alpha-65);
	font-size: var(--wp--preset--font-size--lg);
	line-height: 1.6;
}

.about-index__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.about-index__card {
	display: block;
}

.about-index__card a {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	height: 100%;
	min-height: 12rem;
	padding: 1.5rem 1.5rem 1.4rem;
	border: 1px solid var(--wp--preset--color--white-alpha-15);
	border-radius: 0.5rem;
	background: rgba(255, 255, 255, 0.025);
	color: var(--wp--preset--color--white);
	text-decoration: none;
	transition:
		transform 220ms var(--caravan-ease),
		border-color 220ms var(--caravan-ease),
		background-color 220ms var(--caravan-ease),
		box-shadow 220ms var(--caravan-ease);
}

.about-index__card a:hover,
.about-index__card a:focus-visible {
	transform: translateY(-3px);
	border-color: var(--wp--preset--color--amber-400-alpha-45);
	background: rgba(255, 184, 77, 0.045);
	box-shadow: var(--wp--preset--shadow--lifted);
	text-decoration: none;
}

.about-index__num {
	color: var(--wp--preset--color--amber-400);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
}

.about-index__card h3 {
	margin: 0;
	color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--2-xl);
	font-weight: 800;
	line-height: 1.1;
}

.about-index__card p {
	margin: 0;
	color: var(--wp--preset--color--white-alpha-65);
	font-size: 0.95rem;
	line-height: 1.55;
}

.about-index__chev {
	position: absolute;
	top: 1.5rem;
	right: 1.5rem;
	color: var(--wp--preset--color--amber-400);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 1.4rem;
	transition: transform 220ms var(--caravan-ease);
}

.about-index__card a:hover .about-index__chev,
.about-index__card a:focus-visible .about-index__chev {
	transform: translateX(4px);
}

/* ---- Section body (used on most sub-pages) ---- */
.about-body__copy {
	max-width: 56rem;
}

.about-body h2 {
	margin: 0 0 1.25rem;
	font-size: var(--wp--preset--font-size--5-xl);
	font-weight: 800;
	line-height: 1.04;
	text-wrap: balance;
}

.about-body p {
	max-width: 42rem;
	margin: 1rem 0 0;
	color: var(--wp--preset--color--white-alpha-65);
	font-size: var(--wp--preset--font-size--lg);
	line-height: 1.7;
}

.about-body p:first-of-type {
	margin-top: 0;
}

.about-body--portal {
	background: var(--wp--preset--color--navy-900);
}

/* ---- Profile — services grid ---- */
.about-services-grid h2 {
	margin: 0 0 2rem;
	font-size: var(--wp--preset--font-size--4-xl);
	font-weight: 800;
	line-height: 1.04;
}

.about-services-grid__list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.about-services-grid__list a {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	min-height: 7.5rem;
	padding: 1.25rem;
	border: 1px solid var(--wp--preset--color--white-alpha-15);
	border-radius: 0.5rem;
	background: rgba(255, 255, 255, 0.025);
	color: var(--wp--preset--color--white);
	text-decoration: none;
	transition:
		transform 220ms var(--caravan-ease),
		border-color 220ms var(--caravan-ease),
		background-color 220ms var(--caravan-ease);
}

.about-services-grid__list a:hover,
.about-services-grid__list a:focus-visible {
	transform: translateY(-2px);
	border-color: var(--wp--preset--color--amber-400-alpha-45);
	background: rgba(255, 184, 77, 0.04);
	text-decoration: none;
}

.about-services-grid__list strong {
	color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 700;
}

.about-services-grid__list span {
	color: var(--wp--preset--color--white-alpha-65);
	font-size: 0.9rem;
	line-height: 1.5;
}

/* ---- Profile — locations grid ---- */
.about-locations h2 {
	margin: 0 0 2rem;
	font-size: var(--wp--preset--font-size--4-xl);
	font-weight: 800;
	line-height: 1.04;
}

.about-locations__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.about-locations__card {
	position: relative;
	padding: 1.5rem 1.5rem 1.4rem;
	border: 1px solid var(--wp--preset--color--white-alpha-15);
	border-radius: 0.5rem;
	background: rgba(255, 255, 255, 0.025);
}

.about-locations__card--hq {
	border-color: var(--wp--preset--color--amber-400-alpha-45);
	background: rgba(255, 184, 77, 0.05);
}

.about-locations__badge {
	display: inline-block;
	margin-bottom: 0.85rem;
	padding: 0.2rem 0.55rem;
	border: 1px solid var(--wp--preset--color--amber-400-alpha-45);
	border-radius: 0.25rem;
	color: var(--wp--preset--color--amber-300);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.08em;
}

.about-locations__card h3 {
	margin: 0 0 0.6rem;
	color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--xl);
	font-weight: 700;
	line-height: 1.2;
}

.about-locations__card p {
	margin: 0;
	color: var(--wp--preset--color--white-alpha-65);
	font-size: 0.92rem;
	line-height: 1.55;
}

.about-locations__phone {
	display: inline-block;
	margin-top: 0.85rem;
	color: var(--wp--preset--color--amber-300);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.95rem;
	font-weight: 600;
	letter-spacing: 0.01em;
	text-decoration: none;
}

.about-locations__phone:hover,
.about-locations__phone:focus-visible {
	color: var(--wp--preset--color--amber-400);
	text-decoration: underline;
}

/* ---- History — vertical timeline ---- */
.about-timeline h2 {
	margin: 0 0 2.5rem;
	font-size: var(--wp--preset--font-size--4-xl);
	font-weight: 800;
	line-height: 1.04;
}

.about-timeline__list {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 2rem;
	margin: 0;
	padding: 0 0 0 5.5rem;
	list-style: none;
}

.about-timeline__list::before {
	content: "";
	position: absolute;
	top: 0.5rem;
	bottom: 0.5rem;
	left: 4rem;
	width: 2px;
	background: linear-gradient(
		180deg,
		var(--wp--preset--color--amber-400-alpha-75) 0%,
		var(--wp--preset--color--white-alpha-15) 100%
	);
}

.about-timeline__item {
	position: relative;
}

.about-timeline__item::before {
	content: "";
	position: absolute;
	top: 1.1rem;
	left: -1.75rem;
	width: 0.75rem;
	height: 0.75rem;
	border-radius: 50%;
	background: var(--wp--preset--color--amber-400);
	box-shadow: 0 0 0 4px rgba(245, 166, 35, 0.18);
}

.about-timeline__item.is-current::before {
	background: var(--wp--preset--color--amber-300);
	box-shadow: 0 0 0 6px rgba(245, 166, 35, 0.24);
}

.about-timeline__year {
	position: absolute;
	top: 0.8rem;
	left: -5.5rem;
	width: 3.5rem;
	color: var(--wp--preset--color--amber-300);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.86rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-align: right;
}

.about-timeline__card {
	padding: 1.25rem 1.5rem 1.3rem;
	border: 1px solid var(--wp--preset--color--white-alpha-15);
	border-radius: 0.5rem;
	background: rgba(255, 255, 255, 0.03);
}

.about-timeline__item.is-current .about-timeline__card {
	border-color: var(--wp--preset--color--amber-400-alpha-45);
	background: rgba(255, 184, 77, 0.045);
}

.about-timeline__card h3 {
	margin: 0 0 0.5rem;
	color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--xl);
	font-weight: 700;
	line-height: 1.2;
}

.about-timeline__card p {
	margin: 0;
	color: var(--wp--preset--color--white-alpha-65);
	font-size: 0.95rem;
	line-height: 1.6;
}

/* ---- Pullquote band ---- */
.about-pullquote {
	background:
		radial-gradient(ellipse 70% 50% at 50% 0%, rgba(245, 166, 35, 0.06) 0%, transparent 70%),
		var(--wp--preset--color--navy-900);
}

.about-pullquote__inner {
	max-width: 64rem;
	text-align: center;
}

.about-pullquote__mark {
	margin: 0;
	color: var(--wp--preset--color--amber-400);
	font-family: var(--wp--preset--font-family--inter);
	font-size: clamp(4rem, 7vw, 6rem);
	font-weight: 900;
	line-height: 0.8;
}

.about-pullquote__quote {
	margin: 0.5rem 0 1.25rem;
}

.about-pullquote__quote p {
	margin: 0;
	color: var(--wp--preset--color--white);
	font-size: clamp(1.5rem, 3vw, 2.2rem);
	font-weight: 700;
	line-height: 1.3;
	text-wrap: balance;
}

.about-pullquote__cite {
	margin: 0;
	color: var(--wp--preset--color--white-alpha-65);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

/* ---- Leadership — leader grid ---- */
.about-leaders h2 {
	margin: 0 0 2rem;
	font-size: var(--wp--preset--font-size--4-xl);
	font-weight: 800;
	line-height: 1.04;
}

.about-leaders__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.25rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.about-leaders__card {
	padding: 1.25rem;
	border: 1px solid var(--wp--preset--color--white-alpha-15);
	border-radius: 0.5rem;
	background: rgba(255, 255, 255, 0.025);
}

.about-leaders__photo {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 3 / 4;
	margin-bottom: 1.1rem;
	overflow: hidden;
	border-radius: 0.375rem;
	background:
		linear-gradient(135deg, var(--wp--preset--color--navy-700) 0%, var(--wp--preset--color--navy-900) 100%);
}

.about-leaders__photo-mark {
	color: var(--wp--preset--color--amber-400-alpha-75);
	font-family: var(--wp--preset--font-family--mono);
	font-size: clamp(2rem, 4vw, 3.2rem);
	font-weight: 900;
	letter-spacing: 0.04em;
}

.about-leaders__card h3 {
	margin: 0 0 0.25rem;
	color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 700;
	line-height: 1.2;
}

.about-leaders__title {
	margin: 0 0 0.7rem;
	color: var(--wp--preset--color--amber-300);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.about-leaders__card p {
	margin: 0;
	color: var(--wp--preset--color--white-alpha-65);
	font-size: 0.92rem;
	line-height: 1.55;
}

/* ---- Environmental — commitments grid ---- */
.about-commitments h2 {
	margin: 0 0 2rem;
	font-size: var(--wp--preset--font-size--4-xl);
	font-weight: 800;
	line-height: 1.04;
}

.about-commitments__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.about-commitments__grid li {
	padding: 1.5rem 1.4rem 1.4rem;
	border: 1px solid var(--wp--preset--color--white-alpha-15);
	border-radius: 0.5rem;
	background: rgba(255, 255, 255, 0.025);
}

.about-commitments__num {
	display: block;
	margin-bottom: 0.9rem;
	color: var(--wp--preset--color--amber-400);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
}

.about-commitments__grid h3 {
	margin: 0 0 0.6rem;
	color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--xl);
	font-weight: 700;
	line-height: 1.2;
}

.about-commitments__grid p {
	margin: 0;
	color: var(--wp--preset--color--white-alpha-65);
	font-size: 0.94rem;
	line-height: 1.6;
}

/* ---- Community — causes ---- */
.about-causes h2 {
	margin: 0 0 2rem;
	font-size: var(--wp--preset--font-size--4-xl);
	font-weight: 800;
	line-height: 1.04;
}

.about-causes__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.about-causes__card {
	padding: 1.5rem 1.4rem 1.4rem;
	border: 1px solid var(--wp--preset--color--white-alpha-15);
	border-radius: 0.5rem;
	background: rgba(255, 255, 255, 0.025);
}

.about-causes__num {
	display: block;
	margin-bottom: 0.85rem;
	color: var(--wp--preset--color--amber-400);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
}

.about-causes__card h3 {
	margin: 0 0 0.5rem;
	color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--xl);
	font-weight: 700;
	line-height: 1.2;
}

.about-causes__card p {
	margin: 0;
	color: var(--wp--preset--color--white-alpha-65);
	font-size: 0.94rem;
	line-height: 1.6;
}

/* ---- Technology — capability grid ---- */
.about-techgrid h2 {
	margin: 0 0 2rem;
	font-size: var(--wp--preset--font-size--4-xl);
	font-weight: 800;
	line-height: 1.04;
}

.about-techgrid__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.about-techgrid__card {
	padding: 1.4rem 1.3rem 1.3rem;
	border: 1px solid var(--wp--preset--color--white-alpha-15);
	border-radius: 0.5rem;
	background: rgba(255, 255, 255, 0.025);
}

.about-techgrid__icon {
	display: block;
	margin-bottom: 1rem;
	color: var(--wp--preset--color--amber-400);
}

.about-techgrid__card h3 {
	margin: 0 0 0.5rem;
	color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 700;
	line-height: 1.2;
}

.about-techgrid__card p {
	margin: 0;
	color: var(--wp--preset--color--white-alpha-65);
	font-size: 0.92rem;
	line-height: 1.55;
}

/* ---- Awards — certifications grid ---- */
.about-certs h2 {
	margin: 0 0 2rem;
	font-size: var(--wp--preset--font-size--4-xl);
	font-weight: 800;
	line-height: 1.04;
}

.about-certs__grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.about-certs__card {
	display: flex;
	flex-direction: column;
	flex: 0 0 calc((100% - 3rem) / 4);
	gap: 0.4rem;
	padding: 1.5rem 1.4rem 1.4rem;
	border: 1px solid var(--wp--preset--color--white-alpha-15);
	border-radius: 0.5rem;
	background: rgba(255, 255, 255, 0.025);
}

.about-certs__mark {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 4.2rem;
	margin-bottom: 0.8rem;
	padding: 0.5rem 0.85rem;
	border-radius: 0.375rem;
	background: #fff;
}

.about-certs__mark img {
	display: block;
	max-width: 100%;
	max-height: 100%;
	width: auto;
	object-fit: contain;
}

.about-certs__card h3 {
	margin: 0;
	color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 700;
	line-height: 1.2;
}

.about-certs__card p {
	margin: 0;
	color: var(--wp--preset--color--white-alpha-65);
	font-size: 0.9rem;
	line-height: 1.55;
}

/* ---- Reduced motion ---- */
@media (prefers-reduced-motion: reduce) {
	.about-index__card a,
	.about-services-grid__list a,
	.about-index__chev {
		transition: none !important;
	}

	.about-index__card a:hover,
	.about-index__card a:focus-visible,
	.about-services-grid__list a:hover,
	.about-services-grid__list a:focus-visible {
		transform: none;
	}

	.about-index__card a:hover .about-index__chev,
	.about-index__card a:focus-visible .about-index__chev {
		transform: none;
	}
}

/* ---- About: mobile / tablet ---- */
@media (max-width: 1080px) {
	.about-intro__inner {
		grid-template-columns: 1fr;
	}

	.about-index__grid,
	.about-services-grid__list,
	.about-locations__grid,
	.about-leaders__grid,
	.about-commitments__grid,
	.about-causes__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.about-techgrid__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	/* 3 cards per row at tablet width; partial rows stay centered. */
	.about-certs__card {
		flex-basis: calc((100% - 2rem) / 3);
	}

	.about-subnav {
		top: 3.2rem;
	}
}

@media (max-width: 720px) {
	.about-body,
	.about-intro,
	.about-index,
	.about-services-grid,
	.about-locations,
	.about-timeline,
	.about-pullquote,
	.about-leaders,
	.about-commitments,
	.about-causes,
	.about-techgrid,
	.about-certs {
		padding: 2.75rem 1rem;
	}

	.about-stats-strip {
		padding: 2rem 1rem;
	}

	.about-stats-strip__inner {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.25rem;
	}

	.about-intro__pillars,
	.about-index__grid,
	.about-services-grid__list,
	.about-locations__grid,
	.about-leaders__grid,
	.about-commitments__grid,
	.about-causes__grid,
	.about-techgrid__grid {
		grid-template-columns: 1fr;
	}

	.about-certs__card {
		flex-basis: 100%;
	}

	.about-timeline__list {
		padding-left: 3.5rem;
	}

	.about-timeline__list::before {
		left: 2rem;
	}

	.about-timeline__year {
		left: -3.5rem;
		width: 2.5rem;
		font-size: 0.78rem;
	}

	.about-subnav {
		position: static;
	}

	.about-subnav__inner {
		padding: 0.5rem 1rem;
	}

	.about-numeral {
		font-size: clamp(10rem, 60vw, 16rem);
	}
}

/* WordPress emits the top-level block gap outside our cascade layers. Keep the
   footer template attached to the preceding page section on every route. */
.wp-site-blocks > footer.wp-block-template-part {
	margin-block-start: 0;
	margin-block-end: 0;
	background: var(--wp--preset--color--navy-900);
}
