/**
 * About page - quiet editorial layout.
 */

.neomi-about {
	--neomi-about-ink: #2b153b;
	--neomi-about-muted: #6b5f6d;
	--neomi-about-line: rgba(143, 69, 110, 0.16);
	--neomi-about-gold: #c4a574;
	direction: rtl;
	background: #fbfaf8;
	color: var(--neomi-about-ink);
	font-family: var(--neomi-font-body);
}

.neomi-about :where(h1, h2, p, figure, ul) {
	margin: 0;
}

.neomi-about :where(ul) {
	padding: 0;
	list-style: none;
}

.neomi-about h1,
.neomi-about h2 {
	font-family: var(--neomi-font-display);
	font-weight: 700;
	color: var(--neomi-about-ink);
	letter-spacing: 0;
}

.neomi-about p {
	color: var(--neomi-about-muted);
	font-size: clamp(1rem, 1.15vw, 1.12rem);
	line-height: 1.9;
}

.neomi-about-kicker {
	display: inline-block;
	color: var(--neomi-logo-plum);
	font-size: 0.88rem;
	font-weight: 700;
	margin-block-end: 1.1rem;
}

.neomi-about-hero {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(21rem, 0.95fr);
	align-items: center;
	min-height: 0;
	border-block-end: 1px solid rgba(143, 69, 110, 0.08);
}

.neomi-about-hero__text {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: clamp(2.4rem, 5.2vw, 4.8rem) clamp(1.5rem, 4.7vw, 4.5rem);
	background:
		radial-gradient(circle at 36% 48%, rgba(255, 255, 255, 0.94) 0%, rgba(255, 255, 255, 0.82) 42%, rgba(251, 250, 248, 0.74) 70%, rgba(251, 250, 248, 0) 100%),
		#fbfaf8;
}

.neomi-about-hero__text h1 {
	font-size: clamp(2.75rem, 5.7vw, 5.25rem);
	line-height: 1.16;
}

.neomi-about-hero__text p {
	max-width: 30rem;
	color: #2f2735;
	line-height: 1.72;
}

.neomi-about-ornament {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	width: min(15rem, 70%);
	margin: clamp(1rem, 2.3vw, 1.55rem) 0 clamp(1.15rem, 2.4vw, 1.7rem);
	color: rgba(143, 69, 110, 0.58);
}

.neomi-about-ornament::before,
.neomi-about-ornament::after {
	flex: 1;
	height: 1px;
	content: "";
	background: rgba(196, 165, 116, 0.64);
}

.neomi-about-ornament span::before {
	content: "♡";
	font-family: var(--neomi-font-body);
	font-size: 1.1rem;
}

.neomi-about-hero__image-wrap {
	position: relative;
	display: grid;
	align-content: center;
	gap: clamp(0.75rem, 1.5vw, 1.15rem);
	align-self: center;
	min-height: 0;
	padding: clamp(1rem, 2.2vw, 1.85rem);
	overflow: hidden;
	background:
		linear-gradient(135deg, rgba(234, 223, 212, 0.92), rgba(246, 240, 235, 0.86));
}

.neomi-about-hero__image,
.neomi-about-room__image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: saturate(0.82) contrast(0.94);
}

.neomi-about-hero__image {
	height: auto;
	max-height: none;
	object-fit: contain;
	object-position: center;
	box-shadow: 0 1.2rem 2.6rem rgba(45, 32, 28, 0.09);
}

.neomi-about-hero__image--secondary {
	width: 100%;
	justify-self: end;
	box-shadow: 0 0.9rem 2rem rgba(45, 32, 28, 0.07);
}

.neomi-about-hero__lower {
	display: grid;
	grid-template-columns: minmax(10rem, 0.62fr) minmax(0, 1fr);
	align-items: center;
	gap: clamp(0.85rem, 1.8vw, 1.35rem);
	direction: rtl;
}

.neomi-about-hero__story {
	max-width: 21rem;
	color: #2f2735;
	font-size: clamp(0.94rem, 1vw, 1.05rem);
	font-weight: 500;
	line-height: 1.75;
	text-align: right;
}

.neomi-about-quote,
.neomi-about-numbers,
.neomi-about-care-line,
.neomi-about-volunteers,
.neomi-about-cta {
	max-width: min(58rem, calc(100vw - clamp(1.5rem, 6vw, 6rem)));
	margin-inline: auto;
	text-align: center;
}

.neomi-about-quote {
	padding: clamp(2.4rem, 5vw, 4.2rem) 0;
}

.neomi-about-quote h2 {
	font-size: clamp(2.3rem, 4.3vw, 4rem);
	line-height: 1.25;
	margin-block-end: 1.1rem;
}

