@charset "utf-8";

/*===================
contact
===================*/

.from-wrap {
  max-width: 611px;
  margin: 0 auto;
}
/* .contact__wrap {

} */
.contact .sec__jpTtl,
.contact .sec__enTtl {
  color: #bfff0d;
}
.contact .sec__jpTtl {
  margin-bottom: clamp(12px, 2.4218vw, 31px);
}
.contact__txt {
  font-size: 16px;
  letter-spacing: -0.04em;
  line-height: 2.12;
  text-align: center;
}
.contact__txt02 {
  text-align: center;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.02em;
  line-height: 1.7272;
}
/* プライバシーポリシー */
.privacy__wrap {
  margin-bottom: 35px;
}
.privacy__titleBox {
  padding: 17px 14px 17px 13px;
  border-top: 1px solid #c4c4c4;
  border-bottom: 1px solid #c4c4c4;
  position: relative;
  cursor: pointer;
}
.privacy__titleBox::before {
  background: #000;
  content: "";
  width: 11px;
  height: 1px;
  position: absolute;
  right: 17px;
  top: 50%;
  transform: rotate(90deg);
  transition: transform 0.3s ease-in-out;
}
.privacy__titleBox::after {
  background: #000;
  content: "";
  width: 11px;
  height: 1px;
  position: absolute;

  right: 17px;
  top: 50%;
  transition: transform 0.3s ease-in-out;
}
.privacy__titleBox.open::after {
  transform: rotate(45deg);
}
.privacy__titleBox.open::before {
  transform: rotate(135deg);
}
.privacy__ttl {
  font-size: 13px;
  font-weight: 700;
  color: #000;
  letter-spacing: -0.02em;
  text-align: center;
}
.privacy__contBox {
  padding: 32px 8px 50px 8px;
  border-bottom: 1px solid #c4c4c4;
}
.privacy__textBox + .privacy__textBox {
  margin-top: 30px;
}
.privacy__unit {
  width: 92%;
  margin-left: auto;
  margin-top: 30px;
}
.privacy__set + .privacy__set {
  margin-top: 20px;
}
.privacy__contTtl {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.93;
  color: #000;
}
.privacy__contTxt {
  font-size: 14px;
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1.93;
  color: #000;
}
@media screen and (max-width: 750px) {
  .contact {
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 0;
  }
  .contact__inner {
    padding-bottom: 109px;
  }
  .contact__wrap {
    padding: 0 18px;
  }
  .contact__txt {
    padding-left: 0;
    text-align: left;
  }
  .privacy__ttl {
    text-align: left;
  }
}

/*===================
mwwpform
===================*/
.contact__formBtnLink {
  display: block;
  max-width: 158px;

  margin: 0 auto 17px;
  text-align: center;
  position: relative;
}
.contact__formBtnLink::before {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  background: url(../imgs/common/btn-ancGreen.svg) center center / cover
    no-repeat;
  position: absolute;
  top: 50%;
  right: 7%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  z-index: 1;
}

.contact__formBtnLink input {
  width: 100%;
  height: 44px;
  background-color: #0f1c3e;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  border-radius: 3px;
  border: 1px solid #0f1c3e;
  transition: 0.4s;
  padding-right: 50px;
}

