
@font-face {
    font-family: "Regular";
    src: url('../fonts/Montserrat-Regular.ttf');
}
@font-face {
    font-family: "Title";
    src: url('../fonts/Montserrat-Bold.ttf');
}
@font-face {
    font-family: "Icons";
    src: url('../fonts/heydings_icons.ttf');
}




html, body {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	margin:0;
	padding:0;
	font-family: 'Regular', sans-serif;
	color:#23272b;
	font-weight:normal;
	font-size:14px;
	background:#ffffff;
}

a:focus, input:focus { outline:none; }

input[type="text"], textarea, select {
	border:1px solid #ffffff;
	box-sizing:border-box;
	padding:10px;
	font-family:'Regular';
}

.message-error, .message-confirmation {
	margin:10px auto;
	padding:10px;
	font-size:17px;
	background:#CF5F5F;
	color:#FFFFFF;
}
.message-confirmation {
	background:#92BF4D;
}
.message-error a, .message-error a:visited, .message-confirmation a, .message-confirmation a:visited {
	color:#FFFFFF !important;
	text-decoration:underline;
	font-weight:bold;
}

.clear {
	display:block;
	margin:0;
	clear:both;
}

a {
	color:#ffffff;
	font-weight:bold; }
}
a:hover { color:#000000; }

a img { border:none; }


h1, h2, h3, h4, h5 {
	margin:0 0 40px;
	padding:0 0 20px;
	font-weight:bold;
	color:#000000;
	text-align:center;
	font-family:'Title';
}

h2 strong {
    background: linear-gradient(
        to bottom,
        transparent 70%,
        #f5a123 70%
    );
}


#mentions-legales-content h1 { font-size:50px; text-align:center; }
#mentions-legales-content h2 {
	margin:20px 0 0;
	padding:20px 0 0;
	text-align:center;
	font-size:25px;
}
#mentions-legales-content {
	max-width:1200px;
	margin:0 auto;
	text-align:left;
}


#site-down-content {
	max-width:1200px;
	margin:150px auto;
	text-align:center;
}
#table-down-for-maintenance {
	max-width:500px;
	margin:10px auto;
	text-align:center;
}

.main-content { padding:100px 0 0; }



#overlay-loader {
	position:fixed;
	left:0;
	top:0;
	width:100%;
	height:100%;
	background:#ffffff;
	z-index:1000;
}


span#back-to-top {
	width:50px;
	height:50px;
	position:fixed;
	bottom:10px;
	left:10px;
	z-index:100;
	background:url('../images/button-top.png') no-repeat top;
	box-shadow:0 0 20px rgba(0, 0, 0, .3);
}

header {
	display:block;
	position:fixed;
	top:0;
	left:0;
	width:100%;
	height:150px;
	padding:0;
	box-sizing:border-box;
	transition:all .2s;
	z-index:1000;
}
#header-top {
	position:absolute;
	left:0;
	top:0;
	width:100%;
	background:#f5a123;
	padding:0 20px;
	box-sizing:border-box;
	text-align:right;
	z-index:1;
}
#header-top a {
	margin:0;
	padding:8px 20px;
	display:inline-block;
	text-decoration:none;
	font-weight:normal;
}
header nav {
	position:relative;
	display:inline-block;
	vertical-align:top;
	margin:0;
	width:calc(100% - 305px);
	height:150px;
	padding:0;
	box-sizing:border-box;
	transition:all .2s;
}
header nav.active {
	display:block;
}
header nav ul {
	display:block;
	margin:0;
	padding:0 70px;
	list-style:none;
	text-align:right;
}
header nav ul li {
	position:relative;
	display:inline-block;
	margin:0 0 0 20px;
	padding:60px 0 0;
	vertical-align:top;
	text-align:center;
}
header nav ul li a {
	position:relative;
	display:block;
	padding:0 20px;
	line-height:90px;
	font-family:'Regular';
	font-weight:normal;
	font-size:18px;
	letter-spacing:1px;
	color:#ffffff;
	text-decoration:none;
	text-transform:uppercase;
	cursor:pointer;
	transition:all .2s;
}
header nav ul li a span.nav-icon-submenu {
	display:inline-block;
	vertical-align:sub;
	font-size:21px;
}

