@charset "utf-8";
/* CSS Document */

* {
	margin:0;
	padding:0;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

article, aside, figure, footer, header, hgroup, menu, nav, section {
    display: block;
}

img {
	border:0;
}

html {
	height:100%;
}
	
body {
	height:100%;
	font-family: 'Open Sans', sans-serif;
    font-weight:200;
}

.open {
	font-family: 'Open Sans', sans-serif;
}

.lobster {
    font-family: 'Lobster', cursive;
}

h1 {
    font-size:60px;
    font-family: 'Lobster', cursive;
    margin-bottom:35px;
    font-weight: 500;
}

h2 {
    font-size:50px;
    font-family: 'Lobster', cursive;
    margin-bottom:35px;
    font-weight: 500;
}

h3 {
    font-size:40px;
    font-family: 'Lobster', cursive;
    margin-bottom:35px;
    font-weight: 500;
}

p {
    margin-bottom:35px;
}

/*==============bouton menu ================*/

.bt-menu-trigger {
  font-size: 30px;
  position: relative;
	display: inline-block;
	width: 2em;
	height: 2em;
	cursor: pointer;
}

.bt-menu-trigger span {
	position: absolute;
	top: 50%;
	left: 0;
	display: block;
	width: 80%;
	height: 0.2em;
	margin-top: -0.1em;
	background-color: #000;
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-khtml-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	-webkit-transition: background-color 0.3s;
	transition: background-color 0.3s;
}


.bt-menu-trigger span:after,
.bt-menu-trigger span:before {
	position: absolute;
	left: 0;
	width: 100%;
	height: 100%;
	background: #000;
	content: '';
	-webkit-transition: -webkit-transform 0.3s;
	transition: transform 0.3s;
}

.bt-menu-trigger span:before {
	-webkit-transform: translateY(-0.5em);
	transform: translateY(-0.5em);
}

.bt-menu-trigger span:after {
	-webkit-transform: translateY(0.5em);
	transform: translateY(0.5em);
}

.bt-menu-trigger.bt-menu-open span:after {
	-webkit-transform: translateY(-0.10em) translateX(-0.65em) rotate(-45deg) scaleX(0.7);
	transform: translateY(-0.35em) translateX(-0.55em) rotate(-45deg) scaleX(0.7);
}

.bt-menu-trigger.bt-menu-open span:before {
	-webkit-transform: translateY(0.36em) translateX(-0.60em) rotate(45deg) scaleX(0.7);
	transform: translateY(0.35em) translateX(-0.55em) rotate(45deg) scaleX(0.7);
}

/*====================================*/

.BannerTxt {
	/*width:100%;	
	position:absolute;
	top:33%;*/
    position:relative;
	z-index:555;
	color:#fff;
	text-align:center;
    display:table-cell;
    vertical-align: middle;
}

.BannerTxt h2 {
	font-size:65px;
	font-weight:normal;
	text-shadow:1px 1px #000;
	font-family: 'Lobster', cursive;
	margin-bottom:10px;
    padding:0px 20px;
}

.BannerTxt h3 {
	font-size:16px;
	font-weight:normal;
	text-shadow:1px 1px #000;
	color:#fff;
	margin-bottom:20px;
	letter-spacing:3px;
    font-family: 'Open Sans', sans-serif;
    padding:0px 20px;
}

.BannerTxt h2 span {
	font-size:80px;
	color:#fc3804;
}

.BannerTxt hr {
	border:0px;
	border-bottom:2px solid #fff;
	display:block;
	width:30%;
	margin:0 auto;
}

.top-overlay {
	position:absolute;
	background-color:#000;
	height:100%;
	width:100%;
	top:0px;
	left:0px;
	z-index:444;
	opacity:0.4;
}

#wraper {
	position:relative;
	height:100%;
	/*margin-left:305px;*/
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
}

#wraper.mOpen {
    margin-left:300px;
}

#concepteur-web {
	position:relative;
	width:100%;
	height:100%;
	overflow:hidden;
	border:10px solid #fff;
    min-height:400px;
}

#menuWrap {
	left:-300px;
	top:0px;
	position:fixed;
	width:300px;
	height:100%;
	background-color:#000;
	z-index:999;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
    padding-bottom:76px;
    /*background-repeat:no-repeat;
    background-position:center;
    background-repeat:no-repeat;
    background-size: cover;
    background-image:url(../images/menuWrapBg.jpg);*/
}

