.ttb-booking-calendar {
	box-sizing: border-box;
	border: 1px solid #dcdcde;
	border-radius: 8px;
	padding: 20px;
	margin-bottom: 20px;
	margin-left: auto;
	margin-right: auto;
	max-width: 620px;
	width: 100%;
	background: #fff;
	font-size: clamp(13px, 1.5vw, 15px);
	overflow: hidden;
}

.ttb-booking-calendar *,
.ttb-booking-calendar *::before,
.ttb-booking-calendar *::after {
	box-sizing: border-box;
}

.ttb-booking-calendar--duplicate {
	display: none;
}

.ttb-booking-calendar__title {
	margin: 0 0 16px;
	font-size: clamp(16px, 2vw, 20px);
	line-height: 1.4;
}

.ttb-booking-calendar__nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 16px;
}

.ttb-booking-calendar__nav-button {
	border: 1px solid #c3c4c7;
	border-radius: 6px;
	padding: 8px 12px;
	background: #f6f7f7;
	color: #1d2327;
	cursor: pointer;
	font-size: 0.9375rem;
}

.ttb-booking-calendar__nav-button:hover,
.ttb-booking-calendar__nav-button:focus {
	background: #edf0f0;
}

.ttb-booking-calendar__month {
	font-weight: 700;
	font-size: clamp(15px, 1.8vw, 18px);
	text-align: center;
	flex: 1;
	min-width: 0;
}

.ttb-booking-calendar__weekdays,
.ttb-booking-calendar__days {
	display: grid;
	grid-template-columns: repeat(7, minmax(0, 1fr));
	gap: 8px;
}

.ttb-booking-calendar__weekdays {
	margin-bottom: 8px;
	font-size: clamp(11px, 1.25vw, 13px);
	font-weight: 600;
	text-align: center;
	color: #50575e;
}

.ttb-booking-calendar__weekdays span,
.ttb-booking-calendar__day,
.ttb-booking-calendar__day-empty {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: clamp(34px, 5.8vw, 44px);
	border-radius: 6px;
}

.ttb-booking-calendar__day {
	aspect-ratio: 1 / 0.78;
	border: 1px solid #dcdcde;
	background: #fff;
	color: #1d2327;
	cursor: pointer;
	font: inherit;
	font-size: clamp(13px, 1.6vw, 16px);
	line-height: 1;
	padding: 4px;
}

.ttb-booking-calendar__day:hover,
.ttb-booking-calendar__day:focus {
	border-color: #2271b1;
	outline: none;
}

.ttb-booking-calendar__day--today {
	border-color: #72aee6;
}

.ttb-booking-calendar__day--in-range {
	background: #e8f2fc;
	border-color: #b6d4ef;
}

.ttb-booking-calendar__day--selected,
.ttb-booking-calendar__day--range-end {
	background: #2271b1;
	border-color: #2271b1;
	color: #fff;
}

.ttb-booking-calendar__day-empty {
	background: #f6f7f7;
	color: #8c8f94;
	cursor: default;
}

.ttb-booking-calendar__details {
	margin-top: 16px;
	font-size: clamp(13px, 1.45vw, 15px);
}

.ttb-booking-calendar__details p {
	margin: 0 0 8px;
}

.ttb-booking-calendar__details p:last-child {
	margin-bottom: 0;
}

.ttb-booking-calendar__detail {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 6px;
	min-width: 0;
}

.ttb-booking-calendar__detail-label {
	font-weight: 700;
	color: #1d2327;
}

.ttb-booking-calendar__detail-value {
	color: #1d2327;
}

.ttb-booking-calendar__detail--surcharge-note .ttb-booking-calendar__detail-value {
	overflow-wrap: anywhere;
}

.ttb-booking-calendar__message {
	color: #50575e;
}

.ttb-booking-calendar__participants {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 8px;
}

.ttb-booking-calendar__participants-label {
	display: inline-flex;
	align-items: center;
	margin: 0;
	width: auto;
	font-weight: 700;
	color: #1d2327;
	white-space: nowrap;
}

.ttb-booking-calendar__participants-label::after {
	content: ":";
}

.ttb-booking-calendar__participants-input {
	display: inline-block;
	flex: 0 0 100px;
	width: 100px;
	max-width: 120px;
	min-height: 40px;
	padding: 6px 8px;
	border: 1px solid #c3c4c7;
	border-radius: 6px;
}

.ttb-booking-calendar__payment-options {
	margin-top: 12px;
	min-width: 0;
}

.ttb-booking-calendar__detail--payment-option {
	margin-bottom: 8px;
}

.ttb-booking-calendar__payment-option {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 10px 12px;
	margin-bottom: 10px;
	border: 1px solid #dcdcde;
	border-radius: 8px;
	background: #f9f9f9;
	width: 100%;
	min-width: 0;
}

