/*
 * About page — brand story, promise, values, team, compliance.
 */

.about-page {
	background: var(--color-white);
}

/* Hero */
.about-hero {
	padding-block: clamp(1.15rem, 2.2vw, 2rem) clamp(1.75rem, 3.2vw, 2.5rem);
	background:
		radial-gradient(900px 420px at 80% -10%, rgba(232, 185, 187, 0.22), transparent 60%),
		radial-gradient(700px 360px at 8% 10%, rgba(196, 215, 155, 0.16), transparent 58%),
		var(--color-white);
	text-align: center;
	overflow: hidden;
}

.about-hero__eyebrow {
	display: inline-block;
	margin-bottom: var(--sp-4);
}

.about-hero__heading {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: clamp(2.15rem, 4.45vw, 3.9rem);
	line-height: 1.06;
	letter-spacing: -0.04em;
	color: var(--color-charcoal);
	margin: 0 auto var(--sp-4);
	max-width: 22ch;
	text-wrap: balance;
}

.about-hero__lede {
	font-size: 1.05rem;
	line-height: 1.65;
	color: var(--text-secondary);
	margin: 0 auto;
	max-width: 68ch;
}

/* Shared section headings */
.about-section-head {
	text-align: center;
	max-width: 760px;
	margin: 0 auto var(--sp-7);
}

.about-section-head__title {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: clamp(2rem, 4vw, 3.15rem);
	line-height: 1.12;
	letter-spacing: -0.03em;
	color: var(--color-charcoal);
	margin: var(--sp-3) auto var(--sp-4);
	text-wrap: balance;
}

.about-section-head__body {
	font-size: 1.025rem;
	line-height: 1.7;
	color: var(--text-secondary);
	margin: 0 auto;
	max-width: 62ch;
}

/* Story */
.about-story {
	padding-block: clamp(3rem, 6vw, 5rem);
	background: var(--bg-soft);
}

.about-story__grid {
	display: grid;
	grid-template-columns: 0.85fr 1.15fr;
	gap: var(--sp-7);
	align-items: start;
}

.about-story__title {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: clamp(2rem, 4vw, 3.15rem);
	line-height: 1.12;
	letter-spacing: -0.03em;
	color: var(--color-charcoal);
	margin: var(--sp-3) 0 0;
	max-width: 12ch;
	text-wrap: balance;
}

.about-story__body {
	position: relative;
	background: var(--color-white);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: clamp(1.75rem, 3vw, 2.5rem);
	box-shadow: 0 24px 55px -42px rgba(43, 43, 47, 0.32);
	overflow: hidden;
}

.about-story__body::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 4px;
	background: linear-gradient(90deg, var(--color-green), var(--color-pink), var(--color-sage));
	opacity: 0.95;
}

.about-story__body p {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--text-secondary);
	margin: 0 0 var(--sp-4);
}

.about-story__body p:last-child {
	margin-bottom: 0;
}

/* Shared callout */
.about-callout {
	position: relative;
	background: rgba(196, 215, 155, 0.16);
	border: 1px solid rgba(79, 126, 74, 0.12);
	border-radius: var(--radius-md);
	padding: var(--sp-5) var(--sp-5) var(--sp-5) calc(var(--sp-5) + 12px);
	margin: var(--sp-5) 0 0;
	overflow: hidden;
}

.about-callout::before {
	content: "";
	position: absolute;
	left: 0;
	top: var(--sp-3);
	bottom: var(--sp-3);
	width: 4px;
	border-radius: 999px;
	background: var(--color-green-dark);
	transform: scaleY(0);
	transform-origin: top;
	transition: transform 800ms var(--ease-out) 160ms;
}

.about-callout.is-visible::before {
	transform: scaleY(1);
}

.about-callout p {
	margin: 0;
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: 1.05rem;
	line-height: 1.55;
	color: var(--color-charcoal);
}

/* Promise */
.about-promise {
	padding-block: clamp(3rem, 6vw, 5rem);
	background: var(--color-white);
}

.about-promise__grid {
	display: grid;
	grid-template-columns: 0.95fr 1.05fr;
	gap: var(--sp-7);
	align-items: start;
}

.about-promise__title {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: clamp(2rem, 4vw, 3.15rem);
	line-height: 1.12;
	letter-spacing: -0.03em;
	color: var(--color-charcoal);
	margin: var(--sp-3) 0 var(--sp-4);
	max-width: 14ch;
	text-wrap: balance;
}