#menuWrap.mOpen {
    left:0px;
}

#menuItemWrap {
    overflow-y: auto;
    max-height: 100%;
    overflow-x: hidden;
}


/*#logo {
	float:left;
	margin:25px 0px 19px 15px;
}

#logo img {
	width:262px;
}*/

#logo {
    text-align: center;
    display: block;
}

#logo img {
    width: 80%;
    padding-top: 10px;
}

#menu {
	text-align:right;
	font-size:14px;
	padding-top:0px;
	line-height:35px;
	font-weight:500;
	letter-spacing:3px;
    clear:both;
    margin-bottom:0px;
}

#menu ul {
	list-style:none;
	margin:0;
	padding:50px 0px 0px 0px;
}

#menu li {
	margin:0;
	padding:0;
	margin-bottom:10px;
}

#menu a {
	color:#979696;
	text-decoration:none;
	text-transform:uppercase;
	padding-right:30px;
	display:block;
}

#menu a:hover {
	color:#fff;
}

#menu .current a {
	color:#fff;
	font-size:12px;
	border-right:10px solid #fc3804;
	padding-right:20px;
}

.togBtn {
    background-color: #fff;
    padding: 16px 15px 16px 31px;
    float: right;
    margin-right: -106px;
    text-align: center;
}

.mainBan {
    display:table;
	width:100%;
	height:100%;
	position:absolute;
	bottom:0px;
	left:0px;
	z-index:333;
}

.ban {
    position:absolute;
    width:100%;
	height:100%;
    bottom:0px;
	left:0px;
    background-image:url(../images/bg4.jpg);
	background-repeat:no-repeat;
	background-position:center center;
	background-size:cover;
	-moz-transition: all 4s;
	-webkit-transition: all 4s;
	transition: all 4s;
    z-index:111;
}

.mainBan:hover .ban {
	-webkit-transform: scale(1.25, 1.25);
    transform: scale(1.25, 1.25);
}

#services {
    border-left:5px solid #fff;
    border-right:5px solid #fff;
    border-bottom:5px solid #fff;
    font-size:20px;
    color:#fff;
}

#services h2 {
    font-size:50px;
    font-family: 'Lobster', cursive;
    margin-bottom:35px;
    font-weight: 500;
}

#services p {
    margin-bottom:35px;
}

.servicesCol {
    float:left;
    border-left:5px solid #fff;
    border-right:5px solid #fff;
    display:table;
    height:100%;
}

.servLeft {
    background-color:#ff4a20;
    width:40%
}

.servLeft aside {
    padding:50px;
    text-align:center;
}

.servicesCol article, .servicesCol aside {
    display:table-cell;
    vertical-align: middle;
}

.servLeft aside img {
    max-width:100%;
    margin-bottom:15px;
}

.servLeftCol {
    width:33%;
    float:left;
    font-family: 'Lobster', cursive;
}

.servLeftCol i {
    font-size:40px;
}

.servRight {
    background-color:#000;
    width:60%;
    text-align:center;
}

.servRight article {
    padding:50px;
}

#specialites {
    margin:0;
    padding:0;
    list-style:none;
}

#specialites li {
    margin:0;
    padding:0;
    margin-bottom:10px;
    padding-left:40px;
    width:50%;
    float:left;
}

#specialites li:before {
  content: "\f05d"; /* FontAwesome Unicode */
  color:#fff;
  font-family: FontAwesome;
  display: inline-block;
  margin-left: -1.3em; /* same as padding-left set on li */
  width: 1.3em; /* same as padding-left set on li */
}


#sectionSpec {
    clear:both;
    background-color:#26bbc8;
    border-top:5px solid #fff;
    border-left:10px solid #fff;
    border-right:10px solid #fff;
    border-bottom:10px solid #fff;
    color:#fff;
    font-size:20px;
}

#sectionSpec article {
    padding:40px;
}

#a-propos {
    padding:0px 10px 10px 10px;
    color:#2f2e2e;
    background-image:url(../images/me2.jpg);
    background-repeat: no-repeat;
    background-position:10% 100%;
    background-size:contain;
    border-left:10px solid #fff;
    border-right:10px solid #fff;
    border-bottom:10px solid #fff;
    font-weight:500;
}

