/*DESKTOP CSS

grau: 		#2c3b44
rot dunkel: #c20036
rot hell: 	#fbf2f5

*/



html,body{
	margin:0px;
	padding:0px;
	font-family: "Times New Roman", Times, serif;
	font-size:16px;
	line-height:140%;
	color:#2c3b44;
	background-color: rgba(208, 208, 208, 0.1);
}

h1,h2,h3,h4{
	line-height:140%;
}

h1{
	font-family: "Times New Roman", Times, serif;
	font-size:22px;
	line-height:140%;
	color:#007191;
	text-align:center;
	text-transform:uppercase;
	font-weight:normal;
}

h2{font-size:20px;}

h3{
	margin-top:0px;
	margin-bottom:5px;
	font-size: 17px !important; 
    font-weight: bold !important;
}
h4{
	margin-top:0px;
	margin-bottom:5px;
}

.rot{color:#c20036;}

a{
	text-decoration:none;
	color:#2c3b44;
}

a.button{
	text-transform:uppercase;
	display:inline-block;
	border: 1px solid #2c3b44;
	padding: 5px 10px;
	margin-top:5px;
}

a.button:hover{
	background-color:rgba(204,204,204,0.2);
}

p{
	margin-top:0px;
	margin-bottom:15px;
}

.inside{
	width:670px;
	margin:auto;
}

.narrow {
	font-size: 14px;
	margin: auto;
	padding-bottom: 15px;
	padding-top: 7px;
	line-height: 18px;
}

#logo {
  height: 70px;
  margin: auto;
  padding-top: 30px;
  width: 200px;
}

#banner{
	width:100%;
	height:300px;
	overflow:hidden;
	position:relative;
}

#banner ul{
	margin:0px;
	list-style:none;
	padding:0px;
}

#banner li{
	list-style:none;
	display:block;
	height:100%;
	width:100%;
	background-size:cover;
	margin:0px;
	position:rel;
	background-position:center;
}

#banner li[sel=false] {
	display:none;
}

.bannerLeft, .bannerRight {
	height: 50px;
	margin-top: -25px;
	position: absolute;
	top: 50%;
	width: 50px;
	background-size:cover;
	cursor:pointer;
}

.bannerLeft {
	left:10%;
	/* background-image: url("/lib/media.php?id=287"); */
}

.bannerRight {
	right:10%;
	/* background-image: url("/lib/media.php?id=289"); */
}

#banner h1 {
    color: #FFFFFF;
    font-size: 28px;
    padding: 0;
    position: absolute;
    text-align: left;
    top: 25px;
    width: 880px;
    z-index: 1;
}
#banner h1 em {
  background-color: rgba(240, 123, 0, 0.8);
  font-style: normal;
  line-height: 50px;
  padding: 5px;
}

.ui-effects-wrapper {
	position:absolute !important;
}

.border{
	border: 1px solid #144733;
	margin:30px 0px;
	position:relative;
}

.border_inside {
  background-color: #144733;
  margin: 2px;
  padding: 0 20px;
  width: calc(100% - 44px);
}

.listelement{
	border-top:1px solid #999;
	padding: 10px 30px 0;
	margin: 10px;
	font-size: 14px;
}

.third{
	display:block;
	float:left;
	width:29%;
	padding-left:2.5%;
	padding-right:2%;
	margin-bottom:10px;
}
.third.first,.third.doppel.first{
	padding-left:0px;
	padding-right:4%;
}
.third.last{
	padding-left:4%;
	padding-right:0px;
	float:right;
}

.third.doppel{
	display:block;
	float:left;
	width:62%;
	padding-left:2%;
	padding-right:2%;    
	min-height: 120px;
}

.third.desc{
	display:block;
	float:left;
	width:47%;
	padding-left:2%;
	padding-right:2%;    
	min-height: 120px;
}

.third.price{
	display:block;
	float:left;
	width:13%;
	text-align:center;
	padding-left:2%;
	padding-right:0%;    
	min-height: 120px;
}

.third.price input{
	margin-top:50px;
}

.third img{
	max-width:100%;
}

.page_head{
	width:90%;
	margin:auto;
	margin-top:10px;
	margin-bottom:0px;
	text-align:center;
}

#footer{
	border-top: 1px solid #2c3b44;
	margin-top:100px;
	margin-bottom: 30px;
}
.footer_logo{
	margin:auto;
	position:relative;
	top:-40px;
	width:87px;
	height:74px;
}
.footer_line{
	padding: 10px 0px;
}
.partnerLogo{
	padding: 10px 0px;
}

