/* Inspa — home page sections */

.inspa-hero {
	position: relative;
	overflow: clip;
}

/* Soft studio wash + edge definition without a heavy “hero block” frame */
.inspa-hero--studio {
	background:
		radial-gradient(120% 80% at 0% 0%, rgba(232, 226, 216, 0.55), transparent 55%),
		radial-gradient(90% 60% at 100% 20%, rgba(138, 154, 144, 0.12), transparent 50%),
		linear-gradient(180deg, rgba(255, 252, 248, 0.4), transparent);
	border-bottom: 1px solid rgba(28, 27, 25, 0.04);
}

.inspa-hero--studio::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'%3E%3Cpath d='M0 60h120M60 0v120' fill='none' stroke='%233f5249' stroke-opacity='0.04' stroke-width='0.5'/%3E%3C/svg%3E");
	opacity: 0.9;
	mask-image: radial-gradient(ellipse 85% 70% at 30% 20%, black 20%, transparent 70%);
}

.inspa-hero__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
	align-items: center;
	gap: var(--inspa-space-2xl);
}

@media (max-width: 960px) {
	.inspa-hero__grid {
		grid-template-columns: 1fr;
	}
}

.inspa-hero__title {
	margin: 0 0 var(--inspa-space-md);
}

.inspa-hero__copy .inspa-lede {
	margin: var(--inspa-space-md) 0 0;
	max-width: 38rem;
}

.inspa-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: var(--inspa-space-xl);
}

/* One secondary CTA: booking lives in the header nav */
.inspa-hero__actions--single {
	margin-top: var(--inspa-space-lg);
}

.inspa-hero__meta {
	list-style: none;
	margin: var(--inspa-space-xl) 0 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1.25rem;
	font-size: 0.88rem;
	color: var(--inspa-muted);
}

.inspa-hero__meta li {
	position: relative;
	padding-left: 0;
}

.inspa-hero__figure {
	margin: 0;
	position: relative;
}

.inspa-hero--studio .inspa-hero__figure::after {
	content: "";
	position: absolute;
	right: 1rem;
	bottom: 1rem;
	width: min(38%, 200px);
	height: min(38%, 200px);
	border: 1px solid rgba(63, 82, 73, 0.12);
	border-radius: calc(var(--inspa-radius-xl) - 4px);
	pointer-events: none;
	z-index: 0;
	opacity: 0.85;
}

@media (max-width: 960px) {
	.inspa-hero--studio .inspa-hero__figure::after {
		width: 34%;
		height: 34%;
		right: 0.65rem;
		bottom: 0.65rem;
	}
}

.inspa-hero__img {
	position: relative;
	z-index: 1;
	min-height: min(72vh, 640px);
	border-radius: var(--inspa-radius-xl);
	background-color: var(--inspa-sand);
	background-image: var(
		--inspa-hero-bg,
		url("https://placehold.co/1200x1400/f0ede7/4a5249?text=REPLACE+HERO+IMAGE")
	);
	background-size: cover;
	background-position: center;
	box-shadow:
		var(--inspa-shadow-soft),
		0 0 0 1px rgba(28, 27, 25, 0.04);
}

.inspa-hero__media {
	position: relative;
	z-index: 1;
}

/* Featured row — subtle rule tying eyebrow to heading */
.inspa-section-head--featured .inspa-eyebrow {
	position: relative;
	padding-bottom: 0.65rem;
	margin-bottom: var(--inspa-space-md);
}

.inspa-section-head--featured .inspa-eyebrow.inspa-cta-ico {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

.inspa-section-head--featured .inspa-eyebrow::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 2.5rem;
	height: 2px;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--inspa-accent-soft), rgba(63, 82, 73, 0.15));
}

/* Intro */
.inspa-intro__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.85fr);
	gap: var(--inspa-space-2xl);
	align-items: start;
}

@media (max-width: 900px) {
	.inspa-intro__grid {
		grid-template-columns: 1fr;
	}
}

.inspa-intro .inspa-h2 em {
	font-style: italic;
	font-weight: 400;
	color: var(--inspa-accent);
}

.inspa-intro__panel {
	position: relative;
}

.inspa-intro__img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: var(--inspa-radius-lg);
	box-shadow: var(--inspa-shadow-card);
	object-fit: cover;
}

.inspa-intro__stat {
	position: absolute;
	left: 12%;
	bottom: -1.5rem;
	padding: 1rem 1.25rem;
	background: var(--inspa-surface);
	border-radius: var(--inspa-radius-md);
	box-shadow: var(--inspa-shadow-soft);
	border: 1px solid var(--inspa-border);
	max-width: 16rem;
}

.inspa-intro__stat-value {
	font-family: var(--inspa-font-display);
	font-size: 2rem;
	line-height: 1;
	margin: 0 0 0.25rem;
	color: var(--inspa-accent);
}