#a-propos h2 {
    color:#fc3804;
    margin-bottom:20px;
}

#a-propos h3 {
    font-size:36px;
    font-family: 'Open Sans', sans-serif;
    color:#000;
    margin-bottom:20px;
}

#a-propos .aproposTxt {
    float:right;
    width:60%;
}

.aproposTxt article {
    padding:50px;
}

.aproposPic {
    width:40%;
    float:left;
    text-align:center;
}

.aproposPic img {
    max-width:100%;
}

.realisationRow {
    border-right:5px solid #fff;
    border-left:5px solid #fff;
    border-bottom:10px solid #fff;
}

.rBox {
    border-left:5px solid #fff;
    border-right:5px solid #fff;
    float:left;
    background-repeat:no-repeat;
    background-size:auto 100%;
    background-position:center center;
    -moz-transition: all 4s;
	-webkit-transition: all 4s;
	transition: all 4s;
    overflow: hidden;
    position:relative;
}

.item1 {
    width:60%;
    height:600px;
}

.item2 {
    width:40%;
    border-bottom:10px solid #fff;
    height:300px;
}

.item3 {
    width:40%;
    height:300px;
}

.item4 {
    width:45%;
    height:400px;
}

.item5 {
    width:55%;
    height:400px;
}

/*.rBox:hover {
    background-size:auto 120%;
}

.rBox:focus {
    background-size:auto 120%;
}*/

.descBox {   
    height:200px;
    position:absolute;
    bottom:-120px;
    width:100%;
    color:#6f6e6e;
    z-index:222;
    -moz-transition: bottom 0.4s;
	-webkit-transition: bottom 0.4s;
	transition: bottom 0.4s;
}

.rBox:hover .descBox {
    bottom:0px;
}

.rBox:focus .descBox {
    bottom:0px;
}

.rBox:hover .itemBg {
    height:120%;
    width:120%;
    margin-left:-10%;
}

.rBox:focus .itemBg {
    height:120%;
    width:120%;
}

.itemBg {
    position:absolute;
    bottom:0px;
    left:0px;
    width:100%;
    height:100%;
    background-position: bottom;
    background-repeat:no-repeat;
    background-size: cover;
    z-index:111;
    -moz-transition: all 4s;
	-webkit-transition: all 4s;
	transition: all 4s;
}

.itemBg1 {
    background-image:url(../images/constructionQuirion.jpg);
}

.itemBg2 {
    background-image:url(../images/led-electrique.jpg);
}

.itemBg3 {
    background-image:url(../images/hydro-experts.jpg);
}

.itemBg4 {
    background-image:url(../images/roz.jpg);
}

.itemBg5 {
    background-image:url(../images/duchesses.jpg);
}

.descBox p {
    margin-bottom:20px;
}

.descBox h3 {
    margin-bottom:0px;
    font-family: 'Open Sans', sans-serif;
    font-size:24px;
    font-weight:200;
    color:#000;
}

.descBox h3 a {
    color:#000;
    text-decoration:none;
}

.descBox article {
    padding:10px 20px 100px 20px;
    margin:0px 20px;
    background-color:#fff;
    font-size:14px;
}

.descBox a {
    color:#000;
    text-decoration:none;
}

.projectLink {
    float:right;
    display:block;
    width:44px;
    height:44px;
    background-image:url(../images/link-arrow.jpg);
    background-repeat:no-repeat;
    margin-top:8px;
}

#partenaires {
    background-color:#fc3804;
    color:#fff;
    text-align:center;
    border-left:10px solid #fff;
    border-right:10px solid #fff;
    border-bottom:10px solid #fff;
    font-size:18px;
}

#partenaires h2 {
    margin-bottom:0px;
}

#partenaires h3 {
    color:#000;
    font-weight:200;
    font-size:36px;
    font-family: 'Open Sans', sans-serif;
    font-size:22px;
    text-transform:uppercase;
}

#partenaires article {
    padding:40px;
}

#contact {
    border-left:10px solid #fff;
    border-right:10px solid #fff;
    border-bottom:10px solid #fff;
}

.contactLeft {
    float:left;
    width:45%;
    border-right:10px solid #fff;
    padding:40px;
    background-color:#000;
    color:#fff;
    font-size:18px;
    display:table;
}

