/**
 * Alpaca Flow Booking Widget — full-on makeover edition
 *
 * Pale cream background, paired display + body font tokens (controlled via
 * AppearanceSettings), Lucide icons in the sidebar, practitioner tags,
 * meeting-format chip, "Read more" bios, refined typography across.
 *
 * Font tokens (--afb-font-display, --afb-font-body) get set by inline
 * styles emitted from the PHP shortcode based on the site owner's choice.
 * If unset (theme inherit), we fall back to inherit.
 */

.alpaca-flow-booking-root {
	/* ── Brand tokens (scoped) ────────────────────────────────────── */
	--afb-navy:        #1A2A38;
	--afb-navy-soft:   #2A3A48;
	--afb-bg:          #FBFAF7;       /* paler cream than before */
	--afb-cream:       #FBFAF7;
	--afb-cream-soft:  #F5F3EE;
	--afb-surface:     #FFFFFF;
	--afb-accent:      #08A89A;
	--afb-accent-soft: #0A8077;
	--afb-accent-deep: #076B63;
	--afb-accent-tint: #E2F3F1;
	--afb-accent-glow: #CDE9E6;
	/* Accent as a raw "R, G, B" triplet — lets the focus ring and the
	 * background glow gradients use rgba() with the theme's accent. Must
	 * always match --afb-accent. */
	--afb-accent-rgb:  8, 168, 154;
	--afb-ink:         #1A2A38;
	--afb-ink-soft:    #404D5C;
	--afb-muted:       #6B7480;
	--afb-subtle:      #9CA3AB;
	--afb-line:        #E8E4DA;
	--afb-line-soft:   #F0EDE5;
	--afb-error:       #B3261E;
	--afb-error-bg:    #FBEAE8;

	--afb-r-sm: 6px;
	--afb-r-md: 10px;
	--afb-r-lg: 16px;

	--afb-shadow-sm: 0 1px 2px rgba(26, 42, 56, 0.04);
	--afb-shadow-md: 0 4px 16px rgba(26, 42, 56, 0.06);
	--afb-shadow-lg: 0 12px 40px rgba(26, 42, 56, 0.08);

	/* Font tokens — overridable by inline <style> from PHP. Defaults
	 * are 'inherit' so if appearance settings say "match theme" we use
	 * whatever the page's font stack is. */
	--afb-font-display: inherit;
	--afb-font-body:    inherit;

	/* Size scale (px) */
	--afb-fs-10:   10.5px;
	--afb-fs-12:   12px;
	--afb-fs-13:   13px;
	--afb-fs-14:   14px;
	--afb-fs-15:   14.5px;
	--afb-fs-17:   17px;
	--afb-fs-21:   21px;
	--afb-fs-28:   28px;
	--afb-fs-34:   34px;

	/* Motion */
	--afb-ease:     cubic-bezier(0.4, 0, 0.2, 1);
	--afb-ease-out: cubic-bezier(0.16, 1, 0.3, 1);

	--afb-focus: 0 0 0 3px rgba(var(--afb-accent-rgb), 0.25);

	font-family: var(--afb-font-body);
	color: var(--afb-ink);
	font-size: var(--afb-fs-15);
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	max-width: 1180px;
	margin: 0 auto;
	padding: 20px 20px 48px;

	background-image:
		radial-gradient(ellipse 80% 50% at 50% -10%, rgba(var(--afb-accent-rgb), 0.04), transparent),
		radial-gradient(ellipse 60% 40% at 90% 100%, rgba(var(--afb-accent-rgb), 0.03), transparent);
}

.alpaca-flow-booking-root *,
.alpaca-flow-booking-root *::before,
.alpaca-flow-booking-root *::after { box-sizing: border-box; }

/* Lucide-style inline icons — currentColor stroke so they inherit text colour */
.afb-icon {
	display: inline-block;
	flex-shrink: 0;
	vertical-align: middle;
}

/* ── Initial loading ───────────────────────────────────────────────── */

.afb-loading {
	padding: 80px 24px;
	text-align: center;
}
.afb-loading-rule {
	width: 40px;
	height: 2px;
	background: var(--afb-accent);
	margin: 0 auto 16px;
	animation: afb-pulse 1.4s ease-in-out infinite;
}
.afb-loading-text {
	font-size: var(--afb-fs-13);
	color: var(--afb-muted);
	letter-spacing: 0.04em;
}
@keyframes afb-pulse {
	0%, 100% { opacity: 0.35; transform: scaleX(1); }
	50%      { opacity: 1;    transform: scaleX(1.5); }
}

