/*********************** BOOKING **************************/
div.booking {
	text-align: left;
}

.booking_formelement_container {
	background-position: 95% 15%;
	background-size: 20px 20px;
	background-repeat: no-repeat;
	cursor: pointer;
}

.booking_formelement_container > p {
	font-size: 1rem;
	color: #99ba56;
	font-weight: 300;
	margin-bottom: 10px;
}

.booking_formelement_container:hover > p {
    color: #327385;
}

.booking_formelement_datepicker {
	background-image: url("../img/calendar_icon.png");
}

.booking_formelement_datepicker:hover {
	background-image: url("../img/calendar_icon_hover.png");
}

.booking_formelement_personpicker {
	background-image: url("../img/person_icon.png");
}

.booking_formelement_personpicker:hover {
	background-image: url("../img/person_icon_hover.png");
}

.booking_formelement_roompicker {
	background-image: url("../img/room_icon.png");
}

.booking_formelement_roompicker:hover {
	background-image: url("../img/room_icon_hover.png");
}

.booking_formelement_submitbutton > p {
	margin: 0px;
}

.booking_formelement_container {
	border-bottom: solid 2px #333;
	padding-bottom: 15px;
	padding-top: 15px;
}

.booking_formelement_submitbutton {
	border-bottom: none;
	padding: 0px;
}

div#booking div.booking {
	background-color: transparent;
	max-width: none;
	padding: 0;
}

.booking_button_inline {
	margin-left: 1%;
	float: left;
	width: 32%;
}

.booking_button_loading {
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 15px;
}

div.booking h3 {
	font-size: 1.2em !important;
}

div.first {
	margin-left: 0px !important;
}

.imagecontainer_right {
	display: block;
	width: 400px;
	height: 267px;
	float: right;
	margin-left: 10px;
	margin-bottom: 10px;	
	background-size: cover;
}

.imagecontainer {
	max-width: 1000px;
	height: 0px;
	background-size: cover;
}

div.booking_formelement {
	position: relative;
	cursor: pointer;
	color: #ccc;
	font-size: 1rem;
	font-weight: bold;
	text-align: left;
	letter-spacing: 0.3px;
}

div.booking_formelement:hover {
	color: #fff;
}

div.booking_horizontal {
	font-size: 0px;
	font-family: 'Lato', sans-serif;
	display: inline-block;
	/*width: 32%;*/ /*Drei Buttons*/
	width: 190px; /*Vier Buttons*/
  	margin-bottom: 0px;
  	max-width: 300px;
  	overflow: hidden;
  	text-align: left;
	background-color: rgba(255, 255, 255, 0.1);
	border: none !important;
	padding: 10px !important;
	vertical-align: top;
    min-height: 80px;
    margin-right: 12px;
    -webkit-transition: all 0.2s linear 0.1s;
	transition: all 0.2s linear 0.1s;
	-moz-transition: all 0.2s linear 0.1s;
	-ms-transition: all 0.2s linear 0.1s;
	-o-transition: all 0.2s linear 0.1s;
}

div.booking_horizontal:hover {
	background-color: #222;
}

div.booking_horizontal .title {
	padding: 0px !important;
}

div.booking_horizontal:last-child {
	padding: 0px !important;
}

.booking_formelement_submitbutton {
	background-color: rgba(255, 255, 255, 0) !important;
	padding-top: 15px;
	margin-right: 0px !important;
	min-width: 200px !important;
}

.booking_formelement_submitbutton > p {
	display: none;
}

.booking_horizontal .booking_button {
	font-size: 1rem;
	height: 100px;
	line-height: 100px;
}

div.booking_horizontal_inline {
	float: left;
	width: 32%;
	margin-left: 1%;
}

div.booking_horizontal .booking_formelement p {
	color: #ccc !important;
}

div.booking_horizontal:hover .booking_formelement p {
	color: #fff !important;
}

div.booking_horizontal > p {
	font-size: 1rem;
	font-weight: 300;
	margin-bottom: 10px;
	color: #99ba56 !important;
	text-align: left;
}

div.booking_horizontal:hover > p {
	color: #327385 !important;
}

div.booking_formelement_open {
	cursor: auto !important;
	box-shadow: none !important;
	-moz-box-shadow: none !important;
  	-webkit-box-shadow: none !important;
}

.roomteaser {
	max-width: 1000px;
	height: 300px;
	margin-bottom: 20px;
	background-color: rgba(255, 255, 255, 0.1);
	position: relative;
}

.checkboxicon {
	display: block;
	width: 20px; 
	height: 20px; 
	position: absolute; 
	right: 20px; 
	top: 20px; 
	border-radius: 20px; 
	border: solid 2px #666;
	background-color: #fff;
	cursor: pointer;
}

.room_selected .checkboxicon {
	border-color: #222;
	background-color: #99ba56;
}

