* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: Gotham, sans-serif;
}

body {
  -webkit-font-smoothing: antialiased;
  background-color: rgb(19, 23, 35);
}

ul li, ol li {
  list-style: none;
}

a {
  text-decoration: none;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

.container {
  max-width: 119.3125rem;
  margin: 0 auto;
}

.button--outline {
  padding: 1rem 3rem;
  color: #ffffff !important;
  font-size: 0.875rem;
  font-weight: 700;
  text-align: center;
  text-transform: uppercase;
  border-radius: 2rem;
  cursor: pointer;
  background-color: transparent !important;
  border: 0.125rem solid #ffffff;
  transition: 0.3s;
}
.button--outline:hover {
  background-color: #ffffff !important;
  color: #000 !important;
}

.button--green {
  padding: 1rem 2rem;
  color: #ffffff !important;
  font-size: 0.875rem;
  font-weight: 700;
  text-align: center;
  text-transform: uppercase;
  border-radius: 2rem;
  cursor: pointer;
  background-color: #70b946 !important;
  border: 2px solid #6fb846 !important;
  transition: 0.3s;
}
.button--green:hover {
  background-color: #589338 !important;
  border: 2px solid #589338 !important;
}

.card__product {
  flex-shrink: 0;
  max-width: 17.8125rem;
  margin: 0 0.25rem;
  position: relative;
  overflow: hidden;
  border-radius: 0.5rem;
  transition: 0.5s;
  cursor: pointer;
}
.card__product:hover {
  transform: scale(1.07);
  background-color: rgba(9, 12, 21, 0.6);
  box-shadow: rgba(9, 12, 21, 0.41) 8px 8px 16px;
}
.card__product:hover h2 {
  visibility: visible;
  transform: translate(1rem);
  opacity: 1;
  opacity: 0;
}
.card__product:hover::before {
  opacity: 1;
  opacity: 0;
}
.card__product::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 20;
  opacity: 0;
  transition: 0.5s;
  background-color: rgba(9, 12, 21, 0.6);
  pointer-events: none;
  display: none;
}
.card__product:last-child {
  padding: 1rem;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: gray;
  text-align: center;
  color: #FFF;
}
.card__product > a{
    display: block;
}
.card__product svg {
  position: absolute;
  right: 1.25rem;
  top: 1.25rem;
  z-index: 30;
}
.card__product h2 {
  display: none;
  margin-bottom: 0.3125rem;
  position: absolute;
  bottom: 0.25rem;
  left: 0;
  transform: translateX(-10%);
  opacity: 0;
  z-index: 30;
  visibility: hidden;
  color: #ffffff;
  font-family: GothamBold, sans-serif;
  font-weight: bold;
  font-size: 1.375rem;
  transition: 0.3s ease-out;
}
@media screen and (max-width: 33.75rem) {
  .card__product h2 {
    font-size: 1.125rem;
  }
}

.section__embla:hover .section__embla__buttons button {
  visibility: visible;
  opacity: 1;
  position: relative;
  z-index: 100;
}

.embla__container {
  display: flex;
}

.section__embla__buttons {
  width: calc(100% - 3rem);
  position: absolute;
  top: 50%;
  left: 1.5rem;
  transform: translateY(-50%);
  display: flex;
  gap: 1rem;
  justify-content: space-between;
  align-items: center;
  pointer-events: none;
}
.section__embla__buttons button {
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: transparent;
  border: none;
  outline: none;
  border-radius: 50%;
  visibility: hidden;
  opacity: 0;
  transition: 0.3s;
  cursor: pointer;
  pointer-events: all !important;
}
.section__embla__buttons button svg {
  pointer-events: none;
}

