@font-face {
    font-family:"Title";
    src: url('../fonts/Poppins-Bold.ttf');
	font-weight:normal;
}
@font-face {
    font-family: "Regular";
    src: url('../fonts/Poppins-Regular.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:#eef2f5;
}

span.material-icons { vertical-align:sub; }

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 {
	position:relative;
	margin:0 0 40px;
	padding:0;
	font-weight:normal;
	color:#1f7287;
	text-align:left;
	font-family:'Title';
}

.pre-title {
	margin:0;
	padding:0;
	font-family:'Regular';
	font-weight:normal;
	text-transform:uppercase;
	font-size:18px;
	text-align:center;
}
.pre-title img[src*="title-icon"] {
	display:block;
	margin:0 auto 20px;
	width:auto;
	height:50px;
}

#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:120px 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;
	border-radius:10px;
	background:url('../images/button-top.png') no-repeat center #1f7287;
	background-size:40px auto;
	box-shadow:0 0 20px rgba(0, 0, 0, .3);
	cursor:pointer;
}

header {
	display:block;
	position:fixed;
	top:0;
	left:0;
	width:100%;
	height:120px;
	padding:0;
	background:#ffffff;
	box-sizing:border-box;
	transition:all .2s;
	z-index:1000;
}
#header-top {
	text-align:center;
	padding:5px;
	background:#1f7287;
	color:#fff;
}
#header-top p {
	display:inline-block;
	margin:0;
	padding:0;
	width:calc(50% - 5px);
}
#header-top p a {
	display:inline-block;
	text-decoration:none;
	font-weight:normal;
}
#header-top p:first-of-type { text-align:left; }
#header-top p:last-of-type { text-align:right; }
#header-top p:last-of-type a { margin-left:50px; }
header .material-icons { vertical-align:middle; }
header nav {
	margin:0;
	padding:0;
	box-sizing:border-box;
}
header nav ul {
	display:inline-block;
	width:calc(100% - 440px);
	margin:0;
	padding:0;
	list-style:none;
	text-align:center;
}
header nav ul li {
	position:relative;
	display:inline-block;
	vertical-align:middle;
	margin:0;
	padding:0;
}
header nav ul li a {
	position:relative;
	display:block;
	padding:10px;
	font-family:'Regular';
	font-weight:normal;
	font-size:18px;
	color:#46627b;
	text-decoration:none;
	cursor:pointer;
	transition:all .2s;
}
header nav a#nav-logo {
	display:inline-block;
	vertical-align:middle;
	margin:0 auto;
	width:260px;
	height:80px;
	padding:0;
	background:url('../images/logo.png') no-repeat center bottom;
	background-size:100% auto;
	transition:all .2s;
}




span#button-nav { display:none; }

a#button-rdv, a#button-phone { 
	display:inline-block;
	vertical-align:middle;
	padding:18px;
	background: linear-gradient(to bottom, #61cbe5 0%, #46adc7 100%);
	border-radius:100px;
	text-decoration:none;
	font-size:16px;
	font-weight:normal;
	color:#ffffff;
}
a#button-rdv:hover, a#button-phone:hover { 
	background: linear-gradient(to top, #61cbe5 0%, #46adc7 100%);
	box-shadow:0 3px 8px rgba(0, 0, 0, .1);
}
a#button-phone span.material-icons {
	display:inline-block;
	vertical-align:sub;
	font-size:21px;
}
a#button-phone.sticky { top:21px; }