header nav span.nav-icons {
	position:absolute;
	display:block;
	top:35px;
	left:0;
	width:100%;
	height:50px;
	text-align:center;
	color:#fff;
	font-size:40px;
}



header a#logo {
	display:inline-block;
	vertical-align:top;
	margin:35px auto 0;
	width:300px;
	height:120px;
	padding:0;
	background:url('../images/logo.png') no-repeat bottom;
	background-size:100% auto;
	transition:all .2s;
}
header.sticky, header.no-homepage {
	height:100px;
	padding:0 0 0;
	box-shadow:0 0 20px rgba(0, 0, 0, .4);
	background:#000000;
	transition:all .2s;
}
header.sticky #header-top, header.no-homepage #header-top { padding:0 20px; min-height:auto; }
header.sticky nav, header.no-homepage nav { height:100px; transition:all .2s; }
header.sticky a#logo, header.no-homepage a#logo {
	height:70px;
	background-size:auto 150px;
	background-position:bottom 3px center;
	transition:all .2s;
}
header.sticky nav ul li,
header.no-homepage nav ul li { padding-top:35px; }
header.sticky nav ul li a,
header.no-homepage nav ul li a { padding:0 20px; line-height:65px; }


span#button-nav { display:none; }



ul.nav-submenus {
	position:absolute;
	left:0;
	top:100%;
	display:none;
	background:#000;
	list-style:none;
	padding:0;
	margin:0 auto;
	max-width:400px;
}
header nav ul.nav-submenus li {
	display:block;
	padding:0;
	margin:0;
	height:auto;
	line-height:normal;
}
ul.nav-submenus li a {
	display:block;
	padding:20px;
	font-family:'Regular', sans-serif;
	text-shadow:none;
	font-size:15px;
	font-weight:normal;
	color:#ffffff;
	text-transform:none;
	height:auto;
	text-align:left;
	white-space: nowrap;
	line-height:normal;
}
ul.nav-submenus li a:hover {
	background:#f5a123;
}





a[data-link-type="cms-styled-button"],
span[data-link-type="cms-styled-button"],
input[type="button"] {
	display:inline-block;
	margin:0 10px;
	padding:15px 20px;
	text-align:center;
	box-sizing:border-box;
	background:#f5a123;
	border:1px solid #f5a123;
	border-radius:2px;
	color:#fff;
	font-family:'Regular';
	font-weight:normal;
	text-transform:uppercase;
	text-decoration:none;
	letter-spacing:1px;
	text-shadow:none;
	transition:all .3s;
}
a[data-link-type="cms-styled-button"]:hover,
span[data-link-type="cms-styled-button"]:hover,
input[type="button"]:hover {
	background:transparent;
	border:1px solid #f5a123;
	color:#f5a123;
	transition:all .3s;
}
input[type="button"] {
	padding:10px 15px;
	cursor:pointer;
}



footer {
	display:block;
	margin:0;
	padding:0;
	box-sizing:border-box;
	background:#000;
	color:#fff;
}
#footer-logos {
	margin:0 0 30px;
	padding:40px 0;
	background:#ffffff;
	text-align:center;
}
#footer-logos a {
	display:inline-block;
	width:120px; 
	height:60px;
	background-position:center;
	background-size:contain;
	background-repeat:no-repeat;
	transition:all .2s;
	filter:grayscale(1);
}
#footer-logos a img {
	margin:40px 20px;
	height:50px;
}
#footer-logos a:hover {
	transition:all .2s;
	transform:scale(1.05);
	filter:grayscale(0);
}
footer #footer-block-contact-wrapper {
	padding:0;
	text-align:center;
}
a#footer-logo {
	display:block;
	margin:0 auto 50px;
	width: 300px;
	height: 120px;
	padding: 0;
	background: url('../images/logo.png') no-repeat bottom;
	background-size: auto;
	background-size: 100% auto;
}
#footer-legal-notice {
	padding:0 10px 100px;
	color:#fff;
	font-size:14px;
	text-align:center;
}
#footer-legal-notice a {
	color:#fff;
	text-decoration:none;
}
footer a:hover { color:#f5a123; }
#footer-blocks-wrapper {
	max-width:1200px;
	margin:0 auto;
}
.footer-blocks i {
	margin-right:10px;
	color:#f5a123;
}
.footer-blocks {
	display:inline-block;
	width:calc(20% - 5px);
	margin:0 0 50px;
	padding:0 20px;
	box-sizing:border-box;
	vertical-align:top;
}
.footer-blocks h4 {
	margin:0 auto 20px;
	padding:0;
	color:#f5a123;
	text-align:left;
}
footer p {
	margin:0 0 20px;
	font-size:12px;
}
.footer-blocks ul {
	margin:0;
	padding:0;
	list-style:none;
}
.footer-blocks a {
	text-decoration:none;
	font-weight:normal;
	font-size:12px;
}


