/* About page specific styles */
.page-about-us {
	overflow-x: clip;
	background: var(--color-bg);
	color: var(--color-text);
	padding-bottom: clamp(4rem, 8vw, 8rem);
}

.about-shell {
	width: min(100% - 3rem, var(--container));
	max-width: var(--container);
	margin-inline: auto;
	padding-block: clamp(3.5rem, 7vw, 7rem);
}

.about-grid {
	display: grid;
	grid-template-columns: repeat(12, minmax(0, 1fr));
	gap: clamp(1.2rem, 2.5vw, 1.8rem);
}

.about-kicker,
.mono-kicker {
	display: inline-block;
	font: 800 0.62rem/1.2 "Inter", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.42em;
	color: var(--color-primary);
	margin-bottom: 1rem;
}

.technical-line {
	height: 1px;
	background: repeating-linear-gradient(
		90deg,
		color-mix(in srgb, var(--color-outline) 50%, transparent),
		color-mix(in srgb, var(--color-outline) 50%, transparent) 4px,
		transparent 4px,
		transparent 8px
	);
}

.section-headline {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: clamp(1.2rem, 2vw, 2rem);
}

.section-headline.reverse {
	justify-content: flex-start;
}

.section-headline .technical-line {
	flex: 1;
}

.about-hero {
	border-bottom: 1px solid color-mix(in srgb, var(--color-outline-variant) 30%, transparent);
	padding-top: clamp(4.5rem, 8vw, 6rem);
}

.about-hero-copy {
	grid-column: span 12;
}

.about-hero-copy h1 {
	font-size: clamp(2.1rem, 10vw, 6rem);
	font-weight: 300;
	line-height: 0.9;
	text-transform: uppercase;
	margin-bottom: 1.2rem;
}

.about-hero-copy h1 span {
	display: block;
	color: var(--color-primary);
	font-weight: 900;
}

.about-tagline {
	font: 700 clamp(1rem, 2.4vw, 1.45rem)/1.25 "Epilogue", sans-serif;
	font-style: italic;
	max-width: 32ch;
	color: color-mix(in srgb, var(--color-text) 82%, var(--color-bg));
}

.about-hero-meta {
	grid-column: span 12;
	display: grid;
	gap: 0.8rem;
	color: var(--color-text-muted);
	font: 700 0.6rem/1.75 "Inter", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.18em;
}

.about-story-copy,
.about-story-media,
.about-journey-copy,
.about-journey-media,
.about-commitment-quote,
.about-protocol {
	grid-column: span 12;
}

.about-story-copy h2,
.about-journey-copy h2,
.about-commitment-quote h2,
.about-capabilities h2,
.about-team h2 {
	font-size: clamp(1.8rem, 5vw, 4rem);
	text-transform: uppercase;
	line-height: 0.95;
}

.about-columns {
	column-count: 1;
	column-gap: clamp(1.5rem, 3vw, 2.4rem);
	font-size: 0.92rem;
	line-height: 1.7;
	color: color-mix(in srgb, var(--color-text-muted) 78%, var(--color-text) 22%);
}

.about-columns p {
	margin-bottom: 1rem;
	break-inside: avoid;
	text-align: justify;
}

.primary-shot,
.detail-shot,
.about-journey-media figure {
	margin: 0;
	border: 1px solid color-mix(in srgb, var(--color-outline) 30%, transparent);
	overflow: hidden;
	background: var(--color-surface-lowest);
}

.primary-shot {
	aspect-ratio: 16 / 9;
}

.detail-shot {
	display: none;
	aspect-ratio: 1;
	max-width: 220px;
	position: absolute;
	left: -1.5rem;
	bottom: -1.5rem;
	padding: 0.45rem;
	background: var(--color-bg);
}

.about-story-media {
	position: relative;
	padding-bottom: 0;
}

.about-story-media img,
.about-journey-media img,
.team-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: grayscale(1) brightness(0.8);
	transition: filter 0.45s ease, transform 0.45s ease;
}

.about-story-media:hover img,
.about-journey-media:hover img,
.team-card:hover img {
	filter: grayscale(0.1) brightness(0.95);
	transform: scale(1.03);
}

