/*
  Theme Name : Rives
  Author     : Indigen
*/
._bg-cover {
  background: url("") no-repeat center;
  background-size: cover; }

._bg-contain {
  background: url("") no-repeat center;
  background-size: contain; }

._bg-fit {
  background: url("") no-repeat center;
  background-size: 100% 100%; }

._bg-fit-width {
  background: url("") no-repeat center;
  background-size: 100% auto; }

._bg-fit-height {
  background: url("") no-repeat center;
  background-size: auto 100%; }

._clearfix:after, .clearfix:after {
  content: '\0020';
  display: block;
  overflow: hidden;
  visibility: hidden;
  width: 0;
  height: 0;
  clear: both; }

._trans {
  -webkit-transition: background cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s, opacity cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s, color cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s, border cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s;
  transition: background cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s, opacity cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s, color cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s, border cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden; }

._trans3d {
  -webkit-transition: opacity cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s, -webkit-transform cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s;
  transition: opacity cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s, -webkit-transform cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s;
  transition: transform cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s, opacity cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s;
  transition: transform cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s, opacity cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s, -webkit-transform cubic-bezier(0.645, 0.045, 0.355, 1) 0.3s;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden; }

._pos-center {
  position: absolute;
  left: 50%;
  top: 50%;
  margin-top: -0.5em;
  margin-left: -0.5em; }

._pos-cover {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%; }

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;
  vertical-align: baseline; }

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

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

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

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

template {
  display: none; }

a:active, input:active, button:active {
  -webkit-tap-highlight-color: transparent; }

a {
  color: inherit;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
  cursor: pointer; }

input, textarea {
  outline: none; }

textarea {
  resize: none; }

h1, h2, h3, h4, h5, h6 {
  font-size: 1em;
  font-weight: normal; }

.valign {
  display: table;
  height: 100%; }
  .valign.full-width {
    width: 100%; }
  .valign__middle, .valign__bottom {
    display: table-cell;
    height: 100%;
    width: 100%; }
  .valign__middle {
    vertical-align: middle; }
  .valign__bottom {
    vertical-align: bottom; }

