/* ==========================================================================
   single-treatment.css — Panacea Pastel Child Theme
   Template: single-treatment.php
   Naming: BEM, prefix .pn-treatment-
   Mobile-first breakpoints: 480px, 768px, 1024px
   Tokens: defined in tokens.css (root scope)
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. WRAPPER
   -------------------------------------------------------------------------- */
.pn-treatment-wrap {
	background-color: var(--pn-bg-cream);
	color: var(--pn-ink-deep);
	font-family: var(--pn-font-body);
	font-size: var(--pn-fs-body);
}

/* --------------------------------------------------------------------------
   2. BREADCRUMB
   -------------------------------------------------------------------------- */
.pn-treatment-breadcrumb {
	padding: var(--pn-space-3) var(--pn-space-4);
	background-color: var(--pn-bg-white);
	border-bottom: 1px solid var(--pn-line);
}

.pn-treatment-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--pn-space-1);
	list-style: none;
	margin: 0;
	padding: 0;
	max-width: var(--pn-container);
	margin-inline: auto;
	font-size: var(--pn-fs-eyebrow);
	letter-spacing: 0.05em;
}

.pn-treatment-breadcrumb__link {
	color: var(--pn-ink-soft);
	text-decoration: none;
	transition: color var(--pn-dur-fast) var(--pn-ease);
}

.pn-treatment-breadcrumb__link:hover,
.pn-treatment-breadcrumb__link:focus-visible {
	color: var(--pn-blue-deep);
}

.pn-treatment-breadcrumb__sep {
	color: var(--pn-ink-muted);
}

.pn-treatment-breadcrumb__current {
	color: var(--pn-ink-deep);
	font-weight: 500;
}

/* --------------------------------------------------------------------------
   3. HERO SPLIT
   -------------------------------------------------------------------------- */
.pn-treatment-hero {
	position: relative;
	display: flex;
	flex-direction: column;
	min-height: 100svh;
}

@media (min-width: 768px) {
	.pn-treatment-hero {
		flex-direction: row;
		min-height: 90vh;
		max-height: 100vh;
	}
}

/* Image column */
.pn-treatment-hero__image-col {
	flex: 0 0 100%;
	height: 56vw;
	min-height: 260px;
	overflow: hidden;
}

@media (min-width: 768px) {
	.pn-treatment-hero__image-col {
		flex: 0 0 50%;
		height: auto;
	}
}

.pn-treatment-hero__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center top;
	display: block;
	transition: transform var(--pn-dur-slow) var(--pn-ease);
}

.pn-treatment-hero__image-placeholder {
	width: 100%;
	height: 100%;
	background-color: var(--pn-blue-pastel);
}

/* Content column */
.pn-treatment-hero__content-col {
	flex: 0 0 100%;
	display: flex;
	align-items: center;
	background-color: var(--pn-bg-cream);
	padding: var(--pn-space-5) var(--pn-space-4);
}

@media (min-width: 768px) {
	.pn-treatment-hero__content-col {
		flex: 0 0 50%;
		padding: var(--pn-space-6) var(--pn-space-6) var(--pn-space-6) var(--pn-space-5);
	}
}

@media (min-width: 1024px) {
	.pn-treatment-hero__content-col {
		padding: var(--pn-space-7) var(--pn-space-7) var(--pn-space-7) var(--pn-space-6);
	}
}

.pn-treatment-hero__content {
	max-width: 560px;
}

/* Eyebrow */
.pn-treatment-hero__eyebrow {
	font-family: var(--pn-font-eyebrow);
	font-size: var(--pn-fs-eyebrow);
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--pn-blue-deep);
	margin: 0 0 var(--pn-space-3);
}

/* Title */
.pn-treatment-hero__title {
	font-family: var(--pn-font-display);
	font-size: clamp(36px, 5vw, 64px);
	font-weight: 600;
	line-height: 1.1;
	color: var(--pn-ink-deep);
	margin: 0 0 var(--pn-space-4);
	letter-spacing: -0.02em;
}

/* Badges */
.pn-treatment-hero__badges {
	display: flex;
	flex-wrap: wrap;
	gap: var(--pn-space-2);
	margin-bottom: var(--pn-space-4);
}

.pn-treatment-hero__badge {
	display: inline-flex;
	align-items: center;
	gap: var(--pn-space-1);
	padding: 6px var(--pn-space-3);
	border-radius: var(--pn-radius-pill);
	font-size: var(--pn-fs-eyebrow);
	font-weight: 600;
	letter-spacing: 0.04em;
	white-space: nowrap;
}