#cookies-rules {
	position:fixed;
	bottom:0;
	left:0;
	width:100%;
	padding:20px;
	box-sizing:border-box;
	background:rgba(0, 0, 0, .7);
	color:#FFFFFF;
	font-size:13px;
	text-align:center;
	z-index:10;
}
a#cookies-button-hide, a#cookies-button-more-infos {
	border:1px solid #fff;
	margin:0 0 0 10px;
	padding:10px;
	color:#fff;
	text-decoration:none;
	transition:all .5s;
}
a#cookies-button-more-infos, a#cookies-button-hide:hover {
	border-color:#000;
	background:#000;
	transition:all .5s;
}
a#cookies-button-more-infos:hover {
	border-color:#fff;
	background:none;
}











#navbread-wrapper {
	padding:40px 0;
	text-align:left;
	font-size:12px;
	color:#0e2b4b;
}
#navbread {
	max-width:1200px;
	margin:0 auto;
}
#navbread-wrapper a {
	color:#0e2b4b;
	font-weight:normal;
	text-decoration:underline;
}



span.pill {
	display:inline-block;
	padding:10px 20px;
	font-family:'Regular';
	font-weight:bold;
	background:rgba(0, 0, 0, .05);
	color:#666666;
	border-radius:100px;
	text-transform:uppercase;
	letter-spacing:1px;
	font-size:14px;
}






#index-content { padding:0; }
#index-big-cycle {
	position:relative;
	margin:0 auto;
	height:900px;
}
.index-big-cycle-items {
	height:100%;
	background-size:cover;
	background-repeat:no-repeat;
	background-position:center;
}
#index-big-cycle-item-1 {
	background-image:url('../images/big-slide-1.jpg');
}
.index-big-cycle-items h1 {
	display:block;
	max-width:1200px;
	margin:0 auto;
	padding:350px 0 0 0;
	box-sizing:border-box;
	font-weight:bold;
	color:#FFF;
	text-align:left;
	text-shadow:0 0 10px rgba(0, 0, 0, .3);
	font-size:50px;
}
.index-big-cycle-items h1 strong,
.index-big-cycle-items p strong {
	font-weight:inherit;
	color:#f6a123;
}
.index-big-cycle-items p {
	display:block;
	max-width:1200px;
	margin:0 auto;
	padding:20px 500px 0 0;
	box-sizing:border-box;
	color:#ffffff;
	text-align:left;
	text-shadow:0 0 10px rgba(0, 0, 0, .3);
	font-size:15px;
}
.index-big-cycle-items p a[data-link-type="cms-styled-button"]:first-of-type {
	background:none;
	border:1px solid #fff;
}
.index-big-cycle-items p a[data-link-type="cms-styled-button"]:first-of-type:hover { border-color:#f5a123; }


#index-block-pushes {
	max-width:1500px;
	margin:0 auto;
	padding:50px 0;
	text-align:center;
}

div[id^="index-block-"] h2 { font-size:30px; }
div[id^="index-block-"] h2 span.pill { margin-bottom:20px; }

