:root {
  --main-color: #ffb3c0;
  --sub-color: #fef7f9;
  --text-color: #2c4b61;
  --accent-color: #ff9927;
  --support-color: #fce6d0;
  --secondary-color: #e37e8f;
}

body {
  font-family: sans-serif;
  max-width: 800px;
  margin: 0 auto;
  padding: 50px 20px;
  color: var(--text-color);
  background-color: var(--sub-color);
}

label {
  display: block;
  margin-top: 1em;
}

input,
textarea,
select {
  width: 100%;
  padding: 0.5em;
  margin-top: 0.3em;
  box-sizing: border-box;
  font-size: 0.9rem;
  border-radius: 6px;
  border: 1px solid #999;
}

.checkbox-group label {
  display: inline-block;
  margin-right: 1em;
}

.btn-wrap {
  text-align: center;
  margin-top: 50px;
}

.required {
  font-size: 0.8em;
  color: var(--secondary-color);
}

.flex {
  display: flex;
}

.label-wrap {
  align-items: center;
  gap: 0.5em;

  label {
    margin-top: 0;
    font-weight: normal;
  }
}

.tac {
  text-align: center;
}

.mt50 {
  margin-top: 50px;
}

input {
  &[type="checkbox"],
  &[type="radio"] {
    width: 1em;
    aspect-ratio: 1/1;
  }
}

button {
  background-color: var(--main-color);
  filter: drop-shadow(0px 3px 0px var(--darck-pink, #e37e8f));
  color: #fff;
  border: none;
  cursor: pointer;
  border-radius: 4px;
  transition: 0.1s;
  padding: 1rem 2rem;
  letter-spacing: 0.5em;
  font-size: 1.2rem;

  &:hover {
    filter: none;
    transform: translateY(3px);
  }
}

.no-spacing {
  letter-spacing: normal;
}

h1 {
  color: var(--accent-color);
  text-align: center;
  margin-bottom: 30px;

  @media (max-width: 430px) {
    font-size: 6vw;
  }
}

p + p {
  margin-top: 1em;
}

label {
  font-weight: bold;
}

form {
  margin-top: 50px;
}

@media (max-width: 430px) {
  html {
    font-size: 15px;
  }
}