.about-services {
	padding-block: clamp(3rem, 5vw, 4.6rem);
	border-block: 1px solid color-mix(in srgb, var(--color-outline-variant) 20%, transparent);
	background: color-mix(in srgb, var(--color-surface-lowest) 70%, transparent);
}

.about-service-block,
.about-reference {
	grid-column: span 12;
}

.about-service-block {
	padding: 0 0 1.2rem;
	border-bottom: 1px solid color-mix(in srgb, var(--color-outline-variant) 25%, transparent);
}

.about-service-block h3 {
	font: 800 0.7rem/1 "Epilogue", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.3em;
	color: var(--color-primary);
	margin-bottom: 0.9rem;
}

.about-service-block p {
	font-size: 0.78rem;
	line-height: 1.75;
	color: color-mix(in srgb, var(--color-text-muted) 88%, var(--color-text));
}

.about-service-block p span {
	color: var(--color-primary);
	font-style: italic;
}

.about-reference {
	display: grid;
	align-content: center;
	gap: 0.35rem;
	font: 700 0.58rem/1.45 "Inter", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: color-mix(in srgb, var(--color-text-muted) 82%, var(--color-bg));
}

.about-journey-media figure {
	aspect-ratio: 3 / 4;
}

.journey-line {
	display: none;
	position: absolute;
	top: 50%;
	right: -5.4rem;
	width: 4.2rem;
	height: 1px;
	transform: translateY(-50%);
	background: repeating-linear-gradient(
		90deg,
		color-mix(in srgb, var(--color-outline) 70%, transparent),
		color-mix(in srgb, var(--color-outline) 70%, transparent) 5px,
		transparent 5px,
		transparent 10px
	);
}

.about-stack {
	display: grid;
	gap: 1rem;
	max-width: 62ch;
	font-size: 0.96rem;
	line-height: 1.72;
	color: color-mix(in srgb, var(--color-text-muted) 82%, var(--color-text));
}

.about-capabilities {
	background: var(--color-surface-lowest);
	border-block: 1px solid color-mix(in srgb, var(--color-outline-variant) 30%, transparent);
	padding-block: clamp(4rem, 8vw, 7rem);
}

.capabilities-head {
	display: grid;
	gap: 1.2rem;
	align-items: end;
	margin-bottom: clamp(2rem, 4vw, 3rem);
}

.capabilities-meta {
	font: 700 0.58rem/1.55 "Inter", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: color-mix(in srgb, var(--color-text-muted) 82%, var(--color-bg));
	display: none;
	text-align: right;
	gap: 0.25rem;
}

.capability-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.2rem;
}

.capability-grid article {
	border-top: 1px solid color-mix(in srgb, var(--color-outline-variant) 28%, transparent);
	padding: 0.75rem 0.9rem 1.2rem;
	transition: background-color 0.25s ease;
}

.capability-grid article:hover {
	background: color-mix(in srgb, var(--color-surface) 65%, var(--color-primary) 10%);
}

.capability-grid span {
	display: inline-block;
	font: 700 0.58rem/1 "Inter", sans-serif;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-primary);
	margin-bottom: 0.4rem;
}

.capability-grid h4 {
	font-size: 1.02rem;
	text-transform: uppercase;
	line-height: 1.2;
}

.about-commitment-grid {
	align-items: center;
	gap: clamp(1.5rem, 4vw, 2.5rem);
}

.about-commitment-quote {
	border-left: 4px solid var(--color-primary);
	padding-left: clamp(1.1rem, 3vw, 2rem);
}

.about-commitment-quote h2 {
	font-size: clamp(1.35rem, 4vw, 2.1rem);
	margin-bottom: 1rem;
}

.about-commitment-quote p {
	font: 400 clamp(1.08rem, 2.5vw, 1.8rem)/1.5 "Inter", sans-serif;
	font-style: italic;
	color: color-mix(in srgb, var(--color-text-muted) 76%, var(--color-text));
}

.about-protocol {
	border: 1px solid color-mix(in srgb, var(--color-outline) 26%, transparent);
	padding: clamp(1.2rem, 3vw, 2rem);
	background: color-mix(in srgb, var(--color-surface-low) 72%, transparent);
}

