:root {
	--border-color: #A7BFDF;
	--text-color: #1A4B86;
	
}

/*old*/


/*Choose Services
TODO: auslagern in eigene css
*/

.bookingtable-wrapper {
	padding: 0px;
}
.wrap-preview {
	display: flex;
	align-items: center;
}
.reisezeitraum, .personen-wrapper {
	color: var(--text-color);
	border: 1px solid var(--border-color);
	cursor: pointer;
}
#booking-wrapper .personen-wrapper {
	display: flex;
    justify-content: space-between;
    align-items: center;
	margin-top: 5px;
	position: relative;
}
.toggleGuests {
	display: none;
}
.duration-wrapper, .personen-wrapper  {
	padding: 10px;
}
.persons {
	position: relative;
}
#guests {
	padding: 0px 20px;
}

.reisezeitraum * {
	margin: 0;
}

.reisezeitraum h2 {
	font-weight: bold;
	text-transform: uppercase;
	letter-spacing: 1.2px;
}

.reisezeitraum .fromdate, .reisezeitraum .tilldate {
	background: transparent;
	border: none;
	outline: none;
	padding: 0px 20px;
}

.reisezeitraum img.filter-white {
	filter: invert(100%) sepia(7%) saturate(7482%) hue-rotate(190deg) brightness(122%) contrast(102%);
	width: 50px;
}

.bookingtable-wrapper ul {
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
}

.clear-calendar {
	border: none;
	color: white;
}

.bookingtable-wrapper li {
	display: flex;
	width: 100%;
	align-items: center;
	justify-content: space-between;
}
.button-list {
	flex-wrap: wrap;
}
.error-button button{
	width: 100%;
}
.full-width-button {
	width: 100%;
	margin-bottom: 5px;
}

.bookingtable-wrapper #services_optional li>div.service-label,
.personen-wrapper li>div {
	width: auto;
	display: flex;
	justify-content: space-between;
	height: 100%;
	align-items: center;
}
.reisezeitraum>div {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.bookingtable-wrapper .total {
	min-width: max-content;
	text-align: right;
}
.bookingtable-wrapper #services_optional .total {
	min-width: 60px;
}

.bookingtable-wrapper #services_optional li>div.service-label {
	width: 100%;
}

.servicecount-wrapper,
.buttoncount-wrapper,
.checkbox-count-wrapper {
	width: 33%;
}

.servicecount-wrapper>div,
.buttoncount-wrapper>.number-wrapper {
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.hide-desktop {
	display: none;
	background: transparent;
	width: auto;
	transform: rotate(180deg);
}

.bookingtable-wrapper .servicecount-wrapper,
.buttoncount-wrapper {
	display: flex;
	align-items: center;
	min-height: 40px;
}

.servicecount-wrapper button,
.buttoncount-wrapper button {
	width: 50px;
	padding: 0px;
	height: 100%;
	outline: none;
}

.bookingtable-wrapper .mobile-wrapper,
.bookingtable-wrapper .mobile-wrapbtn {
	height: 100%;
	display: flex;
	align-items: center;
}

.bookingtable-wrapper .open-counter,
.bookingtable-wrapper .open-counter:hover,
.bookingtable-wrapper .open-counter:focus {
	background: transparent;
	width: auto;
	transform: rotate(180deg);
	height: 100%;
	padding: 0;
	border: none;
	outline: none;
}

.bookingtable-wrapper .open-counter img {
	margin-top: 0;
	width: 35px;
	filter: invert(25%) sepia(17%) saturate(912%) hue-rotate(159deg) brightness(93%) contrast(91%);
	transform: rotate(180deg);
}

.mandatory-rent {
	order: -1;
}

.personen-wrapper label {
	width: 50%;
}

.number-wrapper input[type=number] {
	border: none;
	text-align: center;
	width: 30px;
	outline: none;
	-moz-appearance: textfield;
	color: var(--text-color);
}
.number-wrapper input[type='number']::-webkit-inner-spin-button, input[type='number']::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.bookingtable-wrapper select {
	text-align: left;
	margin-right: auto;
	width: 75px;
}

.bookingtable-wrapper label,
.bookingtable-wrapper div {
	margin: 0;
	margin: 0;
	font-size: 14px;
	font-weight: 500;
	width: auto;
}

.bookingtable-wrapper button {
	border: none;
	color: white;
	cursor: pointer;
}

.bookingtable-wrapper button.inc {
	border-left: 1px solid #f1efec;
}



.close.open-counter img {
	transform: rotate(0deg);
}

.flex-wrap {
	flex-wrap: wrap;
}

.flex-wrap>div {
	width: 33%;
	text-align: right;
}

.service-label,
.person-label {
	position: relative;
	cursor: default;
	max-width: 50%;
	line-height: 18px;
}
li#service-inclusive {
    justify-content: space-between;
	padding: 5px 0px;
}


