/**
 * BABE Bali — manual page foundation (Custom HTML + Shortcode blocks).
 * Scoped to .babe-page — does not affect header, mega menu, booking, or treatment templates.
 */

.babe-page {
	--babe-black: #050505;
	--babe-charcoal: #111111;
	--babe-ink: #171717;
	--babe-soft-black: #202020;
	--babe-ivory: #f7f3ec;
	--babe-cream: #fbf8f2;
	--babe-white: #ffffff;
	--babe-silver: #c9c7c1;
	--babe-muted: #6f6b66;
	--babe-line: rgba(0, 0, 0, 0.12);
	--babe-line-dark: rgba(255, 255, 255, 0.16);
	--babe-max: min(1240px, calc(100% - 2 * clamp(1rem, 3vw, 2rem)));
	--babe-radius: 18px;
	--babe-radius-sm: 12px;
	--babe-ease: cubic-bezier(0.22, 1, 0.36, 1);
	--babe-shadow: 0 18px 48px rgba(5, 5, 5, 0.08);
	--babe-font: "Helvetica Neue", Helvetica, Arial, sans-serif;

	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0;
	overflow-x: clip;
	font-family: var(--babe-font);
	font-size: clamp(1rem, 0.35vw + 0.92rem, 1.0625rem);
	line-height: 1.65;
	color: var(--babe-ink);
	-webkit-font-smoothing: antialiased;
}

.babe-page *,
.babe-page *::before,
.babe-page *::after {
	box-sizing: border-box;
}

.babe-page img,
.babe-page video {
	display: block;
	max-width: 100%;
	height: auto;
}

.babe-page-shell {
	width: var(--babe-max);
	margin-inline: auto;
	padding-inline: clamp(1rem, 3vw, 2rem);
}

/* ---------- Hero ---------- */
.babe-page-hero {
	position: relative;
	padding: clamp(2.5rem, 6vw, 4.5rem) 0;
	background: var(--babe-cream);
	border-bottom: 1px solid var(--babe-line);
}

.babe-page-hero--dark {
	background: var(--babe-black);
	color: var(--babe-white);
	border-bottom-color: var(--babe-line-dark);
}

.babe-page-hero--image {
	padding: 0;
	min-height: clamp(280px, 42vh, 520px);
	overflow: hidden;
	border-bottom: 0;
}

.babe-page-hero__media {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.babe-page-hero__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center 42%;
}

.babe-page-hero__content {
	position: relative;
	z-index: 1;
	width: var(--babe-max);
	margin-inline: auto;
	padding: clamp(2.5rem, 6vw, 4.5rem) clamp(1rem, 3vw, 2rem);
}

.babe-page-hero--image .babe-page-hero__content {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: inherit;
}

.babe-eyebrow {
	display: inline-block;
	margin: 0 0 0.75rem;
	padding: 0.35rem 0.75rem;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--babe-muted);
	background: rgba(255, 255, 255, 0.72);
	border: 1px solid var(--babe-line);
	border-radius: 999px;
}

.babe-page-hero--dark .babe-eyebrow,
.babe-page-hero--image .babe-eyebrow {
	color: var(--babe-ivory);
	background: rgba(5, 5, 5, 0.45);
	border-color: var(--babe-line-dark);
}

.babe-display {
	margin: 0 0 0.85rem;
	font-size: clamp(2rem, 4.2vw, 3.25rem);
	font-weight: 700;
	line-height: 1.08;
	letter-spacing: -0.02em;
	color: var(--babe-black);
}

.babe-page-hero--dark .babe-display,
.babe-page-hero--image .babe-display {
	color: var(--babe-white);
}

.babe-lede {
	margin: 0;
	max-width: 42rem;
	font-size: clamp(1.05rem, 1.2vw + 0.9rem, 1.2rem);
	line-height: 1.6;
	color: var(--babe-muted);
}

.babe-page-hero--dark .babe-lede,
.babe-page-hero--image .babe-lede {
	color: rgba(255, 255, 255, 0.82);
}

/* ---------- Sections ---------- */
.babe-section {
	padding: clamp(2.25rem, 5vw, 4rem) 0;
}

.babe-section--ivory {
	background: var(--babe-ivory);
}

.babe-section--white {
	background: var(--babe-white);
}

.babe-section--dark {
	background: var(--babe-black);
	color: var(--babe-white);
}

.babe-section-head {
	margin-bottom: clamp(1.25rem, 3vw, 2rem);
	max-width: 40rem;
}

