/**
 * Technology (HPMS) — Figma node 2113:14827.
 */

body.hypro-tech-page {
	background: #f7f7f8;
	/* --tech-pad + header: body.hypro-unified-nav — inner-nav-unified.css */
}

body.hypro-tech-page #page.site {
	max-width: none;
	width: 100%;
	padding: 0;
	margin: 0;
}

body.hypro-tech-page .site-main {
	padding: 0;
	width: 100%;
}

.hypro-tech {
	overflow-x: hidden;
}

/* Hero header: body.hypro-unified-nav — inner-nav-unified.css */

/* ─── Hero — single asset: assets/images/technology/hero-bg.png ───────── */
.hypro-tech-hero {
	position: relative;
	z-index: 0;
	overflow: hidden;
	background: #1a1e28;
	height: var(--hypro-page-hero-height);
	min-height: unset;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	isolation: isolate;
}

.hypro-tech-hero__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
}

.hypro-tech-hero__photo {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
	display: block;
}

/* Lighten bottom / unify tone so headline stays readable on varied exports */
.hypro-tech-hero__scrim {
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	background: linear-gradient(
		180deg,
		rgba(26, 30, 40, 0.2) 0%,
		rgba(26, 30, 40, 0.35) 45%,
		rgba(26, 30, 40, 0.5) 100%
	);
}

.hypro-tech-hero__fallback {
	position: absolute;
	inset: 0;
	background: radial-gradient(
		ellipse 110% 130% at 50% 110%,
		rgba(46, 196, 230, 1) 0%,
		rgba(26, 30, 40, 1) 100%
	);
}

.hypro-tech-hero__inner {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 80rem;
	margin: 0 auto;
	padding-left: var(--tech-pad);
	padding-right: var(--tech-pad);
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1.25rem;
	box-sizing: border-box;
	flex: 1;
	min-height: 0;
}

.hypro-tech-breadcrumb {
	align-self: flex-start;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem;
	margin: 0 0 0.5rem;
	font-family: Inter, sans-serif;
	font-size: 0.75rem;
	line-height: 1.4;
	color: #bdc2cc;
	text-transform: capitalize;
}

.hypro-tech-breadcrumb__parent {
	color: #bdc2cc;
}

.hypro-tech-breadcrumb__current {
	color: #f7f7f8;
}

.hypro-tech-hero__title {
	margin: 0;
	font-family: Saira, Inter, sans-serif;
	font-weight: 500;
	font-size: clamp(2rem, 5vw, 4rem);
	line-height: 1.1;
	letter-spacing: -0.04em;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.1em;
}

.hypro-tech-hero__title-line {
	display: block;
}

.hypro-tech-hero__title-line--gradient {
	background: radial-gradient(
		ellipse 200% 80% at 20% 40%,
		rgba(46, 196, 230, 1) 22%,
		rgba(85, 168, 199, 1) 54%,
		rgba(123, 140, 167, 1) 86%,
		rgba(49, 54, 68, 0) 100%
	);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}

.hypro-tech-hero__sub {
	margin: 0;
	max-width: 36rem;
	font-family: Inter, sans-serif;
	font-size: 1rem;
	line-height: 1.5;
	color: #dbdde1;
}

/* ─── Lead block (intro + media + stats) ──────────────────────────────── */
.hypro-tech-lead {
	background: #bdc2cc;
}

.hypro-tech-intro {
	padding: clamp(3.5rem, 6.25vw, 6.25rem) var(--tech-pad) clamp(3rem, 6vw, 4rem);
}

.hypro-tech-intro__grid {
	max-width: 80rem;
	margin: 0 auto;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr);
	gap: clamp(2rem, 4vw, 3.5rem);
	align-items: start;
}

.hypro-tech-intro__tag {
	display: inline-block;
	border-left: 3px solid #0b9cbc;
	padding-left: 0.75rem;
	font-family: Saira, Inter, sans-serif;
	font-size: 0.75rem;
	font-weight: 400;
	letter-spacing: 0.48px;
	text-transform: uppercase;
	color: #313644;
	margin-bottom: 1.25rem;
}

.hypro-tech-intro__heading {
	margin: 0;
	font-family: Saira, Inter, sans-serif;
	font-weight: 500;
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	line-height: 1.3;
	letter-spacing: -0.02em;
	color: #262a35;
}

.hypro-tech-intro__heading-line {
	display: block;
}

