/*

    STYLE
    -----------------------------------------
    01 ››› GLOBAL
    02 ››› A PROPOS
    03 ››› REALISATIONS
    04 ››› CONTACT
    05 ››› ZOOM
    06 ››› xxxxxx
    07 ››› xxxxxx
    08 ››› xxxxxx
    09 ››› xxxxxx
    10 ››› xxxxxx
    11 ››› xxxxxx
    12 ››› xxxxxx
    13 ››› xxxxxx
    14 ››› xxxxxx
    15 ››› xxxxxx

*/

@import url('https://fonts.googleapis.com/css?family=Montserrat+Alternates:300,400,500,600,700,800');
@import url('https://fonts.googleapis.com/css?family=Kaushan+Script');

@import url('bootstrap-xlgrid.css');
@import url('ionicons.css');
@import url('interface.css');
@import url('../form/form.css');





/* /////////////////////////////////////////////////////////////////////////////////////

    01 + GLOBAL

///////////////////////////////////////////////////////////////////////////////////// */

*, *::after, *::before { -webkit-box-sizing:border-box; -moz-box-sizing:border-box; box-sizing:border-box; }
::-moz-selection { background-color:#f7f7f7; color:#222; }
::selection { background-color:#f7f7f7; color:#222; }

html { margin:0; padding:0; height:100%; overflow-y: scroll; }
	
body {
  	background:#fff;
    margin:0;
    padding:0;
	height:100%;
  	font-family: 'Montserrat Alternates', Arial, sans-serif;
	font-weight:400;
  	font-size:16px;
	line-height:26px;
  	color:#3c3c3c;
    /**/
    background:#f6f7f7;
	background: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#f6f7f7)) fixed;
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#fff, endColorstr=#f6f7f7);
}

/* LIENS */
a { color:#3c3c3c; text-decoration:none; line-height: 1.2;
	/**/
	-webkit-transition:all .2s; -moz-transition:all .2s; -o-transition:all .2s; transition:all .2s;
}
.no-touch a:hover { color:#3c3c3c; outline:0; text-decoration:none; }
a:active, a:focus { color:#3c3c3c; outline:0; text-decoration:none; }

a.link { display:inline-block; position:relative; }
a.link:after {
	background-color: #3c3c3c;
	content: "";
	height: 1px;
	right: 0;
	left:0;
	margin:0 auto;
	position: absolute;
	bottom: 0;
	width: 0;
	-webkit-transition: all 0.2s ease-in-out;
	-moz-transition: all 0.2s ease-in-out;
	-o-transition: all 0.2s ease-in-out;
	-ms-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
}
.no-touch a.link:hover:after { width:100%; }

a[href^=tel]{
    color:inherit!important;
    text-decoration:inherit!important;
    font-size:inherit!important;
    font-style:inherit!important;
    font-weight:inherit!important;
}

/* TEXTE */
br { font-size:0; line-height:0; }
strong, b { font-weight:600; }

/* IMAGE */
img { height:auto; max-width:100%; }

/* LISTES */
ol, ul { margin:0; padding:0; list-style:none; font-size:0; }

/* PARAGRAPHES */
p { margin:0 0 10px 0; padding:0; }
p:last-child { margin:0; }

/* TITRES */
h1, h2, h3, h4, h5, h6 { 
	font-weight:700; 
	line-height:1;
	margin:0;
	padding:0;
}

.no-padding { padding:0; }





/* /////////////////////////////////////////////////////////////////////////////////////

    02 + A PROPOS

///////////////////////////////////////////////////////////////////////////////////// */

/* ------------------------------------------- 
	BASE
------------------------------------------- */
.about-inner [class*="row"] { margin:150px 0; position: relative; }
.about-inner [class*="row"]:first-child { margin:25px 0 0 0; }
.about-inner [class*="row"]:last-child { margin:150px 0 0 0; }

/* DESCRIPTION */
.about-inner .bloc.desc {
	padding: 40px 20px;
}
.about-inner .bloc.desc .title {
    display:block;
	font-size:48px;
	line-height:48px;
	font-weight:800;
	margin-bottom:30px;
}
.about-inner .bloc.desc a.press {
    font-size: 14px;
	line-height:16px;
	color:#000;
	font-weight:500;
    display:inline-block;
	text-transform:none;
    margin-top:20px;
}
.about-inner .bloc.desc a {
    font-size: 16px;
	line-height:19px;
	color:#000;
	font-weight:600;
    display:inline-block;
	text-transform:uppercase;
    margin-top:20px;
}

/* VISUEL */
.about-inner .bloc.visu {
	padding: 0 40px;
    text-align: center;
}
.shadow {
	position: relative;
	/*padding: 20px;*/
	background-color: #f9f9f9;
    -webkit-box-shadow: 20px 20px 40px 0px rgba(0,0,0,0.3);
    -moz-box-shadow: 20px 20px 40px 0px rgba(0,0,0,0.3);
    box-shadow: 20px 20px 40px 0px rgba(0,0,0,0.3);
}
.shadow.cadre { padding:15px; border: solid 10px #eccea8; border-right-color: #d7bc99; border-left-color: #d7bc99; }

/* DECO */
.about-inner [class*="row"]:before {
	display:block;
	width:100%;
	position: absolute;
	content: "";
	color:#f9f9f9;
	font-weight:700;
	font-size:96px;
	line-height:76px;
	text-transform:uppercase;
	top: -30px;
	white-space: pre;
  	word-wrap: break-word;
}

.about-inner [class*="row"]:nth-child(1):before { 
    content: "reconversion"; 
    text-align:right; 
    padding-right:0%;
}
.about-inner [class*="row"]:nth-child(2):before { 
    content: "formation"; 
    text-align:left; 
    padding-left:0%;
}
.about-inner [class*="row"]:nth-child(3):before { 
    content: "pratique"; 
    text-align:right; 
    padding-right:0%;
}
.about-inner [class*="row"]:nth-child(4):before { 
    content: "philosophie"; 
    text-align:left; 
    padding-left:0%;
}


@media only screen and (max-width: 1200px) {
    .about-inner [class*="row"]:before {
        font-size:76px;
	    line-height:66px;
    }
}
@media only screen and (max-width: 992px) {
    
    .about-inner { padding-right:0; }
    
    .about-inner [class*="row"]:before { display:none; }
    .about-inner [class*="row"] { margin:50px 0; position: relative; }
    .about-inner [class*="row"]:first-child { margin:0 0 0 0; }
    .about-inner [class*="row"]:last-child { margin:0 0 0 0; }
    
    .about-inner .bloc.desc { padding: 0 0; margin:30px 0 0 0; }
    .about-inner .bloc.visu { padding: 0 0; }
}


/* ------------------------------------------- 
	SERVICES
------------------------------------------- */

.section.services {
    padding:60px 0 100px 0;
}
.services-title {
    display:block;
	font-size:48px;
	line-height:48px;
	font-weight:600;
	margin-bottom:50px;
    color:#a0a0a8;
}

/* TAGS */
.bloc-tags {
	position: relative;
	margin:0 0 0 0;
	display:block;
}
.tags {
	list-style: none;
	margin: 0;
	overflow: hidden; 
	padding: 0;
	display:block;
}
.tags li {
	float: left; 
	font-size:16px;
	font-weight:500;
}
.tag {
	position: relative;
	color: #3c3c3c;
	border:#3c3c3c solid 2px;
	background:#fff;
	display: inline-block;
	height: 32px;
	line-height: 30px;
	padding: 0 12px 0 28px;
	margin: 0 15px 15px 0;
	/**/
	-moz-border-radius: 2em;
    -webkit-border-radius: 2em;
    border-radius: 2em;
}
.tag::before {
	content: '\f121';
	left: 10px;
	position: absolute;
	font-family:'Ionicons';
	top: -1px;
	color:#3c3c3c;
}

/* INFOS */
.bloc-infos {
	position: relative;
	margin:0 0 0 0;
	display:block;
}
.infos {
	list-style: none;
	margin: 0;
	overflow: hidden; 
	padding: 0;
	display:block;
}
.infos li { margin-bottom:20px; }
.infos li:last-child { margin-bottom:0; }
.infos li p {
	display:block;
	font-size:16px;
	line-height: 26px;
}
.infos li span {
	color: #3c3c3c;
	display:inline-block;
	font-size:21px;
	line-height:21px;
    text-transform: uppercase;
    font-weight: 800;
	margin: 0 0 5px 0;
	padding: 0 15px 5px 0;
    border-bottom:#a0a0a8 solid 1px;
}

@media only screen and (max-width:992px) {
	.bloc-infos { margin:30px 0 0 0; }
}

/* COULEURS */
.infos li:nth-child(1) span { color: #fba93b; border-bottom:#fba93b solid 1px; }
.infos li:nth-child(2) span { color: #32af77; border-bottom:#32af77 solid 1px; }
.infos li:nth-child(3) span { color: #4b50b7; border-bottom:#4b50b7 solid 1px; }
.infos li:nth-child(4) span { color: #ea6f41; border-bottom:#ea6f41 solid 1px; }
.infos li:nth-child(5) span { color: #1e92d1; border-bottom:#1e92d1 solid 1px; }





/* /////////////////////////////////////////////////////////////////////////////////////

    03 + REALISATIONS

///////////////////////////////////////////////////////////////////////////////////// */

.section.text-intro {
    padding:60px 0 0 0;
}
@media only screen and (max-width:768px) {
	.section.text-intro {
        padding:20px 0 0 0;
        font-size:15px;
        line-height:21px;
    }
    .section.grid-home {
        padding:30px 0 60px 0;
    }
}



/* ------------------------------------------- 
	GRID
------------------------------------------- */
.grid {
    position: relative;
	list-style:none;
    font-size:0;
	overflow: hidden;
}
.grid .grid-sizer { width: 31%; }
.grid .gutter-sizer { width: 3.5%; }
  
@media only screen and (max-width:1350px) {
	.grid .blocThumb { width:48.25%; }
	.grid .grid-sizer { width:48.25%; }
}
@media only screen and (max-width:1200px) {
	.grid .blocThumb { width:48.25%; }
	.grid .grid-sizer { width:48.25%; }
}
@media only screen and (max-width:768px) {
	.grid .blocThumb { width:100%; margin-bottom:20px; }
	.grid .grid-sizer { width:100%; }
	.grid .gutter-sizer { width:0; }
}


/* ------------------------------------------- 
	FILTRES
------------------------------------------- */
.filters {
    position:relative;
    margin-bottom: 60px;
    text-align: center;
}
.filters li {
    display:inline-block;
    width:auto;
    margin:5px 20px;
}
.filters li a {
    display:block;
    width:100%;
    font-size:24px;
    line-height:24px;
    font-weight:500;
    color:#cfcfd3;
    padding:5px 5px;
    text-align: center;
	/**/
    display: inline-block;
    vertical-align:middle;
    -webkit-transform: perspective(1px) translateZ(0);
    transform: perspective(1px) translateZ(0);
    box-shadow: 0 0 1px rgba(0, 0, 0, 0);
    position: relative;
    overflow: hidden;
}
.filters li a:after {
    content: "";
    position: absolute;
    z-index: -1;
    left: 51%;
    right: 51%;
    bottom: 0;
    background: #3c3c3c;
    height: 1px;
    -webkit-transition-property: left, right;
    transition-property: left, right;
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease-out;
    transition-timing-function: ease-out;
}
.filters li a:hover { color:#3c3c3c; }
.no-touch .filters li a:hover:after { left: 0; right: 0; }

.filters li a.active { color:#3c3c3c; }
.filters li a.active:after { left: 0; right: 0; background: #3c3c3c; }

@media only screen and (max-width:768px) {
	.filters { margin-bottom: 30px; }
	.filters li { display:inline-block; width:50%; margin:0; border:#eee solid 1px; vertical-align: top; padding:3px 0; }
	.filters li:last-child { margin:0; }
	.filters li a { 
        font-size:18px;
        line-height:18px;
        top:50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
    }
    .filters li a:after { display:none; }
}


/* COULEURS */
.filters li.filter01 a:after { background: #fba93b; }
.filters li.filter01 a:hover { color:#fba93b; }
.filters li.filter01 a.active { color:#fba93b; }
.filters li.filter01 a.active:after { left: 0; right: 0; background: #fba93b; }

.filters li.filter02 a:after { background: #32af77; }
.filters li.filter02 a:hover { color:#32af77; }
.filters li.filter02 a.active { color:#32af77; }
.filters li.filter02 a.active:after { left: 0; right: 0; background: #32af77; }

.filters li.filter03 a:after { background: #4b50b7; }
.filters li.filter03 a:hover { color:#4b50b7; }
.filters li.filter03 a.active { color:#4b50b7; }
.filters li.filter03 a.active:after { left: 0; right: 0; background: #4b50b7; }

.filters li.filter04 a:after { background: #ea6f41; }
.filters li.filter04 a:hover { color:#ea6f41; }
.filters li.filter04 a.active { color:#ea6f41; }
.filters li.filter04 a.active:after { left: 0; right: 0; background: #ea6f41; }

.filters li.filter05 a:after { background: #879f2c; }
.filters li.filter05 a:hover { color:#879f2c; }
.filters li.filter05 a.active { color:#879f2c; }
.filters li.filter05 a.active:after { left: 0; right: 0; background: #879f2c; }

.filters li.filter06 a:after { background: #1e92d1; }
.filters li.filter06 a:hover { color:#1e92d1; }
.filters li.filter06 a.active { color:#1e92d1; }
.filters li.filter06 a.active:after { left: 0; right: 0; background: #1e92d1; }

.filters li.filter07 a:after { background: #d94a6c; }
.filters li.filter07 a:hover { color:#d94a6c; }
.filters li.filter07 a.active { color:#d94a6c; }
.filters li.filter07 a.active:after { left: 0; right: 0; background: #d94a6c; }



/* ------------------------------------------- 
	THUMB
------------------------------------------- */
.blocThumb {
    position: relative;
	width:31%; 
    float:left;
	display:inline-block;
	margin-bottom:3.5%;
	cursor: pointer;
    font-size:18px;
    color:#3c3c3c;
    height:auto;
    background: #fff;
}

/* IMAGE */
.blocThumb .blocImage {
	vertical-align:top!important;
	display:inline-block;
	position:relative;
	overflow:hidden;
	-webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

.blocImage img {
	position:relative;
	display: block!important;
	-webkit-transition: -webkit-transform .2s ease;
	-moz-transition: -moz-transform .2s ease;
	transition: transform .2s ease; 
}
.no-touch .blocThumb:hover .blocImage img {
	-webkit-transform: scale(1.048);
	-moz-transform: scale(1.048);
	-o-transform: scale(1.048);
	transform: scale(1.048);
}

/* CATEGORIE */
.blocThumb .categorie {
    position: absolute;
    display:block;
	z-index:2;
    top: 7px;
	left:0;
	-webkit-transition:left .2s;
	-moz-transition:left .2s;
	-o-transition:left .2s;
	transition:left .2s;
}
.blocThumb .categorie span {
    font-size:12px;
    line-height: 12px;
    font-weight:500;
    color:#fff;
    background:#3c3c3c;
    padding:2px 6px;
}
.no-touch .blocThumb:hover .categorie {
	left:10px;
}

/* COULEURS */
.blocThumb.filter01 .categorie span { background: #fba93b; }
.blocThumb.filter02 .categorie span { background: #32af77; }
.blocThumb.filter03 .categorie span { background: #4b50b7; }
.blocThumb.filter04 .categorie span { background: #ea6f41; }
.blocThumb.filter05 .categorie span { background: #879f2c; }
.blocThumb.filter06 .categorie span { background: #1e92d1; }
.blocThumb.filter07 .categorie span { background: #d94a6c; }

/* PLUS */
.blocThumb .caption .plus {
    position: absolute;
    display:block;
	z-index:2;
    top:-50px;
	left:50%;
	-webkit-transform: translateX(-50%);
  	-ms-transform: translateX(-50%);
  	transform: translateX(-50%);
    font-size:30px;
    color:rgba(255,255,255,.95);
}
@media only screen and (max-width: 768px) {
    .blocThumb .caption .plus { display: block; }
}

/* CAPTION */
.blocThumb .caption {
    position: absolute;
    display:block;
	z-index:1;
	width:calc(100% - 20px);
	height:calc(100% - 20px);
    top:10px;
	left:10px;
    background:rgba(255,255,255,.8);
	opacity:0;
	-webkit-transition:all .2s;
	-moz-transition:all .2s;
	-o-transition:all .2s;
	transition:all .2s;
}
.no-touch .blocThumb:hover .caption {
	opacity:1;
}
.blocThumb .caption .inner {
    position: relative;
	text-align:center;
	padding:0 20px;
    top:50%;
	-webkit-transform: translateY(-50%);
  	-ms-transform: translateY(-50%);
  	transform: translateY(-50%);
}
.blocThumb .caption .titre {
    display:block;
    color:#3c3c3c;
	font-size:21px;
	line-height:24px;
	font-weight:600;
}

@media only screen and (max-width: 992px) {
	.blocThumb .caption { 
		position: relative;
		opacity:1;
		background:none;
	}
	.blocThumb .caption .inner {
		position: relative;
		text-align:center;
		padding:0 20px 20px 20px;
		top:0;
		-webkit-transform: none;
		-ms-transform: none;
		transform: none;
	}
}

/* ------------------------------------------- 
	PAGINATION
------------------------------------------- */
.pagination {
	position:relative;
	width: 100%;
	text-align: center;
	padding:0;
	margin:50px 0 0 0;
}
.grid-pagination {
	text-align: center;
	display: inline-block;
	margin:0;
	padding:0;
}
.grid-pagination ul { margin:0; padding:0; font-size:0; }

.grid-pagination li {
	margin: 0 2px;
	padding:0;
	float: left;
	border-radius: 0.25em;
}

.grid-pagination a, .grid-pagination span {
	display: inline-block;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	font-size: 14px;
	color:#a0a0a8;
	font-weight:500;
}
.grid-pagination a {
    display: block;
	float: left;
	padding: 12px 18px;
	border-radius: 0.25em;
	background:#f6f8f9;
}
.no-touch .grid-pagination a:hover {
	background-color: #a0a0a8;
	color: #fff;
}
.grid-pagination span {
    background:transparent;
    position: relative;
    top:8px;
	padding: 0 5px;
}
.grid-pagination li:first-of-type a {
	background:transparent;
	font-size: 21px;
    position: relative;
    top:-3px;
}
.grid-pagination .button:first-of-type a::before {
	font-family: "Ionicons";
	content: '\f2ca';
}
.grid-pagination li:last-of-type a {
	background:transparent;
	font-size: 21px;
    position: relative;
    top:-3px;
}
.grid-pagination .button:last-of-type a::after {
	font-family: "Ionicons";
	content: '\f30f';
}
.no-touch .grid-pagination li:last-of-type a:hover,
.no-touch .grid-pagination li:first-of-type a:hover {
	color: #a0a0a8;
	background:transparent;
}
.grid-pagination .current {
	background-color: #a0a0a8;
	color: #fff;
	pointer-events: none;
}

@media only screen and (max-width: 768px) {
    .pagination { margin:20px 0 0 0; }
	.grid-pagination li { display: none; }
	.grid-pagination li:last-of-type,
	.grid-pagination li:first-of-type { display: block; }
}





/* /////////////////////////////////////////////////////////////////////////////////////

    04 + CONTACT

///////////////////////////////////////////////////////////////////////////////////// */

.adresse {
    font-size:18px;
    line-height:26px!important;
}
.adresse p.mention {
    font-size:13px;
    line-height:16px!important;
}
.adresse span {
    display:block;
    font-size:30px;
    line-height: 30px;
    font-weight: 600;
    margin:0 0 10px 0;
}

.tel {
    font-size:21px;
    line-height:21px;
    margin:20px 0 0 0;
    font-weight: 500;
}

.social { margin:30px 0; }
.social i { font-size:24px; }


/* -------------------------------------------
	MAP	
------------------------------------------- */
.contact-details {
	opacity: 1;
	transition: opacity 0.4s ease;
	-webkit-transition: opacity 0.4s ease;
	-moz-transition: opacity 0.4s ease;
}
.contact-details.hide-details {
	opacity: 0;
	visibility: hidden;
	transition: all 0.4s ease;
	-webkit-transition: all 0.4s ease;
	-moz-transition: all 0.4s ease;
}

.align-bottom {
	position: absolute;
	bottom: 30px;
	margin: 0 auto;
	left: 0;
	right: 0;
	z-index: 2;
}

.map-holder div[class*='col-'] {
	z-index: 2;
}
.map-holder {
	overflow: hidden;
	position: relative;
	padding:150px 0;
}
.map-holder iframe {
	border: none;
	position: absolute;
	width: 100%;
	height: 180%;
	top: -40%;
	left: 0;
	z-index: 1;
}
.map-holder:before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 2;
}
.map-holder.interact:before {
	width: 0;
}
.map-holder.inline {
	height: 400px;
	overflow: hidden;
}
.map-canvas {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
}

.blocContact {
	display:block;
  	background: #d94a6c;
	color:#fff;
  	padding:30px 40px 1px 40px;
}

.blocContact a { color:#fff; }
.no-touch .blocContact a:hover { color:#fff; }

.blocContact a:after { background:#fff; }
.no-touch .blocContact a:hover:after { background:#fff; }

/* HACK GOOGLE MAP */
a[href^="http://maps.google.com/maps"]{display:none !important}
a[href^="https://maps.google.com/maps"]{display:none !important}
.gmnoprint a, .gmnoprint span, .gm-style-cc { display:none; }
.gmnoprint div { background:none !important; }

/* BT MAP */
.toggle-map {
	color: #3c3c3c !important;
	background: transparent;
}
.toggle-map.active {
	color: #fff !important;
	background: #3c3c3c;
}
.btn-map {
	border-radius: 2em;
	border: 2px solid #3c3c3c;
	padding: 12px 20px;
	min-width: 150px;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 3px;
	color: #3c3c3c;
	background: rgba(255,255,255,.75);
	text-align: center;
	transition: all 0.3s ease;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	margin-right: 8px;
}
.btn-map:last-child,
.btn-map:last-of-type {
	margin-right: 0;
}
.btn-map:hover {
	background: #3c3c3c;
	color: #fff !important;
}

@media only screen and (max-width: 768px) {
    .contact-form { margin-top:30px; }
}





/* /////////////////////////////////////////////////////////////////////////////////////

    05 + ZOOM

///////////////////////////////////////////////////////////////////////////////////// */

.zoom-header {
    
}

/* CATEGORIE */
.zoom-header .categorie {
    position: relative;
    display:block;
    margin:25px 0 15px 0;
}
.zoom-header .categorie span {
    font-size:14px;
    line-height: 14px;
    font-weight:500;
    color:#fff;
    background:#3c3c3c;
    padding:3px 6px;
}

/* COULEURS */
.zoom-header.filter01 .categorie span { background: #fba93b; }
.zoom-header.filter02 .categorie span { background: #32af77; }
.zoom-header.filter03 .categorie span { background: #4b50b7; }
.zoom-header.filter04 .categorie span { background: #ea6f41; }
.zoom-header.filter05 .categorie span { background: #879f2c; }
.zoom-header.filter06 .categorie span { background: #1e92d1; }
.zoom-header.filter07 .categorie span { background: #d94a6c; }

/* TITRE */
.zoom-header .titre {
    display:block;
    color:#3c3c3c;
	font-size:36px;
	line-height:36px;
	font-weight:600;
    margin:0 0 30px 0;
}


.galerie img {
    margin-top:60px;
}

.back {
    margin-top:60px;
}





/* /////////////////////////////////////////////////////////////////////////////////////

    06 + CGV

///////////////////////////////////////////////////////////////////////////////////// */

.section.cgv h3 { 
    font-size:21px;
    line-height:24px;
    font-weight:700;
    display:block;
    margin-bottom:10px;
}

.section.cgv p + h3 { margin-top:40px; }