.modal__assine {
  width: 100%;
  height: 100vh;
  padding: 2.5rem 1.25rem;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 9999;
  display: flex;
  display: none;
  justify-content: center;
  align-items: center;
  background-color: rgba(0, 0, 0, 0.3);
}
.modal__assine.show-modal {
  display: flex;
}
.modal__assine .modal__assine__container {
  display: flex;
  flex-direction: column;
  border-radius: 0px;
  overflow: hidden;
  background-color: rgb(9, 12, 21);
  box-shadow: rgb(9, 12, 21) 0px 4px 24px;
}
.modal__assine .modal__assine__header {
  margin-bottom: 2rem;
  padding: 2.5rem 2.5rem 0 2.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
@media screen and (max-width: 33.75rem) {
  .modal__assine .modal__assine__header {
    padding: 2rem 1.5rem 0 1.5rem;
  }
}
.modal__assine .modal__assine__header button {
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  background: transparent;
  border: none;
}
.modal__assine .steps {
  display: flex;
  gap: 0.1875rem;
}
.modal__assine .steps li {
  width: 2rem;
  height: 0.25rem;
  position: relative;
  flex: 0 1 auto;
  background-color: rgb(49, 53, 66);
}
.modal__assine .steps .active {
  background-color: #6fb846;
}

.modal--passo1 {
  max-width: 36.25rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.modal--passo1 > h1 {
  padding: 0 2.5rem;
  color: #ffffff;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo1 > h1 {
    padding: 0 1.5rem;
    font-size: 1.125rem;
  }
}
.modal--passo1 .section__embla {
  position: relative;
  overflow: hidden;
  transition: 0.3s;
}
.modal--passo1 .section__embla:hover .div__embla__buttons button {
  opacity: 1;
  visibility: visible;
}
.modal--passo1 .section__embla__viewport {
  width: 92%;
  margin: 0 auto;
}
.modal--passo1 .embla__container {
  display: flex;
}
.modal--passo1 .embla__slide {
  flex-shrink: 0;
  width: 16.1875rem;
  min-height: 9.375rem;
  margin: 0 0.25rem;
  padding: 1.5rem;
  position: relative;
  display: flex;
  flex-direction: column;
  background-color: rgb(49, 53, 66);
  border-radius: 0.5rem;
  cursor: pointer;
}
.modal--passo1 .embla__slide * {
  color: #ffffff;
}
.modal--passo1 .embla__slide .embla__slide__header {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}
.modal--passo1 .embla__slide .embla__slide__header img {
  width: 1.5rem;
  height: 1.5rem;
  flex-shrink: 0;
  border-radius: 50%;
}
.modal--passo1 .embla__slide .embla__slide__header span {
  font-size: 0.875rem;
  font-weight: 700;
}
.modal--passo1 .embla__slide .embla__slide__line {
  height: 0.125rem;
  margin: 1rem 0;
  background-color: rgb(19, 23, 35);
}
.modal--passo1 .embla__slide .embla__slide__plan {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.25rem;
}
.modal--passo1 .embla__slide .embla__slide__plan p {
  font-size: 1.0625rem;
  font-weight: 700;
}
.modal--passo1 .embla__slide .embla__slide__plan .embla__slide__plan__price {
  display: flex;
  align-items: flex-end;
}
.modal--passo1 .embla__slide .embla__slide__plan .embla__slide__plan__price span:first-child {
  font-family: GothamBlack, sans-serif;
  font-weight: 900;
  font-size: 2.5rem;
  line-height: 2.125rem;
}
.modal--passo1 .embla__slide .embla__slide__plan .embla__slide__plan__price span:last-child {
  font-family: GothamBlack, sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
}
.modal--passo1 .active {
  background-color: #6fb846;
}
.modal--passo1 .active .embla__slide__line {
  background-color: #ffffff;
}
.modal--passo1 .div__embla__buttons {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  pointer-events: none;
}
.modal--passo1 .div__embla__buttons button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transition: 0.3s;
  outline: none;
  pointer-events: all !important;
}
.modal--passo1 .modal--passo1__buttons {
  padding: 0 2.5rem 2.5rem 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo1 .modal--passo1__buttons {
    padding: 0 1.5rem 2rem 1.5rem;
  }
}