.hypro-tech-intro__lead {
	margin: 0 0 1.25rem;
	font-family: Inter, sans-serif;
	font-size: 1.25rem;
	font-weight: 500;
	line-height: 1.5;
	color: rgba(49, 54, 68, 0.85);
}

.hypro-tech-intro__body {
	margin: 0;
	font-family: Inter, sans-serif;
	font-size: 1rem;
	line-height: 1.5;
	color: rgba(49, 54, 68, 0.8);
}

.hypro-tech-media {
	padding: 0 var(--tech-pad) 0;
	max-width: 80rem;
	margin: 0 auto;
}

.hypro-tech-media__frame {
	position: relative;
	border-radius: 12px;
	overflow: hidden;
	background: #1a1e28;
}

/* Facility photo: Figma aligns emphasis to horizon / ground; override home .tech__media-img ratio */
.hypro-tech-media .tech__media-img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 1280 / 550;
	object-fit: cover;
	object-position: center bottom;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
}

.hypro-tech-media .tech__video-trigger {
	z-index: 3;
}

.hypro-tech-stats {
	position: relative;
	overflow: hidden;
	padding: clamp(2.5rem, 5vw, 4rem) var(--tech-pad) clamp(3rem, 6vw, 4rem);
	max-width: 80rem;
	margin: 0 auto;
}

/* Figma — line texture only in lower band; cap height so strokes don’t read into the media block above */
.hypro-tech-stats__bg {
	position: absolute;
	left: 50%;
	bottom: 0;
	top: auto;
	transform: translateX(-50%);
	width: 100vw;
	height: min(42%, 11rem);
	max-height: 11.5rem;
	min-height: 0;
	background-image: var(--hypro-tech-stats-bg);
	background-repeat: no-repeat;
	background-size: 100% auto;
	background-position: center bottom;
	opacity: 1;
	pointer-events: none;
}

.hypro-tech-stats__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(1.5rem, 3vw, 2rem);
	max-width: 80rem;
	margin: 0 auto;
}

.hypro-tech-stat__value {
	margin: 0 0 0.25rem;
	font-family: Saira, Inter, sans-serif;
	font-weight: 500;
	font-size: 1.75rem;
	line-height: 1.3;
	letter-spacing: -0.04em;
	color: #262a35;
}

.hypro-tech-stat__label {
	margin: 0;
	font-family: Inter, sans-serif;
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.5;
	color: rgba(49, 54, 68, 0.8);
}

/* ─── Process (all steps expanded; no accordion) ────────────────────── */
.hypro-tech-process {
	background: #f7f7f8;
	padding: clamp(3.25rem, 7vw, 5.5rem) var(--tech-pad) clamp(4rem, 9vw, 6.5rem);
}

.hypro-tech-process__inner {
	max-width: 80rem;
	margin: 0 auto;
	width: 100%;
	box-sizing: border-box;
}

.hypro-tech-process__head {
	max-width: 53rem;
	width: 100%;
	margin: 0 0 clamp(2.25rem, 4.5vw, 3rem);
	padding: 0;
	box-sizing: border-box;
	text-align: left;
}

.hypro-tech-process__title {
	margin: 0 0 1.25rem;
	font-family: Saira, Inter, sans-serif;
	font-weight: 500;
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	line-height: 1.3;
	letter-spacing: -0.02em;
	color: #262a35;
}

.hypro-tech-process__intro {
	margin: 0;
	max-width: 53rem;
	font-family: Inter, sans-serif;
	font-size: 1rem;
	line-height: 1.5;
	color: rgba(49, 54, 68, 0.8);
}

.hypro-tech-process__steps {
	display: flex;
	flex-direction: column;
	border: 1px solid #dbdde1;
	border-radius: 0;
	overflow: hidden;
	background: #f7f7f8;
}

.hypro-tech-process__step {
	border-bottom: 1px solid #dbdde1;
}

.hypro-tech-process__step:last-child {
	border-bottom: none;
}

.hypro-tech-process__panel {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: clamp(1.5rem, 3vw, 2.5rem);
	align-items: start;
	padding: clamp(1.75rem, 3vw, 2.125rem) clamp(1.5rem, 2.5vw, 2.5rem);
	background: #f7f7f8;
}

.hypro-tech-process__copy {
	display: grid;
	grid-template-columns: auto 1fr;
	grid-template-rows: auto auto;
	column-gap: clamp(2.5rem, 4vw, 4.25rem);
	row-gap: 1.25rem;
	align-items: start;
	min-width: 0;
}