/* ── Layout shell ──────────────────────────────────────────────────── */

.afb-widget {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 40px;
	align-items: flex-start;
}
/* Full-width variant — used on the practitioner step, where there's no
   sidebar and the cards want the whole row. */
.afb-widget--full {
	grid-template-columns: 1fr;
}
.afb-main { min-width: 0; }
.afb-sidebar {
	position: sticky;
	top: 20px;
	background: var(--afb-surface);
	border: 1px solid var(--afb-line);
	border-radius: var(--afb-r-md);
	box-shadow: var(--afb-shadow-sm);
	overflow: hidden;
}

/* Sidebar header — always rendered, only acts as a toggle on mobile.
 * On desktop the chevron is hidden, the subtitle is hidden, and the
 * button is just an unstyled container around the eyebrow + title. */
.afb-sidebar-header {
	width: 100%;
	background: transparent;
	border: none;
	padding: 24px 24px 0;
	font-family: inherit;
	color: inherit;
	text-align: left;
	cursor: default;       /* desktop: not actionable */
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}
.afb-sidebar-header-text { min-width: 0; flex: 1; }
.afb-sidebar-header-sub {
	display: none;          /* hidden on desktop, visible on mobile */
	font-size: 12.5px;
	color: var(--afb-muted);
	margin-top: 4px;
}
.afb-sidebar-header-chevron {
	display: none;          /* hidden on desktop, visible on mobile */
	color: var(--afb-muted);
	transition: transform 0.25s var(--afb-ease);
}

.afb-sidebar-body {
	padding: 18px 24px 24px;
	display: block;         /* always visible on desktop */
}

/* ── Mobile (≤900px) ──
 * - Single column, sidebar appears ABOVE the main content
 * - Sidebar header becomes a tappable toggle
 * - Sidebar body collapses unless .is-expanded
 */
@media (max-width: 900px) {
	.afb-widget {
		grid-template-columns: 1fr;
		gap: 16px;
	}
	.afb-sidebar {
		position: static;
		order: -1;            /* push above .afb-main in the grid */
	}
	.afb-sidebar-header {
		cursor: pointer;
		padding: 16px 18px;
	}
	.afb-sidebar-header:hover,
	.afb-sidebar-header:focus-visible {
		background: var(--afb-cream-soft);
	}
	.afb-sidebar-header:focus-visible {
		outline: none;
		box-shadow: var(--afb-focus);
	}
	.afb-sidebar-header-sub { display: block; }
	.afb-sidebar-header-chevron { display: inline-flex; }
	.afb-sidebar.is-expanded .afb-sidebar-header-chevron {
		transform: rotate(180deg);
	}

	/* Hide the big title on mobile — eyebrow + summary line is enough */
	.afb-sidebar-header .afb-summary-title {
		font-size: 16px;
		margin-bottom: 0;
	}

	/* Collapsible body */
	.afb-sidebar-body {
		max-height: 0;
		padding-top: 0;
		padding-bottom: 0;
		overflow: hidden;
		transition: max-height 0.3s var(--afb-ease), padding 0.3s var(--afb-ease);
	}
	.afb-sidebar.is-expanded .afb-sidebar-body {
		max-height: 1200px;   /* generous ceiling; content rarely exceeds */
		padding: 8px 18px 18px;
		border-top: 1px solid var(--afb-line-soft);
	}
}

/* ── Stepper ───────────────────────────────────────────────────────── */

.afb-stepper {
	display: flex;
	align-items: center;
	gap: 0;
	margin-bottom: 32px;
	justify-content: center;
}
.afb-step-dot {
	display: flex;
	align-items: center;
	gap: 8px;
	color: var(--afb-muted);
	font-family: var(--afb-font-body);
	font-size: 12.5px;
	font-weight: 500;
	transition: color 0.4s var(--afb-ease);
}
.afb-step-dot-num {
	width: 24px; height: 24px;
	border-radius: 50%;
	background: var(--afb-surface);
	border: 1px solid var(--afb-line);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	font-weight: 600;
	transition: all 0.4s var(--afb-ease);
}
.afb-step-dot.is-active { color: var(--afb-navy); }
.afb-step-dot.is-active .afb-step-dot-num {
	background: var(--afb-accent-soft);
	color: var(--afb-cream);
	border-color: var(--afb-accent-soft);
}
.afb-step-dot.is-done .afb-step-dot-num {
	background: var(--afb-accent-tint);
	color: var(--afb-accent);
	border-color: var(--afb-accent-tint);
}
.afb-step-line {
	width: 32px;
	height: 1px;
	background: var(--afb-line);
	margin: 0 14px;
	transition: background 0.4s var(--afb-ease);
}
.afb-step-line.is-done { background: var(--afb-accent); }