.modal--passo2 {
  max-width: 33.75rem;
  padding: 0 2.5rem 2.5rem 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo2 {
    padding: 0 1.5rem 2rem 1.5rem;
  }
}
.modal--passo2 > h1 {
  color: #ffffff;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo2 > h1 {
    font-size: 1.125rem;
  }
}
.modal--passo2 .modal--passo2__content {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.modal--passo2 .modal--passo2__content .modal--passo2__content__img {
  flex-shrink: 0;
  width: 5rem;
  height: 5rem;
  border-radius: 0.5rem;
  overflow: hidden;
}
.modal--passo2 .modal--passo2__content .modal--passo2__content__info h2 {
  margin-bottom: 0.625rem;
  font-size: 1.125rem;
  font-weight: 700;
  color: #FFF;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo2 .modal--passo2__content .modal--passo2__content__info h2 {
    font-size: 0.875rem;
  }
}
.modal--passo2 .modal--passo2__content .modal--passo2__content__info p {
  font-size: 0.75rem;
  color: #FFF;
  line-height: 1.5;
}
.modal--passo2 .modal--passo2__productprice {
  display: flex;
  align-items: center;
  gap: 1rem;
  justify-content: space-between;
}
.modal--passo2 .modal--passo2__productprice h3 {
  color: #FFF;
  font-size: 1rem;
  font-weight: 700;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo2 .modal--passo2__productprice h3 {
    font-size: 0.875rem;
  }
}
.modal--passo2 .modal--passo2__productprice div {
  display: flex;
  gap: 1.25rem;
  align-items: center;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo2 .modal--passo2__productprice div {
    gap: 1rem;
  }
}
.modal--passo2 .modal--passo2__productprice div p, .modal--passo2 .modal--passo2__productprice div span {
  color: #FFF;
}
.modal--passo2 .modal--passo2__productprice div span {
  width: 2rem;
  padding: 0.25rem;
  background-color: #6fb846;
  font-size: 0.625rem;
  border-radius: 0.25rem;
  text-align: center;
}
.modal--passo2 .modal--passo2__productprice div p {
  font-size: 1.125rem;
  font-weight: 700;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo2 .modal--passo2__productprice div p {
    font-size: 0.875rem;
  }
}
.modal--passo2 .modal--passo1__buttons {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}

