@charset "UTF-8";
/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/
@import url("https://use.typekit.net/age1gfi.css");
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline; }

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

body {
  line-height: 1; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

@font-face {
  font-family: "INNOVATION-FLUIDES";
  src: url("../fonts/INNOVATION-FLUIDES.eot");
  src: url("../fonts/INNOVATION-FLUIDES.eot?#iefix") format("embedded-opentype"), url("../fonts/INNOVATION-FLUIDES.woff2") format("woff2"), url("../fonts/INNOVATION-FLUIDES.woff") format("woff"), url("../fonts/INNOVATION-FLUIDES.ttf") format("truetype"), url("../fonts/INNOVATION-FLUIDES.svg#INNOVATION-FLUIDES") format("svg");
  font-weight: normal;
  font-style: normal; }

@media screen and (-webkit-min-device-pixel-ratio: 0) {
  @font-face {
    font-family: "INNOVATION-FLUIDES";
    src: url("../fonts/INNOVATION-FLUIDES.svg#INNOVATION-FLUIDES") format("svg"); } }

[data-icons8]:before,
.icons8-arrow-pointing-to-right:before,
.icons8-back-arrow:before,
.icons8-close-button:before,
.icons8-download:before,
.icons8-health-data:before,
.icons8-menu:before,
.icons8-right-pointing-arrow:before,
.icons8-simple-arrow:before {
  display: inline-block;
  font-family: "INNOVATION-FLUIDES";
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  line-height: 1;
  text-decoration: inherit;
  text-rendering: optimizeLegibility;
  text-transform: none;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased; }

[data-icons8]:before {
  content: attr(data-icons8); }

.icons8-arrow-pointing-to-right:before {
  content: ""; }

.icons8-back-arrow:before {
  content: ""; }

.icons8-close-button:before {
  content: ""; }

.icons8-download:before {
  content: ""; }

.icons8-health-data:before {
  content: ""; }

.icons8-menu:before {
  content: ""; }

.icons8-right-pointing-arrow:before {
  content: ""; }

.icons8-simple-arrow:before {
  content: ""; }

h1, h2, h3, h4, h5, a, p, div, span, footer {
  font-family: futura-pt; }

sup {
  font-size: 10px; }

body {
  overflow-x: hidden; }

.message {
  position: absolute;
  z-index: 99;
  width: 100%;
  top: 0;
  padding: 10px 0;
  text-align: center; }
  .message.success {
    background: #000;
    color: #FFF; }
  .message.error {
    background: #000;
    color: #FFF; }

header {
  position: absolute;
  width: 100%;
  top: 0;
  background-color: #fff;
  z-index: 3;
  height: 126px; }
  header.top {
    height: 67px;
    position: fixed;
    border-bottom: 1px solid #e3e3e3;
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out; }
    header.top nav {
      padding: 10px 25px;
      -webkit-transition: all 0.2s ease-in-out;
      -o-transition: all 0.2s ease-in-out;
      transition: all 0.2s ease-in-out; }
      header.top nav .img-container {
        max-width: 160px;
        -webkit-transition: all 0.2s ease-in-out;
        -o-transition: all 0.2s ease-in-out;
        transition: all 0.2s ease-in-out; }
  header nav {
    padding: 30px 25px;
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out; }
    header nav .img-container {
      max-width: 230px;
      -webkit-transition: all 0.2s ease-in-out;
      -o-transition: all 0.2s ease-in-out;
      transition: all 0.2s ease-in-out; }
    header nav .title {
      text-transform: uppercase;
      font-weight: 700;
      letter-spacing: 4px;
      font-size: 20px; }

#menu.home-menu {
  z-index: 3;
  position: absolute;
  top: 0;
  right: 0;
  width: 70px;
  height: 140px;
  background-color: #222831; }
  #menu.home-menu #toggle-menu {
    top: 19px;
    right: 19px; }
    #menu.home-menu #toggle-menu.open span.name {
      color: transparent; }
    #menu.home-menu #toggle-menu span {
      background-color: #fff; }
      #menu.home-menu #toggle-menu span.name {
        top: 47px;
        color: #fff;
        font-weight: 500;
        letter-spacing: 4px;
        -webkit-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
        transform: rotate(90deg);
        background-color: transparent;
        height: auto;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none; }

#menu #toggle-menu {
  position: absolute;
  z-index: 3;
  width: 29px;
  height: 24px;
  right: 50px;
  top: -10px;
  -webkit-transform: rotate(0deg);
  -ms-transform: rotate(0deg);
  transform: rotate(0deg);
  cursor: pointer;
  -webkit-transition: top .2s ease-in-out 0s;
  -o-transition: top .2s ease-in-out 0s;
  transition: top .2s ease-in-out 0s; }
  #menu #toggle-menu.open {
    -webkit-transition: all .5s ease-in-out 0s;
    -o-transition: all .5s ease-in-out 0s;
    transition: all .5s ease-in-out 0s; }
    #menu #toggle-menu.open span {
      background: #fff; }
    #menu #toggle-menu.open span:nth-child(1) {
      top: 18px;
      -webkit-transform: rotate(135deg);
      -ms-transform: rotate(135deg);
      transform: rotate(135deg); }
    #menu #toggle-menu.open span:nth-child(2) {
      left: -60px;
      opacity: 0; }
    #menu #toggle-menu.open span:nth-child(3) {
      top: 18px;
      -webkit-transform: rotate(-135deg);
      -ms-transform: rotate(-135deg);
      transform: rotate(-135deg); }
  #menu #toggle-menu span {
    position: absolute;
    display: block;
    width: 100%;
    height: 2px;
    left: 0;
    background: #222831;
    opacity: 1;
    -webkit-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    transform: rotate(0deg);
    -webkit-transition: all .25s ease-in-out 0s;
    -o-transition: all .25s ease-in-out 0s;
    transition: all .25s ease-in-out 0s; }
    #menu #toggle-menu span:nth-child(1) {
      top: 0; }
    #menu #toggle-menu span:nth-child(2) {
      top: 10px; }
    #menu #toggle-menu span:nth-child(3) {
      top: 20px; }