@media (max-width: 600px) {
	.afb-step-dot-label { display: none; }
	.afb-step-line { width: 20px; margin: 0 8px; }
}

/* ── Step container ────────────────────────────────────────────────── */

.afb-step { animation: afb-fadeUp 0.45s var(--afb-ease-out); }
@keyframes afb-fadeUp {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ── Step header ───────────────────────────────────────────────────── */

.afb-step-header { margin-bottom: 28px; }
.afb-rule {
	display: block;
	width: 48px;
	height: 2px;
	background: var(--afb-accent);
	border: none;
	margin: 0 0 18px 0;
}
.afb-eyebrow {
	display: block;
	margin-bottom: 12px;
	font-size: var(--afb-fs-10);
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--afb-accent);
	font-family: var(--afb-font-body);
}
.afb-title {
	margin: 0;
	font-family: var(--afb-font-display);
	font-size: var(--afb-fs-34);
	font-weight: 700;
	color: var(--afb-navy);
	line-height: 1.1;
	letter-spacing: -0.025em;
}
.afb-title-em {
	color: var(--afb-accent);
	font-style: italic;
}
.afb-subtitle {
	margin: 14px 0 0;
	font-size: var(--afb-fs-15);
	color: var(--afb-ink-soft);
	max-width: 540px;
	line-height: 1.55;
	font-family: var(--afb-font-body);
}

@media (max-width: 600px) {
	.afb-title { font-size: var(--afb-fs-28); }
}

/* ── Practitioner cards (2-col grid, avatar + name + bio + tags) ────── */

.afb-pcards {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
}

@media (max-width: 600px) {
	.afb-pcards { grid-template-columns: 1fr; }
}

