/* Hero Block */

.hero .kh-block-inner {
	padding-block: 0 !important;
}

.hero > div::before {
	bottom: 0;
	left: 0;
	translate: -50% 50%;
}

.hero > div::after {
	top: 0;
	right: 0;
	translate: 50% -50%;
}

.hero-layout {
	display: flex;
	flex-direction: column;
	width: 100%;
	min-height: 53.75rem;
	gap: var(--wp--preset--spacing--lg);
}

.hero-word {
	display: inline-block;
}

/* Left column — heading, CTA, and cards */

.hero-content-col {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: var(--wp--preset--spacing--lg);
	padding-block: var(--wp--preset--spacing--3-xl) var(--wp--preset--spacing--md);
}

.hero-content-col .hero-content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--wp--preset--spacing--sm);
}

.hero-content-col .hero-content > * {
	margin: 0;
}

.hero-content-col .hero-content h1 {
	max-width: 14ch;
	text-wrap: balance;
}

.hero-content-col .hero-cards-grid {
	display: grid;
	gap: var(--wp--preset--spacing--xxs);
	width: 100%;
}

.hero-cards-grid .hero-card {
	position: relative;
	background: var(--wp--custom--color--bg--01);
	overflow: clip;
	text-decoration: none;
	color: var(--wp--custom--color--text--heading-primary);
	border: 1px solid var(--wp--custom--color--border--white);
	border-radius: var(--wp--custom--radius--xl);
	container-type: inline-size;
	transition: border-color .3s ease;
}

.hero-cards-grid .hero-card:is(a):hover {
	border-color: var(--wp--custom--color--border--action);
}

.hero-card .hero-card-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--wp--preset--spacing--xxs);
	padding: var(--wp--preset--spacing--sm) var(--wp--preset--spacing--xs);
}

.hero-card .hero-card-icon {
	width: 1.5rem;
	aspect-ratio: 1;
	flex-shrink: 0;
}

.hero-card .hero-card-icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.hero-card h2 {
	flex: 1;
	margin: 0;
	font-size: clamp(0.9375rem, 0.7132rem + 1.1214vw, 1.125rem);
}

.hero-card .card-arrow {
	display: none;
	visibility: hidden;
	opacity: 0;
	margin-right: .5rem;
	transition: opacity .3s ease;
}

.hero-card:is(a):hover .card-arrow {
	opacity: 1;
}

.hero-card .card-arrow-arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 2.75rem;
	aspect-ratio: 1;
	border-color: var(--wp--custom--color--border--action);
	background-color: var(--wp--custom--color--bg--action);
	color: var(--wp--custom--color--icon--white);
	border-radius: var(--wp--custom--radius--full);
	animation: card-arrow-fade-in .3s ease forwards, card-arrow-pulse 1s .3s ease-in-out infinite alternate;
}

.hero-card .card-arrow-arrow svg {
	width: 1.5rem;
}

@container (width > 17.5rem) {
	.hero-card .card-arrow {
		display: flex;
		visibility: visible;
	}
}

/* Right column — image/video */

.hero-image-col {
	flex: 1;
	position: relative;
	width: 100%;
	min-height: 25rem;
	aspect-ratio: 1.5;
	padding-block: var(--wp--preset--spacing--md);
}

.hero-image-col .hero-image {
	position: absolute;
	z-index: 1;
	inset: 0 auto 0 50%;
	width: 100vw;
	height: 100%;
	overflow: hidden;
	margin: 0;
	border-radius: var(--wp--custom--radius--3-xl);
	translate: -50% 0;
}

.hero-image-col .hero-image img,
.hero-image-col .hero-image video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	scale: 1.1;
	will-change: transform;
}

.hero-image-col .hero-image.is-overlay::before,
.hero-image-col .hero-image.is-overlay::after {
	content: "";
	position: absolute;
	z-index: 1;
	inset: 0;
}

.hero-image-col .hero-image.is-overlay::before {
	background-color: var(--wp--preset--color--teal-900);
	opacity: .25;
}

.hero-image-col .hero-image.is-overlay::after {
	background: linear-gradient(180deg, rgba(46, 60, 64, 0.00) 30%, rgba(46, 60, 64, 0.75) 100%);
}

.hero-image .hero-video-control {
	position: absolute;
	z-index: 2;
	bottom: var(--wp--preset--spacing--sm);
	right: var(--wp--preset--spacing--sm);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	aspect-ratio: 1;
	border-radius: var(--wp--custom--radius--full);
	border: 1px solid var(--wp--custom--color--border--01);
	background-color: var(--wp--custom--color--bg--transparent);
	color: var(--wp--custom--color--text--white);
	cursor: pointer;
	transition: background-color .2s ease;
}

.hero-image .hero-video-control:hover,
.hero-image .hero-video-control:focus-visible {
	background-color: rgba(255, 255, 255, .2);
}

.hero-image .hero-video-control-icon {
	display: flex;
	align-items: center;
	justify-content: center;
}

.hero-image .hero-video-control-icon svg {
	width: 1.5rem;
}

.hero-image .hero-video-control-icon--play {
	display: none;
}

.hero-image .hero-video-control-icon--pause {
	display: block;
}

.hero-image .hero-video-control.is-play .hero-video-control-icon--play {
	display: block;
}

.hero-image .hero-video-control.is-play .hero-video-control-icon--pause {
	display: none;
}

/* Breakpoints */

@media (min-width: 25rem) {
	.hero-content-col .hero-cards-grid {
		grid-template-columns: 1fr 1fr;
	}
}

@media (min-width: 45rem) {
	.hero-content-col {
		padding-block: var(--wp--preset--spacing--4-xl) var(--wp--preset--spacing--lg);
	}

	.hero-content-col .hero-cards-grid {
		gap: var(--wp--preset--spacing--xs);
	}

	.hero-cards-grid .hero-card {
		border-radius: var(--wp--custom--radius--2-xl);
	}

	.hero-card .hero-card-inner {
		padding-inline: var(--wp--preset--spacing--sm);
	}

	.hero-card .hero-card-icon {
		width: 2rem;
	}
}

@media (min-width: 50rem) {
	.hero-image-col {
		padding-block: var(--wp--preset--spacing--xl);
	}

	.hero-image-col .hero-image {
		border-radius: var(--wp--custom--radius--4-xl);
		width: calc(100vw - (var(--wp--preset--spacing--xxs)*2));
	}
}

@media (min-width: 75rem) {
	.hero-layout {
		flex-direction: row;
		align-items: stretch;
	}

	.hero-layout > * {
		width: 100%;
	}

	.hero-content-col {
		gap: var(--wp--preset--spacing--3-xl);
		padding-block: var(--wp--preset--spacing--4-xl);
	}

	.hero-content-col .hero-content {
		gap: var(--wp--preset--spacing--md);
	}

	.hero-content-col .hero-cards-grid {
		gap: var(--wp--preset--spacing--sm);
		max-width: 41rem;
	}

	.hero-image-col {
		flex: unset;
		position: unset;
		aspect-ratio: unset;
		padding-block: var(--wp--preset--spacing--3-xl);
	}

	.hero-image-col .hero-image {
		position: absolute;
		inset: 0 0 0 auto;
		width: calc(50% - (var(--wp--preset--spacing--lg) / 2));
		translate: unset;
	}
}
