/* guides */

/*
dark blue: #0f0f24;
light blue: #3376fc;
light light blue: #4ccffb;
violet: #6759fb;
light grey: #f2f2f2;

font-family: "Poppins", sans-serif;

-webkit-transition: all .2s ease-out;
-moz-transition: all .2s ease-out;
-o-transition: all .2s ease-out;
transition: all .2s ease-out;
*/

/* general */

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  padding: 0;
  color: #0f0f24;
  font-family: "Poppins", sans-serif;
  font-weight: 400;
}

h1, h2, h3, h4, h5, h6, p, ul, ol {
  margin: 0;
}

input {
  font-family: "Poppins", sans-serif;
  font-size: 1rem;
  font-weight: 400;
}

::-webkit-input-placeholder {
  color: #aaa;
  font-family: "Poppins", sans-serif;
}

::-moz-placeholder {
  color: #aaa;
  font-family: "Poppins", sans-serif;
}

:-ms-input-placeholder {
  color: #aaa;
  font-family: "Poppins", sans-serif;
}

:-moz-placeholder {
  color: #aaa;
  font-family: "Poppins", sans-serif;
}

.display-none {
  display: none !important;
}

/* cover */

.cover {
  display: flex;
  align-items: center;
  margin: 7rem 6rem;
  height: calc(100vh - 14rem);
  padding: 4.5rem 3rem;
  background: rgb(51,118,252);
  background: linear-gradient(135deg, rgba(51,118,252,1) 0%, rgba(103,89,251,1) 50%, rgba(103,89,251,1) 100%);
  border-radius: 25px;
}

.cover > div {
  flex: 1;
}

.cover h1 {
  margin-bottom: 1.5rem;
  color: #fff;
  font-size: 1.75rem;
  font-weight: 600;
  -webkit-transition: all .2s ease-out;
  -moz-transition: all .2s ease-out;
  -o-transition: all .2s ease-out;
  transition: all .2s ease-out;
}

.cover h1 span {
  position: relative;
  font-style: italic;
  -webkit-transition: all .2s ease-out;
  -moz-transition: all .2s ease-out;
  -o-transition: all .2s ease-out;
  transition: all .2s ease-out;
}

.cover h1 span:before {
  content: "";
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 100%;
  height: 4px;
  background-color: #4ccffb;
  border-radius: 4px;
  -webkit-transition: all .2s ease-out;
  -moz-transition: all .2s ease-out;
  -o-transition: all .2s ease-out;
  transition: all .2s ease-out;
}

.cover p {
  margin-bottom: 1rem;
  color: #fff;
  font-size: .9rem;
  line-height: 1.5rem;
}

.cover img {
  margin-bottom: 2rem;
  height: 50px;
}

.cover input {
  flex: 1 1 calc(100% - 64px);
  padding: .875rem 1.75rem;
  font-size: 1rem;
  border: 0;
  border-radius: 50px;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  outline: 0;
}

.cover .cover-search {
  display: flex;
  align-items: center;
  width: 500px;
}

.cover .cover-search a {
  flex: 1 1 64px;
  padding: .875rem 1.75rem;
  padding-right: 1.75rem;
  text-align: center;
  color: #4ccffb;
  background-color: #fff;
  border: 0;
  border-radius: 50px;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  outline: 0;
  font-size: 1rem;
  text-decoration: none;
  cursor: pointer;
  -webkit-transition: all .2s ease-out;
  -moz-transition: all .2s ease-out;
  -o-transition: all .2s ease-out;
  transition: all .2s ease-out;
}

.cover .cover-search a:hover {
  color: #3376fc;
}

.cover .illustration {
  display: flex;
  text-align: center;
}

.cover .illustration > div {
  display: flex;
  margin-bottom: -6rem;
  margin-left: 5rem;
}

.cover .illustration .illustration-1 {
  position: relative;
  width: 76px;
  height: 76px;
  background-image: url("../images/cover1.png");
  background-size: cover;
  border-radius: 50%;
}

.cover .illustration .illustration-1 .line {
  position: absolute;
  top: -3rem;
  left: 37px;
  width: 7rem;
  height: 3rem;
  border-left: 2px solid #4ccffb;
  border-top: 2px solid #4ccffb;
  border-top-left-radius: 15px;
}

.cover .illustration .illustration-1 .dot {
  position: absolute;
  top: calc(-3rem - 7px);
  left: 84px;
  height: 16px;
  width: 16px;
  background-color: #4ccffb;
  border-radius: 50%;
  opacity: 0;
  animation: cover-dot-1 5s ease-out infinite;
}

