/**
 * @file : 
 * Mini-site global styles.
 */


/**
 * Contextual rules from parent site.
 * This part should be removed prior to production .
 */
body, div, ul, ol, li, h1, h2, h3, pre, code,
form, fieldset, legend, input,
button, textarea, p, blockquote {
  margin: 0;
  padding: 0;
}
.kw-header-placeholder {
  position: fixed;
  z-index: 999;
  top: 0;
  right: 0;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 63px;
  font-family: "FuturaHeavy", Arial, sans-serif;
  text-align: center;
  text-transform: uppercase;
  color: #f57f69;
  background-color: #fff;
  -webkit-transition: all ease .25s;
  -o-transition: all ease .25s;
  transition: all ease .25s;
}
#page {
  padding-top: 63px;
  -webkit-transition: all ease .25s;
  -o-transition: all ease .25s;
  transition: all ease .25s;
}
@media all and (min-width: 750px) {
  .kw-header-placeholder {
    height: 143px;
  }
  #page {
    padding-top: 143px;
  }
  .kw-js-scrolled .kw-header-placeholder {
    height: 66px;
  }
  .kw-js-scrolled #page {
    padding-top: 66px;
  }

}

/**
 * Fonts
 */
@font-face{
  font-family: "FuturaLight";
  src: url('../fonts/35B454_2_0.eot');
  src: url('../fonts/35B454_2_0.eot?#iefix') format('embedded-opentype'),
       url('../fonts/35B454_2_0.woff2') format('woff2'),
       url('../fonts/35B454_2_0.woff') format('woff'),
       url('../fonts/35B454_2_0.ttf') format('truetype'),
       url("../fonts/35B454_2_0.svg#35B454_2_0") format("svg");
  font-weight: normal;
  font-style: normal;
}
@font-face{
  font-family: "FuturaMedium";
  src: url('../fonts/35B454_3_0.eot');
  src: url('../fonts/35B454_3_0.eot?#iefix') format('embedded-opentype'),
       url('../fonts/35B454_3_0.woff2') format('woff2'),
       url('../fonts/35B454_3_0.woff') format('woff'),
       url('../fonts/35B454_3_0.ttf') format('truetype'),
       url("../fonts/35B454_4_0.svg#35B454_3_0") format("svg");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "FuturaHeavy";
  src: url("../fonts/35B454_4_0.eot");
  src: url("../fonts/35B454_4_0.eot?#iefix") format("embedded-opentype"),
       url('../fonts/35B454_3_0.woff2') format('woff2'),
       url("../fonts/35B454_4_0.woff") format("woff"),
       url("../fonts/35B454_4_0.ttf") format("truetype"),
       url("../fonts/35B454_4_0.svg#35B454_4_0") format("svg");
  font-weight: bold;
  font-style: normal;
}

/**
 * Bases styles
 */
#page .kw-body * {
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  outline: none;
}
.kw-body {
  position: relative;
  max-width: 1920px;
  margin: 0 auto;
  font-family: "FuturaMedium", Arial, Helvetica, sans-serif;
  letter-spacing: .08em;
  color: #555555;
  background-color: #ffffff;
  overflow: hidden;
}
.kw-body a {
  text-decoration: none;
}
.kw-body img {
  max-width: 100%;
  height: auto;
}

/**
 * Page backgrounds
 */
.kw-bg {
  position: fixed;
  z-index: -1;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  -webkit-background-size: cover;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
@media all and (max-width: 750px) {
  .kw-bg {
    background-attachment: scroll;
  }
}
.kw-bg::after,
.kw-bg--adults::before,
.kw-bg--darken::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: linear-gradient(0deg,rgba(0,0,0,.5) 10%,transparent 70%);
}
.kw-bg--hero-next {
  -webkit-background-size: cover;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  position: relative;
  z-index:2;
}
.kw-bg--sun {
  background-image: url("../images/sun/page-background-sun.jpg");
}
.kw-bg--adults {
  background-image: url("../images/adults/page-background-adults.jpg");
  background-position: top center;
}
.kw-bg--kids {
  background-image: url("../images/kids/page-background-kids.jpg");
}
.kw-bg--oceans {
  background-image: url("../images/oceans/page-background-oceans.jpg");
}
.kw-bg--home {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  background-image: url("../images/home/page-background-home.jpg");
}
.kw-main-wrapper {
  position: relative;
  z-index: 2;
}

/**
 * Specificities Home Page
 */
