/*  Rappel : breakpoint variable
theme.$screen-xs: 480px ;
theme.$screen-sm: 768px ;
theme.$screen-md: 992px ;
theme.$screen-lg: 1200px ;
*/
/* mockup

see the icon variable name here : 03-settings / _font-icon.scss

.class-test {

 @include font-icon ($icon-arrow-down , red);

}

 */
/* ----- USEFUL MIXINS

  - 1 / Transition
  - 2 / Animation
  - 3 / Retina
  - 4 / Gradient
  - 5 / Placeholder

*/
/* mockup

div.logo {
  background: url("logo.png") no-repeat;
  @include image-2x("logo2x.png", 100px, 25px);
}

 */
/* mockup

$start-color, $end-color, $orientation - vertical/horizontal/radial

.class-test {
  @include background-gradient(red, black, 'vertical');
}

Output
.class-test {
  background: -webkit-linear-gradient(top, red, black);
  background: linear-gradient(to bottom, red, black);
}

 */
/* mockup

  textarea {
    @include input-placeholder {
        color: $grey;
    }
}

 */
/* mockup

  label {
    @include sr-only;
}

 */
.full-banner-bg, .homepage .top-banner .field.field--name-field-video-fallback-image {
  z-index: -5;
  top: 0;
  position: absolute;
  width: 100%;
}
.full-banner-bg img, .homepage .top-banner .field.field--name-field-video-fallback-image img {
  width: 100%;
}
@media only screen and (max-width: 992px) {
  .full-banner-bg img, .homepage .top-banner .field.field--name-field-video-fallback-image img {
    height: 100%;
    width: initial;
    max-width: initial;
  }
}
@media only screen and (max-width: 768px) {
  .full-banner-bg img, .homepage .top-banner .field.field--name-field-video-fallback-image img {
    width: 150%;
    transform: translateX(-33%);
    max-width: none;
  }
}
@media only screen and (max-width: 992px) {
  .full-banner-bg, .homepage .top-banner .field.field--name-field-video-fallback-image {
    left: 50%;
    transform: translateX(-50%);
    width: auto;
    height: 100%;
  }
  .full-banner-bg div, .homepage .top-banner .field.field--name-field-video-fallback-image div {
    height: 100%;
  }
  .full-banner-bg, .homepage .top-banner .field.field--name-field-video-fallback-image {
    /**
      left: 50%;
      top: 50%;
      transform: translate(-50%,-50%);
     */
  }
}
@media only screen and (max-width: 768px) {
  .full-banner-bg, .homepage .top-banner .field.field--name-field-video-fallback-image {
    position: relative;
    left: 0;
    transform: translateX(0);
    width: auto;
    height: auto;
  }
}

.field--name-field-segment-picture-legend {
  margin-top: 15px;
  font-size: 12px;
  line-height: 14px;
}

.field--type-text-long img, .ck-content img, .field--type-text-with-summary img {
  max-width: 100%;
  height: auto;
}
.field--type-text-long figcaption, .ck-content figcaption, .field--type-text-with-summary figcaption {
  margin-top: 15px;
  font-size: 12px;
  line-height: 14px;
}

.path-frontpage #content .row > section {
  top: 0;
}
.path-frontpage .region-header {
  display: none;
}

