@import url(https://fonts.googleapis.com/css?family=Montserrat:300,300i,400,400i,500,500i,600,600i,700,700i,800,800i,900,900i);
@-webkit-keyframes animline {
  0% {
    width: 0px; }
  100% {
    width: 200px; } }

@-webkit-keyframes slide-in {
  0% {
    -webkit-transform: translateX(600px);
    transform: translateX(600px);
    width: 65px;
    max-height: 65px;
    padding-left: 0; }
  50% {
    -webkit-transform: translateX(-600px);
    transform: translateX(-600px);
    width: 65px;
    max-height: 65px;
    padding-left: 0; }
  75% {
    -webkit-transform: translateX(-600px);
    transform: translateX(-600px);
    padding-left: 65px;
    width: 400px;
    max-height: 65px; }
  100% {
    -webkit-transform: translateX(-600px);
    transform: translateX(-600px);
    padding-left: 65px;
    width: 400px;
    max-height: 500px; } }

@-webkit-keyframes slide-out {
  0% {
    -webkit-transform: translateX(-600px);
    transform: translateX(-600px);
    padding-left: 65px;
    width: 400px;
    max-height: 500px; }
  100% {
    -webkit-transform: translateX(800px);
    transform: translateX(800px);
    padding-left: 65px;
    width: 400px;
    max-height: 500px; } }

@keyframes slide-out {
  0% {
    -webkit-transform: translateX(-600px);
    transform: translateX(-600px);
    padding-left: 65px;
    width: 400px;
    max-height: 500px; }
  100% {
    -webkit-transform: translateX(800px);
    transform: translateX(800px);
    padding-left: 65px;
    width: 400px;
    max-height: 500px; } }

@-webkit-keyframes after-slide-out {
  0% {
    padding-left: 65px;
    width: 400px;
    max-height: 500px; }
  100% {
    padding-left: 0;
    width: 65px;
    max-height: 65px; } }

@-webkit-keyframes opacity_text_in {
  0% {
    opacity: 0; }
  80% {
    opacity: 0; }
  100% {
    opacity: 1; } }

@keyframes opacity_text_in {
  0% {
    opacity: 0; }
  80% {
    opacity: 0; }
  100% {
    opacity: 1; } }

@-webkit-keyframes opacity_text_out {
  0% {
    opacity: 1; }
  80% {
    opacity: 1; }
  100% {
    opacity: 0; } }

@keyframes opacity_text_out {
  0% {
    opacity: 1; }
  80% {
    opacity: 1; }
  100% {
    opacity: 0; } }

/**
 * ----------------------------------------
 * animation scale-in-ver-center
 * ----------------------------------------
 */
@-webkit-keyframes scale-in-ver-center {
  0% {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    opacity: 0; }
  100% {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    opacity: 1; } }
@keyframes scale-in-ver-center {
  0% {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    opacity: 0; }
  100% {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    opacity: 1; } }

@-webkit-keyframes scale-out-ver-center {
  0% {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    opacity: 1; }
  100% {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    opacity: 0; } }

@keyframes scale-out-ver-center {
  0% {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    opacity: 1; }
  100% {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    opacity: 0; } }

/*FIX bootstrap*/
.no-padding {
  padding: 0; }

.no-margin {
  margin: 0 !important; }

.overflow {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 40;
  width: 100%;
  height: 100%;
  cursor: pointer; }

html {
  overflow-x: hidden; }

body {
  overflow-x: hidden; }

h1 {
  font-family: "Montserrat", sans-serif;
  font-size: 40px; }

h2 {
  font-family: "Montserrat", sans-serif; }

h3, h4, h5, h6 {
  font-family: "Montserrat", sans-serif; }

h2 {
  font-size: 30px;
  font-weight: 400; }

h3 {
  font-size: 22px; }

h4 {
  font-size: 20px; }

h5 {
  font-size: 19px; }

h6 {
  font-size: 16px; }

p, a, li {
  font-size: 20px;
  font-weight: 300;
  line-height: 30px;
  color: #3a3a3a;
  font-family: "Montserrat", sans-serif; }

a {
  -o-transition: all ease-in-out 0.5s;
  transition: all ease-in-out 0.5s;
  -webkit-transition: all ease-in-out 0.5s; }

.page-load {
  background: rgba(58, 58, 58, 0.95);
  width: 100%;
  height: 100%;
  position: fixed;
  z-index: 999999999;
  top: 0;
  left: 0;
  bottom: 0;
  display: block; }
  .page-load .logo-load {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%); }