.ttb-booking-calendar__payment-radio {
	margin-top: 3px;
	flex: 0 0 auto;
}

.ttb-booking-calendar__payment-copy {
	display: flex;
	flex-direction: column;
	gap: 4px;
	flex: 1 1 auto;
	min-width: 0;
}

.ttb-booking-calendar__payment-title {
	font-weight: 700;
	color: #1d2327;
}

.ttb-booking-calendar__payment-description {
	color: #50575e;
	font-size: 0.875rem;
}

.ttb-booking-calendar__payment-inline-value {
	font-weight: 400;
	color: #1d2327;
}

.ttb-booking-calendar__detail--amount-to-pay-now {
	margin-top: 12px;
}

form.cart .ttb-booking-calendar ~ button.single_add_to_cart_button,
form.cart .ttb-booking-calendar ~ .single_add_to_cart_button.button,
form.cart .ttb-booking-calendar ~ button[name="add-to-cart"] {
	min-height: 46px;
	padding: 12px 18px;
	font-size: clamp(14px, 1.6vw, 16px);
}

@media (max-width: 768px) {
	.ttb-booking-calendar {
		padding: 18px;
		max-width: 100%;
	}

	.ttb-booking-calendar__nav {
		gap: 10px;
	}

	.ttb-booking-calendar__nav-button {
		padding: 8px 10px;
		font-size: 0.875rem;
	}

	.ttb-booking-calendar__weekdays,
	.ttb-booking-calendar__days {
		gap: 6px;
	}

	.ttb-booking-calendar__payment-option {
		padding: 10px;
	}

	form.cart .ttb-booking-calendar ~ button.single_add_to_cart_button,
	form.cart .ttb-booking-calendar ~ .single_add_to_cart_button.button,
	form.cart .ttb-booking-calendar ~ button[name="add-to-cart"] {
		width: 100%;
	}
}

@media (max-width: 640px) {
	.ttb-booking-calendar {
		padding: 16px;
	}

	.ttb-booking-calendar__nav {
		flex-wrap: wrap;
	}

	.ttb-booking-calendar__month {
		order: -1;
		flex-basis: 100%;
	}
}

@media (max-width: 480px) {
	.ttb-booking-calendar {
		padding: 14px;
		border-radius: 7px;
	}

	.ttb-booking-calendar__nav {
		gap: 8px;
		margin-bottom: 12px;
	}

	.ttb-booking-calendar__nav-button {
		min-height: 40px;
		padding: 7px 9px;
	}

	.ttb-booking-calendar__weekdays,
	.ttb-booking-calendar__days {
		gap: 4px;
	}

	.ttb-booking-calendar__weekdays span,
	.ttb-booking-calendar__day,
	.ttb-booking-calendar__day-empty {
		min-height: 32px;
	}

	.ttb-booking-calendar__day {
		aspect-ratio: 1 / 0.82;
		padding: 3px;
	}

	.ttb-booking-calendar__details {
		margin-top: 14px;
	}

	.ttb-booking-calendar__participants {
		gap: 6px;
	}

	.ttb-booking-calendar__participants-input {
		flex-basis: 96px;
		width: 96px;
		max-width: 110px;
		min-height: 38px;
	}

	.ttb-booking-calendar__payment-option {
		gap: 8px;
		padding: 9px;
	}

	.ttb-booking-calendar__payment-description {
		font-size: 0.8125rem;
	}

	form.cart .ttb-booking-calendar ~ button.single_add_to_cart_button,
	form.cart .ttb-booking-calendar ~ .single_add_to_cart_button.button,
	form.cart .ttb-booking-calendar ~ button[name="add-to-cart"] {
		min-height: 48px;
		padding: 12px 16px;
	}
}

@media (max-width: 360px) {
	.ttb-booking-calendar {
		padding: 12px;
	}

	.ttb-booking-calendar__nav {
		gap: 6px;
	}

	.ttb-booking-calendar__nav-button {
		flex: 0 1 auto;
		min-width: 0;
		padding: 7px 8px;
		font-size: 0.8125rem;
	}

	.ttb-booking-calendar__weekdays,
	.ttb-booking-calendar__days {
		gap: 3px;
	}

	.ttb-booking-calendar__weekdays span,
	.ttb-booking-calendar__day,
	.ttb-booking-calendar__day-empty {
		min-height: 28px;
	}

	.ttb-booking-calendar__day {
		aspect-ratio: 1 / 0.9;
	}

	.ttb-booking-calendar__participants-input {
		flex-basis: 90px;
		width: 90px;
	}

	.ttb-booking-calendar__payment-option {
		padding: 8px;
	}
}