.homepage {
  font-family: "opensans-regular";
}
.homepage .top-banner.full-banner {
  min-height: calc(100vh - 130px);
}
@media only screen and (max-width: 992px) {
  .homepage .top-banner.full-banner {
    display: flex;
    align-items: flex-start;
  }
}
@media only screen and (max-width: 480px) {
  .homepage .top-banner.full-banner {
    min-height: calc(100vh - 190px);
  }
}
.homepage .top-banner.full-banner {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: right;
}
.homepage .top-banner.full-banner.has-video .full-banner-label {
  top: 60%;
}
@media only screen and (min-width: 1200px) {
  .homepage .top-banner.full-banner:not(.has-video) {
    min-height: 100vh;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
  }
}
.homepage .top-banner .label-banner {
  padding: 0;
}
.homepage .top-banner .label-banner .homepage-banner-button {
  padding-top: 70px;
  padding-right: 75px;
}
@media only screen and (max-width: 1200px) {
  .homepage .top-banner .label-banner .homepage-banner-button {
    padding-top: 90px;
  }
}
@media only screen and (max-width: 992px) {
  .homepage .top-banner .label-banner .homepage-banner-button {
    padding-top: 70px;
    padding-left: 75px;
  }
}
@media only screen and (max-width: 768px) {
  .homepage .top-banner .label-banner .homepage-banner-button {
    padding-top: 15px;
    padding-right: 15px;
    padding-left: 15px;
  }
}
.homepage .top-banner .label-banner .homepage-banner-button .banner-intro {
  background-color: #FFFFFF;
  border-bottom: #7D1234 5px solid;
  padding: 30px 15px;
}
.homepage .top-banner .label-banner .homepage-banner-button .banner-intro:before {
  content: url("../../assets/images/hp-butterfly.png");
  position: absolute;
  top: 0;
  right: 0;
}
@media only screen and (max-width: 768px) {
  .homepage .top-banner .label-banner .homepage-banner-button .banner-intro:before {
    zoom: 0.65;
  }
}
@media only screen and (max-width: 480px) {
  .homepage .top-banner .label-banner .homepage-banner-button .banner-intro:before {
    zoom: 0.4;
  }
}
.homepage .top-banner .label-banner h1 {
  font: normal normal normal 33px/49px "opensans-regular";
}
@media only screen and (max-width: 992px) {
  .homepage .top-banner .label-banner h1 {
    font: normal normal normal 27px/40px "opensans-regular";
  }
}
@media only screen and (min-width: 768px) and (max-width: 992px) {
  .homepage .top-banner .label-banner h1 {
    text-align: left;
  }
}
@media only screen and (max-width: 480px) {
  .homepage .top-banner .label-banner h1 {
    min-width: auto;
    padding: 0;
    margin: -30px;
    width: auto;
  }
}
.homepage .top-banner .video-banner {
  z-index: 10;
  pointer-events: none;
}
@media only screen and (max-width: 992px) {
  .homepage .top-banner .video-banner {
    display: none;
  }
}
.homepage .top-banner .video-banner .video-embed-field-responsive-video:after {
  padding-bottom: 50%;
}
@media only screen and (min-width: 992px) {
  .homepage .top-banner .banner-default-hidden {
    opacity: 0;
    -webkit-transition: opacity 0.5s ease-in;
    -moz-transition: opacity 0.5s ease-in;
    -ms-transition: opacity 0.5s ease-in;
    -o-transition: opacity 0.5s ease-in;
    transition: opacity 0.5s ease-in;
  }
  .homepage .top-banner .banner-default-hidden.animate {
    opacity: 1;
  }
  @keyframes animatedBackground {
    from {
      top: -25px;
    }
    to {
      top: 25px;
    }
  }
  @-webkit-keyframes animatedBackground {
    from {
      top: -25px;
    }
    to {
      top: 25px;
    }
  }
  @-ms-keyframes animatedBackground {
    from {
      top: -25px;
    }
    to {
      top: 25px;
    }
  }
  @-moz-keyframes animatedBackground {
    from {
      top: -25px;
    }
    to {
      top: 25px;
    }
  }
  .homepage .top-banner .end-banner .separator-wrapper {
    height: 25px;
    overflow: hidden;
    position: relative;
  }
  .homepage .top-banner .end-banner .separator {
    height: 25px;
  }
  .homepage .top-banner .end-banner .separator:before {
    position: relative;
    height: 25px;
    animation: animatedBackground 1s linear infinite;
    -ms-animation: animatedBackground 1s linear infinite;
    -moz-animation: animatedBackground 1s linear infinite;
    -webkit-animation: animatedBackground 1s linear infinite;
  }
}
@media only screen and (max-width: 1200px) {
  .homepage .top-banner {
    min-height: 400px;
  }
}
.homepage .top-banner .full-banner-label {
  color: unset;
}
@media only screen and (max-width: 992px) {
  .homepage .top-banner .full-banner-label {
    bottom: 0;
    transform: translateY(0);
    top: auto;
    position: sticky;
    height: 100%;
  }
}
@media only screen and (max-width: 768px) {
  .homepage .top-banner .full-banner-label {
    position: sticky;
    height: 100%;
  }
}
@media only screen and (min-width: 1500px) {
  .homepage .top-banner .field.field--name-field-video-fallback-image img {
    margin-top: -5vw;
  }
}
.homepage .top-banner .end-banner {
  font-size: 16px;
  font-family: "opensans-sbold";
  color: #fff;
  bottom: 0;
  position: absolute;
  width: 100%;
  z-index: 100;
  display: none;
}
.homepage .top-banner .end-banner a {
  color: #1c9fab;
  text-decoration: none;
}
.homepage .segment-header h2 {
  font-family: "opensans-bold";
  color: #333333;
}
.homepage .segment-header .subtitle p {
  color: #7D1234;
  font-family: "opensans-sbold";
  font-size: 20px;
  line-height: 24px;
  letter-spacing: 0px;
}
.homepage .link-to-mediaroom {
  color: #676464;
  font-family: "opensans-regular";
  font-weight: 600;
  font-size: 14px;
  line-height: 19px;
  letter-spacing: 0;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  text-transform: uppercase;
  margin-bottom: 15px;
}
.homepage .link-to-mediaroom img {
  margin-left: 10px;
  max-height: 22px;
  width: auto;
}
@media only screen and (min-width: 992px) {
  .homepage .news-list-view {
    display: flex;
    flex: 1 0 auto;
  }
  .homepage .news-list-view .views-element-container {
    width: 100%;
  }
}
.homepage .news-list-view .views-row {
  margin-bottom: 30px;
}
@media only screen and (max-width: 768px) {
  .homepage .news-list-view .news-hightlight .field--name-field-picture-full-page {
    display: none;
  }
}
.homepage .news-list-view .news-hightlight .news-text-bloc {
  padding-top: 20px;
}
@media only screen and (min-width: 992px) {
  .homepage .news-list-view .news-hightlight .news-text-bloc {
    padding-top: 30px;
    padding-left: 40px;
    margin-left: 50px;
    border-left: 1px #7D1234 solid;
  }
}
.homepage .news-list-view .news-hightlight .news-title {
  color: #7D1234;
  font-family: "opensans-regular";
  font-size: 24px;
}
@media only screen and (min-width: 768px) {
  .homepage .news-list-view .news-hightlight .news-title {
    font-size: 34px;
    line-height: 36px;
    font-family: "opensans-light";
  }
}
@media only screen and (min-width: 992px) {
  .homepage .news-list-view .news-hightlight .news-title {
    font-size: 38px;
    line-height: 44px;
  }
}
@media only screen and (min-width: 768px) {
  .homepage .news-list-view .news-secondary {
    padding-top: 55px;
  }
}
.homepage .news-list-view .news-secondary .news-title {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 24px;
  font-family: "opensans-regular";
}
.homepage .news-list-view a {
  text-decoration: none;
}
@media only screen and (min-width: 1200px) {
  .homepage .headroom--pinned.headroom--top {
    position: absolute;
  }
}
.homepage .paragraph--type--rte {
  padding: 60px 0;
}

@media only screen and (min-width: 992px) {
  body:not(.android):not(.ipad) .homepage .has-video {
    max-height: calc(100vh - 130px);
    min-height: auto;
    background: none;
    background-image: none !important;
  }
}

.android .homepage .video-banner, .ipad .homepage .video-banner {
  display: none;
}

/*# sourceMappingURL=node-homepage.css.map */