.babe-section-head .babe-display {
	font-size: clamp(1.65rem, 2.8vw, 2.35rem);
}

.babe-section--dark .babe-display,
.babe-section--dark .babe-lede {
	color: var(--babe-white);
}

.babe-section--dark .babe-lede {
	color: rgba(255, 255, 255, 0.78);
}

.babe-kicker {
	margin: 0 0 0.5rem;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--babe-muted);
}

.babe-section--dark .babe-kicker {
	color: var(--babe-silver);
}

/* ---------- Grid & cards ---------- */
.babe-grid {
	display: grid;
	gap: clamp(1rem, 2.5vw, 1.5rem);
}

.babe-grid--2 {
	grid-template-columns: 1fr;
}

.babe-grid--3 {
	grid-template-columns: 1fr;
}

@media (min-width: 768px) {
	.babe-grid--2 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.babe-grid--3 {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.babe-card {
	padding: clamp(1.15rem, 2.5vw, 1.5rem);
	background: var(--babe-white);
	border: 1px solid var(--babe-line);
	border-radius: var(--babe-radius);
	box-shadow: var(--babe-shadow);
}

.babe-card h3 {
	margin: 0 0 0.5rem;
	font-size: clamp(1.1rem, 1.5vw, 1.25rem);
	font-weight: 700;
	color: var(--babe-black);
}

.babe-card p {
	margin: 0;
	color: var(--babe-muted);
}

.babe-card--ivory {
	background: var(--babe-ivory);
}

.babe-card--dark {
	background: var(--babe-charcoal);
	border-color: var(--babe-line-dark);
	color: var(--babe-white);
}

.babe-card--dark p,
.babe-card--dark h3 {
	color: var(--babe-white);
}

.babe-split {
	display: grid;
	gap: clamp(1.25rem, 3vw, 2rem);
	align-items: center;
}

@media (min-width: 900px) {
	.babe-split {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	}
}

/* ---------- Proof / stats ---------- */
.babe-proof-row {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem 1rem;
	margin: 1.25rem 0 0;
	padding: 0;
	list-style: none;
}

.babe-proof-row li {
	position: relative;
	margin: 0;
	padding-left: 1rem;
	font-size: 0.9rem;
	color: var(--babe-muted);
}

.babe-proof-row li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.55em;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--babe-silver);
}

.babe-section--dark .babe-proof-row li,
.babe-global-cta .babe-proof-row li {
	color: rgba(255, 255, 255, 0.78);
}

.babe-mini-stat {
	padding: 1rem 1.1rem;
	background: var(--babe-cream);
	border: 1px solid var(--babe-line);
	border-radius: var(--babe-radius-sm);
}

.babe-mini-stat strong {
	display: block;
	margin-bottom: 0.25rem;
	font-size: clamp(1.35rem, 2vw, 1.65rem);
	color: var(--babe-black);
}

.babe-mini-stat span {
	font-size: 0.88rem;
	color: var(--babe-muted);
}

/* ---------- Buttons ---------- */
.babe-page .babe-button,
.babe-page a.babe-button,
.babe-global-cta .babe-button,
.babe-booking-stage .babe-button,
.babe-contact-actions .babe-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 0.85rem 1.35rem;
	font-family: inherit;
	font-size: 0.92rem;
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: 0.02em;
	text-decoration: none;
	border: 1px solid transparent;
	border-radius: 999px;
	cursor: pointer;
	transition:
		background 220ms var(--babe-ease),
		color 220ms var(--babe-ease),
		border-color 220ms var(--babe-ease),
		box-shadow 220ms var(--babe-ease),
		transform 220ms var(--babe-ease);
}

.babe-page .babe-button:focus-visible,
.babe-global-cta .babe-button:focus-visible,
.babe-booking-stage .babe-button:focus-visible,
.babe-contact-actions .babe-button:focus-visible {
	outline: 2px solid var(--babe-black);
	outline-offset: 3px;
}

.babe-button--dark,
.babe-page .babe-button--dark {
	background: var(--babe-black);
	color: var(--babe-white);
	border-color: var(--babe-black);
}

.babe-button--dark:hover,
.babe-button--dark:focus-visible {
	background: var(--babe-soft-black);
	border-color: var(--babe-soft-black);
	color: var(--babe-white);
}

.babe-button--light,
.babe-page .babe-button--light {
	background: var(--babe-white);
	color: var(--babe-black);
	border-color: var(--babe-line);
}

