

/* widget --------------------------------------------------------------------------------------------------------------------------------- */

.widget-container{
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	width: 100%;
	display: grid;
	grid-gap: 10px;
	-webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.widget-container-rental{
	grid-template-columns: repeat(1, 1fr);
}


.widget-col, .widget-col-book{
	width: 100%;
	display: flex;
	align-items: flex-end;
}

.widget-col-inner{
	position: relative;
	width: 100%;
}

.widget-col-inner-flex{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.widget-col-inner p{
	font-size: 13px;
	color: #767789;
	margin: 0px;
	padding: 10px 0px!important;
	text-align: center;
}

.widget-col-inner-flex-full{
	flex: 0 0 100%;
}

.widget-col-inner-flex-left{
	padding: 5px 0px 0px 0px;
	text-align: left;
	flex: 0 0 50%;
	font-size: 15px;
	color: #767789;
	font-weight: 500;
}

.widget-col-inner-flex-right{
	padding: 5px 0px 0px 0px;
	text-align: right;
	flex: 0 0 50%;
	font-size: 15px;
	color: #767789;
}

.widget-col-inner-flex-right span{
	color: #ea4335;
	text-decoration: line-through;
}


.widget-col-divider{
	width: 100%;
	height: 1px;
	margin: 8px 0px 10px 0px;
	border-top: 1px solid rgb(221, 221, 221);
}

.widget-col .label, .widget-col-book .label{
	font-size: 12px;
	font-weight: 400;
	color: #353535;
	position: absolute;
    top: 0px;
    left: 0px;
    padding: 6px 10px;
    transition: all 0.2s ease-out;
    z-index: 1;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transform: translateY(3px);
    transform: translateY(3px);
    pointer-events: none;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    opacity: 0;
    font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

.widget-col .label.active, .widget-col-book .label.active{
	opacity: 1;
    -webkit-transform: translateY(0px);
    transform: translateY(0px);
}

.widget-select{
	width: 100%;
	color: #353535!important;
	font-size: 14px!important;
	border: none;
	border-radius: 6px;
	border: 1px solid rgba(0,0,0,.14)!important;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;	
	background-color: #fff!important;
    height: 50px;
	 -webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-image: url('https://bookings.glampmanager.com/Images/arrow2.png');
	background-position: 98% center;
	background-repeat: no-repeat;
	background-size: 25px;
	padding: 0px 10px 0px 10px;
	transition: transform 0.2s ease-out, padding 0.2s ease-out;
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif
}

.widget-select.active{
	padding: 14px 10px 0px 10px;
}

.widget-select:focus{
    /*
    border: none;
    outline: 0;
    box-shadow: #222222 0 0 0 2px inset !important;
    */
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 2px rgba(13,110,253,.25);    
}

.widget-input{
	width: 100%;
	color: #353535!important;
	font-size: 14px!important;
	border: none;
	border: 1px solid rgba(0,0,0,.14)!important;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;	
	background-color: #fff!important;
    height: 50px!important;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	padding: 0px 10px 0px 10px;
	transition: transform 0.2s ease-out, padding 0.2s ease-out;
	border-radius: 6px;
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif
}

.widget-input.active{
	padding: 14px 10px 0px 10px;
}

.widget-input:focus{
    /*
    border: none;
    outline: 0;
    box-shadow: #222222 0 0 0 2px inset !important;
    */
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 2px rgba(13,110,253,.25);    
}

.widget-button, .widget-button-loading{
	display: block;
	font-weight: 700;
	color: #fff!important;
	background-color: #3EB0B7!important;
    font-size: 15px;
    line-height: 1;
    text-decoration: none;
    cursor: pointer;
    padding: 0px 15px 0px 15px;
    height: 45px;
    line-height: 45px;
    outline: none;
    position: relative;
    -webkit-transition: background .3s;
    -o-transition: background .3s;
    transition: background .3s;
	text-align: center;
	border-radius: 6px!important;
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	position: relative;
}

.widget-button:focus-within{
    /*
    border: none;
    outline: 0;
    box-shadow: #222222 0 0 0 2px inset !important;
    */
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 2px rgba(13,110,253,.25);    
}

.widget-button:hover{
	background-color: ;
}

.widget-date-container{
	display: flex;
	width: 100%;
	border-radius: 6px;
	border: 1px solid rgba(0,0,0,.14)!important;
	background-color: #fff;
	box-sizing: border-box;
}

.widget-date-col{
	flex: 0 0 50%;
	position: relative;
	border-right: 1px solid rgba(0,0,0,.14);
	box-sizing: border-box;
}

.widget-date-col:last-child{
	border: 0px;
}

.widget-date{
	width: 100%;
	color: #353535!important;
	font-size: 14px!important;
	cursor: pointer;
	border: none;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;	
    height: 48px;
    border-radius: 6px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	padding: 0px 10px 0px 10px;
	transition: transform 0.2s ease-out, padding 0.2s ease-out;
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

.widget-date-calendar-icon:after{
	content: '';
	position: absolute;
	right: 0px;
	top: 0px;
	width: 40px;
	bottom: 0px;
	background-image: url('https://bookings.glampmanager.com/Images/Icon_Calendar.svg');
	background-position: center center;
	background-size: 17px;
	background-repeat: no-repeat;
}

.widget-date-guests-icon:after{
	content: '';
	position: absolute;
	right: 0px;
	top: 0px;
	width: 45px;
	bottom: 0px;
	background-image: url('https://bookings.glampmanager.com/Images/Icon_Guests.svg');
	background-position: center center;
	background-size: 25px;
	background-repeat: no-repeat;
}


.widget-date.active{
	padding: 22px 10px 0px 10px;
}

.widget-date-container:focus-within{
    /*
    border: none;
    outline: 0;
    box-shadow: #222222 0 0 0 2px inset !important;
    */
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 2px rgba(13,110,253,.25);    
}

.widget-guests-container{
	display: flex;
	width: 100%;
	border-radius: 6px;
	border: 1px solid rgba(0,0,0,.14)!important;
	background-color: #fff;
	box-sizing: border-box;
}

.widget-guests-container:focus-within{
    /*
    border: none;
    outline: 0;
    box-shadow: #222222 0 0 0 2px inset !important;
    */
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 2px rgba(13,110,253,.25);    
}


/* widget --------------------------------------------------------------------------------------------------------------------------------- */

/* calendar ------------------------------------------------------------------------------------------------------------------------------------------ */

.calendar-slide{
	position: absolute; 
	top: 0px; 
	bottom: 0px; 
	width: 50%;
}

.calendar-slide-inner{
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	width: 100%; 
	height: 100%; 
	padding: 0px 10px; 
	box-sizing: border-box;
}

.calendar-slide-inner-month-name{
	width: 100%; 
	height: 35px; 
	line-height: 35px;
	text-align: center;
	font-weight: 500;
	font-size: 16px;
	color: #333333;	
}

.calendar-slide-inner-weekdays{
	width: 100%; 
	display: grid; 
	grid-template-columns: repeat(7,14.285%);
}

.calendar-slide-inner-weekday{
	width: 100%; 
	text-align: center;
	font-weight: normal;
	font-size: 14px;
	color: #333333;
	line-height: 30px;
	height: 30px;
	box-sizing: border-box;
}

.calendar-slide-inner-days{
	width: 100%; 
	display: grid; 
	grid-template-columns: repeat(7,14.285%);
}

.calendar-date{
	width: 100%;
	text-align: center;
	font-weight: normal;
	font-size: 14px;
	font-weight: normal;
	color: #d7d7d7;
	position: relative;	
	height: 35px;
	line-height: 35px;
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-khtml-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;		
	margin: 0px 0px 2px 0px;
}

.calendar-date-tool-tip{
	position: absolute;
	top: -46px;
	left: 50%;
	padding: 6px 10px;
	background-color: #353535;
	border-radius: 4px;
	opacity: 0;
	visibility: hidden;
	color: #fff;
	white-space: nowrap;
    line-height: 32px;
    transform: translateX(-50%);
}

.calendar-date-tool-tip.active{
	opacity: 1;
	visibility: visible;
}

.calendar-date:focus-within{
    /*
    border: none;
    outline: 0;
    box-shadow: #222222 0 0 0 2px inset !important;
    */
    border-color: #86b7fe;
    outline: 0;
    border-radius: 4px;
    box-shadow: 0 0 0 2px rgba(13,110,253,.25);    
}

.calendar-date.arrival{
	cursor: pointer;
	color: #353535;
	font-weight: 400;
	/*text-decoration: underline;*/
}

.calendar-date.arrival:hover{
	cursor: pointer;
}

.calendar-date.arrival2{
	cursor: pointer;
	color: #353535;
	font-weight: 400;
	/*text-decoration: underline;*/
}

.calendar-date.arrival2:hover{
	cursor: pointer;
}

.calendar-inbetween-date{
	background-color: #3EB0B715!important;
	color: #455560;
}

.calendar-date-disabled{
	color: #d7d7d7!important;
	cursor: default!important;
}

.calendar-start-date1{
	background-color: #3EB0B7!important;
	color: #fff!important;
	opacity: 1;
	border-radius: 4px;
	text-decoration: none!important;
}

.calendar-start-date2{
	background-color: #3EB0B7!important;
	color: #fff!important;
	opacity: 1;
	border-radius: 4px 0px 0px 4px;
	text-decoration: none!important;
}

.calendar-end-date2{
	background-color: #3EB0B7!important;
	color: #fff!important;
	opacity: 1;
	border-radius: 0px 4px 4px 0px;
	text-decoration: none!important;
}

.calendar-container{
	width: 700px; 
	height: 376px; 
	padding: 0px 0px; 
	box-sizing: border-box; 
	background-color: #fff; 
	box-shadow: 0px 0px 15px rgba(100,100,100,0.1); 
	border: 1px solid rgba(0,0,0,.14); 
	position: absolute; 
	top: 55px; 
	right: 0px; 
	border-radius: 10px; 
	z-index: 2; 
	display: none;
}

.calendar-container-header{
	position: absolute; 
	top: 0px;
	left: 0px;
	height: 50px;
	right: 0px;
	box-sizing: border-box;
	padding: 13px 20px;
	border-bottom: 1px solid rgba(0,0,0,.14); 
	display: none;
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	font-size: 18px;
	font-weight: 500;
	color: #333333;
}

.calendar-container-header-close{
	position: absolute;
	top: 0px;
	right: 0px;
	bottom: 0px;
	width: 76px;
	cursor: pointer;
}

.calendar-container-header-close img{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 20px;
}

.calendar-container-header-close img:hover{
	opacity: 1;
}

.calendar-container-top{
	position: absolute; 
	top: 0px;
	left: 0px;
	height: 40px;
	right: 0px;
}

.calendar-container-top-left{
	position: absolute; 
	top: 11px; 
	left: 16px; 
	width: 42px; 
	height: 40px; 
	padding: 0px; 
	padding: 3px 0px; 
	text-align: center;
	box-sizing: border-box; 
	display: none; 
	z-index: 2;
	cursor: pointer;
	opacity: 0.5;
}

.calendar-container-top-right{
	position: absolute; 
	top: 11px; 
	right: 16px; 
	width: 42px; 
	height: 40px; 
	padding: 0px;
	padding: 3px 0px; 
	text-align: center;
	box-sizing: border-box; 
	z-index: 2;
	cursor: pointer;
	opacity: 0.5;
}

.calendar-container-top-left:hover, .calendar-container-top-right:hover{
	opacity: 1;
}

.calendar-container-middle{
	position: absolute; 
	top: 10px; 
	left: 10px; 
	right: 10px; 
	bottom: 68px; 
	overflow: hidden;
}

.calendar-container-middle-container{
	position: absolute;
	top: 0px; 
	bottom: 0px; 
	left: 0px; 
	width: 100%; 
	overflow: hidden;
}

.calendar-container-bottom{
	position: absolute; 
	bottom: 0px; 
	left: 0px; 
	right: 0px; 
	height: 60px; 
	display: flex; 
	justify-content: space-between; 
	align-items: center; 
	border-top: 1px solid rgba(0,0,0,.14); 
	padding: 0px 24px;
}

.calendar-container-bottom-left{
	flex: 1 1;
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	font-size: 14px;
	font-weight: 600;
	color: #333333;
}

.calendar-container-bottom-middle a{
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	font-size: 14px;
	font-weight: 600;
	color: #333333;
	text-decoration: underline;
	cursor: pointer;
	line-height: 45px;
	height: 45px;
	display: block;
	padding: 0px 15px;
	border-radius: 4px;
}

.calendar-container-bottom-middle a:focus-within{
    /*
    border: none;
    outline: 0;
    box-shadow: #222222 0 0 0 2px inset !important;
    */
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 2px rgba(13,110,253,.25);    
}

.calendar-container-bottom-right{
	padding-left: 15px;
}

.calendar-apply-button{
	display: block;
	font-weight: 700;
	color: #3EB0B7;
	background-color: #3EB0B7;
	border: 1px solid #3EB0B7;
	cursor: pointer;
    font-size: 15px;
    line-height: 1;
    text-decoration: none;
    padding: 0px 15px 0px 15px;
    height: 45px;
    line-height: 45px;
    outline: none;
    position: relative;
    -webkit-transition: background .3s;
    -o-transition: background .3s;
    transition: background .3s;
	text-align: center;
	border-radius: 6px;
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;	
}

.calendar-apply-button:hover{
	background-color: #3EB0B7;
}

.calendar-apply-button-disabled{
	color: #CCC!important;
	background-color: #FFFFFF!important;
	border: 1px solid #CCC!important;
	cursor: default;
}

.calendar-apply-button-enabled:focus-within{
    /*
    border: none;
    outline: 0;
    box-shadow: #222222 0 0 0 2px inset !important;
    */
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 2px rgba(13,110,253,.25);    
}

.guests-container{
	width: 100%; 
	padding: 0px 0px; 
	box-sizing: border-box; 
	background-color: #fff; 
	box-shadow: 0px 0px 15px rgba(100,100,100,0.1); 
	border: 1px solid rgba(0,0,0,.14); 
	position: absolute; 
	top: 55px; 
	left: 0px; 
	border-radius: 10px; 
	z-index: 2; 
	display: none;
}

.guests-header{
	display: none;
	position: absolute;
	top: 0px;
	left: 0px;
	right: 0px;
	height: 50px;
	border-bottom: 1px solid rgba(0,0,0,.14); 
	padding: 13px 20px;
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	font-size: 18px;
	font-weight: 500;
	color: #333333;
	box-sizing: border-box;
}

.guests-header-close{
	position: absolute;
	top: 0px;
	right: 0px;
	bottom: 0px;
	width: 76px;
	cursor: pointer;
}

.guests-header-close img{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 15px;
	opacity: 0.6;
}

.guests-header-close img:hover{
	opacity: 1;
}


.guests-col{
	width: 100%;
	display: flex;
	padding: 10px 15px;
	box-sizing: border-box;
}

.guests-col-left{
	text-align: left;
	flex: 1 1;
}

.guests-col-left label{
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	font-weight: 500;
    font-size: 14px;
    color: #333333;
    line-height: 18px;
}

.guests-col-left label span{
	font-size: 12px;
	font-weight: 400;
}

.guests-col-right{
	flex: 0 0 90px;
	text-align: right;
	display: flex;
	justify-content: space-between;
}

.guests-button{
	width: 100%;
	padding: 10px 15px;
	box-sizing: border-box;
}

.guests-apply-button{
	display: block;
	font-weight: 700;
	color: #fff!important;
	background-color: #3EB0B7!important;
	border: 1px solid #3EB0B7!important;
	cursor: pointer;
	font-size: 15px;
    line-height: 1;
    text-decoration: none;
    padding: 0px 15px 0px 15px;
    height: 45px;
    line-height: 45px;
    outline: none;
    position: relative;
    -webkit-transition: background .3s;
    -o-transition: background .3s;
    transition: background .3s;
	text-align: center;
	border-radius: 6px!important;
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif
}

.guests-apply-button:focus-within{
    /*
    border: none;
    outline: 0;
    box-shadow: #222222 0 0 0 2px inset !important;
    */
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 2px rgba(13,110,253,.25);    
}

.guests-col-right-button{
	border: 1px solid rgba(0,0,0,.3); 
	border-radius: 50%;
	width: 30px;
	height: 30px;
	text-align: center;
	line-height: 30px;
	position: relative;
	opacity: 1;
	cursor: pointer;
}

.guests-col-right-button:focus-within{
    /*
    border: none;
    outline: 0;
    box-shadow: #222222 0 0 0 2px inset !important;
    */
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 2px rgba(13,110,253,.25);    
}

.guests-col-right-button img{
	width: 10px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}

.guests-col-right-button:hover{
	opacity: 1;
}

.guests-col-right-value{
	font-size: 15px;
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	text-align: center;
	line-height: 30px;
}

.guests-col-button-disabled{
	cursor: not-allowed!important;
	opacity: 0.3!important;
}

.guests-col-button-disabled:focus{
	outline: none;
    box-shadow: none;
}

.guests-col-button-disabled:hover{
	opacity: 0.3!important;
}


/* calendar ------------------------------------------------------------------------------------------------------------------------------------------ */


/* loading spinner styles --------------------------------------------------------------------------------------------------------------------------------------------------- */

.spinner-container{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}

.spinner {
	margin: 0px auto 0;
	width: 100%;
	text-align: center;
	display: block;
}

.spinner > div{
	width: 10px;
	height: 10px;
	background-color: #fff;	
	border-radius: 100%;
	display: inline-block;
	-webkit-animation: sk-bouncedelay 1.4s infinite ease-in-out both;
	animation: sk-bouncedelay 1.4s infinite ease-in-out both;
}

.spinner .bounce1 {
	-webkit-animation-delay: -0.32s;
	animation-delay: -0.32s;
}

.spinner .bounce2 {
	-webkit-animation-delay: -0.16s;
	animation-delay: -0.16s;
}


@-webkit-keyframes sk-bouncedelay {
	0%, 80%, 100% { -webkit-transform: scale(0) }
	40% { -webkit-transform: scale(1.0) }
}

@keyframes sk-bouncedelay {
	0%, 80%, 100% { 
		-webkit-transform: scale(0);
		transform: scale(0);
	} 40% { 
		-webkit-transform: scale(1.0);
		transform: scale(1.0);
	}
}

/* end loading spinner styles --------------------------------------------------------------------------------------------------------------------------------------------------- */


/* media queries ------------------------------------------------------------------------------------------------------------------------------------------ */


@media screen and (max-width: 1100px)
{
	.widget-container-rental{
		grid-template-columns: repeat(1, 1fr);
	}
	.calendar-container-middle-container{
		width: 200%;
	}
	.calendar-container{
		position: fixed;
		top: 0px;
		left: 0px;
		right: 0px;
		bottom: 0px;
	    width: 100%;
	    box-sizing: border-box;
	    height: 100%;
	    border-radius: 0px;
	    z-index: 99999;
	}
	.calendar-container-header{
		display: block;
	}
	.calendar-container-top{
		top: 50px;
	}		
	.calendar-container-top-left{
		top: 11px;
	}
	.calendar-container-top-right{
		top: 11px;
	}
	.calendar-container-middle{
		top: 66px;
    	left: 0px;
    	right: 0px;
	}
	.calendar-slide-inner-weekday{
    	line-height: 35px;
    	height: 35px;
	}
	.calendar-date{
		height: 42px;
   		line-height: 42px;
   		margin: 0px 0px 6px 0px;
	}
	.guests-container{
	
		/*
		position: fixed;
		top: 0px;
		left: 0px;
		right: 0px;
		bottom: 0px;
	    width: 100%;
	    box-sizing: border-box;
	    height: 100%;
	    border-radius: 0px;
	    z-index: 99999;
	    */
	    top: 0px;
	    box-shadow: none;
	    display: block!important;
	    border-radius: 6px;
	    position: relative;
	}
	.widget-guests-container{
		display: none;
	}
	.guests-col{
		padding: 10px 10px;
	}
	.guests-button{
		display: none;
	}
	/*
	.guests-header{
		display: block;
	}
	.guests-body{
		position: absolute;
		top: 50px;
		bottom: 68px;
		left: 0px;
		right: 0px;
		padding: 10px 0px;
	}
	.guests-button{
		position: absolute;
		bottom: 0px;
		left: 0px;
		right: 0px;
		height: 68px;
		border-top: 1px solid rgba(0,0,0,.14);
	}		
	*/
}


/* media queries ------------------------------------------------------------------------------------------------------------------------------------------ */