.pn-treatment-hero__badge--duration {
	background-color: var(--pn-blue-pastel);
	color: var(--pn-blue-deep);
}

.pn-treatment-hero__badge--price {
	background-color: var(--pn-ink-deep);
	color: var(--pn-bg-white);
}

/* Excerpt */
.pn-treatment-hero__excerpt {
	font-size: var(--pn-fs-lead);
	color: var(--pn-ink-soft);
	line-height: 1.6;
	margin: 0 0 var(--pn-space-5);
	max-width: 480px;
}

/* CTAs */
.pn-treatment-hero__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: var(--pn-space-3);
}

/* --------------------------------------------------------------------------
   4. BUTTONS
   -------------------------------------------------------------------------- */
.pn-treatment-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--pn-space-2);
	padding: 14px var(--pn-space-5);
	border-radius: var(--pn-radius-pill);
	font-family: var(--pn-font-body);
	font-size: var(--pn-fs-body);
	font-weight: 600;
	letter-spacing: 0.02em;
	text-decoration: none;
	cursor: pointer;
	border: 2px solid transparent;
	transition:
		background-color var(--pn-dur-fast) var(--pn-ease),
		color var(--pn-dur-fast) var(--pn-ease),
		border-color var(--pn-dur-fast) var(--pn-ease),
		transform var(--pn-dur-fast) var(--pn-ease);
	-webkit-appearance: none;
	appearance: none;
}

.pn-treatment-btn:focus-visible {
	outline: 3px solid var(--pn-blue-deep);
	outline-offset: 2px;
}

.pn-treatment-btn:active {
	transform: translateY(1px);
}

.pn-treatment-btn--primary {
	background-color: var(--pn-blue-deep);
	color: #fff;
	border-color: var(--pn-blue-deep);
}