.kw-home{
  height:calc(100vh - 63px);
  position: relative;
}
.kw-home .kw-main-wrapper{
  height:100%;
  top:0;
  transition: all .5s cubic-bezier(.19,1,.22,1);
}
.kw-landing-poster {
  text-align: center;
  position: absolute;
  top: calc(50% - 30px);
  left: 50%;
  transform: translate(-50%,-50%);
  width: 100%;
}
.kw-landing-poster__title{
  color:#fff;
  text-transform: uppercase;
  font-size:2.25em;
  margin-bottom:1.25rem;
  max-width:100%;
  padding:0 1rem;
  letter-spacing: -1px;
  font-weight: 400;
}
.kw-landing-poster__image{
  width:100px;
  margin-bottom:1.25em;
}
/*Action block home page*/
.kw-action-block--home{
  position: absolute;
  right:0;
  bottom:-10px;
  text-align: center;
}
.kw-action-block--home:hover{
  cursor: pointer;
}
.kw-action-block--home__text{
  font-size:1.075em;
  font-family: "FuturaLight", Arial, Helvetica, sans-serif;
  text-transform: uppercase;
  color:#fff;
  letter-spacing:0.175rem;
}
.kw-action-block--stroke-splash-home::after {
  content: "";
  display: block;
  width: 168px;
  height: 155px;
  background-image: url("../images/home/stroke-splash-home.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin-top:0.5rem;
  transform: translateX(55px);
  transition:all 0.25s;
}
.kw-action-block--stroke-splash-home:hover::after {
  background-image: url("../images/home/stroke-splash-home-hover.svg");
}
@media screen and (min-width:480px) {
  .kw-action-block--home{
    left:50%;
    transform: translateX(-50%);
    right: inherit;
    bottom:0;
  }
}
@media screen and (min-width:750px) {
  .kw-landing-poster{
    top:calc(50% - 50px);
  }
  .kw-home{
    height:calc(100vh - 143px);
  }
  .kw-landing-poster__title{
    font-size:2.2em;
    font-size:1.85em;
    letter-spacing: 0px;
  }
}
@media screen and (min-width:1000px) {
  .kw-landing-poster__title{
    font-size:2.8em;
  }
  .kw-landing-poster__image{
    width:130px;
  }
}
@media screen and (max-height:650px) {
  .kw-action-block--home{
    bottom:-10px;
  }
}

/*
 * Scrollbar
 */
.ps {
  overflow: hidden !important;
  overflow-anchor: none;
  -ms-overflow-style: none;
  touch-action: auto;
  -ms-touch-action: auto;
}
.ps__rail-x {
  display: none;
  opacity: 0;
  transition: background-color .2s linear, opacity .2s linear;
  -webkit-transition: background-color .2s linear, opacity .2s linear;
  height: 15px;
  bottom: 0px;
  position: absolute;
}
.ps__rail-y {
  opacity: 1;
  transition: background-color .2s linear, opacity .2s linear;
  -webkit-transition: background-color .2s linear, opacity .2s linear;
  width: 15px;
  right: 0;
  position: absolute;
}
.ps--active-x > .ps__rail-x,
.ps--active-y > .ps__rail-y {
  display: block;
  background-image: linear-gradient(to bottom, #fff, #fff);
  -webkit-background-size: 1px;
  background-size: 1px 100%;
  background-repeat: no-repeat;
  background-position: 50%;
}
.ps__thumb-x {
  background-color: #fff;
  border-radius: 6px;
  transition: all ease .25s;
  -webkit-transition: all ease .25s;
  height: 6px;
  bottom: 2px;
  position: absolute;
}
.ps__thumb-y {
  background-color: #fff;
  border-radius: 6px;
  transition: background-color .2s linear, width .2s ease-in-out;
  -webkit-transition: background-color .2s linear, width .2s ease-in-out;
  width: 7px;
  right: 
  4px;
  position: absolute;
}
.ps__rail-x:hover > .ps__thumb-x,
.ps__rail-x:focus > .ps__thumb-x,
.ps__rail-x.ps--clicking .ps__thumb-x {
  background-color: #999;
  height: 11px;
}
.ps__rail-y:hover > .ps__thumb-y,
.ps__rail-y:focus > .ps__thumb-y,
.ps__rail-y.ps--clicking .ps__thumb-y {

}
/* MS supports */
@supports (-ms-overflow-style: none) {
  .ps {
    overflow: auto !important;
  }
}
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  .ps {
    overflow: auto !important;
  }
}


/*Modif footer avene*/

#footer{
  z-index:1;
  margin-top:0;
}
#footer.kw-footer-hidden{
  z-index:-2;
}
#footer.kw-footer-not-displayed{
  display: none;
}
#page.kw-page-height-fixed{
  height:calc(100vh - 66px);
  top:66px;
  padding-top:0;
}