ul.nav-submenus {
	position:absolute;
	display:block;
	left:0;
	top:100%;
	width:fit-content;
	display:none;
	background:#1f7287;
	list-style:none;
	padding:0;
	margin:0 auto;
}
header nav ul.nav-submenus li {
	display:block;
	padding:0;
	margin:0;
	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:#61cbe5;
}





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:linear-gradient(to bottom, #61cbe5 0%, #46adc7 100%);
	border:1px solid #61cbe5;
	border-radius:100px;
	color:#fff;
	font-family:'Regular';
	font-weight:normal;
	text-transform:uppercase;
	text-decoration:none;
	letter-spacing:1px;
	transition:all .3s;
}
a[data-link-type="cms-styled-button"]:hover,
span[data-link-type="cms-styled-button"]:hover,
input[type="button"]:hover {
	background:linear-gradient(to top, #61cbe5 0%, #46adc7 100%);
	box-shadow:0 3px 8px rgba(0, 0, 0, .1);
	color:#ffffff;
	transition:all .3s;
}
input[type="button"] {
	padding:10px 15px;
	cursor:pointer;
}

a[data-link-type="cms-styled-button"] span.material-icons {
	display:inline-block;
	vertical-align:sub;
	font-size:130%;
}



footer {
	position:relative;
	display:block;
	padding:0;
	box-sizing:border-box;
	background:#1b6477;
	color:#fff;
}
footer #footer-block-contact-wrapper {
	padding:0;
	background:#eef2f5;
	text-align:center;
}
footer #footer-block-contact {
	margin:0 auto;
	padding:30px 0;
	color:#23272b;
	text-align:center;
}
footer #footer-block-contact-wrapper h2,
#page-contact-form-general h2 {
	margin:20px 0 0;
	padding:0;
	font-size:60px;
	color:#1f7287;
	text-align:center;
}
#footer-block-contact-form-wrapper {
	margin:0 auto;
	max-width:600px;
}
#footer-block-contact-form-wrapper select,
#footer-block-contact-form-wrapper input[type="text"],
#footer-block-contact-form-wrapper textarea {
	display:block;
	margin:0 0 10px;
	padding:10px;
	width:100%;
	box-sizing:border-box;
	background:#ffffff;
	font-family:'Regular';
	font-size:14px;
}
#footer-block-contact-form-wrapper textarea { height:130px; }
#footer-block-contact-form-wrapper input[type="button"] {
	padding:20px 30px; 
	background: linear-gradient(to bottom, #61cbe5 0%, #46adc7 100%);
	color:#ffffff;
}
#footer-block-contact-form-wrapper input[type="button"]:hover {
	box-shadow:0 5px 10px rgba(0, 0, 0, .1);
	background: linear-gradient(to top, #61cbe5 0%, #46adc7 100%);
	color:#ffffff;
}
footer a[data-link-type="cms-styled-button"] { color:#ffffff; }

#form-contact-confirmation {
	margin:0 auto 10px;
	padding:20px;
	box-sizing:border-box;
	max-width:600px;
}

#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-address {
	margin:20px 0 0;
	padding:20px;
	background:#1f7287;
}


#cookies-rules {
	position:fixed;
	bottom:0;
	left:0;
	width:100%;
	padding:20px;
	box-sizing:border-box;
	background:#1f7287;
	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-hide, a#cookies-button-hide:hover {
	border-color:#fff;
	background:#fff;
	color:#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.title-before, article.page-general h1 {
	display:block;
	font-family:'Regular';
	text-transform:uppercase;
	font-size:15px;
	letter-spacing:2px;
	text-align:center;
}






#index-content { padding:150px 0 0; }

#index-big-cycle {
	margin:0 auto;
	padding:0 0 50px;
	max-width:1200px;
	position:relative;
}
#index-big-cycle-image {
	display:block;
	margin:0 auto 0 0;
	background:url('../images/index-big-image.png') no-repeat center;
	background-size:cover;
	border-radius:100px 0 0 0;
	width:500px;
	height:500px;
}
#index-big-cycle-text {
	position:absolute;
	left:450px;
	top:100px;
	padding:20px;
	border-radius:0 0 100px 0;
	box-sizing:border-box;
	background:#ffffff;
	width:calc(100% - 450px);
}
#index-big-cycle-text h1, #index-big-cycle-text h2 { margin:0; }


