@charset "UTF-8";
.grecaptcha-badge {
  visibility: hidden;
}

input:-webkit-autofill {
  box-shadow: 0 0 0px 1000px #FFFFFF inset;
  -webkit-text-fill-color: #242424;
  transition: background-color 9999s ease-out;
  transition-delay: 9999s;
}

.contact__step .contact__step-list {
  display: flex;
  justify-content: center;
}
.contact__step .contact__step-list .contact__step-item {
  width: 32px;
}
@media (max-width: 1023px) {
  .contact__step .contact__step-list .contact__step-item {
    width: 14px;
  }
}
.contact__step .contact__step-list .contact__step-item:not(:first-child) {
  position: relative;
  margin-left: 180px;
}
@media (max-width: 1023px) {
  .contact__step .contact__step-list .contact__step-item:not(:first-child) {
    margin-left: 100px;
  }
}
.contact__step .contact__step-list .contact__step-item:not(:first-child)::before {
  content: "";
  width: 180px;
  height: 1px;
  position: absolute;
  top: 16px;
  left: 0;
  transform: translate(-100%, -50%);
  border-top: 1px dashed #FFFFFF;
}
@media (max-width: 1023px) {
  .contact__step .contact__step-list .contact__step-item:not(:first-child)::before {
    width: 100px;
    top: 7px;
  }
}
.contact__step .contact__step-list .contact__step-item .contact__step-circle {
  width: 100%;
  aspect-ratio: 1;
  display: block;
  border-radius: 50%;
  background-color: #4D4D4D;
}
.contact__step .contact__step-list .contact__step-item .contact__step-label {
  display: block;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.1em;
  white-space: nowrap;
  margin-top: 20px;
}
@media (max-width: 1023px) {
  .contact__step .contact__step-list .contact__step-item .contact__step-label {
    position: relative;
    transform: translateX(-65%);
    margin-top: 10px;
  }
}