.neomi-about-quote p {
	max-width: 25rem;
	margin-inline: auto;
	color: #3d3445;
}

.neomi-about-numbers {
	padding: clamp(2rem, 4vw, 3.2rem) 0;
	border-block: 1px solid var(--neomi-about-line);
}

.neomi-about-numbers h2,
.neomi-about-care-line h2 {
	font-family: var(--neomi-font-body);
	font-size: clamp(1.1rem, 1.6vw, 1.45rem);
	font-weight: 800;
	margin-block-end: clamp(1.6rem, 3vw, 2.3rem);
}

.neomi-about-numbers ul {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	align-items: center;
}

.neomi-about-numbers li {
	border-inline-start: 1px solid rgba(196, 165, 116, 0.42);
}

.neomi-about-numbers li:last-child {
	border-inline-start: 0;
}

.neomi-about-numbers strong {
	display: block;
	font-family: var(--neomi-font-display);
	font-size: clamp(2.5rem, 5vw, 4.15rem);
	font-weight: 500;
	line-height: 1;
	color: var(--neomi-about-ink);
}

.neomi-about-numbers span {
	display: block;
	margin-block-start: 0.4rem;
	font-size: 1rem;
	color: #2f2735;
}

.neomi-about-care-line {
	padding: clamp(2rem, 4vw, 3.2rem) 0;
}

.neomi-about-care-line ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.35rem clamp(1.2rem, 3vw, 2.1rem);
	margin-block-end: 1.25rem;
}

.neomi-about-care-line li {
	color: #2f2735;
	font-size: 1.02rem;
	font-weight: 600;
}

.neomi-about-care-line li + li::before {
	display: inline-block;
	width: 1px;
	height: 1.1em;
	margin-inline-end: clamp(1.2rem, 3vw, 2.1rem);
	vertical-align: -0.2em;
	content: "";
	background: rgba(196, 165, 116, 0.8);
}

.neomi-about-care-line p {
	max-width: 30rem;
	margin-inline: auto;
	color: #3d3445;
}

.neomi-about-room {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(20rem, 1.18fr);
	align-items: stretch;
	border-block: 1px solid rgba(143, 69, 110, 0.11);
}

.neomi-about-room__text {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: clamp(2.5rem, 6vw, 5rem) clamp(1.5rem, 6vw, 6rem);
}

.neomi-about-room__text h2 {
	max-width: 31rem;
	font-family: var(--neomi-font-body);
	font-size: clamp(1.45rem, 2.4vw, 2.05rem);
	font-weight: 800;
	line-height: 1.55;
}

.neomi-about-small-rule {
	width: 3.75rem;
	height: 1px;
	margin: clamp(1.3rem, 3vw, 2rem) 0;
	background: rgba(196, 165, 116, 0.72);
}

.neomi-about-room__text p {
	max-width: 25rem;
	color: #2f2735;
	font-size: clamp(1.08rem, 1.4vw, 1.25rem);
	font-weight: 700;
}

.neomi-about-room__image-wrap {
	min-height: clamp(19rem, 32vw, 28rem);
	overflow: hidden;
	background: #eadfd4;
}

.neomi-about-room__image {
	object-position: center;
}

.neomi-about-volunteers {
	padding: clamp(2.3rem, 5vw, 4.2rem) 0 clamp(2.8rem, 6vw, 5rem);
}

.neomi-about-volunteers h2 {
	max-width: 33rem;
	margin-inline: auto;
	font-family: var(--neomi-font-body);
	font-size: clamp(1.55rem, 2.6vw, 2.25rem);
	font-weight: 800;
	line-height: 1.42;
}

.neomi-about-volunteers .neomi-about-small-rule {
	margin-inline: auto;
}

.neomi-about-volunteers p {
	max-width: 24rem;
	margin-inline: auto;
	color: #3d3445;
}

.neomi-about-cta {
	max-width: min(48rem, calc(100vw - clamp(1.5rem, 6vw, 6rem)));
	padding: clamp(1.45rem, 2.5vw, 2rem) 0 clamp(1rem, 2vw, 1.45rem);
	margin-block-end: 0;
	background: transparent;
	border: 0;
	box-shadow: none;
}

.neomi-about-cta__heart {
	color: var(--neomi-about-gold);
	font-size: 2.2rem;
	line-height: 1;
}

.neomi-about-cta h2 {
	max-width: 32rem;
	margin: 0.65rem auto 1.45rem;
	font-family: var(--neomi-font-body);
	font-size: clamp(1.45rem, 2.6vw, 2.15rem);
	font-weight: 800;
	line-height: 1.35;
}

