/* init */
@font-face {
    font-family: 'ProximaNovaRgBold';
    src: url('fonts/proximanova-bold-webfont.eot');
    src: url('fonts/proximanova-bold-webfont.eot?#iefix') format('embedded-opentype'), url('fonts/proximanova-bold-webfont.woff') format('woff'), url('fonts/proximanova-bold-webfont.ttf') format('truetype'), url('fonts/proximanova-bold-webfont.svg#proxima_nova_rgbold') format('svg');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'ProximaNovaRgRegular';
    src: url('fonts/proximanova-regular-webfont.eot');
    src: url('fonts/proximanova-regular-webfont.eot?#iefix') format('embedded-opentype'), url('fonts/proximanova-regular-webfont.woff') format('woff'), url('fonts/proximanova-regular-webfont.ttf') format('truetype'), url('fonts/proximanova-regular-webfont.svg#proxima_nova_rgregular') format('svg');
    font-weight: normal;
    font-style: normal;
}
body,html,img,a,p,span,div,strong,em,ul,ol,li,label,textarea,form,fieldset,table,tr,th,td,h1,h2,h3,h4,h5,h6,hr,iframe,embed,object {
    list-style-type: none;
    text-decoration: none;
    outline: none;
    border: 0;
    margin: 0;
    padding: 0;
}
a {
    color: #000;
}
table,
td,
tr,
th {
    border-spacing: 0;
    vertical-align: middle;
    border-collapse: collapse;
}
label {
    display: block;
}
.clearfix:after {
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
}
.clearfix {
    display: inline-table;
}
* html .clearfix {
    height: 1%;
}
.clearfix {
    display: block;
}
h2 {
    font-family: 'ProximaNovaRgBold';
}
h2,
h3,
h4,
h5 {
    text-transform: uppercase;
    font-weight: normal;
}
#message {
	display: inline-block;
    background: #cc0000;
    color: #fff;
    padding: 5px;
    text-align: center;
    text-transform: uppercase;
	margin: 0 0 20px 15px;
}
#contact #message {
	margin: 0 0 20px 0;
}
#BtnLaunchBooking,
.co-widget,
.co-widget-button {
    background-color: #000 !important;
    
}
.co-widget-button {
    margin-top: 20px;
    background: url('../img/ticket.svg') no-repeat 10px center #000 !important;
    background-size: 35px !important;
}
.co-widget-button a {
    color: #fff !important;
}
.date-picker-wrapper {
    z-index: 10000 !important;
}

/* layout */
body,html {
	height: 100%;
}
body {
    color: #000;
    font-family: 'ProximaNovaRgRegular', Arial, Verdana, Sans-serif;
    font-size: 13px;
    line-height: 17px;
    letter-spacing: 0.3px;
	background: #f5f5f5;
}
h1 {
    display: none;
}
#container {
	min-height: 100%;
	max-width: 1350px;
	margin: auto;
	box-sizing: border-box;
	position: relative;
	padding-bottom: 175px;
	background: #fff;
}
#container > .wrapper {
    width: 965px;
    padding: 0 15px 0 15px;
    margin: auto;
}
body.home.index #container > .wrapper {
    width: auto;
    padding: 0;
    margin: 0;
}
#header {
	position: absolute;
	background: #fff;
	z-index: 10000;
	left: 0;
	right: 0;
	top: 0;
    padding: 20px;
	height: 105px;
    border-bottom: 1px solid #afafaf;
    position: relative;
	box-sizing: border-box;
}
#logo {
	display: block;
    background: url('../img/logo.svg') no-repeat;
	width: 245px;
	height: 69px;
	background-size: 100%;
}
#header .page_title {
	text-transform: uppercase;
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	font-size: 12px;
}
body.home.index #header .page_title {
	display: none;
}
#content {
    padding-top: 25px;
    position: relative;
}
#footer {
    position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	background: #212121;
	height: 175px;
	padding: 30px 20px;
	box-sizing: border-box;
}
#footer,
#footer a {
	color: #fff;
}
#logos {
    position: absolute;
    top: 30px;
    right: 20px;
}
#logos li {
	display: inline-block;
}
#logos li img {
	height: 60px;
	padding-left: 20px;
}

/* Booking button */
#booking_button {
	position: absolute;
	right: 190px;
	top: 40px;
    
}
.booking_button a {
    text-transform: uppercase;
    display: inline-block;
    color: #fff;
    padding: 3px 5px 3px 20px;
    background: url('../img/ticket.svg') 5px center no-repeat #000;
    background-size: 10px;
}
#menu .booking_button {
    display: none;
    margin-bottom: 20px;
}