.hypro-tech-process__num {
	grid-row: 1 / 3;
	grid-column: 1;
	font-family: Saira, Inter, sans-serif;
	font-weight: 500;
	font-size: 1rem;
	line-height: 1.3;
	letter-spacing: -0.02em;
	color: #2ec4e6;
	padding-top: 0.35rem;
}

.hypro-tech-process__panel-title {
	grid-column: 2;
	grid-row: 1;
	margin: 0;
	font-family: Saira, Inter, sans-serif;
	font-weight: 500;
	font-size: clamp(1.25rem, 2vw, 1.75rem);
	line-height: 1.3;
	letter-spacing: -0.02em;
	color: #262a35;
}

.hypro-tech-process__body {
	grid-column: 2;
	grid-row: 2;
	margin: 0;
	font-family: Inter, sans-serif;
	font-size: 1rem;
	line-height: 1.5;
	color: rgba(49, 54, 68, 0.8);
}

.hypro-tech-process__figure {
	margin: 0;
	border-radius: 12px;
	overflow: hidden;
	background: #fff;
	min-height: 12rem;
	align-self: stretch;
}

.hypro-tech-process__photo {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 17.5rem;
	max-height: 22rem;
	object-fit: cover;
	object-position: center center;
}

@media (max-width: 900px) {
	.hypro-tech-process__panel {
		grid-template-columns: 1fr;
	}

	.hypro-tech-process__copy {
		grid-template-columns: auto 1fr;
	}

	.hypro-tech-process__photo {
		min-height: 14rem;
		max-height: none;
	}
}

/* ─── Pathway ─────────────────────────────────────────────────────────── */
.hypro-tech-pathway {
	background: #1a1e28;
	padding: clamp(3rem, 6vw, 6.25rem) var(--tech-pad);
}

.hypro-tech-pathway__inner {
	max-width: 80rem;
	margin: 0 auto;
}

.hypro-tech-pathway__head {
	max-width: 53rem;
	margin-bottom: clamp(2.5rem, 5vw, 3.75rem);
}

.hypro-tech-pathway__title {
	margin: 0 0 1.25rem;
	font-family: Saira, Inter, sans-serif;
	font-weight: 500;
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	line-height: 1.3;
	letter-spacing: -0.02em;
	color: #f7f7f8;
}

.hypro-tech-pathway__intro {
	margin: 0;
	font-family: Inter, sans-serif;
	font-size: 1rem;
	line-height: 1.5;
	color: #bdc2cc;
}

.hypro-tech-pathway__rows {
	display: flex;
	flex-direction: column;
	gap: clamp(2.5rem, 4vw, 3.75rem);
}

.hypro-tech-pathway__row {
	display: grid;
	grid-template-columns: 1fr minmax(0, 1px) 1fr minmax(0, 1px) 1fr;
	align-items: stretch;
	gap: 0;
}

.hypro-tech-pathway__cell {
	display: contents;
}

.hypro-tech-pathway__item {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	padding: 0 1rem;
}

.hypro-tech-pathway__top {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	align-items: flex-start;
}

.hypro-tech-pathway__num {
	font-family: Saira, Inter, sans-serif;
	font-weight: 500;
	font-size: 0.75rem;
	line-height: 1.3;
	letter-spacing: -0.02em;
	color: #2ec4e6;
}

.hypro-tech-pathway__icon-wrap {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	box-sizing: border-box;
}

.hypro-tech-pathway__icon-wrap--01 {
	width: 125.854px;
	height: 80px;
}

.hypro-tech-pathway__icon-wrap--02 {
	width: 80px;
	height: 80px;
}

.hypro-tech-pathway__icon-wrap--03 {
	width: 80.001px;
	height: 80px;
}

.hypro-tech-pathway__icon-wrap--04 {
	width: 87.274px;
	height: 80px;
}

.hypro-tech-pathway__icon-wrap--05 {
	width: 79.334px;
	height: 80px;
}

.hypro-tech-pathway__icon-wrap--06.hypro-tech-pathway__icon-wrap--clip {
	width: 90px;
	height: 80px;
	overflow: hidden;
	position: relative;
	align-items: flex-start;
}