.service-label:hover .tooltip, .priceinfo-wrapper:hover .tooltip {
	opacity: 1;
}

.highlighted-service {
	background: var(--e-global-color-5f30aae);
}

.bookingtable-wrapper .invisible-row {
	opacity: 0;
	height: 0;
	border: none;
	min-height: 0;
}

.tooltip {
	opacity: 0;
	position: absolute;
	bottom: 37px;
	left: 50%;
	transform: translate(-50%, 0);
	background-color: var(--text-color);
	width: max-content !important;
	padding: 10px;
	color: white;
	pointer-events: none;
	text-align: center;
}

.service-label .tooltip {
	display: block;
}

.service-label.tooltip-flex {
	display: flex;
}

.bookingtable-wrapper .info-icon-wrapper {
	position: relative;
	margin-left: 5px;
}

.bookingtable-wrapper .info-icon {
	content: '\0069';
	border: 1px solid var(--border-color);
	color: var(--border-color);
	border-radius: 50%;
	height: 22px;
	width: 22px;
	right: 0px;
	display: flex;
	justify-content: center;
	align-items: center;
}

.tooltip:after {
	content: "";
	position: absolute;
	top: 100%;
	left: 50%;
	margin-left: -10px;
	border-width: 10px;
	border-style: solid;
	border-color: var(--text-color) transparent transparent transparent;
}
.highlighted-service {
	min-height: 50px;
}

@media only screen and (max-width: 1024px) {

	/* .bookingtable-wrapper #services_optional li > div, .reisezeitraum > div, .personen-wrapper li > div {
        width: 60%;
    } */
	.flex-wrap>div {
		width: auto;
	}
}

@media only screen and (max-width: 767px) {
	.reisezeitraum {
		flex-wrap: wrap;
	}

	.hide-desktop {
		display: block;
	}

	.duration-wrapper {
		flex-wrap: wrap;
	}

	.duration-wrapper input {
		width: 33%;
	}

	.duration-headline {
		justify-content: center;
		margin-top: 20px;
	}

	.reisezeitraum>div {
		flex-wrap: wrap;
	}

	.bookingtable-wrapper li {
		height: auto;
		min-height: 40px;
	}

	.bookingtable-wrapper .highlighted-service {
		min-height: 70px;
	}
	.servicecount-wrapper>div,
	.buttoncount-wrapper>.number-wrapper {
		border: none;
		width: auto;
	}
	.buttoncount-wrapper>div {
		height: 50px;
	}
	.mobile-wrapper button {
		width: 40px;
		height: 40px;
		min-height: 0;
	}

	.hide-mobile {
		order: 2;
	}

	.bookingtable-wrapper .flex-wrap .total {
		width: calc(100% - 50px);
	}
}



/*Choose Services
*/




/* Custom CSS */
#booking-wrapper {
	display: flex;
	flex-direction: column;
}

/* Farbcodes */
:root {
	--litepicker-day-width: 40px;
}



.litepicker .container__main {
	justify-content: center;
}

/* Litepicker */
.litepicker {
	order: -1;
	margin-bottom: 100px;
	font-family: 'Montserrat';
}

.litepicker .container__months .month-item-header div {
	font-size: 17px;
	color: var(--text-color);
}
#calender-wrapper .litepicker .container__months .month-item-header div>.month-item-name, #calender-wrapper .litepicker .container__months .month-item-header div>.month-item-year {
	font-weight: 500;
}

