/* Reset e Root
======================================== */

@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@400;700&family=Space+Mono&display=swap");

:root {
  /*  Primary */

  --Tomato: hsl(4, 100%, 67%);

  /*  Neutral */

  --DarkSlateGrey: hsl(234, 29%, 20%);
  --CharcoalGrey: hsl(235, 18%, 26%);
  --Grey: hsl(231, 7%, 60%);
  --White: hsl(0, 0%, 100%);

  --gradient-pink: #ff3e83;
  --gradient-orange: #fd634a;
  --gradient-shadow: #ff3e8355;

  /*  Typography  */

  /*   Body Copy Paragrafo*/

  --Font-size: 16px;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  background: var(--CharcoalGrey);
  font-family: "Roboto";
  width: 100%;
  height: 100%;
}

.hidden {
  display: none !important;
}

.active {
  display: block !important;
}

main {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100vh;
}

main .main__container {
  background: var(--White);
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
  max-width: 820px;
  margin: 0 auto;
  padding: 20px;
  border-radius: 1rem;
  color: var(--DarkSlateGrey);
  box-shadow: 0 0 7rem 1rem #00000055;
}

main .main__container .main__container--text {
  margin: 1.5rem 2rem;
}

main .main__container .main__container--text .main__container--text--h1 {
  font-size: 2.5rem;
  font-weight: bold;
}

main .main__container .main__container--text .main__container--text--p01 {
  font-size: var(--Font-size);
  padding: 1rem 0;
}

main .main__container .main__container--text .main__container--text--p02 {
  line-height: 2rem;
}

main
  .main__container
  .main__container--text
  .main__container--text--p02
  .main__container--text--icon {
  margin-right: 10px;
  position: relative;
  top: 0.2rem;
}

/* form */

main .main__container .main__container--form {
  margin-top: 2rem;
}

main .main__container .main__container--form .main__container--form--label {
  font-size: 1rem;
  font-weight: bold;
}

main
  .main__container
  .main__container--form
  .main__container--form--input--email {
  padding: 1rem;
  width: 90%;
  margin-top: 1rem;
  margin-bottom: 1rem;
  cursor: pointer;
  border-radius: 0.5rem;
  letter-spacing: 0.5px;
  border: none;
}

/* Input Email efeito */

main
  .main__container
  .main__container--form
  .main__container--form--input--email:hover {
  border: solid 0.2px var(--DarkSlateGrey);
  transition: 0.5;
}

/* ======================================= */

main
  .main__container
  .main__container--form
  .main__container--form--input--btn {
  padding: 1rem;
  width: 90%;
  background: var(--DarkSlateGrey);
  color: var(--White);
  cursor: pointer;
  border-radius: 0.5rem;
  border: none;
}

/* Button Efeito */

main
  .main__container
  .main__container--form
  .main__container--form--input--btn:hover {
  color: var(--White);
  background: var(--Tomato);
  box-shadow: 0 4px 8px hsl(4, 100%, 67%);
  transition: linear 0.5s;
}

main
  .main__container
  .main__container--form
  .main__container--form--input--btn:active {
  transform: scale(0.98);
  box-shadow: none;
}

/* ====================================== */

/* img */

main .main__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ========================== */

/* mensagem de confirmação */

.containerCorfimacao {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-width: 400px;
  background: var(--White);
  padding: 2rem 2rem;
  border-radius: 0.5rem;
  display: none;
}

.containerCorfimacao .containerCorfimacao__text .containerCorfimacao__text--h1 {
  font-size: 2.5rem;
  font-weight: bold;
  padding: 1rem 0;
}

.containerCorfimacao .containerCorfimacao__text .containerConfirmacao__text--p {
  font-size: 15px;
  padding-bottom: 2rem;
  line-height: 1.2rem;
}

.containerCorfimacao .containerCorfimacao__text .containerCorfimacao__btn {
  padding: 1rem;
  width: 100%;
  background: var(--DarkSlateGrey);
  color: var(--White);
  cursor: pointer;
  border-radius: 0.5rem;
  border: none;
}

.containerCorfimacao
  .containerCorfimacao__text
  .containerCorfimacao__btn:hover {
  color: var(--White);
  background: var(--Tomato);
  box-shadow: 0 4px 8px hsl(4, 100%, 67%);
  transition: linear 0.5s;
}

/*  ========================================== */

/* Adicione estas regras de media query para estilos responsivos */

/* Para telas menores que 768px (como smartphones) */
@media screen and (max-width: 768px) {
  main .main__container {
    align-items: center;
    flex-direction: column-reverse;
    width: 100%;
    position: relative;
  }

  main .main__container .main__container--text {
    margin: 1.5rem 0;
  }

  main
    .main__container
    .main__container--form
    .main__container--form--input--email,
  main
    .main__container
    .main__container--form
    .main__container--form--input--btn {
    width: 100%;
  }
}

@media screen and (max-width: 480px) {
  main .main__container .main__container--text .main__container--text--h1 {
    font-size: 2rem;
  }

  main .main__container .main__container--form .main__container--form--label,
  main
    .main__container
    .main__container--form
    .main__container--form--input--email,
  main
    .main__container
    .main__container--form
    .main__container--form--input--btn {
    font-size: 0.9rem;
  }
}