.about-promise__content p {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--text-secondary);
	margin: 0 0 var(--sp-4);
	max-width: 62ch;
}

.about-promise__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: var(--sp-3);
}

.about-promise__list li {
	position: relative;
	background: var(--color-white);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-md);
	padding: 1rem 1.1rem 1rem 3rem;
	box-shadow: 0 18px 38px -32px rgba(43, 43, 47, 0.24);
	font-size: 0.96rem;
	line-height: 1.55;
	color: var(--color-charcoal);
	font-weight: 600;
}

.about-promise__list li::before {
	content: "\2713";
	position: absolute;
	left: 1rem;
	top: 1rem;
	display: grid;
	place-items: center;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: rgba(196, 215, 155, 0.55);
	color: var(--color-green-dark);
	font-size: 0.8rem;
	font-weight: 700;
}

/* Values */
.about-values {
	padding-block: clamp(3rem, 6vw, 5rem);
	background: var(--bg-soft);
}

.about-values__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--sp-4);
	perspective: 1200px;
}

.about-value-card {
	position: relative;
	overflow: hidden;
	background: var(--color-white);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: var(--sp-5);
	box-shadow: 0 24px 50px -38px rgba(43, 43, 47, 0.24);
	transform-style: preserve-3d;
	will-change: transform;
}

.about-value-card::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 4px;
	background: var(--color-green-dark);
}

.about-value-card::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(255, 255, 255, 0), rgba(196, 215, 155, 0.12));
	opacity: 0;
	transition: opacity 280ms var(--ease-out);
	pointer-events: none;
}

.about-value-card:hover::after {
	opacity: 1;
}

.about-value-card:nth-child(2)::before,
.about-value-card:nth-child(4)::before {
	background: #b5686b;
}

.about-value-card:nth-child(3)::before {
	background: var(--color-sage);
}

.about-value-card__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: 999px;
	background: rgba(79, 126, 74, 0.12);
	color: var(--color-green-dark);
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 0.8rem;
	letter-spacing: 0.08em;
	margin-bottom: var(--sp-4);
	position: relative;
	z-index: 1;
}

.about-value-card:nth-child(2) .about-value-card__num,
.about-value-card:nth-child(4) .about-value-card__num {
	background: rgba(232, 185, 187, 0.5);
	color: #b5686b;
}

.about-value-card:nth-child(3) .about-value-card__num {
	background: rgba(196, 215, 155, 0.55);
	color: var(--color-green-dark);
}

.about-value-card h3,
.about-value-card p {
	position: relative;
	z-index: 1;
}

.about-value-card h3 {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 1.18rem;
	line-height: 1.25;
	color: var(--color-charcoal);
	margin: 0 0 var(--sp-3);
}

.about-value-card p {
	font-size: 0.95rem;
	line-height: 1.65;
	color: var(--text-secondary);
	margin: 0;
}

/* Team */
.about-team {
	padding-block: clamp(3rem, 6vw, 5rem);
	background: var(--color-white);
}

.about-team__intro {
	text-align: center;
	max-width: 780px;
	margin: 0 auto var(--sp-7);
}

.about-team__title {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: clamp(2rem, 4vw, 3.15rem);
	line-height: 1.12;
	letter-spacing: -0.03em;
	color: var(--color-charcoal);
	margin: var(--sp-3) auto var(--sp-4);
	max-width: 18ch;
	text-wrap: balance;
}

.about-team__intro p {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--text-secondary);
	margin: 0 auto var(--sp-3);
	max-width: 66ch;
}

.about-team__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--sp-5);
}

.about-team-card {
	position: relative;
	background: var(--color-white);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: clamp(1.75rem, 3vw, 2.25rem);
	text-align: center;
	display: grid;
	justify-items: center;
	gap: var(--sp-3);
	box-shadow: 0 24px 50px -38px rgba(43, 43, 47, 0.24);
	overflow: hidden;
}

.about-team-card::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 4px;
	background: var(--color-green-dark);
	opacity: 0.95;
}

.about-team-card:nth-child(2)::before {
	background: #b5686b;
}

.about-team-card:nth-child(3)::before {
	background: var(--color-sage);
}