.contact__formBtnLink input:hover {
  background: #fff;
  color: #0f1c3e;
}
.contact__formBtnLink--back {
  display: none;
}
.ilbk {
  display: inline-block;
}
.form {
  width: 100%;
  margin-top: 96px;
  margin-bottom: 36px;
}
.form__box {
  margin-bottom: 24px;
}
.form__box:last-child {
  border-bottom: none;
}
.form__item {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 2.57;
  padding-left: 14px;
  position: relative;
}
.form__item::before {
  content: "";
  width: 5px;
  height: 1px;
  background-color: #000;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}

.form__inputTxt {
  font-size: 14px;
  font-weight: 700;
  color: #000;
  position: relative;
}

.form__inputTxt input {
  box-sizing: border-box;
  width: 100%;
  padding: 13px 13px;
  letter-spacing: -0.02em;
  background: #fff;
  font-size: 14px;
  font-weight: 400;
  border-radius: 5px;
}
.form__inputTxt input::-webkit-input-placeholder {
  color: #b4b4b4;
}
.form__inputTxt input:-moz-placeholder {
  color: #b4b4b4;
}
.form__inputTxt input::-moz-placeholder {
  color: #b4b4b4;
}
.form__inputTxt input:-ms-input-placeholder {
  color: #b4b4b4;
}
.form__inputTxt textarea::-webkit-input-placeholder {
  color: #b4b4b4;
}
.form__inputTxt textarea:-moz-placeholder {
  color: #b4b4b4;
}
.form__inputTxt textarea::-moz-placeholder {
  color: #b4b4b4;
}
.form__inputTxt textarea:-ms-input-placeholder {
  color: #b4b4b4;
}

.form__inputTxt.messege textarea {
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  min-height: 220px;
  padding: 13px 13px;
  background: #fff;
  letter-spacing: -0.02em;
  font-size: 14px;
  font-weight: 400;
  border-radius: 5px;
}

.mw_wp_form span.error {
  display: block;
  font-size: 12px;
  padding-top: 3px;
  color: #ff0000;
}

.preview__text {
  display: none;
  font-size: 25px;
  color: #000;
  text-align: center;
  margin-bottom: 30px;
  letter-spacing: 0.08em;
}
.contact__btmText {
  margin-bottom: 54px;
  font-size: 13px;
  color: #000;
  text-align: center;
  letter-spacing: -0.02em;
}
.contact__btmText .mwform-checkbox-field label input.form__privacy-form {
  margin-right: 10px !important;
  margin-bottom: 3px;
  width: 20px;
  height: 20px;
}

/* 確認画面 */
.mw_wp_form_confirm .contact__formBtnLink--back {
  display: flex;
  justify-content: center;
  align-items: center;
}
.mw_wp_form_confirm .form__submits-item--back {
  display: block;
}
.mw_wp_form_confirm .contact__formBtnLink input {
  padding: 0;
}
.contact__formBtnLink--back::before {
  top: 43%;
  left: 10%;
  transform: rotate(180deg);
}
.mw_wp_form_confirm .form__inputTxt {
  color: #000;
}
#confirm h1.page-title__jp {
  font-size: 30px;
  text-align: center;
  margin: 0 4%;
}
#confirm .page-titleWrap {
  margin-bottom: 70px;
}
#confirm .attension__text {
  font-size: 20px;
  text-align: center;
  margin: 0 4%;
  margin-bottom: 20px;
  line-height: 1.75;
}
.confirm__wrap {
  padding: 30px 0 0;
}
#confirm .form {
  margin-bottom: 50px;
}
#confirm .form__inputTxt {
  padding-left: 0;
  border: none;
  background: none;
  padding-top: 6px;
}
#confirm .form__inputTxt.messege {
  min-height: 60px;
}
#confirm .contact__formBtn {
  padding-bottom: 95px;
}
#confirm .contact__formBtnLink {
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5%;
  width: 100%;
  max-width: 415px;
}
#confirm .contact__formBtnLink input {
  padding: 0;
}

/* 完了画面 */

/* #comp {
  padding-top: 210px;
} */
#comp .page-titleWrap {
  margin-bottom: 50px;
}
#comp .page-title__jp {
  margin-bottom: 100px;
  font-size: 30px;
  text-align: center;
  margin: 0 4%;
}
.comp__wrap {
  width: 90%;
  max-width: 850px;
  margin: 0 auto;
  padding-bottom: 100px;
}
#comp .catch_ttl__contact {
  text-align: center;
  margin-bottom: 50px;
  font-size: 21px;
}
#comp .attension__text {
  line-height: 1.8;
}
.comp__btnWrap {
  margin-top: 30px;
}
.comp__btn {
  display: block;
  max-width: 237px;
  padding: 8px 5px;
  margin: 0 auto;
  font-size: 16px;
  letter-spacing: 0.024em;
  border: 1px solid #275aa3;
  background-color: #275aa3;
  background-size: 7px 9px;
  text-align: center;
  color: #fff;
  border-radius: 999px;
}
.contact_thanks {
  margin-top: 36px;
  margin-bottom: 70px;
  font-size: 14px;
  line-height: 2.1;
  text-align: center;
}
.contact_thanks--head {
  font-size: 16px;
  display: block;
  margin-bottom: 10px;
}
.mw_wp_form_complete .contact__txt,
.mw_wp_form_confirm .contact__txt {
  display: none;
}
@media screen and (max-width: 920px) {
}
@media screen and (max-width: 750px) {
  .contact__btnBox .box-outer {
    width: 100%;
    min-width: auto;
  }
  .form {
    padding: 0;
    margin-top: 76px;
    margin-bottom: 36px;
  }
  .form__right,
  .form__right.half {
    width: 100%;
    min-width: auto;
  }
  .form__itemReq {
    padding: 3px 7px;
    margin-left: 15px;
    font-size: 13px;
  }

  /* 確認画面 */

  /* #confirm {
    padding-top: 130px;
  } */
  #confirm h1.page-title__jp {
    font-size: 25px;
  }
  #confirm .page-titleWrap {
    margin-bottom: 30px;
  }
  #confirm .attension__text {
    font-size: 16px;
  }

  /* 完了画面 */
  /* #comp {
    padding-top: 130px;
  } */
  #comp .page-title__jp {
    margin-bottom: 70px;
    font-size: 25px;
    text-align: center;
    margin: 0 4%;
  }
  .comp__wrap {
    padding-bottom: 80px;
  }
  #comp .catch_ttl__contact {
    margin-bottom: 40px;
    font-size: 18px;
  }
  #comp .attension__text {
    font-size: 14px;
  }
  .mw_wp_form_preview .confirm__top-text {
    font-size: 16px;
  }
  .comp__title {
    margin: 80px auto 40px;
    font-size: 25px;
  }
  .lang-contact__wrap .mw_wp_form_complete {
    margin-bottom: 80px;
  }
  .comp__text {
    font-size: 14px;
  }
}