.roomteaser h2 {
	color: #99ba56 !important;
	font-size: 1.4rem;
	margin-bottom: 0px;
	margin-top: 0px;
}

.roomteaser_image {
	float: left;
	overflow: hidden;
	width: 50%;
	height: 300px;
	background-size: cover;
}

.room_image {
	width: 260px;
	height: 150px;
	margin-top: 20px;
	margin-bottom: 20px;
}

.roomteaser_text {
	overflow: hidden;
	padding-top: 20px;
	padding-left: 30px;
	color: #000;
}

.roomteaser_text ul li {
	color: #fff;
	line-height: 30px;
}

.roomteaser_text ul {
	margin-left: 0px;
	margin-bottom: 20px !important;
}

a.black_button {
	font-family: 'Lato', sans-serif;
	height: 40px;
	display: block;
	background-color: #327385;
	color: white;
	font-size: 1rem;
	font-weight: bold;
	line-height: 38px;
	text-decoration: none;
	overflow: hidden;
	max-width: 300px;
	text-align: center;
	margin-top: 20px;
	margin-bottom: 20px;
}

.add_room {
	margin-top: 15px;
	margin-bottom: 15px;
	background-image: url("../img/plus_icon.png");
	background-size: 10px 10px;
	background-position: 15px center;
	background-repeat: no-repeat;
	max-width: 280px !important;
	text-align: left !important;
	padding-left: 40px;
}

a.action_button {
	font-family: 'Lato', sans-serif;
	height: 40px;
	display: block;
	background-color: #327385;
	color: white !important;
	font-size: 1rem;
	font-weight: bold;
	line-height: 38px;
	text-decoration: none;
	overflow: hidden;
	max-width: 300px;
	text-align: center;
	cursor: pointer;
	letter-spacing: 0.3px;
	-webkit-transition: all 0.2s linear 0.1s;
	transition: all 0.2s linear 0.1s;
	-moz-transition: all 0.2s linear 0.1s;
	-ms-transition: all 0.2s linear 0.1s;
	-o-transition: all 0.2s linear 0.1s;
}

a.action_button:hover, input.action_button:hover, input.formbutton:hover {
	background-color: #a2ba47;
}