.pn-treatment-btn--primary:hover {
	background-color: color-mix(in srgb, var(--pn-blue-deep) 85%, #000);
	border-color: color-mix(in srgb, var(--pn-blue-deep) 85%, #000);
	color: #fff;
}

.pn-treatment-btn--outline {
	background-color: transparent;
	color: var(--pn-ink-deep);
	border-color: var(--pn-ink-deep);
}

.pn-treatment-btn--outline:hover {
	background-color: var(--pn-ink-deep);
	color: var(--pn-bg-white);
}

.pn-treatment-btn--full {
	width: 100%;
}

/* --------------------------------------------------------------------------
   5. STICKY TABS BAR
   -------------------------------------------------------------------------- */
.pn-treatment-tabs {
	position: sticky;
	top: 0;
	z-index: 50;
	background-color: var(--pn-bg-white);
	border-bottom: 1px solid var(--pn-line);
	box-shadow: 0 1px 4px rgba(27, 31, 42, 0.06);
}

.pn-treatment-tabs__inner {
	display: flex;
	gap: 0;
	overflow-x: auto;
	scrollbar-width: none;
	-ms-overflow-style: none;
	max-width: var(--pn-container);
	margin-inline: auto;
	padding-inline: var(--pn-space-4);
}

.pn-treatment-tabs__inner::-webkit-scrollbar {
	display: none;
}

.pn-treatment-tabs__link {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	padding: var(--pn-space-3) var(--pn-space-4);
	font-family: var(--pn-font-body);
	font-size: clamp(13px, 0.9vw, 15px);
	font-weight: 500;
	color: var(--pn-ink-soft);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
	white-space: nowrap;
	transition:
		color var(--pn-dur-fast) var(--pn-ease),
		border-color var(--pn-dur-fast) var(--pn-ease);
}

.pn-treatment-tabs__link:hover,
.pn-treatment-tabs__link:focus-visible {
	color: var(--pn-blue-deep);
	outline: none;
}

.pn-treatment-tabs__link--active,
.pn-treatment-tabs__link[aria-current="true"] {
	color: var(--pn-blue-deep);
	border-bottom-color: var(--pn-blue-deep);
	font-weight: 600;
}

/* --------------------------------------------------------------------------
   6. SECTION BASE
   -------------------------------------------------------------------------- */
.pn-treatment-section {
	padding: var(--pn-space-6) 0;
	background-color: var(--pn-bg-white);
}

.pn-treatment-section--alt {
	background-color: var(--pn-bg-cream);
}

@media (min-width: 768px) {
	.pn-treatment-section {
		padding: var(--pn-space-7) 0;
	}
}

.pn-treatment-section__container {
	max-width: var(--pn-container);
	margin-inline: auto;
	padding-inline: var(--pn-space-4);
}

@media (min-width: 768px) {
	.pn-treatment-section__container {
		padding-inline: var(--pn-space-5);
	}
}

.pn-treatment-eyebrow {
	display: block;
	font-family: var(--pn-font-eyebrow);
	font-size: var(--pn-fs-eyebrow);
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--pn-blue-deep);
	margin-bottom: var(--pn-space-2);
}

.pn-treatment-eyebrow--light {
	color: var(--pn-blue-pastel);
}

.pn-treatment-section__title {
	font-family: var(--pn-font-display);
	font-size: var(--pn-fs-h2);
	font-weight: 600;
	line-height: 1.1;
	color: var(--pn-ink-deep);
	margin: 0 0 var(--pn-space-5);
	letter-spacing: -0.02em;
}

.pn-treatment-section__title--center {
	text-align: center;
}

/* --------------------------------------------------------------------------
   7. STICKY SIDEBAR (desktop only)
   -------------------------------------------------------------------------- */
.pn-treatment-sidebar {
	display: none;
}

@media (min-width: 1024px) {
	.pn-treatment-sidebar {
		display: block;
		position: absolute;
		top: 0;
		right: 0;
		width: 30%;
		/* The sidebar is positioned within the hero; sticky behaviour
		   is applied via JS IntersectionObserver class toggling */
	}
}

.pn-treatment-sidebar__inner {
	position: sticky;
	top: 100px;
	background-color: var(--pn-bg-white);
	border: 1px solid var(--pn-line);
	border-radius: var(--pn-radius-lg);
	padding: var(--pn-space-5);
	box-shadow: var(--pn-shadow);
	margin: var(--pn-space-5);
}

.pn-treatment-sidebar__price-label {
	font-size: var(--pn-fs-eyebrow);
	color: var(--pn-ink-muted);
	margin: 0 0 4px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.pn-treatment-sidebar__price {
	font-family: var(--pn-font-display);
	font-size: clamp(28px, 2.5vw, 40px);
	font-weight: 700;
	color: var(--pn-ink-deep);
	margin: 0 0 var(--pn-space-2);
	letter-spacing: -0.02em;
}

.pn-treatment-sidebar__price span {
	font-size: 0.6em;
	color: var(--pn-ink-soft);
}

.pn-treatment-sidebar__duration {
	font-size: var(--pn-fs-body);
	color: var(--pn-ink-soft);
	margin: 0 0 var(--pn-space-3);
}

.pn-treatment-sidebar__divider {
	border: none;
	border-top: 1px solid var(--pn-line);
	margin: var(--pn-space-4) 0;
}

.pn-treatment-sidebar__includes-label {
	font-weight: 600;
	font-size: var(--pn-fs-body);
	color: var(--pn-ink-deep);
	margin: 0 0 var(--pn-space-2);
}

.pn-treatment-sidebar__includes-list {
	list-style: none;
	margin: 0 0 var(--pn-space-4);
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--pn-space-2);
}

.pn-treatment-sidebar__includes-list li {
	display: flex;
	align-items: center;
	gap: var(--pn-space-2);
	font-size: var(--pn-fs-body);
	color: var(--pn-ink-soft);
}

.pn-treatment-sidebar__includes-list li::before {
	content: "";
	display: inline-block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background-color: var(--pn-blue-deep);
	flex-shrink: 0;
}

/* --------------------------------------------------------------------------
   8. SECTION: ÇFARË ËSHTË
   -------------------------------------------------------------------------- */
.pn-treatment-cfare__layout {
	display: flex;
	flex-direction: column;
	gap: var(--pn-space-5);
}

@media (min-width: 768px) {
	.pn-treatment-cfare__layout {
		flex-direction: row-reverse;
		align-items: flex-start;
		gap: var(--pn-space-6);
	}
}

.pn-treatment-cfare__text {
	flex: 1;
}

.pn-treatment-cfare__body {
	font-size: var(--pn-fs-body);
	line-height: 1.8;
	color: var(--pn-ink-soft);
	margin-bottom: var(--pn-space-4);
}

.pn-treatment-cfare__body p {
	margin-bottom: var(--pn-space-3);
}

.pn-treatment-cfare__sub-title {
	font-family: var(--pn-font-display);
	font-size: var(--pn-fs-h3);
	font-weight: 600;
	color: var(--pn-ink-deep);
	margin: var(--pn-space-4) 0 var(--pn-space-2);
}

.pn-treatment-cfare__ingredients {
	margin-bottom: var(--pn-space-4);
}

.pn-treatment-cfare__ingredients p {
	font-size: var(--pn-fs-body);
	color: var(--pn-ink-soft);
	line-height: 1.7;
}

.pn-treatment-cfare__contraindications {
	margin-bottom: var(--pn-space-4);
}

.pn-treatment-cfare__image {
	flex: 0 0 40%;
}

@media (min-width: 768px) {
	.pn-treatment-cfare__image {
		position: sticky;
		top: 80px;
	}
}

.pn-treatment-cfare__img {
	width: 100%;
	height: auto;
	border-radius: var(--pn-radius-lg);
	display: block;
	object-fit: cover;
}

.pn-treatment-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--pn-space-2);
}

