.bb-wca-booking {
	position: relative;
	isolation: isolate;
	margin: 18px 0;
	padding: 20px;
	font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	line-height: 1.45;
	border: 1px solid #cfddd5;
	border-radius: 8px;
	background:
		linear-gradient(180deg, #ffffff 0%, #f8fcfa 55%, #f2f7f4 100%);
	color: #17211e;
	box-shadow: 0 30px 72px rgba(18, 27, 24, 0.11);
	overflow: visible;
}

.bb-wca-booking::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	height: 6px;
	border-radius: 8px 8px 0 0;
	background: linear-gradient(90deg, #1f7a5c 0%, #5f876f 100%);
}

.bb-wca-booking.has-error {
	border-color: #d9aaa3;
	box-shadow: 0 14px 34px rgba(138, 31, 31, 0.09);
}

.bb-wca-booking.is-attention {
	border-color: #1f7a5c;
	box-shadow: 0 0 0 3px rgba(31, 122, 92, 0.12), 0 14px 34px rgba(28, 42, 37, 0.08);
}

.bb-wca-booking.has-calendar-open {
	z-index: 100000;
}

.bb-wca-booking__header {
	display: grid;
	gap: 8px;
	margin: 0 0 14px;
	padding: 0 0 12px;
	border-bottom: 1px solid #e1ebe5;
}

.bb-wca-booking__header strong {
	color: #17211e;
	font-size: 26px;
	line-height: 1.15;
}

.bb-wca-booking__header p {
	max-width: 680px;
	margin: 0;
	color: #5e6b66;
	font-size: 14px;
	line-height: 1.55;
}

.bb-wca-booking__eyebrow {
	display: inline-flex;
	width: fit-content;
	align-items: center;
	min-height: 28px;
	padding: 0 12px;
	border: 1px solid #d4e2db;
	border-radius: 8px;
	background: #edf6f1;
	color: #155b43;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0;
	text-transform: uppercase;
}

form.variations_form.bb-wca-has-booking .variations {
	margin-bottom: 12px;
	padding: 12px 14px;
	border: 1px solid #d8e3de;
	border-radius: 8px;
	background: linear-gradient(180deg, #fcfefd 0%, #f7fbf9 100%);
	border-collapse: separate;
	border-spacing: 0 10px;
	box-shadow: 0 10px 24px rgba(23, 33, 30, 0.04);
}

form.variations_form.bb-wca-has-booking .variations th,
form.variations_form.bb-wca-has-booking .variations td {
	padding-top: 0;
	padding-bottom: 0;
	vertical-align: middle;
}

form.variations_form.bb-wca-has-booking .variations label,
.bb-wca-field-label,
.bb-wca-time-label {
	color: #34423e;
	font-size: 13px;
	font-weight: 700;
}

form.variations_form.bb-wca-has-booking .variations select {
	box-sizing: border-box;
	width: 100%;
	min-height: 44px;
	padding: 8px 12px;
	border: 1px solid #cbd8d3;
	border-radius: 8px;
	background-color: #ffffff;
	color: #17211e;
	font: inherit;
	box-shadow: 0 1px 0 rgba(23, 33, 30, 0.03);
}

form.variations_form.bb-wca-has-booking .variations select:focus {
	border-color: #1f7a5c;
	box-shadow: 0 0 0 3px rgba(31, 122, 92, 0.12);
	outline: none;
}

form.variations_form.bb-wca-has-booking .reset_variations {
	display: inline-block;
	margin-top: 6px;
	color: #5f6f69;
	font-size: 13px;
	text-decoration: none;
}

.bb-wca-booking__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 12px;
	align-items: start;
}

.bb-wca-booking__field,
.bb-wca-time-field {
	display: grid;
	gap: 10px;
	margin-bottom: 10px;
	padding: 14px;
	border: 1px solid #dce7e1;
	border-radius: 8px;
	background: linear-gradient(180deg, #ffffff 0%, #f6faf8 100%);
	box-shadow: 0 20px 40px rgba(20, 31, 27, 0.08);
}

.bb-wca-staff-field[hidden] {
	display: none !important;
}

.bb-wca-staff-options {
	display: grid;
	gap: 8px;
}

.bb-wca-staff-choice-card {
	display: grid;
	grid-template-columns: 20px minmax(0, 1fr);
	gap: 10px;
	align-items: start;
	margin: 0;
	padding: 12px;
	border: 1px solid #d7e5de;
	border-radius: 8px;
	background: #ffffff;
	color: #17211e;
	cursor: pointer;
	box-shadow: 0 8px 20px rgba(20, 31, 27, 0.05);
	transition: border-color 140ms ease, box-shadow 140ms ease, transform 140ms ease;
}

.bb-wca-staff-choice-card:hover,
.bb-wca-staff-choice-card:focus-within {
	border-color: #2f7d5b;
	box-shadow: 0 0 0 3px rgba(47, 125, 91, 0.12), 0 10px 24px rgba(20, 31, 27, 0.07);
}

.bb-wca-staff-choice-card:active {
	transform: scale(0.99);
}

.bb-wca-staff-choice-card input {
	width: 18px;
	height: 18px;
	margin: 2px 0 0;
	accent-color: #233528;
}

.bb-wca-staff-choice-card span {
	display: grid;
	gap: 3px;
	min-width: 0;
}

.bb-wca-staff-choice-card strong {
	overflow: hidden;
	color: #17211e;
	font-size: 14px;
	font-weight: 800;
	line-height: 1.25;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.bb-wca-staff-choice-card small,
.bb-wca-booking__auto-staff-note {
	margin: 0;
	color: #5f6e68;
	font-size: 12px;
	line-height: 1.45;
}

.bb-wca-booking__auto-staff-note {
	padding: 10px 12px;
	border: 1px solid #d8e3de;
	border-radius: 8px;
	background: #f6faf8;
	font-weight: 600;
}

.bb-wca-date-field {
	position: relative;
	z-index: 5;
	overflow: visible;
}

.bb-wca-booking__section-head {
	display: grid;
	grid-template-columns: 34px minmax(0, 1fr);
	gap: 14px;
	align-items: start;
}

.bb-wca-booking__section-head--compact {
	grid-template-columns: minmax(0, 1fr);
	gap: 0;
}

.bb-wca-booking__section-step {
	display: inline-flex;
	width: 34px;
	height: 34px;
	align-items: center;
	justify-content: center;
	border-radius: 8px;
	background: linear-gradient(180deg, #2f8b63 0%, #206342 100%);
	border: 1px solid #2b7a55;
	color: #f7fbf8;
	font-size: 13px;
	font-weight: 800;
	line-height: 1;
	box-shadow: 0 14px 24px rgba(9, 15, 13, 0.22);
}

.bb-wca-booking__section-copy {
	display: grid;
	gap: 6px;
	min-width: 0;
}

.bb-wca-booking__timezone-note {
	margin: 0;
	color: #5f6e68;
	font-size: 12px;
	line-height: 1.45;
}

.bb-wca-booking__section-text {
	margin: 0;
	color: #63716b;
	font-size: 13px;
	line-height: 1.5;
}

.bb-wca-booking .bb-wca-field-label,
.bb-wca-booking .bb-wca-time-label {
	color: #15211d;
	font-size: 15px;
	font-weight: 800;
}

.bb-wca-date {
	display: none !important;
}

.bb-wca-date-picker {
	position: relative;
	display: grid;
	gap: 6px;
}

.bb-wca-date-display,
.bb-wca-date-trigger {
	display: flex;
	width: 100%;
	min-height: 60px;
	align-items: center;
	justify-content: flex-start;
	gap: 12px;
	padding: 12px 15px;
	border: 1px solid #cfe0d7;
	border-radius: 8px;
	background: linear-gradient(180deg, #ffffff 0%, #f7fbf9 100%);
	color: #15211d;
	font-family: inherit;
	text-align: left;
	text-transform: none;
	box-shadow: 0 14px 28px rgba(20, 31, 27, 0.06);
	transition: background-color 160ms ease, border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.bb-wca-date-display {
	display: grid;
	gap: 6px;
}

.bb-wca-date-helper {
	margin: 0;
	padding: 10px 12px;
	border: 1px solid #d8e3de;
	border-radius: 8px;
	background: linear-gradient(180deg, #fcfefd 0%, #f2f8f5 100%);
	color: #4e6058;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.45;
}

.bb-wca-booking.has-error .bb-wca-date-helper {
	border-color: #e4b5b2;
	background: linear-gradient(180deg, #fff7f6 0%, #f8eceb 100%);
	color: #8f3330;
}

.bb-wca-date-trigger:hover,
.bb-wca-date-trigger:focus-visible,
.bb-wca-booking.has-calendar-open .bb-wca-date-trigger {
	border-color: #3a8f69;
	background: #ffffff;
	box-shadow: 0 0 0 3px rgba(58, 143, 105, 0.14), 0 18px 34px rgba(20, 31, 27, 0.08);
	outline: none;
}

.bb-wca-date-trigger[aria-disabled="true"] {
	background: linear-gradient(180deg, #f6f8f7 0%, #eef3f1 100%);
	color: #7f8d87;
	cursor: not-allowed;
	box-shadow: inset 0 0 0 1px rgba(199, 211, 205, 0.6);
}

.bb-wca-date-trigger__content {
	display: grid;
	gap: 6px;
	min-width: 0;
}

.bb-wca-date-display__eyebrow,
.bb-wca-date-trigger__eyebrow {
	display: block;
	color: #23714d;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.2;
	text-transform: uppercase;
}

.bb-wca-date-value {
	display: block;
	min-width: 0;
	overflow: hidden;
	color: #14201c;
	font-size: 20px;
	font-weight: 800;
	line-height: 1.15;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.bb-wca-date-trigger[aria-disabled="true"] .bb-wca-date-value {
	color: #94a19b;
}

.bb-wca-date-display[aria-disabled="true"] .bb-wca-date-value {
	color: #94a19b;
}

.bb-wca-date-trigger__icon {
	display: inline-flex;
	width: 44px;
	height: 44px;
	flex: 0 0 44px;
	align-items: center;
	justify-content: center;
	border-radius: 8px;
	background: linear-gradient(180deg, #254636 0%, #183227 100%);
	color: #dff3e8;
	font-size: 24px;
	line-height: 1;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), 0 10px 18px rgba(0, 0, 0, 0.16);
	transition: transform 160ms ease, background-color 160ms ease;
}

.bb-wca-date-trigger[aria-disabled="true"] .bb-wca-date-trigger__icon {
	background: #1f2925;
	color: #7f8d87;
}

.bb-wca-booking.has-calendar-open .bb-wca-date-trigger__icon {
	transform: rotate(180deg);
}

.bb-wca-calendar {
	position: static;
	z-index: 2;
	width: 100%;
	margin-top: 2px;
	padding: 2px 0 0;
	border: 0;
	border-radius: 8px;
	background: transparent;
	box-shadow: none;
}

.bb-wca-calendar__surface {
	display: grid;
	gap: 10px;
	padding: 12px;
	border: 1px solid #d6e2dd;
	border-radius: 8px;
	background: linear-gradient(180deg, #fcfefd 0%, #f3f8f5 100%);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8), 0 16px 28px rgba(20, 31, 27, 0.05);
}

.bb-wca-calendar[hidden],
.bb-wca-calendar[aria-hidden="true"] {
	display: none !important;
}

.bb-wca-calendar__nav {
	display: grid;
	grid-template-columns: 44px 1fr 44px;
	gap: 10px;
	align-items: center;
}

.bb-wca-calendar__title {
	color: #15211d;
	font-size: 18px;
	font-weight: 800;
	line-height: 1.3;
	text-align: center;
}

.bb-wca-calendar__nav-button {
	appearance: none;
	width: 44px;
	height: 44px;
	padding: 0;
	border: 1px solid #d2dfd8;
	border-radius: 8px;
	background: linear-gradient(180deg, #ffffff 0%, #f3f7f5 100%);
	color: #15211d;
	cursor: pointer;
	font-family: inherit;
	font-size: 22px;
	font-weight: 700;
	line-height: 1;
	text-transform: none;
	box-shadow: 0 10px 18px rgba(20, 31, 27, 0.05);
	transition: border-color 160ms ease, background-color 160ms ease, box-shadow 160ms ease, color 160ms ease, transform 160ms ease;
}

.bb-wca-calendar__nav-button:hover,
.bb-wca-calendar__nav-button:focus-visible {
	border-color: #3a8f69;
	background: linear-gradient(180deg, #f4fbf7 0%, #ebf5ef 100%);
	box-shadow: 0 0 0 3px rgba(58, 143, 105, 0.14);
	color: #154d36;
	outline: none;
}

.bb-wca-calendar__nav-button:disabled {
	cursor: not-allowed;
	opacity: 0.45;
	box-shadow: none;
}

.bb-wca-calendar__nav-button:active:not(:disabled) {
	transform: translateY(1px);
}

.bb-wca-calendar__weekdays,
.bb-wca-calendar__grid {
	display: grid;
	grid-template-columns: repeat(7, minmax(0, 1fr));
	gap: 7px;
	min-width: 0;
}

.bb-wca-calendar__frame {
	display: grid;
	gap: 0;
	min-width: 0;
}

.bb-wca-calendar__weekdays {
	margin-bottom: 8px;
	color: #73827b;
	font-size: 11px;
	font-weight: 800;
	text-align: center;
	text-transform: uppercase;
}

.bb-wca-calendar__day {
	appearance: none;
	display: grid;
	min-width: 0;
	min-height: 0;
	aspect-ratio: 1;
	align-content: center;
	justify-items: center;
	gap: 3px;
	border: 1px solid #dce7e1;
	border-radius: 8px;
	background: linear-gradient(180deg, #ffffff 0%, #f4f8f6 100%);
	color: #1d2c26;
	cursor: pointer;
	font-family: inherit;
	font-weight: 800;
	font-size: 15px;
	text-transform: none;
	line-height: 1;
	box-shadow: 0 8px 16px rgba(20, 31, 27, 0.05);
	padding: 6px 4px;
	overflow: hidden;
	transition: border-color 160ms ease, background-color 160ms ease, box-shadow 160ms ease, color 160ms ease, transform 160ms ease;
}

.bb-wca-calendar__day-number {
	display: block;
	font-size: 16px;
	font-weight: 800;
	line-height: 1;
	font-variant-numeric: tabular-nums;
}

.bb-wca-calendar__day-status {
	display: block;
	font-size: 8px;
	font-weight: 800;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.bb-wca-customer-portal {
	display: grid;
	gap: 14px;
}

.bb-wca-customer-appointment {
	display: flex;
	justify-content: space-between;
	gap: 14px;
	align-items: flex-start;
	padding: 14px;
	border: 1px solid #dce7e2;
	border-radius: 8px;
	background: #fff;
}

.bb-wca-customer-appointment > div,
.bb-wca-customer-appointment__actions {
	display: grid;
	gap: 8px;
}

.bb-wca-customer-appointment__actions {
	grid-template-columns: 1fr auto;
	align-items: end;
}

.bb-wca-customer-appointment__notice {
	margin: 0;
	padding: 10px 12px;
	border: 1px solid #efc4c4;
	border-radius: 10px;
	background: #fff4f4;
	color: #8e3535;
	font-size: 13px;
	line-height: 1.5;
}

.bb-wca-customer-appointment__actions input,
.bb-wca-customer-appointment__actions button {
	min-height: 38px;
	border-radius: 8px;
}

.bb-wca-customer-reschedule {
	grid-column: 1 / -1;
	padding: 10px;
	border: 1px solid #dce7e2;
	border-radius: 8px;
	background: #f8fbfa;
}

.bb-wca-customer-reschedule summary {
	cursor: pointer;
	color: #155b43;
	font-weight: 800;
}

.bb-wca-customer-reschedule > button {
	margin-top: 10px;
}

.bb-wca-customer-reschedule__fallback {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
	margin-top: 10px;
}

.bb-wca-booking--portal {
	margin: 10px 0 0;
	padding: 0;
	border: 0;
	background: transparent;
	box-shadow: none;
}

.bb-wca-booking--portal::before,
.bb-wca-booking--portal .bb-wca-booking__header {
	display: none;
}

.bb-wca-booking--portal .bb-wca-booking__layout {
	grid-template-columns: minmax(220px, 280px) minmax(240px, 1fr);
	gap: 10px;
}

.bb-wca-booking--portal .bb-wca-booking__field,
.bb-wca-booking--portal .bb-wca-time-field {
	padding: 10px;
	box-shadow: none;
}

.bb-wca-booking--portal .bb-wca-calendar__surface {
	gap: 8px;
	padding: 10px;
	box-shadow: none;
}

.bb-wca-booking--portal .bb-wca-calendar__nav {
	grid-template-columns: 36px 1fr 36px;
	gap: 8px;
}

.bb-wca-booking--portal .bb-wca-calendar__nav-button {
	width: 36px;
	height: 36px;
}

.bb-wca-booking--portal .bb-wca-calendar__title {
	font-size: 15px;
}

.bb-wca-booking--portal .bb-wca-calendar__weekdays,
.bb-wca-booking--portal .bb-wca-calendar__grid {
	gap: 5px;
}

.bb-wca-booking--portal .bb-wca-calendar__day {
	padding: 4px 2px;
	font-size: 12px;
}

.bb-wca-booking--portal .bb-wca-calendar__day-number {
	font-size: 13px;
}

.bb-wca-booking--portal .bb-wca-time-grid {
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 7px;
}

.bb-wca-booking--portal .bb-wca-time-option {
	min-height: 42px;
	padding: 7px 5px;
	font-size: 12px;
}

.bb-wca-booking--portal .bb-wca-booking__hint {
	padding: 10px;
}

.bb-wca-danger-action {
	color: #a33b3b;
}

.bb-wca-calendar__day:hover,
.bb-wca-calendar__day:focus-visible {
	border-color: #3a8f69;
	background: linear-gradient(180deg, #f1faf5 0%, #e7f4ed 100%);
	box-shadow: 0 0 0 3px rgba(58, 143, 105, 0.14);
	color: #16563c;
	outline: none;
}

.bb-wca-calendar__day.is-outside {
	background: linear-gradient(180deg, #fbfcfc 0%, #f6f8f7 100%);
	color: #a2afa9;
	box-shadow: none;
}

.bb-wca-calendar__day.is-today {
	border-color: #b9d9ca;
	background: linear-gradient(180deg, #eff8f3 0%, #e5f2ea 100%);
	color: #1b6d48;
}

.bb-wca-calendar__day.is-selected {
	border-color: #5cc08a;
	background: linear-gradient(180deg, #3fa06f 0%, #1c6c4a 100%);
	box-shadow: 0 18px 28px rgba(23, 93, 63, 0.34);
	color: #ffffff;
	transform: translateY(-1px);
}

.bb-wca-calendar__day.is-selected .bb-wca-calendar__day-status {
	color: rgba(255, 255, 255, 0.88);
}

.bb-wca-calendar__day:disabled {
	cursor: not-allowed;
	border-color: #e7edeb;
	background: linear-gradient(180deg, #f8faf9 0%, #f1f4f3 100%);
	color: #bcc5c1;
	box-shadow: none;
}

.bb-wca-calendar__day.is-closed {
	border-color: #edc6c6;
	background: linear-gradient(180deg, #fff7f6 0%, #f9eceb 100%);
	color: #8a3636;
	box-shadow: 0 8px 16px rgba(138, 54, 54, 0.08);
}

.bb-wca-calendar__day.is-closed .bb-wca-calendar__day-status {
	color: #a34949;
}

.bb-wca-calendar__day.is-closed:hover,
.bb-wca-calendar__day.is-closed:focus-visible {
	border-color: #d08f8f;
	background: linear-gradient(180deg, #fff2f1 0%, #f7e3e1 100%);
	box-shadow: 0 0 0 3px rgba(176, 83, 83, 0.12);
	color: #7b2d2d;
}

.bb-wca-calendar__day.is-closed:disabled {
	cursor: not-allowed;
	border-color: #e8cfcf;
	background: linear-gradient(180deg, #fff7f6 0%, #f9efee 100%);
	color: #9b5a5a;
	box-shadow: none;
}

.bb-wca-calendar__day.is-closed.is-outside {
	background: linear-gradient(180deg, #fcf7f7 0%, #f7efef 100%);
	color: #bc8f8f;
}

.bb-wca-booking.is-date-locked .bb-wca-date-field {
	border-color: #d9e3de;
	background: linear-gradient(180deg, #fafcfb 0%, #f3f7f5 100%);
}

.bb-wca-booking.is-date-locked .bb-wca-date-helper {
	border-color: #d6e0db;
	background: linear-gradient(180deg, #f6f8f7 0%, #eef3f1 100%);
	color: #6e7f78;
}

.bb-wca-booking.is-date-locked .bb-wca-date-trigger {
	background: linear-gradient(180deg, #f6f8f7 0%, #eef3f1 100%);
	color: #7d8c86;
	box-shadow: inset 0 0 0 1px rgba(46, 58, 53, 0.4);
}

.bb-wca-booking.is-date-locked .bb-wca-date-value {
	color: #8ea098;
}

.bb-wca-booking__slots {
	position: relative;
	min-height: 44px;
}

.bb-wca-slots-panel .bb-wca-time-field {
	padding: 0;
	border: 0;
	background: transparent;
	box-shadow: none;
}

.bb-wca-time-group {
	display: grid;
	gap: 10px;
}

.bb-wca-time-group + .bb-wca-time-group {
	margin-top: 4px;
}

.bb-wca-time-group__title {
	color: #72817a;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0;
	text-transform: uppercase;
}

.bb-wca-booking.has-slots .bb-wca-booking__slots {
	min-height: 0;
}

.bb-wca-booking.is-loading .bb-wca-booking__slots::after {
	content: "";
	position: absolute;
	top: 13px;
	right: 13px;
	width: 18px;
	height: 18px;
	border: 2px solid #cbd8d3;
	border-top-color: #1f7a5c;
	border-radius: 50%;
	animation: bb-wca-spin 0.8s linear infinite;
}

.bb-wca-time-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px;
}

.bb-wca-time-option {
	appearance: none;
	display: grid;
	align-content: center;
	justify-items: center;
	gap: 4px;
	width: 100%;
	min-height: 54px;
	padding: 10px 10px;
	border: 1px solid #d9e4df;
	border-radius: 8px;
	background: linear-gradient(180deg, #ffffff 0%, #f4f8f6 100%);
	color: #17251f;
	cursor: pointer;
	font-family: inherit;
	font-size: 13px;
	font-weight: 800;
	line-height: 1.2;
	text-transform: none;
	box-shadow: 0 12px 22px rgba(20, 31, 27, 0.05);
	transition: background-color 160ms ease, border-color 160ms ease, box-shadow 160ms ease, color 160ms ease, transform 160ms ease;
}

.bb-wca-time-option__label {
	display: block;
	font-variant-numeric: tabular-nums;
}

.bb-wca-time-option__status {
	display: block;
	color: #a24d49;
	font-size: 10px;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
}

.bb-wca-time-option:hover,
.bb-wca-time-option:focus-visible {
	border-color: #4aa678;
	background: linear-gradient(180deg, #f1faf5 0%, #e8f4ed 100%);
	box-shadow: 0 0 0 3px rgba(58, 143, 105, 0.14);
	color: #174e37;
	outline: none;
}

.bb-wca-time-option.is-selected {
	border-color: #60c58e;
	background: linear-gradient(180deg, #3da16f 0%, #1b6e4b 100%);
	box-shadow: 0 18px 28px rgba(21, 91, 67, 0.28);
	color: #ffffff;
}

.bb-wca-time-option:active:not(:disabled):not(.is-locked) {
	transform: translateY(1px);
}

.bb-wca-time-option.is-locked,
.bb-wca-time-option:disabled {
	cursor: not-allowed;
	border-color: #e0bbbb;
	background: linear-gradient(180deg, #fff3f2 0%, #f9eaea 100%);
	box-shadow: none;
	color: #8b4340;
	opacity: 1;
}

.bb-wca-booking__hint {
	display: grid;
	gap: 4px;
	margin: 0;
	padding: 14px 15px;
	border: 1px solid #dce7e1;
	border-radius: 8px;
	background: linear-gradient(180deg, #fbfdfc 0%, #f4f8f6 100%);
	color: #67756f;
	line-height: 1.5;
}

.bb-wca-booking__hint-title {
	display: block;
	color: #2e3d37;
	font-size: 12px;
	font-weight: 800;
	line-height: 1.35;
	text-transform: uppercase;
}

.bb-wca-booking__hint-text {
	display: block;
}

.bb-wca-booking__hint-footer {
	display: block;
	color: #6c7b75;
	font-size: 11px;
	font-weight: 600;
	line-height: 1.35;
}

.bb-wca-booking__hint-action {
	appearance: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: fit-content;
	min-height: 40px;
	margin-top: 4px;
	padding: 0 12px;
	border: 1px solid #c9d9d1;
	border-radius: 8px;
	background: linear-gradient(180deg, #ffffff 0%, #f1f6f3 100%);
	color: #1f4f3a;
	font-family: inherit;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.1;
	text-decoration: none;
	cursor: pointer;
	transition: background-color 160ms ease, border-color 160ms ease, box-shadow 160ms ease, color 160ms ease, transform 160ms ease;
}

.bb-wca-booking__hint-action:hover,
.bb-wca-booking__hint-action:focus-visible {
	border-color: #4aa678;
	background: linear-gradient(180deg, #f2f9f5 0%, #e7f3ec 100%);
	box-shadow: 0 0 0 3px rgba(58, 143, 105, 0.14);
	color: #174e37;
	outline: none;
}

.bb-wca-booking__hint-action:active {
	transform: translateY(1px);
}

.bb-wca-booking__hint.is-error .bb-wca-booking__hint-action {
	border-color: #dba9a5;
	background: linear-gradient(180deg, #fff7f6 0%, #f8eceb 100%);
	color: #7f2f2d;
}

.bb-wca-booking__hint.is-empty .bb-wca-booking__hint-action {
	border-color: #d7cda3;
	background: linear-gradient(180deg, #fbf7ea 0%, #f3edd8 100%);
	color: #5d5534;
}

.bb-wca-booking__hint.is-error {
	border-color: #e4b5b2;
	background: linear-gradient(180deg, #fff3f2 0%, #faeceb 100%);
	color: #8f3330;
}

.bb-wca-booking__hint.is-error .bb-wca-booking__hint-title,
.bb-wca-booking__hint.is-error .bb-wca-booking__hint-footer {
	color: #7f2f2d;
}

.bb-wca-booking__hint.is-empty {
	border-color: #dddab8;
	background: linear-gradient(180deg, #fbf8ec 0%, #f6f2df 100%);
	color: #685f3b;
}

.bb-wca-booking__hint.is-empty .bb-wca-booking__hint-title,
.bb-wca-booking__hint.is-empty .bb-wca-booking__hint-footer {
	color: #5d5534;
}

.bb-wca-booking__hint.is-loading {
	padding-right: 42px;
	background: linear-gradient(180deg, #f1faf5 0%, #e8f4ed 100%);
	color: #355142;
}

.bb-wca-booking__hint.is-loading .bb-wca-booking__hint-title,
.bb-wca-booking__hint.is-loading .bb-wca-booking__hint-footer {
	color: #2f4c3f;
}

.bb-wca-booking__summary {
	display: grid;
	gap: 6px;
	margin-top: 10px;
	padding: 14px;
	border: 1px solid #c8dfd3;
	border-radius: 8px;
	background: linear-gradient(180deg, #f4fbf7 0%, #eaf5ef 100%);
	box-shadow: 0 16px 26px rgba(20, 31, 27, 0.05);
}

.bb-wca-booking__summary span {
	color: #7fd0a4;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
}

.bb-wca-booking__summary strong {
	color: #163022;
	font-size: 17px;
	line-height: 1.4;
	font-variant-numeric: tabular-nums;
}

.bb-wca-booking__summary[hidden] {
	display: none;
}

form.cart .bb-wca-booking ~ .single_add_to_cart_button,
form.cart .bb-wca-booking ~ .quantity + .single_add_to_cart_button {
	display: block;
	width: fit-content;
	min-height: 56px;
	padding: 0 28px;
	margin: 12px auto 0;
	border: 0;
	border-radius: 8px;
	background: linear-gradient(180deg, #2e8f62 0%, #1d6f4a 100%);
	box-shadow: 0 18px 30px rgba(22, 95, 63, 0.22);
	color: #ffffff;
	font-size: 15px;
	font-weight: 800;
	letter-spacing: 0;
	transition: background-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

form.cart .bb-wca-booking ~ .single_add_to_cart_button:hover,
form.cart .bb-wca-booking ~ .single_add_to_cart_button:focus-visible,
form.cart .bb-wca-booking ~ .quantity + .single_add_to_cart_button:hover,
form.cart .bb-wca-booking ~ .quantity + .single_add_to_cart_button:focus-visible {
	background: linear-gradient(180deg, #38a370 0%, #216d4a 100%);
	box-shadow: 0 20px 36px rgba(22, 95, 63, 0.26);
	color: #ffffff;
	outline: none;
}

form.cart .bb-wca-booking ~ .single_add_to_cart_button:active,
form.cart .bb-wca-booking ~ .quantity + .single_add_to_cart_button:active {
	transform: translateY(1px);
}

@keyframes bb-wca-spin {
	to {
		transform: rotate(360deg);
	}
}

@media (max-width: 640px) {
	.bb-wca-booking {
		margin: 16px 0;
		padding: 12px;
	}

	.bb-wca-booking__header {
		margin-bottom: 12px;
		padding-bottom: 12px;
	}

	.bb-wca-booking__header strong {
		font-size: 21px;
	}

	.bb-wca-booking__field,
	.bb-wca-time-field {
		padding: 12px;
	}

	.bb-wca-booking__section-head {
		grid-template-columns: 28px minmax(0, 1fr);
		gap: 10px;
	}

	.bb-wca-booking__section-head--compact {
		grid-template-columns: minmax(0, 1fr);
		gap: 0;
	}

	.bb-wca-booking__section-step {
		width: 28px;
		height: 28px;
		font-size: 12px;
	}

	form.variations_form.bb-wca-has-booking .variations,
	form.variations_form.bb-wca-has-booking .variations tbody,
	form.variations_form.bb-wca-has-booking .variations tr,
	form.variations_form.bb-wca-has-booking .variations th,
	form.variations_form.bb-wca-has-booking .variations td {
		display: block;
		width: 100%;
	}

	form.variations_form.bb-wca-has-booking .variations th {
		margin-bottom: 6px;
	}

	.bb-wca-calendar {
		width: 100%;
		margin-top: 6px;
		padding: 2px 0 0;
	}

	.bb-wca-calendar__surface {
		gap: 14px;
		padding: 10px;
	}

	.bb-wca-calendar__weekdays,
	.bb-wca-calendar__grid {
		grid-template-columns: repeat(7, minmax(0, 1fr));
		gap: 4px;
	}

	.bb-wca-calendar__day {
		min-height: 0;
		font-size: 13px;
		padding: 4px 2px;
	}

	.bb-wca-date-display,
	.bb-wca-date-trigger {
		min-height: 64px;
		padding: 13px 14px;
	}

	.bb-wca-date-value {
		font-size: 17px;
	}

	.bb-wca-date-trigger__icon {
		width: 38px;
		height: 38px;
		flex-basis: 38px;
		font-size: 20px;
	}

	.bb-wca-time-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 8px;
	}

	.bb-wca-time-option {
		min-height: 44px;
		padding: 8px 6px;
		font-size: 12px;
	}

	.bb-wca-time-option__status {
		font-size: 9px;
	}

	.bb-wca-customer-appointment,
	.bb-wca-customer-appointment__actions {
		display: grid;
		grid-template-columns: 1fr;
	}

	.bb-wca-customer-reschedule__fallback,
	.bb-wca-booking--portal .bb-wca-booking__layout {
		grid-template-columns: 1fr;
	}

	.bb-wca-date-selection strong,
	.bb-wca-slots-selected-date strong {
		font-size: 16px;
	}

	form.cart .bb-wca-booking ~ .single_add_to_cart_button,
	form.cart .bb-wca-booking ~ .quantity + .single_add_to_cart_button {
		width: 100%;
	}
}

@media (max-width: 420px) {
	.bb-wca-booking {
		padding: 10px;
	}

	.bb-wca-booking__field,
	.bb-wca-time-field {
		padding: 10px;
	}

	.bb-wca-calendar__surface {
		padding: 8px;
	}

	.bb-wca-calendar__weekdays,
	.bb-wca-calendar__grid {
		gap: 3px;
	}

	.bb-wca-calendar__day {
		font-size: 12px;
	}

	.bb-wca-calendar__day-number {
		font-size: 14px;
	}

	.bb-wca-time-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.bb-wca-date-value {
		font-size: 16px;
	}

	.bb-wca-date-trigger__icon {
		width: 34px;
		height: 34px;
		flex-basis: 34px;
		font-size: 18px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.bb-wca-booking *,
	.bb-wca-booking *::before,
	.bb-wca-booking *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}
