/* ==========================================================================
   Body
   ========================================================================== */

body {
    background-color: #fff;
    color: #424141;
    font-size: 14px;
	line-height: 20px;
	font-family: 'Source Sans Pro', sans-serif;
}


/* ==========================================================================
   Base
   ========================================================================== */

a { color: #0f75bc; text-decoration: none;}
a:hover { color: #23a54d;}
a:focus { outline: none;}

h1, h2, h3, h4, h5, h6 { color: #0f75bc; font-weight: normal; line-height: 1; margin: 0;}
p { margin-top: 0;}

*, *:before, *:after {
	-moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box;
}


/* ==========================================================================
   Container
   ========================================================================== */

.container {
	position: relative;
	width: 940px;
	margin-right: auto;
	margin-left: auto;
}
.container:before,
.container:after {
	display: table;
	line-height: 0;
	content: "";
}
.container:after {
	clear: both;
}
.wide {
	width: 1220px;
}

/* row */
.row { margin-left: -20px;}
.row:before,
.row:after {
	display: table;
	line-height: 0;
	content: "";
}
.row:after {
	clear: both;
}


/* ==========================================================================
   Header
   ========================================================================== */

header {
	height: 120px;
	background-color: #f3f9fd;
}

/* logo */
a.logo {
	display: block;
	width: 245px;
	height: 70px;
	margin: 25px auto;
	background-image: url(../images/logo.png);
	background-size: 245px 70px;
}
    a.logo:hover { opacity: 0.9;}

/* language */
.language {
	position: absolute;
	top: 20px;
	right: 0;
	margin: 0;
	padding: 0;
	list-style: none;
}
.language li {
	font-size: 12px;
	text-align: right;
}
.language li a { color: #a7a7a7;}
.language li a:hover, .language li.active a { color: #0f75bc;}


/* ==========================================================================
   Navbar
   ========================================================================== */

.navbar {
	position: relative;
	z-index: 999;

	height: 50px;
	background-color: #0e76bc;
	border-top: 1px solid #fff;
	border-bottom: 1px solid #fff;
}

/* navbar > scroll */
.navbar.scroll {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
}

/* Menu
   ========================================================================== */
.menu {
	margin: 0;
	padding: 0;
	list-style: none;
	text-align: center;
}
.menu li {
	display: inline-block;
	font-size: 16px;
	font-weight: 300;
	line-height: 48px;
}
.menu li a {
    display: block;
	height: 48px;
	padding: 0 15px;
	color: #fff;
	text-decoration: none;
}
nav.de .menu li a { padding: 0 11px;}
.menu li a:hover, .menu li.active > a, .menu li:hover > a {
	background-color: #0c629c;
}

/* menu > ul */
.menu li ul {
    display: none;
    position: absolute;
	z-index: 999;
}
.menu li:hover ul {
    display: block;
	margin: 0 0 0 -1px;
	padding: 0;
	list-style: none;
	min-width: 150px;
	background-color: #0e76bc;
	border: 1px solid #fff;
	border-top: none;
}
.menu li ul li {
    display: block;
	text-align: left;
	line-height: 38px;
}
.menu li ul li a { height: 38px;}
.menu li ul li a:hover, .menu li ul li.active a { background-color: #0c629c;}
.menu li.active ul li.active:first-child a { background-color: #0e76bc;}
.menu li.active ul li.active:first-child a:hover { background-color: #0c629c;}

/* Language-mobile
   ========================================================================== */
.language-mobile { display: none;}


/* ==========================================================================
   Portal-banner
   ========================================================================== */

.portal-banner {
	position: relative;
	height: 400px;
	overflow: hidden;
}

/* carousel */
.portal-banner .carousel {
	margin: 0;
	padding: 0;
	list-style: none;
}
.portal-banner .carousel li {
	position: relative;
	float: left;
	height: 400px;
	border-right: 1px solid #fff;
}
.portal-banner .carousel li .caption {
	position: absolute;
	top: 60px;
	left: 0;
	right: 0;
	text-align: center;
	color: #fff;
	font-weight: 600;
	text-shadow: 0 0 5px rgba(0, 0, 0, 0.5);
}
.portal-banner .carousel li .caption .title { font-size: 36px; margin-bottom: 20px;}
.portal-banner .carousel li .caption .subtitle { font-size: 28px;}

/* direction */
.portal-banner .direction { margin: 0; padding: 0; list-style: none;}
.portal-banner .direction a { display: block; width: 45px; height: 45px; margin-top: -20px; background: url(../images/direction-nav.png) no-repeat 0 0; cursor: pointer; position: absolute; top: 50%; z-index: 10; -webkit-transition: all .3s ease; -moz-transition: all .3s ease; transition: all .3s ease;}
.portal-banner .direction a.prev { background-position: 0 100%; left: 15px;}
.portal-banner .direction a.prev:hover { left: 12px;}
.portal-banner .direction a.next { background-position: 100% 0; right: 15px;}
.portal-banner .direction a.next:hover { right: 12px;}


/* ==========================================================================
   Main-banner
   ========================================================================== */

.main-banner {
	position: relative;
	height: 390px;
	overflow: hidden;
}
.main-banner.home {
	height: 400px;
	margin-top: 30px;
	margin-bottom: -120px;
}
.main-banner .carousel {
	margin: 0;
	padding: 0;
	list-style: none;
}
.main-banner .carousel li {
	position: relative;
	float: left;
	height: 400px;
	border-right: 1px solid #fff;
}
.main-banner .carousel li .caption {
	position: absolute;
	top: 60px;
	left: 0;
	right: 0;
	text-align: center;
	color: #fff;
	font-weight: 600;
	text-shadow: 0 0 5px rgba(0, 0, 0, 0.5);
}
.main-banner .carousel li .caption .title { font-size: 36px; margin-bottom: 20px;}
.main-banner .carousel li .caption .subtitle { font-size: 28px;}

/* direction */
.main-banner .direction { margin: 0; padding: 0; list-style: none;}
.main-banner .direction a { display: block; width: 45px; height: 45px; margin-top: -22px; background: url(../images/direction-nav.png) no-repeat 0 0; cursor: pointer; position: absolute; top: 50%; z-index: 10; -webkit-transition: all .3s ease; -moz-transition: all .3s ease; transition: all .3s ease; }
.main-banner .direction a.prev { background-position: 0 100%; left: 15px;}
.main-banner .direction a.prev:hover { left: 12px;}
.main-banner .direction a.next { background-position: 100% 0; right: 15px;}
.main-banner .direction a.next:hover { right: 12px;}

.main-banner .item {
    border-right: 1px solid #fff;
	border-left: 1px solid #fff;
	background-size: cover; 
	background-position: center center; 
	min-height: 400px;
}

/* owl-nav */
.main-banner .owl-carousel .owl-nav div {display: block;position: absolute;top: 50%;transition: all 0.3s ease;color: #fff;cursor: pointer;}
.main-banner .owl-carousel .owl-nav div .fa { display: block; font-size: 30px;}
.main-banner .owl-carousel .owl-nav .owl-prev {left: 10px;}
.main-banner .owl-carousel .owl-nav .owl-prev:hover { left: 5px;}
.main-banner .owl-carousel .owl-nav .owl-next {right: 10px;}
.main-banner .owl-carousel .owl-nav .owl-next:hover { right: 5px;}
.main-banner .owl-carousel .owl-nav i.fa {
    font-size: 25px;
    background-color:  #fff;
    width:  30px;
    line-height: 33px;
    height:  30px;
    text-align:  center;
    border-radius:  100%;
    color: #333;
}


/* ==========================================================================
   Reservation-bar
   ========================================================================== */

.reservation-bar {
	margin-bottom: 30px;
	border-top: 1px solid #fff;
	background-color: #c3ddee;
}
.reservation-bar form {
	float: right;
	margin: 22px 0;
}
.reservation-bar .control-label {
	float: left;
	margin-right: 15px;
	font-size: 18px;
	font-weight: 600;
	line-height: 30px;
	text-transform: uppercase;
}
.reservation-bar .control-group {
	float: left;
	position: relative;
	height: 30px;
	margin-right: 5px;
	background-color: #e1eef7;
	border-radius: 2px;
}
.reservation-bar .control-group .icon {
	position: absolute;
	top: 0;
	left: 10px;
	bottom: 0;
	line-height: 30px;
}
.reservation-bar .control-group select {
	width: auto;
	margin-left: 25px;
	border: none;
	background: none;
	box-shadow: none;
}
.reservation-bar .control-group input {
	width: auto;
	margin-left: 25px;
	border: none;
	background: none;
	box-shadow: none;
}
.reservation-bar .control-button {
	float: left;
	height: 30px;
}
.reservation-bar .control-button button { text-transform: uppercase;}

a.book2017 {
    border-radius: 0;
    background-color: #63b0e4;
}
a.book2017:hover {
	background-color: #0e76bc;
}


/* ==========================================================================
   Highlights
   ========================================================================== */

.highlights {
	margin-top: 60px;
	margin-bottom: 60px;
}
.highlights .box {
	float: left;
	width: 220px;
	margin-left: 20px;
}

/* image */
.highlights .box .image {
	position: relative;
	width: 220px;
	height: 200px;
	overflow: hidden;
}
.highlights .box .image img {
	display: block;
	max-width: 100%;
	height: auto;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
.highlights .box:hover a .image img {
	-webkit-transform: scale(1.02);
	-moz-transform: scale(1.02);
	transform: scale(1.02);
}

/* mask */
.highlights .box .image .mask {
	position: absolute;
	top: 0;
	width: 220px;
	height: 200px;
}
.highlights .box .image .mask.one { background-image: url(../images/mask-one.png);}
.highlights .box .image .mask.two { background-image: url(../images/mask-two.png);}
.highlights .box .image .mask.three { background-image: url(../images/mask-three.png);}
.highlights .box .image .mask.four { background-image: url(../images/mask-four.png);}

/* description */
.highlights .box  .description {
	margin: 0 20px;
	text-align: center;
}
.highlights .box  .description h3 {
	margin: 15px 0 10px 0;
	color: #23a54d;
	font-size: 24px;
}
.highlights .box  .description p { color: #0e76bc;}


/* ==========================================================================
   Main
   ========================================================================== */

.main {
	margin-top: 60px;
}


/* ==========================================================================
   Content
   ========================================================================== */

.content h1 { font-size: 36px; font-weight: 600; margin-bottom: 14px;}
.content h2 { font-size: 24px; line-height: 1.2; color: #23a54d; margin-bottom: 14px;}
.content h3 { font-size: 18px; line-height: 1.2; margin-bottom: 2px;}
.content img, .content iframe { border: none;}
.content hr { height: 0; border: 0; border-top: 1px dashed #ccc;} 

.content.content-left {
	float: left;
	width: 440px;
}
.content.content-right {
	float: left;
	width: 460px;
	margin-left: 40px;
	padding-top: 45px;
}

/* Gallery
   ========================================================================== */
.gallery {
	position: relative;
	width: 460px;
	margin-top: 10px;
	margin-bottom: 45px;
}

/* carousel */
.gallery .carousel {
	margin: 0;
	padding: 0;
	list-style: none;
}
.gallery .carousel li {
	position: relative;
	float: left;
	width: 460px;
	height: 300px;
}
.gallery .carousel li img {
	display: block;
	max-width: 100%;
	height: auto;
}
.gallery .carousel li .caption {
	position: absolute;
	bottom: 20px;
	left: 0;
	right: 0;
	text-align: center;
	color: #fff;
	font-size: 14px;
	font-weight: 600;
	text-shadow: 0 0 3px rgba(0, 0, 0, 0.4);
}
/* broken */
.gallery.broken {
	margin-bottom: 60px;
	float: left;
    width: 100%;
}
.gallery.broken .carousel li {
	border-left: 1px solid #fff;
	border-top:1px solid #fff;
}
.gallery.broken .carousel li:not(:first-child) {
	width:153px;
	max-height: 120px;
}
.gallery.gallery .direction a {
	display: none;
}

/* direction */
.gallery .direction { margin: 0; padding: 0; list-style: none;}
.gallery .direction a { display: block; width: 30px; height: 30px; margin-top: -15px; background: url(../images/direction-nav-small.png) no-repeat 0 0; cursor: pointer; position: absolute; top: 50%; z-index: 10; -webkit-transition: all .3s ease; -moz-transition: all .3s ease; transition: all .3s ease;}
.gallery .direction a.prev { background-position: 0 100%; left: 10px;}
.gallery .direction a.prev:hover { left: 7px;}
.gallery .direction a.next { background-position: 100% 0; right: 10px;}
.gallery .direction a.next:hover { right: 7px;}

/* owl-nav */
.gallery .owl-carousel .owl-nav div {display: block;position: absolute;top: 50%;transition: all 0.3s ease;color: #fff;cursor: pointer;}
.gallery .owl-carousel .owl-nav div .fa { display: block; font-size: 30px;}
.gallery .owl-carousel .owl-nav .owl-prev {left: 10px;}
.gallery .owl-carousel .owl-nav .owl-prev:hover { left: 5px;}
.gallery .owl-carousel .owl-nav .owl-next {right: 10px;}
.gallery .owl-carousel .owl-nav .owl-next:hover { right: 5px;}
.gallery .owl-carousel .owl-nav i.fa {
    font-size: 25px;
    background-color:  #fff;
    width:  30px;
    line-height: 33px;
    height:  30px;
    text-align:  center;
    border-radius:  100%;
    color: #333;
}

/* Object search
   ========================================================================== */
.object-search {
    float:  left;
    width:  100%;
}

.object-search h2 {
    margin-bottom: 10px;
}


/* News-item
   ========================================================================== */
.news-item { min-height: 200px;}
.news-item h2 { margin: 0;}
.news-item p.date { margin: 5px 0; font-size: 12px;}
.news-item .image {
	position: relative;
	float: left;
	width: 220px;
	height: 200px;
	margin-top: -15px;
	margin-right: 20px;
	background-color: #c3ddee;
	overflow: hidden;
}
.news-item .image img {
	display: block;
	max-width: 100%;
	height: auto;
}
.news-item .image .mask {
	position: absolute;
	top: 0;
	width: 220px;
	height: 200px;
	background-image: url(../images/mask-one.png);
}


/* =============================================================================
   Photoalbum
   ========================================================================== */

.photoalbum { overflow: hidden;}
.photoalbum .thumb {
	float: left;
	width: 150px;
	margin: 0 20px 20px 0;
	overflow: hidden;
}
.photoalbum .thumb:hover { opacity: 0.9;}
.photoalbum .thumb img {
	display: block;
	max-width: 100%;
	height: auto;
	margin-bottom: 5px;
	box-shadow: 0 0 5px rgba(0, 0, 0, 0.5);
}

/* albums */
.albums { clear: both;}


/* ==========================================================================
   Accommodations
   ========================================================================== */

.accommodations .item {
	float: left;
	width: 220px;
	margin-left: 20px;	
	margin-bottom: 40px;	
}
.accommodations .item .img { width: 220px;}
.accommodations .item .img img {
	display: block;
	max-width: 100%;
	height: auto;	
}
.accommodation .object-info { margin-top: 20px;}

/* Carousel bugfix */
div.gallery > div.caroufredsel_wrapper { height: 368px !important;}
div.gallery > div > ul.carousel { height: 100% !important;}


/* ==========================================================================
   Footer
   ========================================================================== */

footer {
	position: relative;
	height: 260px;
	background: url(../images/footer-bg.png) no-repeat bottom center;
	overflow: hidden;
}

/* Footer-top
   ========================================================================== */
.footer-top {
	height: 210px;
	margin-left: 220px;
	padding-top: 50px;
}
.ft-col {
	float: left;
	width: 220px;
	margin-right: 20px;
}
.ft-col h5 {
	margin-bottom: 10px;
	color: #424141;
	font-size: 18px;
}
.ft-col ul {
	float: left;
	width: 110px;
	margin: 0;
	padding: 0;
	list-style: none;
}
.ft-col ul li {
	font-size: 12px;
	line-height: 22px;
}

.ft-col-address { width: 240px; margin-right: 0;}
.ft-col-address ul li { width: 130px;}
.ft-col-address ul li span { color: #0f75bc;}


/* Footer-bottom
   ========================================================================== */
.footer-bottom {
	height: 50px;
	margin-left: 220px;
	line-height: 50px;
}
.ft-copyright {
	color: #fff;
	font-size: 12px;
}


/* ==========================================================================
   Contact-form
   ========================================================================== */

.contact-form table { width: 100%;}
.contact-form small { color: #f00;}


/* ==========================================================================
   CSS3 transition
   ========================================================================== */

a.logo, .btn, .language li a {
	-webkit-transition: all 0.3s ease;
	   -moz-transition: all 0.3s ease;
		-ms-transition: all 0.3s ease;
		 -o-transition: all 0.3s ease;
			transition: all 0.3s ease;
}
.menu li a {
	-webkit-transition: background 0.3s ease;
	   -moz-transition: background 0.3s ease;
		-ms-transition: background 0.3s ease;
		 -o-transition: background 0.3s ease;
			transition: background 0.3s ease;
}


/* ==========================================================================
   Buttons
   ========================================================================== */

.btn {
	display: inline-block;
	padding: 5px 15px;
	color: #fff;
	line-height: 20px;
	text-align: center;
	vertical-align: middle;
	cursor: pointer;
	border: none;
	border-radius: 2px;
	background-color: #0e76bc;
}
	.btn:hover { color: #fff; background-color: #0c629c;}
	.btn.active { color: #fff; background-color: #0c629c; cursor: default;}

.btn-block {
	display: block;
	width: 100%;
	padding-left: 0;
	padding-right: 0;
}

/* Size
   ========================================================================== */
.btn-large { padding: 6px 14px; font-size: 15px;}
.btn-small { padding: 2px 8px; font-size: 12px;}
.btn-mini { padding: 0 6px; font-size: 11px;}


/* ==========================================================================
   Forms
   ========================================================================== */

.form-horizontal .form-group label {
	display: inline-block;
	margin-right: 20px;
    margin-bottom: 0;
}
.form-group {
	margin-bottom: 10px;
}
label {
    display: block;
    margin-bottom: 5px;
}
select,
textarea,
input[type="text"],
input[type="password"] {
	display: inline-block;
	height: 30px;
	padding: 5px 6px;
	vertical-align: middle;
	border-radius: 2px;
	color: #595959;
	line-height: 20px;
}
input,
select,
textarea {
	width: 220px;
}
select,
textarea,
input[type="text"],
input[type="password"] {
	background-color: #fff;
	border: 1px solid #ccc;
	box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
}
select.invalid,
textarea.invalid,
input[type="text"].invalid,
input[type="password"].invalid {
	border: 1px solid #d44950;
}
select.invalid:focus,
textarea.invalid:focus,
input[type="text"].invalid:focus,
input[type="password"].invalid:focus {
	border: 1px solid #d44950;
	box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #d44950;
}
select:focus,
textarea:focus,
input[type="text"]:focus,
input[type="password"]:focus {
	border-color: rgba(82, 168, 236, 0.8);
	outline: 0;
	box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(82, 168, 236, 0.6);
}
input[type="file"],
input[type="image"],
input[type="submit"],
input[type="reset"],
input[type="button"],
input[type="radio"],
input[type="checkbox"] {
	width: auto;
}
select[multiple],
select[size],
textarea {
	height: auto;
}
select,
input[type="radio"],
input[type="checkbox"] {
	cursor: pointer;
}

/* Size
   ========================================================================== */	
.input-mini { width: 50px;}
.input-small { width: 110px;}
.input-medium { width: 170px;}
.input-large { width: 260px;}


/* ==========================================================================
   Helper classes
   ========================================================================== */

.pull-left { float: left;}
.pull-right { float: right;}

.text-left { text-align: left;}
.text-right { text-align: right;}
.text-center { text-align: center;}

.clear { clear: both;}

.clearfix:before, .clearfix:after { display: table; content: "";}
.clearfix:after { clear: both;}


/* ==========================================================================
   Print styles
   ========================================================================== */

@media print {
	* { color: #000 !important; text-shadow: none !important; background: transparent !important; box-shadow: none !important; }
	a, a:visited { text-decoration: underline; }
	a[href]:after { content: " (" attr(href) ")";}
	abbr[title]:after { content: " (" attr(title) ")";}
	.ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after { content: "";}
	pre, blockquote { border: 1px solid #999; page-break-inside: avoid;}
	thead { display: table-header-group;}
	tr, img { page-break-inside: avoid;}
	img { max-width: 100% !important;}
	@page { margin: 0.5cm;}
	p, h2, h3 { orphans: 3; widows: 3;}
	h2, h3 { page-break-after: avoid;}
}