a.action_button_red {
	background: #93aa10; /* Old browsers */
	background: -moz-linear-gradient(top, #93aa10 0%, #60850b 50%, #486c00 51%, #6b900c 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#93aa10), color-stop(50%,#60850b), color-stop(51%,#486c00), color-stop(100%,#6b900c)); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(top, #93aa10 0%,#60850b 50%,#486c00 51%,#6b900c 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(top, #93aa10 0%,#60850b 50%,#486c00 51%,#6b900c 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(top, #93aa10 0%,#60850b 50%,#486c00 51%,#6b900c 100%); /* IE10+ */
	background: linear-gradient(to bottom, #93aa10 0%,#60850b 50%,#486c00 51%,#6b900c 100%); /* W3C */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#93aa10', endColorstr='#6b900c',GradientType=0 ); /* IE6-9 */
	display: block;
	color: white;
	font-weight: bold;
	text-decoration: none;
	border: none;	
	border-style: outset;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
	border-radius: 0px;
}

a.action_button_red:hover {
	background-color: #6b900c;
	background-image: none;
}

a.action_button_gray {
	background-color: #f1f0eb;
	background-image: linear-gradient(bottom, #E0D9D5 30%, #f1f0eb 73%);
	background-image: -o-linear-gradient(bottom, #E0D9D5 30%, #f1f0eb 73%);
	background-image: -moz-linear-gradient(bottom, #E0D9D5 30%, #f1f0eb 73%);
	background-image: -webkit-linear-gradient(bottom, #E0D9D5 30%, #f1f0eb 73%);
	background-image: -ms-linear-gradient(bottom, #E0D9D5 30%, #f1f0eb 73%);
	
	background-image: -webkit-gradient(
		linear,
		left bottom,
		left top,
		color-stop(0.3, #E0D9D5),
		color-stop(0.73, #f1f0eb)
	);
	
	display: block;
	color: #888;
	font-weight: bold;
	text-decoration: none;
	border: none;	
	border-style: outset;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
	border-radius: 0px;
}

a.action_button_gray:hover {
	background-color: #f1f0eb;
	background-image: none;
}

input.action_button, input.formbutton  {
	height: 40px;
	display: block;
	background-color: #317286;
	color: #ccc;
	font-size: 1rem;
	font-family: 'Lato', sans-serif;
	font-weight: 700;
	line-height: 38px;
	text-decoration: none;
	overflow: hidden;
	width: 300px;
	text-align: center;
	cursor: pointer;
	border: none;
	margin-top: 20px;
	letter-spacing: 0.3px;
	-webkit-transition: all 0.2s linear 0.1s;
	transition: all 0.2s linear 0.1s;
	-moz-transition: all 0.2s linear 0.1s;
	-ms-transition: all 0.2s linear 0.1s;
	-o-transition: all 0.2s linear 0.1s;
}

a.booking_button {
	font-family: 'Lato', sans-serif;
	height: 40px;
	display: block;
	background-color: #327385;
	color: white !important;
  	font-size: 1rem;
  	font-weight: bold;
	line-height: 38px;
	text-decoration: none;
	overflow: hidden;
	max-width: 300px;
	text-align: center;
	cursor: pointer;
	letter-spacing: 0.3px;
	-webkit-transition: all 0.2s linear 0.1s;
	transition: all 0.2s linear 0.1s;
	-moz-transition: all 0.2s linear 0.1s;
	-ms-transition: all 0.2s linear 0.1s;
	-o-transition: all 0.2s linear 0.1s;
}

a.booking_button_small {
	font-family: 'Lato', sans-serif;
	height: 40px;
	display: block;
	background-color: #327385;
	color: #fff;
	font-size: 1rem;
	font-weight: bold;
	line-height: 38px;
	text-decoration: none;
	overflow: hidden;
	max-width: 300px;
	text-align: center;
	margin-top: 15px;
	margin-bottom: 20px;
	cursor: pointer;
	letter-spacing: 0.3px;
	-webkit-transition: all 0.2s linear 0.1s;
	transition: all 0.2s linear 0.1s;
	-moz-transition: all 0.2s linear 0.1s;
	-ms-transition: all 0.2s linear 0.1s;
	-o-transition: all 0.2s linear 0.1s;
}

a.booking_button:hover, a.booking_button_small:hover {
	background-color: #a2ba47;
}

a.booking_room_select_button_selected {
	border: solid 1px #a2ba47;
	background-color: #a2ba47;
	background-image: url(../img/check_icon_white.png);
	background-repeat: no-repeat;
	background-size: 25px 25px;
	background-position: 10px center;
	display: none;
}

.room_selected a.booking_room_select_button_selected {
	display: block !important;	
}

a.booking_room_select_button_deselected {
	border: solid 1px #327385;
	background-color: transparent;
}

a.booking_room_select_button_deselected:hover {
	background-color: transparent;
}


.room_selected a.booking_room_select_button_deselected {
	display: none !important;
}

#formloader_booking_form_1_0 img, #formloader_booking_form_2_0 img {
	width: 43px !important;
	height: 11px !important;
}

div.booking_formelement div.title p {
	margin: 0px !important;
	padding: 0px !important;
	line-height: 18px !important;
	font-size: 1.0em !important;
	text-align: left !important;
}

div.booking_formelemet_detail_top {
	display: none;
	position: absolute;
	left: -1px;
	top: 45px;
	background-color: black;
	width: 100%;
	height: 15px;
	border-left: solid 1px black;
	border-right: solid 1px black;
	z-index: 501;
}

#personpicker_detail_booking_sfbooking p {
	margin-bottom: 15px;
	padding-bottom: 15px;
	border-bottom: solid 2px #333;
}

div.booking_formelement_detail {
	display: none;
	z-index: 500;
	padding: 10px;
	background-color: #000;
	width: 880px;
}

div.booking_formelement_detail h3 {
	margin: 0px !important;
	color: #99ba56 !important;
	font-weight: 700;
}

.booking_form {
	padding-bottom: 10px; 
}

.booking_detail_width {
	margin-bottom: 15px;
	padding-bottom: 15px;
	border-bottom: solid 2px #333;
}

select.booking_detail_width {
	width: 100%;
	max-width: 200px;
    display: block;
    font-size: 16px;
    font-family: 'Lato', sans-serif;
    font-weight: 700;
    color: #333;
    line-height: 1.3;
    padding: .6em 1.4em .5em .8em;
    box-sizing: border-box;
    margin: 0;
    border: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    background-color: #ccc;
    
    background-image:
    linear-gradient(45deg, transparent 50%, gray 50%),
    linear-gradient(135deg, gray 50%, transparent 50%),
    linear-gradient(to right, #aaa, #aaa);
	background-position:
    calc(100% - 20px) calc(1em + 2px),
    calc(100% - 15px) calc(1em + 2px),
    calc(100% - 2.5em) 0.5em;
	background-size:
    5px 5px,
    5px 5px,
    1px 1.5em;
	background-repeat: no-repeat;
}

select.booking_detail_width:focus {
	background-image:
	  linear-gradient(45deg, gray 50%, transparent 50%),
	  linear-gradient(135deg, transparent 50%, gray 50%),
	  linear-gradient(to right, #aaa, #aaa);
	background-position:
	  calc(100% - 15px) 1em,
	  calc(100% - 20px) 1em,
	  calc(100% - 2.5em) 0.5em;
	background-size:
	  5px 5px,
	  5px 5px,
	  1px 1.5em;
	background-repeat: no-repeat;
	border-color: gray;
	outline: 0;
}

select.booking_detail_width::-ms-expand {
    display: none;
}

select.booking_detail_width option {
    font-weight:normal;
}

.datum {
	display: none;
}

.reisedauer {
	display: block;
}

.anreiseabreise {
	border-bottom: solid 2px #333;
	margin-bottom: 5px;
}

.anreise {
	float: left;
	border: none !important;
	margin-bottom: 0px;
}

.abreise {
/*	display: none; */
	float: left;	
	margin-left: 50px;
	border: none !important;
	margin-bottom: 0px;
}

.age_child2 booking_detail_width {
	padding: 4px;
}

div.datepicker_departure, div.datepicker_arrival {
	font-size: 0.7em;
}

div.booking_formelement_detail label {
	color: white;
	font-size: 1.0em;
}

div.booking_formelement_detail a {
	color: white;
}

.anreiseabreise:after {
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}

*+html .anreiseabreise {
	display: inline-block;
}

* html .anreiseabreise {
	height: 1%;
}

a.formelement_close {
	display: none;
	position: absolute;
	width: 30px;
	height: 30px;
	right: -14px;
	top: -10px;
	background-image: url(fancybox/fancy_close.png);	
}

div.price {
	width: 75px;
	height: 75px;
	background-image: url("../img/price_back.png");
	background-repeat: no-repeat;
	background-position: center center;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}

div.pricelabel_small {
	position: absolute;
	left: 10px;
	top: 22px;
	width: 55px;
	height: 11px;
	color: white;
	font-size: 11px;
	line-height: 11px;
	text-align: center; 	
}

div.pricelabel_large {
	position: absolute;
	left: 10px;
	top: 36px;
	width: 55px;
	height: 16px;
	color: white;
	font-weight: bold;
	font-size: 16px;
	line-height: 16px;
}

div.pricelabel {
	position: absolute;
	left: 10px;
	top: 31px;
	width: 55px;
	height: 16px;
	color: white;
	font-weight: bold;
	font-size: 16px;
	line-height: 16px;
}

/******* OFFERS ********/

.offers_header span {
	font-size: 0.9rem;
	color: #fff;
	font-weight: 400;
}

.offers_header span strong {
    font-size: 1rem;
    font-weight: 700;
    color: #99ba56; 
}

.offers_header {
	border-bottom: solid 2px #333;
	padding-bottom: 15px;
	margin-bottom: 15px;
}

.offers_body span {
	color: #fff;
}

div.offers_wrapper {
	max-width: 1000px;
	margin-bottom: 30px;
}

div.offerrow {
	padding-top: 10px;
	padding-bottom: 10px;
	margin-left: 0px !important;
	margin-right: 0px !important;
}

.offerrow_buchen span {
	color: #99ba56;
}

div.offerrow > div {
	float: left;
	text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden;
	height: auto;
	line-height: 32px;
	vertical-align: middle;
	font-size: 1.0rem !important;
}

div.offerrow > div span {
	display: inline-block;
	vertical-align: middle;
	line-height: normal;
}

.totalnormalprice {
	text-decoration: line-through;
}

.discount {
	color: #99ba56 !important;
}

div.offerrow_icon  {
	text-align: center;
} 

div.offerrow_icon > img  {
	padding-top: 10px;
	display: block;
	margin-left: auto;
	margin-right: auto;
}

div.tr1 {
	/*background-color: #b07979;*/
}

div.tr2 {
	/*background-color: #925959;*/
}

div.offerrow_icon {
	width: 6%;
}

div.offerrow_anreise {
	width: 18%;
}

div.offerrow_abreise {
	width: 18%;
}

div.offerrow_einzelpreis {
	width: 23%;
}

div.offerrow_gesamtpreis {
	width: 23%;
}

div.offerrow_buchen {
	width: 12%;
}

div.offerrow_anreise_mobile, div.offerrow_abreise_mobile, div.offerrow_gesamtpreis_mobile {
	display: none;
}

.offer_message {
	background-color: rgba(255, 0, 0, 0.3);
	padding: 20px;
}

.warn_message {
	color: #fff;
	background-color: rgba(255, 204, 0, 0.6);
	padding: 10px;
	margin-bottom: 10px;
}

.error_message {
	color: #fff;
	background-color: rgba(255, 0, 0, 0.6);
	padding: 10px;
	margin-bottom: 10px;
}

.ok_message {
	color: #fff;
	background-color: rgba(127, 216, 0, 0.6);
	padding: 10px;
	margin-bottom: 10px;
	
}

/******* PAGINATION *********/

div.dialog_pagination_wrapper {
	margin-top: 30px;
	clear: both;
	float: left;
	overflow: hidden;
	width: 100%;
}

div.dialog_pagination {
	position: relative;
	margin: 0 auto;
	float: left;
	left: 0%;
}

div.dialog_pagination div {
	display: inline !important;
	font-size: 1rem !important;
	height: 30px !important;
	width: 30px !important;
	text-align: center;
	line-height: 28px !important;
	color: #fff !important;
	font-weight: normal !important;
	float: left;
}

div.dialog_pagination a {
	color: #fff !important;
	display: block;
	height: 30px;
	line-height: 28px;
	overflow: hidden;
	padding-left: 8px;
	padding-right: 8px;
	text-decoration: none;
}

div.dialog_pagination a:hover {
	color: #fff !important;
	text-decoration: none;
}

div.dialog_pagination div.pagination-current-page {
	border: none !important;
	background-color: #317286 !important;
	color: #fff !important;
	font-weight: 400 !important;
}

div.dialog_pagination div.pagination-page {
	border: none;
	background-color: #317286 !important;
}

div.dialog_pagination div.pagination-page:hover {
	border: none !important;
	background-color: #99ba56 !important;
}

div.dialog_pagination div.pagination-separator {
	width: 10px !important;
}

.teaser {
	color: black !important;
	background: url("../img/opacity_white_95.png");
}

.teaser h1 {
	color: black !important;
	margin-bottom: 0px;
}

.teaser h2 {
	color: black !important;
	margin-top: 0px;
}

.teaser h3 {
	color: black !important;
	margin-top: 0px;
}

.teaser p {
	color: black !important;
	text-align: left;
	margin-bottom: 0px;
}

/**************** BOOKING STORNO **************/

.storno_booking_header {
	background-color: #317286;
	color: white;
	padding: 10px;
}

.storno_booking_table {
	background-color: white;
	color: #6b3939;
	width: 800px;
	padding: 10px;
}


/******* Shopping Cart **********/

#shopping_cart {
	margin-top: 40px !important;
}

.sc_header {
	border-bottom: solid 2px #333;
}

.sc_subheader {
	top: 35px;
	width: 100%;
	border-bottom: solid 2px #333;
	padding-bottom: 15px;
	padding-top: 15px;
}

.booking_subheader h3 {
	font-size: 1rem;
	font-weight: bold;
	color: #fff;
	text-transform: uppercase;
	letter-spacing: 0.3px;
	margin: 0px !important;
	clear: both;
	margin-bottom: 5px !important;
	line-height: normal;
}

.booking_subheader:last-child {
	border-bottom: solid 0px #333;
	padding-bottom: 0px;
}

.paymenttype_container {
	float: left;
	background-color: rgba(255, 255, 255, 0.8);
	height: 20px;
	padding: 2%;
	width: 45%;
	margin-right: 2%;
	margin-bottom: 2%;
}

.paymenttype_container:hover {
	background-color: rgba(255, 255, 255, 0.9);
}

.paymenttype_container:nth-of-type(2n) {
	margin-right: 0;
}


.paymenttype {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	height: 100%;
}

.sc_icon {
	display: block;
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 15px 15px;
	color: #ccc;
	padding: 5px;
	padding-left: 30px;
	font-size: 0.8rem;
	letter-spacing: 0.3px;
}

.sc_icon:hover {
	color: #fff;
}

.sc_hotel_city {
	background-image: url("../img/house_icon.png");
}

.sc_hotel_city:hover {
	background-image: url("../img/house_icon_hover.png");
}

.sc_hotel_address {
	background-image: url("../img/city_icon.png");
}

.sc_hotel_address:hover {
	background-image: url("../img/city_icon_hover.png");
}

.sc_hotel_phone {
	background-image: url("../img/phone_icon.png");
}

.sc_hotel_phone:hover {
	background-image: url("../img/phone_icon_hover.png");
}

.sc_hotel_email {
	background-image: url("../img/email_icon.png");
}

.sc_hotel_email:hover {
	background-image: url("../img/email_icon_hover.png");
}

.sc_hotel_support {
	background-image: url("../img/support_icon.png");
}

.sc_hotel_support:hover {
	background-image: url("../img/support_icon_hover.png");
}

.sc_content {
	width: 100%;
	top: 200px;
}

.sc_article {
	border-bottom: solid 2px #333;
	position: relative;
	padding-bottom: 10px;
	margin-bottom: 10px;
}

.sc_article_image {
	background-image: url("../img/hotelzimmer_foto.png");
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	width: 260px;
	height: 160px;
	display: block;
	margin-top: 10px;
	margin-bottom: 15px;
}

.sc_article_date {
	background-image: url("../img/calendar_icon.png");
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 20px 16px;
	margin-bottom: 15px;
}

.sc_article_title {
	color: #ccc;
	font-size: 0.9rem;
	display: block;
}

.sc_article_title:hover {
	color: #fff;
}

.sc_article_subtitle {
	color: #ccc;
	font-size: 0.9rem;
	display: block;
}

.sc_article_subtitle:hover {
	color: #fff;
}

.sc_article_price {
	position: absolute;
	right: 0px;
	top: 0px;
	color: #99ba56;
	font-size: 0.9rem;
}

.sc_article_quantity {
	background-image: url("../img/person_icon.png");
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 20px 18px;
	margin-bottom: 15px;
}

.sc_article_room {
	background-image: url("../img/room_icon.png");
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 20px 15px;
	margin-bottom: 15px;
}

.sc_article {
	border-bottom: solid 2px #333;
}

a.sc_delete {
	display: block;
	font-size: 0.8rem;
	color: #666;
	text-align: left;
	cursor: pointer;
	margin-top: 10px;
	background-image: url("../img/close_icon.png");
	background-repeat: no-repeat;
	background-position: right center;
	background-size: 10px 10px;
	position: absolute;
	left: 0px;
}

a.sc_delete:hover {
	color: #327385;
	background-image: url("../img/close_icon_hover.png");
}

.sc_article_image {
	background-image: url("../img/hotelzimmer_foto.png");
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	width: 260px;
	height: 160px;
	display: block;
	margin-top: 10px;
	margin-bottom: 15px;
}

.sc_price {
    padding-bottom: 10px;
    border-bottom: solid 2px #333;
    margin-bottom: 10px;
}

.sc_single_price {
	font-size: 0.8rem;
	color: #666;
	text-align: left;
	display: inline-block;
	width: 50%;
}

.sc_single_price_sum {
	font-size: 0.8rem;
	color: #666;
	text-align: right;
	display: inline-block;
	width: 48%;
}

.sc_price_title {
	font-size: 1rem;
	font-weight: 700;
	color: #ccc;
	text-align: left;
	display: inline-block;
	width: 50%;
}

.sc_price_sum {
	font-size: 1rem;
	font-weight: 700;
	color: #99ba56;
	text-align: right;
	display: inline-block;
	width: 48%;
}

.sc_greybutton {
	margin-bottom: 10px;
}

/******* Shopping Cart Ende **********/

/******* Booking Right **********/

.booking_container {
	position: relative;
	margin: 20px;
	width: calc(100% - 40px);
}

.booking_head {
	width: 100%;
	height: 35px;
	border-bottom: solid 2px #333;
	display: none;
}

.booking_headline {
	font-size: 1.2rem;
	font-weight: 800;
	color: #666;
	text-transform: uppercase;
	top: -4px;
	left: 30px;
	display: inline-block;
}

.booking_logo {
	background-image: url("../img/overnight_stay.png");
	background-repeat: no-repeat;
	background-size: cover;
	width: 15px;
	height: 15px;
	left: 0px;
	top: 0px;
}

.booking_content {
  clear: both;
	width: 100%;
}

.booking_header {
	display: block;
	width: 100%;
}

.booking_number {
	color: #99ba56;
	font-size: 1rem;
	font-weight: 800;
	display: inline-block;
	width: 25px;
}

.booking_line {
	color: #99ba56;
	font-size: 1rem;
	font-weight: 300;
	display: inline-block;
	width: 20px;
}

.booking_title {
	display: inline-block;
	font-weight: 500;
	font-size: 1rem;
	color: #888;
	text-align: left;
	width: 180px;
}

.booking_icon {
	display: inline-block;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	vertical-align: bottom;
	width: 20px;
	height: 20px;
}

.booking_icon_datepicker {
	background-image: url("../booking/img/calendar.png");
}

.booking_icon_personpicker {
	background-image: url("../booking/img/family.png");
}

.booking_icon_roompicker {
	background-image: url("../booking/img/room.png");
}

.booking_element {
	border-bottom: solid 2px #333;
	padding-top: 20px;
	padding-bottom: 10px;
}

a.booking_select {
	color: #ccc;
	font-size: 1.2rem;
	display: block;
	padding-top: 10px;
	padding-bottom: 10px;
	font-weight: 800;
}

a.booking_select:hover {
	color: #fff;
}

.booking_footer {
	position: fixed;
	z-index: 500;
	width: 260px;
	bottom: 20px;
	height: 40px;
}

a.booking_btn {
	width: 100%;
	background-color: #327385;
	color: #fff;
	text-align: center;
	height: 40px;
	display: inline-block;
	line-height: 40px;
	font-size: 1rem;
	text-transform: uppercase;
	cursor: pointer;
	transition: all .2s ease-in-out;
	float: right;
}

a.booking_btn:hover {
	background-color: #99ba56;
}

/******* Booking Right Ende **********/

/******* Anreise / Abreise **********/

.ui-corner-all, .ui-corner-bottom, .ui-corner-right, .ui-corner-br {
	border-radius: 0px !important;
}

.ui-widget-content {
	border: none !important;
	color: #333 !important;
	background-color: #000 !important;
	background: none !important;
}

.ui-widget {
	font-family: 'Lato', sans-serif !important;
	font-size: 1.2rem !important;
}

.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default {
    border: none !important;
    background: none !important;
    font-weight: 400 !important;
    color: #ccc !important;
}

.ui-datepicker table {
    margin: 0 0 15px !important;
}

.ui-datepicker td:hover {
    background-color: rgba(255, 255, 255, 0.1);
}

.ui-datepicker-current-day, .ui-datepicker-current-day > a, .ui-datepicker-current-day > a:active {
	/*background-color: #317286 !important;*/
	border: solid 2px white !important;	
}

 .ui-datepicker-current-day > a, .ui-datepicker-current-day > a:active {
	border: solid 2px white !important;	
 }

.datepicker_available {
   background-color : rgba(0, 255, 0, 0.5);
}

.datepicker_notavailable {
   background-color : rgba(255, 0, 0, 0.5);
}

.ui-datepicker-unselectable {
	background-color: transparent;
}

/******* Anreise / Abreise Ende **********/

/********** RESPONSIVE ***********/

@media only screen and (min-width: 0px) and (max-width: 1710px) {
	div.booking_horizontal {
		width: 170px;
	    margin-right: 6px;
	}
}


@media only screen and (min-width: 0px) and (max-width: 1279px) {
	div.booking_formelement_detail {
		width: 100%;
		max-width: 880px;
		padding: 0px;
		margin: 0px;
	}
  
	.ui-datepicker {
		width: 100% !important;
		padding: 0px !important;
	}
  
	.booking_formelement_roompicker {
		margin-bottom: 15px;
	}
	
	.booking_formelement_submitbutton {
    	padding-top: 0px;
	}
}

/* Small Desktops */
@media only screen and (min-width: 768px) and (max-width: 1279px) {
	.roomteaser {
		width: 800px;
		height: 240px;
	}
	.roomteaser_image {
		width: 400px;
		height: 240px;
	}
	/*.storno_booking_header {
		width: 800px;
	} */ /** Bei Storno geht nicht */ 
	.storno_booking_table {
		width: 800px;
	}
	
	.imagecontainer_right {
		display: none;
	}
	
	.imagecontainer {
		display: block;
		width: 800px;
		height: 550px;
	}
	
	.booking_subheader {
		border-bottom: solid 2px #333;
		padding-bottom: 10px;
	}
}

@media only screen and (min-width: 0px) and (max-width: 1023px) {
	div.booking_horizontal {
		display: block;
		margin-bottom: 10px;
		margin-left: 0px !important;
		width: 96%;
		padding: 2%;
		max-width: none;
		min-height: 40px;
	}
	
	div.booking_horizontal > p {
		margin-bottom: 5px;
	}

	div.booking_formelement_submitbutton > p  {
		display: none;
	}
	
	div.booking_horizontal a.booking_button {
		margin-left: 0px;
		margin-top: 10px;
	}
	
	.roomteaser {
		width: 100%;
		height: auto;
	}
	
	.roomteaser_image {
		display: block;
		float: none;
		width: 100%;
		height: 250px;
	}
	
	.roomteaser_text {
		float: none;
		padding-top: 5%;
		padding-left: 5%;
		padding-right: 5%;
		padding-bottom: 5%;
	}
	
	.roomteaser_text ul {
		margin-left: 5%;
		margin-bottom: 5%;
	}
	
	.storno_booking_header {
		width: 100%;
	}
	
	.storno_booking_table {
		width: 100%;
	}
	
	.imagecontainer_right {
		display: none;
	}
	
	.imagecontainer {
		display: block;
		width: 100%;
		height: 500px;
	}
	
	body.url_booking div.roomteaser a.booking_button {
		display: none;
	}
	
	body.url_booking div.roomteaser ul {
		margin-bottom: 0px !important;
	}
	
	.booking_horizontal .booking_button {
    	margin-top: 0px;
		height: 40px;
    	line-height: 38px;
	}
	
}

@media only screen and (min-width: 0px) and (max-width: 767px) {
	#offers2 {
		display: block;
	}
	
	div.offerrow > div {
    	display: block;
		float: none;
		margin-left: 0px;
		line-height: 30px;
	}
	
	.storno_booking_header {
		padding: 5px;
	}
	
	.storno_booking_table {
		padding: 5px;
	}
	
	div.offerrow_anreise {
		width: 100%;
	}
	
	div.offerrow_abreise {
		width: 100%;
	}
	
	div.offerrow_einzelpreis {
		display: none !important;
	}
	
	div.offerrow_gesamtpreis {
		width: 100%;
	}
	
	div.offerrow_buchen{
		width: 100%;
	}
	
	.imagecontainer_right {
		display: none;
	}
	
	.imagecontainer {
		display: block;
		height: 400px;
	}
	
	div.offerrow {
		border: none;
		margin-top: 20px;
		position: relative;
		padding: 18px;
		color: white;
		background-color: #333;
		box-shadow: black 2px 2px 2px;
	}
	
	div.offerrow_icon {
		width: auto;
		position: absolute;
		right: 18px;
		top: 8px;
	}
	
	div.offers_header {
		display: none;
	}
	
	div.offerrow_anreise_mobile, div.offerrow_abreise_mobile, div.offerrow_gesamtpreis_mobile {
		display: block;
		line-height: normal;
		color: #ccc;
		font-size: 0.9rem;
	}
	
	div.offerrow_anreise_mobile strong, div.offerrow_abreise_mobile strong, div.offerrow_gesamtpreis_mobile strong {
		color: #fff;
	}

	div.offerrow_abreise_mobile, div.offerrow_gesamtpreis_mobile {
		margin-top: 15px;
	}
	
	div.offerrow_gesamtpreis_mobile {
		margin-bottom: 10px;
	}
	
	div.offerrow_anreise_mobile > strong, div.offerrow_abreise_mobile > strong, div.offerrow_gesamtpreis_mobile > strong {
		font-size: 1rem;
	}
	
	div.offerrow_anreise > span, div.offerrow_abreise > span, div.offerrow_gesamtpreis > span {
		display: none !important;
	}
	
	div.offerrow_buchen a.action_button {
		margin-left: auto;
		margin-right: auto;
	}
	
	.roomteaser h2 {
	    font-size: 1.2rem;
	    margin-bottom: 10px;
	    margin-top: 0px;
	}
	
	.roomteaser_text ul {
	    margin-bottom: 20px !important;
	}
	
	.booking_subheader {
	    border-bottom: solid 2px #333;
	    padding-bottom: 10px;
	}
	
	.booking_formelement_container > p {
	    font-size: 0.9rem;
	}
	
	.add_room {
		margin-top: 10px;
		margin-bottom: 10px;
		background-position: 0px center;
		max-width: 300px !important;
		text-align: left !important;
		background-color: rgba(0, 0, 0, 0) !important;
		padding: 0px !important;
		padding-left: 20px !important;
		height: auto !important;
		line-height: 20px !important;
		overflow: auto !important;
		background-image: url("../img/plus_icon.png");
	}
	
	.add_room:hover {
		background-image: url("../img/plus_icon.png");
	}
	
	.sc_article:first-child {
		margin-top: 10px;
	}
	
	div.booking_horizontal {
	    width: 92%;
	}
}

@media only screen and (min-width: 0px) and (max-width: 550px) {
	.anreise {
		float: none;	
	}
	
	.abreise {
		float: none;
		margin-left: 0px;
	}
	
	.imagecontainer_right {
		display: none;
	}
	
	.imagecontainer {
		display: block;
		height: 250px;
	}
	
	div.form_field > select[name="guest_birthday_day"], div.form_field > select[name="guest_birthday_month"], div.form_field > select[name="guest_birthday_year"] {
	    margin-bottom: 10px !important;
	}
}

@media only screen and (min-width: 0px) and (max-width: 400px) {
	.imagecontainer_right {
		display: none;
	}
	
	.imagecontainer {
		display: block;
		height: 150px;
	}
	
	.roomteaser_image {
	    height: 150px;
	}
	
	div.dialog_pagination div.pagination-separator {
	    width: 5px !important;
	}
	
	input.action_button, input.formbutton  {
		width: 100%;
	}
}

/**************** BOOKING CART **************/

.bookingcart_container {
	background-color: rgba(0, 0, 0, 0.1);
	color: white;	
	padding-top: 100px;
	padding-bottom: 20px;
	padding-left: 150px;
}

/* Small Desktops */
@media only screen and (min-width: 1280px) and (max-width: 1399px) {
	.bookingcart_container {
		padding-left: 50px;
	}
}

@media only screen and (min-width: 768px) and (max-width: 1279px) {
	.bookingcart_container {
		padding-left: 50px;
		padding-right: 50px;
	}
}
	
/* Small Desktops */
@media only screen and (min-width: 0px) and (max-width: 767px) {
	.bookingcart_container {
		padding-left: 5%;
		padding-right: 5%;
	}
}


@media only screen and (min-width: 0px) and (max-width: 510px) {
	.bookingcart_container {
		padding-left: 2%;
		padding-right: 2%;
	}
}