.nav-container {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100vh;
  z-index: -1;
  -webkit-transition: all .3s ease-in-out 0s;
  -o-transition: all .3s ease-in-out 0s;
  transition: all .3s ease-in-out 0s;
  background-color: rgba(255, 255, 255, 0); }
  .nav-container.open {
    z-index: 2;
    -webkit-transition: all .3s ease-in-out 0.2s;
    -o-transition: all .3s ease-in-out 0.2s;
    transition: all .3s ease-in-out 0.2s; }
    .nav-container.open nav {
      right: 0;
      -webkit-transition: all .3s ease-in-out 0.2s;
      -o-transition: all .3s ease-in-out 0.2s;
      transition: all .3s ease-in-out 0.2s; }
  .nav-container nav {
    position: absolute;
    top: 0;
    right: -400px;
    width: 100%;
    max-width: 400px;
    height: 100%;
    background-color: #222831;
    -webkit-transition: all .3s ease-in-out 0s;
    -o-transition: all .3s ease-in-out 0s;
    transition: all .3s ease-in-out 0s; }
    .nav-container nav ul {
      position: absolute;
      top: 50%;
      left: 45%;
      -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%); }
      .nav-container nav ul li {
        text-align: left; }
        .nav-container nav ul li:not(:last-child) {
          margin-bottom: 50px; }
        .nav-container nav ul li a {
          position: relative;
          text-decoration: none;
          color: #fff;
          text-align: left;
          text-transform: uppercase;
          font-size: 30px;
          letter-spacing: 3px;
          -webkit-user-select: none;
          -moz-user-select: none;
          -ms-user-select: none;
          user-select: none;
          -webkit-transition: opacity .25s ease-in-out 0s;
          -o-transition: opacity .25s ease-in-out 0s;
          transition: opacity .25s ease-in-out 0s; }
          .nav-container nav ul li a:after {
            content: '';
            position: absolute;
            display: block;
            bottom: -10px;
            left: 0;
            height: 2px;
            width: 63px;
            background-color: #fff;
            opacity: 0;
            -webkit-transition: opacity .25s ease-in-out 0s;
            -o-transition: opacity .25s ease-in-out 0s;
            transition: opacity .25s ease-in-out 0s; }
          .nav-container nav ul li a:hover {
            opacity: 0.4; }
            .nav-container nav ul li a:hover:after {
              opacity: inherit; }

footer {
  margin: 30px 0 40px;
  color: #222831;
  text-transform: uppercase;
  font-size: 12px; }
  footer a, footer a:hover {
    color: #222831;
    text-decoration: underline; }

.container {
  max-width: 1250px; }

#brand-home {
  position: absolute;
  top: 0;
  left: 0;
  height: 100vh;
  width: 100%;
  max-width: 400px;
  background-image: url("/img/fond-home.png");
  background-position: center;
  background-size: cover;
  background-repeat: repeat-y;
  z-index: 1;
  padding: 60px;
  opacity: 1;
  -webkit-transition: opacity 0.2s ease-in-out;
  -o-transition: opacity 0.2s ease-in-out;
  transition: opacity 0.2s ease-in-out; }
  #brand-home .chapo {
    text-transform: uppercase;
    font-size: 16px;
    letter-spacing: 2px;
    line-height: 1.2;
    color: #222831; }
  #brand-home .brand-container {
    position: absolute;
    top: calc(50% + 140px);
    left: calc(50% + 7px);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%); }
    #brand-home .brand-container h1 {
      color: #222831;
      text-transform: uppercase;
      letter-spacing: 6px;
      font-weight: 600;
      font-size: 22px;
      line-height: 1.2; }
  #brand-home .copyright {
    text-transform: uppercase;
    font-family: futura-pt;
    font-size: 12px;
    color: #222831;
    line-height: 1.6; }
    #brand-home .copyright a {
      color: #222831;
      text-decoration: underline; }
      #brand-home .copyright a:hover {
        text-decoration: none; }

#home-projects, #connexion {
  width: 100vw;
  height: 100vh;
  position: relative;
  z-index: 0;
  overflow: hidden;
  opacity: 1;
  -webkit-transition: opacity 0.2s ease-in-out;
  -o-transition: opacity 0.2s ease-in-out;
  transition: opacity 0.2s ease-in-out; }
  #home-projects .home-project-container, #connexion .home-project-container {
    width: 100%;
    height: 100vh; }
    #home-projects .home-project-container .img-container .blackfade, #connexion .home-project-container .img-container .blackfade {
      position: absolute;
      bottom: 0px;
      left: 0;
      width: 100%;
      height: 340px;
      background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0.55)));
      background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.55) 100%);
      background: -o-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.55) 100%);
      background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.55) 100%); }
  #home-projects .project-infos, #connexion .project-infos {
    position: relative;
    height: 100%;
    width: calc(100% - 400px);
    margin-left: auto;
    padding: 60px;
    top: 0;
    left: 0; }
    #home-projects .project-infos .project-infos-container, #connexion .project-infos .project-infos-container {
      position: absolute;
      bottom: 45px;
      color: #fff;
      text-transform: uppercase; }
      #home-projects .project-infos .project-infos-container .project-desc, #connexion .project-infos .project-infos-container .project-desc {
        letter-spacing: 4px;
        font-size: 16px;
        margin-bottom: 13px; }
      #home-projects .project-infos .project-infos-container .title, #connexion .project-infos .project-infos-container .title {
        font-size: 40px;
        font-weight: 700;
        letter-spacing: 4px; }
        @media screen and (max-width: 1500px) {
          #home-projects .project-infos .project-infos-container .title, #connexion .project-infos .project-infos-container .title {
            font-size: 30px; } }
        #home-projects .project-infos .project-infos-container .title a, #connexion .project-infos .project-infos-container .title a {
          color: #fff; }
          #home-projects .project-infos .project-infos-container .title a:hover, #home-projects .project-infos .project-infos-container .title a:visited, #home-projects .project-infos .project-infos-container .title a:focus, #connexion .project-infos .project-infos-container .title a:hover, #connexion .project-infos .project-infos-container .title a:visited, #connexion .project-infos .project-infos-container .title a:focus {
            text-decoration: none;
            outline: none; }

