/*--------------------------------------------------------------

--------------------------------------------------------------*/


/** {
  min-height: 0vw;
  min-height: 0;
}*/


/*=======================
common
========================*/


p.Yline span {
  background: linear-gradient(transparent 50%, #fcff54 50%);
}
.kome {
  font-size: 0.75rem;
}
.explanation-p {
  font-size: 0.75rem;
}


/*==============================
form
==============================*/
#formWrap {
  width: 90%;
  max-width: 900px;
  margin: 5% auto;
  border-radius: 20px;
  padding: 5%;
  box-sizing: border-box;
  border: dotted 2px;
}
#formWrap h1{
  margin: 5% auto 3%;
  text-align: center;
  font-size: clamp(1.625rem, 1.375rem + 1.25vw, 2.313rem);
  width: 90%;
  font-weight: normal;
  line-height: 1.6em;
  letter-spacing: 0.12em;
}
#formWrap h2 {
  text-align: center;
  font-size: clamp(1rem, 0.955rem + 0.23vw, 1.125rem);
  line-height: 1em;
  margin-bottom: 15px;
}
.h1-p{
  text-align: center;
}
ul.formList {
  list-style: none;
  padding: 0;
  margin: 0;
}
ul.formList li {
  border-bottom: 1px solid #fff;
  padding: 10px 0;
}
ul.formList li:last-child {
  border-bottom: none;
}
ul.formList p {
  font-weight: bold;
  margin-bottom: 5px;
}
input {
  background: #fff;
}
input[type="text"],
select,
textarea {
  border: none;
  line-height: 30px;
  padding: 5px 10px;
  font-size: 1rem;
  font-family: "Yu Gothic", "游ゴシック", "游ゴシック体",
    "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic Pro",
    "ヒラギノ角ゴ Pro";
  width: 100%;
  box-sizing: border-box;
}
textarea {
  min-height: 100px;
}
ul.formList :where(input, button, textarea, select) {
  border: none;
}
input[type="submit"],
input[type="reset"],
input[type="button"] {
  padding: 10px 0px;
  border-radius: 50px;
  border: solid 1px;
  font-weight: bold;
  margin: 10px auto;
  width: 40%;
  color: #0a1934;
}
.required {
  color: #d1347e;
  padding-left: 3px;
}
.wpcf7-checkbox {
  display: flex;
  flex-wrap: wrap;
}
span.wpcf7-list-item {
  margin-right: 10px;
}
.submit-btn p{
  display: flex;
  justify-content: center;
}
.wpcf7-spinner{
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
}
/*　簡易版レスポンシブ用CSS（必要最低限のみとしています。ブレークポイントも含め自由に設定下さい）　*/
@media screen and (max-width: 767px) {
  #formWrap {
    width: 95%;
  }
  ul.formList li {
    display: block;
  }
  form input[type="text"],
  form textarea {
    padding: 5px;
    font-size: 110%;
    display: block;
  }
  form input[type="submit"],
  form input[type="reset"],
  form input[type="button"] {
    display: block;
    width: 100%;
    max-width: 280px;
  }
  .submit-btn p {
    display: block;
  }
}
/*確認画面*/
#contact-confirm,
#contact-thanks{
  margin-top: 100px;
}
.screen-reader-response {
  color: #d1347e;
}
.wpcf7-response-output {
  color: #d1347e;
}
span.wpcf7-not-valid-tip {
  display: block;
  color: #d1347e;
}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output{
  border-color: #d1347e;
}
.wpcf7 form .wpcf7-response-output {
  margin: 2em 0 0;
  padding: 1em;
  border: 1px solid #8ab3c4;
}

/*==============================
thanks
==============================*/
.saito-btn {
  display: block;
  border: solid 1px;
  font-weight: bold;
  padding: 10px 20px;
  border-radius: 50px;
  margin: 20px auto;
  width: fit-content;
}