.modal--passo3 {
  max-width: 61.25rem;
  padding: 0 2.5rem 2.5rem 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
@media screen and (max-width: 64rem) {
  .modal--passo3 {
    height: 60vh;
    overflow-y: auto;
  }
}
@media screen and (max-width: 48rem) {
  .modal--passo3 {
    padding: 0 1.5rem 2.5rem 1.5rem;
  }
}
.modal--passo3 > h1 {
  color: #ffffff;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo3 > h1 {
    font-size: 1.125rem;
  }
}
.modal--passo3 .modal--passo3__content {
  display: flex;
}
@media screen and (max-width: 64rem) {
  .modal--passo3 .modal--passo3__content {
    flex-direction: column;
  }
}
.modal--passo3 .modal--passo3__content1 .content1__flex {
  margin-bottom: 2rem;
  display: flex;
  gap: 1rem;
}
.modal--passo3 .modal--passo3__content1 .content1__flex .content1__flex__img {
  width: 5rem;
  height: 5rem;
  border-radius: 0.5rem;
  overflow: hidden;
  flex-shrink: 0;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo3 .modal--passo3__content1 .content1__flex .content1__flex__img {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 0.25rem;
  }
}
.modal--passo3 .modal--passo3__content1 .content1__flex .content1__flex__price h2 {
  margin-bottom: 1rem;
  color: #FFF;
  font-size: 1.125rem;
  font-weight: 700;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo3 .modal--passo3__content1 .content1__flex .content1__flex__price h2 {
    font-size: 0.875rem;
  }
}
.modal--passo3 .modal--passo3__content1 .content1__flex .content1__flex__price p {
  margin-bottom: 0.25rem;
  color: #FFF;
  font-size: 1rem;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo3 .modal--passo3__content1 .content1__flex .content1__flex__price p {
    font-size: 0.75rem;
  }
}
.modal--passo3 .modal--passo3__content1 .content1__flex .content1__flex__price span {
  color: #FFF;
  font-size: 1.125rem;
  font-weight: 700;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo3 .modal--passo3__content1 .content1__flex .content1__flex__price span {
    font-size: 0.875rem;
  }
}
.modal--passo3 .modal--passo3__content1 .content1__cart {
  max-width: 22.625rem;
  min-height: 14.875rem;
  padding: 1.625rem 1.875rem 2.25rem 1.875rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 2.5rem;
  background-color: rgb(187, 187, 187);
  border-radius: 0.5rem;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo3 .modal--passo3__content1 .content1__cart {
    min-height: 12.5rem;
    gap: 2rem;
    padding: 1.625rem 1rem;
  }
}
.modal--passo3 .modal--passo3__content1 .content1__cart .content1__cart__chip {
  flex-shrink: 0;
}
.modal--passo3 .modal--passo3__content1 .content1__cart .content1__cart__chip img {
  width: 2.58875rem;
  height: 1.6475rem;
}
.modal--passo3 .modal--passo3__content1 .content1__cart .content1__cart__number {
  color: #67696E;
  font-family: Consolas, Courier, monospace;
  font-size: 1.25rem;
}
.modal--passo3 .modal--passo3__content1 .content1__cart .content1__cart__data {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
}
.modal--passo3 .modal--passo3__content1 .content1__cart .content1__cart__data #titular-name {
  width: 100%;
  font-family: Consolas, Courier, monospace;
  font-size: 1.0625rem;
  line-height: 1;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  text-transform: uppercase;
  font-weight: bold;
}
.modal--passo3 .modal--passo3__content1 .content1__cart .content1__cart__data div {
  flex-shrink: 0;
}
.modal--passo3 .modal--passo3__content1 .content1__cart .content1__cart__data div p {
  color: #67696E;
}
.modal--passo3 .modal--passo3__content1 .content1__cart .content1__cart__data div p:first-child {
  font-size: 0.625rem;
  margin-bottom: 0.3125rem;
}
.modal--passo3 .modal--passo3__content1 .content1__cart .content1__cart__data div p:last-child {
  font-family: Consolas, Courier, monospace;
  font-size: 1rem;
}
.modal--passo3 .modal--passo3__content2 {
  width: 25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo3 .modal--passo3__content2 {
    width: 100%;
  }
}
.modal--passo3 .modal--passo3__content2 label {
  display: flex;
  position: relative;
  align-items: center;
  width: 100%;
  background-color: rgb(30, 34, 47);
  overflow: hidden;
  border-radius: 8px;
}
.modal--passo3 .modal--passo3__content2 input {
  min-height: 50px;
  background-color: transparent;
  font-family: GothamBook, sans-serif;
  font-size: 0.875rem;
  color: #ffffff;
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 0;
  outline: none;
  border-radius: 8px;
  border: 2px solid rgb(30, 34, 47);
  transition: 0.3s;
}
.modal--passo3 .modal--passo3__content2 input:focus {
  border: 2px solid #ffffff;
}
.modal--passo3 .modal--passo3__content2 input::-moz-placeholder {
  color: #bbbbbb;
  font-size: 0.875rem;
  font-family: GothamBold, sans-serif;
}
.modal--passo3 .modal--passo3__content2 input::placeholder {
  color: #bbbbbb;
  font-size: 0.875rem;
  font-family: GothamBold, sans-serif;
}
.modal--passo3 .modal--passo3__content2 .button--green {
  margin-top: 1.5rem;
}
@media screen and (max-width: 33.75rem) {
  .modal--passo3 .modal--passo3__content2 .button--green {
    margin-top: 0;
  }
}
.modal--passo3 .modal--passo3__line {
  flex-shrink: 0;
  width: 0.125rem;
  min-height: 100%;
  margin: 0 1.5rem;
  background-color: rgb(30, 34, 47);
}
@media screen and (max-width: 64rem) {
  .modal--passo3 .modal--passo3__line {
    min-height: 0.125rem;
    width: 100%;
    margin: 1.5rem 0;
  }
}
.modal--passo3 .modal--passo3__copy .modal--passo3__copy__div1,
.modal--passo3 .modal--passo3__copy .modal--passo3__copy__div2 {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.modal--passo3 .modal--passo3__copy .modal--passo3__copy__div1 {
  margin-bottom: 0.5rem;
}
.modal--passo3 .modal--passo3__copy .modal--passo3__copy__div1 span {
  color: #FFF;
  font-size: 0.5rem;
}
.modal--passo3 .modal--passo3__copy .modal--passo3__copy__div2 p {
  color: #FFF;
  font-size: 0.75rem;
}

.modal--passo1, .modal--passo2, .modal--passo3 {
  display: none;
}

.active--step {
  display: flex !important;
}

.cancel--button {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.875rem;
  border-radius: 2rem;
  padding: 1em;
  cursor: pointer;
  background: transparent;
  color: #ffffff;
  text-align: center;
  border: none;
  transition: 0.3s;
}
.cancel--button:hover {
  color: rgb(204, 204, 204);
}

.modal__video {
  width: 100%;
  height: 100vh;
  padding: 2.5rem 1.25rem;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 9999;
  display: none;
  justify-content: center;
  align-items: center;
  background-color: rgba(0, 0, 0, 0.4);
}
.modal__video.show--video {
  display: flex;
}
.modal__video.show--video .modal__video__container {
  opacity: 1;
}
.modal__video .modal__video__container {
  max-width: 68.75rem;
  margin: 0 auto;
  opacity: 0;
}
@media screen and (max-width: 64rem) {
  .modal__video .modal__video__container {
    max-width: 60rem;
  }
}
.modal__video #btn--close--modalvideo {
  width: -moz-fit-content;
  width: fit-content;
  height: -moz-fit-content;
  height: fit-content;
  margin: 0 auto 2rem auto;
  padding: 0.75rem;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  background-color: red;
  border: none;
  cursor: pointer;
  transition: 0.3s;
}
.modal__video #btn--close--modalvideo:hover {
  background-color: #a30000;
}
.modal__video video {
  max-width: 100%;
  height: auto;
  display: block;
  border-radius: 0.5rem;
  overflow: hidden;
}