/* Menu */
#menu_button {
	position: absolute;
	right: 20px;
	top: 40px;
	background: url('../img/menu.svg') no-repeat right center;
	background-size: 25px;
	width: 25px;
	line-height: 25px;
	height: 24px;
	cursor: pointer;
	padding-right: 50px;
	text-transform: uppercase;
}
body.menu_expanded #menu_button {
	background: url('../img/cross.svg') no-repeat right center;
	background-size: 25;
	height: 25px;
}
#menu_lang {
    position: absolute;
    right: 120px;
    top: 40px;
    line-height: 25px;
    text-transform: uppercase;
}
#menu_lang .selected {
    font-family: 'ProximaNovaRgBold';
}
#menu {
    position: absolute;
	z-index: 9999;
    right: 0;
	left: 0;
    top: 105px;
	transform: translateY(-100%);
	background: #212121;
	padding: 20px;
	color: #fff;
	transition: 0.4s;
}
body.menu_expanded #menu {
	transform: translateY(0);
	transition: 0.4s;
}
#menu > ul > li {
    float: left;
	margin-right: 30px;
}
#menu > ul > li:last-child {
    margin-right: 0;
}
#menu a {
	color: #fff;
	font-size: 16px;
}
.menu {
    display: inline;
    font-family: 'ProximaNovaRgRegular', 'Arial', 'Sans-serif';
    text-transform: uppercase;
    font-size: 15px;
	line-height: 20px;
    letter-spacing: 0.6px;
    padding: 0 2px 0 2px;
}
a.menu:hover,
a.menu.selected {
	background: #000;
	color: #fff;
}
#footer a.menu.selected,
#footer a.menu:hover,
#menu a.menu.selected,
#menu a.menu:hover {
	opacity: 0.8;
	background: transparent;
}
#menu .children {
	margin-top: 10px;
}
#menu .children a {
	font-size: 15px;
	color: #989898;
	text-transform: none;
}
#submenu_1_container,
#submenu_2_container {
    padding: 8px 0 8px 0;
    border-bottom: 1px solid #afafaf;
}
#submenu_1_container li,
#submenu_2_container li {
    float: left;
    padding-right: 8px;
}
.menu_footer,
.network {
    float: left;
    width: 245px;
}
.network li {
	margin-bottom: 10px;
}
#newsletter {
	display: block;
	background: url('../img/newsletter.svg') no-repeat left center;
	background-size: 15px;
	padding-left: 20px;
}

/* Popup */
.page_popup {
    display: none;
	position: fixed;
    z-index: 100000;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	background: rgba(255,255,255, 0.8);
}
.page_popup.unclosable {
    background: rgba(255,255,255, 0.95);
}
.page_popup > .wrapper {
    width: 100%;
	max-width: 700px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
    box-shadow: 0 0 10px #666;
    padding: 35px;
    box-sizing: border-box;
}
.page_popup > .wrapper .close {
    position: absolute;
    z-index: 1000;
    top: 15px;
    right: 15px;
    width: 15px;
    height: 15px;
    background: url('../img/close_black.png') no-repeat;
    background-size: 100%;
    cursor: pointer;
}
.page_popup.unclosable > .wrapper .close {
    display: none;
}
.page_popup > .wrapper .image {
    float: left;
    width: 50%;
    position: relative;
}
.page_popup > .wrapper .image img {
    width: 100%;
}
.page_popup > .wrapper .details {
    float: right;
    width: 45%;
}
.page_popup > .wrapper .details h2 {
    font-size: 20px;
    line-height: 23px;
}
.page_popup > .wrapper .details .description {
    margin-top: 20px;
    font-size: 18px;
    line-height: 21px;
}
.page_popup > .wrapper .details .more {
    font-size: 15px;
    display: block;
    padding: 10px;
    margin: auto;
    border: 1px solid #000;
    text-align: center;

    margin-top: 20px;
}
@media only screen and (max-width: 1023px) {
}
@media only screen and (max-width: 767px) {
    .page_popup {
        height: 100vh;
        top: 15px;
        left: 15px;
        right: 15px;
        bottom: 15px;
        width: auto;
    }
    .page_popup > .wrapper {
        position: static;
        top: 0;
        left: 0;
        transform: none;
        height: calc(100vh - 30px);
        overflow: auto;
        
    }
    .page_popup > .wrapper .image {
        float: none;
        width: 100%;
    }
    .page_popup > .wrapper .details {
        float: none;
        width: 100%;
    }
}