html.ie7 body {
  background: url("../images/misc/not-supported.jpg") no-repeat center #f4f4f4 !important; }
  html.ie7 body > * {
    display: none !important;
    visibility: hidden !important; }

html.ie8 body {
  background: url("../images/misc/not-supported.jpg") no-repeat center #f4f4f4 !important; }
  html.ie8 body > * {
    display: none !important;
    visibility: hidden !important; }

html.safari4 body {
  background: url("../images/misc/not-supported.jpg") no-repeat center #f4f4f4 !important; }
  html.safari4 body > * {
    display: none !important;
    visibility: hidden !important; }

.mobile-out {
  display: block; }

.desktop-out {
  display: none; }

@media screen and (max-width: 768px) {
  .mobile-out {
    display: none !important; }
  .desktop-out {
    display: block; } }

.multiply {
  background-blend-mode: multiply; }

.screen {
  background-blend-mode: screen; }

.overlay {
  background-blend-mode: overlay; }

.darken {
  background-blend-mode: darken; }

.lighten {
  background-blend-mode: lighten; }

.color-dodge {
  background-blend-mode: color-dodge; }

.color-burn {
  background-blend-mode: color-burn; }

.hue {
  background-blend-mode: hue; }

.difference {
  background-blend-mode: difference; }

.soft-light {
  background-blend-mode: soft-light; }

.hard-light {
  background-blend-mode: hard-light; }

.exclusion {
  background-blend-mode: exclusion; }

.color {
  background-blend-mode: color; }

.luminosity {
  background-blend-mode: luminosity; }

.saturation {
  background-blend-mode: saturation; }

.btn--line {
  color: #000;
  border: 1px solid black;
  display: block;
  padding: 1.5rem 1rem;
  position: relative;
  font-weight: normal;
  text-align: center;
  cursor: pointer;
  text-transform: uppercase;
  font-size: 1.2rem; }
  .btn--line:before, .btn--line:after, .btn--line span:after, .btn--line span:before {
    content: "";
    background: rgba(255, 255, 255, 0.5);
    position: absolute;
    -webkit-transition: all 0.5s cubic-bezier(0, 0, 0.43, 1.05);
    transition: all 0.5s cubic-bezier(0, 0, 0.43, 1.05); }
  .btn--line:before {
    width: 0;
    height: 1px;
    top: -1px;
    left: 0; }
  .btn--line:after {
    width: 1px;
    right: -1px;
    height: 0;
    top: 0; }
  .btn--line span:before {
    width: 0;
    bottom: -1px;
    height: 1px;
    right: 0; }
  .btn--line span:after {
    width: 1px;
    left: -1px;
    height: 0;
    bottom: 0; }
  .btn--line:hover:before, .btn--line:hover span:before {
    width: 100%; }
  .btn--line:hover:after, .btn--line:hover span:after {
    height: 100%; }

.animation-1, .homepage__visual, .collab, .sur-mesure, .boutique {
  visibility: hidden; }
  .loaded .animation-1, .loaded .homepage__visual, .loaded .collab, .loaded .sur-mesure, .loaded .boutique {
    visibility: visible;
    -webkit-animation: slideIn 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
            animation: slideIn 0.3s cubic-bezier(0.215, 0.61, 0.355, 1); }
    @media screen and (max-width: 768px) {
      .loaded .animation-1, .loaded .homepage__visual, .loaded .collab, .loaded .sur-mesure, .loaded .boutique {
        -webkit-animation: none;
                animation: none; } }

.animation-2, .contacts {
  visibility: hidden; }
  .loaded .animation-2, .loaded .contacts {
    visibility: visible;
    -webkit-animation: fadeIn 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
            animation: fadeIn 0.3s cubic-bezier(0.215, 0.61, 0.355, 1); }

@-webkit-keyframes popin {
  from {
    opacity: 0; }
  to {
    opacity: 0.5; } }

@keyframes popin {
  from {
    opacity: 0; }
  to {
    opacity: 0.5; } }

@-webkit-keyframes loading {
  from {
    width: 0; }
  to {
    width: 100%; } }

@keyframes loading {
  from {
    width: 0; }
  to {
    width: 100%; } }

@-webkit-keyframes fadeIn {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }

@keyframes fadeIn {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }

@-webkit-keyframes fadeOut {
  from {
    opacity: 1; }
  to {
    opacity: 0; } }

@keyframes fadeOut {
  from {
    opacity: 1; }
  to {
    opacity: 0; } }

@-webkit-keyframes slideIn {
  from {
    opacity: 0;
    -webkit-transform: translateY(5rem);
            transform: translateY(5rem); }
  to {
    opacity: 1;
    -webkit-transform: none;
            transform: none; } }

@keyframes slideIn {
  from {
    opacity: 0;
    -webkit-transform: translateY(5rem);
            transform: translateY(5rem); }
  to {
    opacity: 1;
    -webkit-transform: none;
            transform: none; } }

@-webkit-keyframes slideOut {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translateY(5rem);
            transform: translateY(5rem); } }

@keyframes slideOut {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translateY(5rem);
            transform: translateY(5rem); } }

html {
  font-size: 9px;
  font-family: 'Lato', sans-serif;
  /*font-family: 'HelveticaNeue', sans-serif;*/
  height: 100%;
  overflow: hidden; }
  html.page-journal {
    overflow: auto; }
  html.page-contacts {
    overflow: auto; }
  html.menu-mobile-open {
    overflow: hidden !important; }
  @media (max-width: 960px) {
    html {
      overflow: auto;
      min-width: 960px; } }
  @media (max-height: 500px) {
    html {
      overflow: auto;
      min-height: 500px; } }
  @media screen and (max-height: 700px) {
    html {
      font-size: 8px; } }
  @media screen and (max-width: 1024px) {
    html {
      font-size: 7px; } }
  @media screen and (max-width: 768px) {
    html {
      min-width: inherit;
      min-height: inherit;
      font-size: 8px; } }

p, a, h1, h2 {
  letter-spacing: 0.2em;
  line-height: 1.8em;
  font-size: 1.1rem; }

body {
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  width: 100%;
  height: 100%;
  margin: 0; }
  body:after {
    content: '';
    height: 5px;
    width: 0;
    background: black;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1000;
    visibility: hidden; }
  body.loading:after {
    -webkit-animation: loading 6s cubic-bezier(0.215, 0.61, 0.355, 1);
            animation: loading 6s cubic-bezier(0.215, 0.61, 0.355, 1);
    visibility: visible;
    width: 100%; }
  body.popin:before {
    content: '';
    width: 100%;
    height: 100%;
    position: fixed;
    background: black;
    z-index: 3;
    opacity: 0.3;
    -webkit-animation: popin 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
            animation: popin 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
    -webkit-animation-fill-mode: forwards;
            animation-fill-mode: forwards; }
  body * {
    -webkit-tap-highlight-color: transparent; }

.container {
  display: inline-block;
  width: 100%;
  height: 100%;
  padding-left: 19rem;
  box-sizing: border-box;
  position: relative; }
  @media screen and (max-width: 768px) {
    .container {
      padding-left: 0;
      margin-top: 60px;
      height: auto; }
      .popin-contact .container {
        height: 100vh;
        overflow: hidden; }
      .menu-mobile-open .container {
        height: 100vh;
        overflow: hidden;
        opacity: 0; } }

footer {
  position: absolute;
  width: 55rem;
  left: 30rem;
  bottom: 2.5rem;
  font-size: 1.1rem;
  line-height: 1.8em;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  text-align: justify; }
  html.page-collab footer,
  html.page-journal footer {
    display: none; }
  @media screen and (max-width: 768px) {
    footer {
      display: none; } }
  html.page-contacts footer {
    position: fixed; }

.page-404 {
  margin: 20rem; }

.menu {
  position: absolute;
  display: inline-block;
  width: 19rem;
  height: 100%;
  font-size: 1.1rem;
  text-transform: uppercase;
  text-align: right;
  z-index: 2; }
  .menu__button {
    display: none; }
  @media screen and (max-width: 768px) {
    .menu {
      position: absolute;
      width: 100%;
      text-align: center;
      background: white;
      height: 60px;
      overflow: hidden;
      -webkit-transition: height 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
      transition: height 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
      font-size: 1.2rem;
      z-index: 300;
      /*
    &.open-animated {
      position:absolute;
      min-height: 100%;
      height:auto;
    }
    */ }
      .menu .menu__button {
        position: absolute;
        display: block;
        padding-top: 22px;
        padding-left: 22px;
        padding-right: 20px;
        padding-bottom: 20px;
        top: 0;
        right: 0; }
        .menu .menu__button a {
          position: relative;
          margin-top: 6px;
          margin-bottom: 6px;
          -webkit-user-select: none;
          -moz-user-select: none;
          -ms-user-select: none;
          user-select: none; }
          .menu .menu__button a, .menu .menu__button a::before, .menu .menu__button a::after {
            display: block;
            width: 25px;
            height: 1px;
            background-color: #222;
            -webkit-transition-property: background-color, -webkit-transform;
            transition-property: background-color, -webkit-transform;
            transition-property: background-color, transform;
            transition-property: background-color, transform, -webkit-transform;
            -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s; }
          .menu .menu__button a::before, .menu .menu__button a::after {
            position: absolute;
            content: ""; }
          .menu .menu__button a::before {
            top: -6px; }
          .menu .menu__button a::after {
            top: 6px; }
      .menu.open {
        height: 100%;
        overflow: auto;
        -webkit-overflow-scrolling: touch; }
        .menu.open .menu__button a {
          background-color: transparent; }
        .menu.open .menu__button a::before {
          -webkit-transform: translateY(6px) rotate(45deg);
          transform: translateY(6px) rotate(45deg); }
        .menu.open .menu__button a::after {
          -webkit-transform: translateY(-6px) rotate(-45deg);
          transform: translateY(-6px) rotate(-45deg); }
        .menu.open .menu__logo {
          opacity: 0; } }
  .menu__logo {
    width: 16rem;
    margin-bottom: 1rem;
    margin-top: 0.8rem; }
    @media screen and (max-width: 768px) {
      .menu__logo {
        width: auto;
        height: 30px;
        margin-bottom: 20px;
        margin-top: 0; } }
  .menu--level1 > ul > li {
    margin-top: 2.2rem;
    margin-bottom: 2.2rem; }
    @media screen and (max-width: 768px) {
      .menu--level1 > ul > li {
        margin-top: 0;
        margin-bottom: 15px; }
        .menu--level1 > ul > li:first-child {
          margin-top: 15px;
          margin-bottom: 0; }
        .menu--level1 > ul > li.current-menu-parent > a {
          font-weight: bold; } }
    .menu--level1 > ul > li > a {
      -webkit-transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
      transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
      cursor: pointer; }
      .menu--level1 > ul > li > a:hover {
        opacity: 0.6; }
      @media screen and (max-width: 768px) {
        .menu--level1 > ul > li > a {
          font-size: 1.6rem; } }
    .menu--level1 > ul > li.active a {
      text-decoration: underline; }
  .menu--level2 {
    height: 0;
    overflow: hidden;
    -webkit-transition: all 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: all 0.3s cubic-bezier(0.215, 0.61, 0.355, 1); }
    .menu--level2 > ul > li > a {
      -webkit-transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
      transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1); }
      .menu--level2 > ul > li > a:hover {
        opacity: 0.6; }
      @media screen and (max-width: 768px) {
        .menu--level2 > ul > li > a {
          font-size: 1.4rem; } }
    .menu--level2 > ul > li.menu-open {
      margin-bottom: 0.5rem; }
    .menu--level2 > ul > li.current-menu-item a,
    .menu--level2 > ul > li.active a {
      text-decoration: underline; }
  .menu .current-menu-ancestor .menu--level2,
  .menu .menu-open .menu--level2 {
    height: auto;
    margin-top: 2rem; }
  .popin .menu .menu__button a {
    background-color: transparent; }
  .popin .menu .menu__button a::before {
    -webkit-transform: translateY(6px) rotate(45deg);
    transform: translateY(6px) rotate(45deg); }
  .popin .menu .menu__button a::after {
    -webkit-transform: translateY(-6px) rotate(-45deg);
    transform: translateY(-6px) rotate(-45deg); }
  .page-contacts .menu,
  .page-journal .menu {
    position: fixed; }
  .menu .menu-item-1182 a {
    letter-spacing: 0.15em; }
  .menu .lang.active {
    text-decoration: underline; }
  .menu__address {
    display: none;
    position: relative;
    font-size: 1.4rem;
    line-height: 2.5rem; }
    @media screen and (max-width: 768px) {
      .menu__address {
        display: block; } }
    .menu__address:before {
      display: block;
      content: '';
      height: 1px;
      width: 30%;
      background: black;
      margin: auto;
      margin-bottom: 2rem; }
    .menu__address a {
      font-size: 1.4rem !important; }