.inspa-intro__stat-label {
	margin: 0;
	font-size: 0.9rem;
	color: var(--inspa-muted);
	line-height: 1.45;
}

/* Couples (same room — home) */
.inspa-couples__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.9fr);
	gap: var(--inspa-space-2xl);
	align-items: start;
}

.inspa-couples__copy .inspa-section-head {
	margin-bottom: var(--inspa-space-md);
}

.inspa-couples__note {
	margin: var(--inspa-space-sm) 0 0;
	font-size: 1.02rem;
	line-height: 1.65;
	color: var(--inspa-muted);
}

.inspa-couples__benefits {
	list-style: none;
	margin: var(--inspa-space-lg) 0 0;
	padding: 0;
	display: grid;
	gap: 0.65rem;
	max-width: 36rem;
}

.inspa-couples__benefits li {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	font-size: 0.93rem;
	line-height: 1.55;
	color: var(--inspa-ink-soft);
}

.inspa-couples__benefits .inspa-ico-svg {
	flex-shrink: 0;
	margin-top: 0.15em;
	color: var(--inspa-accent);
}

.inspa-couples__actions {
	margin: var(--inspa-space-xl) 0 0;
}

.inspa-couples__figure {
	margin: 0;
}

.inspa-couples__img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: var(--inspa-radius-lg);
	box-shadow: var(--inspa-shadow-card);
	object-fit: cover;
}

@media (max-width: 900px) {
	.inspa-couples__grid {
		grid-template-columns: 1fr;
		gap: var(--inspa-space-lg);
	}

	.inspa-couples__figure {
		order: -1;
	}
}

/* Service preview cards */
.inspa-card-grid {
	display: grid;
	gap: var(--inspa-space-lg);
}

@media (min-width: 700px) {
	.inspa-card-grid--3 {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.inspa-card {
	background: var(--inspa-surface);
	border: 1px solid var(--inspa-border);
	border-radius: var(--inspa-radius-lg);
	padding: 0 0 1.35rem;
	display: flex;
	flex-direction: column;
	box-shadow: var(--inspa-shadow-card);
	transition:
		transform var(--inspa-duration) var(--inspa-ease),
		box-shadow var(--inspa-duration) var(--inspa-ease),
		border-color var(--inspa-duration) var(--inspa-ease);
}

.inspa-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 20px 50px rgba(24, 22, 18, 0.1);
	border-color: rgba(63, 82, 73, 0.18);
}

.inspa-card__visual {
	height: 200px;
	border-radius: calc(var(--inspa-radius-lg) - 2px) calc(var(--inspa-radius-lg) - 2px) 0 0;
	background-image: var(--inspa-card-img);
	background-size: cover;
	background-position: center;
}

.inspa-card__title {
	font-family: var(--inspa-font-display);
	font-size: 1.35rem;
	font-weight: 500;
	margin: 1.1rem 1.35rem 0.5rem;
}

.inspa-card__text {
	margin: 0 1.35rem;
	font-size: 0.95rem;
	line-height: 1.6;
	color: var(--inspa-muted);
	flex-grow: 1;
}

.inspa-card__meta {
	margin: var(--inspa-space-md) 1.35rem 0;
	font-size: 0.82rem;
	font-weight: var(--inspa-fw-medium);
	color: var(--inspa-ink-soft);
}

.inspa-card__cta {
	margin: var(--inspa-space-lg) 1.35rem 0;
	align-self: flex-start;
	font-weight: var(--inspa-fw-semibold);
	font-size: 0.9rem;
	color: var(--inspa-accent);
	text-decoration: none;
	border-bottom: 1px solid rgba(63, 82, 73, 0.35);
	width: fit-content;
	transition: color var(--inspa-duration) var(--inspa-ease), border-color var(--inspa-duration) var(--inspa-ease);
}

.inspa-card__cta:hover,
.inspa-card__cta:focus-visible {
	color: var(--inspa-ink);
	border-bottom-color: var(--inspa-ink);
}

/*
 * BookingPress home “Featured” cards: center the row, wrap at up to 3 cards per row.
 * (Replaces a fixed 3-column grid so 1–2 cards or last-row orphans stay centered.)
 */
.inspa-bp-service-cards.inspa-card-grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: stretch;
	gap: var(--inspa-space-lg);
	width: 100%;
	max-width: min(100%, 72rem);
	margin-inline: auto;
}

.inspa-bp-service-cards .inspa-card {
	flex: 1 1 clamp(16rem, calc((100% - 2 * var(--inspa-space-lg)) / 3), 22rem);
	max-width: min(100%, 22rem);
	min-width: 0;
}

/* Benefits */
.inspa-benefits__list {
	list-style: none;
	margin: var(--inspa-space-xl) 0 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--inspa-space-lg);
	max-width: 52rem;
}

