.booking-widget {
	margin-top: 8px;
}

.booking-widget .title {
	font-family: var(--georgia);
	font-weight: normal;
	font-size: 40px;
	line-height: 1;
	color: var(--white);
	display: none;
}

.booking-widget .input-col {
	position: relative;
	z-index: 1;
}

.booking-widget .input-col + .input-col {
	z-index: 2;
}

.booking-widget .tooltip {
	position: absolute;
	top: -12px;
	left: 50%;
	transform: translate(-50%, -90%);
	width: 100%;
	max-width: 160px;
	padding: var(--space-2);
	background: var(--white);
	box-shadow: var(--shadow-md);
	border-radius: 6px;
	color: var(--black);
	line-height: 1.2;
	font-size: var(--text-sm);
	text-align: center;
	opacity: 0;
	transition: transform .3s ease, opacity .3s ease;
	pointer-events: none;
}

.booking-widget .tooltip::before {
	position: absolute;
	bottom: -19px;
	left: 50%;
	transform: translateX(-50%);
	display: block;
	width: var(--space-5);
	height: var(--space-5);
	border: 10px solid transparent;
	border-top-color: var(--white);
	content: '';
}

.booking-widget .tooltip.active {
	opacity: 1;
	transform: translate(-50%, -100%);
}

.booking-widget label {
	display: block;
	font-family: var(--georgia);
	font-weight: normal;
	font-size: 17px;
	line-height: 1;
	color: var(--grey-alt-2);
	flex-shrink: 0;
	display:  flex;
	background-color: var(--white);
	align-items: center;
	padding-right:  5px;
}

.booking-widget .date-inp {
	position: relative;
	width: 134px;
	border: 3px solid transparent;
	background-color: var(--white);
	font-family: var(--averta-semi);
	color: var(--blue);
	font-size: 15px;
	padding-left: 20px;
	padding-right: -12px;
	display: flex;
	justify-content: flex-start;
}

.booking-widget .date-inp:before {
	position: absolute;
	left: 0;
	bottom: 0;
	content: '\f073';
	font-family: 'Font Awesome 5 Free';
	pointer-events: none;
}

.booking-widget .date-inp:after {
	content: '\f0d7';
	display: inline;
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	font-size: 12px;
	pointer-events: none;
}

.booking-widget .date-inp.error {
	border: 3px solid var(--red);
	background-color: #ffcece;
}

.booking-widget .date-inp::-webkit-calendar-picker-indicator {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	padding: 0;
	margin: 0;
	opacity: 0;
}

.booking-widget .submit-button {
	width: 100%;
	padding: 23px 80px 21px 30px;
}

@media (min-width: 375px) {
	.booking-widget .date-inp {
		background-position: var(--space-4) center;
	}
}

.booking-widget {
	position: relative;
	z-index: 12;
	margin-bottom: 30px;
	color: var(--white);
}

.booking-widget .row {
	position: absolute;
	top: 0;
	left: 0;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 3px;
	width: 100%;
	max-width: 1186px;
	padding: 54px 31px var(--space-5);
}

.booking-widget .img-cont {
	position: relative;
	width: 100%;
}

.booking-widget .img-cont:before {
	position: absolute;
	content: '';
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	background: rgba(0,0,0,.2);
	pointer-events: none;
}

.booking-widget .img-cont img {
	width: 100%
}

.booking-widget .row::before,
.booking-widget .row::after {
	display: none;
}

.booking-widget .input-col {
	width: 100%;
	margin: 0 auto;
}

.booking-widget .input-and-label {
	display: flex;
	width:  100%;
	min-width: 242px;
	padding: 11px 19px 11px 19px;
	background: var(--white);
	border-radius: 4px;
}

@media (min-width: 64em) {
	.booking-widget .input-and-label {
		padding: 20px 19px 18px;
	}
}

.booking-widget .input-col.button {
	display: flex;
	justify-content: center;
	margin-top: 9px;
}