.afb-pcard {
	background: var(--afb-surface);
	border: 1px solid var(--afb-line);
	border-radius: var(--afb-r-md);
	padding: 20px;
	cursor: pointer;
	transition: all 0.25s var(--afb-ease);
	position: relative;
	text-align: left;
	width: 100%;
	font-family: inherit;
	color: inherit;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

/* ── Single-practitioner hero card ──────────────────────────────────
   Photo column adapts to the practitioner's chosen hero aspect; text
   always sits on the right. Landscape is the exception — a 16:9 photo
   beside text would crush the text column, so it becomes a full-width
   banner with the text stacked below. */
.afb-hero-card {
	background: var(--afb-surface);
	border: 1px solid var(--afb-line);
	border-radius: var(--afb-r-md);
	overflow: hidden;
	margin-bottom: 1.25rem;
	display: grid;
}
.afb-hero-card--square    { grid-template-columns: 220px 1fr; }
.afb-hero-card--portrait  { grid-template-columns: 260px 1fr; }
.afb-hero-card--landscape { grid-template-columns: 1fr; }

.afb-hero-photo {
	background-color: var(--afb-accent-tint);
	background-size: cover;
	background-position: center;
}
.afb-hero-card--square .afb-hero-photo    { min-height: 240px; }
.afb-hero-card--portrait .afb-hero-photo  { min-height: 340px; }
.afb-hero-card--landscape .afb-hero-photo { aspect-ratio: 16 / 9; width: 100%; }

.afb-hero-info {
	padding: 1.75rem 2rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.afb-hero-name {
	font-family: var(--afb-font-display);
	font-size: 26px;
	font-weight: 600;
	color: var(--afb-ink);
	letter-spacing: -0.01em;
	margin-bottom: 4px;
}
.afb-hero-role {
	font-size: 13px;
	color: var(--afb-muted);
	margin-bottom: 14px;
	letter-spacing: 0.02em;
}
.afb-hero-bio {
	font-size: 14.5px;
	color: var(--afb-ink-soft);
	line-height: 1.65;
	margin: 0 0 16px;
}
.afb-hero-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 14px 18px;
	padding-top: 14px;
	border-top: 1px solid var(--afb-line-soft);
	font-size: 13px;
	color: var(--afb-ink-soft);
}
.afb-hero-meta-item {
	display: flex;
	align-items: center;
	gap: 6px;
}
.afb-hero-meta-item .afb-icon { color: var(--afb-accent); }
.afb-hero-actions {
	display: flex;
	justify-content: flex-end;
}

@media (max-width: 560px) {
	.afb-hero-card--square,
	.afb-hero-card--portrait { grid-template-columns: 1fr; }
	.afb-hero-card--square .afb-hero-photo,
	.afb-hero-card--portrait .afb-hero-photo { aspect-ratio: 3 / 2; min-height: 0; }
	.afb-hero-info { padding: 1.5rem 1.5rem; }
}

.afb-pcard:hover {
	border-color: var(--afb-muted);
	transform: translateY(-1px);
	box-shadow: var(--afb-shadow-md);
}
.afb-pcard:focus-visible {
	outline: none;
	border-color: var(--afb-accent);
	box-shadow: var(--afb-focus);
}
.afb-pcard.is-selected {
	border-color: var(--afb-accent);
	background: linear-gradient(180deg, var(--afb-accent-tint) 0%, var(--afb-surface) 70%);
	box-shadow: var(--afb-shadow-md);
}
.afb-pcard.is-selected::before {
	content: '';
	position: absolute;
	top: 14px; right: 14px;
	width: 22px; height: 22px;
	border-radius: 50%;
	background: var(--afb-accent);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
	background-size: 13px;
	background-position: center;
	background-repeat: no-repeat;
}
.afb-pcard-head {
	display: flex;
	gap: 14px;
	align-items: flex-start;
}
.afb-avatar {
	width: 52px; height: 52px;
	border-radius: 50%;
	background: var(--afb-accent-tint);
	color: var(--afb-accent-deep);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 600;
	font-size: var(--afb-fs-17);
	font-family: var(--afb-font-display);
	flex-shrink: 0;
	background-size: cover;
	background-position: center;
	overflow: hidden;
}
.afb-avatar.has-photo { color: transparent; }
.afb-pcard-name {
	margin: 0;
	font-family: var(--afb-font-display);
	font-size: var(--afb-fs-17);
	font-weight: 600;
	color: var(--afb-navy);
	letter-spacing: -0.01em;
	line-height: 1.3;
}
.afb-pcard-role {
	margin-top: 2px;
	font-size: var(--afb-fs-12);
	color: var(--afb-muted);
	letter-spacing: 0.02em;
}
.afb-pcard-bio {
	font-size: 13.5px;
	color: var(--afb-ink-soft);
	line-height: 1.5;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.afb-pcard-bottom {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 10px;
	margin-top: auto;
}
.afb-tags {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}
.afb-tag {
	background: var(--afb-cream-soft);
	color: var(--afb-ink-soft);
	font-size: 11.5px;
	font-weight: 500;
	padding: 3px 9px;
	border-radius: 999px;
	letter-spacing: 0.01em;
}
.afb-pcard-profile-link {
	font-family: inherit;
	font-size: var(--afb-fs-12);
	color: var(--afb-accent-soft);
	text-decoration: none;
	cursor: pointer;
	padding: 4px 0;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	white-space: nowrap;
	transition: color 0.15s var(--afb-ease);
}
/* Armoured against host themes that set a global `a { color }` — the
   doubled root class + :link/:visited/:hover keeps the widget accent. */
.alpaca-flow-booking-root.alpaca-flow-booking-root a.afb-pcard-profile-link,
.alpaca-flow-booking-root.alpaca-flow-booking-root a.afb-pcard-profile-link:link,
.alpaca-flow-booking-root.alpaca-flow-booking-root a.afb-pcard-profile-link:visited {
	color: var(--afb-accent-soft);
}
.alpaca-flow-booking-root.alpaca-flow-booking-root a.afb-pcard-profile-link:hover {
	color: var(--afb-accent-deep);
}

/* "Selected" confirmation line below practitioner cards */
.afb-pcards-foot {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	margin-top: 24px;
}
.afb-selected-line {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: var(--afb-fs-13);
	color: var(--afb-muted);
}
.afb-selected-line.is-active {
	color: var(--afb-accent);
}

/* ── Service cards ──────────────────────────────────────────────────── */

.afb-scards {
	display: grid;
	gap: 12px;
}
.afb-scard {
	background: var(--afb-surface);
	border: 1px solid var(--afb-line);
	border-radius: var(--afb-r-md);
	padding: 20px 22px;
	cursor: pointer;
	transition: all 0.2s var(--afb-ease);
	text-align: left;
	width: 100%;
	font-family: inherit;
	color: inherit;
	display: flex;
	align-items: flex-start;
	gap: 16px;
}
.afb-scard:hover {
	border-color: var(--afb-muted);
	transform: translateY(-1px);
	box-shadow: var(--afb-shadow-sm);
}
.afb-scard:focus-visible {
	outline: none;
	border-color: var(--afb-accent);
	box-shadow: var(--afb-focus);
}
.afb-scard-body { flex: 1; min-width: 0; }
.afb-scard-name {
	margin: 0;
	font-family: var(--afb-font-display);
	font-size: var(--afb-fs-17);
	font-weight: 600;
	color: var(--afb-navy);
	letter-spacing: -0.01em;
	line-height: 1.3;
}
.afb-scard-meta {
	margin-top: 4px;
	font-size: var(--afb-fs-13);
	color: var(--afb-muted);
}
.afb-scard-desc {
	margin-top: 10px;
	font-size: var(--afb-fs-13);
	color: var(--afb-ink-soft);
	line-height: 1.5;
}
.afb-scard-price {
	flex-shrink: 0;
	text-align: right;
}
.afb-scard-price-main {
	font-family: var(--afb-font-display);
	font-size: var(--afb-fs-21);
	font-weight: 600;
	color: var(--afb-navy);
	letter-spacing: -0.01em;
}
.afb-scard-price-meta {
	font-size: var(--afb-fs-12);
	color: var(--afb-muted);
	margin-top: 2px;
}

/* ── When-step layout ──────────────────────────────────────────────── */

.afb-when-grid {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 14px;
}

@media (max-width: 720px) {
	.afb-when-grid { grid-template-columns: 1fr; }
}

.afb-calendar,
.afb-slots-section {
	background: var(--afb-surface);
	border: 1px solid var(--afb-line);
	border-radius: var(--afb-r-md);
	padding: 20px;
	box-shadow: var(--afb-shadow-sm);
}

.afb-cal-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 16px;
}
/* Slots header stacks — the day name on its own line, the timezone
   quietly beneath it (rather than crammed alongside a wrapping date). */
.afb-slots-head {
	margin-bottom: 16px;
}
.afb-cal-month, .afb-slots-day {
	font-family: var(--afb-font-display);
	font-size: var(--afb-fs-17);
	font-weight: 600;
	color: var(--afb-navy);
	letter-spacing: -0.01em;
}
.afb-slots-day { line-height: 1.25; }
.afb-cal-nav { display: flex; gap: 4px; }
.afb-cal-nav-btn {
	width: 30px; height: 30px;
	border: 1px solid var(--afb-line);
	background: var(--afb-surface);
	border-radius: var(--afb-r-sm);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--afb-muted);
	transition: all 0.2s var(--afb-ease);
	font-family: inherit;
}
.afb-cal-nav-btn:hover:not(:disabled) {
	border-color: var(--afb-accent);
	color: var(--afb-accent);
}
.afb-cal-nav-btn:disabled { opacity: 0.35; cursor: not-allowed; }