.header {
  width: 100%;
  padding: 1rem 5rem;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1541;
  background-color: rgb(9, 12, 21);
}
@media screen and (max-width: 64rem) {
  .header {
    padding: 1rem 1.5rem;
  }
}
@media screen and (max-width: 33.75rem) {
  .header {
    padding: 1rem;
  }
}
.header .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.header .header__logo {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 2rem;
}
.header .header__list {
  display: flex;
  align-items: center;
  gap: 2rem;
}
@media screen and (max-width: 48rem) {
  .header .header__list {
    gap: 0.5rem;
  }
}
.header .header__list a {
  display: block;
  color: #fff;
}
@media screen and (max-width: 64rem) {
  .header .header__list svg {
    display: none;
  }
}
@media screen and (max-width: 48rem) {
  .header .header__list .button--outline {
    display: none;
  }
}
@media screen and (max-width: 33.75rem) {
  .header .header__list .button--green {
    padding: 0.75rem 1.25rem;
    font-size: 0.75rem;
  }
}
.header .list1 a {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  font-size: 0.9375rem;
  transition: 0.3s;
  font-weight: 700;
  text-decoration: none;
  color: #ffffff;
  filter: brightness(0.7);
  transition: 0.3s filter;
}
.header .list1 a:hover {
  filter: brightness(1);
}
.header .list1 .active {
  filter: brightness(1);
  text-transform: uppercase;
}
@media screen and (max-width: 64rem) {
  .header .list1 {
    display: none;
  }
}

