/* ================================================================
   Party Booker — Custom Styles
   Brand: Get Air  |  Green #58B948  |  Gold #FFEA00
================================================================ */

:root {
	--green:      #58B948;
	--green-dark: #62BB51;
	--green-text: #2D7A1E; /* darker green for text on white — WCAG AA compliant */
	--green-btn:  #3A8F2C; /* darker green for black-text buttons — WCAG AA 5.2:1 */
	--gold:       #FFEA00;
	--bg:         #F9FAFB;
	--black:      #2A2D34;
	--muted:      #5B6370; /* darkened from #6B7280 for WCAG AA contrast on light backgrounds */
	--border:     #CBD2DA;
	--card-bg:    #FFFFFF;

	/* Shadows */
	--shadow-xs:    0 1px 2px rgba(0,0,0,.05);
	--shadow-sm:    0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
	--shadow-md:    0 4px 8px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);
	--shadow-lg:    0 10px 20px rgba(0,0,0,.08), 0 4px 8px rgba(0,0,0,.04);
	--shadow-xl:    0 20px 30px rgba(0,0,0,.10), 0 8px 12px rgba(0,0,0,.05);
	--shadow-green: 0 4px 12px rgba(88,185,72,.35);
	--shadow-green-lg: 0 8px 20px rgba(88,185,72,.42);

	/* Border radius */
	--r-sm:   6px;
	--r-md:   8px;
	--r-lg:   12px;
	--r-xl:   16px;
	--r-full: 99px;

	/* Easing */
	--ease:        cubic-bezier(0.4, 0.0, 0.2, 1);
	--ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
	--ease-out:    cubic-bezier(0.0, 0.0, 0.2, 1);
}

@font-face {
	font-family: 'Komika Axis';
	src: url('/fonts/komika-axis.ttf');
	font-display: swap;
}

.bi-spin { animation: bi-spin 1s linear infinite; display: inline-block; }
@keyframes bi-spin { to { transform: rotate(360deg); } }

* { box-sizing: border-box; }
html { touch-action: manipulation; overflow-x: hidden; }

/* ── Field validation ─────────────────────────────────────── */
.field-wrap { margin-bottom: 10px; }
.field-error {
	display: none;
	font-size: 12px;
	color: #DC2626;
	margin-top: 4px;
	padding-left: 2px;
}
.field-error.visible { display: block; }
.form-input.input-error { border-color: #EF4444; }
.form-input.input-error:focus { box-shadow: 0 0 0 2px rgba(239,68,68,.2); }
.field-error-global {
	display: none;
	background: #FEF2F2;
	border: 1px solid #FECACA;
	border-radius: 8px;
	padding: 10px 14px;
	font-size: 13px;
	color: #DC2626;
	margin-bottom: 12px;
}
.field-error-global.visible { display: block; }

/* ── Loading spinner ─────────────────────────────────────── */
.loading-spinner {
	text-align: center;
	padding: 40px 16px;
	color: var(--muted);
	font-size: 14px;
	font-weight: 500;
}
.loading-spinner .bi-arrow-repeat {
	font-size: 18px;
	margin-right: 6px;
}

body {
	background: #fff;
	color: var(--black);
	font-family: 'Geist', -apple-system, 'Helvetica Neue', Arial, sans-serif;
	margin: 0;
	padding-bottom: 100px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* ── Header ──────────────────────────────────────────────── */
#booking-header {
	position: sticky;
	top: 0;
	z-index: 200;
}

/* Dark brand bar — matches Manage portalHeader */
.header-brand {
	background: #111827;
	color: #fff;
	padding: 0.6rem 1rem;
	box-shadow: 0 1px 3px rgba(0,0,0,.1);
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.header-brand-left {
	display: flex;
	align-items: center;
	gap: 8px;
}
.header-brand-right {
	display: flex;
	align-items: center;
	gap: 10px;
}
.header-logo {
	height: 30px;
	width: auto;
}
.header-brand-title {
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -0.01em;
}
.header-brand-subtitle {
	font-size: 0.75rem;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	opacity: 0.8;
	font-weight: 500;
}
.header-location {
	font-size: 0.8rem;
	font-weight: 500;
	color: rgba(255,255,255,.7);
	white-space: nowrap;
	text-decoration: none;
	cursor: pointer;
}
.header-location:hover { color: #fff; }

/* White progress strip below the dark bar */
.header-progress-wrap {
	background: #fff;
	padding: 8px 16px 10px;
	box-shadow: var(--shadow-sm);
}
.header-progress-inner {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	max-width: 640px;
	margin: 0 auto 6px;
	min-height: 44px;
}
.header-back {
	position: absolute;
	left: 0;
	background: none; border: none; cursor: pointer;
	display: flex; align-items: center; gap: 4px;
	color: var(--muted); font-size: 14px; font-weight: 500;
	padding: 8px 4px;
	min-height: 44px;
}
.header-back:hover { color: var(--black); }
#step-announcer {
	text-align: center;
}
.header-title {
	font-size: 14px;
	font-weight: 700;
	color: var(--black);
	letter-spacing: -0.2px;
	white-space: nowrap;
}
.header-step-count {
	font-size: 12px;
	color: var(--muted);
}

/* ── Coupon banner ────────────────────────────────────────── */
#coupon-banner {
	background: #111827;
	color: #fff;
	font-size: 13px;
	font-weight: 600;
	text-align: center;
	padding: 8px 16px;
}

/* ── BONUS5 constraint warning ────────────────────────────── */
.bonus5-warn {
	background: #FEF3C7;
	color: #92400E;
	border: 1px solid #FCD34D;
	border-radius: 6px;
	padding: 8px 12px;
	margin-top: 10px;
	font-size: 13px;
	display: flex;
	align-items: center;
	gap: 8px;
}
.bonus5-warn i { color: #D97706; flex-shrink: 0; }

/* ── Progress bar ─────────────────────────────────────────── */
.progress-track {
	height: 6px;
	background: #E5E7EB;
	border-radius: 99px;
	overflow: hidden;
	max-width: 640px;
	margin: 0 auto;
}
.progress-fill {
	height: 100%;
	border-radius: 99px;
	background: var(--green);
	transition: width .4s var(--ease);
	will-change: width;
}

/* ── Page layout ─────────────────────────────────────────── */
#booking-layout {
	display: block;
}
.booking-wrap {
	max-width: 640px;
	margin: 0 auto;
	padding: 24px 16px;
}

/* ── Cart visibility — driven by body.cart-open ──────────── */

/* Mobile: full-screen modal overlay */
body.cart-open                    { overflow: hidden; }
body.cart-open #cart-drawer       { display: block; }

/* Desktop: fixed sidebar to the right of content, sized to content */
@media (min-width: 1280px) {
	body.cart-open                { overflow: auto; }
	body.cart-open #cart-drawer {
		display: block;
		position: fixed;
		inset: auto;  /* reset the base inset:0 */
		top: 140px;   /* below sticky header + breathing room */
		right: max(16px, calc((100vw - 640px) / 2 - 376px));
		width: 340px;
		z-index: 10;
	}
	body.cart-open #cart-drawer .cart-backdrop { display: none; }
	body.cart-open #cart-drawer .cart-panel {
		position: static;
		transform: none;
		width: 100%;
		max-width: none;
		height: auto;
		max-height: calc(100vh - 220px);
		overflow-y: auto;
		box-shadow: var(--shadow-lg);
	}
	body.cart-open #cart-drawer .cart-panel-close { display: none; }
}

/* ── Step show/hide ──────────────────────────────────────── */
.booking-step { display: none; }

/* ── Screen headers ──────────────────────────────────────── */
.screen-header { text-align: center; margin-bottom: 24px; }
.screen-title  { font-size: 28px; font-weight: 800; color: var(--black); margin: 0 0 6px; letter-spacing: -0.5px; }
.screen-sub    { font-size: 14px; color: var(--muted); margin: 0; font-weight: 500; }

/* ── Cards ───────────────────────────────────────────────── */
.b-card {
	background: var(--card-bg);
	border: 1px solid var(--border);
	border-radius: 16px;
	padding: 20px;
	margin-bottom: 16px;
	box-shadow: var(--shadow-xs);
}
.b-card-gray {
	background: #F3F4F6;
	border: none;
	border-radius: 12px;
	padding: 14px 16px;
	margin-bottom: 16px;
}