#index-block-welcome {
	position:relative;
	margin:50px auto;
	max-width:1150px;
	position:relative;
}
#index-block-welcome-image {
	display:block;
	margin:0 auto 0 0;
	vertical-align:top;
	width:600px;
	height:400px;
	border-radius:100px 0 0;
	background:url('../images/index-welcome.jpg') no-repeat center;
	background-size:cover;
}
#index-block-welcome-text {
	display:block;
	position:absolute;
	top:0;
	left:500px;
	border-radius:0 0 100px 0;
	margin:50px 0 0 0;
	padding:50px;
	width:calc(100% - 500px);
	box-sizing:border-box;
	text-align:left;
	background:#ffffff;
	color:#000000;
}
#index-block-welcome-text h3 {
	margin:0;
	padding:0;
	text-align:left;
	font-size:40px;
	color:#000000;
}


p.index-block-punchline {
	position:absolute;
	left:0;
	bottom:-21px;
	z-index:10;
	margin:0;
	padding:0 20px;
	box-sizing:border-box;
	color:#ffffff;
	background:#000000;
	font-size:40px;
	font-family:'Title2';
	text-align:left;
}


#index-block-news { background:#fff; }

#index-block-news,
#index-block-pushes,
#index-block-photos,
#index-block-welcome-wrapper {
	position:relative;
	padding:100px 0;
	text-align:center;
}
#index-block-news h2,
#index-block-pushes h2,
#index-block-welcome-wrapper h2 {
	text-align:center;
	font-size:50px;
}
#index-block-pushes { background:#ffffff; }
#index-block-pushes a.index-pushes {
	display:inline-block;
	background:#ffffff;
	margin:20px 30px 80px;
	padding:0;
	vertical-align:top;
	width:calc(20% - 65px);
	max-width:300px;
	border-radius:50px 0 0 0;
	box-sizing:border-box;
	font-weight:normal;
	text-decoration:none;
	box-shadow:0 0 15px rgba(0, 0, 0, .15);
	transition:all .3s;
}
#index-block-pushes span.index-pushes-image {
	display:block;
	height:300px;
	border-radius:50px 0 0 0;
	background-size:cover;
	background-position:center;
	background-repeat:no-repeat;
	transition:all .3s;
}
#index-block-pushes .index-pushes:nth-of-type(1) span.index-pushes-image { background-image:url('../images/index-push-01.jpg'); }
#index-block-pushes .index-pushes:nth-of-type(2) span.index-pushes-image { background-image:url('../images/index-push-02.jpg'); }
#index-block-pushes .index-pushes:nth-of-type(3) span.index-pushes-image { background-image:url('../images/index-push-03.jpg'); }
#index-block-pushes .index-pushes:nth-of-type(4) span.index-pushes-image { background-image:url('../images/index-push-04.jpg'); }

#index-block-pushes a.index-pushes span.index-pushes-title {
	display:block;
	padding:30px;
	background:#1f7287;
	font-family:'Title';
	color:#ffffff;
	font-size:20px;
	font-weight:normal;
	text-align:left;
}

#index-block-pushes a.index-pushes:hover,
article.news-small-blocks:hover {
	transform:scale(1.05);
	filter:grayscale(0);
	transition:all .3s;
}



#news-small-blocks-wrapper {
	max-width:1200px;
	margin:0 auto;
	text-align:center;
}
article.news-small-blocks {
	display:inline-block;
	position:relative;
	background:#ffffff;
	margin:20px 30px 80px;
	padding:0;
	border-radius:50px 0 0 0;
	vertical-align:top;
	width:calc(33% - 65px);
	box-sizing:border-box;
	font-weight:normal;
	text-decoration:none;
	box-shadow:0 0 15px rgba(0, 0, 0, .15);
	transition:all .3s;
}
article.news-small-blocks a {
	display:block;
	position:absolute;
	left:0;
	top:0;
	width:100%;
	height:100%;
	z-index:2;
}
.news-small-block-image {
	display:block;
	height:300px;
	border-radius:50px 0 0 0;
	background-position:center;
	background-size:cover;
}
article.news-small-blocks h3 {
	display:block;
	margin:0;
	padding:20px;
	background:#1f7287;
	color:#ffffff;
	font-size:20px;
	font-weight:normal;
}
article.news-small-blocks p {
	display:block;
	margin:0;
	padding:0 30px 30px;
	text-align:left;
}
article.news-small-blocks p a {
	font-weight:normal;
}