.afb-cal-dow-row {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 2px;
	margin-bottom: 4px;
}
.afb-cal-dow {
	text-align: center;
	font-size: 10px;
	color: var(--afb-muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding: 6px 0;
	font-weight: 600;
	font-family: var(--afb-font-body);
}

.afb-cal-grid {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 2px;
}
.afb-cal-day {
	aspect-ratio: 1;
	background: transparent;
	border: 1px solid transparent;
	border-radius: var(--afb-r-sm);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--afb-font-body);
	font-size: 13px;
	font-weight: 500;
	color: var(--afb-ink);
	cursor: pointer;
	transition: all 0.15s var(--afb-ease);
	position: relative;
}
.afb-cal-day:hover:not(:disabled) { background: var(--afb-cream-soft); }
.afb-cal-day.is-today { font-weight: 700; }
.afb-cal-day.is-today:not(.is-selected) { color: var(--afb-accent); }
.afb-cal-day.is-available::after {
	content: '';
	position: absolute;
	bottom: 4px;
	width: 4px; height: 4px;
	border-radius: 50%;
	background: var(--afb-accent);
}
.afb-cal-day.is-selected {
	background: var(--afb-accent-soft);
	color: var(--afb-cream);
	border-color: var(--afb-accent-soft);
}
.afb-cal-day.is-selected::after { background: var(--afb-cream); }
.afb-cal-day:disabled, .afb-cal-day.is-unavailable {
	color: var(--afb-line);
	cursor: not-allowed;
	background: transparent;
}