#wpadminbar {
  display: none; }

.contact-form form {
  width: 100%;
  color: #3a3a3a;
  font-family: "Montserrat", sans-serif;
  font-size: 20px; }
  .contact-form form input, .contact-form form button, .contact-form form textarea {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 0; }
  .contact-form form label {
    display: block;
    width: 100%;
    margin-bottom: 5px;
    margin-top: 20px;
    font-size: 18px;
    color: #3a3a3a; }
  .contact-form form input {
    width: 100%;
    padding: 10px;
    border: solid 1px rgba(58, 58, 58, 0.2);
    background: #fdfdfd; }
    .contact-form form input:focus {
      outline: rgba(58, 58, 58, 0.5) solid thin; }
  .contact-form form input[type="submit"] {
    cursor: pointer; }
  .contact-form form input[type="text"], .contact-form form input[type="email"], .contact-form form textarea {
    color: #3a3a3a;
    font-weight: 300;
    font-size: 18px; }
  .contact-form form textarea {
    width: 100%;
    height: 160px;
    border: solid 1px rgba(58, 58, 58, 0.2);
    background: #fdfdfd;
    padding: 5px; }
    .contact-form form textarea:focus {
      outline: rgba(58, 58, 58, 0.5) solid thin; }
  .contact-form form button {
    margin-top: 20px;
    outline: none;
    border: none;
    color: #fff;
    padding: 10px 20px;
    -webkit-transition: all ease-in-out 0.5s;
    -o-transition: all ease-in-out 0.5s;
    transition: all ease-in-out 0.5s; }
    .contact-form form button:hover {
      background: #3a3a3a; }

.contact-form .screen-reader-response {
  display: none; }

.contact-form .wpcf7-submit {
  background: #3a3a3a;
  color: #fff;
  -webkit-transition: all ease 0.4s !important;
  -o-transition: all ease 0.4s !important;
  transition: all ease 0.4s !important;
  font-size: 20px;
  font-weight: 700;
  border: none;
  text-transform: uppercase; }
  .contact-form .wpcf7-submit:hover {
    background: #3a3a3a; }

.contact-form .wpcf7-display-none {
  display: none; }

.contact-form .wpcf7-mail-sent-ok, .contact-form .wpcf7-validation-errors {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-shadow: 0px 10px 40px 0px rgba(0, 0, 0, 0.3);
  box-shadow: 0px 10px 40px 0px rgba(0, 0, 0, 0.3);
  border: none !important;
  margin: 0 !important;
  padding: 15px 20px 15px 70px;
  z-index: 9999;
  overflow: hidden;
  -webkit-animation: scale-in-ver-center 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both, scale-out-ver-center 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 5s both;
  animation: scale-in-ver-center 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both, scale-out-ver-center 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 5s both;
  font-weight: bold;
  color: #FFF;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  background: #3a3a3a;
  text-transform: lowercase;
  font-size: 18px;
  line-height: 26px;
  font-weight: 400; }

.contact-form .wpcf7-mail-sent-ok a, .contact-form .wpcf7-validation-errors a, .contact-form .wpcf7-mail-sent-ok a:hover, .contact-form .wpcf7-validation-errors a:hover {
  color: #fff; }

.contact-form .wpcf7-mail-sent-ok span, .contact-form .wpcf7-validation-errors span {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  top: 15px;
  left: 15px;
  width: 65px;
  height: 100%;
  font-size: 30px;
  color: #FFF; }

.contact-form .wpcf7-mail-sent-ok .wpcf7-not-valid-tip-text, .contact-form .wpcf7-validation-errors .wpcf7-not-valid-tip-text, .contact-form .wpcf7-mail-sent-ok .wpcf7-valid-tip-text, .contact-form .wpcf7-validation-errors .wpcf7-valid-tip-text {
  -webkit-animation: scale-in-ver-center 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
  animation: scale-in-ver-center 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
  color: #fff; }

.contact-form span.wpcf7-not-valid-tip {
  font-size: 14px;
  text-transform: none; }

.contact-form .recap {
  margin-bottom: 30px !important; }

input.wpcf7-validates-as-required.wpcf7-not-valid {
  border-color: #f55b5f; }

.page-404 {
  min-height: 800px; }
  .page-404 a:hover {
    color: #000; }

header {
  width: 100%;
  position: relative;
  padding-top: 40%;
  padding-bottom: 40px; }
  header.header-404 {
    padding-top: 10%; }
  header nav {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 99999;
    -webkit-transition: all ease-in-out 0.5s;
    -o-transition: all ease-in-out 0.5s;
    transition: all ease-in-out 0.5s;
    background: #fff;
    width: 100%;
    height: 100px;
    float: left;
    margin: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0px 80px; }
    header nav .menu-nav {
      float: left;
      width: 80%; }
      header nav .menu-nav ul {
        display: block;
        float: right;
        margin-bottom: 0; }
        header nav .menu-nav ul li {
          float: left;
          display: block;
          text-align: center;
          padding: 14px 15px;
          font-size: 18px;
          font-family: "Montserrat", sans-serif;
          text-transform: uppercase;
          font-weight: 500; }
          header nav .menu-nav ul li a {
            color: #3a3a3a;
            text-decoration: none; }
          header nav .menu-nav ul li:hover {
            text-decoration: none; }
      header nav .menu-nav.opened ul li a {
        color: #fff; }
    header nav.big-nav {
      padding: 0px 80px 0px 380px; }
      header nav.big-nav .menu-nav {
        width: 100%; }
    header nav .logo {
      position: relative;
      width: 20%;
      float: left;
      z-index: 10;
      cursor: pointer; }
      header nav .logo a {
        cursor: pointer; }
      header nav .logo img {
        max-height: 80px;
        width: auto;
        position: relative;
        z-index: 10;
        cursor: pointer; }
    header nav .logo-big {
      position: absolute;
      top: 0;
      padding: 10px 20px;
      left: 80px;
      width: 300px;
      background: #fff;
      -webkit-box-shadow: 7px 7px 12px 0px rgba(71, 71, 71, 0.3);
      box-shadow: 7px 7px 12px 0px rgba(71, 71, 71, 0.3);
      -o-transition: all ease-in-out 0.5s;
      transition: all ease-in-out 0.5s;
      -webkit-transition: all ease-in-out 0.5s; }
    header nav .menu-hamburger {
      position: absolute;
      top: 29px;
      right: 29px;
      cursor: pointer;
      display: none; }
      header nav .menu-hamburger:hover span:first-child {
        -ms-transform: translateY(-3px);
        transform: translateY(-3px);
        -webkit-transform: translateY(-3px); }
      header nav .menu-hamburger:hover span:last-child {
        -ms-transform: translateY(3px);
        transform: translateY(3px);
        -webkit-transform: translateY(3px); }
      header nav .menu-hamburger span {
        display: block;
        background: #3a3a3a;
        width: 50px;
        height: 4px;
        margin-bottom: 8px;
        -webkit-transition: all ease 0.5s;
        -o-transition: all ease 0.5s;
        transition: all ease 0.5s; }
    header nav .menu-close {
      display: none;
      position: absolute;
      z-index: 999999999;
      top: 20px;
      right: 20px;
      cursor: pointer; }
      header nav .menu-close span {
        color: #fff;
        font-size: 20px;
        -o-transition: all ease-in-out 0.5s;
        transition: all ease-in-out 0.5s;
        -webkit-transition: all ease-in-out 0.5s; }
    header nav.fixed {
      height: 60px !important;
      top: 0;
      left: 0;
      background: rgba(255, 255, 255, 0.8); }
      header nav.fixed .menu-nav ul li {
        padding: 0px 20px; }
        header nav.fixed .menu-nav ul li a {
          font-size: 15px; }
      header nav.fixed .logo {
        padding-left: 10px; }
        header nav.fixed .logo img {
          height: 40px; }
      header nav.fixed .logo-big {
        width: 200px; }
      header nav.fixed.big-nav {
        padding: 0px 80px 0px 260px; }
      header nav.fixed .menu-hamburger {
        top: 15px;
        right: 15px; }
        header nav.fixed .menu-hamburger span {
          width: 40px;
          height: 3px;
          margin-bottom: 6px; }
  header .baseline {
    position: relative;
    z-index: 100;
    text-align: center;
    max-width: 1000px;
    margin: auto; }
    header .baseline h1 {
      color: #fff;
      text-transform: uppercase; }

.container-section {
  padding-top: 60px; }
  .container-section h2 {
    text-transform: uppercase;
    padding-bottom: 10px;
    margin-bottom: 15px; }
  .container-section .about-1 {
    margin-bottom: 60px; }
    .container-section .about-1 .txt {
      padding-left: 30px;
      padding-right: 0; }
  .container-section .about-1 .img, .container-section .about-2 .img {
    min-height: 300px; }
  .container-section .about-2 .txt {
    padding-right: 30px;
    padding-left: 0; }
  .container-section.services {
    padding-bottom: 10px; }
    .container-section.services h2 {
      color: #fff !important;
      text-align: center; }
  .container-section .about-3 {
    margin-top: 60px; }

.about-two .about-2 {
  margin-bottom: 60px; }

.services article {
  margin-bottom: 40px; }
  .services article .icon img {
    max-width: 100px;
    margin: auto;
    display: block; }
  .services article .txt {
    padding-top: 30px;
    color: #fff;
    text-align: center; }
    .services article .txt h3 {
      margin-bottom: 15px;
      text-transform: uppercase;
      font-size: 20px;
      line-height: 28px; }
    .services article .txt p {
      color: #fff;
      font-size: 18px;
      font-weight: 300;
      line-height: 26px; }

.services .row {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center; }

.realisations {
  text-align: center;
  padding-bottom: 30px; }
  .realisations .row-reali {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center; }
  .realisations article {
    position: relative;
    cursor: pointer;
    padding: 0 15px;
    margin-bottom: 30px; }
    .realisations article a.overflow {
      z-index: 200; }
    .realisations article a:focus {
      outline: none; }
    .realisations article .img {
      height: 360px;
      display: block;
      width: 100%;
      position: relative;
      -o-transition: all ease-in-out 0.5s;
      transition: all ease-in-out 0.5s;
      -webkit-transition: all ease-in-out 0.5s;
      overflow: hidden; }
      .realisations article .img .background {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        width: 100%;
        -o-transition: all ease-in-out 0.5s;
        transition: all ease-in-out 0.5s;
        -webkit-transition: all ease-in-out 0.5s;
        z-index: 50; }
    .realisations article .title {
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      z-index: 160;
      padding: 15px 10px; }
      .realisations article .title h4 {
        color: #fff;
        margin-bottom: 0;
        text-transform: uppercase;
        font-size: 16px; }
    .realisations article .overlay {
      position: absolute;
      bottom: 0;
      left: 0;
      top: 0;
      width: 100%;
      height: 0;
      overflow: hidden;
      -o-transition: all ease-in-out 0.5s;
      transition: all ease-in-out 0.5s;
      -webkit-transition: all ease-in-out 0.5s;
      -webkit-transform: translateY(-100%);
      -ms-transform: translateY(-100%);
      transform: translateY(-100%);
      z-index: 100;
      background: rgba(255, 255, 255, 0.9);
      padding: 30px; }
      .realisations article .overlay p {
        padding: 10px;
        margin-bottom: 0;
        font-size: 16px;
        line-height: 22px;
        width: 100%;
        displaY: block;
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%); }
        .realisations article .overlay p span {
          margin-top: 10px;
          display: block;
          font-size: 26px; }
    .realisations article:hover .overlay {
      -webkit-transform: translateY(0);
      -ms-transform: translateY(0);
      transform: translateY(0);
      height: auto;
      width: 100%; }
    .realisations article:hover .img .background {
      -webkit-transform: scale(1.1) rotate(2deg);
      -ms-transform: scale(1.1) rotate(2deg);
      transform: scale(1.1) rotate(2deg); }

.fancybox-toolbar, .fancybox-infobar {
  top: 80px; }

/* Outer */
.popup {
  width: 100%;
  height: 100%;
  display: none;
  position: fixed;
  top: 0px;
  left: 0px;
  background: rgba(0, 0, 0, 0.75);
  z-index: 999999999; }

/* Inner */
.popup-inner {
  max-width: 700px;
  max-height: 95%;
  overflow-y: auto;
  width: 90%;
  padding: 40px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  background: #fff;
  color: #3a3a3a;
  text-align: center; }
  .popup-inner p {
    font-size: 16px;
    line-height: 26px; }
  .popup-inner h2 {
    font-size: 18px;
    margin-bottom: 5px; }
  .popup-inner h3 {
    font-size: 16px;
    margin-bottom: 15px; }

/* Close Button */
.popup-close {
  width: 30px;
  height: 30px;
  padding-top: 4px;
  display: inline-block;
  position: absolute;
  top: 0px;
  right: 0px;
  -webkit-transition: ease 0.25s all;
  -o-transition: ease 0.25s all;
  transition: ease 0.25s all;
  font-family: Arial, Sans-Serif;
  font-size: 20px;
  text-align: center;
  line-height: 100%;
  color: #fff; }

.popup-close:hover {
  background: #3a3a3a;
  text-decoration: none;
  color: #fff; }

.equipe {
  padding-bottom: 30px; }
  .equipe .row {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center; }
  .equipe h2 {
    text-align: center; }
  .equipe article {
    padding: 0 15px;
    text-align: center;
    margin-bottom: 30px; }
    .equipe article .more {
      position: absolute;
      top: 0;
      right: 15px;
      width: 30px;
      height: 30px;
      color: #fff;
      -o-transition: all ease-in-out 0.5s;
      transition: all ease-in-out 0.5s;
      -webkit-transition: all ease-in-out 0.5s; }
      .equipe article .more span {
        margin-top: 1px;
        display: inline-block;
        text-align: center; }
      .equipe article .more:hover {
        background: #3a3a3a; }
    .equipe article .img {
      width: 100%;
      height: 300px; }
    .equipe article .nom {
      width: calc(100% - 30px);
      margin: -33px auto 0px auto;
      -o-transition: all ease-in-out 0.5s;
      transition: all ease-in-out 0.5s;
      -webkit-transition: all ease-in-out 0.5s; }
      .equipe article .nom h5 {
        color: #fff;
        padding: 5px;
        margin-bottom: 0;
        text-transform: uppercase;
        font-size: 18px;
        -o-transition: all ease-in-out 0.5s;
        transition: all ease-in-out 0.5s;
        -webkit-transition: all ease-in-out 0.5s; }
      .equipe article .nom h6 {
        padding: 5px 10px;
        margin-bottom: 0;
        font-size: 16px;
        min-height: 50px;
        width: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        text-align: center;
        -o-transition: all ease-in-out 0.5s;
        transition: all ease-in-out 0.5s;
        -webkit-transition: all ease-in-out 0.5s; }
        .equipe article .nom h6 span {
          margin: auto; }
    .equipe article p {
      margin-top: 15px;
      font-size: 16px;
      line-height: 24px; }
    .equipe article.no-descr:hover h5 {
      background: #3a3a3a; }
    .equipe article.no-descr:hover h6 {
      color: #3a3a3a; }
    .equipe article.no-descr:hover .nom {
      border: solid 2px #3a3a3a; }
    .equipe article.two-memb .img {
      height: 500px; }

@media (min-width: 992px) {
  .equipe article {
    margin-top: 40px;
    margin-bottom: 20px; }
    .equipe article.equipe-one .img {
      height: 310px; }
    .equipe article.equipe-one .infos {
      text-align: left; }
    .equipe article.equipe-one p {
      margin-top: 0; } }

.baseline {
  padding-bottom: 60px; }
  .baseline .logo img {
    width: 100%;
    max-width: 200px; }
  .baseline .txt-baseline {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding-left: 30px; }
    .baseline .txt-baseline h6 {
      color: #fff;
      font-size: 30px;
      display: block; }
    .baseline .txt-baseline img {
      max-width: 80px; }
  .baseline .titre-baseline {
    text-align: right;
    float: left;
    width: 80%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end; }
  .baseline .icon {
    padding-left: 30px;
    width: 20%;
    float: left;
    opacity: 0.9;
    -o-transition: all ease-in-out 0.5s;
    transition: all ease-in-out 0.5s;
    -webkit-transition: all ease-in-out 0.5s;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center; }
    .baseline .icon:hover {
      opacity: 1; }

#map {
  height: calc(100% - 100px);
  min-height: 400px; }

.contact {
  padding-bottom: 20px; }

.logos h2 {
  text-align: center; }

.logos article {
  padding: 30px;
  position: relative;
  -webkit-filter: grayscale(100%);
  filter: grayscale(100%);
  opacity: 0.9;
  -o-transition: all ease-in-out 0.5s;
  transition: all ease-in-out 0.5s;
  -webkit-transition: all ease-in-out 0.5s; }
  .logos article img {
    margin: auto;
    max-height: 100px; }
  .logos article:hover {
    -webkit-filter: none;
    filter: none;
    opacity: 1; }

footer {
  background: #3a3a3a;
  color: #fff;
  padding-bottom: 50px; }
  footer h3 {
    font-size: 20px;
    text-transform: uppercase;
    margin-bottom: 30px; }
  footer p, footer a, footer li {
    color: #fff;
    font-size: 14px;
    line-height: 24px; }
  footer p {
    margin-bottom: 30px; }
  footer ul {
    list-style-type: none;
    width: 100%;
    display: block;
    float: left;
    padding-left: 0; }
    footer ul li {
      width: 100%;
      display: block;
      float: left;
      margin-bottom: 8px; }
      footer ul li span {
        float: left;
        display: block; }
        footer ul li span.day {
          width: 100px; }
        footer ul li span.hour {
          width: calc(100% - 100px); }
  footer a p {
    margin-bottom: 0;
    -o-transition: all ease-in-out 0.5s;
    transition: all ease-in-out 0.5s;
    -webkit-transition: all ease-in-out 0.5s; }
  footer .tel {
    margin-bottom: 15px; }
  footer a:hover {
    text-decoration: none; }
  footer .social a {
    display: block;
    float: left;
    margin-bottom: 15px; }
    footer .social a span {
      font-size: 34px;
      margin-right: 15px; }
    footer .social a:hover {
      text-decoration: none; }
    footer .social a.cart-footer {
      float: none;
      clear: both;
      margin-bottom: 30px; }

.rights {
  padding-top: 30px;
  padding-bottom: 30px; }
  .rights p, .rights a {
    color: #fff;
    font-size: 16px;
    margin-bottom: 0; }
  .rights a:hover {
    text-decoration: none;
    color: #3a3a3a; }
  .rights .cvr {
    text-align: right; }
    .rights .cvr .link-cvr {
      font-weight: 400; }

@media (max-width: 1500px) {
  header nav {
    padding: 0px 0px 0px 20px; }
    header nav .menu-nav {
      width: 90%; }
    header nav .logo {
      width: 10%; }
    header nav .logo-big {
      left: 30px; }
    header nav.big-nav {
      padding: 0px 30px 0px 330px; }
      header nav.big-nav .menu-nav ul {
        padding-left: 0; } }

@media (max-width: 1400px) {
  header nav.big-nav .menu-nav ul li a {
    font-size: 16px; } }

@media (max-width: 1230px) {
  header nav .menu-nav ul li a {
    font-size: 16px;
    font-weight: 400; } }

@media (max-width: 1200px) {
  header nav .menu-nav ul li a {
    font-size: 14px; }
  header nav .logo-big {
    left: 15px; }
  header nav.big-nav {
    padding: 0px 15px 0px 315px; }
    header nav.big-nav .menu-nav ul li {
      padding: 14px 10px; }
  .equipe article.two-memb .img {
    height: 400px; }
  .equipe article.equipe-one .img {
    height: 310px; } }

@media (max-width: 1100px) {
  header nav .logo-big {
    width: 300px; }
  header nav.big-nav {
    padding: 0px 15px 0px 345px; }
    header nav.big-nav .menu-nav ul li a {
      font-size: 14px; } }

@media (max-width: 992px) {
  header nav {
    padding: 0px 30px;
    height: 60px; }
    header nav .menu-nav {
      -ms-transform: translateX(120%);
      transform: translateX(120%);
      -webkit-transform: translateX(120%);
      position: fixed;
      top: 0;
      left: 0;
      width: 100%;
      background: #3a3a3a;
      z-index: 999999;
      -o-transition: all ease-in-out 0.5s;
      transition: all ease-in-out 0.5s;
      -webkit-transition: all ease-in-out 0.5s;
      overflow-y: scroll;
      height: 100vh;
      padding: 200px 60px; }
      header nav .menu-nav ul {
        width: 100%;
        padding-left: 0; }
        header nav .menu-nav ul li {
          width: 100%;
          margin-bottom: 20px;
          border-bottom: solid 1px rgba(255, 255, 255, 0.1); }
          header nav .menu-nav ul li a {
            font-size: 18px; }
      header nav .menu-nav .menu-menu-1-container {
        float: left;
        width: 100%; }
      header nav .menu-nav.opened {
        -ms-transform: translateX(0);
        transform: translateX(0);
        -webkit-transform: translateX(0); }
    header nav .logo {
      width: 80%; }
      header nav .logo img {
        height: 40px; }
    header nav .menu-hamburger {
      display: block;
      top: 17px;
      right: 15px; }
      header nav .menu-hamburger span {
        width: 40px;
        height: 3px;
        margin-bottom: 6px; }
    header nav .menu-close {
      display: block; }
    header nav.fixed {
      height: 40px;
      background: transparent; }
      header nav.fixed .logo {
        display: none; }
      header nav.fixed .logo-big {
        -webkit-transform: translateY(-125%);
        -ms-transform: translateY(-125%);
        transform: translateY(-125%); }
      header nav.fixed .menu-hamburger {
        top: 10px;
        right: 10px;
        background: rgba(0, 0, 0, 0.5);
        padding: 10px; }
        header nav.fixed .menu-hamburger span {
          width: 30px;
          background: #fff; }
          header nav.fixed .menu-hamburger span:last-child {
            margin-bottom: 0px; }
      header nav.fixed .menu-nav ul li {
        padding: 14px 20px; }
        header nav.fixed .menu-nav ul li a {
          font-size: 18px; }
  header .baseline h1 {
    font-size: 30px; }
  .contact-form .recap > div {
    margin-left: auto;
    margin-right: auto; }
  .baseline .txt-baseline h6 {
    font-size: 26px; }
  #map {
    height: 400px; }
  .contact {
    padding-bottom: 60px; }
    .contact h2 {
      text-align: center; }
  .contact-form {
    margin-bottom: 30px; } }

@media (max-width: 991px) {
  footer {
    text-align: center; }
    footer h3 {
      margin-bottom: 5px; }
    footer ul li {
      margin-bottom: 15px; }
      footer ul li span {
        float: none;
        display: inline-block; }
    footer .social h3 {
      margin-bottom: 10px; }
    footer .social a {
      float: none;
      display: inline-block; }
    footer .coords {
      margin-bottom: 30px; }
  .container-section .about-1 {
    margin-bottom: 30px; }
    .container-section .about-1 .img {
      margin-bottom: 30px; }
    .container-section .about-1 .txt {
      text-align: center;
      padding-left: 0px; }
  .container-section .about-3 {
    margin-top: 30px; }
  .container-section .about-2 .img, .container-section .about-3 .img {
    display: none; }
  .container-section .about-2 .txt, .container-section .about-3 .txt {
    text-align: center;
    padding-right: 0px; }
  .equipe article.two-memb .img {
    height: 560px; } }

@media (max-width: 767px) {
  header {
    padding-bottom: 10px; }
    header .baseline h1 {
      font-size: 20px; }
  .baseline .txt-baseline h6 {
    font-size: 26px; }
  .baseline .titre-baseline {
    margin-top: 30px;
    text-align: center; }
  .baseline .titre-baseline, .baseline .icon {
    width: 100%;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center; }
  .baseline .icon {
    padding-left: 0; }
  .baseline .logo {
    text-align: center; }
  .equipe article .img {
    height: 500px; }
  .equipe article.two-memb .img {
    height: 500px; }
  .rights {
    text-align: center; }
    .rights p {
      font-size: 14px; }
    .rights .cvr {
      text-align: center;
      margin-top: 5px; } }

@media (max-width: 600px) {
  .contact-form .wpcf7-mail-sent-ok, .contact-form .wpcf7-validation-errors {
    max-width: 280px; }
  .g-recaptcha {
    -webkit-transform: scale(0.85);
    -ms-transform: scale(0.85);
    transform: scale(0.85);
    -webkit-transform-origin: 0 50%;
    -ms-transform-origin: 0 50%;
    transform-origin: 0 50%; }
  @-webkit-keyframes slide-in {
    0% {
      -webkit-transform: translateX(600px);
      transform: translateX(600px);
      width: 65px;
      max-height: 65px;
      padding-left: 0; }
    50% {
      -webkit-transform: translateX(-300px);
      transform: translateX(-300px);
      width: 65px;
      max-height: 65px;
      padding-left: 0; }
    75% {
      -webkit-transform: translateX(-300px);
      transform: translateX(-300px);
      padding-left: 65px;
      width: 400px;
      max-height: 65px; }
    100% {
      -webkit-transform: translateX(-300px);
      transform: translateX(-300px);
      padding-left: 65px;
      width: 400px;
      max-height: 500px; } }
  @keyframes slide-in {
    0% {
      -webkit-transform: translateX(600px);
      transform: translateX(600px);
      width: 65px;
      max-height: 65px;
      padding-left: 0; }
    50% {
      -webkit-transform: translateX(-300px);
      transform: translateX(-300px);
      width: 65px;
      max-height: 65px;
      padding-left: 0; }
    75% {
      -webkit-transform: translateX(-300px);
      transform: translateX(-300px);
      padding-left: 65px;
      width: 400px;
      max-height: 65px; }
    100% {
      -webkit-transform: translateX(-300px);
      transform: translateX(-300px);
      padding-left: 65px;
      width: 400px;
      max-height: 500px; } }
  @-webkit-keyframes slide-out {
    0% {
      -webkit-transform: translateX(-300px);
      transform: translateX(-300px);
      padding-left: 65px;
      width: 400px;
      max-height: 500px; }
    100% {
      -webkit-transform: translateX(800px);
      transform: translateX(800px);
      padding-left: 65px;
      width: 400px;
      max-height: 500px; } }
  @keyframes slide-out {
    0% {
      -webkit-transform: translateX(-300px);
      transform: translateX(-300px);
      padding-left: 65px;
      width: 400px;
      max-height: 500px; }
    100% {
      -webkit-transform: translateX(800px);
      transform: translateX(800px);
      padding-left: 65px;
      width: 400px;
      max-height: 500px; } }
  header {
    padding-top: 60%; }
    header nav .menu-nav {
      padding: 100px 30px; }
    header .baseline h1 {
      font-size: 26px;
      line-height: 1.5; }
  .container-section {
    padding-top: 30px; }
    .container-section .about-1 .img, .container-section .about-2 .img {
      min-height: 200px; }
    .container-section .about-1 {
      padding: 15px 15px 0px 15px;
      margin-bottom: 30px; }
    .container-section .about-2 .txt {
      padding: 0px 15px 0px 15px; }
  .about-two .about-2 {
    margin-bottom: 30px; }
  .about-two.services {
    padding-bottom: 0; }
  .services {
    padding-bottom: 0; }
    .services article {
      margin-bottom: 30px; }
      .services article .txt {
        padding-top: 15px; }
  h2 {
    font-size: 26px; }
  .realisations {
    padding-bottom: 0; }
  .equipe {
    padding-bottom: 0; }
    .equipe article .img {
      height: 420px; }
    .equipe article.two-memb .img {
      height: 420px; }
  .popup-inner {
    padding: 30px 15px; }
  .contact {
    padding-bottom: 30px; }
  #map {
    height: 300px;
    min-height: 300px; }
  footer {
    padding-bottom: 30px; } }

@media (max-width: 500px) {
  header nav .logo-big {
    width: 150px; }
  header nav.big-nav {
    padding: 0px 15px 0px 170px; }
  header nav.fixed.big-nav {
    padding: 0px 15px 0px 170px; }
  header nav.fixed .logo-big {
    width: 150px; } }

@media (max-width: 400px) {
  .equipe article .img {
    height: 300px; }
  .equipe article.two-memb .img {
    height: 300px; }
  .realisations {
    padding-bottom: 0; }
    .realisations article .img {
      height: 240px; } }

@media (max-height: 455px) {
  header nav .menu-nav {
    display: block; }
    header nav .menu-nav ul li {
      margin-bottom: 0px; } }
