@charset "UTF-8";
/*
body {
  margin: 0; }

.main-wrapper {
  background-color: #fff;
  width: 1590px;
  max-width: 100%;
  margin: 0 auto;
  position: relative; }

@media (max-width: 1589px) {
  .main-wrapper {
    width: 1360px; } }

@media (max-width: 1023px) {
  .main-wrapper {
    width: 100%; } }

@font-face {
  font-family: FuturaNewDemi-Reg;
  src: url(../fonts/FuturaNewDemi-Reg.eot);
  src: url(../fonts/FuturaNewDemi-Reg.woff2) format("woff2"), url(../fonts/FuturaNewDemi-Reg.woff) format("woff"), url(../fonts/FuturaNewDemi-Reg.ttf) format("truetype");
  font-style: normal; }
*/
@-webkit-keyframes zoomScale {
  0% {
    -webkit-transform: scale(1.2) rotate(0.02deg);
    transform: scale(1.2) rotate(0.02deg); }
  to {
    -webkit-transform: scale(1) rotate(0.02deg);
    transform: scale(1) rotate(0.02deg); } }

@keyframes zoomScale {
  0% {
    -webkit-transform: scale(1.2) rotate(0.02deg);
    transform: scale(1.2) rotate(0.02deg); }
  to {
    -webkit-transform: scale(1) rotate(0.02deg);
    transform: scale(1) rotate(0.02deg); } }

@-webkit-keyframes raiseIn {
  0% {
    -webkit-transform: translate(-50%, -45%);
    transform: translate(-50%, -45%); }
  to {
    -webkit-transform: translateY(-50%, -50%);
    transform: translateY(-50%, -50%); } }

@keyframes raiseIn {
  0% {
    -webkit-transform: translate(-50%, -45%);
    transform: translate(-50%, -45%); }
  to {
    -webkit-transform: translateY(-50%, -50%);
    transform: translateY(-50%, -50%); } }

@-webkit-keyframes fadeIn {
  0% {
    opacity: 0; }
  to {
    opacity: 1; } }

@keyframes fadeIn {
  0% {
    opacity: 0; }
  to {
    opacity: 1; } }

/* Slider */
.slick-loading .slick-list {
  background: #fff url("./ajax-loader.gif") center center no-repeat; }

/* Arrows */
.slick-prev,
.slick-next {
  position: absolute;
  display: block;
  height: 50px;
  width: 50px;
  line-height: 0px;
  font-size: 0px;
  cursor: pointer;
  background: transparent;
  color: transparent;
  top: 45%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  padding: 0;
  border: 1px solid white;
  transition: border .6s;
  border-radius: 50%;
  outline: none;
  z-index: 1; }
  .slick-prev:hover, .slick-prev:focus,
  .slick-next:hover,
  .slick-next:focus {
    outline: none;
    background: transparent;
    color: transparent; }
    .slick-prev:hover:before, .slick-prev:focus:before,
    .slick-next:hover:before,
    .slick-next:focus:before {
      opacity: 1; }
  .slick-prev:hover,
  .slick-next:hover {
    border-color: #FD3C3C;
    transition: border-color .6s; }
    .slick-prev:hover:before,
    .slick-next:hover:before {
      color: #FD3C3C;
      transition: color .6s; }
  .slick-prev.slick-disabled,
  .slick-next.slick-disabled {
    opacity: 0.25;
    cursor: auto; }
    .slick-prev.slick-disabled:hover,
    .slick-next.slick-disabled:hover {
      border-color: white; }
      .slick-prev.slick-disabled:hover:before,
      .slick-next.slick-disabled:hover:before {
        color: white; }
  .slick-prev:before,
  .slick-next:before {
    font-size: 20px;
    line-height: 1;
    color: white;
    transition: color .6s;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale; }

.slick-prev {
  left: 25px; }
  [dir="rtl"] .slick-prev {
    left: auto;
    right: 25px; }
  .slick-prev:before {
    content: "←"; }
    [dir="rtl"] .slick-prev:before {
      content: "→"; }

.slick-next {
  right: 25px; }
  [dir="rtl"] .slick-next {
    left: 25px;
    right: auto; }
  .slick-next:before {
    content: "→"; }
    [dir="rtl"] .slick-next:before {
      content: "←"; }

/* Dots */
.slick-dotted.slick-slider {
  margin-bottom: 30px; }

.slick-dots {
  position: absolute;
  bottom: 10px;
  z-index: 1;
  list-style: none;
  display: block;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%; }
  .slick-dots li {
    position: relative;
    display: inline-block;
    height: 20px;
    width: 20px;
    margin: 0 5px;
    padding: 0;
    cursor: pointer; }
    .slick-dots li button {
      background: transparent;
      display: block;
      height: 15px;
      width: 15px;
      outline: none;
      color: transparent;
      padding: 5px;
      cursor: pointer;
      border: 1px solid white;
      border-radius: 50%; }
      .slick-dots li button:hover, .slick-dots li button:focus {
        outline: none; }
        .slick-dots li button:hover:before, .slick-dots li button:focus:before {
          opacity: 1; }
    .slick-dots li.slick-active button {
      border-color: #DB3332; }

/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent; }

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0; }
  .slick-list:focus {
    outline: none; }
  .slick-list.dragging {
    cursor: pointer;
    cursor: hand; }

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0); }

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto; }
  .slick-track:before, .slick-track:after {
    content: "";
    display: table; }
  .slick-track:after {
    clear: both; }
  .slick-loading .slick-track {
    visibility: hidden; }

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none; }
  [dir="rtl"] .slick-slide {
    float: right; }
  .slick-slide img {
    display: block; }
  .slick-slide.slick-loading img {
    display: none; }
  .slick-slide.dragging img {
    pointer-events: none; }
  .slick-initialized .slick-slide {
    display: block; }
  .slick-loading .slick-slide {
    visibility: hidden; }
  .slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent; }