.contactLeft footer {
    padding:40px;
    text-align:center;
    display:table-cell;
    vertical-align:middle;
}

.contactLeft h3 {
    margin:0;
    font-family: 'Open Sans', sans-serif;
    text-transform:uppercase;
    font-size:18px;
}

.contactLeft h2 {
    font-size:40px;
}

.contactLeft ul {
    list-style:none;
    margin:0;
    padding:0;
}

.contactLeft li {
    margin:0;
    padding:0;
    margin-bottom:10px;
    line-height:26px;
}

.contactLeft a {
    color:#fff;
    text-decoration:none;
}

.contactLeft i {
    margin-right:10px;
    font-size:26px;
}

.contactRight {
    float:left;
    width:55%;   
    background-color:#fff;
    padding:40px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    border:2px solid #000;
}

.contactRightBorder {
    
}

.contactRight h3 {
    margin:0;
    font-family: 'Open Sans', sans-serif;
    text-transform:uppercase;
    font-size:18px;
}

.contactRight h2 {
    font-size:40px;
}

.contactRight footer {
    padding:40px;
    text-align:center;
    color:#000;
}

#contactForm span {
    display:block;
    width:100%;
}

#contactForm input[type="text"] {
    display:block;
    width:100%;
    padding:0px 10px;
    height:40px;
    border:0px;
    border-bottom:2px solid #000;
    margin-bottom:30px;
}

#contactForm textarea {
    display:block;
    width:100%;
    padding:0px 10px;
    height:40px;
    border:0px;
    border-bottom:2px solid #000;
    margin-bottom:30px;
    height:100px;
    font-family: 'Open Sans', sans-serif;
}

#contactForm input[type="submit"] {
    line-height:30px;
    background-color:#000;
    border:2px solid #000;
    color:#fff;
    padding:20px 30px;
    cursor:pointer;
    -webkit-appearance: none;
   -moz-appearance: none;
   appearance: none;
}

#contactForm input[type="submit"]:hover {
    background-color:#fff;
    color:#000;
}

#contactForm button {
    line-height:30px;
    background-color:#000;
    border:2px solid #000;
    color:#fff;
    padding:20px 30px;
    cursor:pointer;
    -webkit-appearance: none;
   -moz-appearance: none;
   appearance: none;
}

#contactForm button:hover {
    background-color:#fff;
    color:#000;
}

.contactCol {
    height:100%;
}

#cntLink {
    position:absolute;
    bottom:0px;
    left:0px;
    list-style:none;
    margin:0;
    padding:0;
}

#cntLink li {
    display:block;
    width:100px;
    float:left;
    text-align: center;
}

#cntLink a {
    display:block;
    font-size:40px;
    padding:10px 0px;
    color:#fff;
    -webkit-transition: color 1s; /* Safari */
    transition: color 1s;
}

#cntLink a:hover {
    color:#fc3804;
}

.cntlk1 {
    background-color:#101010;
}

.cntlk2 {
    background-color:#0c0c0c;
}

.cntlk3 {
    background-color:#070707;
}

#success, #error {
    display:none
}

#success span, #erro span {
    font-weight:bold;
    padding:14px;
}

#success span p, #error span p {
    margin:0;
}

#success span p {
  color:#000;
}

#error span p {
  color:#ff0000;
}

label.error {
    margin-top: -20px;
    text-align: left;
    float: left;
    font-size: 12px;
    color: #f00;
    margin-left: 10px;
}

#wait {
    display:none;
    float:left;
}

#wait i {
    margin-bottom:10px;
    font-size:40px;
}

.siteLnk {
    float:right;
    font-size:30px;
}

/* ==========================================================================
   Media Queries
   ========================================================================== */
/* ==================== small screen ========================*/

@media only screen and (max-width: 1200px ) {
    #wraper.mOpen {
        margin-left:0px;
    }
}

/* ==================== tablet ========================*/