.babe-button--light:hover,
.babe-button--light:focus-visible {
	background: var(--babe-ivory);
}

.babe-button--ghost,
.babe-page .babe-button--ghost {
	background: transparent;
	color: var(--babe-black);
	border-color: var(--babe-line);
}

.babe-button--ghost:hover,
.babe-button--ghost:focus-visible {
	background: var(--babe-cream);
}

.babe-section--dark .babe-button--ghost {
	color: var(--babe-white);
	border-color: var(--babe-line-dark);
}

.babe-section--dark .babe-button--ghost:hover {
	background: rgba(255, 255, 255, 0.08);
}

.babe-page .babe-button + .babe-button,
.babe-global-cta__actions .babe-button + .babe-button {
	margin-left: 0.65rem;
}

.babe-global-cta__actions,
.babe-contact-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	align-items: center;
}

/* ---------- Lists & steps ---------- */
.babe-link-list {
	margin: 0;
	padding: 0;
	list-style: none;
}

.babe-link-list li + li {
	margin-top: 0.5rem;
}

.babe-link-list a {
	color: var(--babe-black);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.babe-link-list a:hover {
	color: var(--babe-soft-black);
}

.babe-steps {
	display: grid;
	gap: 1rem;
	counter-reset: babe-step;
}

.babe-step-card {
	position: relative;
	padding: 1.15rem 1.15rem 1.15rem 3.25rem;
	background: var(--babe-white);
	border: 1px solid var(--babe-line);
	border-radius: var(--babe-radius-sm);
	counter-increment: babe-step;
}

.babe-step-card::before {
	content: counter(babe-step, decimal-leading-zero);
	position: absolute;
	left: 1rem;
	top: 1.1rem;
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	color: var(--babe-muted);
}

.babe-note {
	margin: 1rem 0 0;
	padding: 0.9rem 1rem;
	font-size: 0.92rem;
	color: var(--babe-muted);
	background: var(--babe-cream);
	border-left: 3px solid var(--babe-silver);
	border-radius: 0 var(--babe-radius-sm) var(--babe-radius-sm) 0;
}

.babe-admin-note {
	margin: 1.5rem 0 0;
	padding: 0.85rem 1rem;
	font-size: 0.85rem;
	color: var(--babe-muted);
	background: var(--babe-ivory);
	border: 1px dashed var(--babe-line);
	border-radius: var(--babe-radius-sm);
}

/* ---------- FAQ ---------- */
.babe-faq {
	display: grid;
	gap: 0.65rem;
}

.babe-faq details {
	border: 1px solid var(--babe-line);
	border-radius: var(--babe-radius-sm);
	background: var(--babe-white);
	overflow: hidden;
}

.babe-faq summary {
	padding: 1rem 1.1rem;
	font-weight: 700;
	cursor: pointer;
	list-style: none;
}

.babe-faq summary::-webkit-details-marker {
	display: none;
}

.babe-faq summary:focus-visible {
	outline: 2px solid var(--babe-black);
	outline-offset: -2px;
}

.babe-faq__answer {
	padding: 0 1.1rem 1rem;
	color: var(--babe-muted);
}

/* ---------- Global CTA (shortcode) ---------- */
.babe-global-cta {
	padding: clamp(2rem, 4vw, 3rem);
	background: var(--babe-black);
	color: var(--babe-white);
	border-radius: var(--babe-radius);
	box-shadow: var(--babe-shadow);
}

.babe-global-cta .babe-display {
	color: var(--babe-white);
	font-size: clamp(1.65rem, 2.8vw, 2.2rem);
}

.babe-global-cta .babe-lede {
	color: rgba(255, 255, 255, 0.8);
	max-width: 38rem;
}

.babe-global-cta--contact {
	background: var(--babe-ivory);
	color: var(--babe-ink);
}

.babe-global-cta--contact .babe-display {
	color: var(--babe-black);
}

.babe-global-cta--contact .babe-lede {
	color: var(--babe-muted);
}

/* ---------- Legacy video CTA (global shortcode only) ---------- */
.babe-video-cta {
	margin-top: 1rem;
}

/* ---------- Contact actions ---------- */
.babe-contact-actions {
	margin-top: 1rem;
}

/* ---------- Logo shortcode ---------- */
.babe-page-logo {
	display: inline-block;
	line-height: 0;
}

.babe-page-logo img {
	width: auto;
	max-width: min(220px, 72vw);
	height: auto;
}

/* ---------- Shortcode blocks outside .babe-page wrapper ---------- */
.entry-content > .babe-global-cta,
.entry-content > .babe-booking-stage,
.entry-content > .babe-contact-actions {
	margin-block: clamp(1.5rem, 3vw, 2.5rem);
}

/* Isolate from Elementor / WP button styles when nested */
.elementor-widget-shortcode .babe-global-cta .babe-button,
.elementor-widget-shortcode .babe-booking-stage .babe-button {
	appearance: none;
}

/* ==========================================================================
   /book/ page — premium booking layout (manual HTML + shortcodes)
   ========================================================================== */

.babe-page.babe-page--book .babe-proof-row,
.babe-book-hero .babe-proof-row {
	display: none !important;
}

/* ---------- Book hero ---------- */
.babe-book-hero {
	background: var(--babe-black);
	color: var(--babe-white);
	padding: clamp(52px, 7vw, 92px) 0;
}

.babe-book-hero__inner {
	width: min(1120px, calc(100% - 32px));
	margin: 0 auto;
}

.babe-book-hero__logo img {
	display: block;
	width: clamp(150px, 17vw, 210px);
	height: auto;
	margin-bottom: clamp(28px, 4vw, 44px);
}

.babe-book-hero .babe-eyebrow {
	color: rgba(255, 255, 255, 0.66);
	border-color: rgba(255, 255, 255, 0.22);
	background: rgba(255, 255, 255, 0.06);
}

.babe-book-hero .babe-display {
	max-width: 760px;
	font-size: clamp(2.4rem, 6.2vw, 5.375rem);
	line-height: 0.96;
	letter-spacing: -0.06em;
	margin: 0 0 1.5rem;
	color: var(--babe-white);
}

.babe-book-hero .babe-lede {
	max-width: 660px;
	color: rgba(255, 255, 255, 0.74);
	font-size: clamp(1.05rem, 2vw, 1.55rem);
	line-height: 1.45;
	margin: 0;
}

.babe-book-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 1.85rem;
}