.index-pushes {
	display:inline-block;
	margin:0 20px 40px;
	padding:0;
	width:calc(25% - 45px);
	vertical-align:top;
	box-shadow:0 10px 15px rgba(0, 0, 0, .2);
	background:#ffffff;
	text-decoration:none;
	transition:all .2s;
}
.index-pushes:hover {
	transform:scale(1.05);
	transition:all .2s;
}
.index-pushes span.image {
	display:block;
	height:200px;
	background-size:cover;
	background-position:center;
	background-repeat:no-repeat;
}
.index-pushes span.title,
.news-small-blocks h3 {
	display:block;
	padding:20px;
	background:#f5a123;
	color:#ffffff;
	font-family:'Title';
	font-size:20px;
}
.index-pushes span.description {
	display:block;
	padding:20px;
	background:#000;
	font-size:12px;
	text-align:left;
}




#index-block-news {
	padding:50px 0;
	background:rgba(0, 0, 0, .05);
	text-align:center;
}
#news-small-blocks-wrapper {
	max-width:1200px;
	margin:0 auto;
}
.news-small-blocks {
	display:inline-block;
	vertical-align:top;
	width:calc(33% - 45px);
	margin:0 20px 40px;
	box-shadow:0 10px 15px rgba(0, 0, 0, .2);
}
.news-small-block-image {
	display:block;
	height:200px;
	background-size:cover;
	background-position:center;
	background-repeat:no-repeat;
}
.news-small-blocks h3 { margin:0; }
.news-small-block-text {
	display:block;
	padding:20px;
	text-align:left;
	background:#ffffff;
}

#index-block-welcome-wrapper {
    display: flex;
    align-items: stretch;
}
#index-block-welcome-image {
	flex: 1;
	background-position:center;
	background-repeat:no-repeat;
	background-size:cover;
}
#index-block-welcome-text {
	flex: 1;
    padding: 20px;
	background-position:center;
	background-repeat:no-repeat;
	background-size:cover;
}








#page-cover {
	position:relative;
	height:600px;
	background-repeat:no-repeat;
	background-position:center;
	background-size:cover;
}
#page-cover:before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background: linear-gradient(
	to bottom,
	rgba(0, 0, 0, 0.6) 0%,
	rgba(0, 0, 0, 0.0) 100%
	);
}
#page-title-wrapper {
	position: absolute;
	left:0;
	top:0;
	margin:0;
	width:100%;
	text-align:left;
}
#page-title {
	margin:0 auto;
	max-width:1200px;
}
#page-title-wrapper h1 {
	margin:0 auto;
	padding:200px 0 10px;
	color:#ffffff;
	font-family:'Title';
	font-size:50px;
	text-align:left;
}
#page-title-wrapper p#page-subtitle {
	display:inline-block;
	width:auto;
	margin:0 0 30px;
	padding:0;
	background: linear-gradient( to bottom, transparent 70%, #f5a123 70% );
	color:#ffffff;
	font-family:'Title'; 
	font-size:30px;
}
#page-content-general {
	padding:0;
}
article.page-general p {
	margin:0 auto;
	padding:0 0 20px;
	max-width:1200px;
	font-size:16px;
}



article.page-general {
	margin:0 auto;
	padding:40px 0 0;
	vertical-align:top;
	max-width:1200px;
}
article.page-general h2 {
	clear:both;
	margin:0;
	text-align:left;
	color:#000000;
	font-size:30px;
}
article.page-general p { text-align:justify; }

article.page-general img { margin:0 20px 20px; }






article.page-general ul,
#page-list-subpages ul {
	margin:0 auto;
	padding:20px 0 0;
	list-style:none;
	text-align:center;
}
article.page-general ul li,
#page-list-subpages ul li {
	display: inline-block;
	margin: 0 20px 40px;
	padding: 0;
	width: calc(33% - 45px);
	vertical-align: top;
	box-shadow: 0 10px 15px rgba(0, 0, 0, .2);
	background: #ffffff;
	text-decoration: none;
	transition: all .2s;
}
article.page-general ul li a,
#page-list-subpages ul li a { text-decoration:none; }
article.page-general ul li strong ,
#page-list-subpages ul li a span.title {
	display: block;
	padding: 20px;
	background: #f5a123;
	color: #ffffff;
	font-family: 'Title';
	font-size: 20px;
}
#page-list-subpages ul li a span.image {
	display: block;
	height: 200px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
#page-list-subpages ul li a span.description {
	display: block;
	padding: 20px;
	background: #000;
	font-size: 12px;
	text-align: left;
}

