.swop25-cover {
  background: #4d2f29;
  /* Navbar height. */
  padding-top: 52px;
  position: relative;
}

@media all and (min-width: 1000px) {
  .swop25-cover {
    /* Navbar height. */
    padding-top: 70px;
  }
}

.swop25-cover-texts {
  padding-top: 60px;
  padding-bottom: 300px;
  font-size: 36px;
  line-height: 1.333em;
  text-align: center;
  position: relative;
  z-index: 2;
}

h1.swop25-cover-title {
  color: #fff;
  font-size: inherit;
  line-height: inherit;
  text-transform: uppercase;
}

p.swop25-cover-subtitle {
  margin: 4px auto 17px auto;
  width: 16em;
  max-width: 90vw;
  color: #f6be8e;
  font-size: 0.555em;
  line-height: 1.2em;
  text-align: inherit;
}

.swop25-cover-arrow {
  margin-left: -17px;
  width: 34px;
  height: 32px;
  background: url(images/arrow-down.svg) 0 0 no-repeat;
  background-size: 100% auto;
  position: absolute;
  bottom: 20px;
  left: 50%;
  z-index: 2;
  animation: swop25-cover-arrow-bounce 1.5s infinite ease;
}

.swop25-cover-img {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
}

.swop25-cover-img-mobile,
.swop25-cover-img-desktop {
  display: block;
  width: 100%;
  height: 100%;
  background: center center no-repeat;
  background-size: cover;
}

.swop25-cover-img-desktop {
  display: none;
}

.swop25-cover-img:after {
  content: '';
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-image: linear-gradient(to bottom, rgba(75, 54, 47, 0.50) 28%, rgba(75, 54, 47, 0.40) 46%, rgba(75, 54, 47, 0.00) 74%);
}

@media all and (min-width: 640px) {
  .swop25-cover-texts {
    font-size: 46px;
    line-height: 1.3333em;
  }
}

@media all and (min-width: 768px) {
  .swop25-cover-texts {
    font-size: 56px;
    line-height: 1.3333em;
  }

  p.swop25-cover-subtitle {
    margin-top: 5px;
    margin-bottom: 26px;
    font-size: 36px;
    line-height: 1.2em;
  }

  .swop25-cover-arrow {
    width: 38px;
    height: 36px;
  }
}

@media all and (min-width: 1000px) {
  .swop25-cover {
    min-height: 100vh;
  }

  .swop25-cover-texts {
    padding-top: 72px;
    padding-bottom: 200px;
    font-size: 80px;
    line-height: 90px;
  }

  p.swop25-cover-subtitle {
    width: 560px;
  }

  .swop25-cover-img-mobile {
    display: none;
  }

  .swop25-cover-img-desktop {
    display: block;
  }

  .swop25-cover-arrow {
    bottom: 120px;
  }
}

@keyframes swop25-cover-arrow-bounce {
  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-10px);
  }
}