.main {
  min-height: 90vh;
  height: auto;
  padding: 2.5rem 5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  position: relative;
}
@media screen and (max-width: 64rem) {
  .main {
    padding: 1rem 1.5rem;
  }
}
@media screen and (max-width: 33.75rem) {
  .main {
    min-height: auto;
    padding: 5rem 1.5rem;
  }
}
.main::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  background: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)) center center/cover no-repeat, url("../imgs/banner-main.webp");
  background-position: center center;
  background-repeat: no-repeat;
}
.main::after {
  content: "";
  position: absolute;
  width: 100%;
  left: 0;
  height: 7rem;
  top: auto;
  bottom: -0.0625rem;
  background: linear-gradient(0deg, rgb(19, 23, 35) 2.05%, rgba(19, 23, 35, 0) 98.59%);
}
.main .container {
  width: 100%;
  margin-top: 3.75rem;
}
.main .main__info {
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 48rem) {
  .main .main__info {
    align-items: center;
  }
}
.main .main__info > svg {
  margin-bottom: 1rem;
}
.main .main__info .main__info__title {
  margin-bottom: 1.25rem;
  max-width: 42.5rem;
  color: #fff;
  font-size: 2.5rem;
  font-weight: bold;
  line-height: 1.25;
}
@media screen and (max-width: 33.75rem) {
  .main .main__info .main__info__title {
    text-align: center;
    font-size: 2rem;
  }
}
.main .main__info .main__info__descricao {
  color: #fff;
  font-size: 1.125rem;
}
.main .main__info .main__info__list {
  margin: 1.5rem 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
@media screen and (max-width: 33.75rem) {
  .main .main__info .main__info__list {
    flex-wrap: wrap;
    justify-content: center;
  }
}
.main .main__info .main__info__list li {
  color: #fff;
  font-size: 0.875rem;
}
.main .main__info .main__info__prices {
  max-width: 29.375rem;
  margin: 1rem 0 1.5rem 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.main .main__info .main__info__prices .main__info__prices__svg {
  width: 3rem;
  height: 3rem;
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #ffffff;
  border-radius: 50%;
}
.main .main__info .main__info__prices p {
  color: #FFF;
  font-size: 0.875rem;
  line-height: 1.3;
  font-weight: 700;
}
.main .main__info .main__info__prices p span {
  color: #6fb846;
}
.main .main__info .main__info__buttons {
  max-width: 620px;
  margin-top: 1rem;
  display: flex;
  gap: 1.5rem;
}
.main .main__info .main__info__buttons a {
  width: 100%;
}
@media screen and (max-width: 48rem) {
  .main .main__info .main__info__buttons {
    width: 100%;
  }
}
@media screen and (max-width: 33.75rem) {
  .main .main__info .main__info__buttons {
    flex-direction: column;
  }
}
.main .main__line {
  max-width: 38.75rem;
  width: 100%;
  height: 0.0625rem;
  margin: 1.5rem 0;
  display: block;
  background-color: #313542;
}
.main .main__program {
  display: flex;
  gap: 1rem;
  align-items: center;
}
.main .main__program p {
  margin-bottom: 0.5rem;
  color: #6fb846;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.3;
}
.main .main__program span {
  max-width: 15.5625rem;
  display: block;
  color: #fff;
  font-size: 0.75rem;
  line-height: 1.3;
}

.main-curso2::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  background: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)) center center/cover no-repeat, url("../imgs/banner-main2.webp");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

.main-curso3::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  background: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)) center center/cover no-repeat, url("../imgs/banner-main3.webp");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

.main-curso4::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  background: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)) center center/cover no-repeat, url("../imgs/banner-main4.webp");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

