@charset "UTF-8";
/*=============================================
=            NOTICE            =
=============================================*/
/*=============================================
=            NOTICE            =
=============================================*/
#notice .noticeWrapper {
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
  background-color: #eaf7f7;
  padding: 30px 10px 30px;
  border-radius: 8px;
  position: relative;
  margin-top: 20px;
}
@media only screen and (min-width: 768px) {
  #notice .noticeWrapper {
    padding: 50px 30px;
  }
}
#notice .noticeWrapper .noticeIcon {
  text-align: center;
  width: 60px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 5px;
}
#notice .noticeWrapper .sectionTitle {
  text-align: center;
  font-size: 2.4rem;
  color: #57bebb;
  font-weight: bold;
  margin-bottom: 20px;
}
#notice .noticeWrapper .lead {
  text-align: center;
  font-weight: bold;
  font-size: 1.4rem;
  margin-bottom: 10px;
  line-height: 1.75;
}
@media only screen and (min-width: 768px) {
  #notice .noticeWrapper .lead {
    font-size: 1.8rem;
    margin-bottom: 20px;
    line-height: 1.75;
  }
}
#notice .noticeWrapper .inner {
  background-color: #fdfdfd;
  padding: 10px;
  border-radius: 8px;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  #notice .noticeWrapper .inner {
    padding: 30px;
  }
}
#notice .noticeWrapper .inner ul {
  padding-left: 0;
  margin-bottom: 0;
  list-style-type: none;
  font-size: 1.2rem;
}
@media only screen and (min-width: 768px) {
  #notice .noticeWrapper .inner ul {
    font-size: 1.6rem;
  }
}
#notice .noticeWrapper .inner ul > li {
  padding-left: 1em;
  text-indent: -1em;
  margin-bottom: 0.8em;
  line-height: 1.75;
  letter-spacing: 0.15em;
  font-weight: 400;
}
#notice .noticeWrapper .inner ul > li:last-child {
  margin-bottom: 0;
}
#notice .noticeWrapper .inner ul > li .dots {
  color: #da352b;
  font-size: 0.8em;
}

/*=====  End of NOTICE  ======*/
/*=============================================
=            COMMON            =
=============================================*/
:focus-visible {
  outline-color: #d6d6d6;
  border-radius: 0;
  outline: none;
}

/*=====  End of COMMON  ======*/
/*=============================================
=            DscWrapper            =
=============================================*/
.dscWrapper {
  margin-top: 50px;
  margin-bottom: 50px;
  text-align: center;
  font-weight: 400;
  font-size: 1.4rem;
}
.dscWrapper h4 {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 1em;
}