.detail.active > div {
  opacity: 1;
  -webkit-transform: none;
          transform: none; }

.detail > div {
  opacity: 0;
  -webkit-transform: translateY(10rem);
          transform: translateY(10rem);
  -webkit-transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  width: auto; }
  @media screen and (max-width: 768px) {
    .detail > div {
      width: auto !important;
      left: 0 !important;
      -webkit-transform: none;
              transform: none;
      -webkit-transition: none;
      transition: none; } }

.detail__visual {
  position: relative;
  height: 100%;
  font-size: 0;
  float: left; }
  @media screen and (max-width: 768px) {
    .detail__visual {
      width: 100% !important;
      height: auto;
      background: #FFF; } }
  .detail__visual > img {
    height: 100%;
    background: #999999; }
  .detail__visual.thumbs > img {
    height: 80%; }
    @media screen and (max-width: 768px) {
      .detail__visual.thumbs > img {
        height: auto;
        width: 100%; } }
  .detail__visual.thumbs .detail__visual__images {
    height: 20%;
    white-space: nowrap; }
    .detail__visual.thumbs .detail__visual__images a {
      letter-spacing: 0;
      font-size: 0; }
    .detail__visual.thumbs .detail__visual__images .thumb {
      display: inline-block;
      height: 99%;
      width: 0;
      overflow: hidden; }
      @media screen and (max-width: 768px) {
        .detail__visual.thumbs .detail__visual__images .thumb {
          background: white; } }
      .detail__visual.thumbs .detail__visual__images .thumb img {
        border-top: 0.4rem solid white;
        border-right: 0.4rem solid white;
        width: 100%;
        background: #999999;
        box-sizing: border-box; }
        @media screen and (max-width: 768px) {
          .detail__visual.thumbs .detail__visual__images .thumb img {
            box-sizing: content-box;
            width: calc(100% - 0.4rem); } }
    .detail__visual.thumbs .detail__visual__images a:last-child img {
      border-right: 0; }
      @media screen and (max-width: 768px) {
        .detail__visual.thumbs .detail__visual__images a:last-child img {
          border-right: 0.4rem solid #999999;
          position: relative;
          left: 1px; } }

.detail__content {
  position: relative;
  float: left;
  height: 100%;
  background: white;
  text-align: center;
  text-transform: uppercase;
  font-size: 1rem; }
  @media screen and (max-width: 768px) {
    .detail__content {
      width: 100% !important;
      height: 50vh;
      position: static; } }
  .detail__content h1 {
    padding-left: 3rem;
    padding-right: 3rem; }
  .detail__content h2 {
    padding-left: 3rem;
    padding-right: 3rem;
    box-sizing: border-box;
    padding-top: 5rem; }
  .detail__content .valign {
    height: calc(100% - 24rem);
    margin: auto;
    position: relative;
    width: 100%; }
  .detail__content p {
    position: absolute;
    padding-left: 3rem;
    padding-right: 3rem;
    box-sizing: border-box;
    width: 100%;
    bottom: 5rem; }
    .detail__content p .btn--line {
      padding: 1rem 1.5rem;
      display: inline-block; }
    @media screen and (max-width: 768px) {
      .detail__content p {
        position: static;
        bottom: 0; } }
  .detail__content__social {
    position: absolute;
    bottom: 0.7rem;
    right: 0.8rem; }
    @media screen and (max-width: 768px) {
      .detail__content__social {
        position: static;
        margin-right: 0rem;
        margin-top: 1.5rem; } }
    .detail__content__social a {
      width: 1.5rem;
      height: 1.5rem;
      background-repeat: no-repeat;
      background-size: contain;
      display: inline-block;
      margin: 0.8rem 0.3rem;
      opacity: 1;
      -webkit-transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
      transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1); }
      @media screen and (max-width: 768px) {
        .detail__content__social a {
          width: 2.5rem;
          height: 2.5rem;
          margin: 0.8rem 0.6rem; } }
      .detail__content__social a:hover {
        opacity: 1; }
      .detail__content__social a.facebook {
        background-image: url(../images/facebook.png); }
      .detail__content__social a.twitter {
        background-image: url(../images/twitter.png); }
      .detail__content__social a.pinterest {
        background-image: url(../images/pinterest.png); }

@media screen and (max-width: 768px) {
  .detail--look {
    display: none; } }

.detail .swiper-container {
  height: 100%; }

.detail .swiper-button-next {
  position: static;
  display: inline-block;
  background-image: url(../images/arrow-right-black.png);
  background-size: auto 40%;
  margin: 0;
  height: 3rem;
  width: 3rem;
  vertical-align: middle;
  margin-top: -0.3rem; }

.detail .swiper-button-prev {
  position: static;
  display: inline-block;
  background-image: url(../images/arrow-left-black.png);
  background-size: auto 40%;
  margin: 0;
  height: 3rem;
  width: 3rem;
  vertical-align: middle;
  margin-top: -0.3rem; }

.detail .swiper-button-disabled {
  display: none; }

.close {
  display: block;
  width: 1.2rem;
  height: 1.2rem;
  position: absolute;
  right: 1.2rem;
  top: 1.2rem;
  background: url(../images/close.png) no-repeat;
  background-size: contain; }
  @media screen and (max-width: 768px) {
    .close {
      display: none; } }

/*
.next {
  top:calc(50% - 1.8rem);
  width: 1.2rem;
  height: 1.2rem;
  position: absolute;
  background: url(../images/arrow.png) no-repeat;
  background-size: contain;
  right:1.2rem;
}
*/
.popin__transition {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 2000;
  display: table;
  -webkit-transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  -webkit-transform: translateY(10rem);
          transform: translateY(10rem); }
  @media screen and (max-width: 768px) {
    .popin__transition {
      top: 60px;
      height: calc(100% - 60px); } }
  .popin__transition__wrapper {
    display: table-cell;
    vertical-align: middle; }
    .popin__transition__wrapper__content {
      position: relative;
      width: 35rem;
      padding: 10rem;
      background: white;
      margin: auto;
      text-transform: uppercase;
      text-align: center; }
      @media screen and (max-width: 768px) {
        .popin__transition__wrapper__content {
          width: 100%;
          padding: 3rem;
          box-sizing: border-box; } }
  .popin .popin__transition {
    opacity: 1;
    -webkit-transform: none;
            transform: none; }

.popin_newsletter,
.popin_contact {
  display: none;
  position: absolute;
  background: #FFF;
  top: 4rem;
  left: calc(50% - 29rem);
  width: 58rem;
  z-index: 2000; }
  @media (max-height: 600px) {
    .popin_newsletter,
    .popin_contact {
      top: 0 !important; } }
  @media screen and (max-width: 768px) {
    .popin_newsletter,
    .popin_contact {
      top: 60px !important;
      left: 0;
      width: 100%;
      z-index: 300; } }
  .popin_newsletter .screen-reader-response,
  .popin_contact .screen-reader-response {
    display: none; }
  .popin_newsletter > br,
  .popin_contact > br {
    display: none; }
  .popin_newsletter .wpcf7 > br,
  .popin_contact .wpcf7 > br {
    display: none; }
  .popin_newsletter .wpcf7-form,
  .popin_contact .wpcf7-form {
    margin: 3.5rem 4rem 4rem 4rem; }
    .popin_newsletter .wpcf7-form br,
    .popin_contact .wpcf7-form br {
      display: none; }
    .popin_newsletter .wpcf7-form p,
    .popin_contact .wpcf7-form p {
      margin-bottom: 1.2rem; }
  .popin_newsletter .wpcf7-validation-errors,
  .popin_newsletter .wpcf7-not-valid-tip,
  .popin_contact .wpcf7-validation-errors,
  .popin_contact .wpcf7-not-valid-tip {
    text-align: right;
    display: block;
    color: #ff0001; }
  .popin_newsletter .wpcf7-mail-sent-ok,
  .popin_contact .wpcf7-mail-sent-ok {
    font-size: 1.1rem;
    font-weight: bold;
    text-transform: uppercase;
    text-align: center;
    padding-right: 0.7rem;
    padding: 5rem;
    line-height: 1.8em;
    letter-spacing: 0.2em; }

.contact-form__head {
  text-align: justify;
  margin-bottom: 2rem; }

.contact-form__line {
  margin-bottom: 2rem;
  margin-left: 0;
  letter-spacing: 0.2em; }
  @media screen and (max-width: 768px) {
    .contact-form__line {
      margin-bottom: 4rem; } }
  .contact-form__line label {
    padding-right: 1rem;
    width: 14rem;
    display: inline-block;
    vertical-align: top;
    font-size: 1.1rem;
    text-transform: uppercase;
    position: relative;
    top: 0.2rem; }
    @media screen and (max-width: 768px) {
      .contact-form__line label {
        font-size: 1.4rem;
        width: auto;
        margin-bottom: 1rem; } }
  .contact-form__line .wpcf7-text {
    width: 34rem;
    border: 0 solid black;
    border-bottom: 1px solid black;
    font-size: 1.1rem; }
    @media screen and (max-width: 768px) {
      .contact-form__line .wpcf7-text {
        width: 100%;
        font-size: 3rem; } }
  .contact-form__line .wpcf7-textarea,
  .contact-form__line .wpcf7-select {
    width: 34rem;
    border: 1px solid black;
    font-size: 1.1rem; }
    @media screen and (max-width: 768px) {
      .contact-form__line .wpcf7-textarea,
      .contact-form__line .wpcf7-select {
        width: 100%;
        font-size: 1.4rem; } }
  .contact-form__line .wpcf7-textarea {
    width: 33.5rem;
    height: 8rem; }
    @media screen and (max-width: 768px) {
      .contact-form__line .wpcf7-textarea {
        width: 100%;
        font-size: 1.4rem; } }
  .contact-form__line .civility {
    position: absolute; }
  .contact-form__line .civility .wpcf7-select {
    width: auto; }
  .contact-form__line .wpcf7-submit {
    text-transform: uppercase;
    font-size: 1.1rem;
    width: 14rem;
    color: #000;
    border-radius: 0;
    border: 1px solid #000;
    background: none;
    padding-top: 1rem;
    padding-bottom: 1rem;
    display: block;
    margin-left: auto;
    margin-right: 0.8rem;
    letter-spacing: 0.2em; }
    .contact-form__line .wpcf7-submit:hover {
      background: #000;
      color: #fff; }
    @media screen and (max-width: 768px) {
      .contact-form__line .wpcf7-submit {
        margin: auto; } }
  .contact-form__line.optin label {
    width: auto; }
  .contact-form__line .wpcf7-quiz {
    width: 24rem;
    border: 0 solid black;
    border-bottom: 1px solid black;
    font-size: 1.1rem; }
  .contact-form__line .quiz-520 label {
    width: 100%; }
  .contact-form__line .quiz-520 .wpcf7-quiz-label {
    top: 0.4rem;
    width: 46%;
    position: relative;
    display: inline-block;
    margin-right: 2rem; }

.homepage {
  width: 100%;
  height: 100%;
  text-align: right; }
  @media screen and (max-width: 500px) {
    .homepage {
      overflow: auto;
      height: auto; } }
  .homepage__visual {
    margin-top: 11rem;
    height: 60%; }
    @media screen and (max-width: 500px) {
      .homepage__visual {
        display: none; } }
  .homepage__visual--mobile {
    display: none; }
    @media screen and (max-width: 500px) {
      .homepage__visual--mobile {
        display: block;
        width: 100%; } }
  .homepage_contact--mobile {
    display: none; }
    @media screen and (max-width: 500px) {
      .homepage_contact--mobile {
        display: block;
        width: 100%;
        position: absolute;
        text-align: center;
        color: white;
        bottom: -0.5rem;
        font-weight: bold; } }

.look {
  height: 100%;
  text-align: right; }
  @media screen and (max-width: 768px) {
    .look {
      display: none; } }
  .look .swiper-container {
    float: right;
    height: 80%;
    position: relative;
    right: -10%;
    visibility: hidden; }
    .look .swiper-container .swiper-slide {
      left: -1px;
      overflow: hidden; }
      .look .swiper-container .swiper-slide img {
        width: calc(100% - 2rem); }
      .look .swiper-container .swiper-slide:last-of-type {
        pointer-events: none; }
    .look .swiper-container.ready {
      visibility: visible; }
      .look .swiper-container.ready .swiper-slide:nth-child(1) {
        -webkit-animation: slideIn 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
                animation: slideIn 0.3s cubic-bezier(0.215, 0.61, 0.355, 1); }
      .look .swiper-container.ready .swiper-slide:nth-child(2) {
        -webkit-animation: slideIn 0.36s cubic-bezier(0.215, 0.61, 0.355, 1);
                animation: slideIn 0.36s cubic-bezier(0.215, 0.61, 0.355, 1); }
      .look .swiper-container.ready .swiper-slide:nth-child(3) {
        -webkit-animation: slideIn 0.42s cubic-bezier(0.215, 0.61, 0.355, 1);
                animation: slideIn 0.42s cubic-bezier(0.215, 0.61, 0.355, 1); }
    .look .swiper-container .swiper-button-prev {
      left: 2%;
      margin-top: -4rem;
      background-image: url(../images/arrow-left.png);
      background-size: auto 60%;
      background-position: center; }
    .look .swiper-container .swiper-button-next {
      left: 84%;
      right: inherit;
      margin-top: -4rem;
      background-image: url(../images/arrow-right.png);
      background-size: auto 60%;
      background-position: center; }
    .look .swiper-container .swiper-button-disabled {
      display: none; }
    @media screen and (max-aspect-ratio: 16 / 8) {
      .look .swiper-container {
        height: 73%; }
        .look .swiper-container .swiper-button-next {
          left: 86%; } }
    @media screen and (max-aspect-ratio: 14 / 9) {
      .look .swiper-container {
        right: -25%;
        height: 65%; }
        .look .swiper-container .swiper-button-next {
          left: 73%; } }

.look--mobile {
  display: none; }
  @media screen and (max-width: 768px) {
    .look--mobile {
      display: block; }
      .look--mobile .look__content {
        width: 100%; }
        .look--mobile .look__content img {
          width: 100%; }
        .look--mobile .look__content h2 {
          text-align: center;
          font-size: 1.2rem;
          margin-top: 20px;
          margin-bottom: 20px;
          text-transform: uppercase; }
        .look--mobile .look__content p {
          text-align: center;
          margin-left: 20px;
          margin-right: 20px; }
          .look--mobile .look__content p .btn--line {
            padding: 1rem 1.5rem;
            display: inline-block;
            font-size: 1rem; }
        .look--mobile .look__content:last-child {
          display: none; }
        .look--mobile .look__content__social {
          text-align: center;
          margin-bottom: 19px;
          margin-top: 20px;
          margin-right: 0; }
          .look--mobile .look__content__social a {
            width: 2rem;
            height: 2rem;
            margin: 0 0.8rem; } }

.product {
  position: relative;
  float: right;
  width: 100%;
  height: 85%;
  min-width: 90rem;
  text-align: right;
  overflow: auto;
  visibility: hidden;
  -webkit-overflow-scrolling: touch; }
  @media screen and (max-width: 768px) {
    .product {
      display: none; } }
  .product a {
    display: inline-block;
    width: 12%;
    min-width: 13rem;
    margin-left: 3px;
    margin-bottom: 3px;
    background: #999999;
    overflow: hidden;
    font-size: 0; }
    .product a img {
      width: 100%; }
    .product a.big img {
      position: relative;
      width: 120%;
      left: -10%; }
  .product__line {
    font-size: 0; }
    .loaded .product__line a:nth-child(1) {
      -webkit-animation: slideIn 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
              animation: slideIn 0.3s cubic-bezier(0.215, 0.61, 0.355, 1); }
    .loaded .product__line a:nth-child(2) {
      -webkit-animation: slideIn 0.36s cubic-bezier(0.215, 0.61, 0.355, 1);
              animation: slideIn 0.36s cubic-bezier(0.215, 0.61, 0.355, 1); }
    .loaded .product__line a:nth-child(3) {
      -webkit-animation: slideIn 0.42s cubic-bezier(0.215, 0.61, 0.355, 1);
              animation: slideIn 0.42s cubic-bezier(0.215, 0.61, 0.355, 1); }
    .loaded .product__line a:nth-child(4) {
      -webkit-animation: slideIn 0.48s cubic-bezier(0.215, 0.61, 0.355, 1);
              animation: slideIn 0.48s cubic-bezier(0.215, 0.61, 0.355, 1); }
    .loaded .product__line a:nth-child(5) {
      -webkit-animation: slideIn 0.54s cubic-bezier(0.215, 0.61, 0.355, 1);
              animation: slideIn 0.54s cubic-bezier(0.215, 0.61, 0.355, 1); }
    .loaded .product__line a:nth-child(6) {
      -webkit-animation: slideIn 0.6s cubic-bezier(0.215, 0.61, 0.355, 1);
              animation: slideIn 0.6s cubic-bezier(0.215, 0.61, 0.355, 1); }
  .loaded .product {
    visibility: visible; }
  .product.back .product__line a {
    -webkit-animation: none !important;
            animation: none !important; }

.product--mobile {
  display: none; }
  @media screen and (max-width: 768px) {
    .product--mobile {
      display: block; }
      .product--mobile .product__line {
        overflow: hidden;
        white-space: nowrap;
        width: 100%; }
      .product--mobile a {
        display: inline-block;
        width: calc(50% - 5px);
        background: #999999;
        overflow: hidden;
        margin-right: 10px;
        margin-bottom: 10px;
        -webkit-animation: none !important;
                animation: none !important; }
        .product--mobile a img {
          width: 100%; }
      .popin .product--mobile {
        height: 100vh;
        overflow: hidden;
        -webkit-transition: opacity 0.6s cubic-bezier(0.215, 0.61, 0.355, 1);
        transition: opacity 0.6s cubic-bezier(0.215, 0.61, 0.355, 1);
        opacity: 0; } }

.campagne {
  width: 120%;
  height: 100%;
  max-width: 1700px;
  text-align: right;
  float: right;
  right: -55rem;
  position: relative;
  visibility: hidden; }
  .loaded .campagne {
    visibility: visible;
    -webkit-animation: slideIn 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
            animation: slideIn 0.3s cubic-bezier(0.215, 0.61, 0.355, 1); }
  @media screen and (max-width: 768px) {
    .campagne {
      display: none; } }
  .campagne .swiper-container {
    margin-top: 10rem;
    height: 70%; }
    @media (max-height: 574px) {
      .campagne .swiper-container {
        height: 25%; } }
    .campagne .swiper-container .swiper-slide {
      width: auto; }
    .campagne .swiper-container img {
      width: calc(100% - 2rem); }
  .campagne .swiper-button {
    top: 8rem; }
  .campagne .swiper-button-next {
    left: 50%; }
  .campagne--mobile {
    display: none; }
    @media screen and (max-width: 768px) {
      .campagne--mobile {
        display: block; }
        .campagne--mobile .campagne__content {
          width: 100%;
          margin-bottom: 3rem; }
          .campagne--mobile .campagne__content img {
            width: 100%; } }

.collab {
  width: 100%;
  height: 100%;
  position: relative; }
  .collab__visual {
    width: 50%;
    float: right; }
    .collab__visual img {
      width: 100%; }
    @media screen and (max-width: 768px) {
      .collab__visual {
        height: auto; }
        .collab__visual img {
          height: auto;
          width: 100%; } }
  .collab__content {
    height: calc(80% - 1.2rem);
    width: 50%;
    float: right;
    text-align: justify;
    font-size: 1.2rem;
    line-height: 140%;
    padding: 0;
    -webkit-overflow-scrolling: touch; }
    @media screen and (max-width: 768px) {
      .collab__content {
        width: 100%;
        height: auto;
        box-sizing: border-box;
        float: none; } }
    .collab__content h2,
    .collab__content p {
      padding-left: 0.5rem;
      padding-right: 0.5rem; }
    .collab__content p:last-of-type {
      margin-bottom: -2rem; }
    .collab__content img {
      width: 100%; }
    .collab__content .collab__embed {
      display: none; }
    @media screen and (max-width: 768px) {
      .collab__content .collab__embed {
        display: block !important; } }
    .collab__content__text {
      overflow: auto;
      min-height: 100px;
      padding-right: 1rem; }
      @media screen and (max-width: 768px) {
        .collab__content__text {
          overflow: visible;
          min-height: 0;
          padding: 0;
          height: auto !important;
          padding-bottom: 20px; } }
  .collab__embed {
    height: 12rem;
    width: 40rem;
    position: absolute;
    bottom: 0;
    left: 10em; }
    @media screen and (max-width: 768px) {
      .collab__embed {
        display: none;
        position: relative;
        width: 100%;
        left: 0;
        top: -0.5rem;
        height: 20rem;
        margin-bottom: 1rem; } }
    .collab__embed .play:before {
      position: absolute;
      top: 0;
      left: 0;
      content: '';
      display: block;
      height: 100%;
      width: 100%;
      background: #000;
      opacity: 0.3; }
    .collab__embed .play:after {
      position: absolute;
      top: calc(50% - 20px);
      left: calc(50% - 10px);
      content: '';
      display: block;
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 20px 0 20px 20px;
      border-color: transparent transparent transparent white;
      opacity: 0.8; }
    .collab__embed .play:hover:after {
      -webkit-transition: opacity 0.3s ease;
      transition: opacity 0.3s ease;
      opacity: 1; }

.sur-mesure {
  width: 100%;
  height: 100%; }
  .sur-mesure__visual {
    margin-top: 5rem;
    height: 70%;
    float: right; }
    .sur-mesure__visual img {
      height: 100%; }
    @media screen and (max-width: 768px) {
      .sur-mesure__visual {
        width: 100% !important;
        height: auto;
        margin-top: 2rem; }
        .sur-mesure__visual img {
          height: auto;
          width: 100%; } }
  .sur-mesure__content {
    margin-top: 5rem;
    margin-right: 5rem;
    height: calc(70% - 1.5rem);
    width: 30%;
    float: right;
    text-align: justify;
    line-height: 140%;
    padding: 0.4rem 1rem;
    overflow: auto;
    -webkit-overflow-scrolling: touch; }
    .sur-mesure__content h2 {
      text-transform: uppercase; }
    .sur-mesure__content p:last-of-type {
      margin-bottom: -2rem; }
    @media screen and (max-width: 768px) {
      .sur-mesure__content {
        width: 100% !important;
        height: auto;
        margin: 0;
        padding: 0.4rem 1rem;
        box-sizing: border-box;
        overflow: inherit; } }

.boutique {
  float: right;
  height: 80%;
  width: 80%; }
  @media screen and (max-width: 768px) {
    .boutique {
      display: none; } }
  .boutique td {
    border: 1.5rem solid white;
    height: 50%;
    width: 50%;
    vertical-align: middle;
    overflow: hidden;
    min-width: 35rem;
    position: relative; }
    .boutique td .imagelink {
      height: 100%;
      position: absolute;
      width: 100%;
      top: 0; }
    .boutique td img {
      display: none; }
  .boutique__content {
    padding: 0 1.5rem;
    line-height: 140%; }
  .boutique--mobile {
    display: none; }
    @media screen and (max-width: 768px) {
      .boutique--mobile {
        display: block; }
        .boutique--mobile img {
          width: 100%;
          margin-bottom: 30px; }
        .boutique--mobile__content {
          margin-bottom: 30px;
          padding: 0 15px; }
          .boutique--mobile__content .btn--line {
            width: 70%;
            margin: auto; } }

.contacts {
  width: 40rem;
  background: #999999;
  float: right;
  margin-right: 15rem;
  height: 100%;
  display: table; }
  @media screen and (max-width: 768px) {
    .contacts {
      margin-right: 0;
      width: 100%; } }
  .contacts__content {
    padding: 6rem 5rem 0 5rem;
    line-height: 130%;
    display: table-cell;
    vertical-align: middle; }
    .contacts__content p {
      margin-bottom: 5rem; }

._journal-color.blue, .journal .blue.post, .blue.journal--detail {
  background: #dbecee; }

._journal-color.pink, .journal .pink.post, .pink.journal--detail {
  background: #f4dff1; }

._journal-color.yellow, .journal .yellow.post, .yellow.journal--detail {
  background: #f9f9df; }

._journal-color.green, .journal .green.post, .green.journal--detail {
  background: #dbeee4; }

.journal {
  width: 30%;
  min-width: 450px;
  margin: auto; }
  @media screen and (max-width: 768px) {
    .journal {
      width: 100%;
      min-width: inherit; } }
  .journal .post {
    padding: 1rem 2rem;
    margin-bottom: 2rem;
    position: relative; }
    .journal .post:last-child {
      margin-bottom: 0; }
    .journal .post h2 {
      font-weight: bold;
      text-align: right;
      text-transform: uppercase; }
    .journal .post__date {
      text-align: right; }
    .journal .post__visual {
      margin-top: 7rem; }
      .journal .post__visual img {
        width: 100%; }
  .journal--detail {
    height: 100%; }
    .journal--detail .post {
      padding-bottom: 0; }
      .journal--detail .post__content {
        margin-top: 7rem;
        padding-bottom: 4rem;
        /*AH*/
        text-align: justify;
        /*AH*/
        /*AH*/ }
        .journal--detail .post__content img {
          width: 100%;
          height: auto; }
        .journal--detail .post__content a {
          text-decoration: underline; }
        .journal--detail .post__content__social {
          position: absolute;
          bottom: 0.7rem;
          right: 1.5rem; }
          .journal--detail .post__content__social a {
            width: 1.5rem;
            height: 1.5rem;
            background-repeat: no-repeat;
            background-size: contain;
            display: inline-block;
            margin: 0.8rem 0.3rem;
            opacity: 1;
            -webkit-transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
            transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1); }
            @media screen and (max-width: 768px) {
              .journal--detail .post__content__social a {
                width: 2.5rem;
                height: 2.5rem;
                margin: 0.8rem 0.5rem; } }
            .journal--detail .post__content__social a:hover {
              opacity: 1; }
            .journal--detail .post__content__social a.facebook {
              background-image: url(../images/facebook.png); }
            .journal--detail .post__content__social a.twitter {
              background-image: url(../images/twitter.png); }
            .journal--detail .post__content__social a.pinterest {
              background-image: url(../images/pinterest.png); }

.journal-back {
  width: 19rem;
  text-align: right;
  position: fixed;
  left: 0;
  bottom: 2rem;
  text-transform: uppercase;
  z-index: 2; }
  @media screen and (max-width: 768px) {
    .journal-back {
      top: 24px;
      left: 24px;
      bottom: inherit;
      z-index: 300;
      width: auto; } }