.contact {
  background-color: #242424;
  padding-top: 200px;
}
@media (max-width: 1023px) {
  .contact {
    padding-top: 60px;
  }
}
.contact.is_confirm .contact__step .contact__step-list .contact__step-item--input .contact__step-circle {
  background-color: #4D4D4D;
}
.contact.is_confirm .contact__step .contact__step-list .contact__step-item--confirm .contact__step-circle {
  background-color: #FFFFFF;
}
.contact.is_confirm .contact__info--input {
  display: none;
}
.contact.is_confirm .contact__info--confirm {
  display: flex;
}
.contact.is_confirm .contact-form .contact-form__input-area {
  display: none;
}
.contact.is_confirm .contact-form .contact-form__confirm-area {
  display: block;
}
.contact .contact__step .contact__step-list .contact__step-item--input .contact__step-circle {
  background-color: #FFFFFF;
}
.contact .contact__info {
  width: 100%;
  letter-spacing: 0.1em;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  padding-bottom: 120px;
  margin-top: 120px;
}
@media (max-width: 1023px) {
  .contact .contact__info {
    padding-bottom: 50px;
    margin-top: 50px;
  }
}
.contact .contact__info::after {
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  bottom: 0;
  background-color: #FFFFFF;
}
.contact .contact__info .contact__info-msg {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.458;
}
@media (max-width: 1023px) {
  .contact .contact__info .contact__info-msg {
    font-size: 1.8rem;
    line-height: 1.444;
  }
}
.contact .contact__info .contact__notice {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.875;
  margin-top: 42px;
}
@media (max-width: 1023px) {
  .contact .contact__info .contact__notice {
    width: clamp(300px, 80%, 524px);
    font-size: 1.4rem;
    line-height: 1.571;
  }
}
.contact .contact__info .contact__notice .contact__notice-list .contact__notice-item::before {
  content: "※";
}
@media (min-width: 500px) {
  .contact .contact__info .contact__notice .contact__notice-list .contact__notice-item br {
    display: none;
  }
}
.contact .contact__info--confirm {
  display: none;
}
.contact .contact-form {
  width: 800px;
  padding: 100px 0 300px;
  margin: 0 auto;
}
@media (max-width: 1023px) {
  .contact .contact-form {
    width: clamp(300px, 85.3333333333vw, 800px);
    padding: 50px 0 90px;
  }
}
.contact .contact-form .is-required::after {
  content: "必須";
  width: 42px;
  height: 22px;
  display: inline-block;
  position: relative;
  transform: translateY(-1px);
  font-size: 1.3rem;
  font-weight: 600;
  line-height: 22px;
  letter-spacing: 0.1em;
  text-align: center;
  color: #FFFFFF;
  background-color: #EF3434;
  border-radius: 3px;
  margin-left: 16px;
}
.contact .contact-form .contact-form__item:not(:first-child) {
  margin-top: 40px;
}
@media (max-width: 1023px) {
  .contact .contact-form .contact-form__item:not(:first-child) {
    margin-top: 24px;
  }
}
.contact .contact-form .contact-form__item.is_error .contact-form__input {
  border: 3px solid #EF3334;
}
.contact .contact-form .contact-form__item.is_error .contact-form__input:focus {
  border: 3px solid #37789A;
}
.contact .contact-form .contact-form__item.is_error .contact-form__error {
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.429;
  letter-spacing: 0.1em;
  color: #EF3334;
  margin-top: 10px;
}
@media (max-width: 1023px) {
  .contact .contact-form .contact-form__item.is_error .contact-form__error {
    margin-top: 6px;
  }
}
.contact .contact-form .contact-form__item.is_error .contact-form__error::before {
  content: "！";
  width: 18px;
  height: 18px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-size: 1.2rem;
  font-weight: 600;
  line-height: 1.5;
  color: #FFFFFF;
  background-color: #EF3334;
  border-radius: 50%;
  padding-left: 1px;
  margin-right: 11px;
}
.contact .contact-form .contact-form__label {
  display: block;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
@media (max-width: 1023px) {
  .contact .contact-form .contact-form__label {
    font-size: 1.4rem;
    line-height: 1.5;
  }
}
.contact .contact-form .contact-form__btn {
  display: block;
  font-size: 1.6rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  margin: 60px auto 0;
  cursor: pointer;
}
.contact .contact-form .contact-form__btn--submit {
  width: 320px;
  height: 80px;
  line-height: 80px;
  color: #242424;
  background-color: #FFE627;
}
.contact .contact-form .contact-form__btn--back {
  color: #FFFFFF;
}
.contact .contact-form .contact-form__input {
  width: 100%;
  height: 60px;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 60px;
  letter-spacing: 0.1em;
  background-color: #FFFFFF;
  border: 3px solid #FFFFFF;
  border-radius: 4px;
  padding: 0 30px;
  margin-top: 6px;
  outline: none;
  box-shadow: none;
}
@media (max-width: 1023px) {
  .contact .contact-form .contact-form__input {
    line-height: 50px;
    padding: 0 20px;
  }
}
.contact .contact-form .contact-form__input::placeholder {
  color: #CBCBCB;
}
.contact .contact-form .contact-form__input:focus {
  outline: none;
  box-shadow: none;
  border: 3px solid #37789A;
}
.contact .contact-form .contact-form__input.contact-form__input--short {
  width: 50%;
}
@media (max-width: 1023px) {
  .contact .contact-form .contact-form__input.contact-form__input--short {
    width: 100%;
  }
}
.contact .contact-form .contact-form__input.contact-form__input--textarea {
  height: 270px;
  resize: none;
  line-height: 1.875;
  padding: 18px 30px;
}
@media (max-width: 1023px) {
  .contact .contact-form .contact-form__input.contact-form__input--textarea {
    padding: 12px 20px;
  }
}
.contact .contact-form .contact-form__privacy-note {
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.1em;
  text-align: center;
  margin-top: 66px;
}
@media (max-width: 1023px) {
  .contact .contact-form .contact-form__privacy-note {
    text-align: left;
  }
}
.contact .contact-form .contact-form__privacy-note .contact-form__privacy-link {
  color: #FFFFFF;
  text-decoration: underline;
}
@media (min-width: 500px) {
  .contact .contact-form .contact-form__privacy-note br {
    display: none;
  }
}
.contact .contact-form .contact-form__reCAPTCHA-text {
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.1em;
  text-align: center;
  margin-top: 20px;
}
@media (max-width: 1023px) {
  .contact .contact-form .contact-form__reCAPTCHA-text {
    text-align: left;
  }
}
.contact .contact-form .contact-form__reCAPTCHA-text .contact-form__reCAPTCHA-link {
  color: #FFFFFF;
  text-decoration: underline;
}
.contact .contact-form .contact-form__confirm-area {
  display: none;
}
.contact .contact-form .contact-form__confirm-content {
  width: 100%;
  display: block;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.875;
  letter-spacing: 0.1em;
  word-break: break-all;
  margin-top: 15px;
}
@media (max-width: 1023px) {
  .contact .contact-form .contact-form__confirm-content {
    font-size: 1.4rem;
    line-height: 1.571;
  }
}
.contact .contact-form .contact-form__confirm-content.contact-form__confirm-content--message {
  white-space: pre-line;
}

.contact-fin {
  background-color: #242424;
  padding: 200px 0 588px;
}
@media (max-width: 1023px) {
  .contact-fin {
    padding: 60px 0 110px;
  }
}
.contact-fin .contact__step .contact__step-list .contact__step-item--fin .contact__step-circle {
  background-color: #FFFFFF;
}
.contact-fin .contact-fin__msg {
  margin-top: 120px;
}
@media (max-width: 1023px) {
  .contact-fin .contact-fin__msg {
    margin-top: 50px;
  }
}
.contact-fin .contact-fin__msg .contact-fin__title {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.458;
  letter-spacing: 0.1em;
  text-align: center;
}
@media (max-width: 1023px) {
  .contact-fin .contact-fin__msg .contact-fin__title {
    font-size: 1.8rem;
    line-height: 1.444;
  }
}
.contact-fin .contact-fin__msg .contact-fin__text {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.875;
  letter-spacing: 0.1em;
  text-align: center;
  margin-top: 42px;
}
@media (max-width: 1023px) {
  .contact-fin .contact-fin__msg .contact-fin__text {
    font-size: 1.4rem;
    line-height: 1.571;
    margin-top: 17px;
  }
}
@media (max-width: 620px) {
  .contact-fin .contact-fin__msg .contact-fin__text {
    width: 80vw;
    text-align: left;
    margin: 17px auto 0;
  }
}
.contact-fin .contact-fin__top-btn {
  width: 320px;
  height: 80px;
  display: block;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 80px;
  letter-spacing: 0.1em;
  text-align: center;
  color: #242424;
  background-color: #FFFFFF;
  margin: 80px auto 0;
}
@media (max-width: 1023px) {
  .contact-fin .contact-fin__top-btn {
    width: 200px;
    height: 80px;
    margin: 60px auto 0;
  }
}/*# sourceMappingURL=contact.css.map */