.section__header {
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.section__header h1 {
  color: #fff;
  font-family: GothamBold, sans-serif;
  font-size: 1.75rem;
  font-weight: 700;
}
@media screen and (max-width: 64rem) {
  .section__header h1 {
    font-size: 1.5rem;
  }
}

.section1__page1 {
  padding: 1rem 5rem;
}
@media screen and (max-width: 64rem) {
  .section1__page1 {
    padding: 1rem 1.5rem;
  }
}
.section1__page1 a {
  display: inline-block;
}

.section1__page2,
.section1__page3,
.section1__page4,
.section1__page5,
.section1__page6 {
  margin-top: 3rem;
  padding: 1rem 5rem;
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 64rem) {
  .section1__page2,
  .section1__page3,
  .section1__page4,
  .section1__page5,
  .section1__page6 {
    padding: 1rem 1.5rem;
  }
}

.footer {
  padding: 1.5rem 3.5rem 2.5rem;
}
@media screen and (max-width: 64rem) {
  .footer {
    padding: 3.5rem 1.5rem;
  }
}
.footer .footer__div1 {
  margin-bottom: 2rem;
  display: flex;
  gap: 1rem;
  justify-content: space-between;
}
@media screen and (max-width: 48rem) {
  .footer .footer__div1 {
    flex-direction: column-reverse;
    align-items: center;
    gap: 2rem;
  }
}
.footer .footer__div1 .footer__div1__links {
  display: flex;
  align-items: center;
  gap: 2.5rem;
}
@media screen and (max-width: 48rem) {
  .footer .footer__div1 .footer__div1__links {
    flex-direction: column-reverse;
    align-items: center;
    gap: 1.5rem;
  }
}
.footer .footer__div1 .footer__div1__links__link {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  flex-wrap: wrap;
}
@media screen and (max-width: 48rem) {
  .footer .footer__div1 .footer__div1__links__link {
    justify-content: center;
  }
}
.footer .footer__div1 .footer__div1__links__link a {
  font-family: GothamBold, sans-serif;
  font-size: 0.875rem;
  font-weight: 700;
  color: #ffffff;
  transition: 0.3s;
}
.footer .footer__div1 .footer__div1__links__link a:hover svg {
  fill: #6fb846;
}
.footer .footer__div1 .footer__div1__img {
  flex-shrink: 0;
}
.footer .footer__div2 {
  color: #FFF;
  font-size: 0.875rem;
  line-height: 1.5;
}
@media screen and (max-width: 48rem) {
  .footer .footer__div2 {
    text-align: center;
  }
}

.section1__page2 {
  padding: 1rem 5rem;
}
@media screen and (max-width: 64rem) {
  .section1__page2 {
    padding: 1rem 1.5rem;
  }
}
.section1__page2 ul {
  display: flex;
  gap: 3.5rem;
  width: 100%;
  border-bottom: 1px solid rgb(49, 53, 66);
  overflow: auto hidden;
}
@media screen and (max-width: 48rem) {
  .section1__page2 ul {
    gap: 0;
  }
}
.section1__page2 li {
  padding: 1rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  color: #FFF;
  font-size: 0.75rem;
  font-weight: 700;
  text-align: center;
  white-space: nowrap;
  transition: 0.3s;
  cursor: pointer;
  position: relative;
}
@media screen and (max-width: 48rem) {
  .section1__page2 li {
    gap: 0.5rem;
  }
}
.section1__page2 li svg {
  flex-shrink: 0;
}
.section1__page2 li.active {
  color: #6FB846;
}
.section1__page2 li.active::before {
  content: "";
  width: 100%;
  height: 0.25rem;
  position: absolute;
  left: 0;
  bottom: -0.125rem;
  background-color: #6FB846;
  border-radius: 10rem;
}

.section2__page2 {
  padding: 2.5rem 5rem;
}
@media screen and (max-width: 64rem) {
  .section2__page2 {
    padding: 1rem 1.5rem;
  }
}
.section2__page2 .section2__page2__container {
  max-width: 54.875rem;
  margin: 0 auto;
  border: 1px solid #313542;
}
.section2__page2 .section2__page2__header {
  padding: 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  background-color: #131723;
}
.section2__page2 .section2__page2__header h1 {
  color: #FFF;
  font-size: 1rem;
  font-weight: 700;
}
.section2__page2 .section2__page2__list {
  display: flex;
  flex-direction: column;
}
.section2__page2 .section2__page2__listitem {
  padding: 1rem;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  background-color: #1e222f;
  border-top: 1px solid rgb(49, 53, 66);
}
@media screen and (max-width: 33.75rem) {
  .section2__page2 .section2__page2__listitem {
    gap: 1rem;
    align-items: flex-end;
  }
}
.section2__page2 .section2__page2__listitem .listitem__details {
  width: 100%;
  max-width: 42.62125rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}
@media screen and (max-width: 33.75rem) {
  .section2__page2 .section2__page2__listitem .listitem__details {
    align-items: flex-start;
    flex-direction: column;
  }
}
.section2__page2 .section2__page2__listitem .listitem__details__min {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.section2__page2 .section2__page2__listitem .listitem__details__min p {
  color: #fff;
  font-size: 0.75rem;
  font-weight: bold;
}
.section2__page2 .section2__page2__listitem .listitem__details__img {
  flex-shrink: 0;
  width: 9rem;
  height: 5rem;
  overflow: hidden;
  border-radius: 0.5rem;
}
@media screen and (max-width: 33.75rem) {
  .section2__page2 .section2__page2__listitem .listitem__details__img {
    order: 1;
  }
}
.section2__page2 .section2__page2__listitem .listitem__details__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
.section2__page2 .section2__page2__listitem .listitem__details__info {
  display: flex;
  flex-direction: column;
}
.section2__page2 .section2__page2__listitem .listitem__details__info .listitem__details__info__episode {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.section2__page2 .section2__page2__listitem .listitem__details__info .listitem__details__info__episode p {
  color: #FFF;
  font-size: 0.75rem;
  font-weight: bold;
}
.section2__page2 .section2__page2__listitem .listitem__details__info .listitem__details__info__text p {
  margin: 0.5rem 0;
  color: #FFF;
  font-size: 1rem;
  font-weight: bold;
}
.section2__page2 .section2__page2__listitem .listitem__details__info .listitem__details__info__text span {
  display: block;
  color: #FFF;
  font-size: 0.625rem;
  font-weight: bold;
}
.section2__page2 .section2__page2__listitem button {
  flex-shrink: 0;
  width: 2.75rem;
  height: 2.75rem;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #6FB846;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  transition: 0.3s;
}
.section2__page2 .section2__page2__listitem button:hover {
  background-color: #589338;
}
.feedback-message{
    width: min(100%, 20rem);
    padding: 1rem 1.25rem;
    position: fixed;
    top: 1.5rem;
    right: 1.5rem;
    z-index: 99999;
    font-size: 1.125rem;
    color: white;
    font-weight: 500;
    line-height: 1.5;
    border-radius: 0.5rem;
    transition: .3s;
    visibility: hidden;
    opacity: 0;
}
.feedback-message.success-active{
    background-color: #70b946;
    visibility: visible;
    opacity: 1;
}
.feedback-message.error-active{
    background-color: red;
    visibility: visible;
    opacity: 1;
}
.custom-loader {
  width: 2rem;
  height: 2rem;
  margin: 0.5rem auto;
  display: none;
  border-radius:50%;
  border: 6px solid;
  border-color:#E4E4ED;
  border-right-color: #52F429;
  animation:s2 1s infinite linear;
}

.custom-loader.show{
    display: block;
}

@keyframes s2 {
    to{transform: rotate(360deg);}
}