#connexion .connexion-infos {
  margin: 0 auto;
  top: 200px;
  background-color: #fff;
  padding: 50px 100px; }
  #connexion .connexion-infos label {
    margin: 20px 0 10px; }
  #connexion .connexion-infos .button-more {
    background-color: #222831;
    color: #fff;
    text-decoration: underline;
    padding: 11px 23px;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 1px;
    font-size: 14px;
    margin-top: 25px;
    -webkit-appearance: none;
    -moz-appearance: none;
    border: none; }
    #connexion .connexion-infos .button-more:hover {
      text-decoration: none; }

.home-projects-nav {
  position: absolute;
  right: 50px;
  bottom: 35px;
  color: #fff;
  width: 115px; }
  .home-projects-nav .slick-arrow {
    font-size: 30px;
    -webkit-transition: -webkit-transform 0.2s ease-in-out;
    transition: -webkit-transform 0.2s ease-in-out;
    -o-transition: transform 0.2s ease-in-out;
    transition: transform 0.2s ease-in-out;
    transition: transform 0.2s ease-in-out, -webkit-transform 0.2s ease-in-out; }
    .home-projects-nav .slick-arrow:hover {
      -webkit-transform: scale(1.1);
      -ms-transform: scale(1.1);
      transform: scale(1.1);
      cursor: pointer;
      -webkit-transition: -webkit-transform 0.2s ease-in-out;
      transition: -webkit-transform 0.2s ease-in-out;
      -o-transition: transform 0.2s ease-in-out;
      transition: transform 0.2s ease-in-out;
      transition: transform 0.2s ease-in-out, -webkit-transform 0.2s ease-in-out; }

#home-news {
  position: absolute;
  right: -400px;
  top: 140px;
  width: 400px;
  height: 570px;
  background-color: #fff;
  padding: 70px 50px 35px;
  -webkit-transition: right 0.4s ease;
  -o-transition: right 0.4s ease;
  transition: right 0.4s ease; }
  #home-news.open {
    right: 0px;
    -webkit-transition: right 0.4s ease;
    -o-transition: right 0.4s ease;
    transition: right 0.4s ease; }
    #home-news.open .display-button .icon-container:after {
      content: '-'; }
  #home-news .display-button {
    position: absolute;
    width: 70px;
    height: 70px;
    top: 0;
    right: 100%;
    background-color: #fff;
    text-transform: uppercase;
    color: #222831;
    text-align: center;
    padding: 15px 0 17px; }
    #home-news .display-button:hover {
      cursor: pointer; }
    #home-news .display-button .icon-container:after {
      content: '+'; }
    #home-news .display-button .title {
      text-transform: uppercase;
      font-weight: 600; }
  #home-news .news-container {
    text-align: center; }
    #home-news .news-container .img-container {
      width: 100%;
      height: 185px;
      margin-bottom: 30px; }
    #home-news .news-container .title {
      text-transform: uppercase;
      font-weight: 600;
      color: #222831;
      font-size: 28px;
      letter-spacing: 1px;
      margin-bottom: 10px; }
    #home-news .news-container .date {
      margin-bottom: 10px; }
    #home-news .news-container .content p {
      font-size: 14px;
      line-height: 1.3;
      margin-bottom: 50px; }
    #home-news .news-container .button-more {
      background-color: #222831;
      color: #fff;
      text-decoration: underline;
      padding: 11px 23px;
      text-transform: uppercase;
      font-weight: 600;
      letter-spacing: 1px;
      font-size: 14px; }
      #home-news .news-container .button-more:hover {
        text-decoration: none; }

.filters-container {
  position: fixed;
  top: 126px;
  width: 100%;
  text-align: center;
  -webkit-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  background-color: #fff;
  padding: 20px 0;
  z-index: 2; }
  .filters-container.top {
    top: 67px;
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out; }
  .filters-container .filter-list {
    margin: 0; }
  .filters-container .filter {
    margin-right: 25px; }
    .filters-container .filter:not(:last-child):after {
      content: '|';
      position: relative;
      display: inline;
      left: 13px;
      opacity: 0.4; }
    .filters-container .filter a {
      color: #222831;
      opacity: 0.4; }
      .filters-container .filter a.bold {
        opacity: 1; }
  .filters-container .filter-map {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    text-align: right;
    margin-right: 0; }
    .filters-container .filter-map a {
      opacity: 0.8; }
    .filters-container .filter-map .icon {
      max-width: 9px;
      margin-right: 5px; }

