@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

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

:root {
  --red-400: hsl(0, 100%, 74%);
  --green-400: hsl(154, 59%, 51%);
  --purple-700: hsl(248, 32%, 49%);
  --purple-350: hsl(246, 25%, 77%);
  --gray-900: hsl(249, 10%, 26%);
}

body {
  font-size: 16px;
  font-family: "Poppins", sans-serif;
  background-image: url(../images/bg-intro-desktop.png);
  background-color: var(--red-400);
  min-height: 100vh;
  padding: 4rem 1.75rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 3rem;
}

main .container {
  max-width: 950px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  justify-content: center;
  gap: 2rem;
}

main .container .first-container {
  color: #fff;
  margin: auto 0;
}

main .container .first-container h1 {
  font-size: 3rem;
  font-weight: 700;
  margin-bottom: 1rem;
}

main .container .second-container {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.message-container, .form-container {
  box-shadow: 0 7px 4px 0px hsl(249, 10%, 26%, 30%);
}

main .container .second-container .message-container {
  color: #fff;
  background-color: var(--purple-700);
  border-radius: .5rem;
}

main .container .second-container .message-container .message {
  text-align: center;
  padding: 1rem;
  font-weight: 600;
}

main .container .second-container .message-container .message span {
  color: var(--purple-350);
  font-weight: 400;
}

main .container .second-container .form-container {
  background-color: #fff;
  text-align: center;
  padding: 2rem;
  border-radius: .5rem;
}

input, button {
  width: 100%;
  padding: 1rem 1.5rem;
  outline: none;
  font-weight: 700;
  border-radius: .25rem;
  letter-spacing: 1px;
}

input {
  border: 1px solid var(--purple-350);
}

button {
  border-color: var(--green-400);
}

input:focus {
  border-color: var(--purple-700);
}

.form-group, button {
  margin-bottom: 1rem;
}

.form-group p {
  display: none;
  text-align: right;
  font-size: .6rem;
  margin-top: .5rem;
  font-style: italic;
  color: var(--red-400);
  font-weight: 500;
}

button {
  color: #fff;
  background-color: var(--green-400);
  text-transform: uppercase;
}

.input-box {
  position: relative;
}

.form-group .input-box i {
  display: none;
  position: absolute;
  top: 25%;
  right: 5%;
  font-size: 1.5rem;
  color: var(--red-400);
}

main .container .second-container .form-container .agreement {
  font-size: .6rem;
  font-weight: 500;
  color: var(--purple-350);
}

main .container .second-container .form-container .agreement a {
  text-decoration: none;
  color: var(--red-400);
}

footer .attribution {
  font-size: 10px;
  text-align: center;
  color: #fff;
}

footer .attribution a {
  background-color: var(--purple-700);
  padding: .5rem;
  border-radius: 1rem;
  color: #fff;
  text-decoration: none;
  border: 1px solid var(--purple-700);
}

footer .attribution a:hover {
  color: var(--purple-700);
  background-color: #fff;
}

@media (max-width: 768px) {
  main .container {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
  }
  
  main .container .first-container h1 {
    font-size: 2rem;
  }
  
  main .container .second-container .message-container {
    padding: 0 2rem;
  }
}