.home .header { height: 85px; }
.home section.bg-white { background-color: #fff; }
.home section.bg-sand { background-color: #f0efed; }

.home .slider { margin-bottom: 0; }
.home .slider .owl-carousel .top { height: 250px; background-position: center center; background-repeat: no-repeat; background-size: cover; }
.home .slider .owl-carousel .bottom { width: 100%; height: 200px; }
.home .slider .owl-carousel .container { position: relative; }
.home .slider .caption-square { position: absolute; text-align: center; top: -290px; left: 0; right: 0; width: 270px; height: 270px; margin: 0 auto; padding: 20px; background-color: rgba(255,255,255,0.90); -webkit-box-shadow: 0px 10px 10px 0px #e5e5e5; box-shadow: 0px 10px 10px 0px #e5e5e5; }
.home .slider .caption-square .title { font-size: 3.2rem; line-height: 3.4rem; text-transform: uppercase; } 
.home .slider .caption-square .text { font-size: 1.8rem; } 
.home .slider .caption-square .link { font-size: 2.0rem; font-weight: 400; } 

.home .home-section { padding-top: 20px; padding-bottom: 50px; }
.home .home-section .picto { width: 50px; margin: 0 auto; }
.home .home-section .title { font-size: 2.8rem; text-transform: uppercase; margin-bottom: 15px; }
.home .home-section ul.links { margin: 0; padding: 0; width: 100%; margin: 0 auto; overflow: hidden; }
.home .home-section ul.links li { list-style: none; display: block; float: left; width: 33.333333%; text-transform: uppercase; padding-top: 10px; }
.home .home-section ul.links li a { display: block; position: relative; text-decoration: none; padding-top: 22px; }
.home .home-section ul.links li a::before { content: ''; position: absolute; display: block; top: 0; left: 0; right: 0; margin-left: auto; margin-right: auto; width: 15px; height: 15px; background-color: #444; -webkit-transition: all 0.5s; -o-transition: all 0.5s; transition: all 0.5s; }
.home .home-section ul.links li a:hover::before { -webkit-transform: rotate(180deg); -ms-transform: rotate(180deg); transform: rotate(180deg); }

.home .home-parts [class*="col-"] { margin-bottom: 10px; }
.home .home-parts { padding-top: 40px; position: relative; }
.home .home-parts h2 { font-size: 3.0rem; line-height: 1.1; text-align: center; border-bottom: none; margin: 0; padding-bottom: 10px; background-color: #f0efed; }
.home .home-parts p { text-align: center; margin-bottom: 3px; }
.home .home-parts a { text-decoration: none; }
.home .home-parts .more { text-align: right; margin-top: 10px; padding-right: 20px; padding-bottom: 0px; }
.home .home-parts .more span { display: inline-block; vertical-align: middle; font-weight: 400; }
.home .home-parts .more .chevron { margin-right: 5px; border-right: 1px solid #444; border-bottom: 1px solid #444; width: 10px; height: 10px; -webkit-transform: scaleX(0.6) rotate(-45deg); -ms-transform: scaleX(0.6) rotate(-45deg); transform: scaleX(0.6) rotate(-45deg); }
.home .home-parts .more .square { margin-left: 8px; width: 18px; height: 18px; background-color: #444; -webkit-transition: all 0.5s; -o-transition: all 0.5s; transition: all 0.5s; }
.home .home-parts .more:hover .square { -webkit-transform: rotate(180deg); -ms-transform: rotate(180deg); transform: rotate(180deg); } 
.home .home-parts .link { display: block; position: relative; text-align: center; height: 110px; padding: 41px 0; z-index: 9; }
.home .home-parts .link::after { content: ''; position: absolute; display: block; top: 18px; left: calc(50% - 35px); width: 70px; height: 70px; border: 1px solid #000;  z-index: 15; }
.home .home-parts .link a { position: relative; background-color: #000; color: #fff; padding: 5px 12px; z-index: 999 }

.home-offers { padding-top: 40px; padding-bottom: 40px; }
.home-offers .bloc { text-align: center; border: 6px solid; padding: 25px 25px 0 25px; margin-bottom: 20px; }
.home-offers .bloc.offer { border-color: #b61615; }
.home-offers .bloc.gift { border-color: #d5b2aa; }
.home-offers .bloc h3 { font-family: 'Akzidenz'; font-size: 3.0rem; line-height: 3.0rem; text-transform: uppercase; color: #000; margin: 0 0 5px 0; }
.home-offers .bloc p { font-family: Castro; font-size: 1.8rem; line-height: 2.2rem; text-transform: none; margin-bottom: 10px; }
.home-offers .bloc > a { display: inline-block; text-decoration: none; margin-top: 10px; padding: 3px 10px 2px 10px; text-transform: uppercase; color: #fff; -webkit-transition: all 0.2s; -o-transition: all 0.2s; transition: all 0.2s; }
.home-offers .bloc > a:hover { padding-left: 20px; padding-right: 20px; }
.home-offers .bloc.offer > a { background-color: #b61615 }
.home-offers .bloc.gift > a { background-color: #d5b2aa }

.home .home-even { padding-top: 35px !important; }

.home .home-promo { color: #fff; }
.home .home-promo .row > div { background-color: #796e6a; overflow: hidden; }
.home .home-promo .left { padding-left: 0; padding-right: 0; }
.home .home-promo img { margin-bottom: 5px; }
.home .home-promo .right { padding: 20px 30px; }
.home .home-promo .new { display: inline-block; font-size: 3.0rem; font-weight: 300; letter-spacing: 0.20rem; padding-bottom: 10px; margin-bottom: 10px; border-bottom: 1px solid #fff; }
.home .home-promo h4 { text-transform: uppercase; font-weight: 300; letter-spacing: 0.20rem; margin-bottom: 15px; }
.home .home-promo p { margin-bottom: 20px; }
.home .home-promo .more { color: #fff; text-transform: uppercase; }

.home .home-activities { position: relative; max-width: 2000px; margin: 0 auto; }
.home .home-activities .activity { position: relative; width: 100%; height: 300px; background-size: cover; }
.home .home-activities .activity-1 { background-image: url("../images/home-activity-01.jpg"); background-position: left top; }
.home .home-activities .activity-2 { background-image: url("../images/home-activity-02.jpg"); background-position: center top; }
.home .home-activities .activity-3 { background-image: url("../images/home-activity-03.jpg"); background-position: right top; }

.home .home-activities .activity .caption-square { position: absolute; text-align: center; top: 40px; left: 0; right: 0; width: 240px; height: 220px; margin: 0 auto; padding: 20px; background-color: rgba(255,255,255,0.90); }
.home .home-activities .activity .caption-square .keyword { font-size: 1.6rem; }
.home .home-activities .activity .caption-square .title { font-size: 3.0rem; line-height: 3.2rem; text-transform: uppercase; }
.home .home-activities .activity .caption-square .text { font-size: 1.6rem; }
.home .home-activities .activity .caption-square .link { font-size: 1.8rem; font-weight: 400; }


@keyframes activity-darken {
  from { background-color: rgba(0,0,0,0.0); }
  to { background-color: rgba(0,0,0,0.6); }
}

@keyframes caption-square-darken {
  from { opacity: 1.0; }
  to { opacity: 0.0; }
}

@media only screen and (min-width : 576px) {

}


@media only screen and (min-width : 768px) {
  .home .header { height: 170px; }
  .home .slider .owl-carousel .top { height: 350px; }
  .home .slider .owl-carousel .bottom { width: 100%; height: 160px; }
  .home .slider .caption-square { top: -290px; }
  
  .home .home-section .title { font-size: 3.0rem; }
  .home .home-section p:not(.title) { margin-bottom: 25px; }
  .home .home-section p:not(.title):last-child { margin-bottom: 10px; }
  .home .home-section ul.links { margin-top: 15px; }
  .home .home-section ul.links li a { font-size: 2.0rem; }

  .home .home-parts div.h2 { width: 100%; display: table; padding: 0; margin: 0; }
  .home .home-parts h2 { padding-bottom: 15px; height: 80px; width: 100%; vertical-align: bottom; display: table-cell; }
  .home .home-parts::after { content: ''; display: block; position: absolute; bottom: 0px; width: 100%; height: 55px; background-color: #fff; }
  .home .home-parts .row { display: -webkit-box; display: -ms-flexbox; display: flex; }
  .home .home-parts [class*="col-"] { margin-bottom: 0; float: none; -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }
  .home .home-parts [class*="col-"] > div { position: relative; background-color: #fff; height: 100%; padding-bottom: 160px; }
  .home .home-parts [class*="col-"] p { padding: 10px 15px 0 15px; } 
  .home .home-parts .links { position: absolute; width: 100%; bottom: 0; }
  .home .home-parts .more { margin-bottom: 10px;  }
  .home .home-parts .link { display: block; position: relative; text-align: center; background-color: #f0efed; height: 110px; padding: 41px 0; z-index: 9;
                          background: #f0efed;
                          background: -webkit-gradient(linear, left top, left bottom, from(#f0efed), color-stop(50%, #f0efed), color-stop(50%, #ffffff), to(#ffffff));
                          background: -webkit-linear-gradient(top,  #f0efed 0%,#f0efed 50%,#ffffff 50%,#ffffff 100%);
                          background: -o-linear-gradient(top,  #f0efed 0%,#f0efed 50%,#ffffff 50%,#ffffff 100%);
                          background: linear-gradient(to bottom,  #f0efed 0%,#f0efed 50%,#ffffff 50%,#ffffff 100%);
  }
  .home .home-parts .link::after { content: ''; position: absolute; display: block; top: 20px; left: calc(50% - 35px); width: 70px; height: 70px; border: 1px solid #000; -webkit-transition: all 0.5s; -webkit-transform : rotate(0deg) scale(0); -ms-transform: rotate(0deg) scale(0); transform: rotate(0deg) scale(0); z-index: 15; }
  .home .home-parts .link:hover::after { width: 70px; height: 70px; -webkit-transform: rotate(180deg) scale(1); -ms-transform: rotate(180deg) scale(1); transform: rotate(180deg) scale(1); }
  .home .home-parts .link a { position: relative; background-color: #000; color: #fff; padding: 5px 12px; z-index: 999 }
  
  .home .home-offers { padding-top: 20px; }
  .home .home-offers .bloc h3 { margin-bottom: 10px }
  .home .home-offers .bloc p { margin-bottom: 15px; font-size: 2.0rem; }

  .home .home-even { padding-top: 40px !important; }
  .home .home-even p:not(.title):last-child { margin-bottom: 20px; }

  .home .home-promo { padding-top: 60px; padding-bottom: 50px; }
  .home .home-promo .row > div { margin-left: 15px; margin-right: 15px; }
  .home .home-promo img { margin-bottom: 0; }
  .home .home-promo .right { padding-left: 20px; padding-right: 20px; }

  .home .home-activities { height: 400px; margin-bottom: 70px; }
  .home .home-activities .activity { position: absolute; width: 33.33333333%; height: 400px; top: 0; -webkit-transition: all 1.0s; -o-transition: all 1.0s; transition: all 1.0s; }
  .home .home-activities .activity-1 { left: 0; z-index: 1 }
  .home .home-activities .activity-2 { left: 0; right: 0; margin-left: auto; margin-right: auto; z-index: 1; }
  .home .home-activities .activity-2::after { content: ''; position: absolute; display: block; width: 100%; height: 100%; background-color: rgba(0,0,0,0.0); -webkit-transition: all 1.0s; -o-transition: all 1.0s; transition: all 1.0s; }
  .home .home-activities .activity-2 .caption-square { z-index: 1; -webkit-transition: all 1.0s; -o-transition: all 1.0s; transition: all 1.0s; }
  .home .home-activities .activity-3 { right: 0; z-index: 1 }

  .home .home-activities .activity-1:hover { width: 90%; z-index: 100; }
  .home .home-activities .activity-2:hover { width: 90%; z-index: 100; }
  .home .home-activities .activity-3:hover { width: 90%; z-index: 100; }

  .home .home-activities .activity-1:hover ~ .activity-2 { width: 10%; left: 80%; z-index: 50; }
  .home .home-activities .activity-1:hover ~ .activity-2::after { background-color: rgba(0,0,0,0.6); }
  .home .home-activities .activity-1:hover ~ .activity-2 .caption-square { opacity: 0.0; }
  .home .home-activities .activity-3:hover ~ .activity-2 { width: 10%; left: -80%; z-index: 50; }
  .home .home-activities .activity-3:hover ~ .activity-2::after { background-color: rgba(0,0,0,0.6); }
  .home .home-activities .activity-3:hover ~ .activity-2 .caption-square { opacity: 0.0; }

  .home .home-activities .activity-1.darken::after { content: ''; position: absolute; display: block; width: 100%; height: 100%; -webkit-animation-name: activity-darken; animation-name: activity-darken; -webkit-animation-duration: 1s; animation-duration: 1s; -webkit-animation-fill-mode: forwards; animation-fill-mode: forwards; }
  .home .home-activities .activity-3.darken::after { content: ''; position: absolute; display: block; width: 100%; height: 100%; -webkit-animation-name: activity-darken; animation-name: activity-darken; -webkit-animation-duration: 1s; animation-duration: 1s; -webkit-animation-fill-mode: forwards; animation-fill-mode: forwards; }

  .home .home-activities .activity-1.darken .caption-square { -webkit-animation-name: caption-square-darken; animation-name: caption-square-darken; -webkit-animation-duration: 1s; animation-duration: 1s; -webkit-animation-fill-mode: forwards; animation-fill-mode: forwards; }
  .home .home-activities .activity-3.darken .caption-square { -webkit-animation-name: caption-square-darken; animation-name: caption-square-darken; -webkit-animation-duration: 1s; animation-duration: 1s; -webkit-animation-fill-mode: forwards; animation-fill-mode: forwards; }

  .home .home-activities .activity .caption-square { top: 80px; width: 220px; height: 240px; padding: 30px 15px; }
  .home .home-activities .activity .caption-square .keyword { font-size: 1.6rem; }
  .home .home-activities .activity .caption-square .title { font-size: 3.0rem; line-height: 3.2rem; }
  .home .home-activities .activity .caption-square .text { font-size: 1.6rem; }
  .home .home-activities .activity .caption-square .link { font-size: 1.8rem; }
}


@media only screen and (min-width : 992px) {
  .home .slider .owl-carousel .top { height: 450px; }
  .home .slider .owl-carousel .bottom { width: 100%; height: 0; }
  .home .slider .caption-square { width: 310px; height: 310px; left: auto; top: auto; bottom: 70px ; right: 30px; margin: 0; padding: 40px; -moz-box-shadow: none; -webkit-box-shadow: none; -o-box-shadow: none; box-shadow: none; }

  .home .home-section { padding-top: 40px; }
  .home .home-section .title { font-size: 3.2rem; margin-bottom: 15px; }

  .home .home-offers .bloc { padding-left: 40px; padding-right: 40px; }
  .home .home-offers .bloc h3 { font-size: 3.8rem; line-height: 3.8rem; }
  .home .home-offers .bloc p { line-height: 2.4rem; font-size: 2.4rem; }

  .home .home-even p:not(.title):last-child { margin-bottom: 30px; }

  .home .home-promo .right { padding: 25px 40px 0 40px; }

  .home .home-activities .activity .caption-square { width: 240px; height: 240px; padding: 30px 20px; }
}


@media only screen and (min-width : 1200px) {
  .home .slider .owl-carousel .top { height: 550px; }
  .home .slider .caption-square { width: 350px; height: 350px; bottom: 100px ; right: 30px; padding: 60px; }
  .home .slider .caption-square .keyword { font-size: 1.8rem; margin-bottom: 20px; } 
  .home .slider .caption-square .title { font-size: 3.4rem; line-height: 3.6rem; }
  .home .slider .caption-square .text { margin-bottom: 20px; }

  .home .home-section .title { font-size: 3.6rem; margin-bottom: 15px; }

  .home .home-offers .bloc { padding: 35px 50px 0 50px; }
  .home .home-offers .bloc h3 { font-size: 4.6rem; line-height: 4.6rem; }
  .home .home-offers .bloc p { font-size: 2.6rem; line-height: 2.8rem; margin-bottom: 20px; }
  .home .home-offers .bloc > a { margin-top: 20px; padding: 5px 15px 4px 15px; }
  .home .home-offers .bloc > a:hover { padding-left: 30px; padding-right: 30px; }

  .home .home-activities { height: 500px; }
  .home .home-activities .activity { height: 500px; }
  .home .home-activities .activity .caption-square { top: 115px; width: 270px; height: 270px; padding: 35px 30px; }
  .home .home-activities .activity .caption-square .keyword { font-size: 1.8rem; margin-bottom: 15px;  }
  .home .home-activities .activity .caption-square .title { font-size: 3.2rem; line-height: 3.4rem; margin-bottom: 15px; }

  .home .home-promo { padding-top: 70px; padding-bottom: 60px; }
  .home .home-promo .new { font-size: 3.6rem; }
  .home .home-promo h4 { font-size: 2.4rem; }
  .home .home-promo p { margin-bottom: 50px;  }
  .home .home-promo a { font-size: 1.8rem;  }
  .home .home-promo .right { padding: 40px 50px 0 50px; }
}

@media only screen and (min-width : 1600px) {
  .home .slider .owl-carousel .top { height: 620px; }
  .home .slider .caption-square { width: 380px; height: 380px; bottom: 120px ; right: 0; padding: 70px; }
  .home .slider .caption-square .keyword { font-size: 2.0rem;  } 
  .home .slider .caption-square .title { font-size: 3.7rem; line-height: 4.0rem; }

  .home .home-activities { height: 610px; margin-bottom: 70px; }
  .home .home-activities .activity { height: 610px; }
  .home .home-activities .activity .caption-square { top: 130px; width: 350px; height: 350px; padding: 35px 30px; }
  .home .home-activities .activity .caption-square .keyword { font-size: 2.0rem; margin-bottom: 30px;  }
  .home .home-activities .activity .caption-square .title { font-size: 3.6rem; line-height: 3.8rem; margin-bottom: 30px; }
  .home .home-activities .activity .caption-square .text { font-size: 1.8rem; margin-bottom: 30px; }
  .home .home-activities .activity .caption-square .link { font-size: 2.0rem; }
}