.footer_w50{
	width: 50%;
	float:left;
	text-align:center;
	font-weight:bold;
	font-style:italic;
}
.footer_w33{
	width: 33%;
	float:left;
	text-align:center;
	font-weight:bold;
	font-style:italic;
}

.relImage {
	background-position: center center;
	background-size: cover;
	height: 200px;
	width: 100%;
}

/* Buchungsmaske */ 
.bookingArea .col1 {
	display: table-cell;
	float: left;
	position: relative;
	width: 310px;
}

.bookingArea input[type="button"]{
	background-color:#2C3B44;
	color:#fff;
	border:none;    
	margin: 10px 0;
    padding: 5px;
	cursor:pointer;
}

.bookingArea {
	color:#fff;
}

.bookingArea .col2 {
	display: table-cell;
	float: right;
	position: relative;
	width: 310px;
}

.col2 > h2 {
  margin-left: 13px;
  color: #fff !important;
}

.col1 > h2 {
  margin-left: 13px;
  color: #fff !important;
}

.controlMask .date{
	width:130px;
}

.controlMask .number{
	width:35px;
	font-size: 0.8em;
}

.journeyTeaser .leftArrow,
.journeyTeaser .rightArrow {
	cursor: pointer;
	display: block;
	height: 30px;
	position: absolute;
	top: 85px;
	width: 30px;
	background-size:cover;
}

.journeyTeaser .leftArrow {
	/* background-image: url("/lib/media.php?id=273"); */
}

.journeyTeaser .rightArrow {
	/* background-image: url("/lib/media.php?id=285"); */
	right: 0;
}

#journeyTeaserError > h3 {
    color:#ffffff;   
}
.page1 {
  display: block;
  left: 0;
  width: 100%;
}
.page2 {
    display: block;
    left: 100%;
    position: absolute;
    width: 100%;
}
.journeyImageBox {
  background-color: #2c3b44;
  background-position: center center;
  background-size: cover;
  display: block;
  height: 190px;
  margin-right: 15px;
  position: absolute;
  width: 100%;
}

.journeyTextBox {
  color: #fff;
  height: 200px;
  position: absolute;
  width: 100%;
}

.journeyTeaser {
  height: 190px;
  margin-bottom: 20px;
  margin-right: 20px;
  margin-top: 25px;
  overflow: hidden;
  position: relative;
}
.journeyTeaser .journeyTextBox h3 {
	color: #fff;
	font-family:"Times New Roman", Times, serif;
	font-size: 20px;
	font-style: italic;
	font-weight: 300;
	line-height: 22px;
	margin: 10px 10px 10px 20px;
}
.journeyTeaser .journeyTextBox  p {
	color: #fff;
	float: none;
	font-size: 12px;
	line-height: 20px;
	margin: 0 30px;
}
.journeyTeaser .journeyTextBox  span {
	color: #fff;
	float: none;
	font-size: 12px;
	line-height: 20px;
	margin: 0 30px;
}

.ui-datepicker {
	font-size:0.6em;
	line-height:100%;
}

.imageSmall {
    display: inline-block;
    margin: 1%;
    width: 23%;
	cursor:pointer;
}
.third.first ul {
	/* list-style:none; */
	padding-left: 15px;
}
.third.first ul li {
	font-size: 12px;
	line-height: 14px;
	margin-right: 5%;
	
	-moz-hyphens: auto;
	-webkit-hyphens: auto;
	-ms-hyphens: auto;
	-o-hyphens: auto;
	hyphens: auto; 
}
.third.first li:nth-child(2n-1) {
}
.third.first li:nth-child(2n) {
    margin: 0;
}

#preloader {
	background-color: #000000;
	height: 100%;
	opacity: 0.6;
	position: absolute;
	text-align: center;
	top: 0;
	width: 100%;
	color: #FFFFFF;
}
#loaderImage {    
	height: 100px;
    margin: 6% auto;
    width: 100px;
	/* background-image:url("/lib/media.php?id=397"); */
}

.journeyPicker {
  bottom: 0;
  display: block;
  height: 65px;
  position: absolute;
  background-color: rgba(0, 0, 0, 0.8);
  font-size: 12px;
  width: 100%;
}

.journeyPicker[sel="true"]{
	display:block;
}
.page1:hover .journeyPicker,
.page2:hover .journeyPicker {
	display:block;
}

.selectButton,
.unselectButton {
    margin: 60px auto;
}


.narrow > ul {
    list-style: none outside none;
}

.narrow ul li {
    float: left;
    text-align: center;
    width: 33%;
}

.additionList {
	display:table;
	width:100%;
}

.additionList  > div {
	display:table-row;
}