.pn-treatment-list li {
	display: flex;
	align-items: flex-start;
	gap: var(--pn-space-2);
	font-size: var(--pn-fs-body);
	color: var(--pn-ink-soft);
	line-height: 1.6;
}

.pn-treatment-list li::before {
	content: "";
	display: inline-block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background-color: var(--pn-blue-deep);
	flex-shrink: 0;
	margin-top: 8px;
}

/* --------------------------------------------------------------------------
   9. TIMELINE (Procesi)
   -------------------------------------------------------------------------- */
.pn-treatment-timeline {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--pn-space-4);
}

@media (min-width: 768px) {
	.pn-treatment-timeline {
		flex-direction: row;
		gap: var(--pn-space-3);
		align-items: flex-start;
	}
}

.pn-treatment-timeline__step {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--pn-space-3);
	padding: var(--pn-space-4);
	background-color: var(--pn-bg-white);
	border: 1px solid var(--pn-line);
	border-radius: var(--pn-radius-md);
	box-shadow: var(--pn-shadow);
	transition: transform var(--pn-dur-base) var(--pn-ease);
}

.pn-treatment-timeline__step:hover {
	transform: translateY(-4px);
}

.pn-treatment-timeline__number {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background-color: var(--pn-blue-pastel);
	color: var(--pn-blue-deep);
	font-family: var(--pn-font-display);
	font-size: 20px;
	font-weight: 700;
	flex-shrink: 0;
}

.pn-treatment-timeline__title {
	font-family: var(--pn-font-display);
	font-size: var(--pn-fs-h3);
	font-weight: 600;
	color: var(--pn-ink-deep);
	margin: 0 0 var(--pn-space-2);
}

.pn-treatment-timeline__desc {
	font-size: var(--pn-fs-body);
	color: var(--pn-ink-soft);
	line-height: 1.7;
	margin: 0;
}

/* --------------------------------------------------------------------------
   10. RESULTS CARDS
   -------------------------------------------------------------------------- */
.pn-treatment-results__stat {
	text-align: center;
	margin-bottom: var(--pn-space-5);
}

.pn-treatment-results__stat p {
	display: inline-block;
	padding: var(--pn-space-2) var(--pn-space-5);
	background-color: var(--pn-blue-pastel);
	color: var(--pn-blue-deep);
	border-radius: var(--pn-radius-pill);
	font-weight: 600;
	font-size: var(--pn-fs-body);
}

.pn-treatment-results__cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--pn-space-4);
}

@media (min-width: 480px) {
	.pn-treatment-results__cards {
		grid-template-columns: repeat(3, 1fr);
	}
}

.pn-treatment-results__card {
	padding: var(--pn-space-5);
	background-color: var(--pn-bg-white);
	border: 1px solid var(--pn-line);
	border-radius: var(--pn-radius-md);
	box-shadow: var(--pn-shadow);
	text-align: center;
}

.pn-treatment-results__period {
	display: block;
	font-family: var(--pn-font-display);
	font-size: var(--pn-fs-h3);
	font-weight: 700;
	color: var(--pn-blue-deep);
	margin-bottom: var(--pn-space-3);
}

.pn-treatment-results__desc {
	font-size: var(--pn-fs-body);
	color: var(--pn-ink-soft);
	line-height: 1.7;
	margin: 0;
}