.afb-slots-tz {
	display: block;
	margin-top: 3px;
	font-size: var(--afb-fs-12);
	color: var(--afb-muted);
}
.afb-slots-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 6px;
}
.afb-slot {
	padding: 10px 8px;
	border: 1px solid var(--afb-line);
	background: var(--afb-surface);
	border-radius: var(--afb-r-sm);
	font-family: var(--afb-font-body);
	font-size: 13.5px;
	font-weight: 500;
	cursor: pointer;
	color: var(--afb-ink);
	text-align: center;
	transition: all 0.15s var(--afb-ease);
}
.afb-slot:hover {
	border-color: var(--afb-accent);
	color: var(--afb-accent);
}
.afb-slot.is-selected {
	background: var(--afb-accent-soft);
	border-color: var(--afb-accent-soft);
	color: var(--afb-cream);
}
.afb-slots-empty {
	padding: 28px 16px;
	text-align: center;
	color: var(--afb-muted);
	font-style: italic;
	font-size: var(--afb-fs-13);
	background: var(--afb-cream-soft);
	border-radius: var(--afb-r-sm);
}
.afb-slots-placeholder {
	padding: 60px 16px;
	text-align: center;
	color: var(--afb-muted);
	font-size: var(--afb-fs-13);
}

/* Meeting format chip (shown above calendar on When step) */
.afb-meeting-chip {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
	padding: 14px 16px;
	background: var(--afb-cream-soft);
	border: 1px solid var(--afb-line-soft);
	border-radius: var(--afb-r-md);
	color: var(--afb-ink-soft);
	font-size: var(--afb-fs-13);
}
.afb-meeting-chip-icon {
	display: inline-flex;
	color: var(--afb-accent);
}
.afb-meeting-chip strong {
	color: var(--afb-navy);
	font-weight: 600;
}

/* ── Form ───────────────────────────────────────────────────────────── */

.afb-form { display: grid; gap: 18px; max-width: 560px; }
.afb-field { display: block; }
.afb-label {
	display: block;
	margin-bottom: 8px;
	font-size: var(--afb-fs-13);
	font-weight: 500;
	color: var(--afb-ink);
}
.afb-label-required::after {
	content: ' *';
	color: var(--afb-accent);
}
.afb-input, .afb-textarea {
	width: 100%;
	padding: 12px 14px;
	font-family: inherit;
	font-size: var(--afb-fs-15);
	color: var(--afb-ink);
	background: var(--afb-surface);
	border: 1px solid var(--afb-line);
	border-radius: var(--afb-r-sm);
	line-height: 1.4;
	transition: all 0.15s var(--afb-ease);
}
.afb-input:focus, .afb-textarea:focus {
	outline: none;
	border-color: var(--afb-accent);
	box-shadow: var(--afb-focus);
}
.afb-textarea { min-height: 100px; resize: vertical; }
.afb-help {
	margin: 6px 0 0;
	font-size: var(--afb-fs-12);
	color: var(--afb-muted);
	font-style: italic;
}
.afb-field-error {
	margin: 6px 0 0;
	font-size: var(--afb-fs-12);
	color: var(--afb-error);
}

/* ── Actions ───────────────────────────────────────────────────────── */

.afb-actions {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	margin-top: 28px;
	padding-top: 20px;
	border-top: 1px solid var(--afb-line-soft);
}

/* Sticky action bar — date/time step. Pinned to the viewport bottom so
   Continue is reachable from anywhere in a long slot list. position:sticky
   keeps it inside the widget's flow (it won't sit over a site footer once
   scrolled past the widget). */