.additionCell {
	border-bottom: 1px solid #e8dfe2;
	display: table-cell;
	padding-bottom: 5px;
	padding-top: 5px;
	width: 50%;
}

div .additionCell:first-child {
	width:20%;
}
.readonly .additionCell:first-child {
	width: 80%;
}
div .additionCell:last-child {
	width:20%;
	text-align:right;
}

.additionCell .ui-spinner {
    border: 1px solid #c9c9c9;
    font-size: 0.8em;
    width: 40px;
}

.loading {
	display:block;
	margin-top: -22px;
}

.dateInfo,
.roomInfo {
	background-color: #FFFFFF;
	border-radius: 2px;
	bottom: 30%;
	color: #C20036;
	font-size: 0.8em;
	padding: 5px;
	z-index: 1;
	line-height: 13px;
}
#roomListTarget  .dateInfo,
#roomListTarget  .roomInfo {
	border:1px solid #C20036;    
	margin-bottom: 15px;
	margin-top: 15px;
}

/* BookingProcess*/

.bookingControls {
	display:table;
	width:100%;
}

.stepBox {
	display: table-cell;
    text-align: center;
    vertical-align: middle;
    width: 20%;    
	opacity: 0.5;
}
.buttonBox {
	width: 12%;
}

.stepButton {
	background-color: #2C3B44;
	color: #FFFFFF;
	display: block;
	padding: 5px;
	min-width: 100px;
	opacity:1;
	cursor:pointer;    
	text-align: center;
}

.buttonDisabled {
	opacity: 0.5;
	cursor:not-allowed;
}

.stepNumber {
	border: 1px solid #2C3B44;
	border-radius: 10px;
	height: 20px;
	margin: auto;
	width: 20px;
}

.active {
	opacity:1;
}

.wideField {
  width: calc(100% - 30px);
}

.nameFiled {
    width: 23%;
}

.cityField {
	width: calc(100% - 90px);
}

.zipcodeField {
	width: 50px;
}

.fullPriceRow {
	border-bottom: 3px double #999999;
	border-top: 2px solid #999;
	color: #c20036;
	font-size: 30px;
	margin-top: 5px;
	padding-bottom: 10px;
	padding-top: 10px;
	text-align: right;
}

#personalData,
#showPersonalData {
	display: inline-block;
    vertical-align: top;
    width: 49%;
}
#addNotes,
#showAddNotes {
	display: inline-block;
    vertical-align: top;
    width: 50%;
}

.bookingArea .ui-spinner-disabled {
	background-color:#D0D0D0;
	opacity:1;
}

.buttonAttention {
	background-color:#C20036;
}

.halfWidthInput {
  margin: 0;
  width: calc(50% - 5px);
  box-sizing: border-box;
}

input[type="text"] {
	padding:3px;
}
textarea {
	padding:3px;
}

.fullWidthInput {
	margin: 15px auto 0;
	width: calc(100% - 9px);
	box-sizing: border-box;
}

#inseciaCaptchaImage {
	margin-left: calc(50% - 65px);
	margin-top: 15px;
}

.contactForm input[type="submit"] {
	text-transform:uppercase;
	display:inline-block;
	border: 1px solid #2c3b44;
	padding: 5px 10px;
	margin-top:5px;
}

.contactForm input[type="submit"]:hover{
	background-color:rgba(204,204,204,0.2);
}

textarea.fullWidthInput {
	height: 200px;    
	resize: none;
}


/* PicBox */

#bigPictureBox {
	background-color: rgba(0, 0, 0, 0.80);
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;    
	z-index: 10;
	
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-khtml-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

#bigPicture {
	position: absolute;
    top: 50%;
	left: 50%;
	background-repeat:no-repeat;
	background-position:center center;
	overflow:hidden;    
}

.picBoxNav {
	height: 50px;
    margin-top: -25px;
    position: absolute;
    top: 50%;
    width: 50px;
	background-color:#fff;
	opacity:0.25;
	line-height: 50px;    
	font-size: 30px;
	cursor:pointer;    
	font-weight: 600;
}

.picBoxNav:hover {
	opacity:0.8
}

.picBoxLeft {
    border-radius: 0 25px 25px 0;
    left: -35px;    
    padding-right: 15px;
	text-align: right;
}

.picBoxLeft:hover {
	left: -15px;
}

.picBoxRight {
    border-radius: 25px 0 0 25px;
    right: -35px;
    padding-left: 15px;
}

.picBoxRight:hover {
	right: -15px;
}