#projects {
  position: relative;
  z-index: 0;
  margin-top: 191px; }
  #projects .project-container {
    position: relative;
    width: 100%;
    padding: 15px 0;
    z-index: 9999; }
    #projects .project-container:hover .img-container .project-content .desc-container {
      height: 62px;
      -webkit-transition: all 0.2s ease-in-out;
      -o-transition: all 0.2s ease-in-out;
      transition: all 0.2s ease-in-out; }
    #projects .project-container:hover .img-container .project-categories {
      opacity: 1;
      -webkit-transition: all 0.2s ease-in-out;
      -o-transition: all 0.2s ease-in-out;
      transition: all 0.2s ease-in-out; }
    #projects .project-container .img-container {
      position: relative;
      height: 0;
      padding-top: 78.1%; }
      #projects .project-container .img-container .project-categories {
        opacity: 0;
        position: absolute;
        top: 30px;
        left: 35px;
        background-color: #222831;
        padding: 8px 15px;
        -webkit-transition: all 0.2s ease-in-out;
        -o-transition: all 0.2s ease-in-out;
        transition: all 0.2s ease-in-out; }
        #projects .project-container .img-container .project-categories span {
          text-transform: uppercase;
          letter-spacing: 1px;
          font-weight: 600;
          font-size: 12px;
          color: #fff; }
          #projects .project-container .img-container .project-categories span:not(:last-child):after {
            content: '-'; }
      #projects .project-container .img-container .blackfade {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 50%;
        background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0.55)));
        background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.55) 100%);
        background: -o-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.55) 100%);
        background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.55) 100%); }
      #projects .project-container .img-container .project-content {
        position: absolute;
        width: 100%;
        max-width: 480px;
        height: auto;
        left: 0;
        bottom: 0;
        padding: 0 40px 35px;
        color: #fff; }
        #projects .project-container .img-container .project-content .title-container {
          text-transform: uppercase;
          letter-spacing: 4px; }
          #projects .project-container .img-container .project-content .title-container .date {
            font-size: 13px;
            margin-bottom: 9px; }
          #projects .project-container .img-container .project-content .title-container .title {
            font-weight: 700;
            font-size: 30px; }
        #projects .project-container .img-container .project-content .desc-container {
          height: 0;
          overflow: hidden;
          -webkit-transition: all 0.2s ease-in-out;
          -o-transition: all 0.2s ease-in-out;
          transition: all 0.2s ease-in-out; }
          #projects .project-container .img-container .project-content .desc-container .separator {
            margin-top: 16px;
            height: 1px;
            width: 30px;
            background-color: #fff;
            margin-bottom: 7px; }
          #projects .project-container .img-container .project-content .desc-container p {
            display: block;
            line-height: 1.2;
            font-weight: 400;
            font-size: 15px;
            -o-text-overflow: ellipsis;
            text-overflow: ellipsis; }
  #projects #map {
    width: 100%;
    height: 500px; }
    #projects #map .gm-style-iw {
      padding: 15px 0; }
      #projects #map .gm-style-iw img {
        max-width: 100%; }
      #projects #map .gm-style-iw .date {
        font-size: 10px;
        letter-spacing: 1px;
        text-transform: uppercase; }
      #projects #map .gm-style-iw .title {
        font-weight: 700;
        font-size: 16px;
        text-transform: uppercase;
        margin-bottom: 7px;
        line-height: 1; }
      #projects #map .gm-style-iw p {
        line-height: 1.4;
        margin-bottom: 10px; }
      #projects #map .gm-style-iw a {
        color: #000;
        font-size: 16px;
        letter-spacing: 1px; }
        #projects #map .gm-style-iw a i {
          font-size: 17px;
          margin-left: 5px;
          position: relative;
          top: 4px; }

.header-project {
  margin-top: 135px; }
  .header-project .title-container {
    text-transform: uppercase;
    color: #222831;
    letter-spacing: 4px; }
    .header-project .title-container .date {
      font-size: 16px;
      margin-bottom: 9px; }
    .header-project .title-container .title {
      font-weight: 600;
      font-size: 38px;
      letter-spacing: 2px; }
    .header-project .title-container .categories-list {
      margin-top: 15px; }
      .header-project .title-container .categories-list span {
        text-transform: uppercase;
        letter-spacing: 1px;
        font-weight: 600;
        font-size: 16px; }
        .header-project .title-container .categories-list span:not(:last-child):after {
          content: '-'; }
  .header-project .projects-nav a {
    font-size: 16px;
    color: #222831;
    font-weight: 500;
    letter-spacing: 1px; }
    .header-project .projects-nav a.icon {
      position: relative; }
      .header-project .projects-nav a.icon .img-container {
        width: 20px;
        height: 20px;
        margin: 0 10px; }
  .header-project .projects-nav i {
    position: relative;
    font-size: 25px;
    top: 5px;
    margin-right: 7px; }

.slider-project-container {
  margin-top: 22px;
  position: relative; }
  .slider-project-container #slider-project {
    position: relative; }
  .slider-project-container .img-container {
    height: 0;
    padding-top: 52%; }
  .slider-project-container .arrows {
    position: absolute;
    bottom: 0;
    right: 0; }
    .slider-project-container .arrows .slick-arrow {
      background-color: rgba(255, 255, 255, 0.8);
      height: 60px;
      width: 60px;
      display: inline-block !important;
      -webkit-transition: all 0.2s ease-in-out;
      -o-transition: all 0.2s ease-in-out;
      transition: all 0.2s ease-in-out;
      background-size: 20px;
      background-position: center;
      background-repeat: no-repeat; }
      .slider-project-container .arrows .slick-arrow.slick-prev {
        background-image: url(/img/left_arrow.png); }
      .slider-project-container .arrows .slick-arrow.slick-next {
        background-image: url(/img/right_arrow.png); }
      .slider-project-container .arrows .slick-arrow:hover {
        cursor: pointer;
        background-size: 23px;
        -webkit-transition: background-size 0.2s ease-in-out;
        -o-transition: background-size 0.2s ease-in-out;
        transition: background-size 0.2s ease-in-out; }