.babe-book-hero__actions .babe-button {
	min-height: 48px;
	padding: 14px 22px;
	border-radius: 999px;
	font-size: 0.9rem;
	font-weight: 700;
	letter-spacing: 0.03em;
}

.babe-book-hero__actions .babe-button--light {
	background: var(--babe-white);
	color: var(--babe-black);
	border-color: var(--babe-white);
}

.babe-book-hero__actions .babe-button--light:hover,
.babe-book-hero__actions .babe-button--light:focus-visible {
	background: var(--babe-ivory);
}

.babe-book-hero__actions .babe-button--ghost {
	color: var(--babe-white);
	border-color: rgba(255, 255, 255, 0.35);
}

.babe-book-hero__actions .babe-button--ghost:hover,
.babe-book-hero__actions .babe-button--ghost:focus-visible {
	background: rgba(255, 255, 255, 0.08);
	color: var(--babe-white);
}

/* ---------- Dark booking stage ([babe_booking_stage]) ---------- */
.babe-booking-stage,
.babe-booking-stage.babe-booking-stage--dark,
#babe-booking-stage {
	position: relative;
	width: min(1280px, calc(100% - 32px));
	margin: clamp(22px, 4vw, 44px) auto;
	overflow: hidden;
	background: var(--babe-black);
	color: var(--babe-white);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 32px;
	min-height: 680px;
	box-shadow: var(--babe-shadow);
}

.babe-booking-stage__media {
	position: absolute;
	inset: 0;
	z-index: 0;
	background: var(--babe-black);
	pointer-events: none;
}

.babe-booking-stage__media video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.babe-booking-stage::before,
.babe-booking-stage::after {
	content: none !important;
	display: none !important;
}

.babe-booking-stage__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(260px, 0.72fr) minmax(460px, 1fr);
	gap: clamp(22px, 4vw, 52px);
	align-items: start;
	padding: clamp(28px, 5vw, 64px);
}

.babe-booking-stage__intro {
	max-width: 420px;
	color: var(--babe-white);
}

.babe-booking-stage__intro .babe-kicker {
	color: rgba(255, 255, 255, 0.66);
	border-color: rgba(255, 255, 255, 0.22);
	background: rgba(255, 255, 255, 0.06);
}