.about-team-card .about-team-card__role {
	margin: calc(var(--sp-3) * -0.45) 0 0;
	color: var(--color-green-dark);
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: 0.92rem;
	letter-spacing: 0.01em;
	line-height: 1.35;
}

.about-team-card__avatar {
	position: relative;
	width: 120px;
	height: 120px;
	border-radius: 50%;
	overflow: hidden;
	display: block;
}

.about-team-card__photo {
	position: absolute;
	max-width: none;
	top: -8px;
	left: 50%;
	width: 160px;
	height: 160px;
	transform: translateX(-50%);
	object-fit: cover;
	display: block;
}

.about-team-card:nth-child(2) .about-team-card__avatar {
	background: rgba(232, 185, 187, 0.5);
	color: #b5686b;
}

.about-team-card:nth-child(3) .about-team-card__avatar {
	background: rgba(196, 215, 155, 0.55);
	color: var(--color-green-dark);
}

.about-team-card h3,
.about-team-card p {
	position: relative;
	z-index: 1;
}

.about-team-card h3 {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 1.15rem;
	color: var(--color-charcoal);
	margin: 0;
}

.about-team-card p {
	font-size: 0.94rem;
	line-height: 1.65;
	color: var(--text-secondary);
	margin: 0;
	max-width: 32ch;
}

.about-team__note {
	max-width: 800px;
	margin-inline: auto;
	margin-top: var(--sp-7);
}

/* Compliance */
.about-compliance {
	padding-block: clamp(3rem, 6vw, 5rem);
	background: var(--bg-soft);
}

.about-compliance__grid {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: var(--sp-7);
	align-items: start;
}

.about-compliance__title {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: clamp(2rem, 4vw, 3.15rem);
	line-height: 1.12;
	letter-spacing: -0.03em;
	color: var(--color-charcoal);
	margin: var(--sp-3) 0 var(--sp-5);
	max-width: 15ch;
	text-wrap: balance;
}

.about-compliance__content p {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--text-secondary);
	margin: 0 0 var(--sp-4);
	max-width: 64ch;
}

.about-compliance__card {
	position: relative;
	overflow: hidden;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(250, 248, 245, 0.96)),
		var(--color-white);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: clamp(1.75rem, 4vw, 2.75rem);
	box-shadow: 0 28px 56px -34px rgba(43, 43, 47, 0.25);
}

.about-compliance__card::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 5px;
	background: linear-gradient(90deg, var(--color-green), var(--color-pink), var(--color-sage));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 900ms var(--ease-out) 120ms;
}

.about-compliance__card::after {
	content: "";
	position: absolute;
	right: -70px;
	bottom: -70px;
	width: 180px;
	height: 180px;
	border-radius: 999px;
	background: rgba(196, 215, 155, 0.22);
	pointer-events: none;
}

.about-compliance__card.is-visible::before {
	transform: scaleX(1);
}

.about-compliance__seal {
	display: grid;
	place-items: center;
	width: 64px;
	height: 64px;
	border-radius: 999px;
	background: rgba(79, 126, 74, 0.14);
	color: var(--color-green-dark);
	margin-bottom: var(--sp-4);
	position: relative;
	z-index: 1;
	box-shadow: inset 0 0 0 1px rgba(79, 126, 74, 0.08);
}

.about-compliance__seal svg {
	width: 32px;
	height: 32px;
}

.about-compliance__label,
.about-compliance__number,
.about-compliance__list {
	position: relative;
	z-index: 1;
}

.about-compliance__label {
	display: block;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--color-green-dark);
	margin-bottom: var(--sp-2);
}

.about-compliance__number {
	display: block;
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: clamp(1.8rem, 3vw, 2.4rem);
	color: var(--color-charcoal);
	margin-bottom: var(--sp-5);
}

.about-compliance__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: var(--sp-3);
}

.about-compliance__list li {
	position: relative;
	padding-left: 2rem;
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--color-charcoal);
	font-weight: 500;
}

.about-compliance__list li::before {
	content: "\2713";
	position: absolute;
	left: 0;
	top: 0.05rem;
	display: grid;
	place-items: center;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: rgba(196, 215, 155, 0.55);
	color: var(--color-green-dark);
	font-size: 0.8rem;
	font-weight: 700;
}