@media (min-width: 40em) {
	.booking-widget {
		margin-top: 24px;
	}
	.booking-widget .row {
		flex-direction: row;
		flex-wrap: wrap;
		height: 100%;
		align-items: center;
		align-content: center;
		padding: 0 40px;
	}

	.booking-widget .title {
		width: 100%;
		text-align: left;
	}

	.booking-widget .input-col {
		flex: 1 0 calc(50% - var(--space-4));
		width: auto;
		max-width: none;
		margin: 0;
	}

	.booking-widget .input-col.button {
		width: 100%;
		justify-content: flex-end;
	}
	
}

@media (min-width: 64em) {
	.booking-widget {
		margin-bottom: 60px;
	}

	.slideshow-container .booking-widget {
		margin-top: -20px;
	}

	.booking-widget .row {
		flex-wrap: nowrap;
		justify-content: space-between;
		left: 50%;
		transform: translateX(-50%);
		display:  grid;
		grid-template-columns: 1fr repeat(2, 251px) 215px;
		gap: 0;
	}

	.booking-widget .title {
		display: unset;
		margin-right: 5px;
	}

	.booking-widget .title,
	.booking-widget .input-col.button {
		width: auto;
	}

	.booking-widget .input-col.button {
		margin-top: var(--space-8);
	}

	.booking-widget .input-col {
		flex: 1 0 auto;
	}

	.booking-widget .input-col:first-of-type .input-and-label {
		border-top-right-radius: 0;
		border-bottom-right-radius: 0;
		padding-left: 27px;
	}

	.booking-widget .input-col:nth-of-type(2) .input-and-label {
		border-top-left-radius: 0;
		border-bottom-left-radius: 0;
		margin-left: -1px;
	}

	.booking-widget .input-and-label {
		flex-direction: row;
		align-items: stretch;
	}
	
	.booking-widget .submit-button {
		padding-left: 28px;
	}

	.booking-widget .shared-button-mega:after {
		right: 34px;
	}

	.booking-widget label {
		padding-right:  8px;
	}
	.booking-widget .submit-button {
		margin-left: 2px;
	}
}

@media (min-width: 90em) {
	.booking-widget .row {
		gap: 0;
		padding-right: 43px;
	}

	.booking-widget .submit-button {
		margin-left: 2px;
	}
}

/* Booking panel */
.booking-panel {
	display: flex;
	align-items: center;
	position: relative;
	margin-bottom: 30px;
	margin-top: 25px;
}

.booking-panel .booking-widget {
	margin-top: 0;
}

.booking-panel .bg-img {
	position: absolute;
	top: 0;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: top;
	width: 100%;
	height: calc(100% - 22px);
}

.booking-panel .bg-img:before {
	position: absolute;
	content: '';
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	background: rgba(0,0,0,.2);
}

.booking-panel .booking-widget {
	margin-bottom: 0;
	padding-bottom: 0;
}

.booking-panel .booking-widget .row {
	padding-top: 34px;
	padding-bottom: 26px;
}

.booking-panel .imagebox {
	display: grid;
	grid-template-columns: 1fr;
	margin-bottom: 0;
}

.booking-panel .imagebox .block-inner {
	background-color: var(--white);
	padding: 5px;
	padding-bottom: 10px;
	margin: 0 11px 14px 12px;
	border-radius: 4px;
	box-shadow: var(--shadow-xl);
}
.booking-panel .imagebox > .columns:last-child .block-inner {
	margin-bottom: 0;
}

.booking-panel .imagebox .featured {
	top: 15px;
	padding: 10px 26px 9px;
}

.booking-panel .imagebox .featured > p {
	letter-spacing: normal;
	font-size: 15px;
}

.booking-panel .imagebox .block-text {
	padding-left: 9px;
	padding-right: 9px;
}