.about-protocol h3 {
	font: 800 0.68rem/1.1 "Epilogue", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.38em;
	color: var(--color-primary);
	margin-bottom: 1.1rem;
}

.protocol-grid {
	display: grid;
	gap: 0.5rem;
	grid-template-columns: 1fr;
	margin-bottom: 1rem;
}

.protocol-grid div {
	border-left: 1px solid color-mix(in srgb, var(--color-outline-variant) 50%, transparent);
	padding: 0.65rem 0.8rem;
	font: 800 0.58rem/1.35 "Inter", sans-serif;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.about-protocol > p {
	font-size: 0.75rem;
	line-height: 1.7;
	font-style: italic;
	color: color-mix(in srgb, var(--color-text-muted) 75%, var(--color-text));
}

.about-team-head {
	display: grid;
	gap: 0.8rem;
	align-items: center;
	margin-bottom: clamp(1.6rem, 4vw, 3rem);
}

.about-team-head p {
	font: 700 0.6rem/1 "Inter", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: color-mix(in srgb, var(--color-text-muted) 80%, var(--color-bg));
}

.team-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: clamp(0.9rem, 2vw, 1.5rem);
}

.team-card-link {
	display: block;
	color: inherit;
	text-decoration: none;
}

.team-card-link .team-card {
	transition: transform 0.2s ease;
}

.team-card-link:hover .team-card,
.team-card-link:focus-visible .team-card {
	transform: translateY(-2px);
}

.team-card-link:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-primary) 62%, transparent);
	outline-offset: 2px;
}

.team-card figure {
	margin: 0 0 0.65rem;
	position: relative;
	aspect-ratio: 3 / 4;
	overflow: hidden;
	background: var(--color-surface-low);
}

.team-card figure span {
	position: absolute;
	right: 0.45rem;
	bottom: 0.45rem;
	font: 700 0.5rem/1 "Inter", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: rgba(255, 255, 255, 0.4);
}

.team-card h3 {
	font-size: 0.88rem;
	text-transform: uppercase;
	margin-bottom: 0.15rem;
}

.team-card p {
	font: 700 0.58rem/1.2 "Inter", sans-serif;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--color-primary);
}

[data-reveal] {
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 0.65s ease, transform 0.65s ease;
}

[data-reveal].is-visible {
	opacity: 1;
	transform: translateY(0);
}

@media (min-width: 760px) {
	.about-hero-copy {
		grid-column: span 8;
	}

	.about-hero-meta {
		grid-column: span 4;
		text-align: right;
		align-content: end;
		padding-left: 1.4rem;
		border-left: 1px solid color-mix(in srgb, var(--color-outline-variant) 28%, transparent);
	}

	.about-story-copy {
		grid-column: span 7;
	}

	.about-story-media {
		grid-column: span 5;
		padding-bottom: 2rem;
	}

	.about-columns {
		column-count: 2;
	}

	.detail-shot {
		display: block;
	}

	.about-service-block,
	.about-reference {
		grid-column: span 4;
	}

	.about-service-block {
		border-bottom: 0;
	}

	.about-service-block:nth-child(1),
	.about-service-block:nth-child(2) {
		border-right: 1px solid color-mix(in srgb, var(--color-outline-variant) 25%, transparent);
		padding-right: 1.5rem;
	}

	.about-service-block:nth-child(2) {
		padding-left: 0.5rem;
	}

	.about-reference {
		padding-left: 1rem;
	}

	.about-journey-media {
		grid-column: span 4;
		position: relative;
	}

	.about-journey-copy {
		grid-column: span 8;
		padding-left: clamp(1rem, 3vw, 3rem);
	}

	.journey-line {
		display: block;
	}

	.capabilities-head {
		grid-template-columns: 1fr auto;
	}

	.capabilities-meta {
		display: grid;
	}

	.capability-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 0.5rem;
	}

	.about-commitment-quote {
		grid-column: span 5;
	}

	.about-protocol {
		grid-column: span 7;
	}

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

	.about-team-head {
		grid-template-columns: auto 1fr auto;
		gap: 1.2rem;
	}

	.team-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}