.cover .illustration .illustration-2 {
  position: relative;
  width: 76px;
  height: 76px;
  margin-top: -5.25rem;
  margin-left: 4rem;
  background-image: url("../images/cover2.png");
  background-size: cover;
  border-radius: 50%;
}

.cover .illustration .illustration-2 .line {
  position: absolute;
  top: -3rem;
  left: 37px;
  width: 16rem;
  height: 3rem;
  border-left: 2px solid #4ccffb;
  border-top: 2px solid #4ccffb;
  border-right: 2px solid #4ccffb;
  border-top-left-radius: 15px;
  border-top-right-radius: 15px;
}

.cover .illustration .illustration-2 .dot {
  position: absolute;
  top: calc(-3rem - 7px);
  left: 155px;
  height: 16px;
  width: 16px;
  background-color: #4ccffb;
  border-radius: 50%;
  opacity: 0;
  animation: cover-dot-2 5s ease-out infinite;
}

.cover .illustration .illustration-3 {
  position: relative;
  width: 76px;
  height: 76px;
  margin-top: -5.25rem;
  margin-left: 11.125rem;
  background-image: url("../images/cover3.png");
  background-size: cover;
  border-radius: 50%;
}

.cover .illustration .illustration-3 .line {
  position: absolute;
  bottom: -6rem;
  left: -41px;
  width: 5rem;
  height: 6rem;
  border-right: 2px solid #4ccffb;
  border-bottom: 2px solid #4ccffb;
  border-bottom-right-radius: 15px;
}

.cover .illustration .illustration-3 .dot {
  position: absolute;
  top: 6.9rem;
  left: 30px;
  height: 16px;
  width: 16px;
  background-color: #4ccffb;
  border-radius: 50%;
  opacity: 0;
  animation: cover-dot-3 5s ease-out infinite;
}

.cover .illustration .illustration-4 {
  position: relative;
  width: 76px;
  height: 76px;
  margin-top: 3.25rem;
  margin-left: -12rem;
  background-image: url("../images/cover4.png");
  background-size: cover;
  border-radius: 50%;
}

.cover .illustration .illustration-4 .line {
  position: absolute;
  bottom: -6rem;
  left: -41px;
  width: 5rem;
  height: 6rem;
  border-right: 2px solid #4ccffb;
  border-bottom: 2px solid #4ccffb;
  border-bottom-right-radius: 15px;
}

.cover .illustration .illustration-4 .dot {
  position: absolute;
  bottom: -6.45rem;
  left: -55px;
  height: 16px;
  width: 16px;
  background-color: #4ccffb;
  border-radius: 50%;
  opacity: 0;
  animation: cover-dot-4 5s ease-out infinite;
}

.cover .illustration .illustration-5 {
  position: relative;
  background-image: url("../images/cover5.png");
  width: 76px;
  height: 76px;
  margin-top: 7.25rem;
  margin-left: -15rem;
  background-size: cover;
  border-radius: 50%;
}

.cover .illustration .illustration-5 .line {
  position: absolute;
  bottom: -2rem;
  left: 36px;
  width: 5.5rem;
  height: 2rem;
  border-left: 2px solid #4ccffb;
  border-bottom: 2px solid #4ccffb;
  border-bottom-left-radius: 15px;
}

.countdown {
  font-style: italic;
}

@keyframes cover-dot-1 {
  0% {
    opacity: 1;
  }
  20% {
    opacity: 1;
  }
  25% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}

@keyframes cover-dot-2 {
  0% {
    opacity: 0;
  }
  45% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  70% {
    opacity: 1;
  }
  75% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}

@keyframes cover-dot-3 {
  0% {
    opacity: 0;
  }
  20% {
    opacity: 0;
  }
  25% {
    opacity: 1;
  }
  45% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}

@keyframes cover-dot-4 {
  0% {
    opacity: 0;
  }
  70% {
    opacity: 0;
  }
  75% {
    opacity: 1;
  }
  95% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

@media (max-width: 1399px) {
  .cover .illustration {
    display: none;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  .cover {
    margin: 10rem 3rem;
    height: calc(100vh - 20rem);
    padding: 3rem;
  }
}

@media (max-width: 767px) {
  .cover {
    margin: 2rem 1.5rem;
    height: calc(100vh - 4rem);
    padding: 2rem;
  }

  .cover > div {
    max-width: 100%;
  }

  .cover h1 {
    margin-bottom: 1.5rem;
    color: #fff;
    font-size: 1.5rem;
    font-weight: 600;
  }

  .cover img {
    margin-bottom: 2rem;
    height: 35px;
  }

  .cover .cover-search {
    width: calc(100% - 2rem);
  }

  .cover input {
    max-width: calc(100% - 2rem);
  }
}
