/**
 * Homepage sections.
 */

/* --------------------------------------------------------------------------
 * Hero (with background video / poster)
 * ---------------------------------------------------------------------- */
.home-hero {
	position: relative;
	overflow: hidden;
	padding: calc(var(--jai-header-height-lg) + var(--jai-space-4xl)) 0 var(--jai-space-4xl);
	background: linear-gradient(135deg, var(--jai-color-primary) 0%, var(--jai-color-primary-2) 55%, var(--jai-color-primary-soft) 130%);
	color: rgba(255, 255, 255, 0.82);
}

.home-hero__media {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.home-hero__video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 1;
}

/* Light overlay: keeps the video clearly visible while preserving enough
 * contrast for the white headline. Stronger only behind the text column. */
.home-hero__overlay {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, rgba(15, 20, 54, 0.62) 0%, rgba(15, 20, 54, 0.34) 42%, rgba(15, 20, 54, 0.12) 100%),
		linear-gradient(0deg, rgba(15, 20, 54, 0.28) 0%, rgba(15, 20, 54, 0) 55%);
}

.home-hero__inner {
	position: relative;
	z-index: 1;
}

.home-hero .section-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.5em;
	color: var(--jai-color-white);
	font-size: 0.75rem;
}

/* Accent dot echoing the logo wordmark mark. */
.home-hero .section-eyebrow::before {
	content: "";
	width: 0.5em;
	height: 0.5em;
	border-radius: 50%;
	background-color: var(--jai-color-accent-2);
}

.home-hero h1 {
	max-width: 18ch;
	color: var(--jai-color-white);
}

.home-hero p {
	max-width: 60ch;
	font-size: var(--jai-font-size-lg);
}

.home-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--jai-space-md);
	margin-top: var(--jai-space-xl);
}

/* --------------------------------------------------------------------------
 * Trust strip
 * ---------------------------------------------------------------------- */
.section--tight {
	padding: var(--jai-space-2xl) 0;
}

.trust-strip__title {
	margin-bottom: var(--jai-space-lg);
	color: var(--jai-color-muted);
	font-size: var(--jai-font-size-sm);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-align: center;
	text-transform: uppercase;
}

.section__actions {
	display: flex;
	justify-content: center;
	margin-top: var(--jai-space-2xl);
}

/* --------------------------------------------------------------------------
 * By the Numbers
 * ---------------------------------------------------------------------- */
.stat-grid {
	display: grid;
	gap: var(--jai-space-lg);
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (min-width: 1024px) {
	.stat-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

/* --------------------------------------------------------------------------
 * How We Work (process list)
 * ---------------------------------------------------------------------- */
.process-section__grid {
	display: grid;
	gap: var(--jai-space-2xl);
}

.process-list {
	display: grid;
	gap: var(--jai-space-md);
	margin: 0;
	padding: 0;
	counter-reset: process;
	list-style: none;
}

.process-list li {
	position: relative;
	display: grid;
	gap: var(--jai-space-2xs);
	padding: var(--jai-space-lg) var(--jai-space-lg) var(--jai-space-lg) 4.5rem;
	border: 1px solid var(--jai-color-border);
	border-radius: var(--jai-radius-lg);
	background: var(--jai-color-white);
	box-shadow: var(--jai-shadow-soft);
}

.process-list li::before {
	content: counter(process);
	counter-increment: process;
	position: absolute;
	top: var(--jai-space-lg);
	left: var(--jai-space-lg);
	display: grid;
	place-items: center;
	width: 2rem;
	height: 2rem;
	border-radius: 999px;
	background: var(--jai-color-primary);
	color: var(--jai-color-white);
	font-family: var(--jai-font-heading);
	font-weight: 700;
}

.process-list__title {
	color: var(--jai-color-primary);
	font-size: 1.1rem;
}

.process-list__text {
	color: var(--jai-color-muted);
}

/* --------------------------------------------------------------------------
 * European Operations
 * ---------------------------------------------------------------------- */
.european-ops__grid {
	display: grid;
	gap: var(--jai-space-2xl);
	align-items: center;
}

.european-ops__content p {
	max-width: 56ch;
}

.european-ops__map {
	border-radius: var(--jai-radius-xl);
	overflow: hidden;
	background: rgba(255, 255, 255, 0.06);
}

.european-ops__map img {
	width: 100%;
	height: auto;
}

/* --------------------------------------------------------------------------
 * CTA panel
 * ---------------------------------------------------------------------- */
.cta-panel {
	display: grid;
	justify-items: start;
	gap: var(--jai-space-sm);
	padding: var(--jai-space-2xl);
	border-radius: var(--jai-radius-xl);
	background: linear-gradient(135deg, var(--jai-color-primary), var(--jai-color-primary-soft) 100%);
	color: rgba(255, 255, 255, 0.82);
}

.cta-panel h2,
.cta-panel .section-eyebrow {
	color: var(--jai-color-white);
}

.cta-panel p {
	max-width: 60ch;
}

/* --------------------------------------------------------------------------
 * Responsive
 * ---------------------------------------------------------------------- */
@media (min-width: 1024px) {
	.process-section__grid {
		grid-template-columns: 0.9fr 1.1fr;
		align-items: start;
	}

	.european-ops__grid {
		grid-template-columns: 1fr 1fr;
	}
}