#page-list-subpages {
	margin:0 auto;
	padding:40px 0 0;
	max-width:1200px;
	list-style:none;
}

#page-list-subpages ul li { padding:0; }
#page-list-subpages ul li a {
	display:block;
	margin:0;
	padding:0;
	box-sizing: border-box;
}



#page-cms-contact {
	margin:20px 0 0;
	padding:20px;
	background:#f2f2f2;
	text-align:center;
}
#page-cms-contact i { font-size:50px; }
#page-cms-contact h3 {
	margin:0;
	padding:0 0 20px;
	font-size:40px;
	text-align:center;
}
#page-cms-contact p { margin:0; padding:0 0 20px; }





#page-gallery-wrapper {
	margin:0;
	padding:40px 0 0;
	text-align:center;
}
#page-gallery-wrapper h2 {
	font-size:40px;
	text-align:center;
}
.album-gallery {
	margin:0 auto;
	max-width:1120px;
	padding:0;
	clear:left;
}

.album-gallery a {
	display:block;
	width:calc(25% - 5px);
	height:auto;
	transition:all .5s;
}
@media screen and (max-width:1000px) {
	.album-gallery a { width:calc(50% - 10px); }
}
.album-gallery a img {
	width:100%;
	border:5px solid #FFFFFF;
	box-sizing:border-box;
	height:auto;
}
@media screen and (min-width:1000px) {
	/* Only if screen > 1000px large */
	.album-gallery a img:hover {
		-webkit-transform: scale(1.05);
		-ms-transform: scale(1.05);
		transform: scale(1.05);
		z-index:100;
		box-shadow:0 0 5px rgba(0, 0, 0, .5);
		border:5px solid #FFFFFF;
		transition:all .5s;
	}
}









#page-contact-form-wrapper {
	display: flex;
	align-items: stretch;
}
#page-contact-form-wrapper iframe {
	flex: 1;
	height:auto;
	border: none;
}
#page-contact-form-general {
	flex: 0 0 auto;
	margin:0 auto;
	padding:20px;
	background:#000000;
	text-align:center;
	color:#ffffff;
}
#page-contact-form-general #form-wrapper { margin:0 auto; }
#page-contact-form-general p i {
	font-size:40px;
	color:#f5a123;
}
#page-contact-form-general h2 {
	margin:0;
	color:#ffffff;
	font-size:40px;
}
#page-contact-form-general input[type="text"], #page-contact-form-general select, #page-contact-form-general textarea {
	width:100%;
	max-width:600px;
	height:40px;
	margin:10px auto 0;
	padding:10px 16px;
	box-sizing:border-box;
	border:1px solid #000000;
	font-family:'PT Sans', sans-serif;
	font-size:14px;
	background:#ffffff;
}
#page-contact-form-general textarea { height:140px; }
#page-contact-form-general label {
	display:block;
	margin:10px auto 0;
	max-width:600px;
}
#page-contact-form-general input[type="button"], #page-contact-form-general input[type="submit"] { cursor:pointer; }




/* Back-office - Toolbar en Front-office - EOF */
@font-face {
    font-family: "Icons";
    src: url('../fonts/heydings_icons.ttf');
}
#front-office-toolbar {
	position:fixed;
	bottom:0;
	left:0;
	width:100%;
	padding:0 0 0 10px;
	z-index:99999;
	box-sizing:border-box;
	font-size:15px;
	background:#000000;
	color:#CCCCCC;
	box-shadow:0 0 5px rgba(0, 0, 0, .3);
}
#front-office-toolbar a, #front-office-toolbar a:visited {
	margin:0 10px;
	display:inline-block;
	padding:10px;
	color:#CCCCCC;
	text-decoration:none;
	transition:all .5s;
}
#front-office-toolbar a:hover {
	background:#5b544d;
	transition:all .5s;
	text-shadow:0 0 2px rgba(0, 0, 0, .5);
}
#front-office-toolbar span.icons {
	margin:0 5px 0 0;
	font-family:'Icons';
	font-size:15px;
	color:#CCCCCC;
}
/* Back-office - Toolbar en Front-office - EOF */