.neomi-about-cta .neomi-btn {
	min-width: 11rem;
	border-radius: 0.35rem;
	box-shadow: none;
}

body.page-id-1127 .neomi-about {
	padding-block-end: 0;
}

body.page-id-1127 .neomi-about-cta + * {
	display: none !important;
}

@media (max-width: 63.99rem) {
	.neomi-about-hero,
	.neomi-about-room {
		grid-template-columns: 1fr;
	}

	.neomi-about-hero__image-wrap {
		order: -1;
		min-height: 0;
		padding: clamp(0.85rem, 3.5vw, 1.25rem);
	}

	.neomi-about-hero__image--secondary {
		width: 100%;
	}

	.neomi-about-hero__lower {
		grid-template-columns: 1fr;
	}

	.neomi-about-hero__story {
		max-width: none;
		text-align: center;
	}

	.neomi-about-hero__text {
		padding-block: clamp(2.5rem, 8vw, 4rem);
	}

	.neomi-about-room__image-wrap {
		order: -1;
	}
}

@media (max-width: 39.99rem) {
	.neomi-about-numbers ul {
		gap: 1.4rem;
		grid-template-columns: 1fr;
	}

	.neomi-about-numbers li,
	.neomi-about-numbers li:last-child {
		border-inline-start: 0;
	}

	.neomi-about-care-line ul {
		display: grid;
		gap: 0.55rem;
	}

	.neomi-about-care-line li + li::before {
		display: none;
	}
}

/* Compact page rhythm: preserve all content, reduce vertical travel. */
.neomi-about p {
	line-height: 1.58;
}

.neomi-about-kicker {
	margin-block-end: 0.65rem;
}

.neomi-about-hero__text {
	padding-block: clamp(1.8rem, 3.8vw, 3.25rem);
}

.neomi-about-hero__text h1 {
	font-size: clamp(2.45rem, 4.5vw, 4.15rem);
	line-height: 1.08;
}

.neomi-about-ornament {
	margin-block: clamp(0.65rem, 1.35vw, 1rem) clamp(0.75rem, 1.45vw, 1.05rem);
}

.neomi-about-hero__image-wrap {
	gap: clamp(0.55rem, 1vw, 0.8rem);
	padding: clamp(0.75rem, 1.5vw, 1.2rem);
}

.neomi-about-hero__image {
	max-height: clamp(10rem, 18vw, 16rem);
}

.neomi-about-hero__lower {
	gap: clamp(0.6rem, 1.2vw, 0.9rem);
}

.neomi-about-hero__story {
	font-size: clamp(0.88rem, 0.95vw, 0.98rem);
	line-height: 1.48;
}

.neomi-about-quote {
	padding-block: clamp(1.55rem, 3vw, 2.5rem);
}

.neomi-about-quote h2 {
	font-size: clamp(2rem, 3.35vw, 3.25rem);
	margin-block-end: 0.65rem;
}

.neomi-about-numbers,
.neomi-about-care-line {
	padding-block: clamp(1.45rem, 2.7vw, 2.25rem);
}

.neomi-about-numbers h2,
.neomi-about-care-line h2 {
	margin-block-end: clamp(1rem, 1.8vw, 1.45rem);
}

.neomi-about-numbers strong {
	font-size: clamp(2.15rem, 4vw, 3.35rem);
}

.neomi-about-room__text {
	padding-block: clamp(1.9rem, 4vw, 3.35rem);
}

.neomi-about-room__text h2 {
	font-size: clamp(1.3rem, 2vw, 1.75rem);
	line-height: 1.38;
}

.neomi-about-small-rule {
	margin-block: clamp(0.9rem, 1.8vw, 1.35rem);
}

.neomi-about-room__text p {
	font-size: clamp(1rem, 1.15vw, 1.12rem);
}

.neomi-about-room__image-wrap {
	min-height: clamp(14rem, 23vw, 20rem);
}

.neomi-about-volunteers {
	padding-block: clamp(1.55rem, 3vw, 2.5rem);
}

.neomi-about-volunteers h2 {
	font-size: clamp(1.32rem, 2.1vw, 1.85rem);
	line-height: 1.3;
}

.neomi-about-cta {
	padding-block: clamp(1rem, 1.8vw, 1.45rem) clamp(0.75rem, 1.5vw, 1rem);
}

.neomi-about-cta__heart {
	font-size: 1.55rem;
}

.neomi-about-cta h2 {
	margin-block: 0.4rem 1rem;
	font-size: clamp(1.25rem, 2vw, 1.7rem);
}