@media only screen and (max-width: 900px ) {
    .servLeft {
        width:50%;
    }
    
    .servRight {
        width:50%;
    }
    
    .contactLeft {
        width:50%;
    }
    
    .contactRight {
        width:50%;
    }
    
    .BannerTxt h2 {
        font-size:45px;
    }
    
    #services h2 {
        font-size:35px;
    }
    
    #services {
        font-size:16px;
    }
    
    .servRight article {
        padding:25px;
    }
    
    .servLeft aside {
        padding:25px;
    }
    
    h2 {
        font-size:35px;
    }
    
    #sectionSpec {
        font-size:16px;
    }
    
    #sectionSpec article {
        padding:25px;
    }
    
    #a-propos .aproposTxt {
        float:none;
        width:inherit;
        text-align:center;
    }
    
    #a-propos {
        background-image:none;
    }
    
    #a-propos h3 {
        font-size:24px;
    }
    
    .rBox {
        background-size:cover;
        -moz-transition-property: none;
        -webkit-transition-property: none;
        -o-transition-property: none;
        transition-property: none;
    }

    .item1 {
        width:50%;
        height:400px;
    }

    .item2 {
        width:50%;
        height:200px;
    }

    .item3 {
        width:50%;
        height:200px;
    }

    .rBox:hover {
        background-size:cover;
    }
    
    .itemBg {
        -moz-transition: none;
        -webkit-transition: none;
        transition: none;
    }
    
    .rBox:hover .itemBg {
        height:100%;
    }

    .rBox:focus .itemBg {
        height:100%;
    }
    
    .aproposTxt article {
        padding:25px;
    }
    
    #partner article {
        padding:25px;
    }
    
    .contactLeft footer {
        padding:25px;
    }
    
    .contactRight footer {
        padding:25px;
    }
    
    .contactLeft {
        padding:0;
        font-size:16px;
    }
    
    .contactRight {
        padding:0;
    }
    
    .contactRight h2 {
        font-size:35px;
    }
    
    .contactLeft h2 {
        font-size:35px;
    }
    
    .descBox h3 {
        font-size:18px;
    }
    
    .projectLink {
        margin-bottom:0px;
    }
    
    .descBox {
        bottom:-127px;
    }
    
    .mainBan {
        min-height:400px;
    }
    
    .mainBan:hover {
        background-size:cover;
    }
    
    .ban {
	   -moz-transition: none;
	   -webkit-transition: none;
	   transition: none;
    }

    .mainBan:hover .ban {
        -webkit-transform: scale(1, 1);
        transform: scale(1, 1);
    }

}

/* ==================== mobile ========================*/

@media only screen and (max-width: 700px) {
    .servLeft {
        width:100%;
        border-bottom:10px solid #fff;
    }
    
    .servRight {
        width:100%;
    }
    
    .servicesCol {
        float:none;
        height:auto;
    }
    
    #specialites li {
        width:100%;
        float:none;
        margin-bottom:20px;
        padding-left:0px;
    }
    
    #sectionSpec {
        text-align: center;
    }
    
    .contactLeft {
        width:100%;
        float:none;
        height:auto;
        border-right:0px;
        border-bottom:10px solid #fff;
    }
    
    .contactRight {
        width:100%;
        float:none;
        height:auto;
    }
    
    .BannerTxt h2 {
        font-size:32px;
    }
    
    .rBox {
        float:none;
    }

    .item1 {
        width:100%;
        height:300px;
        border-bottom:10px solid #fff;
    }

    .item2 {
        width:100%;
        height:300px;
        border-bottom:10px solid #fff;
    }

    .item3 {
        width:100%;
        height:300px;
    }
    
    .item4 {
        width:100%;
        height:300px;
        border-bottom:10px solid #fff;
    }
    
    .item5 {
        width:100%;
        height:300px;
    }
    
}

@media only screen and (max-width: 450px) {
    #cntLink li {
        width: 75px;
    }
    
    #cntLink a {
        padding: 1px 0px;
    }
    
    #menuWrap {
        width: 226px;
        left:-226px;
    }
    
    #menu {
        font-size: 10px;
        line-height:24px;
    }
    
    #menu .current a {
        font-size: 10px;
    }
    
    #logo img {
        width: 80%;
    }
    
    #logo {
        margin: 0px;
    }
    
    .togBtn {
        background-color: #fff;
        padding: 0px 9px 0px 15px;
        float: right;
        margin-right: -84px;
        text-align: center;
    }
    
    #menuWrap {
        left:-226px;
        padding-bottom:57px;
    }
    
    .descBox {
        bottom: -154px;
    }
    
    .descBox {
        height: 230px;
    }
    
    
}