.hypro-tech-pathway__icon-wrap--06 .hypro-tech-pathway__icon {
	width: 90.127px;
	height: 96.4px;
	max-width: none;
	position: absolute;
	left: 0;
	top: -8px;
	object-fit: contain;
}

.hypro-tech-pathway__icon-wrap:not(.hypro-tech-pathway__icon-wrap--clip) .hypro-tech-pathway__icon {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: left center;
}

.hypro-tech-pathway__icon {
	display: block;
}

.hypro-tech-pathway__item-title {
	margin: 0;
	font-family: Inter, sans-serif;
	font-size: 1.25rem;
	font-weight: 600;
	line-height: 1.5;
	color: #f7f7f8;
}

.hypro-tech-pathway__item-text {
	margin: 0;
	font-family: Inter, sans-serif;
	font-size: 1rem;
	line-height: 1.5;
	color: #bdc2cc;
	max-width: 26rem;
}

.hypro-tech-pathway__divider {
	width: 1px;
	min-height: 10rem;
	margin: 0 auto;
	background: linear-gradient(180deg, transparent, rgba(123, 140, 167, 0.45), transparent);
}

.hypro-tech-pathway__divider--alt {
	background: linear-gradient(180deg, transparent, rgba(123, 140, 167, 0.35), transparent);
}

@media (max-width: 900px) {
	.hypro-tech-pathway__row {
		grid-template-columns: 1fr;
	}

	.hypro-tech-pathway__divider {
		display: none;
	}

	.hypro-tech-pathway__item {
		padding: 0 0 2rem;
		border-bottom: 1px solid rgba(123, 140, 167, 0.25);
	}

	.hypro-tech-pathway__row .hypro-tech-pathway__item:last-child {
		border-bottom: none;
		padding-bottom: 0;
	}
}

/* ─── Compare — section: Figma 2113:14827 (cool blue band + lighter cyan at bottom) ─ */
/* Table columns: Figma 2285:10562 — Attribute white, Conventional #F0F4F8-ish, HPMS dark card + cyan edge ─ */
.hypro-tech-compare-wrap {
	position: relative;
	isolation: isolate;
	padding-top: clamp(3rem, 8vw, 5rem);
	padding-bottom: clamp(2.5rem, 6vw, 5rem);
	background-color: #d8eaf2;
	background-image:
		radial-gradient(ellipse 95% 65% at 50% 100%, rgba(162, 227, 241, 0.55) 0%, rgba(208, 239, 246, 0.35) 42%, transparent 68%),
		linear-gradient(
			180deg,
			#f5fafc 0%,
			#e8f3f8 28%,
			#d6eaf3 58%,
			#c5e3ef 100%
		);
}

.hypro-tech-compare-wrap::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	background: radial-gradient(ellipse 80% 50% at 50% 88%, rgba(46, 196, 230, 0.12) 0%, transparent 55%);
}

.hypro-tech-compare {
	position: relative;
	z-index: 1;
	padding: 0 var(--tech-pad) clamp(4rem, 8vw, 6rem);
	max-width: 80rem;
	margin: 0 auto;
}

.hypro-tech-compare__head {
	max-width: 53rem;
	width: 100%;
	margin: 0 auto clamp(2rem, 4vw, 2.5rem);
	box-sizing: border-box;
}

.hypro-tech-compare__title {
	margin: 0 0 1.25rem;
	font-family: Saira, Inter, sans-serif;
	font-weight: 500;
	/* Figma 2317:12750 — 40px headline */
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	line-height: 1.3;
	letter-spacing: -0.02em;
	color: #262a35;
}

.hypro-tech-compare__intro {
	margin: 0;
	font-family: Inter, sans-serif;
	font-size: 1rem;
	line-height: 1.5;
	color: rgba(49, 54, 68, 0.8);
}

.hypro-tech-compare__intro strong {
	font-weight: 600;
	color: rgba(49, 54, 68, 0.95);
}

.hypro-tech-compare__table {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr);
	gap: 0;
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 1px 0 rgba(38, 42, 53, 0.06);
}

.hypro-tech-compare__thead,
.hypro-tech-compare__tbody,
.hypro-tech-compare__tr {
	display: contents;
}

.hypro-tech-compare__tr--head .hypro-tech-compare__th {
	padding: 2.5rem 1.75rem 1.25rem;
	font-family: Inter, sans-serif;
	/* Figma — column titles Title/20 (Sb) */
	font-size: 1.25rem;
	font-weight: 600;
	line-height: 1.5;
	text-transform: uppercase;
}