.project-content {
  margin-top: 30px; }
  .project-content .copyright {
    font-size: 13px;
    font-style: italic;
    padding-top: 5px; }
  .project-content .about-title {
    font-size: 21px;
    font-weight: 600;
    text-transform: uppercase;
    margin-bottom: 16px; }
  .project-content .desc p {
    line-height: 1.2;
    font-size: 15px;
    margin-bottom: 14px; }
  .project-content .button {
    margin-top: 20px;
    background-color: #222831;
    color: #fff;
    padding: 17px 12px 20px 39px;
    letter-spacing: 1px;
    font-size: 18px;
    border: none;
    position: relative; }
    .project-content .button:hover {
      cursor: pointer; }
    .project-content .button i {
      position: absolute;
      top: 11px;
      left: 11px;
      font-size: 23px; }
  .project-content .details-container {
    margin-top: 30px;
    position: relative; }
  .project-content .list-detail {
    max-width: 500px;
    margin-left: auto; }
    .project-content .list-detail:before {
      content: '';
      position: absolute;
      height: 1px;
      background-color: #222831;
      width: calc(100% - 520px);
      left: 0;
      top: 10px; }
    .project-content .list-detail p {
      margin-bottom: 20px;
      line-height: 1.2; }
      .project-content .list-detail p .title {
        text-transform: uppercase;
        letter-spacing: 1px;
        font-weight: 600; }
      .project-content .list-detail p a {
        color: #222831;
        text-decoration: initial; }
        .project-content .list-detail p a:hover {
          text-decoration: underline; }
  .project-content .map-container p {
    margin-bottom: 20px;
    line-height: 1.2; }
    .project-content .map-container p .title {
      text-transform: uppercase;
      letter-spacing: 1px;
      font-weight: 600; }
  .project-content .map-container #map {
    margin-top: 35px;
    height: 300px;
    margin-bottom: 20px; }

.captions-nav-container {
  position: relative; }
  .captions-nav-container #captions-nav {
    margin: 0 -15px;
    position: relative; }
    .captions-nav-container #captions-nav .slick-current .img-container {
      -webkit-filter: grayscale(0%);
      filter: grayscale(0%);
      -webkit-transition: all 0.2s ease-in-out;
      -o-transition: all 0.2s ease-in-out;
      transition: all 0.2s ease-in-out; }
    .captions-nav-container #captions-nav .img-container {
      height: 0;
      padding-top: 77%;
      -webkit-filter: grayscale(100%);
      filter: grayscale(100%);
      -webkit-transition: all 0.2s ease-in-out;
      -o-transition: all 0.2s ease-in-out;
      transition: all 0.2s ease-in-out; }
      .captions-nav-container #captions-nav .img-container:hover {
        cursor: pointer; }
    .captions-nav-container #captions-nav .caption-container {
      padding: 0 15px; }
  .captions-nav-container .captions-arrows {
    width: 100%;
    height: 100%;
    top: 0;
    left: 0; }
    .captions-nav-container .captions-arrows .slick-arrow {
      position: absolute;
      width: 28px;
      height: 100%;
      top: 0;
      background: rgba(255, 255, 255, 0.8);
      text-align: center;
      font-size: 19px;
      line-height: 7.3; }
      .captions-nav-container .captions-arrows .slick-arrow:hover {
        cursor: pointer; }
      .captions-nav-container .captions-arrows .slick-arrow.slick-next {
        right: -2px; }