.slick-arrow.slick-hidden {
  display: none; }

.carousel__container {
  position: relative; 
}

.carousel__item {
	overflow-x: hidden; /* CSI - avoid that the next slide overlays the current slide (c.f. carousel__visual with max-width 140%) */
	overflow-y: hidden; /* CSI - improve aspect ration by allowing the image to be taller than the carousel__item (c.f. carousel__visual changed max-height from 840px to 140%) */
}

.carousel__overlay {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  opacity: 0.67;
  z-index: 1;
  background-image: linear-gradient(to top, #000000, rgba(0, 0, 0, 0) 100%); }

.carousel__wrapper {
  padding: 0;
  margin: 0; }
  .carousel__wrapper .slick-slide {
    height: 100vh;
    max-height: 840px; }

.carousel__figure {
  margin: 0;
  position: relative;
  height: 100vh;
  max-height: 840px; }

.carousel__visual {
  min-height: 100%;
  min-width: 100%;
  max-width: 140%;
  max-height: 140%;  /* was 840px; */
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); }

.carousel__zoomscale {
  height: 100%;
  width: 100%;
  -webkit-animation: 16s forwards zoomScale;
  animation: 16s forwards zoomScale; }

.carousel__caption {
  position: absolute;
  z-index: 2;
  left: 50%;
  top: 45%;
  transform: translate(-50%, -50%);
  width: 50%;
  text-align: center;
  opacity: 0;
  -webkit-animation: 1s .8s forwards fadeIn,1s .8s forwards raiseIn;
  animation: 1s .8s forwards fadeIn,1s .8s forwards raiseIn; }
  .carousel__caption a {
    color: white;
    text-decoration: none;
    outline: none; }
  .carousel__caption__title {
    margin: 15px 0;
    font-size: 2.75rem;
    line-height: 3rem;
    font-weight: normal;
    font-family: FuturaNewDemi-Reg; }
  .carousel__caption__readmore {
    display: flex;
    min-width: 150px;
    padding: 15px 25px;
    margin: auto;
    margin-top: 30px;
    border: none;
    border-radius: 30px;
    background-color: #DB3332;
    color: white;
    font-size: 1.1rem;
    font-family: FuturaNewDemi-Reg;
    cursor: pointer; }
    .carousel__caption__readmore .icon {
      margin-left: 25px;
      transition: margin-left .6s;
      margin-top: 4px; }
      .carousel__caption__readmore .icon path {
        fill: white; }
    .carousel__caption__readmore:hover {
      background-color: #FD3C3C; }
      .carousel__caption__readmore:hover .icon {
        margin-left: 10px;
        transition: margin-left .6s; }

.carousel__nav {
  position: absolute;
  bottom: 0;
  z-index: 2;
  width: 100%;
  margin: 0;
  padding: 0 5%;
  display: flex;
  opacity: 0;
  overflow: hidden;
  -webkit-animation: 1.6s 1s forwards fadeIn;
  animation: 1.6s 1s forwards fadeIn; }
  .carousel__nav .slick-list {
    width: 100%;
    padding: 0 !important;
    overflow: visible; }
  .carousel__nav .slick-track {
    margin: 0; }
  .carousel__nav__item {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100px;
    padding-top: 0.5rem;
    margin-bottom: 1rem;
    margin-right: 25px;
    border-top: 1px solid rgba(150, 150, 150, 0.8);
    overflow: hidden;
    transition: color .6s;
    color: rgba(150, 150, 150, 0.8);
    text-align: left;
    font-family: FuturaNewDemi-Reg;
    cursor: pointer;
    outline: none; }
    .carousel__nav__item:hover .carousel__nav__title {
      color: #FD3C3C;
      transition: color .6s; }
  .carousel__nav__title {
    margin: 10px 0;
    text-align: left;
    font-size: 1.25rem; }
  .carousel__nav .slick-current {
    color: white;
    font-weight: bold;
    border-top-color: white; }

@media (max-width: 850px) {
  .carousel__nav {
    display: none; }
  .carousel__wrapper .slick-slide {
    height: 95vh; }
  .carousel__figure {
    height: 95vh;
    overflow: hidden; }
  .carousel__visual {
    max-width: none;
    max-height: 100%; }
  .carousel__caption {
    top: 50%;
    width: 80%; }
    .carousel__caption__title {
      font-size: 2rem;
      line-height: 2.15rem; }
    .carousel__caption__readmore {
      width: 35%;
      justify-content: space-between; } }

@media (max-width: 550px) {
  .carousel__caption {
    width: 90%;
    text-align: left; }
    .carousel__caption__readmore {
      width: 100%; } }