/*=====  End of DscWrapper  ======*/
/*=============================================
=            FORM WRAPPER            =
=============================================*/
.formWrapper {
  margin-bottom: 65px;
  margin-top: 60px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .formWrapper {
    padding-left: 20px;
    padding-right: 20px;
    margin-bottom: 65px;
    max-width: 1040px;
  }
}
.formWrapper .formTitle {
  color: #fdfdfd;
  background-color: #57bebb;
  padding: 10px 20px;
  font-weight: bold;
  font-size: 2rem;
  letter-spacing: 0.1em;
  margin-bottom: 10px;
}
.formWrapper .titleAnno {
  font-weight: bold;
  font-size: 1.4rem;
  margin-bottom: 10px;
  margin-top: -5px;
}
.formWrapper .reqAnno {
  color: #da352b;
  font-weight: bold;
  font-size: 1.4rem;
  margin-bottom: 5px;
}
.formWrapper dl {
  position: relative;
  margin-bottom: 0;
}
@media only screen and (min-width: 768px) {
  .formWrapper dl {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
}
.formWrapper dl dt {
  padding-top: 40px;
  padding-bottom: 15px;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .formWrapper dl dt {
    padding-top: 32px;
    padding-bottom: 20px;
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 210px;
        -ms-flex: 0 0 210px;
            flex: 0 0 210px;
    margin-right: 40px;
  }
}
.formWrapper dl dt small {
  padding-left: 10px;
  line-height: 1.2;
}
@media only screen and (min-width: 768px) {
  .formWrapper dl dt small {
    display: block;
    padding-left: 0;
    margin-top: -3px;
    font-size: 1.2rem;
  }
}
.formWrapper dl dt .req {
  color: #da352b;
}
.formWrapper dl dd {
  margin-bottom: 0;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  word-break: break-all;
}
@media only screen and (min-width: 768px) {
  .formWrapper dl dd {
    -webkit-box-flex: 1;
    -webkit-flex: 1 1 auto;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    margin-bottom: 0;
    padding-top: 20px;
    padding-bottom: 20px;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
  }
}
.formWrapper dl dd a {
  text-decoration: underline;
}
.formWrapper dl dd .extrainfo {
  margin-top: 10px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.formWrapper dl dd .extrainfo .countWrapper {
  font-size: 1.3rem;
}
.formWrapper dl dd .extrainfo .countWrapper.disable {
  color: #da352b;
}
.formWrapper dl dd .anno {
  margin-top: 10px;
  line-height: 1.3;
}
.formWrapper [type=text],
.formWrapper [type=email],
.formWrapper [type=file],
.formWrapper textarea,
.formWrapper [type=button],
.formWrapper [type=reset],
.formWrapper [type=submit],
.formWrapper button {
  -webkit-appearance: unset;
     -moz-appearance: unset;
          appearance: unset;
}
.formWrapper [type=text],
.formWrapper [type=email],
.formWrapper textarea {
  border: none;
  width: 100%;
  border-radius: 0;
  padding: 17px 20px;
  background-color: #f0f0f0;
  font-size: 1.6rem;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .formWrapper [type=text],
  .formWrapper [type=email],
  .formWrapper textarea {
    border: none;
    width: 100%;
    border-radius: 0;
    padding: 15px 20px;
  }
}
.formWrapper [type=text].short {
  width: 200px;
}
.formWrapper textarea {
  height: 280px;
  vertical-align: bottom;
}
@media only screen and (min-width: 768px) {
  .formWrapper textarea {
    height: auto;
  }
}
.formWrapper [type=text]::-webkit-input-placeholder, .formWrapper [type=email]::-webkit-input-placeholder, .formWrapper textarea::-webkit-input-placeholder {
  color: #cbcbcb;
}
.formWrapper [type=text]::-moz-placeholder, .formWrapper [type=email]::-moz-placeholder, .formWrapper textarea::-moz-placeholder {
  color: #cbcbcb;
}
.formWrapper [type=text]:-ms-input-placeholder, .formWrapper [type=email]:-ms-input-placeholder, .formWrapper textarea:-ms-input-placeholder {
  color: #cbcbcb;
}
.formWrapper [type=text]::-ms-input-placeholder, .formWrapper [type=email]::-ms-input-placeholder, .formWrapper textarea::-ms-input-placeholder {
  color: #cbcbcb;
}
.formWrapper [type=text]::placeholder,
.formWrapper [type=email]::placeholder,
.formWrapper textarea::placeholder {
  color: #cbcbcb;
}
.formWrapper input[type=file]:focus {
  outline: 0;
}
.formWrapper .file-upload_area {
  position: relative;
}
.formWrapper .file-upload_area .file-upload_input::before {
  background: #f0f0f0;
  border-radius: 2px;
  color: #333;
  content: "選択する";
  font-size: 1.3rem;
  padding: 14px 15px;
  min-width: 160px;
  text-align: center;
  position: absolute;
  cursor: pointer;
  font-weight: bold;
}
.formWrapper .file-upload_area input[type=file]::-webkit-file-upload-button {
  background: -webkit-gradient(linear, left top, left bottom, from(transparent), to(transparent));
  background-color: transparent;
  border: 0;
  min-width: 160px;
  height: 54px;
  margin-right: 20px;
}
.formWrapper .select-box {
  position: relative;
  width: 100%;
}
.formWrapper .select-box:before {
  position: absolute;
  content: "";
  width: 0px;
  height: 0px;
  top: 50%;
  left: auto;
  right: 15px;
  border-style: solid;
  border-width: 6px 6px 0 6px;
  border-color: #333 transparent transparent transparent;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  z-index: 1;
}
.formWrapper .select-box select {
  -webkit-appearance: unset;
  -moz-appearance: unset;
  appearance: unset;
  padding: 15px 20px;
  border: none;
  width: 100%;
  position: relative;
  line-height: 1.5;
  background-color: #f0f0f0;
  color: #000;
}
@media (min-width: 768px) {
  .formWrapper .checkbox-list > span {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 50%;
        -ms-flex: 0 0 50%;
            flex: 0 0 50%;
    max-width: 50%;
  }
  .formWrapper .agreement.checkbox-list > span {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 100%;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    max-width: 100%;
  }
}
.formWrapper .checkbox-list label {
  position: relative;
  cursor: pointer;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.formWrapper .checkbox-list label span {
  font-size: 1.6rem;
  display: inline-block;
  font-weight: bold;
  line-height: 3.5rem;
}
.formWrapper .checkbox-list input[type=checkbox] {
  cursor: pointer;
  margin-right: 1rem;
  width: 3.5rem;
  height: 3.5rem;
  position: relative;
}
.formWrapper .checkbox-list input[type=checkbox]:before {
  position: absolute;
  z-index: 1;
  top: 50%;
  left: 50%;
  width: 2rem;
  height: 1rem;
  content: "";
  -webkit-transform: translate(-48%, -63%) rotate(-45deg) scale(0, 0);
          transform: translate(-48%, -63%) rotate(-45deg) scale(0, 0);
  border: 3px solid #57bebb;
  border-top-style: none;
  border-right-style: none;
  -webkit-transition: 0.1s ease-in-out all;
  transition: 0.1s ease-in-out all;
}
.formWrapper .checkbox-list input[type=checkbox]:checked:before {
  -webkit-transform: translate(-48%, -63%) rotate(-45deg) scale(1, 1);
          transform: translate(-48%, -63%) rotate(-45deg) scale(1, 1);
}
.formWrapper .checkbox-list input[type=checkbox]:after {
  position: absolute;
  top: 0;
  left: 0;
  width: 3.5rem;
  height: 3.5rem;
  content: "";
  cursor: pointer;
  border: 2px solid #333;
  background: #ffffff;
}

.mw_wp_form_confirm .formWrapper .select-box:before {
  display: none;
}

/*=====  End of FORM WRAPPER  ======*/
.confirmBtnBox {
  text-align: center;
  margin-bottom: 40px;
}
@media only screen and (min-width: 768px) {
  .confirmBtnBox {
    margin-bottom: 60px;
  }
}
.confirmBtnBox button {
  -webkit-appearance: unset;
     -moz-appearance: unset;
          appearance: unset;
  padding: 0;
  border: none;
  cursor: pointer;
  margin-left: auto;
  margin-right: auto;
  max-width: 100%;
  background: transparent;
}
.confirmBtnBox .formBtn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  background-color: #57bebb;
  color: #fdfdfd;
  height: 80px;
  position: relative;
  width: 500px;
  max-width: 100%;
  margin: 15px 0;
  border-radius: 100px;
}
@media only screen and (min-width: 768px) {
  .confirmBtnBox .formBtn {
    height: 102px;
  }
}
.confirmBtnBox .formBtn h3 {
  font-weight: 700;
  margin-bottom: 0;
  font-size: 1.8rem;
  letter-spacing: 0.15em;
}
@media only screen and (min-width: 768px) {
  .confirmBtnBox .formBtn {
    margin: 15px;
  }
}
.confirmBtnBox .formBtn .arrow {
  position: absolute;
  top: 50%;
  right: 40px;
  left: auto;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  content: url(../img/arrow_r.svg);
}
.confirmBtnBox .formBtn.backBtn {
  background-color: #696969;
}
.confirmBtnBox .formBtn.backBtn .arrow {
  right: auto;
  left: 40px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  content: url(../img/arrow_l.svg);
}

/*=============================================
=            HOW TO            =
=============================================*/
.howtoWrapper {
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  padding: 20px;
  margin-bottom: 60px;
  background-color: #f5f5f5;
  font-size: 1.4rem;
}
@media only screen and (min-width: 768px) {
  .howtoWrapper {
    padding: 50px;
    font-size: 1.6rem;
  }
}
.howtoWrapper .title {
  text-align: center;
  font-weight: bold;
  font-size: 2rem;
  margin-bottom: 20px;
  display: inline-block;
  margin-left: auto;
  margin-right: auto;
}

/*=====  End of HOW TO  ======*/
/*=============================================
=            KIYAKU            =
=============================================*/
.kiyakuWrapper {
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  padding: 20px;
  border: 1px solid #333;
  border-radius: 0px;
  margin-bottom: 20px;
  max-height: 260px;
  overflow: auto;
  font-size: 1.4rem;
  font-weight: 400;
}
@media only screen and (min-width: 768px) {
  .kiyakuWrapper {
    padding: 20px;
  }
}
.kiyakuWrapper .title {
  font-weight: bold;
  font-size: 1.6rem;
  margin-bottom: 5px;
}
.kiyakuWrapper ul {
  padding-left: 0;
  margin-bottom: 0;
  list-style-type: none;
  line-height: 1.5;
}
.kiyakuWrapper ul li {
  font-size: 1.4rem;
  padding-left: 1em;
  text-indent: -1em;
}
.kiyakuWrapper a {
  word-break: break-all;
  color: #da352b;
  text-decoration: underline;
}

/*=====  End of KIYAKU  ======*/
/*=============================================
=            CONFORM            =
=============================================*/
.mw_wp_form_confirm .formWrapper dl dt {
  padding-top: 20px;
}
.mw_wp_form_confirm .formWrapper dl dd .extrainfo {
  display: none;
}
.mw_wp_form_confirm .formWrapper dl dd .anno {
  display: none;
}

/*=====  End of CONFORM  ======*/
/*=============================================
=            THANKS             =
=============================================*/
#thanks {
  padding-top: 80px;
  padding-bottom: 80px;
}
@media only screen and (min-width: 992px) {
  #thanks .thanksContainer {
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
  }
}
#thanks .thanksContainer h2 {
  text-align: center;
  font-weight: bold;
  font-size: 4rem;
  margin-bottom: 40px;
}
#thanks .thanksContainer ul {
  list-style-type: none;
  padding-left: 0;
  margin-bottom: 0;
  background-color: #f5f5f5;
  padding: 30px;
  font-size: 1.4rem;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
#thanks .thanksContainer ul li {
  padding-left: 1em;
  text-indent: -1em;
  margin-bottom: 0.5em;
}
#thanks .thanksContainer ul li:last-child {
  margin-bottom: 0;
}
#thanks .thanksContainer .btnWrapper {
  text-align: center;
  margin-top: 80px;
}

.thanksBtnBox {
  padding-top: 80px;
  padding-bottom: 150px;
}

/*=====  End of THANKS   ======*/
/*=============================================
=            RECAPTCHA ANNO            =
=============================================*/
.recaptchaAnno {
  margin-bottom: 80px;
  padding: 30px;
  font-size: 1.4rem;
  background-color: #f5f5f5;
  border: 1px solid #333;
}

.mw_wp_form.mw_wp_form_confirm.mw_wp_form_complete .recaptchaAnno {
  display: none;
}

/*=====  End of RECAPTCHA ANNO  ======*//*# sourceMappingURL=form.css.map */