.litepicker .container__months .month-item-weekdays-row>div {
	font-size: 14px;
	font-weight: 500;
}

.litepicker .container__months.columns-3 {
	width: calc((var(--litepicker-month-width) * 3) + 80px);
}

.litepicker .container__months .month-item {
	padding: 10px;
}

.litepicker .container__months .month-item-weekdays-row {
	margin-bottom: 10px;
}

#calender-wrapper .litepicker .container__months .month-item-header button {
	background: transparent;
	outline: none;
    cursor: pointer;
}

.litepicker .container__days>div {
	border: 1px solid white;
	box-sizing: border-box;
}

.litepicker .container__days .day-item {
	color: white !important;
	border-radius: 50%;
	border: 6px solid white;
	font-size: 12px;
}

.litepicker .day-item {
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.litepicker .container__days .day-item.past,
.litepicker .container__days .day-item.past:hover {
	background: #F5F3F1;
	color: #C6C6C6 !important;
}

.litepicker .container__days .day-item.available {
	background: #36A763;
	cursor: pointer;
}

.litepicker .container__days .day-item.unavailable,
.litepicker .container__days .day-item.unavailable:hover {
	background: #C83742;
}

.litepicker .container__days .day-item.check-in,
.litepicker .container__days .day-item.is-locked.check-in:hover {
	background: #36A763;
	background: -moz-linear-gradient(to right, #C83742 50%, #36A763 50%);
	background: -webkit-linear-gradient(to right, #C83742 50%, #36A763 50%);
	background: linear-gradient(to right, #C83742 50%, #36A763 50%);
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#C83742', endColorstr='#C83742', GradientType=1);
}

.litepicker .container__days .day-item.check-out,
.litepicker .container__days .day-item.is-locked.check-out:not(.is-end-date):hover {
	background: #36A763;
	background: -moz-linear-gradient(to right, #36A763 50%, #C83742 50%);
	background: -webkit-linear-gradient(to right, #36A763 50%, #C83742 50%);
	background: linear-gradient(to right, #36A763 50%, #C83742 50%);
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#C83742', endColorstr='#C83742', GradientType=1);
}


/* on select*/
.litepicker .container__days .day-item.is-start-date,
.litepicker .container__days .day-item.is-start-date.is-locked:hover {
	border-top-left-radius: 50%;
	border-bottom-left-radius: 50%;
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
	background: #B38B50;
	border-right: none;
}

.litepicker .container__days .day-item.is-in-range {
	background: #B38B50;
	color: white;
	border-left: none;
	border-right: none;
}

.litepicker .container__days .day-item.is-end-date {
	border-top-right-radius: 50%;
	border-bottom-right-radius: 50%;
	border-top-left-radius: 0;
	border-bottom-left-radius: 0;
	background: #B38B50;
	border-left: none;
}


/* on hover */
.litepicker .container__days .day-item:hover {
	background: #B38B50;
	color: white;
	cursor: pointer;
	box-shadow: none;
}

.litepicker .container__days .day-item.is-locked.available:not(.is-start-date):not(.is-end-date):hover {
	background: #36A763;
}

/*Tooltipfix*/
.litepicker .container__tooltip:after,
.litepicker .container__tooltip:before {
	left: 30px;
}

.litepicker .container__tooltip {
	background: #7d8d9e;
	color: white;
	border-radius: 0;
}

.litepicker .container__tooltip:after {
	border-top: 4px solid #7d8d9e;
}

.month-item-header button {
	position: relative;
}


.month-item-header button.button-previous-month::before {
	transform: rotate(180deg);
}
#litepicker-wrapper .litepicker .container__months .month-item-header .button-next-month>svg, #litepicker-wrapper .litepicker .container__months .month-item-header .button-next-month>img,
#litepicker-wrapper .litepicker .container__months .month-item-header .button-previous-month>svg, #litepicker-wrapper .litepicker .container__months .month-item-header .button-previous-month>img,
#litepicker-wrapper .litepicker .container__months .month-item-header .button-previous-month:hover, #litepicker-wrapper .litepicker .container__months .month-item-header .button-next-month:hover {
	fill: var(--text-color);
	color: var(--text-color);
}

.litepicker .month-item button {
	display: flex;
	align-items: center;
}
.litepicker .button-next-month {
	justify-content: right;
}
.litepicker .button-previous-month {
	justify-content: left;
}
.litepicker .container__footer {
	margin: 0;
	border-radius: 0;
	box-shadow: none;
	background-color: white;
}

.litepicker .container__months {
	box-shadow: none;
	justify-content: center;
	border-radius: 0;
}





.litepicker .container__days .day-item.past,
.litepicker .container__days .day-item.past:hover {
	background: #DBE3EB;
    color: white!important;
}
.bookingtable-wrapper {
    color: var(--text-color);
}
.litepicker .container__days .day-item.available {
    background: #56b623;
}

.litepicker .container__days .day-item.unavailable, .litepicker .container__days .day-item.unavailable:hover {
	background: #d61313;
}
/* .litepicker .container__days .day-item.check-out, .litepicker .container__days .day-item.is-locked.check-out:not(.is-end-date):hover, .litepicker .container__days .day-item.check-in, .litepicker .container__days .day-item.is-locked.check-in:hover, .litepicker .container__days .day-item.is-locked.available:not(.is-start-date):not(.is-end-date):hover {
	background: var( --e-global-color-accent );
} */
.litepicker .container__days .day-item.check-in, .litepicker .container__days .day-item.is-locked.check-in:hover {
	background: #56b623;
	background: -moz-linear-gradient(to right, #d61313 50%, #56b623 50%);
	background: -webkit-linear-gradient(to right, #d61313 50%, #56b623 50%);
	background: linear-gradient(to right, #d61313 50%, #56b623 50%);
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#d61313', endColorstr='#d61313', GradientType=1);
}
.litepicker .container__days .day-item.check-out, .litepicker .container__days .day-item.is-locked.check-out:not(.is-end-date):hover {
	background: #56b623;
	background: -moz-linear-gradient(to right, #56b623 50%, #d61313 50%);
	background: -webkit-linear-gradient(to right, #56b623 50%, #d61313 50%);
	background: linear-gradient(to right, #56b623 50%, #d61313 50%);
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#d61313', endColorstr='#d61313', GradientType=1);
}
.litepicker .container__days .day-item.is-start-date, .litepicker .container__days .day-item.is-start-date.is-locked:hover, .litepicker .container__days .day-item.is-in-range, .litepicker .container__days .day-item.is-end-date {
	background: var( --e-global-color-accent );
}
.litepicker .container__days .day-item.is-locked.available:not(.is-start-date):not(.is-end-date):hover {
	background: #56b623;
}



.litepicker .container__tooltip {
	background: #A2BFE2;
}


.litepicker .container__tooltip:after {
	border-color: #A2BFE2 transparent transparent transparent;
}

#booking-wrapper .bookingtable-wrapper .servicecount-wrapper button, #booking-wrapper .buttoncount-wrapper button{
	border-radius: 50%;
	max-height: 25px;
	width: 25px;
	min-height: 25px;
	padding: 0;
	font-weight: 500;
}
.reisezeitraum img.filter-white {
	display: none;
}
#calender-wrapper {
    position: absolute;
    padding: 0;
    z-index: 1;
    right: 0;
	display: none;
	background: white;
}
#calender-wrapper, .toggleGuests {
	top: 52px;
	box-shadow: 10px 10px 30px #00000029;
}

#litepicker-wrapper .litepicker .container__months.columns-2 {
	width: calc((var(--litepicker-month-width) * 2) + 50px);
}

#litepicker-wrapper.singlemonth .litepicker{
	display: flex !important;
	justify-content: center;
}
button#calender_select {
    width: 100%;
    border: none;
    cursor: pointer;
}
ul#services_optional {
    border-top: 1px solid var(--border-color);
	border-bottom: 1px solid var(--border-color);
	padding: 10px 0px;
}
.formicon-dropdown {
	filter: invert(80%) sepia(12%) saturate(867%) hue-rotate(179deg) brightness(92%) contrast(92%);
    width: 14px;
}
.close .formicon-dropdown{
	transform: rotate(180deg);
}
.flex-wrap > .price {
    display: none;
}
#service-inclusive .service-label {
    font-size: 17px;
}
.highlighted-service .endprice-label, .finalsum.highlighted-service .total  {
	font-weight: bold;
	font-size: 17px;
}
#endprice .coupon .endprice-label, #endprice .coupon .total {
	color: #ff1616;
	font-weight: bold;
}
#endprice li.error-label div {
    color: #ff1616;
    line-height: 1.8;
}
.finalsum.highlighted-service {
	min-height: 30px;
}
.persons .toggleGuests {
    width: 100%;
	position: absolute;
    left: 0;
	background: white;
	z-index: 1;
}
.personen-wrapper .toggleGuests ul {
	padding: 12px;
}
#calender-shortcode .elementor-shortcode {
	display: flex;
	flex-direction: column;
}
#minprice-button {
	margin: 10px auto 0px auto;
	border: none;
	outline: none;
	cursor: pointer;
	width: 100%;
}
.wrap-calcservices-wrapper {
	display: none;
}
button#calcGuests {
    width: 100%;
}
#toggleGuests.open {
	display: block;
}
.toggleGuests ul {
	padding: 0px;
}
.toggleGuests ul li {
	padding: 0 10px;
}
.persons .toggleGuests, #calender-wrapper{
	border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
}
.lightgrey-button, #calcServices {
	background: #A2BFE2 !important;
	margin-top: 10px;
	font-size: 14px !important;
	border: none;
	cursor: pointer;
	outline: none;
}
.lightgrey-button {
	width: 49%;
}
#calcServices {
	width: 100%;
	background: var(--text-color) !important;
}
.full-width-btn {
	width: 100%;
}
.bookingtable-wrapper li.priceinfo-wrapper {
	justify-content: flex-start;
	margin-bottom: 10px;
}
.smallfont, .priceinfo-wrapper .tooltip {
	font-size: 12px;
	line-height: 1.4em;
	max-width: 350px;
	left: auto !important;
    right: -20px;
    transform: none;
}
.smallfont, .priceinfo-wrapper .tooltip:after {
    left: auto;
}
#service-inclusive .service-label {
	max-width: 80%;
}
.wrap-default-buttons {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
@media only screen and (min-width: 1025px) and (max-height: 820px) {
	.highlighted-service {
		min-height: 0px;
	}
	.bookingtable-wrapper .servicecount-wrapper, .buttoncount-wrapper {
		min-height: 35px;
	}
	ul#services_optional {
		padding: 5px 0px;
	}
	#stickybox {
		top: 75px;
	}
	.lightgrey-button {
		padding: 10px !important;
	}
}
@media only screen and (min-width: 1025px) and (max-height: 720px) {
	#stickybox {
		transform: scale(0.9);
		top: 45px;
	}
	#calender-wrapper {
		transform: scale(1.1);
	}
}
@media (min-width:768px) and (max-width:1024px) {
	.litepicker .container__footer button {
		width: 45%;
		margin-top: 5px;
		padding: 10px 0 !important;
	}
	#minprice-button {
		display: none;
	}

	.button-apply:after,
	.button-cancel:after {
		padding: 10px 0 !important;
	}
	

	.litepicker .container__footer {
		display: flex !important;
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: center;
	}

	.preview-date-range {
		width: 100% !important;
		text-align: center;
	}

	.litepicker .container__main .container__months {
		display: flex;
		flex-direction: row;
	}
}
@media (max-width:767px) {
	.litepicker .container__footer {
		display: flex;
		flex-direction: column;
		align-items: center;
	}

	.litepicker .container__footer button {
		width: 45vw;
		margin-top: 5px;
		padding: 10px 0 !important;
	}

	.button-apply:after,
	.button-cancel:after {
		padding: 10px 0 !important;
	}
	#calender-wrapper {
		position: fixed;
		z-index: 2;
		width: max-content;
		left: 50%;
		top: 50%;
		transform: translate(-50%, -50%);
	}
	.litepicker .container__months {
		width: 100%;
	}
	.lightgrey-button {
		font-size: 12px !important;
	}
}