.inspa-benefit {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	gap: var(--inspa-space-lg);
	padding: var(--inspa-space-lg);
	border-radius: var(--inspa-radius-md);
	border: 1px solid rgba(244, 241, 234, 0.12);
	background: rgba(0, 0, 0, 0.12);
}

.inspa-benefit__index {
	font-family: var(--inspa-font-display);
	font-size: 1.25rem;
	color: rgba(244, 241, 234, 0.45);
	line-height: 1;
	padding-top: 0.15rem;
}

.inspa-benefit__title {
	font-family: var(--inspa-font-display);
	font-size: 1.25rem;
	font-weight: 500;
	margin: 0 0 0.4rem;
	color: var(--inspa-dark-ink);
}

.inspa-benefit__text {
	margin: 0;
	font-size: 0.98rem;
	line-height: 1.65;
	color: var(--inspa-dark-muted);
}

/* Testimonials */
.inspa-quote-grid {
	display: grid;
	gap: var(--inspa-space-lg);
}

@media (min-width: 900px) {
	.inspa-quote-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.inspa-quote-grid--duo {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		max-width: 56rem;
		margin-inline: auto;
	}
}

.inspa-quote {
	margin: 0;
	padding: var(--inspa-space-lg);
	border-radius: var(--inspa-radius-lg);
	background: linear-gradient(165deg, rgba(255, 252, 248, 0.98), rgba(247, 245, 241, 0.85));
	border: 1px solid var(--inspa-border);
	box-shadow: var(--inspa-shadow-card);
	display: flex;
	flex-direction: column;
	gap: var(--inspa-space-md);
	min-height: 100%;
	transition:
		transform var(--inspa-duration) var(--inspa-ease),
		box-shadow var(--inspa-duration) var(--inspa-ease);
}

.inspa-quote:hover {
	transform: translateY(-2px);
	box-shadow: 0 18px 44px rgba(24, 22, 18, 0.08);
}

.inspa-quote blockquote {
	margin: 0;
}

.inspa-quote__rating {
	margin: 0;
	font-size: 1.05rem;
	line-height: 1.2;
	letter-spacing: 0.04em;
	color: #c25a28;
}

.inspa-quote__star-empty {
	color: #c9c4bc;
}

.inspa-quote blockquote p {
	font-size: 1.02rem;
	line-height: 1.65;
	color: var(--inspa-ink-soft);
}

.inspa-quote figcaption {
	font-size: 0.88rem;
	color: var(--inspa-muted);
}

.inspa-quote cite {
	font-style: normal;
	font-weight: var(--inspa-fw-semibold);
	color: var(--inspa-ink);
}

.inspa-quote__note {
	display: block;
	margin-top: 0.2rem;
}

/* Process */
.inspa-process__steps {
	list-style: none;
	margin: var(--inspa-space-xl) 0 0;
	padding: 0;
	display: grid;
	gap: var(--inspa-space-md);
}

@media (min-width: 800px) {
	.inspa-process__steps {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

.inspa-process__steps li {
	position: relative;
	padding: var(--inspa-space-lg);
	border-radius: var(--inspa-radius-md);
	background: rgba(255, 252, 248, 0.78);
	border: 1px solid var(--inspa-border);
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--inspa-ink-soft);
}

.inspa-process__head {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 0.5rem;
}

.inspa-process__li-icon {
	display: flex;
	color: var(--inspa-accent);
}

.inspa-process__li-icon .inspa-ico-svg {
	width: 1.25rem;
	height: 1.25rem;
}

.inspa-process__label {
	font-size: 0.72rem;
	font-weight: var(--inspa-fw-semibold);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--inspa-accent-soft);
}

.inspa-process__body {
	margin: 0;
}

/* CTA banner */
.inspa-cta-banner {
	padding-block: var(--inspa-space-2xl);
}

.inspa-cta-banner__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--inspa-space-xl);
	padding: var(--inspa-space-2xl);
	border-radius: var(--inspa-radius-xl);
	background:
		linear-gradient(125deg, rgba(232, 226, 216, 0.78), rgba(255, 252, 248, 0.96)),
		radial-gradient(90% 100% at 100% 0%, rgba(138, 154, 144, 0.28), transparent 55%);
	border: 1px solid var(--inspa-border);
	box-shadow:
		var(--inspa-shadow-soft),
		inset 0 1px 0 rgba(255, 255, 255, 0.45);
}

.inspa-cta-banner__inner > div:first-child .inspa-h2 {
	max-width: 28ch;
}

.inspa-cta-banner__copy {
	margin: 0.5rem 0 0;
	font-size: 1.02rem;
	color: var(--inspa-muted);
	max-width: 44ch;
}

.inspa-cta-banner__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}