.babe-booking-stage__intro h2,
.babe-booking-stage__intro .babe-display {
	margin: 0 0 14px;
	color: var(--babe-white);
	font-size: clamp(2.25rem, 4.8vw, 4.5rem);
	line-height: 0.96;
	letter-spacing: -0.055em;
}

.babe-booking-stage__intro p,
.babe-booking-stage__intro .babe-lede {
	margin: 0;
	color: rgba(255, 255, 255, 0.72);
	font-size: clamp(1rem, 1.4vw, 1.25rem);
	line-height: 1.55;
}

.babe-booking-stage__form {
	min-width: 0;
	color: var(--babe-white);
	background: rgba(5, 5, 5, 0.74);
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: 28px;
	padding: clamp(22px, 3vw, 38px);
	box-shadow: 0 28px 80px rgba(0, 0, 0, 0.42);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
}

.babe-booking-stage__form,
.babe-booking-stage__form h1,
.babe-booking-stage__form h2,
.babe-booking-stage__form h3,
.babe-booking-stage__form h4,
.babe-booking-stage__form p,
.babe-booking-stage__form label,
.babe-booking-stage__form span,
.babe-booking-stage__form li,
.babe-booking-stage__form a {
	color: var(--babe-white);
}

.babe-booking-stage__form small,
.babe-booking-stage__form .description,
.babe-booking-stage__form .babe-booking-subtext,
.babe-booking-stage__form .babe-booking-reassurance,
.babe-booking-stage__form [class*="description"],
.babe-booking-stage__form [class*="hint"],
.babe-booking-stage__form [class*="meta"] {
	color: rgba(255, 255, 255, 0.68) !important;
}

.babe-booking-stage__form .babe-theme,
.babe-booking-stage__form .babe-booking-wrap,
.babe-booking-stage__form #babe-booking {
	max-width: 100%;
	width: 100%;
	margin: 0;
	background: transparent !important;
	box-shadow: none !important;
	--babe-text: #ffffff;
	--babe-muted: rgba(255, 255, 255, 0.68);
}

.babe-booking-stage__form .babe-theme-overlay {
	display: none !important;
}

.babe-booking-stage__form .babe-booking-logo,
.babe-booking-stage__form .babe-booking-header {
	display: none;
}

.babe-booking-stage__form .babe-progress {
	margin-bottom: 1rem;
	border-color: rgba(255, 255, 255, 0.16);
}

.babe-booking-stage__form .babe-progress-step {
	color: rgba(255, 255, 255, 0.55);
}

.babe-booking-stage__form .babe-progress-step.is-active {
	color: var(--babe-white);
}

.babe-booking-stage__form .babe-step h3 {
	color: var(--babe-white);
}

.babe-booking-stage__form input:not([type="radio"]):not([type="checkbox"]),
.babe-booking-stage__form select,
.babe-booking-stage__form textarea,
.babe-booking-stage__form .babe-category-select {
	background: rgba(255, 255, 255, 0.08) !important;
	color: var(--babe-white) !important;
	border: 1px solid rgba(255, 255, 255, 0.22) !important;
	border-radius: 14px !important;
	max-width: 100%;
}

.babe-booking-stage__form input::placeholder,
.babe-booking-stage__form textarea::placeholder {
	color: rgba(255, 255, 255, 0.48) !important;
}

.babe-booking-stage__form option {
	color: var(--babe-charcoal) !important;
	background: var(--babe-white) !important;
}

.babe-booking-stage__form .babe-btn,
.babe-booking-stage__form button,
.babe-booking-stage__form input[type="button"],
.babe-booking-stage__form input[type="submit"],
.babe-booking-stage__form .button,
.babe-booking-stage__form .babe-next-btn {
	border-radius: 999px !important;
}

.babe-booking-stage__form .babe-link-button {
	color: rgba(255, 255, 255, 0.85) !important;
}

/* ---------- How it works (editorial timeline) ---------- */
.babe-book-flow {
	display: grid;
	gap: 0;
	border-top: 1px solid var(--babe-line);
	margin-top: 0;
}

.babe-section .babe-book-flow {
	margin-top: 2rem;
}

.babe-book-flow__item {
	display: grid;
	grid-template-columns: 72px minmax(0, 1fr);
	gap: 22px;
	padding: clamp(22px, 3vw, 34px) 0;
	border-bottom: 1px solid var(--babe-line);
}

.babe-book-flow__item span {
	font-size: 0.72rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: #77716a;
	font-weight: 800;
}