.booking-panel .imagebox :is(.slide-title, .slide-title > a) {
	font-family: var(--averta-bold);
	font-size: 20px;
	line-height: 1.2;
}

.booking-panel .imagebox .slide-title {
	margin-bottom: 7px;
}

.booking-panel .imagebox p {
	font-size: 14px;
	line-height: 1.25;
}

.booking-panel .imagebox .block-btn {
	font-size: 17px;
	font-family: var(--averta-extra);
	text-decoration: underline;
	text-underline-offset: 1px;
	margin-top: 4px;
}

.booking-panel .booking-widget .img-cont img,
.booking-panel .booking-widget .img-cont:before {
	display: none;
	content: none;
}

.booking-panel .booking-widget .title {
	display: none;
}

.booking-panel .booking-widget .row {
	grid-template-columns:  1fr 1fr;
	position: static;
}

@media (min-width: 40em) {
	.booking-panel .imagebox {
		display: grid;
		grid-template-columns: 1fr 1fr;
	}

	.booking-panel .imagebox .block-inner {
		height: 100%;
	}

	.booking-panel .imagebox .item {
		height: calc(100% - 14px);
	}

	.booking-panel .bg-img {
		height: calc(100% - 32px);
	}
}

@media (min-width: 64em) {
	.booking-panel {
		margin-top: 0;
		margin-bottom: 100px;
	}

	.booking-panel .bg-img {
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		height: 310px;
	}

	.booking-panel .imagebox {
		margin-top: 7px;
		gap: 12px;
	}

	.booking-panel .booking-widget .input-and-label {
		padding-top: 11px;
		padding-bottom: 11px;
	}

	.booking-panel .booking-widget .submit-button {
		padding-top: 22px;
		padding-bottom: 21px;
	}

	.booking-panel .imagebox .block-text {
		padding-top: 14px;
		padding-bottom: 22px;
	}

	.booking-panel .imagebox .slide-title {
		margin-bottom: 5px;
	}

	.booking-panel .imagebox .block-btn {
		margin-top: 5px;
	}

	.booking-panel .booking-widget .row {
		transform: translateY(-1px);
	}

	.booking-panel .booking-widget {
		width: 100%;
	}

	.booking-panel .shared-button-mega {
		padding-right: 46%;
		text-align: right;
	}

	.booking-panel .shared-button-mega:after {
		right: 36%;
	}

	@media (hover: hover) {
		.booking-panel .shared-button-mega:hover:after {
			right: 35%;
		}
	}

	.booking-panel .booking-widget .input-col .input-and-label {
		min-width: 250px;
	}

	.booking-panel .booking-widget .columns {
		padding-bottom: 0;
	}

	.booking-panel .booking-widget .input-col:first-of-type .input-and-label {
		border-top-right-radius: 4px;
		border-bottom-right-radius: 4px;
		padding-left: 17px;
	}

	.booking-panel .booking-widget .input-col:nth-of-type(2) .input-and-label {
		border-top-left-radius: 4px;
		border-bottom-left-radius: 4px;
		padding-left: 17px;
		margin-left: 0px;
	}

	.booking-panel .booking-widget .row {
		display:  grid;
		gap: 4px;
		padding: 0;
	}

	.booking-panel .booking-widget .input-col:last-of-type {
		grid-column: 1/3;
	}

	.booking-panel .imagebox .block-inner {
		margin: 0;
	}

	.booking-panel .inner {
		display: grid;
		grid-template-columns: 48fr 66fr;
		align-items: center;
		max-width: 1230px;
		margin: 0 auto;
		padding: 0 10px;
		gap: 10px
	}

	.booking-panel .submit-button {
		margin-left: 0;
	}
}

@media (min-width: 80em) {
	.booking-panel .inner {
		gap: 25px
	}

	.booking-panel .imagebox {
		margin-right: 23px;
	}

	.booking-panel .imagebox .booking-imagebox-slide {
		height: 100%;
	}
}