#page-news-subtitle-list-news {
	margin:0;
	padding:0;
	text-align:center;
	font-size:40px;
}




#index-block-photos { background:none; }
#index-block-photos ul {
	margin:0 auto;
	padding:0;
	max-width:1130px;
	text-align:center;
}
#index-block-photos ul li {
	margin:20px;
	width:200px;
	background:#ffffff;
	border-radius:5px;
}
#index-block-photos p.index-block-punchline {
	left:auto;
	right:0;
}



#page-cover {
	position:absolute;
	right:0;
	top:0;
	width:500px;
	height:300px;
	box-shadow:0 5px 15px rgba(0, 0, 0, .1);
	border-radius:50px 0;
	background-repeat:no-repeat;
	background-position:center;
	background-size:cover;
}
#page-title-wrapper {
	position:relative;
	margin:50px auto;
	padding:50px 0;
	max-width:1200px;
	text-align:left;
}
#page-title-wrapper h1 {
	margin:0;
	padding:0 500px 0 0;
	font-family:'Title';
	font-size:50px;
	text-align:left;
	background: linear-gradient(to bottom, #61cbe5 0%, #46adc7 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
#page-title-wrapper p {
	margin:0;
	font-family:'Title';
	color:#1f7287;
}
#page-cover p {
	display:inline-block;
	margin:0;
	padding:10px;
	background:#000000;
	color:#ffffff;
	font-family:'Title2'; 
	font-size:30px;
}
#page-content-general {
	padding:0;
}
article.page-general p,
article.page-general h2 {
	margin:0 auto;
	padding:0 0 20px;
	max-width:1200px;
	font-size:18px;
}



article.page-general {
	margin:0;
	padding:70px 0 40px;
	background:#ffffff;
	vertical-align:top;
}
article.page-general h2 {
	clear:both;
	text-align:center !important;
	font-size:40px;
}

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






article.page-general ul,
#page-list-subpages ul {
	margin:0 auto;
	max-width:1200px;
	padding:20px 0 0;
	list-style:none;
	text-align:center;
}
article.page-general ul li {
	display:inline-block;
	margin:0 20px 40px;
	width:calc(33% - 44px);
	padding:20px;
	font-size:16px;
	box-sizing:border-box;
	vertical-align:top;
}
article.page-general ul li strong {
	font-family:'Title';
	font-size:20px;
	font-weight:normal;
	color:#456179;
}


#page-list-subpages {
	margin:0 auto;
	padding:40px 0 0;
	max-width:1200px;
	list-style:none;
}
#page-list-subpages ul li {
	display:inline-block;
	margin:20px 30px 80px;
	padding:0;
	width:calc(33% - 64px);
	box-sizing:border-box;
	vertical-align:top;
}
#page-list-subpages ul li a {
	display:block;
	margin:0;
	padding:0;
	box-sizing: border-box;
	font-weight:normal;
	text-align: center;
	text-decoration:none;
	transition:all .5s;
}
#page-list-subpages ul li a:hover {
	transform:scale(1.05);
	box-shadow:0 5px 20px rgba(0, 0, 0, .2);
	transition:all .5s;
}
#page-list-subpages ul li a span { display:block; }
#page-list-subpages ul li a span.image {
	height:300px;
	border-radius:40px 0 0;
	background-position:center;
	background-size:cover;
}
#page-list-subpages ul li a span.title {
	display: block;
	padding: 30px;
	background: #1f7287;
	font-family: 'Title';
	color: #ffffff;
	font-size: 20px;
	font-weight: normal;
	text-align: left;
}


#page-cms-contact {
	margin:20px 0 0;
	padding:20px;
	background:#fff;
	text-align:center;
}
#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-general {
	margin:0 auto;
	padding:100px 10px;
	background:#191919;
	text-align:center;
	color:#f8e6c2;
}
#page-contact-form-general #form-wrapper {
	margin:0 auto;
	max-width:600px;
}
#page-contact-form-general input[type="text"], #page-contact-form-general select, #page-contact-form-general textarea {
	width:100%;
	height:40px;
	margin:10px 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 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 */