/* ── Calendar (inline jQuery UI) ────────────────────────── */
#datepicker-inline { width: 100%; }
.ui-datepicker                            { width: 100% !important; border: none !important; box-shadow: none !important; font-size: 15px; background: transparent !important; }
.ui-datepicker-header                     { background: transparent !important; border: none !important; color: var(--black) !important; font-weight: 700; padding: 6px 0 10px; }
.ui-datepicker-prev, .ui-datepicker-next  { cursor: pointer; top: 6px !important; }
.ui-datepicker td                         { padding: 2px; }
.ui-datepicker td a, .ui-datepicker td span { text-align: center; padding: 7px; border-radius: 8px !important; display: block; font-size: 14px; }
.ui-state-active,
.ui-widget-content .ui-state-active       { background: var(--black) !important; border-color: var(--black) !important; color: #fff !important; border-radius: 8px !important; }
/* Today (when not selected): render like any other inactive day. jQuery UI adds
   both ui-datepicker-today and ui-state-highlight to this cell — match the
   ui-state-default styling so today is indistinguishable from unselected days. */
.ui-datepicker td.ui-datepicker-today a,
.ui-datepicker td.ui-datepicker-today a.ui-state-highlight,
.ui-widget-content .ui-state-highlight { background: #e6e6e6 url("/styles/images/ui-bg_glass_75_e6e6e6_1x400.png") 50% 50% repeat-x !important; border: 1px solid #d3d3d3 !important; color: #555555 !important; border-radius: 8px !important; }
.ui-datepicker td.ui-datepicker-today a.ui-state-active { background: var(--black) !important; color: #fff !important; border-color: var(--black) !important; }
.ui-datepicker td.cal-blackout span                              { color: #9CA3AF !important; text-decoration: line-through; opacity: 1 !important; }
.ui-datepicker td.cal-unavailable.ui-datepicker-unselectable span { color: #6B7280 !important; opacity: 1 !important; cursor: default; background: transparent !important; text-decoration: line-through; }
.ui-datepicker-calendar th                { font-size: 12px; color: var(--muted); font-weight: 500; padding-bottom: 6px; }
.ui-widget-content                        { background: transparent !important; }

/* ── Time slots ──────────────────────────────────────────── */
.slot-btn {
	width: 100%;
	border: 2px solid var(--border);
	border-radius: 12px;
	padding: 14px 16px;
	margin-bottom: 10px;
	cursor: pointer;
	transition: border-color .2s var(--ease), box-shadow .2s var(--ease), transform .15s var(--ease);
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: space-between;
	text-align: left;
}
.slot-btn:hover:not(.slot-unavailable):not(.selected) { border-color: #D1D5DB; box-shadow: var(--shadow-sm); }
.slot-btn.selected, .slot-btn.selected:hover          { box-shadow: 0 0 0 2px var(--green), var(--shadow-sm); border-color: var(--green); }
.slot-btn .slot-selected-check                        { color: var(--green-text); }
.space-card .space-selected-check                     { color: var(--green-text); margin-left: 6px; font-size: 15px; vertical-align: middle; }
.slot-btn.slot-nonstandard                 { border-style: dashed; opacity: 0.75; }
.slot-btn.slot-nonstandard:hover           { opacity: 1; }
.slot-btn.slot-nonstandard.selected        { opacity: 1; border-style: solid; }
.slot-btn.slot-toddler                     { background: #F3F4F6; border-color: #D1D5DB; }
.slot-btn.slot-club                        { background: #111827; border-color: #374151; }
.slot-btn.slot-club .slot-time-text        { color: #fff; }
.slot-btn.slot-club .slot-tag              { color: #9CA3AF; }
.slot-btn.slot-club .slot-space-badge      { background: #374151; color: #E5E7EB; }
.slot-left { display: flex; align-items: center; gap: 10px; }
.slot-icon { color: var(--muted); font-size: 16px; flex-shrink: 0; }
.slot-btn.slot-club .slot-icon { color: #9CA3AF; }
.slot-time-text { font-weight: 600; font-size: 15px; color: var(--black); }
.slot-tag       { font-size: 12px; color: var(--muted); margin-left: 6px; }
.slot-spaces    { display: flex; gap: 4px; flex-wrap: wrap; }
.slot-space-badge { font-size: 11px; padding: 2px 7px; border-radius: 4px; background: #F3F4F6; color: var(--muted); }

/* ── Counter ─────────────────────────────────────────────── */
.counter-pill {
	display: inline-flex;
	align-items: center;
	gap: 16px;
	background: #fff;
	border: 1px solid var(--border);
	box-shadow: 0 1px 3px rgba(0,0,0,.06);
	border-radius: 99px;
	padding: 6px 10px;
}
.counter-pill.small { gap: 10px; padding: 4px 8px; }
.counter-btn-minus {
	width: 44px; height: 44px; border-radius: 50%; border: none;
	background: #F3F4F6; color: var(--muted); cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	transition: background .15s var(--ease), color .15s var(--ease), transform .15s var(--ease-spring);
	font-size: 20px; font-weight: 700; line-height: 1;
}
.counter-pill.small .counter-btn-minus { width: 44px; height: 44px; font-size: 16px; }
.counter-btn-minus:hover:not(:disabled)  { background: #E5E7EB; color: #6B7280; transform: scale(1.08); }
.counter-btn-minus:active:not(:disabled) { transform: scale(0.92); }
.counter-btn-minus:disabled { opacity: 0.4; cursor: not-allowed; }
.counter-btn-plus {
	width: 44px; height: 44px; border-radius: 50%; border: none;
	background: var(--black); color: #fff; cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	transition: background .15s var(--ease), transform .15s var(--ease-spring), box-shadow .15s var(--ease);
	font-size: 20px; font-weight: 700; line-height: 1;
	box-shadow: 0 2px 6px rgba(0,0,0,.2);
}
.counter-pill.small .counter-btn-plus { width: 44px; height: 44px; font-size: 16px; }
.counter-btn-plus:hover:not(:disabled)  { background: #374151; transform: scale(1.08); box-shadow: 0 4px 10px rgba(0,0,0,.25); }
.counter-btn-plus:active:not(:disabled) { transform: scale(0.92); }
.counter-btn-plus:disabled  { opacity: 0.4; cursor: not-allowed; background: #9CA3AF; box-shadow: none; }
.counter-val {
	font-size: 26px; font-weight: 800; color: var(--black);
	min-width: 3ch; text-align: center; letter-spacing: -0.5px;
	font-variant-numeric: tabular-nums;
}
.counter-pill.small .counter-val { font-size: 20px; }

/* Typed qty input inside counter pill — matches span styling */
input.counter-val {
	border: none;
	background: transparent;
	outline: none;
	width: 3.5ch;
	padding: 0;
	-moz-appearance: textfield;
	appearance: textfield;
}
input.counter-val::-webkit-outer-spin-button,
input.counter-val::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}
input.counter-val:focus {
	background: #F3F4F6;
	border-radius: 4px;
}
input.counter-val:focus-visible {
	outline: 2px solid var(--green);
	outline-offset: 2px;
}

/* ── Package view toggle ────────────────────────────────── */
.pkg-view-toggle {
	display: flex;
	gap: 4px;
	background: #F3F4F6;
	border-radius: 8px;
	padding: 3px;
	margin-bottom: 14px;
}
.pkg-toggle-btn {
	flex: 1;
	background: none;
	border: none;
	padding: 8px 12px;
	font-size: 13px;
	font-weight: 600;
	color: var(--muted);
	border-radius: 6px;
	cursor: pointer;
	transition: all .15s;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
}
.pkg-toggle-btn.active {
	background: #fff;
	color: var(--black);
	box-shadow: var(--shadow-sm);
}
.pkg-toggle-btn:hover:not(.active) { color: var(--black); }

/* ── Comparison picker ───────────────────────────────────── */
.compare-picker {
	text-align: center;
	padding: 20px 0;
}
.compare-picker-prompt {
	font-size: 15px;
	font-weight: 600;
	color: var(--black);
	margin-bottom: 16px;
}
.compare-picker-hint {
	font-size: 13px;
	color: var(--muted);
	margin-top: 12px;
}
.compare-picker-list {
	display: flex;
	flex-direction: column;
	gap: 6px;
	max-width: 400px;
	margin: 0 auto;
}
.compare-pick-btn {
	border: 2px solid var(--border);
	border-radius: 10px;
	padding: 12px 16px;
	min-height: 44px;
	font-size: 14px;
	background: #fff;
	color: var(--black);
	cursor: pointer;
	transition: all .15s;
	display: flex;
	align-items: center;
	justify-content: space-between;
	text-align: left;
	width: 100%;
}
.compare-pick-btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.compare-pick-btn.picked { font-weight: 700; }
.compare-pick-label {
	font-weight: 600;
}
.compare-pick-price {
	font-size: 13px;
	color: var(--muted);
	font-weight: 500;
}
.compare-go-btn {
	display: block;
	width: 100%;
	max-width: 400px;
	margin: 16px auto 0;
	padding: 12px;
	border: none;
	border-radius: 8px;
	background: var(--green-btn);
	color: #000;
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
	transition: opacity .15s;
}
.compare-go-btn:hover { opacity: 0.9; }

/* ── Side-by-side comparison ────────────────────────────── */
.compare-header-bar {
	margin-bottom: 12px;
}
.compare-back-btn {
	background: none;
	border: none;
	font-size: 13px;
	font-weight: 600;
	color: var(--muted);
	cursor: pointer;
	padding: 4px 0;
	display: flex;
	align-items: center;
	gap: 4px;
}
.compare-back-btn:hover { color: var(--black); }
.compare-cards {
	border: 1px solid var(--border);
	border-radius: 12px;
	overflow: hidden;
}
.compare-row {
	display: flex;
	border-bottom: 1px solid #F3F4F6;
}
.compare-row:last-child { border-bottom: none; }
.compare-row-header { border-bottom: 2px solid var(--border); }
.compare-row-actions { border-top: 2px solid var(--border); border-bottom: none; background: #F9FAFB; }
.compare-label-cell {
	flex: 0 0 110px;
	padding: 9px 12px;
	font-size: 12px;
	font-weight: 500;
	color: var(--muted);
	display: flex;
	align-items: center;
	background: #fff;
}
.compare-value-cell {
	flex: 1;
	padding: 9px 8px;
	text-align: center;
	font-size: 13px;
	font-weight: 600;
	color: var(--black);
	display: flex;
	align-items: center;
	justify-content: center;
}
.compare-pkg-header {
	flex: 1;
	padding: 14px 8px;
	text-align: center;
	cursor: default;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
}
.compare-pkg-header.selected { box-shadow: inset 0 -3px 0 rgba(255,255,255,.4); }

/* Selected package column — left+right borders across every row, closed off on top and bottom. */
.compare-col-selected        { border-left: 2px solid #2563EB; border-right: 2px solid #2563EB; }
.compare-col-top             { border-top: 2px solid #2563EB; }
.compare-col-bottom          { border-bottom: 2px solid #2563EB; border-bottom-left-radius: 8px; border-bottom-right-radius: 8px; }
.compare-pkg-icon { margin-bottom: 4px; }
.compare-pkg-icon svg { width: 18px; height: 18px; opacity: 0.9; }
.compare-pkg-name {
	font-family: 'Komika Axis', Arial, sans-serif;
	font-size: 13px;
	font-weight: normal;
	text-transform: uppercase;
	letter-spacing: 0.02em;
}
.compare-select-btn {
	border: none;
	border-radius: 6px;
	padding: 12px 16px;
	min-height: 44px;
	font-size: 12px;
	font-weight: 700;
	cursor: pointer;
	transition: opacity .15s;
	white-space: nowrap;
}
.compare-select-btn:hover { opacity: 0.85; }
.compare-select-btn.selected { opacity: 0.8; cursor: default; }

@media (max-width: 640px) {
	.compare-label-cell { flex: 0 0 80px; font-size: 11px; padding: 8px; }
	.compare-pkg-name { font-size: 11px; }
	.compare-value-cell { font-size: 12px; padding: 8px 4px; }
}

/* ── Package cards ───────────────────────────────────────── */
.pkg-grid {
	display: flex;
	flex-direction: column;
	gap: 14px;
	margin-bottom: 16px;
}
.pkg-card {
	background: #fff;
	border: 2px solid var(--border);
	border-radius: 12px;
	overflow: hidden;
	position: relative;
	text-align: left;
	width: 100%;
	transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.pkg-card.selected { border-color: #2563EB; box-shadow: 0 0 0 2px #2563EB, var(--shadow-sm); }

/* Color header block */
.pkg-header-block {
	padding: 16px 20px;
	border-radius: 10px 10px 0 0;
	cursor: pointer;
	position: relative;
}
/* Selected state uses .pkg-card.selected border only — no badge overlay */
.pkg-header-icon {
	position: absolute;
	top: 14px;
	right: 14px;
}
.pkg-header-icon svg { width: 36px; height: 36px; }
.pkg-header-title {
	font-family: 'Komika Axis', Arial, sans-serif;
	font-size: 20px;
	font-weight: normal;
	text-transform: uppercase;
	letter-spacing: 0.02em;
	margin-bottom: 10px;
}
.pkg-pricing-row {
	display: flex;
	gap: 8px;
}
.pkg-price-box {
	background: rgba(255,255,255,.2);
	border-radius: 8px;
	padding: 6px 16px;
	text-align: center;
	min-width: 100px;
}
.pkg-price-box.single { min-width: 140px; }
.pkg-price-label {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	opacity: 0.85;
	margin-bottom: 2px;
}
.pkg-price-val {
	font-size: 22px;
	font-weight: 900;
	letter-spacing: -0.5px;
}

/* Stats section — always visible */
.pkg-stats-section {
	padding: 16px 20px 12px;
}
.pkg-desc { font-size: 13px; color: var(--muted); margin: 0 0 14px; line-height: 1.4; }
.pkg-stats {
	display: flex;
	gap: 24px;
	margin-bottom: 8px;
}
.pkg-stat { text-align: center; }
.pkg-stat-val {
	font-size: 32px;
	font-weight: 900;
	color: var(--black);
	line-height: 1;
}
.pkg-stat-label {
	font-size: 12px;
	color: var(--muted);
	font-weight: 500;
	margin-top: 2px;
}
.pkg-extra-info {
	font-size: 12px;
	color: var(--muted);
	margin-bottom: 10px;
}

/* Details toggle */
.pkg-details-toggle {
	background: none;
	border: none;
	color: var(--muted);
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	padding: 6px 0;
	display: flex;
	align-items: center;
	gap: 6px;
}
.pkg-details-toggle:hover { color: var(--black); }
.pkg-toggle-arrow {
	font-size: 11px;
	transition: transform .2s var(--ease);
}
.pkg-toggle-arrow.open { transform: rotate(180deg); }

/* Collapsible details */
.pkg-details {
	padding: 0 20px 20px;
	border-top: 1px solid var(--border);
	margin: 0 20px;
	padding-top: 14px;
}
.pkg-desc       { font-size: 13px; color: var(--muted); margin: 0 0 12px; }

/* ── Package inclusions (data-driven) ───────────────────── */
.pkg-inclusions {
	margin-top: 14px;
	padding-top: 14px;
	border-top: 1px solid var(--border);
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.pkg-incl-row {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 13px;
	color: var(--black);
}
.pkg-incl-icon {
	width: 22px;
	text-align: center;
	flex-shrink: 0;
	color: var(--green-text);
	font-size: 14px;
}
.pkg-incl-emoji { font-size: 15px; color: #000; }
.pkg-incl-text  { flex: 1; line-height: 1.3; }
.pkg-incl-text strong { font-weight: 700; }
.pkg-incl-scale {
	display: block;
	font-size: 11px;
	color: var(--muted);
	font-weight: 400;
	margin-top: 1px;
}

/* ── Package footer ─────────────────────────────────────── */
.pkg-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 14px;
	padding-top: 12px;
	border-top: 1px solid var(--border);
}
.pkg-deposit-note { font-size: 12px; color: var(--muted); margin: 0; font-weight: 500; }
.pkg-extra-note   { font-size: 12px; color: var(--muted); margin: 0; font-weight: 500; }

.upgrade-hint {
	display: flex; align-items: center; justify-content: center;
	gap: 4px; font-size: 12px; color: #6B7280; padding: 4px 0;
}

/* ── Party spaces ────────────────────────────────────────── */
.space-card {
	background: #fff;
	border: 2px solid var(--border);
	border-radius: 16px;
	padding: 18px;
	cursor: pointer;
	transition: border-color .2s var(--ease), transform .2s var(--ease), box-shadow .2s var(--ease);
	position: relative;
	display: flex;
	align-items: center;
	gap: 14px;
	width: 100%;
	text-align: left;
	margin-bottom: 12px;
}
.space-card:hover:not(:disabled):not(.selected) { border-color: #D1D5DB; transform: translateY(-2px); box-shadow: var(--shadow-md); }
.space-card.selected, .space-card.selected:hover { box-shadow: 0 0 0 2px var(--green), var(--shadow-sm); border-color: var(--green); background: #F4FBF3; transform: none; }
.space-card:disabled               { opacity: 0.5; cursor: not-allowed; }
.space-icon-wrap {
	width: 48px; height: 48px; border-radius: 50%;
	background: #F3F4F6;
	display: flex; align-items: center; justify-content: center;
	flex-shrink: 0; font-size: 22px;
}
.space-info { flex: 1; min-width: 0; }
.space-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.space-name  { font-size: 17px; font-weight: 700; color: var(--black); }
.space-price { font-size: 17px; font-weight: 700; color: var(--black); }
.space-desc  { font-size: 13px; color: var(--muted); margin: 0; }
.space-vip-badge {
	position: absolute; top: -12px; right: 14px;
	background: #000; color: #fff;
	font-size: 11px; font-weight: 800; padding: 3px 12px; border-radius: 99px;
}
.space-unavail-badge {
	position: absolute; top: -12px; right: 14px;
	background: #9CA3AF; color: #fff;
	font-size: 11px; font-weight: 800; padding: 3px 12px; border-radius: 99px;
}
.availability-notice {
	display: flex; align-items: center; gap: 8px;
	background: #F3F4F6; border-radius: 10px;
	padding: 12px 14px; font-size: 13px; color: #4B5563;
	margin-bottom: 16px;
}

/* ── Party Hub (add-ons) ─────────────────────────────────── */
.pkg-summary-bar {
	display: flex; align-items: center; gap: 8px;
	background: #F3F4F6; border-radius: 10px;
	padding: 12px 14px; margin-bottom: 20px;
	font-size: 14px;
}
.pkg-summary-bar .check { color: var(--green); }
.category-section { margin-bottom: 20px; }
.category-toggle {
	width: 100%; background: none; border: none; cursor: pointer;
	display: flex; align-items: center; justify-content: space-between;
	padding: 8px 0; margin-bottom: 8px;
}
.category-toggle-left { display: flex; align-items: center; gap: 8px; }
.category-icon { font-size: 18px; color: #6B7280; transition: color .2s var(--ease); }
.category-body.open ~ * .category-icon,
.category-toggle[aria-expanded="true"] .category-icon { color: var(--green-text); }
.category-title { font-size: 17px; font-weight: 700; color: var(--black); letter-spacing: -0.2px; }
.category-toggle-right { display: flex; align-items: center; gap: 8px; }
.selection-badge {
	font-size: 12px; padding: 2px 10px; border-radius: 99px; font-weight: 600;
}
.selection-badge.needs  { background: #FEF3C7; color: #92400E; }
.selection-badge.done   { background: #D1FAE5; color: #065F46; }
.category-body { display: none; }
.category-body.open { display: block; }
.addon-required-notice {
	background: #FFFBEB; border: 1px solid #FCD34D;
	border-radius: 8px; padding: 10px 14px;
	font-size: 13px; color: #92400E; margin-bottom: 10px;
}
.addon-card {
	background: #fff; border-radius: 12px; overflow: hidden;
	border: 1px solid var(--border);
}
.addon-card.ring-green  { box-shadow: 0 0 0 2px var(--green); }
.addon-card.ring-amber  { box-shadow: 0 0 0 2px #FCD34D; }
.addon-row {
	display: flex; align-items: center; justify-content: space-between;
	padding: 12px 16px;
	border-bottom: 1px solid #F3F4F6;
}
.addon-row:last-child { border-bottom: none; }
.addon-name  { font-size: 14px; font-weight: 500; color: var(--black); margin-bottom: 2px; }
.addon-price { font-size: 12px; color: var(--muted); line-height: 1.5; }
/* Inclusion badges on addon items */
.item-avail-tag {
	display: inline-block;
	font-size: 11px; font-weight: 600;
	color: #1E40AF; background: #DBEAFE;
	padding: 1px 6px; border-radius: 4px;
	margin-left: 4px;
}
.item-incl-tag {
	display: inline-block;
	font-size: 11px; font-weight: 600;
	color: #065F46; background: #D1FAE5;
	padding: 1px 6px; border-radius: 4px;
	margin-left: 4px;
}
.item-paid-tag {
	display: inline-block;
	font-size: 11px; font-weight: 600;
	color: #92400E; background: #FEF3C7;
	padding: 1px 6px; border-radius: 4px;
	margin-left: 2px;
}

/* Category pool notice (shown inside toggle button) */
/* Per-item inclusion label (Extras category) */
.addon-included-label {
	font-size: 12px;
	font-weight: 600;
	color: #2563EB;
	margin-top: 3px;
	line-height: 1.3;
}
.addon-included-label.done {
	color: var(--green-text);
}
.addon-included-label .bi {
	margin-right: 3px;
}

.addon-pool-notice {
	font-size: 13px;
	color: var(--muted);
	background: #F9FAFB;
	border-radius: 8px;
	padding: 8px 12px;
	margin-bottom: 10px;
	text-align: center;
}
.addon-pool-notice.done {
	color: var(--green-text);
	background: #F4FBF3;
}
.addon-pool-notice .bi { margin-right: 4px; }
.addon-confirm-btn {
	display: block; width: 100%; margin-top: 12px;
	padding: 12px; background: var(--green-btn); color: #000;
	border: none; border-radius: 10px;
	font-size: 15px; font-weight: 700; cursor: pointer;
	transition: background .15s var(--ease), transform .1s var(--ease), box-shadow .15s var(--ease);
	box-shadow: 0 2px 8px rgba(88,185,72,.3);
}
.addon-confirm-btn:hover:not([disabled])  { background: var(--green-dark); box-shadow: 0 4px 12px rgba(88,185,72,.4); transform: translateY(-1px); }
.addon-confirm-btn:active:not([disabled]) { transform: scale(0.98); }
.addon-confirm-btn[disabled] { background: #9CA3AF; cursor: not-allowed; box-shadow: none; }
.category-toggle.locked { opacity: 0.4; cursor: not-allowed; }

/* ── Save Progress ───────────────────────────────────────── */
.save-icon-wrap {
	width: 56px; height: 56px; border-radius: 50%;
	background: #F3F4F6; display: flex; align-items: center; justify-content: center;
	margin: 0 auto 14px; font-size: 26px;
}
.form-input {
	width: 100%;
	border: 1px solid var(--border);
	border-radius: 10px;
	padding: 14px 16px;
	font-size: 16px; /* must be >= 16px to prevent iOS auto-zoom on focus */
	scroll-margin-top: 120px; /* prevents sticky header from covering focused input */
	color: var(--black);
	background: #fff;
	margin-bottom: 12px;
	outline: none;
	transition: border-color .15s var(--ease), box-shadow .15s var(--ease), background .15s var(--ease);
}
.form-input:focus {
	border-color: var(--green);
	box-shadow: 0 0 0 3px rgba(88,185,72,.12);
	background: #F4FBF3;
}
.form-input::placeholder { color: var(--muted); }

/* ── OTP Verification ────────────────────────────────────── */
.otp-wrap { display: flex; gap: 10px; justify-content: center; margin: 20px 0; }
.otp-input {
	width: 48px; height: 56px;
	border: 2px solid var(--border); border-radius: 10px;
	font-size: 24px; font-weight: 800; text-align: center;
	color: var(--black); background: #fff; outline: none;
}
.otp-input:focus { border-color: var(--green); }
.resend-link { background: none; border: none; cursor: pointer; color: var(--green-text); font-size: 14px; font-weight: 600; }
.resend-link:hover { color: var(--green-dark); }

/* ── Payment ─────────────────────────────────────────────── */
.apple-pay-btn {
	width: 100%;
	background: #000; color: #fff;
	border: none; border-radius: 12px;
	padding: 16px; font-size: 17px; font-weight: 700;
	cursor: pointer; margin-bottom: 16px;
	display: flex; align-items: center; justify-content: center; gap: 8px;
}
.divider-or {
	display: flex; align-items: center; gap: 12px;
	color: var(--muted); font-size: 13px; margin-bottom: 16px;
}
.divider-or::before, .divider-or::after {
	content: ''; flex: 1; height: 1px; background: var(--border);
}
.card-field-label { font-size: 12px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 6px; }
.pay-row { display: flex; gap: 12px; }
#payment-error:not(.sr-only) {
	background: #FEF2F2; border: 1px solid #FECACA; border-radius: 8px;
	color: #991B1B; font-size: 13px; padding: 10px 14px; margin-bottom: 12px;
}
.pay-row .form-input { flex: 1; }
/* ── Payment card brands + gift card ─────────────────────── */
.card-brands-inline {
	margin-top: 6px;
	opacity: 0.6;
}
.optional-tag {
	font-size: 11px;
	font-weight: 400;
	color: var(--muted);
	margin-left: 4px;
}
.gift-card-row {
	display: flex;
	gap: 8px;
	align-items: flex-start;
}
.gift-card-row .form-input {
	flex: 1;
	margin-bottom: 0;
}
.btn-apply-gc {
	flex-shrink: 0;
	padding: 12px 18px;
	min-height: 44px;
	background: var(--black);
	color: #fff;
	border: none;
	border-radius: var(--r-md);
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: background .15s var(--ease);
}
.btn-apply-gc:hover { background: #374151; }
.btn-apply-gc:disabled { opacity: 0.5; cursor: not-allowed; }
.gift-card-result {
	display: none;
	margin-top: 8px;
	padding: 8px 12px;
	border-radius: var(--r-md);
	font-size: 13px;
	font-weight: 500;
}
.gift-card-result.success {
	display: block;
	background: #D1FAE5;
	color: #065F46;
}
.gift-card-result.checking {
	display: block;
	background: #F3F4F6;
	color: var(--muted);
}
.gift-card-result.error {
	display: block;
	background: #FEF2F2;
	color: #DC2626;
}
/* ── Code toggle sections (gift card / coupon / school) ── */
.code-toggle {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 12px 0;
	border-top: 1px solid var(--border);
	cursor: pointer;
	font-size: 14px;
	font-weight: 500;
	color: var(--black);
}
.b-card > .code-toggle:first-child { border-top: none; padding-top: 0; }
.code-toggle:hover { color: var(--green-dark); }
.code-toggle-status {
	flex: 1;
	text-align: right;
	font-size: 12px;
	font-weight: 600;
	color: var(--green-text);
}
.code-toggle-arrow {
	font-size: 12px;
	color: var(--muted);
	transition: transform .2s var(--ease);
}
.code-toggle-arrow.open { transform: rotate(180deg); }
.code-section {
	display: none;
	padding: 0 0 12px;
}
.code-section.open { display: block; }

/* ── Email verification ──────────────────────────────────── */
.email-verify-row {
	display: flex;
	gap: 8px;
	align-items: flex-start;
}
.email-verify-row .form-input { flex: 1; margin-bottom: 0; }
.btn-verify-email {
	flex-shrink: 0;
	padding: 12px 16px;
	min-height: 44px;
	background: var(--black);
	color: #fff;
	border: none;
	border-radius: var(--r-md);
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: background .15s var(--ease);
}
.btn-verify-email:hover { background: #374151; }
.btn-verify-email:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-verify-email.verified {
	background: var(--green-btn);
	pointer-events: none;
}
.email-verify-status {
	display: none;
	font-size: 12px;
	margin-top: 6px;
	padding: 6px 10px;
	border-radius: 6px;
}
.email-verify-status.sent    { display: block; background: #DBEAFE; color: #1E40AF; }
.email-verify-status.success { display: block; background: #D1FAE5; color: #065F46; }
.email-verify-status.error   { display: block; background: #FEF2F2; color: #DC2626; }
.otp-input-wrap {
	display: flex;
	gap: 8px;
	margin-top: 8px;
	align-items: center;
}
.otp-input-wrap .otp-code-input {
	width: 120px;
	padding: 8px 12px;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 4px;
	text-align: center;
	border: 1px solid var(--border);
	border-radius: var(--r-md);
	margin-bottom: 0;
}
.otp-input-wrap .otp-code-input:focus {
	outline: none;
	border-color: var(--green);
	box-shadow: 0 0 0 2px rgba(88,185,72,.15);
}
.verify-timer {
	font-size: 12px;
	color: var(--muted);
	margin-left: 4px;
}

/* ── Early code input (step 3) ────────────────────────────── */
.early-code-card { margin-top: 16px; }
.early-code-header {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 14px;
	font-weight: 600;
	color: var(--black);
	margin-bottom: 10px;
}
.early-code-row {
	display: flex;
	gap: 8px;
	align-items: center;
}
.early-code-row .form-input { flex: 1; }
.early-code-btn {
	background: var(--green-btn);
	color: #000;
	border: none;
	border-radius: 10px;
	padding: 10px 18px;
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
	white-space: nowrap;
	transition: background .15s;
}
.early-code-btn:hover { background: var(--green-dark); }
.early-code-btn:disabled { background: #9CA3AF; cursor: not-allowed; }

/* ── Collapsible codes section ────────────────────────────── */
.codes-collapse-toggle {
	display: flex;
	align-items: center;
	width: 100%;
	background: none;
	border: none;
	padding: 0;
	font-size: 14px;
	font-weight: 600;
	color: var(--black);
	cursor: pointer;
	text-align: left;
}
.codes-collapse-toggle:hover { color: var(--green-dark); }
.codes-collapse-arrow {
	font-size: 12px;
	color: var(--muted);
	transition: transform .2s var(--ease);
}
.codes-collapse-arrow.open { transform: rotate(180deg); }
.codes-collapse-body { padding-top: 16px; }

.code-divider {
	border-top: 1px solid var(--border);
	margin: 14px 0;
}

/* Payment amount selector */
.pay-amount-options {
	display: flex;
	gap: 8px;
	margin-bottom: 12px;
}
.pay-opt-btn {
	flex: 1;
	border: 2px solid var(--border);
	border-radius: 10px;
	padding: 12px 10px;
	background: #fff;
	cursor: pointer;
	text-align: center;
	transition: all .15s;
}
.pay-opt-btn:hover { border-color: #D1D5DB; }
.pay-opt-btn.selected { border-color: #2563EB; background: #EFF6FF; }
.pay-opt-label {
	font-size: 12px;
	font-weight: 600;
	color: var(--muted);
	margin-bottom: 2px;
}
.pay-opt-btn.selected .pay-opt-label { color: #2563EB; }
.pay-opt-value {
	font-size: 16px;
	font-weight: 800;
	color: var(--black);
}
.pay-amount-custom-wrap { margin-top: 8px; }
.pay-amount-input-row {
	display: flex;
	align-items: center;
}
.pay-amount-prefix {
	font-size: 16px;
	font-weight: 700;
	color: var(--black);
	margin-right: 4px;
}
.pay-amount-range {
	font-size: 12px;
	color: var(--muted);
	margin-top: 4px;
}
@media (max-width: 640px) {
	.pay-amount-options { flex-direction: column; }
}

/* .link-btn renders a <button> as an inline link so operations (Remove, Check
   balance, Skip included items) keep the visual link affordance without abusing
   <a href="#">. Applies to .gc-balance-link, .gc-remove-link, .addon-decline-link
   and the inline "Remove" buttons in coupon/funraiser results. */
.link-btn {
	background: none;
	border: none;
	padding: 0;
	font: inherit;
	cursor: pointer;
	text-decoration: underline;
}
.link-btn:focus-visible { outline: 2px solid var(--green); outline-offset: 2px; border-radius: 3px; }

.gc-balance-link {
	margin-left: 8px;
	font-size: 12px;
	color: var(--green-text);
}
.gc-balance-link:hover { color: var(--black); }
.gc-remove-link {
	margin-left: 8px;
	font-size: 12px;
	color: #DC2626;
}
.gc-remove-link:hover { color: #991B1B; }

/* Balance check modal */
/* Toast notification — stack of independently-dismissable messages */
.book-toast-stack {
	position: fixed;
	bottom: 24px;
	right: 24px;
	z-index: 2000;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 10px;
	pointer-events: none;
	max-width: calc(100% - 48px);
}
.book-toast {
	transform: translateY(20px);
	padding: 12px 24px;
	border-radius: 10px;
	font-size: 14px;
	font-weight: 600;
	opacity: 0;
	pointer-events: auto;
	transition: opacity .3s, transform .3s;
	box-shadow: var(--shadow-lg);
	max-width: 100%;
}
.book-toast.visible {
	opacity: 1;
	transform: translateY(0);
}
.book-toast.success { background: #065F46; color: #fff; }
.book-toast.removed { background: #374151; color: #fff; }
.book-toast.error   { background: #DC2626; color: #fff; }

.bc-modal-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,.4);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	z-index: 1000;
	display: flex;
	align-items: center;
	justify-content: center;
}
.bc-modal {
	background: #fff;
	border-radius: 14px;
	width: calc(100% - 32px);
	max-width: 400px;
	max-height: 90vh;
	overflow-y: auto;
	box-shadow: var(--shadow-xl);
}
.bc-modal-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 16px 20px 12px;
	border-bottom: 1px solid var(--border);
}
.bc-modal-title { font-size: 16px; font-weight: 700; color: var(--black); }
.bc-modal-close {
	background: none; border: none; cursor: pointer;
	font-size: 16px; color: var(--muted); padding: 12px;
	min-width: 44px; min-height: 44px;
	display: flex; align-items: center; justify-content: center;
}
.bc-modal-close:hover { color: var(--black); }
.bc-modal-body { padding: 16px 20px 20px; }
.bc-modal-body .field-wrap { margin-bottom: 12px; }
.bc-submit-btn {
	display: block;
	width: 100%;
	padding: 12px;
	border: none;
	border-radius: 8px;
	background: var(--green-btn);
	color: #000;
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
	margin-top: 4px;
}
.bc-submit-btn:hover { opacity: 0.9; }
.bc-submit-btn:disabled { opacity: 0.6; cursor: default; }
#bc-result {
	padding: 10px 12px;
	border-radius: 8px;
	font-size: 13px;
	margin-bottom: 12px;
}
#bc-result.success { background: #F4FBF3; color: var(--green-text); }
#bc-result.error   { background: #FEF2F2; color: #DC2626; }

.gc-amount-wrap {
	margin-top: 12px;
	padding-top: 12px;
	border-top: 1px solid var(--border);
}
.gc-amount-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 4px;
}
.gc-remove-btn {
	background: none;
	border: none;
	font-size: 12px;
	color: #DC2626;
	cursor: pointer;
	padding: 10px 4px;
	min-height: 44px;
	font-weight: 500;
}
.gc-remove-btn:hover { color: #DC2626; text-decoration: underline; }
.gc-amount-note {
	font-size: 12px;
	color: var(--muted);
	margin-top: 4px;
}
.security-note {
	display: flex; align-items: center; justify-content: center;
	gap: 6px; font-size: 12px; color: var(--muted); margin-top: 14px;
}
.cancel-policy {
	text-align: center;
	font-size: 11px;
	color: var(--muted);
	margin-top: 8px;
	line-height: 1.4;
}

/* ── Confirm screen ──────────────────────────────────────── */
.trust-signals { display: flex; gap: 10px; margin-bottom: 20px; }
.trust-signal {
	flex: 1; display: flex; align-items: center; gap: 8px;
	background: #F3F4F6; border-radius: 10px; padding: 12px;
	font-size: 13px; color: #374151;
}
.trust-signal-icon { font-size: 18px; color: #6B7280; flex-shrink: 0; }
.confirm-card {
	background: #fff; border: 1px solid var(--border);
	border-radius: 16px; padding: 28px;
	text-align: center; margin-bottom: 16px;
	box-shadow: 0 4px 16px rgba(0,0,0,.06);
}
.confirm-total-label  { font-size: 12px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 4px; }
.confirm-total-amount { font-size: 40px; font-weight: 900; color: var(--black); margin: 0 0 16px; }
.confirm-divider      { border: none; border-top: 2px dashed var(--border); margin: 0 0 16px; }
.confirm-deposit-label  { font-size: 12px; font-weight: 700; color: var(--green-text); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 4px; }
.confirm-deposit-amount { font-size: 40px; font-weight: 900; color: var(--green-text); margin: 0 0 10px; }
.confirm-remaining { font-size: 14px; color: var(--muted); background: #F9FAFB; border-radius: 8px; padding: 8px 14px; display: inline-block; }
.verify-notice {
	background: #F9FAFB; border-radius: 12px; padding: 16px;
	text-align: center; font-size: 14px; color: var(--muted); margin-bottom: 16px;
}
.secure-note {
	display: flex; align-items: center; justify-content: center;
	gap: 6px; font-size: 12px; color: var(--muted);
}

/* ── Guest of Honor (Complete) ───────────────────────────── */
@keyframes success-pulse {
	0%   { box-shadow: 0 0 0 0   rgba(88,185,72,.5); }
	60%  { box-shadow: 0 0 0 18px rgba(88,185,72,.0); }
	100% { box-shadow: 0 0 0 0   rgba(88,185,72,.0); }
}
@keyframes success-pop {
	0%   { transform: scale(0.6); opacity: 0; }
	70%  { transform: scale(1.12); }
	100% { transform: scale(1);   opacity: 1; }
}
.complete-icon {
	width: 72px; height: 72px; border-radius: 50%;
	background: #2E6E22;
	display: flex; align-items: center; justify-content: center;
	margin: 0 auto 14px; font-size: 32px; color: #fff;
	animation: success-pop .5s var(--ease-spring) both, success-pulse 1.2s .5s ease-out both;
}
.honor-input-wrap {
	background: var(--green-btn); border-radius: 16px;
	padding: 28px 24px; text-align: center; color: #fff; margin-bottom: 16px;
}
.honor-input-label { font-size: 14px; font-weight: 600; opacity: .85; display: block; margin-bottom: 10px; }
.honor-input {
	background: transparent; border: none; border-bottom: 2px solid rgba(255,255,255,.4);
	color: #fff; font-size: 24px; font-weight: 800; text-align: center;
	width: 100%; outline: none; padding: 8px 0;
}
.honor-input::placeholder { color: rgba(255,255,255,.5); }
.invite-card {
	background: #fff; border: 1px solid var(--border);
	border-radius: 14px; padding: 16px 18px;
	display: flex; align-items: center; gap: 14px; margin-bottom: 16px;
	text-decoration: none; color: inherit; cursor: pointer;
	transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.invite-card:hover { border-color: var(--green); box-shadow: var(--shadow-sm); }
.invite-icon { font-size: 26px; color: var(--green); flex-shrink: 0; }

/* ── Sticky footer ───────────────────────────────────────── */
#booking-footer {
	position: fixed; bottom: 0; left: 0; right: 0;
	background: #fff; border-top: 1px solid var(--border);
	padding: 14px 16px; z-index: 200;
	box-shadow: 0 -4px 16px rgba(0,0,0,.07), 0 -1px 4px rgba(0,0,0,.04);
}
.footer-inner {
	max-width: 640px; margin: 0 auto;
	display: flex; align-items: center; gap: 16px;
}
.footer-total       { flex-shrink: 0; }
.footer-total-line  { display: flex; align-items: baseline; gap: 6px; }
.footer-total-label { font-size: 12px; color: var(--muted); }
.footer-total-amt   { font-size: 18px; font-weight: 800; color: var(--black); letter-spacing: -0.3px; font-variant-numeric: tabular-nums; }
.footer-deposit-line  { display: flex; align-items: baseline; gap: 6px; margin-top: 1px; }
.footer-deposit-label { font-size: 11px; color: var(--green-text); }
.footer-deposit-amt   { font-size: 14px; font-weight: 700; color: var(--green-text); font-variant-numeric: tabular-nums; }
.btn-cta {
	flex: 1;
	background: var(--green-btn); color: #000;
	border: none; border-radius: 12px;
	padding: 15px 20px; font-size: 16px; font-weight: 700;
	cursor: pointer;
	transition: background .15s var(--ease), transform .12s var(--ease), box-shadow .15s var(--ease);
	box-shadow: var(--shadow-green);
}
.btn-cta:hover:not([disabled])  { background: var(--green-dark); box-shadow: var(--shadow-green-lg); transform: translateY(-1px); }
.btn-cta:active:not([disabled]) { transform: scale(0.98); box-shadow: var(--shadow-green); }
.btn-cta[disabled]              { background: #9CA3AF; box-shadow: none; cursor: not-allowed; }
.btn-cta.full { flex: none; width: 100%; }

/* ── Self-managed step CTAs ──────────────────────────────── */
.step-cta-green {
	width: 100%; background: var(--green-btn); color: #000;
	border: none; border-radius: 12px;
	padding: 16px; font-size: 16px; font-weight: 700;
	cursor: pointer; margin-bottom: 12px;
	transition: background .15s var(--ease), transform .12s var(--ease), box-shadow .15s var(--ease);
	box-shadow: var(--shadow-green);
}
.step-cta-green:hover:not([disabled])  { background: var(--green-dark); box-shadow: var(--shadow-green-lg); transform: translateY(-1px); }
.step-cta-green:active:not([disabled]) { transform: scale(0.98); box-shadow: var(--shadow-green); }
.step-cta-green[disabled]              { background: #9CA3AF; box-shadow: none; cursor: not-allowed; }
.step-cta-skip {
	width: 100%; background: none; border: none;
	padding: 10px; font-size: 13px; color: var(--muted);
	cursor: pointer;
}
.step-cta-skip:hover { color: var(--black); }
.step-cta-black {
	width: 100%; background: #000; color: #fff;
	border: none; border-radius: 12px;
	padding: 16px; font-size: 16px; font-weight: 700;
	cursor: pointer; margin-bottom: 12px;
}

/* ── Step 1 — Location Search ────────────────────────────── */
/* Search row: input + geo button */
.loc-search-row {
	display: flex;
	gap: 8px;
	margin-bottom: 16px;
}
.loc-search-wrap {
	position: relative;
	flex: 1;
}
.loc-search-row { align-items: stretch; }
.loc-geo-btn {
	width: 48px;
	min-height: 48px;
	border: 1.5px solid var(--border);
	border-radius: 10px;
	background: #fff;
	color: var(--muted);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	flex-shrink: 0;
	transition: all .15s;
}
.loc-geo-btn:hover { border-color: var(--green); color: var(--green-text); }
.loc-geo-btn:disabled { opacity: 0.5; cursor: default; }
.loc-geo-btn.active { border-color: var(--green); color: var(--green-text); background: #F4FBF3; }

/* Nearest park results */
.loc-nearest-label {
	font-size: 12px;
	color: var(--muted);
	text-align: center;
	margin-bottom: 10px;
}
.loc-closest-badge {
	display: inline-block;
	font-size: 11px;
	font-weight: 600;
	background: #FFEA00;
	color: var(--black);
	padding: 1px 8px;
	border-radius: 4px;
	margin-bottom: 4px;
}
.loc-distance {
	font-size: 13px;
	color: var(--green-text);
	font-weight: 600;
}
.loc-no-results {
	text-align: center;
	padding: 20px;
	color: var(--muted);
	font-size: 14px;
}
.loc-search-icon {
	position: absolute;
	left: 14px;
	top: 50%;
	transform: translateY(-50%);
	color: #9CA3AF;
	font-size: 15px;
	pointer-events: none;
}
.loc-search-input {
	width: 100%;
	padding: 15px 14px 15px 40px;
	border: 1.5px solid var(--border);
	border-radius: 14px;
	font-size: 16px;       /* 16px prevents iOS zoom on focus */
	background: #fff;
	color: var(--black);
	outline: none;
	-webkit-appearance: none;
	appearance: none;
	transition: border-color .15s var(--ease), box-shadow .15s var(--ease), background .15s var(--ease);
}
.loc-search-input:focus {
	border-color: var(--green);
	box-shadow: 0 0 0 3px rgba(88,185,72,.15);
	background: #F4FBF3;
}

/* Prompt / empty state */
.loc-prompt {
	text-align: center;
	padding: 56px 16px 40px;
}
.loc-prompt-icon {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: #F0F9E0;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 16px;
	font-size: 26px;
	color: var(--green);
}
.loc-prompt-title { font-size: 17px; font-weight: 700; color: var(--black); margin-bottom: 6px; }
.loc-prompt-sub   { font-size: 14px; color: var(--muted); }

/* Selected-park banner (shown when query is empty but a park is already chosen) */
.loc-selected-banner {
	display: flex;
	align-items: center;
	gap: 12px;
	background: #F0F9E0;
	border: 1.5px solid var(--green);
	border-radius: 14px;
	padding: 14px 16px;
	margin-bottom: 10px;
	color: var(--green-text);
	font-size: 20px;
}
.loc-selected-name { font-size: 15px; font-weight: 700; color: var(--black); }
.loc-selected-addr { font-size: 12px; color: var(--muted); margin-top: 2px; }
.loc-change-hint   { text-align: center; font-size: 13px; color: var(--muted); }

/* Result cards */
.loc-card {
	display: flex;
	align-items: center;
	gap: 12px;
	width: 100%;
	background: #fff;
	border: 1.5px solid var(--border);
	border-radius: 14px;
	padding: 14px 14px;
	margin-bottom: 8px;
	cursor: pointer;
	text-align: left;
	transition: border-color .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease), transform .15s var(--ease);
	-webkit-tap-highlight-color: transparent;
}
.loc-card:hover    { border-color: var(--green); box-shadow: 0 0 0 2px var(--green), var(--shadow-sm); background: #F4FBF3; transform: translateY(-1px); }
.loc-card:active   { transform: translateY(0); }
.loc-card.selected { border-color: var(--green); box-shadow: 0 0 0 2px var(--green); background: #F4FBF3; transform: none; }

.loc-icon {
	width: 38px;
	height: 38px;
	border-radius: 50%;
	background: #F0F9E0;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: var(--green);
	font-size: 15px;
}
.loc-card.selected .loc-icon { background: var(--green-btn); color: #fff; }

.loc-info { flex: 1; min-width: 0; }
.loc-name {
	font-size: 14px;
	font-weight: 700;
	color: var(--black);
	margin-bottom: 2px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.loc-addr {
	font-size: 12px;
	color: var(--muted);
}

.loc-arrow {
	font-size: 20px;
	color: var(--muted);
	flex-shrink: 0;
	line-height: 1;
}
.loc-card.selected .loc-arrow { color: var(--green-text); font-size: 16px; font-weight: 700; }

/* ── Review rows (step 9) ─────────────────────────── */
.review-kv-row {
	display: flex; align-items: center;
	padding: 10px 0;
	border-bottom: 1px solid #F3F4F6;
}
.review-kv-row.no-border { border-bottom: none; }
.review-kv-label { font-size: 12px; color: var(--muted); min-width: 72px; }
.review-kv-value { flex: 1; font-size: 14px; font-weight: 600; color: var(--black); }
.review-change-btn {
	background: none; border: none;
	font-size: 13px; font-weight: 600; color: var(--green-text);
	cursor: pointer; padding: 4px 8px; flex-shrink: 0;
}

/* ── Expandable sections ─────────────────────────── */
.review-expand-section { border-top: 1px solid #F3F4F6; }
.review-expand-toggle {
	display: flex; align-items: center; width: 100%;
	background: none; border: none; cursor: pointer;
	padding: 12px 0; gap: 8px; text-align: left;
}
.review-expand-label   { font-size: 14px; font-weight: 700; color: var(--black); }
.review-expand-summary { flex: 1; font-size: 13px; color: var(--muted); text-align: right; }
.review-expand-toggle .bi { color: #9CA3AF; font-size: 13px; flex-shrink: 0; }
.review-expand-body { padding-bottom: 12px; }

.review-guest-row  { display: flex; justify-content: space-between; padding: 5px 0; }
.review-guest-label { font-size: 13px; color: var(--muted); }
.review-guest-val  { font-size: 13px; font-weight: 600; color: var(--black); text-align: right; max-width: 60%; overflow-wrap: break-word; }

.review-addon-cat  { font-size: 11px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .5px; padding: 8px 0 3px; }
.review-addon-line { display: flex; justify-content: space-between; font-size: 13px; padding: 6px 0; color: var(--black); gap: 12px; border-bottom: 1px solid #F3F4F6; }
.review-addon-line:last-child { border-bottom: none; }
.review-addon-qty  { color: var(--muted); font-weight: 500; }
/* Muted inclusion sub-line (matches cart). Divider lives here (not on the
   main row above) so it separates items from the NEXT item, not from their
   own qty/inclusion sub-line. */
.review-addon-line:has(+ .review-addon-inc) { border-bottom: none; }
.review-addon-inc {
	font-size: 12px;
	color: var(--muted);
	padding: 0 0 6px 16px;
	border-bottom: 1px solid #F3F4F6;
}
.review-addon-inc:last-child { border-bottom: none; }

/* ── Pricing breakdown ───────────────────────────── */
.review-price-breakdown { border-top: 1px solid #F3F4F6; padding-top: 12px; margin-top: 4px; }
.review-price-row { display: flex; justify-content: space-between; font-size: 14px; color: var(--black); padding: 4px 0; }
.review-price-inc { font-size: 12px; color: var(--muted); padding: 0 0 4px 16px; }
.review-price-total {
	font-size: 17px; font-weight: 800;
	border-top: 2px solid var(--border); margin-top: 6px; padding-top: 10px;
}
.review-deposit-banner {
	display: flex; align-items: center; justify-content: space-between;
	background: #F0F9E0; border-radius: 12px;
	padding: 14px 16px; margin-top: 14px;
}
.review-deposit-label { font-size: 12px; font-weight: 700; color: var(--green-text); text-transform: uppercase; letter-spacing: .5px; }
.review-deposit-sub   { font-size: 12px; color: var(--muted); margin-top: 2px; }
.review-deposit-amt   { font-size: 28px; font-weight: 900; color: var(--green-text); }

/* ── Step reveal animation ───────────────────────────────── */
@keyframes step-reveal {
	from { opacity: 0; transform: translateY(12px); }
	to   { opacity: 1; transform: translateY(0); }
}
.step-entering {
	animation: step-reveal .25s var(--ease-out) both;
}

/* ── Inline-style replacements ───────────────────────────── */
.card-section-title  { font-size: 15px; font-weight: 700; color: var(--black); margin-bottom: 14px; }
.counter-row         { display: flex; align-items: center; justify-content: space-between; padding: 4px 0 12px; }
.counter-row.no-top-pad { padding-top: 0; padding-bottom: 4px; }
.guest-type-name     { font-size: 15px; font-weight: 700; color: var(--black); }
.guest-type-sub      { font-size: 13px; color: var(--muted); }
.guest-type-price    { font-size: 12px; color: var(--green-text); font-weight: 600; margin-top: 2px; }
.card-divider        { margin: 0 0 12px; border: none; border-top: 1px solid #F3F4F6; }
.free-badge          { background: var(--black); color: #fff; font-size: 11px; font-weight: 800; padding: 2px 8px; border-radius: var(--r-full); vertical-align: middle; }
.guest-type-note     { font-size: 12px; color: var(--muted); margin-top: 4px; line-height: 1.4; }
.pkg-summary-name    { font-weight: 600; color: var(--black); }
.pkg-summary-dot     { color: #4B5563; }
.pkg-summary-incl    { font-size: 13px; color: var(--muted); }
.b-card-cal          { padding: 14px; }
.date-hint           { text-align: center; color: var(--muted); font-size: 13px; padding: 8px 0; }
.time-slots-header   { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.time-section-title  { font-size: 17px; font-weight: 700; margin: 0; letter-spacing: -0.3px; }
.date-label          { font-size: 12px; color: var(--muted); }
.slot-pricing-note   { font-size: 12px; text-align: center; color: var(--muted); margin-top: 6px; }
/* ── Marketing opt-in (matches shop/EC_PartyBooker) ──── */
.opt-in-container {
	border: 2px solid var(--green);
	border-radius: 12px;
	padding: 16px 20px;
	background: #F4FBF3;
	margin-bottom: 16px;
}
.opt-in-container .form-check-input { flex-shrink: 0; cursor: pointer; }
.opt-in-container .form-check-input:checked { background-color: var(--green); border: none; }
.opt-in-container .form-check-input:focus { border-color: var(--green); box-shadow: 0 0 0 0.25rem rgba(88,185,72,.25); }
.opt-in-text {
	font-size: 14px;
	font-weight: 500;
	color: var(--black);
	line-height: 1.4;
	cursor: pointer;
}
.recaptcha-wrap      { margin: 16px 0; display: flex; flex-direction: column; align-items: center; gap: 8px; }
.recaptcha-sub       { font-size: 13px; color: var(--muted); margin: 0; text-align: center; }
.success-header      { text-align: center; margin-bottom: 20px; }

/* ── Confirmation page ──────────────────────────────────── */
.conf-number-card {
	text-align: center;
	background: #2E6E22;
	color: #fff;
	border-radius: 12px;
	padding: 16px;
	margin-bottom: 16px;
}
.conf-number-label { font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; }
.conf-number-value { font-size: 28px; font-weight: 900; letter-spacing: 1px; margin-top: 4px; }
.conf-manage-link { display: block; margin-top: 10px; font-size: 13px; color: #fff; text-decoration: underline; }
.conf-manage-link:hover { color: #fff; }
.conf-details-card { margin-bottom: 12px; }

/* School/Fundraiser callout — full-width encouragement banner shown above the
   party breakdown when the party has a funraiser attached. Mirrors EC_ThankYou. */
.conf-funraiser-card {
	background: #F0F9E0;
	border: 1.5px solid var(--green);
	color: var(--black);
	font-size: 15px;
	text-align: center;
	padding: 16px 20px;
	margin-bottom: 12px;
}
.conf-funraiser-card strong { color: var(--green-text); }

/* 3-column receipt-style breakdown table: Item | Qty | Sub Total */
.conf-breakdown-head,
.conf-breakdown-row {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 0;
	font-size: 13px;
	border-bottom: 1px solid var(--border);
}
.conf-breakdown-head {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--muted);
	padding: 6px 0;
}
.conf-breakdown-col-name  { flex: 1; color: var(--black); overflow-wrap: break-word; min-width: 0; }
.conf-breakdown-col-qty   { flex: 0 0 40px; text-align: center; color: var(--muted); }
.conf-breakdown-col-price { flex: 0 0 80px; text-align: right; font-weight: 600; color: var(--black); }
.conf-breakdown-row.is-discount .conf-breakdown-col-price { color: var(--green-text); }
/* Divider lives on the inclusion sub-line (not the row above) so it reads as
   "item + its qty" above and "next item" below — matches cart/review. */
.conf-breakdown-row.has-included { border-bottom: none; }
.conf-breakdown-inc {
	font-size: 12px;
	color: var(--muted);
	padding: 0 0 10px 16px;
	border-bottom: 1px solid var(--border);
}
.conf-breakdown-inc:last-child { border-bottom: none; }
.conf-fine-print { font-size: 12px; color: var(--muted); line-height: 1.6; }
.conf-fine-print p { margin: 0 0 10px; }
.conf-fine-print p:last-child { margin-bottom: 0; }
.conf-balance-fine-print { font-size: 12px; color: #6B7280; line-height: 1.5; margin-top: 10px; }
.conf-row {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding: 10px 0;
	border-bottom: 1px solid var(--border);
	font-size: 14px;
	gap: 12px;
}
.conf-row.no-border { border-bottom: none; }
.conf-label {
	color: var(--muted);
	min-width: 0;
	overflow-wrap: break-word;
}
.conf-label .bi {
	width: 16px;
	text-align: center;
	margin-right: 6px;
}
.conf-value {
	text-align: right;
	font-weight: 600;
	color: var(--black);
	flex-shrink: 1;
	min-width: 0;
	overflow-wrap: break-word;
}
.conf-party-details .conf-row {
	flex-wrap: nowrap;
}
.conf-party-details .conf-label {
	flex: 0 0 40%;
	white-space: nowrap;
	overflow-wrap: normal;
	display: inline-flex;
	align-items: center;
}
.conf-party-details .conf-value {
	flex: 1 1 0;
	min-width: 0;
	overflow-wrap: break-word;
	text-align: left;
	font-weight: 600;
}
.conf-value-green { color: var(--green-text); }
.conf-value-bold  { font-size: 16px; font-weight: 800; }
.conf-deposit-row {
	background: #FEF3C7;
	border-radius: 8px;
	padding: 12px 14px;
	margin: 12px 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
}
.conf-deposit-label { font-size: 13px; font-weight: 700; color: #92400E; }
.conf-deposit-note  { font-size: 12px; color: #92400E; margin-top: 2px; }
.conf-deposit-amount { font-size: 20px; font-weight: 900; color: #92400E; flex-shrink: 0; }
.conf-summary-section {
	margin-top: 8px;
	padding-top: 10px;
	border-top: 1px solid var(--border);
	background: #F9FAFB;
	border-radius: 0 0 12px 12px;
	margin: 8px -20px -20px;
	padding: 12px 20px 14px;
}
.conf-total-row { border-top: 2px solid var(--black); margin-top: 4px; padding-top: 10px; }
.conf-balance-row { padding-top: 12px; }
.conf-next-step-row {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 0;
	border-bottom: 1px solid var(--border);
	text-decoration: none;
	color: inherit;
	transition: background .15s var(--ease);
	cursor: pointer;
}
.conf-next-step-row:last-child { border-bottom: none; }
.conf-next-step-row:hover { color: var(--green-text); }
.conf-next-step-row > .bi:first-child { font-size: 18px; color: var(--green-text); width: 22px; text-align: center; flex-shrink: 0; }
.conf-next-step-row > .bi:last-child  { font-size: 12px; color: var(--muted); margin-left: auto; flex-shrink: 0; }
.conf-next-title { font-size: 14px; font-weight: 600; }
.conf-next-sub   { font-size: 12px; color: var(--muted); margin-top: 2px; }

.invite-title        { font-weight: 700; font-size: 14px; margin-bottom: 2px; }
.invite-sub          { font-size: 13px; color: var(--muted); }

/* ── Visually hidden (screen-reader only) ────────────────── */
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0,0,0,0);
	white-space: nowrap;
	border: 0;
}

/* ── Skip navigation ─────────────────────────────────────── */
.skip-nav {
	position: absolute;
	top: -100%;
	left: 0;
	background: var(--black);
	color: #fff;
	padding: 10px 16px;
	z-index: 9999;
	font-size: 14px;
	font-weight: 600;
	border-radius: 0 0 8px 0;
	text-decoration: none;
}
.skip-nav:focus { top: 0; }

/* ── Keyboard focus styles ───────────────────────────────── */
button:focus-visible,
[role="button"]:focus-visible,
input:focus-visible,
a:focus-visible {
	outline: 2px solid var(--green);
	outline-offset: 2px;
}
.header-back:focus-visible        { color: var(--black); }
.slot-btn:focus-visible:not(.slot-unavailable)  { border-color: #D1D5DB; }
.btn-cta:focus-visible:not([disabled])          { background: var(--green-dark); }
.step-cta-green:focus-visible:not([disabled])   { background: var(--green-dark); }
.loc-card:focus-visible           { border-color: var(--green); box-shadow: 0 0 0 3px rgba(88,185,72,.25); }
.space-card:focus-visible         { border-color: var(--green); box-shadow: 0 0 0 3px rgba(88,185,72,.25); }
.pkg-header-block:focus-visible    { outline: 2px solid #fff; outline-offset: -4px; }
.pkg-details-toggle:focus-visible { outline: 2px solid var(--green); outline-offset: 2px; }
.category-toggle:focus-visible    { outline: 2px solid var(--green); outline-offset: 2px; border-radius: 6px; }
.counter-btn-minus:focus-visible,
.counter-btn-plus:focus-visible   { outline: 2px solid var(--green); outline-offset: 1px; }

/* ── Cart icon (header top-right) ─────────────────────────── */
.cart-icon-btn {
	position: relative;
	background: none;
	border: none;
	cursor: pointer;
	font-size: 18px;
	color: rgba(255,255,255,.85);
	padding: 8px;
	min-width: 44px;
	min-height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 0.5rem;
	transition: color .2s ease;
}
.cart-icon-btn:hover { color: #fff; }
.cart-badge {
	position: absolute;
	top: 2px;
	right: 2px;
	background: var(--green-btn);
	color: #000;
	font-size: 11px;
	font-weight: 800;
	min-width: 16px;
	height: 16px;
	border-radius: 99px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 3px;
	line-height: 1;
}

/* ── Cart drawer (bottom sheet) ───────────────────────────── */
/* Mobile: hidden overlay by default; shown via JS toggleCart() */
.cart-drawer {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 900;
}
.cart-drawer.cart-disabled {
	pointer-events: none;
	opacity: 0.5;
}
.cart-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,.35);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
}
.cart-panel {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background: #fff;
	border-radius: 16px;
	width: calc(100% - 24px);
	max-width: 560px;
	max-height: 85vh;
	display: flex;
	flex-direction: column;
	box-shadow: var(--shadow-xl);
}
.cart-panel-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 18px 20px 14px;
	border-bottom: 1px solid #F3F4F6;
	flex-shrink: 0;
}
.cart-panel-title {
	font-size: 16px;
	font-weight: 700;
	color: #111827;
}
.cart-panel-close {
	background: none;
	border: none;
	font-size: 18px;
	color: #6B7280;
	cursor: pointer;
	padding: 4px;
	line-height: 1;
}
.cart-panel-body {
	overflow-y: auto;
	padding: 12px 20px 32px;
	flex: 1;
}
/* Cart table layout */
.cart-table-head {
	display: flex;
	align-items: center;
	padding: 0 0 6px;
	border-bottom: 2px solid #E5E7EB;
	margin-bottom: 2px;
}
.cart-table-head .cart-cell-name  { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: #6B7280; }
.cart-table-head .cart-cell-qty   { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: #6B7280; }
.cart-table-head .cart-cell-price { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: #6B7280; }
.cart-table-row {
	display: flex;
	align-items: center;
	padding: 7px 0;
	border-bottom: 1px solid #F3F4F6;
	gap: 6px;
}
.cart-table-row:last-of-type { border-bottom: none; }
/* When an inclusion sub-line follows a row, move the divider below the
   sub-line so it separates items from the NEXT item (not from their own
   sub-line). */
.cart-table-row:has(+ .cart-addon-inc) { border-bottom: none; }
.cart-cell-name {
	flex: 1;
	font-size: 13px;
	font-weight: 500;
	color: #111827;
	min-width: 0;
}
.cart-incl-note {
	font-size: 11px;
	font-weight: 500;
	color: var(--green-text);
	text-align: right;
	padding: 0 0 4px;
}
.cart-cell-qty {
	width: 32px;
	text-align: center;
	font-size: 13px;
	color: #6B7280;
	flex-shrink: 0;
}
.cart-cell-price {
	width: 64px;
	text-align: right;
	font-size: 13px;
	font-weight: 600;
	color: #374151;
	flex-shrink: 0;
}
.cart-cell-price.free {
	color: #10B981;
}
.cart-pkg-inclusions {
	display: flex;
	flex-wrap: wrap;
	gap: 4px 10px;
	padding: 4px 0 8px 2px;
	border-bottom: 1px solid #F3F4F6;
}
.cart-pkg-inclusions span {
	display: flex;
	align-items: center;
	gap: 4px;
	font-size: 11px;
	color: #6B7280;
}
.cart-pkg-inclusions .bi {
	color: var(--green-text, #2D7A1E);
	font-size: 11px;
}

.cart-cell-ctrl {
	display: flex;
	align-items: center;
	gap: 2px;
	flex-shrink: 0;
}
.cart-ctrl-btn {
	width: 32px; height: 32px;
	border: 1px solid #E5E7EB;
	border-radius: 6px;
	background: #F9FAFB;
	color: #374151;
	font-size: 14px;
	cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	padding: 0;
	line-height: 1;
	transition: background .12s var(--ease), border-color .12s var(--ease), transform .1s var(--ease-spring);
}
.cart-ctrl-btn:hover:not(:disabled)  { background: #F3F4F6; border-color: #D1D5DB; }
.cart-ctrl-btn:active:not(:disabled) { transform: scale(0.88); }
.cart-ctrl-btn:disabled { opacity: 0.35; cursor: default; }
.cart-ctrl-btn:focus-visible { outline: 2px solid var(--green); outline-offset: 2px; }
.cart-ctrl-qty {
	width: 22px;
	text-align: center;
	font-size: 13px;
	font-weight: 600;
	color: #111827;
}
.cart-ctrl-del {
	min-width: 44px; min-height: 44px;
	border: none;
	background: none;
	color: #6B7280;
	font-size: 13px;
	cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	padding: 4px;
	margin-left: 4px;
	border-radius: 6px;
	transition: color 0.15s, background 0.15s;
}
.cart-ctrl-del:hover { color: #DC2626; background: #FEF2F2; }
.cart-ctrl-del:focus-visible { outline: 2px solid var(--green); outline-offset: 2px; }
.cart-section-label {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: #6B7280;
	padding: 10px 0 2px;
}
.cart-divider {
	border: none;
	border-top: 1px solid #F3F4F6;
	margin: 8px 0;
}
/* Legacy — kept for backward-compat if any caller still references it. */
.cart-addon-savings {
	font-size: 11px;
	font-weight: 600;
	color: var(--green-text);
	text-align: right;
	padding: 0 0 2px;
}
/* Receipt-style inclusion sub-line under a main cart row. A single muted
   "N of M included" count — keeps the right column reserved for what the
   customer actually pays, no credit math to parse.
   The divider lives on the sub-line (not the main row above) so it reads
   as "item + its qty" above the line and "next item" below. */
.cart-addon-inc {
	font-size: 11px;
	color: var(--muted);
	padding: 0 0 7px 8px;
	border-bottom: 1px solid #F3F4F6;
}
.cart-addon-inc:last-child { border-bottom: none; }
.cart-coupon-row {
	font-size: 12px;
	font-weight: 600;
	color: var(--green-text);
	padding: 6px 0;
}
.cart-coupon-row .bi { margin-right: 4px; }
.cart-total-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px 0 4px;
	font-size: 16px;
	font-weight: 700;
	color: #111827;
}
.cart-deposit-note {
	font-size: 12px;
	color: #6B7280;
	text-align: right;
}
.cart-tax-note {
	font-size: 12px;
	color: #6B7280;
	text-align: right;
	font-style: italic;
}

/* ── Mobile responsive ───────────────────────────────────── */
@media (max-width: 640px) {
	.screen-title { font-size: 22px; }
	.booking-wrap { padding: 16px 12px; }
	.b-card       { padding: 16px; }

	/* Confirmation rows: stack label/value on narrow screens */
	.conf-summary-section .conf-row,
	.conf-balance-row {
		flex-wrap: wrap;
	}
	.conf-summary-section .conf-value {
		text-align: right;
		word-break: break-word;
	}
	.conf-summary-section .conf-label {
		flex: 1 1 auto;
		min-width: 0;
	}
	.conf-deposit-row {
		flex-wrap: wrap;
	}
	.conf-deposit-amount {
		width: 100%;
		text-align: right;
		margin-top: 4px;
	}
	.conf-summary-section {
		margin: 8px -16px -16px;
		padding: 12px 16px 14px;
	}

	/* Package cards: smaller image */
	.pkg-image { max-height: 120px; }
	.pkg-image img { height: 120px; }

	/* Things to know: slightly larger for readability */
	.conf-fine-print { font-size: 13px; }

	/* Header brand: tighten on small screens */
	.header-brand { padding: 0.5rem 12px; }
	.header-brand-subtitle { display: none; }
	.header-location { font-size: 11px; max-width: 140px; overflow: hidden; text-overflow: ellipsis; }
}


/* Respect users who request reduced motion (WCAG 2.3.3). Disables step reveal,
   toast transitions, hover lifts, and any other motion-based UI cues. */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.001ms !important;
		scroll-behavior: auto !important;
	}
}

/* ── Mobile responsiveness ───────────────────────────────── */
@media (max-width: 575px) {
	/* Datepicker touch targets — minimum 44×44 */
	.ui-datepicker td a, .ui-datepicker td span { padding: 10px !important; }

	/* Early coupon input — stack vertically on narrow screens */
	.early-code-row { flex-direction: column; }
	.early-code-btn { width: 100%; }
}