/* --------------------------------------------------------------------------
   11. BEFORE & AFTER SLIDER (CSS + JS clip-path)
   -------------------------------------------------------------------------- */
.pn-ba-slider {
	position: relative;
	width: 100%;
	max-width: 800px;
	margin-inline: auto;
	border-radius: var(--pn-radius-lg);
	overflow: hidden;
	user-select: none;
	touch-action: none;
	aspect-ratio: 4/3;
	box-shadow: var(--pn-shadow);
}

.pn-ba-slider__before,
.pn-ba-slider__after {
	position: absolute;
	inset: 0;
}

.pn-ba-slider__after {
	clip-path: inset(0 50% 0 0);
	transition: clip-path 0ms;
}

.pn-ba-slider__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	pointer-events: none;
	-webkit-user-drag: none;
}

.pn-ba-slider__label {
	position: absolute;
	bottom: var(--pn-space-3);
	padding: 4px 12px;
	background-color: rgba(27, 31, 42, 0.7);
	color: #fff;
	font-size: var(--pn-fs-eyebrow);
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	border-radius: var(--pn-radius-pill);
	pointer-events: none;
}

.pn-ba-slider__label--before {
	left: var(--pn-space-3);
}

.pn-ba-slider__label--after {
	right: var(--pn-space-3);
}

.pn-ba-slider__range {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	cursor: ew-resize;
	z-index: 10;
	margin: 0;
	padding: 0;
	-webkit-appearance: none;
	appearance: none;
}

.pn-ba-slider__handle {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 50%;
	width: 3px;
	background-color: #fff;
	transform: translateX(-50%);
	pointer-events: none;
	z-index: 5;
	transition: left 0ms;
}

.pn-ba-slider__handle::before,
.pn-ba-slider__handle::after {
	content: "";
	position: absolute;
	top: 50%;
	width: 40px;
	height: 40px;
	background-color: #fff;
	border-radius: 50%;
	transform: translateY(-50%) translateX(-50%);
	left: 50%;
	box-shadow: 0 2px 8px rgba(27, 31, 42, 0.3);
}

.pn-ba-slider__handle::after {
	content: "◀▶";
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 10px;
	color: var(--pn-blue-deep);
}

/* Extra gallery images */
.pn-ba-gallery {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--pn-space-3);
	margin-top: var(--pn-space-5);
	max-width: 800px;
	margin-inline: auto;
}

@media (min-width: 480px) {
	.pn-ba-gallery {
		grid-template-columns: repeat(3, 1fr);
	}
}

.pn-ba-gallery__img {
	width: 100%;
	aspect-ratio: 1;
	object-fit: cover;
	border-radius: var(--pn-radius-md);
	display: block;
}

/* --------------------------------------------------------------------------
   12. FAQ ACCORDION
   -------------------------------------------------------------------------- */
.pn-treatment-faq__container {
	max-width: 760px;
}

.pn-treatment-faq__list {
	display: flex;
	flex-direction: column;
	gap: var(--pn-space-2);
	margin-top: var(--pn-space-2);
}

.pn-treatment-faq__item {
	background-color: var(--pn-bg-white);
	border: 1px solid var(--pn-line);
	border-radius: var(--pn-radius-md);
	overflow: hidden;
	transition: box-shadow var(--pn-dur-fast) var(--pn-ease);
}

.pn-treatment-faq__item[open] {
	box-shadow: var(--pn-shadow);
}

.pn-treatment-faq__question {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--pn-space-3);
	padding: var(--pn-space-4);
	cursor: pointer;
	font-size: var(--pn-fs-body);
	font-weight: 600;
	color: var(--pn-ink-deep);
	list-style: none;
	transition: background-color var(--pn-dur-fast) var(--pn-ease);
}

.pn-treatment-faq__question::-webkit-details-marker {
	display: none;
}

.pn-treatment-faq__question:hover {
	background-color: var(--pn-bg-cream);
}

.pn-treatment-faq__question:focus-visible {
	outline: 3px solid var(--pn-blue-deep);
	outline-offset: -3px;
}

.pn-treatment-faq__chevron {
	display: inline-block;
	width: 20px;
	height: 20px;
	flex-shrink: 0;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%232E6E8E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	transition: transform var(--pn-dur-fast) var(--pn-ease);
}