#agency-container {
  margin-top: 60px; }
  #agency-container .agency-anchors .anchor a {
    color: #000;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    font-weight: 200;
    text-decoration: none;
    position: relative; }
    #agency-container .agency-anchors .anchor a.active:after, #agency-container .agency-anchors .anchor a:hover:after, #agency-container .agency-anchors .anchor a:focus:after {
      content: '';
      position: absolute;
      bottom: -10px;
      left: 0;
      width: 100%;
      height: 2px;
      background-color: #222831;
      -webkit-transition: all .3s ease-in-out;
      -o-transition: all .3s ease-in-out;
      transition: all .3s ease-in-out; }
    #agency-container .agency-anchors .anchor a.active {
      font-weight: 700; }
  #agency-container .title-agency {
    font-weight: 700;
    font-size: 35px;
    letter-spacing: 3px; }
  #agency-container .details-container {
    margin-top: 30px;
    position: relative; }
  #agency-container .list-detail {
    max-width: 500px;
    margin-left: auto; }
    #agency-container .list-detail:before {
      content: '';
      position: absolute;
      height: 1px;
      background-color: #222831;
      width: calc(100% - 520px);
      left: 0;
      top: 10px; }
    #agency-container .list-detail p {
      margin-bottom: 20px;
      line-height: 1.2; }
      #agency-container .list-detail p .title {
        text-transform: uppercase;
        letter-spacing: 1px;
        font-weight: 600; }
  #agency-container .expertise-card {
    margin-bottom: 30px; }
    #agency-container .expertise-card:first-child .card-container {
      background-color: #222831;
      color: #fff;
      padding: 50px 0; }
      #agency-container .expertise-card:first-child .card-container .title-agency {
        margin-bottom: 30px; }
      #agency-container .expertise-card:first-child .card-container .card-content {
        max-width: 310px;
        padding: 0 15px;
        margin: 0 auto; }
      #agency-container .expertise-card:first-child .card-container ul {
        list-style: none; }
      #agency-container .expertise-card:first-child .card-container li {
        font-weight: 500;
        margin-bottom: 10px;
        font-size: 14px;
        line-height: 1.3; }
        #agency-container .expertise-card:first-child .card-container li:before {
          content: '–';
          display: inline-block;
          padding-right: 15px; }
        #agency-container .expertise-card:first-child .card-container li span {
          display: inline-block;
          max-width: 250px;
          vertical-align: top; }
    #agency-container .expertise-card:not(:first-child) p {
      color: #222831;
      font-size: 31px;
      font-weight: 700; }
    #agency-container .expertise-card:not(:first-child) .card-container {
      height: 450px;
      position: relative; }
      #agency-container .expertise-card:not(:first-child) .card-container .card-content {
        position: absolute;
        left: 0;
        bottom: 0;
        color: #222831;
        max-width: 350px;
        width: 100%;
        background-color: rgba(255, 255, 255, 0.95);
        overflow: hidden; }
        #agency-container .expertise-card:not(:first-child) .card-container .card-content:hover {
          cursor: pointer; }
        #agency-container .expertise-card:not(:first-child) .card-container .card-content .card-title {
          position: relative;
          line-height: 1.1;
          font-size: 20px;
          font-weight: 700;
          max-width: 290px;
          margin: 0 auto;
          padding: 20px 0; }
          #agency-container .expertise-card:not(:first-child) .card-container .card-content .card-title:after {
            content: '+';
            position: absolute;
            right: 0;
            font-weight: 400;
            font-size: 32px;
            line-height: 0.9; }
        #agency-container .expertise-card:not(:first-child) .card-container .card-content.open .card-title:after {
          content: '–'; }
        #agency-container .expertise-card:not(:first-child) .card-container .card-content.open .card-list {
          max-height: 320px;
          -webkit-transition: max-height 0.3s ease-out;
          -o-transition: max-height 0.3s ease-out;
          transition: max-height 0.3s ease-out;
          padding-bottom: 15px; }
        #agency-container .expertise-card:not(:first-child) .card-container .card-content .card-list {
          max-width: 290px;
          margin: 0 auto;
          max-height: 0;
          -webkit-transition: max-height 0.3s ease-out;
          -o-transition: max-height 0.3s ease-out;
          transition: max-height 0.3s ease-out;
          overflow: hidden; }
          #agency-container .expertise-card:not(:first-child) .card-container .card-content .card-list ul {
            list-style: none inside;
            padding-bottom: 15px; }
          #agency-container .expertise-card:not(:first-child) .card-container .card-content .card-list li {
            font-weight: 300;
            margin-bottom: 10px;
            font-size: 14px;
            line-height: 1.2; }
            #agency-container .expertise-card:not(:first-child) .card-container .card-content .card-list li:before {
              content: '–';
              display: inline-block;
              padding-right: 15px; }
            #agency-container .expertise-card:not(:first-child) .card-container .card-content .card-list li span {
              display: inline-block;
              max-width: 250px;
              vertical-align: top; }

.agency-numbers {
  position: relative;
  width: 100vw;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  color: #fff;
  font-weight: 700;
  padding: 130px 0; }
  .agency-numbers .overlay {
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6); }
  .agency-numbers .number-container {
    z-index: 2; }
    .agency-numbers .number-container .number {
      font-size: 40px;
      margin-right: 15px;
      min-width: 100px; }
    .agency-numbers .number-container sup {
      font-size: 12px; }

#expertises {
  padding: 70px 0 0; }

#philosophie {
  padding: 70px 0; }
  #philosophie .img-container {
    max-width: 535px; }

#bureaux {
  position: relative;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 100vw; }
  #bureaux .title-agency {
    margin-bottom: 30px; }
  #bureaux #map {
    height: 300px; }

#histoire {
  padding: 70px 0; }
  #histoire .details-container {
    max-width: 520px; }
    #histoire .details-container .list-detail {
      max-width: 425px; }
      #histoire .details-container .list-detail:before {
        width: calc(100% - 445px); }

#equipe {
  padding: 70px 0; }
  #equipe .member {
    position: relative;
    height: 0;
    padding-top: 133%;
    margin-top: 30px; }
    #equipe .member .member-info {
      position: absolute;
      top: 0;
      left: 0;
      opacity: 0;
      width: 100%;
      height: 100%;
      background-color: rgba(34, 40, 49, 0.63);
      -webkit-transition: opacity 0.3s ease-out;
      -o-transition: opacity 0.3s ease-out;
      transition: opacity 0.3s ease-out;
      padding: 15px; }
      #equipe .member .member-info:hover {
        -webkit-transition: opacity 0.3s ease-out;
        -o-transition: opacity 0.3s ease-out;
        transition: opacity 0.3s ease-out;
        opacity: 1; }
      #equipe .member .member-info .member-info-container {
        position: relative;
        color: #fff;
        line-height: 1.4;
        font-size: 0.9em;
        font-weight: 300;
        letter-spacing: 2px; }
        #equipe .member .member-info .member-info-container:before {
          content: '';
          position: absolute;
          top: -20px;
          left: 0;
          width: 10px;
          height: 1px;
          background-color: #fff; }
  #equipe p {
    color: #222831;
    font-size: 26px;
    font-weight: 700;
    line-height: 1.3; }
  #equipe .title-agency:after {
    content: '';
    display: block;
    position: relative;
    top: 50px;
    width: 80px;
    height: 1px;
    background-color: #222831; }