.babe-book-flow__item h3 {
	margin: 0 0 8px;
	font-size: clamp(1.25rem, 2.6vw, 2.1rem);
	letter-spacing: -0.035em;
	color: var(--babe-black);
}

.babe-book-flow__item p {
	margin: 0;
	max-width: 760px;
	color: #5f5a55;
	font-size: clamp(1rem, 1.4vw, 1.2rem);
	line-height: 1.55;
}

/* ---------- Patient account strip ---------- */
.babe-book-account-strip {
	background: var(--babe-black);
	color: var(--babe-white);
	padding: clamp(44px, 6vw, 76px) 0;
}

.babe-book-account-strip__box {
	width: min(1120px, calc(100% - 32px));
	margin: 0 auto;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 28px;
	padding: clamp(26px, 4vw, 48px);
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(240px, 0.8fr);
	gap: 34px;
	align-items: end;
}

.babe-book-account-strip h2 {
	margin: 0 0 14px;
	font-size: clamp(2rem, 4.6vw, 4rem);
	line-height: 1;
	letter-spacing: -0.055em;
	color: var(--babe-white);
}

.babe-book-account-strip p {
	margin: 0;
	color: rgba(255, 255, 255, 0.72);
	font-size: clamp(1rem, 1.5vw, 1.35rem);
	line-height: 1.55;
}

.babe-book-account-strip ul {
	list-style: none;
	display: grid;
	gap: 12px;
	padding: 0;
	margin: 0;
}

.babe-book-account-strip li {
	border-top: 1px solid rgba(255, 255, 255, 0.16);
	padding-top: 12px;
	color: rgba(255, 255, 255, 0.82);
	font-weight: 700;
	font-size: 0.95rem;
}

/* ---------- Book FAQ (premium accordion) ---------- */
.babe-book-faq .babe-faq,
.babe-book-faq {
	display: grid;
	gap: 12px;
}

.babe-book-faq details {
	background: var(--babe-white);
	border: 1px solid var(--babe-line);
	border-radius: 18px;
	overflow: hidden;
}

.babe-book-faq summary {
	cursor: pointer;
	list-style: none;
	padding: 22px 26px;
	font-weight: 800;
	font-size: clamp(1rem, 1.3vw, 1.35rem);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	color: var(--babe-black);
}

.babe-book-faq summary::-webkit-details-marker {
	display: none;
}

.babe-book-faq summary::after {
	content: "+";
	font-size: 24px;
	font-weight: 500;
	line-height: 1;
	color: var(--babe-muted);
	flex-shrink: 0;
}

.babe-book-faq details[open] summary::after {
	content: "–";
}

.babe-book-faq details p,
.babe-book-faq .babe-faq__answer {
	margin: 0;
	padding: 0 26px 24px;
	color: #625d57;
	font-size: clamp(1rem, 1.2vw, 1.15rem);
	line-height: 1.6;
}

.babe-book-faq summary:focus-visible {
	outline: 2px solid var(--babe-black);
	outline-offset: -2px;
}

/* ---------- Responsive ---------- */
@media (max-width: 920px) {
	.babe-booking-stage,
	.babe-booking-stage.babe-booking-stage--dark,
	#babe-booking-stage {
		width: calc(100% - 20px);
		min-height: 0;
		border-radius: 24px;
	}

	.babe-booking-stage__inner {
		grid-template-columns: 1fr;
		padding: 22px;
	}

	.babe-booking-stage__intro {
		max-width: none;
	}

	.babe-booking-stage__intro h2,
	.babe-booking-stage__intro .babe-display {
		font-size: clamp(2.125rem, 11vw, 3.375rem);
	}

	.babe-booking-stage__form {
		border-radius: 22px;
		padding: 18px;
	}

	.babe-book-account-strip__box {
		grid-template-columns: 1fr;
	}

	.babe-book-flow__item {
		grid-template-columns: 1fr;
		gap: 8px;
	}
}

@media (max-width: 480px) {
	.babe-book-hero {
		padding: 44px 0 48px;
	}

	.babe-book-hero .babe-display {
		font-size: clamp(2.35rem, 12vw, 3.35rem);
	}

	.babe-book-hero__actions {
		flex-direction: column;
	}

	.babe-book-hero__actions .babe-button {
		width: 100%;
		justify-content: center;
	}
}

@media (prefers-reduced-motion: reduce) {
	.babe-booking-stage__media video {
		display: none;
	}
}