details[open] .pn-treatment-faq__chevron {
	transform: rotate(180deg);
}

.pn-treatment-faq__answer {
	padding: 0 var(--pn-space-4) var(--pn-space-4);
}

.pn-treatment-faq__answer p {
	font-size: var(--pn-fs-body);
	color: var(--pn-ink-soft);
	line-height: 1.8;
	margin: 0;
}

/* --------------------------------------------------------------------------
   13. BOOKING SECTION
   -------------------------------------------------------------------------- */
.pn-treatment-booking {
	background-color: var(--pn-blue-pastel) !important; /* override section--alt specificity */
}

.pn-treatment-booking__layout {
	display: flex;
	flex-direction: column;
	gap: var(--pn-space-6);
}

@media (min-width: 768px) {
	.pn-treatment-booking__layout {
		flex-direction: row;
		align-items: flex-start;
		gap: var(--pn-space-7);
	}
}

.pn-treatment-booking__intro {
	flex: 0 0 36%;
}

.pn-treatment-booking__title {
	font-family: var(--pn-font-display);
	font-size: var(--pn-fs-h2);
	font-weight: 600;
	line-height: 1.1;
	color: var(--pn-ink-deep);
	margin: 0 0 var(--pn-space-4);
	letter-spacing: -0.02em;
}

.pn-treatment-booking__desc {
	font-size: var(--pn-fs-lead);
	color: var(--pn-ink-soft);
	line-height: 1.7;
	margin: 0;
}

.pn-treatment-booking__form {
	flex: 1;
	background-color: var(--pn-bg-white);
	border-radius: var(--pn-radius-lg);
	padding: var(--pn-space-5);
	box-shadow: var(--pn-shadow);
}

/* Form fields */
.pn-treatment-form__row {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--pn-space-4);
	margin-bottom: var(--pn-space-4);
}

@media (min-width: 480px) {
	.pn-treatment-form__row {
		grid-template-columns: 1fr 1fr;
	}
}

.pn-treatment-form__field {
	display: flex;
	flex-direction: column;
	gap: var(--pn-space-1);
	margin-bottom: var(--pn-space-4);
}

.pn-treatment-form__field:last-of-type {
	margin-bottom: 0;
}

.pn-treatment-form__row .pn-treatment-form__field {
	margin-bottom: 0;
}

.pn-treatment-form__label {
	font-size: var(--pn-fs-eyebrow);
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--pn-ink-soft);
}

.pn-treatment-form__label span {
	color: var(--pn-error, var(--pn-error));
}

.pn-treatment-form__input {
	width: 100%;
	padding: 12px var(--pn-space-3);
	border: 1px solid var(--pn-line);
	border-radius: var(--pn-radius-md);
	background-color: var(--pn-bg-cream);
	color: var(--pn-ink-deep);
	font-family: var(--pn-font-body);
	font-size: var(--pn-fs-body);
	transition:
		border-color var(--pn-dur-fast) var(--pn-ease),
		box-shadow var(--pn-dur-fast) var(--pn-ease);
	-webkit-appearance: none;
	appearance: none;
	box-sizing: border-box;
}

.pn-treatment-form__input::placeholder {
	color: var(--pn-ink-muted);
}

.pn-treatment-form__input:focus {
	outline: none;
	border-color: var(--pn-blue-deep);
	box-shadow: 0 0 0 3px rgba(46, 110, 142, 0.15);
}

.pn-treatment-form__textarea {
	resize: vertical;
	min-height: 120px;
}

.pn-treatment-form__feedback {
	min-height: 24px;
	margin-bottom: var(--pn-space-3);
	font-size: var(--pn-fs-body);
	font-weight: 500;
	border-radius: var(--pn-radius-md);
}

.pn-treatment-form__feedback--success {
	padding: var(--pn-space-3);
	background-color: #eaf4ec;
	color: var(--pn-success, var(--pn-success));
}

.pn-treatment-form__feedback--error {
	padding: var(--pn-space-3);
	background-color: #fdf0f0;
	color: var(--pn-error, var(--pn-error));
}

/* --------------------------------------------------------------------------
   14. RELATED TREATMENTS GRID
   -------------------------------------------------------------------------- */
.pn-treatment-related__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--pn-space-4);
	margin-top: var(--pn-space-2);
}