#certifications {
  padding: 70px 0 110px; }
  #certifications .img-container {
    margin-left: auto;
    max-width: 400px; }
  #certifications .list-detail {
    max-width: 590px; }
    #certifications .list-detail .bold {
      font-weight: 700; }
    #certifications .list-detail:before {
      width: calc(100% - 620px); }
  #certifications .button {
    margin-top: 20px;
    background-color: #222831;
    color: #fff;
    padding: 17px 12px 20px 39px;
    letter-spacing: 1px;
    font-size: 18px;
    border: none;
    position: relative; }
    #certifications .button:hover {
      cursor: pointer; }
    #certifications .button i {
      position: absolute;
      top: 11px;
      left: 11px;
      font-size: 23px; }

#news-container {
  margin-top: 135px; }
  #news-container > .row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start; }
  #news-container .title {
    font-weight: 600;
    font-size: 35px;
    line-height: 1.1;
    max-width: 400px;
    letter-spacing: 1px;
    margin-left: 25px;
    margin-bottom: 40px; }

.post-container {
  position: relative;
  margin-bottom: 50px;
  padding: 0 25px; }
  .post-container .date {
    position: absolute;
    top: 76px;
    left: 15px;
    -webkit-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    transform: rotate(-90deg);
    -webkit-transform-origin: left bottom;
    -ms-transform-origin: left bottom;
    transform-origin: left bottom;
    letter-spacing: 2px; }
  .post-container .img-container {
    height: 0;
    padding-top: 82%; }
  .post-container .post-title {
    margin-top: 40px;
    text-transform: uppercase;
    font-weight: 600;
    line-height: 1.1;
    font-size: 20px;
    max-width: 300px; }
  .post-container .post-content {
    margin-top: 20px;
    line-height: 1.3;
    max-width: 556px; }
    .post-container .post-content p {
      display: inline; }
    .post-container .post-content .morecontent span {
      display: none; }
    .post-container .post-content .morelink {
      color: #222831;
      text-decoration: underline; }
      .post-container .post-content .morelink:hover {
        cursor: pointer; }
  .post-container .button-more {
    display: inline-block;
    margin-top: 25px;
    background-color: #222831;
    color: #fff;
    text-decoration: underline;
    padding: 11px 23px;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 1px;
    font-size: 14px; }
    .post-container .button-more:hover {
      text-decoration: none; }

#connexion, #contact-container {
  margin-top: 128px; }

#contact-container .map-container {
  width: 100%;
  margin-left: -15px; }
  #contact-container .map-container #map {
    height: 535px;
    position: relative; }
    #contact-container .map-container #map:after {
      content: '';
      display: block;
      position: absolute;
      right: 0;
      top: 0;
      height: 100%;
      background: -webkit-gradient(linear, right top, left top, from(white), to(rgba(255, 255, 255, 0)));
      background: -webkit-linear-gradient(right, white 0%, rgba(255, 255, 255, 0) 100%);
      background: -o-linear-gradient(right, white 0%, rgba(255, 255, 255, 0) 100%);
      background: linear-gradient(to left, white 0%, rgba(255, 255, 255, 0) 100%);
      width: 440px; }

#contact-container .contact-infos {
  margin-top: 30px; }
  #contact-container .contact-infos .address {
    line-height: 1.5;
    margin-right: 40px; }
    #contact-container .contact-infos .address span {
      font-weight: 600; }
  #contact-container .contact-infos .social {
    line-height: 1.5; }
    #contact-container .contact-infos .social span {
      position: relative;
      top: -8px; }
      #contact-container .contact-infos .social span img {
        display: inline-block;
        width: 27px;
        position: relative;
        top: 10px; }

#contact-container .title {
  font-weight: 600;
  font-size: 35px;
  line-height: 1.1;
  max-width: 400px;
  letter-spacing: 1px;
  margin-top: 50px;
  margin-bottom: 40px; }

#contact-container .form-container {
  max-width: 550px;
  margin-bottom: 30px; }
  #contact-container .form-container label {
    margin-bottom: 10px; }
  #contact-container .form-container .form-control {
    border-radius: 0;
    border-color: #222831;
    background-color: transparent;
    padding: 0.775rem .75rem; }
  #contact-container .form-container .button-submit {
    background-color: #222831;
    color: #fff;
    padding: 15px 57px;
    font-weight: 400;
    letter-spacing: 0px;
    font-size: 15px;
    border: none;
    margin-top: 25px; }
    #contact-container .form-container .button-submit:hover {
      text-decoration: none;
      cursor: pointer; }

#mentions-legales p, #mentions-legales h3, #mentions-legales h4, #mentions-legales b {
  color: #222831;
  line-height: 1.2; }

#mentions-legales h3 {
  font-size: 22px;
  font-weight: 700; }

#mentions-legales h4 {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 10px; }

#mentions-legales b {
  font-weight: 700; }

#mentions-legales p {
  margin-bottom: 20px; }