/* Column 1 — Attribute: white (Figma) */
.hypro-tech-compare__th {
	background: #ffffff;
	color: #262a35;
	border-bottom: 1px solid rgba(49, 54, 68, 0.1);
}

/* Column 2 — Conventional: light gray-blue */
.hypro-tech-compare__th:nth-child(2) {
	background: #f0f4f8;
	color: rgba(49, 54, 68, 0.82);
	border-left: 1px solid rgba(123, 140, 167, 0.2);
}

/*
 * HPMS column — Figma 2285:10562: one blackish card (no cyan border, no per-row gradients).
 * Same linear fill + background-attachment: fixed keeps one continuous slab across rows.
 */
.hypro-tech-compare__th--hpms {
	color: #f7f7f8;
	border-radius: 0 16px 0 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	border-left: 1px solid rgba(255, 255, 255, 0.06);
	background-color: #1a1e28;
	background-image: linear-gradient(
		94.86deg,
		#1a1e28 24%,
		#313644 91%,
		#262a35 100%
	);
	background-attachment: fixed;
	background-size: cover;
	background-position: 100% 50%;
	box-shadow: 0 28px 56px rgba(6, 7, 10, 0.35);
}

.hypro-tech-compare__col--attr.hypro-tech-compare__th {
	border-radius: 16px 0 0 0;
}

.hypro-tech-compare__td {
	padding: 1.125rem 1.75rem;
	font-family: Inter, sans-serif;
	/* Figma body rows — 18px regular */
	font-size: 1.125rem;
	line-height: 1.5;
	border-bottom: 1px solid rgba(49, 54, 68, 0.1);
}

.hypro-tech-compare__cell-line {
	display: flex;
	align-items: flex-start;
	gap: 12px;
}

.hypro-tech-compare__cell-line > .hypro-tech-compare__icon {
	margin-top: 0.15em;
}

.hypro-tech-compare__icon {
	display: flex;
	flex-shrink: 0;
	width: 24px;
	height: 24px;
	align-items: center;
	justify-content: center;
}

.hypro-tech-compare__icon svg {
	display: block;
	width: 24px;
	height: 24px;
}

.hypro-tech-compare__td:nth-child(1) {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	background: #ffffff;
	color: #262a35;
}

.hypro-tech-compare__attr-num {
	flex-shrink: 0;
	min-width: 1ch;
	font-weight: 500;
	font-size: 1.125rem;
	line-height: 1.5;
	color: #262a35;
}

.hypro-tech-compare__attr-label {
	font-weight: 700;
	font-size: 1.125rem;
	line-height: 1.5;
}

.hypro-tech-compare__td:nth-child(2) {
	background: #f0f4f8;
	color: rgba(49, 54, 68, 0.78);
	border-left: 1px solid rgba(123, 140, 167, 0.18);
}

.hypro-tech-compare__td--hpms {
	color: #f7f7f8;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	border-left: 1px solid rgba(255, 255, 255, 0.06);
	background-color: #1a1e28;
	background-image: linear-gradient(
		94.86deg,
		#1a1e28 24%,
		#313644 91%,
		#262a35 100%
	);
	background-attachment: fixed;
	background-size: cover;
	background-position: 100% 50%;
	box-shadow: none;
}

.hypro-tech-compare__tbody .hypro-tech-compare__tr:last-child .hypro-tech-compare__td {
	border-bottom: none;
}

.hypro-tech-compare__tbody .hypro-tech-compare__tr:last-child .hypro-tech-compare__td--hpms {
	border-radius: 0 0 16px 0;
}

.hypro-tech-compare__tbody .hypro-tech-compare__tr:last-child .hypro-tech-compare__col--attr {
	border-radius: 0 0 0 16px;
}

@media (max-width: 960px) {
	.hypro-tech-intro__grid {
		grid-template-columns: 1fr;
	}

	.hypro-tech-stats__inner {
		grid-template-columns: 1fr;
	}

	.hypro-tech-compare {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		overscroll-behavior-x: contain;
	}

	.hypro-tech-compare__table {
		min-width: 720px;
	}

	/* Fixed attachment can glitch on iOS; flat card reads like Figma without row banding */
	.hypro-tech-compare__th--hpms,
	.hypro-tech-compare__td--hpms {
		background-attachment: scroll;
		background-image: none;
		background-color: #1a1e28;
	}
}