.afb-sticky-bar {
	position: sticky;
	bottom: 0;
	z-index: 20;
	margin: 20px -20px 0;       /* bleed to the widget's edges */
	padding: 0 20px;
	pointer-events: none;        /* inner element re-enables — lets edge gutters click through */
}
.afb-sticky-bar-inner {
	pointer-events: auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 12px 16px;
	background: var(--afb-surface);
	border: 1px solid var(--afb-line);
	border-radius: var(--afb-r-md);
	box-shadow: var(--afb-shadow-lg);
}
.afb-sticky-bar-info {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: var(--afb-fs-15);
	color: var(--afb-ink);
	min-width: 0;
}
.afb-sticky-bar-check {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 26px;
	height: 26px;
	flex: 0 0 26px;
	border-radius: 50%;
	background: var(--afb-accent-tint);
	color: var(--afb-accent-soft);
}
.afb-sticky-bar-sub {
	color: var(--afb-muted);
	font-weight: 400;
}
@media (max-width: 560px) {
	.afb-sticky-bar-inner { padding: 10px 12px; gap: 10px; }
	.afb-sticky-bar-sub { display: none; }   /* keep the bar compact on phones */
}

.afb-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 11px 22px;
	font-family: inherit;
	font-size: var(--afb-fs-15);
	font-weight: 500;
	line-height: 1.4;
	color: var(--afb-navy);
	background: var(--afb-surface);
	border: 1px solid var(--afb-line);
	border-radius: var(--afb-r-sm);
	cursor: pointer;
	text-decoration: none;
	transition: all 0.15s var(--afb-ease);
}
.afb-btn:hover {
	background: var(--afb-cream-soft);
	border-color: var(--afb-muted);
}
.afb-btn:focus-visible {
	outline: none;
	box-shadow: var(--afb-focus);
}
.afb-btn-primary {
	background: var(--afb-accent-soft);
	border-color: var(--afb-accent-soft);
	color: var(--afb-cream);
	font-weight: 600;
}
.afb-btn-primary:hover {
	background: var(--afb-accent-deep);
	border-color: var(--afb-accent-deep);
	color: var(--afb-cream);
}
.alpaca-flow-booking-root.alpaca-flow-booking-root a.afb-btn-primary,
.alpaca-flow-booking-root.alpaca-flow-booking-root a.afb-btn-primary:hover,
.alpaca-flow-booking-root.alpaca-flow-booking-root a.afb-btn-primary:visited {
	color: var(--afb-cream);
	text-decoration: none;
}
.afb-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.afb-btn-back {
	background: transparent;
	border: none;
	padding: 8px 0;
	color: var(--afb-muted);
	font-size: var(--afb-fs-13);
	cursor: pointer;
	font-family: inherit;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	transition: color 0.15s var(--afb-ease);
}
.afb-btn-back:hover { color: var(--afb-navy); }
.afb-btn-back:disabled { opacity: 0.5; cursor: not-allowed; }

/* ── Sidebar ───────────────────────────────────────────────────────── */

.afb-summary-eyebrow {
	font-size: var(--afb-fs-10);
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--afb-accent);
	margin-bottom: 6px;
	font-family: var(--afb-font-body);
}
.afb-summary-title {
	margin: 0 0 18px;
	font-family: var(--afb-font-display);
	font-size: var(--afb-fs-21);
	font-weight: 600;
	color: var(--afb-navy);
	letter-spacing: -0.015em;
}
.afb-summary-row {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	padding: 14px 0;
	border-top: 1px solid var(--afb-line-soft);
}
.afb-summary-row:first-of-type { border-top: none; padding-top: 0; }
.afb-summary-row-icon {
	color: var(--afb-muted);
	flex-shrink: 0;
	padding-top: 2px;
}
.afb-summary-row-body { flex: 1; min-width: 0; }
.afb-summary-label {
	font-size: var(--afb-fs-10);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--afb-muted);
	margin-bottom: 6px;
	font-family: var(--afb-font-body);
}
.afb-summary-value {
	font-size: var(--afb-fs-15);
	color: var(--afb-navy);
	font-weight: 500;
	font-family: var(--afb-font-body);
}
.afb-summary-value-sub {
	font-size: var(--afb-fs-12);
	color: var(--afb-muted);
	margin-top: 3px;
	font-weight: 400;
}
.afb-summary-empty {
	font-size: var(--afb-fs-12);
	color: var(--afb-subtle);
	font-style: italic;
	padding: 4px 0;
}