@media screen and (max-width: 575px) {
  #menu #toggle-menu {
    right: 20px; }
  #brand-home {
    z-index: 4;
    max-width: 575px; }
    #brand-home .brand-container {
      top: calc(50% + 100px); }
    #brand-home .button-enter {
      background-color: #222831;
      color: #fff;
      padding: 10px 23px; }
  #home-projects {
    z-index: 3; }
  #home-news {
    position: fixed;
    right: -240px;
    bottom: 60px;
    top: 67px;
    max-width: 240px;
    height: calc(100vh - 176px);
    background-color: #fff;
    padding: 20px 25px 0;
    -webkit-transition: right 0.4s ease;
    -o-transition: right 0.4s ease;
    transition: right 0.4s ease; }
    #home-news.open .display-button {
      width: 240px;
      -webkit-transition: width 0.4s ease;
      -o-transition: width 0.4s ease;
      transition: width 0.4s ease; }
    #home-news .display-button {
      position: fixed;
      width: 100px;
      height: 42px;
      top: unset;
      bottom: 67px;
      right: 0;
      background-color: #222831;
      color: #fff;
      text-align: center;
      padding: 14px 5px;
      -webkit-transition: width 0.4s ease;
      -o-transition: width 0.4s ease;
      transition: width 0.4s ease; }
      #home-news .display-button .icon-container:after {
        position: relative;
        top: -2px;
        margin-right: 8px; }
      #home-news .display-button .title {
        font-weight: 400;
        text-transform: initial; }
    #home-news .news-container .title {
      font-size: 20px; }
    #home-news .news-container .content p {
      height: 55px;
      overflow: hidden; }
  .hidden {
    display: none !important; }
  .visuallyhidden {
    opacity: 0 !important; }
  #projects {
    margin-top: 62px;
    margin-bottom: 70px; }
    #projects .projects-container .project-container {
      padding: 5px 0;
      margin: 0 -15px;
      width: calc(100% + 30px); }
      #projects .projects-container .project-container .img-container .project-content {
        padding: 20px;
        background-color: #fff;
        color: #222831;
        opacity: 0;
        width: calc(100% - 30px);
        left: 15px;
        bottom: 15px;
        -webkit-transition: opacity 0.2s ease-in-out;
        -o-transition: opacity 0.2s ease-in-out;
        transition: opacity 0.2s ease-in-out; }
        #projects .projects-container .project-container .img-container .project-content .title-container .title {
          font-size: 22px; }
        #projects .projects-container .project-container .img-container .project-content .desc-container {
          height: 80px; }
          #projects .projects-container .project-container .img-container .project-content .desc-container .separator {
            background-color: #222831; }
      #projects .projects-container .project-container.view .img-container .project-content {
        opacity: 1;
        -webkit-transition: opacity 0.2s ease-in-out;
        -o-transition: opacity 0.2s ease-in-out;
        transition: opacity 0.2s ease-in-out; }
  #filters {
    top: unset;
    bottom: 67px;
    right: 0;
    width: 170px;
    padding: 0;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out; }
    #filters.open {
      width: 270px; }
      #filters.open .filters-title {
        width: 100%; }
        #filters.open .filters-title:before {
          content: '-'; }
      #filters.open .filter-list {
        right: 0;
        -webkit-transition: right 0.2s ease-in-out 0.1s;
        -o-transition: right 0.2s ease-in-out 0.1s;
        transition: right 0.2s ease-in-out 0.1s; }
    #filters .container {
      padding: 0; }
    #filters .filters-title {
      font-size: 14px;
      background-color: #222831;
      color: #fff;
      font-weight: 400;
      text-align: center;
      padding: 15px; }
      #filters .filters-title:before {
        content: '+';
        display: inline; }
      #filters .filters-title:hover {
        cursor: pointer; }
    #filters .filter-list {
      position: absolute;
      bottom: 44px;
      right: -300px;
      width: 100%;
      height: calc(100vh - 176px);
      text-align: left;
      padding-left: 20%;
      background-color: #fff;
      -webkit-transition: right 0.2s ease-in-out 0s;
      -o-transition: right 0.2s ease-in-out 0s;
      transition: right 0.2s ease-in-out 0s; }
      #filters .filter-list .filter {
        margin-bottom: 12px; }
        #filters .filter-list .filter:after {
          content: none; }
      #filters .filter-list .filter-map {
        text-align: left;
        -webkit-box-flex: initial;
        -ms-flex-positive: initial;
        flex-grow: initial; }
  #philosophie {
    padding: 30px 0; }
  #bureaux #map {
    height: 300px;
    margin-bottom: 66px; }
  #certifications .title-agency {
    text-align: center; }
  .header-project {
    margin-top: 15px; }
    .header-project .title-container .title {
      font-size: 28px; }
    .header-project .mobile-separator {
      width: 60px;
      height: 1px;
      background: #222831;
      margin-top: 30px; }
  .slider-project-container {
    margin-top: 67px;
    margin-left: -15px;
    margin-right: -15px; }
    .slider-project-container .slide-project .img-container {
      padding-top: 60%; }
    .slider-project-container .arrows {
      width: 100%;
      padding: 15px; }
      .slider-project-container .arrows .img-container {
        padding-top: 0;
        width: 50px;
        height: 50px; }
      .slider-project-container .arrows .slick-next {
        float: right; }
  .project-content.order-3 {
    margin-bottom: 60px; }
  #news-container {
    margin-top: 95px;
    margin-bottom: 45px; }
  #contact-container {
    margin-top: 50px;
    margin-bottom: 70px;
    padding: 0 30px; }
    #contact-container .map-container {
      width: 100%;
      margin-left: 0; }
      #contact-container .map-container #map {
        height: 385px; }
        #contact-container .map-container #map:after {
          content: none; }
    #contact-container .contact-infos .address {
      margin-right: 15px; }
  footer {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    background-color: #fff;
    padding: 15px 10px 15px 20px;
    border-top: 1px solid #e3e3e3;
    margin: 0;
    font-size: 10px;
    line-height: 1.2; }
    footer .img-container {
      width: 33px;
      margin-left: auto;
      margin-right: 20px; } }
