/* Inspa — services page */

/* Page hero: shared with Booking + Thank-you (same `.inspa-page-hero` structure) */
.inspa-page-hero {
	text-align: start;
}

.inspa-page-hero__inner {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 0;
	max-width: 56rem;
	min-width: 0;
}

.inspa-main--page .inspa-page-hero .inspa-eyebrow {
	margin: 0 0 var(--inspa-space-sm);
}

.inspa-main--page .inspa-page-hero h1 {
	margin: 0 0 var(--inspa-space-md);
}

.inspa-page-hero__lede {
	margin: 0;
	font-size: 1.05rem;
	line-height: 1.65;
	color: var(--inspa-muted);
	max-width: 50ch;
}

.inspa-service-list__intro {
	margin: 0 0 var(--inspa-space-xl);
	max-width: 42rem;
}

.inspa-service-list__intro .inspa-eyebrow {
	margin-bottom: var(--inspa-space-sm);
}

.inspa-service-list__intro .inspa-h2 {
	margin-bottom: var(--inspa-space-sm);
}

.inspa-service-list__intro .inspa-prose {
	margin: 0;
}

.inspa-page-hero__rule {
	height: 1px;
	background: linear-gradient(90deg, var(--inspa-accent-soft), transparent);
	opacity: 0.45;
	margin-top: var(--inspa-space-xl);
}

.inspa-service-list__stack {
	display: flex;
	flex-direction: column;
	gap: clamp(3rem, 8vw, 5rem);
	min-width: 0;
}

.inspa-service-block {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
	gap: var(--inspa-space-2xl);
	align-items: center;
	padding-bottom: clamp(2.5rem, 6vw, 3.5rem);
	border-bottom: 1px solid var(--inspa-border);
}

.inspa-service-block__body {
	min-width: 0;
}

.inspa-service-block:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.inspa-service-block--reverse {
	direction: rtl;
}

.inspa-service-block--reverse > * {
	direction: ltr;
}

@media (max-width: 880px) {
	.inspa-service-block,
	.inspa-service-block--reverse {
		grid-template-columns: 1fr;
		direction: ltr;
	}
}

.inspa-service-block__media img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: var(--inspa-radius-lg);
	object-fit: cover;
	box-shadow: var(--inspa-shadow-card);
}

.inspa-service-block__title {
	font-family: var(--inspa-font-display);
	font-size: clamp(1.45rem, 2.2vw, 1.85rem);
	font-weight: 500;
	margin: 0 0 0.65rem;
}

.inspa-service-block__intro {
	margin: 0 0 var(--inspa-space-md);
	font-size: 1.02rem;
	line-height: 1.65;
	color: var(--inspa-ink-soft);
}

.inspa-service-block__highlights {
	margin: 0 0 var(--inspa-space-lg);
	padding-left: 1.15rem;
	color: var(--inspa-muted);
	font-size: 0.95rem;
	line-height: 1.55;
}

.inspa-service-block__foot {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--inspa-space-md);
	justify-content: space-between;
	padding-top: var(--inspa-space-sm);
	border-top: 1px dashed var(--inspa-border);
}

.inspa-service-block__price {
	margin: 0;
	font-size: 0.95rem;
	color: var(--inspa-muted);
}

.inspa-faq__intro {
	text-align: start;
	max-width: 50ch;
}

.inspa-faq__intro .inspa-h2 {
	margin: 0 0 var(--inspa-space-sm);
}

.inspa-faq__intro .inspa-prose {
	margin: 0;
}

.inspa-faq__inner {
	display: grid;
	grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
	gap: var(--inspa-space-2xl);
	align-items: start;
}

@media (max-width: 800px) {
	.inspa-faq__inner {
		grid-template-columns: 1fr;
	}
}

.inspa-faq__list {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.inspa-details {
	border-radius: var(--inspa-radius-md);
	border: 1px solid var(--inspa-border);
	background: rgba(255, 252, 248, 0.75);
	padding: 0.85rem 1rem;
	transition:
		border-color var(--inspa-duration) var(--inspa-ease),
		background var(--inspa-duration) var(--inspa-ease);
}

.inspa-details[open] {
	border-color: rgba(63, 82, 73, 0.25);
	background: var(--inspa-surface);
}

.inspa-details summary {
	cursor: pointer;
	font-weight: var(--inspa-fw-semibold);
	font-size: 0.98rem;
	list-style: none;
}

.inspa-details summary::-webkit-details-marker {
	display: none;
}

.inspa-details summary::after {
	content: "+";
	float: right;
	color: var(--inspa-accent-soft);
	font-weight: var(--inspa-fw-semibold);
}

.inspa-details[open] summary::after {
	content: "–";
}

.inspa-details p {
	margin: 0.75rem 0 0.15rem;
	font-size: 0.95rem;
	line-height: 1.6;
	color: var(--inspa-muted);
}

.inspa-services-cta__inner {
	text-align: center;
	max-width: 44rem;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: var(--inspa-space-lg);
	align-items: center;
	padding-block: var(--inspa-space-xl);
}

.inspa-services-cta__copy {
	margin: 0;
	font-size: 1.05rem;
	color: var(--inspa-dark-muted);
}

/* BookingPress-driven service list ([inspa_bookingpress_services] shortcode) */
.inspa-service-block__media--bp {
	min-height: 280px;
	border-radius: var(--inspa-radius-lg);
	background-size: cover;
	background-position: center;
	box-shadow: var(--inspa-shadow-card);
}

.inspa-bp-thumb--0 {
	background-image: linear-gradient(145deg, #efe9e1 0%, #d8d0c5 100%);
}

.inspa-bp-thumb--1 {
	background-image: linear-gradient(145deg, #e8ede7 0%, #c9d2c8 100%);
}

.inspa-bp-thumb--2 {
	background-image: linear-gradient(145deg, #efeaf3 0%, #d6cfd8 100%);
}

.inspa-bp-thumb--3 {
	background-image: linear-gradient(145deg, #f2f0eb 0%, #d9d6cf 100%);
}

.inspa-bp-thumb--4 {
	background-image: linear-gradient(145deg, #e9f1ee 0%, #cad8d3 100%);
}

.inspa-bp-thumb--5 {
	background-image: linear-gradient(145deg, #f5f2ec 0%, #dee0d7 100%);
}

/* Service photo from BookingPress admin (service_image_details meta) */
.inspa-service-block__media--with-image {
	background-image: none;
	aspect-ratio: 3 / 2;
	min-height: 220px;
}

.inspa-service-block__media--with-image::after {
	display: none;
}

.inspa-service-block__media--with-image .inspa-service-block__img {
	display: block;
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.inspa-service-block__media.inspa-service-block__media--bp {
	position: relative;
	overflow: hidden;
}

.inspa-service-block__media.inspa-service-block__media--bp::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background: radial-gradient(80% 60% at 20% 20%, rgba(255, 255, 255, 0.45), transparent 70%);
	pointer-events: none;
}

.inspa-bp-services__empty {
	margin: 0;
	padding: var(--inspa-space-xl);
	text-align: center;
	color: var(--inspa-muted);
	border: 1px dashed var(--inspa-border-strong);
	border-radius: var(--inspa-radius-md);
	background: rgba(247, 245, 241, 0.65);
}
