:root {
  --clr-purple: hsl(259, 100%, 65%);
  --clr-light-red: hsl(0, 100%, 67%);
  --clr-white: hsl(0, 0%, 100%);
  --clr-off-white: hsl(0, 0%, 94%);
  --clr-light-grey: hsl(0, 0%, 86%);
  --clr-smokey-grey: hsl(0, 1%, 44%);
  --clr-off-black: hsl(0, 0%, 8%);
  --font-size-input: 2rem;
  --font-weight-700: 700;
  --font-weight-800: 800;
}

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

body {
  height: 100vh;
  display: grid;
  grid-template-rows: 1fr auto;
  font-family: "Poppins", sans-serif;
  background-color: var(--clr-off-white);
}

main {
  display: flex;
  justify-content: center;
  align-items: center;
}
.form-container {
  width: min(90%, 600px);
  background-color: var(--clr-white);
  padding: 1rem;
  border-bottom-right-radius: 30px;
  box-shadow: 0px 0px 6px rgba(0, 0, 0, 0.1);
}

.form-container label {
  display: block;
  color: var(--clr-smokey-grey);
  font-weight: var(--font-weight-700);
  font-size: 16px;
}

.form-input {
  display: flex;
  gap: 1rem;
  margin-bottom: 1rem;
}
.form-input div {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
input {
  border: 1px solid var(--clr-light-grey);
  width: 100%;
  max-width: 130px;
  border-radius: 5px;
  outline: none;
  padding: 1rem;
  text-align: center;
  font-size: 20px;
  font-weight: var(--font-weight-700);
}

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

input::placeholder {
  text-align: center;
  font-size: 20px;
  font-weight: var(--font-weight-700);
}
.submit-block {
  display: flex;
  align-items: center;
}
.border-line {
  border: 1px solid var(--clr-light-grey);
  width: 100%;
  display: block;
}

.img-wrapper {
  background-color: var(--clr-purple);
  display: inline-block;
  padding: 0.5rem;
  border-radius: 50%;
  cursor: pointer;
  border: none;
}
.img-wrapper:hover {
  background-color: var(--clr-off-black);
  transition: 0.3s ease-in;
}
.result-container {
  margin-top: 1rem;
  font-size: var(--font-size-input);
  font-weight: var(--font-weight-800);
  font-size: var(--font-size-input);
}
.result-container span {
  color: var(--clr-purple);
}

.error-text {
  font-size: 12px;
  color: var(--clr-light-red);
}

@media (max-width: 550px) {
  .img-wrapper {
    left: 40%;
    position: absolute;
  }
  .submit-block {
    position: relative;
  }
  .form-input {
    margin-bottom: 2rem;
  }
  .result-container {
    margin-top: 2rem;
  }
  .error-text {
    font-size: 8px;
  }
}
/******
END CREDITS
******/
.attribution {
  font-size: 11px;
  text-align: center;
}
.attribution a {
  color: hsl(228, 45%, 44%);
}
