.swop21-intro {
  min-height: 100vh;
  position: relative;
}

.swop21-intro-img {
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: center center no-repeat;
  background-size: 100%;
  z-index: 1;
}

.swop21-intro-sizer {
  height: 0;
  padding-bottom: 110.1875%;
}

/* Div for position fixing title as sticky. */
.swop21-intro-title-sticker {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 2;
}

html.js .swop21-intro-title-sticker {
  opacity: 0;
  transform: translateY(150px);
  transition: opacity 0.3s ease-out, transform 1s ease-out;
}

html.js .swop21-intro-title-sticker.sticked,
html.js .swop21-intro-title-sticker.after {
  opacity: 1;
  transform: translateY(0);
}

.swop21-intro-title-sticker.sticked {
  position: fixed;
}

.swop21-intro-title-sticker.after {
  top: auto;
  bottom: 0;
}

.swop21-intro-title-pos {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

h2.swop21-intro-title {
  max-width: 850px;
  padding: 46px 80px 39px 20px;
  background: #000;
  font-size: 46px;
  line-height: 50px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
}

.swop21-intro-title .swop21-font-outline {
  text-transform: uppercase;
}

.swop21-intro-arrow {
  width: 42px;
  height: 42px;
  background: url(../../images/2021/intro/icon-arrow-down.svg) 0 0 no-repeat;
  background-size: 100% 100%;
  position: absolute;
  right: 49px;
  bottom: 47px;
}

@media all and (max-width: 360px) {
  .swop21-fr h2.swop21-intro-title {
    font-size: 42px;
    line-height: 46px;
  }
}

@media all and (max-width: 767px) {
  .swop21-intro {
    background: top center no-repeat;
    background-size: 100%;
  }

  .swop21-intro-arrow {
    display: none;
  }
}

@media all and (min-width: 768px) {
  .swop21-intro-title-pos {
    padding: 0 24px;
  }

  h2.swop21-intro-title {
    max-width: 554px;
    padding: 46px 100px 39px 50px;
    font-size: 64px;
    line-height: 66px;
  }
}

@media all and (min-width: 1000px) {
  h2.swop21-intro-title {
    max-width: 800px;
    font-size: 120px;
    line-height: 100px;
  }

  .swop21-fr h2.swop21-intro-title,
  .swop21-es h2.swop21-intro-title {
    font-size: 64px;
    line-height: 66px;
  }
}

@media all and (min-width: 1000px) and (min-height: 800px) {
  .swop21-fr h2.swop21-intro-title,
  .swop21-es h2.swop21-intro-title {
    font-size: 110px;
    line-height: 90px;
  }
}

@media all and (min-width: 1400px) {
  h2.swop21-intro-title {
    max-width: 900px;
  }
}

@media all and (min-width: 1400px) and (min-height: 800px) {
  .swop21-fr h2.swop21-intro-title,
  .swop21-es h2.swop21-intro-title {
    font-size: 120px;
    line-height: 100px;
  }
}