/* Networks */
.network h4 {
    font-family: 'ProximaNovaRgBold';
    margin-bottom: 10px;
}
.network .facebook,
.network .twitter,
.network .instagram,
.network .youtube {
    display: inline-block;
    margin-right: 5px;
}
.network .facebook a,
.network .twitter a,
.network .instagram a,
.network .youtube a {
    content: '';
    width: 25px;
    height: 25px;
    display: block;
    float: left;
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: center;
}
.network .facebook a {
    background-image: url('../img/facebook.svg');
}
.network .twitter a {
    background-image: url('../img/twitter.svg');
}
.network .instagram a {
    background-image: url('../img/instagram.svg');
}
.network .youtube a {
    background-image: url('../img/youtube.svg');
}
@media only screen and (max-width: 1023px) {
	/* Menu */
	#menu > ul > li {
	    float: none;
	    padding: 0;
	    width: 100%;
	}
	#menu > ul > li > a {
		display: block;
		margin-bottom: 10px;
	}
	#menu .children {
		margin-top: 0;
	    margin-bottom: 15px;
	}
    #booking_button {
    	right: 190px;
    }
}
@media only screen and (max-width: 767px) {
    #booking_button {
    	display: none;
    }
    #menu .booking_button {
        display: block;
        filter: invert(1);
    }
	/* Layout */
	#container > .wrapper {
		width: 100%;
		padding: 0;
	}
	#menu_button {
		font-size: 0;
	}
    #menu_lang {
        right: 70px;
    }
	#header .page_title {
		display: none;
	}
	#content {
	    padding-top: 10px;
	}
	#footer #logos {
		position: static;
		float: none;
	}
	#footer {
		position: static;
		height: auto;
	    margin-top: 0;
	    padding-top: 15px;
	}
	.menu_footer li a,
	.network li a {
	    display: block;
	    width: auto;
	    text-align: left;
	    font-size: 16px;
	    line-height: 30px;
	}
	.menu_footer,
	.network {
	    float: none;
	    width: 100%;
	}
}

/* Html */
#html {
    font-size: 14px;
    line-height: 20px;
}
#html a:hover {
    text-decoration: underline;
}


/* Newsletter */
#newsletter_form > div {
	margin-bottom: 15px;
}
#newsletter_form .legal {
	font-style:italic;
	color: #666;
}
#newsletter_form label {
	font-weight: bold;
}
#newsletter_form input[type=email]
{
    border: 1px solid #000;
    padding: 5px;
    width: 400px;
    resize: none;
}


/* Ajax browser */
#ajaxBrowserContainer {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 20000;
    overflow-y: scroll;
    width: 100%;
}
#ajaxBrowser {
    background: #fff;
    margin: auto;
    margin-top: 40px;
    margin-bottom: 20px;
    position: relative;
    z-index: 30000;
    padding: 15px;
    width: 965px;
}
#ajaxBrowserContent {}
#ajaxBrowserMask {
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    background: #000;
    z-index: 10000;
    filter: alpha(opacity=80);
    -moz-opacity: 0.80;
    opacity: 0.80;
}
.ajaxBrowserClose {
    position: absolute;
    top: -30px;
    right: 0;
    width: 17px;
    height: 17px;
    background: url('../img/close.png') no-repeat;
    cursor: pointer;
}


/* Blog */
#blog .posts .post {
	padding-bottom: 30px;
	margin-bottom: 30px;
	border-bottom: 1px solid #afafaf;
}
#blog .posts .post:last-child {
	border: 0;
}
.post .date {
	text-transform: none;
	font-size: 10px;
	margin-top: 5px;
}
.post .details,
.post .thumbnail {
	float: left;
	width: 50%;
	box-sizing: border-box;
}
.post .details {
	padding-left: 10px;
}
.post .details .title {
	margin-bottom: 5px;
}
.post .details .text,
.post .details .catcher {
	margin-top: 10px;
	padding-right: 20px;
}
.post .thumbnail {
	padding-right: 10px;
	position: relative;
} 
.post .thumbnail .caption {
	display: none;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 10px;
	background: rgba(0,0,0, 0.5);
	color: #fff;
	padding: 5px;
}
.post .thumbnail:hover .caption {
	display: block;
}
.post .thumbnail img {
	width: 100%;
	display: block;
}
#blog .posts .post:nth-child(even) .thumbnail {
	float: right;
	padding: 0 0 0 10px;
}
#blog .posts .post:nth-child(even) .details {
	padding: 0 10px 0 0;
}
#blog .posts .post:nth-child(even) .thumbnail .caption {
	right: 0;
	left: 10px;
}
#post .linked_files {
	margin-top: 30px;
	padding-top: 30px;
	border-top: 1px solid #afafaf;
}
#post #linked {
    margin-top: 20px;
    border-top: 1px solid #afafaf;
    padding-top: 20px;
}
@media only screen and (max-width: 767px) {
	/* Blog */
	.post .details, .post .thumbnail {
	    float: none;
	    width: 100%;
	}
	#blog {
		padding: 0 10px;
	}
	#blog .posts .post:nth-child(2n) .thumbnail,
	#blog .posts .post .details,
	#blog .posts .post .thumbnail {
		padding: 0;
	}
	#blog .posts .post .thumbnail {
		margin-bottom: 10px;
	}
	#post .post .thumbnail {

    	padding: 0 10px;
		margin-bottom: 10px;
	}
}


