/* Final CTA */
.about-final {
	padding-block: clamp(3.5rem, 7vw, 6rem);
	background:
		radial-gradient(720px 360px at 20% 20%, rgba(196, 215, 155, 0.18), transparent 62%),
		radial-gradient(720px 360px at 85% 45%, rgba(232, 185, 187, 0.22), transparent 62%),
		var(--color-white);
}

.about-final__card {
	margin-inline: auto;
	position: relative;
	overflow: hidden;
}

/* Motion */
.about-page [data-reveal],
.about-page [data-reveal-group] > * {
	opacity: 0;
	transform: translateY(28px);
	transition:
		opacity 700ms var(--ease-out),
		transform 700ms var(--ease-out);
	will-change: opacity, transform;
}

.about-page [data-reveal].is-visible,
.about-page [data-reveal-group].is-visible > * {
	opacity: 1;
	transform: translateY(0);
}

.about-page .about-hero__eyebrow,
.about-page .about-hero__heading,
.about-page .about-hero__lede {
	opacity: 0;
	animation: aboutFadeUp 850ms var(--ease-out) forwards;
}

.about-page .about-hero__heading {
	animation-delay: 120ms;
}

.about-page .about-hero__lede {
	animation-delay: 240ms;
}

.about-value-card,
.about-team-card,
.about-compliance__card,
.about-promise__list li,
.about-story__body,
.about-final__card {
	transition:
		transform 280ms var(--ease-out),
		box-shadow 280ms var(--ease-out),
		border-color 280ms var(--ease-out);
}

.about-value-card:hover,
.about-team-card:hover,
.about-compliance__card:hover,
.about-promise__list li:hover,
.about-story__body:hover,
.about-final__card:hover {
	transform: translateY(-4px);
	box-shadow: 0 28px 60px -38px rgba(43, 43, 47, 0.35);
	border-color: rgba(79, 126, 74, 0.22);
}

.about-compliance__seal,
.about-team-card__avatar,
.about-value-card__num {
	transition:
		transform 260ms var(--ease-out),
		background-color 260ms var(--ease-out);
}

.about-compliance__card:hover .about-compliance__seal,
.about-team-card:hover .about-team-card__avatar,
.about-value-card:hover .about-value-card__num {
	transform: scale(1.05);
}

@keyframes aboutFadeUp {
	from {
		opacity: 0;
		transform: translateY(24px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Tablet */
@media (max-width: 1024px) {
	.about-story__grid,
	.about-promise__grid,
	.about-compliance__grid {
		grid-template-columns: 1fr;
	}

	.about-story__title,
	.about-promise__title,
	.about-compliance__title {
		max-width: 18ch;
	}

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

/* Mobile */
@media (max-width: 640px) {
	.about-hero {
		text-align: left;
	}

	.about-hero__heading,
	.about-hero__lede {
		margin-inline: 0;
	}

	.about-values__grid,
	.about-team__grid {
		grid-template-columns: 1fr;
	}

	.about-story__body,
	.about-value-card,
	.about-team-card,
	.about-compliance__card {
		padding: var(--sp-5);
	}
}

/* Motion accessibility */
@media (prefers-reduced-motion: reduce) {
	.about-page [data-reveal],
	.about-page [data-reveal-group] > *,
	.about-page .about-hero__eyebrow,
	.about-page .about-hero__heading,
	.about-page .about-hero__lede,
	.about-value-card,
	.about-team-card,
	.about-compliance__card,
	.about-promise__list li,
	.about-story__body,
	.about-final__card,
	.about-compliance__seal,
	.about-team-card__avatar,
	.about-value-card__num {
		opacity: 1;
		transform: none;
		animation: none;
		transition: none;
	}
}

/* === About photos — added 2026-06-05 === */
.about-hero__cover {
	margin-top: clamp(1.5rem, 3vw, 2.5rem);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: 0 30px 60px -34px rgba(43, 52, 40, 0.45);
}
.about-hero__cover img {
	display: block;
	width: 100%;
	height: clamp(220px, 30vw, 360px);
	object-fit: cover;
	object-position: center 38%;
}
.about-story__media {
	margin-top: var(--sp-5);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: 0 24px 50px -34px rgba(43, 52, 40, 0.4);
}
.about-story__media img {
	display: block;
	width: 100%;
	height: clamp(240px, 30vw, 380px);
	object-fit: cover;
	object-position: center 26%;
}