/* Breakdown rows at the bottom of the sidebar */
.afb-summary-breakdown {
	margin-top: 18px;
	padding: 16px 0 0;
	border-top: 1px solid var(--afb-line);
}
.afb-summary-line {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: 6px 0;
	font-size: var(--afb-fs-13);
	color: var(--afb-ink-soft);
}
.afb-summary-line-meta {
	font-size: 11.5px;
	color: var(--afb-muted);
	margin-left: 4px;
}
.afb-summary-total {
	padding: 14px 0 0;
	margin-top: 8px;
	border-top: 1px solid var(--afb-line);
	display: flex;
	justify-content: space-between;
	align-items: baseline;
}
.afb-summary-total-label {
	font-size: var(--afb-fs-13);
	font-weight: 500;
	color: var(--afb-navy);
}
.afb-summary-total-value {
	font-family: var(--afb-font-display);
	font-size: var(--afb-fs-21);
	font-weight: 700;
	color: var(--afb-navy);
	letter-spacing: -0.015em;
}

/* ── Success ───────────────────────────────────────────────────────── */

.afb-success {
	text-align: center;
	padding: 60px 24px;
}
.afb-success-rule {
	width: 48px;
	height: 2px;
	background: var(--afb-accent);
	margin: 0 auto 20px;
}
.afb-success-eyebrow {
	font-size: var(--afb-fs-10);
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--afb-accent);
	margin-bottom: 14px;
	font-family: var(--afb-font-body);
}
.afb-success-title {
	margin: 0 0 20px;
	font-family: var(--afb-font-display);
	font-size: var(--afb-fs-34);
	font-weight: 700;
	color: var(--afb-navy);
	letter-spacing: -0.025em;
	line-height: 1.1;
}
.afb-success-body { max-width: 480px; margin: 0 auto; color: var(--afb-ink-soft); }
.afb-success-body p { margin: 0 0 14px; font-size: var(--afb-fs-15); line-height: 1.6; }
.afb-success-home {
	display: inline-flex;
	margin-top: 18px;
	text-decoration: none;
}
.afb-success-summary {
	max-width: 440px;
	margin: 28px auto;
	padding: 24px;
	background: var(--afb-surface);
	border: 1px solid var(--afb-line);
	border-radius: var(--afb-r-md);
	text-align: left;
	box-shadow: var(--afb-shadow-sm);
}

/* ── Error banner ─────────────────────────────────────────────────── */

.afb-error-banner {
	margin-bottom: 20px;
	padding: 14px 18px;
	background: var(--afb-error-bg);
	border: 1px solid var(--afb-error);
	border-radius: var(--afb-r-sm);
	color: var(--afb-error);
	font-size: var(--afb-fs-13);
}

/* ── Spinner ──────────────────────────────────────────────────────── */

.afb-spinner {
	display: inline-block;
	width: 14px;
	height: 14px;
	border: 2px solid currentColor;
	border-right-color: transparent;
	border-radius: 50%;
	animation: afb-spin 0.7s linear infinite;
	vertical-align: middle;
}
@keyframes afb-spin {
	to { transform: rotate(360deg); }
}

/* ── High-specificity font overrides ─────────────────────────────────
 *
 * Themes and page builders (looking at you, Breakdance) often set
 * font-family directly on heading elements and form controls with
 * selectors that beat ours via specificity. The doubled class
 * .alpaca-flow-booking-root.alpaca-flow-booking-root gives every
 * descendant rule double-class specificity (0,2,0) which beats just
 * about every realistic theme rule without resorting to !important.
 */

.alpaca-flow-booking-root.alpaca-flow-booking-root,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-eyebrow,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-subtitle,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-cal-dow,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-cal-day,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-slot,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-pcard-bio,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-tag,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-scard-meta,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-scard-desc,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-scard-price-meta,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-meeting-chip,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-pcard-role,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-summary-eyebrow,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-summary-label,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-summary-value,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-summary-value-sub,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-summary-empty,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-summary-line,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-summary-total-label,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-step-dot,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-step-dot-num,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-input,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-textarea,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-label,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-help,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-btn,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-btn-back,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-cal-nav-btn,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-pcard-profile-link,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-selected-line {
	font-family: var(--afb-font-body);
}

.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-title,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-pcard-name,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-scard-name,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-scard-price-main,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-cal-month,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-slots-day,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-summary-title,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-summary-total-value,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-success-title,
.alpaca-flow-booking-root.alpaca-flow-booking-root .afb-avatar {
	font-family: var(--afb-font-display);
}