@media (min-width: 480px) {
	.pn-treatment-related__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 768px) {
	.pn-treatment-related__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.pn-treatment-related__card {
	border-radius: var(--pn-radius-md);
	background-color: var(--pn-bg-white);
	border: 1px solid var(--pn-line);
	overflow: hidden;
	box-shadow: var(--pn-shadow);
	transition:
		transform var(--pn-dur-base) var(--pn-ease),
		box-shadow var(--pn-dur-base) var(--pn-ease);
}

.pn-treatment-related__card:hover {
	transform: translateY(-4px);
	box-shadow: 0 4px 12px rgba(27, 31, 42, 0.1), 0 16px 40px rgba(27, 31, 42, 0.08);
}

.pn-treatment-related__card-link {
	display: block;
	text-decoration: none;
	color: inherit;
}

.pn-treatment-related__img-wrap {
	overflow: hidden;
	aspect-ratio: 4/3;
}

.pn-treatment-related__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform var(--pn-dur-slow) var(--pn-ease);
}

.pn-treatment-related__card:hover .pn-treatment-related__img {
	transform: scale(1.04);
}

.pn-treatment-related__card-body {
	padding: var(--pn-space-4);
}

.pn-treatment-related__card-title {
	font-family: var(--pn-font-display);
	font-size: var(--pn-fs-h3);
	font-weight: 600;
	color: var(--pn-ink-deep);
	margin: 0 0 var(--pn-space-2);
	line-height: 1.2;
}

.pn-treatment-related__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--pn-space-2);
}

.pn-treatment-related__meta-item {
	font-size: var(--pn-fs-eyebrow);
	color: var(--pn-ink-muted);
}

/* --------------------------------------------------------------------------
   15. MOBILE STICKY BOTTOM BAR
   -------------------------------------------------------------------------- */
.pn-treatment-mobile-bar {
	display: none;
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 100;
	background-color: var(--pn-bg-white);
	border-top: 1px solid var(--pn-line);
	box-shadow: 0 -4px 16px rgba(27, 31, 42, 0.08);
	padding: var(--pn-space-2) var(--pn-space-4);
	padding-bottom: max(var(--pn-space-2), env(safe-area-inset-bottom, 8px));
}

.pn-treatment-mobile-bar--visible {
	display: flex;
	align-items: center;
	gap: var(--pn-space-2);
}

.pn-treatment-mobile-bar__cta {
	flex: 3;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 14px var(--pn-space-3);
	background-color: var(--pn-blue-deep);
	color: #fff;
	border-radius: var(--pn-radius-pill);
	font-family: var(--pn-font-body);
	font-weight: 600;
	font-size: var(--pn-fs-body);
	text-decoration: none;
	transition: background-color var(--pn-dur-fast) var(--pn-ease);
}

.pn-treatment-mobile-bar__cta:hover,
.pn-treatment-mobile-bar__cta:focus-visible {
	background-color: color-mix(in srgb, var(--pn-blue-deep) 85%, #000);
	outline: none;
}

.pn-treatment-mobile-bar__phone {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 14px;
	background-color: var(--pn-bg-cream);
	color: var(--pn-ink-deep);
	border-radius: var(--pn-radius-pill);
	border: 1px solid var(--pn-line);
	text-decoration: none;
	transition: background-color var(--pn-dur-fast) var(--pn-ease);
}

.pn-treatment-mobile-bar__phone:hover,
.pn-treatment-mobile-bar__phone:focus-visible {
	background-color: var(--pn-blue-pastel);
	outline: none;
}

/* Only show mobile bar on mobile viewports */
@media (min-width: 1024px) {
	.pn-treatment-mobile-bar,
	.pn-treatment-mobile-bar--visible {
		display: none !important;
	}
}

/* --------------------------------------------------------------------------
   16. UTILITY
   -------------------------------------------------------------------------- */
.pn-treatment-placeholder {
	font-size: var(--pn-fs-body);
	color: var(--pn-ink-muted);
	font-style: italic;
	padding: var(--pn-space-5);
	border: 1px dashed var(--pn-line);
	border-radius: var(--pn-radius-md);
	text-align: center;
	margin: 0;
}

.pn-treatment-placeholder--center {
	text-align: center;
}

/* Body padding when mobile bar is visible — prevent content overlap */
body.pn-has-mobile-bar {
	padding-bottom: 80px;
}

@media (min-width: 1024px) {
	body.pn-has-mobile-bar {
		padding-bottom: 0;
	}
}