.picBoxExit {
    position: absolute;
    right: 0;
    top: 0;
    height: 20px;
    width: 20px;
    opacity: 0.25;
    border-radius: 0 0 0 40px;
	background-color: #FFFFFF;
    line-height: 18px;
    font-size: 18px;
    padding: 5px;
    text-align: right;
	cursor:pointer;
}

.picBoxDescription {
	background-color: rgba(255, 255, 255, 0.6);
	position: relative;
    text-align: center;
    top: 50%;
	margin: 0 auto;
}

.picBoxExit:hover {
	opacity:0.8;
	height: 30px;
    width: 30px;
}

/*Menü*/
#desktop_mainnav {
  font-size: 16px;
  height: 50px;
  position: relative;
  text-transform: uppercase;
  z-index: 5000;
}
.mainnav ul{margin:0px;padding: 2px 0;text-align:center;}
.mainnav ul li{width:auto;display:inline-block;padding-top:0}
.mainnav ul li a, .mainnav ul li span {
  color: #007191;
  display: block;
  height: 23px;
  padding-left: 5px;
  padding-right: 5px;
  padding-top: 15px;
}
.mainnav ul li a:hover, .mainnav ul li a:active,.mainnav ul li span.active{color:rgba(240, 123, 0, 1);cursor:pointer;text-decoration:underline;}

.mainnav ul li ul.level_2{
	position:absolute;
	display:none;
	width:auto;
	min-width:200px;
	background-color:rgba(255,255,255,0.9);
	overflow:hidden;
	text-align:left;
	padding-left:5px;
	text-transform:none;
	
}
.mainnav ul li:hover ul.level_2, .mainnav ul li:focus ul.level_2, .mainnav ul li:active ul.level_2{
	z-index:10000;
	display:block;
	-webkit-animation:myfirst linear 0.2s alternate;
	animation:myfirst linear 0.2s;
	animation-direction: alternate;
	animation-play-state: running;
	animation-fill-mode: both;
}

.mainnav ul li ul li{height:38px;float:none;display:block;margin-top:0;font-family:"Times New Roman", Times, serif; font-size:12px;}
.mainnav ul li ul li a,.mainnav ul li ul li span{height:auto;float:none;display:block;padding:8px 4px 8px 4px; font-weight:normal;}
.mainnav ul li ul li a:hover{color:#f07b00; text-decoration:none;}
.mainnav ul li ul li span.active{color:#c20036;}

.mainnav ul li ul li ul.level_3{left:230px;margin-top:-37px;position:absolute;display:none;box-shadow:2px 3px 2px #333}

.mainnav ul li.activeNav  > a{
    color:  #f07b00;
	text-decoration:underline;
}

.mainnav ul li ul li  > a.activeNav{
    color: #C20036;
}

/*.mainnav ul li.activeNav ul.level_2 {
    display: block;
}*/
.mainnav ul li.activeNav:hover ul.level_2{
	-webkit-animation:none;
	animation:none;
}

/*.journeyPicker{
	display: block;
	height: 50px;
	top: calc(100% - 60px);
}*/

.selectButton, .unselectButton {
	margin: 10px auto;
}

.rListContainer {
	display: inline-block;
    margin-right: 4%;
    vertical-align: top;
    width: 65%;
}
.jdContainer {
	width:30%;
	display:inline-block;
	vertical-align:top;
	margin-top:45px;
}

#journeyDetailsContainer {
    margin-top: -52px;
}
#journeyDetailsContainer .narrow {
    font-size: 12px;
	text-align: justify;
}
#journeyDetailsContainer h1 {
    font-size: 1.3em;
}
#journeyDetailsContainer ul {
    list-style: inherit;    
	padding: 0 15px;
}
#journeyDetailsContainer ul li {
    float: none;
    text-align: left;
    width: 100%;
}

.price > h3 {
    font-size: 1.7em;
}
.roomSelector {
	font-size: 0.95em;
}
#journeyHeadlineContainer .page_head{
	margin: -15px auto 0;
}
#journeyHeadlineContainer h1 {
    margin: 0;
}

.additionList div:last-child .additionCell {
  border-bottom: 0 none;
}
.addPriceShow {
  font-size: 16px;
  display:block;
}

.addPriceShowType {
	font-size: 14px;
}
.addName {
	font-weight: bold;
}
.addDesc {
	font-size: 14px;
}
.offererAdditions {
	padding-top: 20px;
}
.journeyAdditions {
	padding-top: 20px;
}
.showAddCalc {
	display: block;
	font-size: 12px;
	white-space: nowrap;
}
.showAddCalc .addPriceShow:after {
    content: " ";
}
.showAddCalc .addPriceShow {
    display: inline;
    font-size: 12px;
}