@charset "UTF-8";
/* =======================================

基本設定

======================================= */
@media (min-width: 521px) {
  .custom--root .sp {
    display: none !important;
  }
}
@media (max-width: 520px) {
  .custom--root .pc {
    display: none !important;
  }
}
.custom--root .wrap_out, .custom--root .wrap_main {
  width: 100%;
  height: auto;
}
.custom--root .wrap_in {
  max-width: 846px;
  height: auto;
  margin: 0 auto;
  padding: 0 20px;
}
@media (max-width: 520px) {
  .custom--root .wrap_in {
    padding: 0 15px;
  }
}

.custom--root {
  font-family: "Noto Sans JP", sans-serif;
}

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

見積もりシミュレーション

---------------------------------------- */
.cr_btn {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center; /*縦方向（Safari用）*/
  align-items: center; /* 縦方向*/
  -webkit-justify-content: center; /*横方向（Safari用）*/
  justify-content: center; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 100%;
  max-width: 300px;
  height: 53px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.5;
  color: #0D0504;
  text-decoration: none;
  background-color: #F2EC2B;
  border-radius: 20px;
  border: 0;
  margin: 86px auto 0;
  transition: opacity 0.4s;
  cursor: pointer;
}
@media (min-width: 521px) {
  .cr_btn:hover {
    opacity: 0.7;
  }
}

.cr_btn_text {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center; /*縦方向（Safari用）*/
  align-items: center; /* 縦方向*/
  -webkit-justify-content: center; /*横方向（Safari用）*/
  justify-content: center; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 13px auto 0;
}
.cr_btn_text--item {
  display: block;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.4;
  text-align: center;
  text-decoration: underline;
  color: #454545;
  cursor: pointer;
}

/* 扉
------------------------------- */
.cr_simuration_section {
  padding: 195px 0 0;
  margin-bottom: 140px;
}
@media (max-width: 520px) {
  .cr_simuration_section {
    padding-top: 80px;
    margin-bottom: 86px;
  }
}
.cr_simuration_section--ttlimg {
  display: block;
  width: 100%;
}

/* 質問
------------------------------- */
.cr_question_section {
  padding: 195px 0 100px;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}
@media (max-width: 520px) {
  .cr_question_section {
    padding-top: 80px;
    padding-bottom: 86px;
  }
}
.cr_question_section--ttl {
  font-size: 36px;
  font-weight: 700;
  line-height: 1.5555555556;
  text-align: center;
  margin: 35px auto 13px;
}
@media (max-width: 520px) {
  .cr_question_section--ttl {
    font-size: 24px;
    margin: 16px auto 8px;
  }
}
.cr_question_section--block--ttl {
  font-size: 32px;
  font-weight: 700;
  line-height: 1.4375;
  text-align: center;
}
@media (max-width: 520px) {
  .cr_question_section--block--ttl {
    font-size: 20px;
  }
}
.cr_question_section--block--dedc {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center; /*縦方向（Safari用）*/
  align-items: center; /* 縦方向*/
  -webkit-justify-content: flex-start; /*横方向（Safari用）*/
  justify-content: flex-start; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 605px;
  max-width: 100%;
  margin: 79px auto 0;
  padding-bottom: 22px;
  padding-left: 10px;
  border-bottom: 1px solid #F2EC2B;
}
@media (max-width: 520px) {
  .cr_question_section--block--dedc {
    display: block;
    width: 100%;
    margin: 36px auto 0;
    padding-bottom: 24px;
    padding-left: 0;
  }
}
.cr_question_section--block--dedc--img {
  width: 95.75px;
  aspect-ratio: 95.75/77.96;
}
@media (max-width: 520px) {
  .cr_question_section--block--dedc--img {
    width: 120px;
    margin: 0 auto 15px;
  }
}
.cr_question_section--block--dedc--img img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cr_question_section--block--dedc--item {
  width: calc(100% - 95.75px);
  font-size: 19px;
  font-weight: 400;
  line-height: 1.5789473684;
  padding-left: 45px;
}
@media (max-width: 520px) {
  .cr_question_section--block--dedc--item {
    width: auto;
    font-size: 16px;
    line-height: 1.8;
    text-align: center;
    margin: 0 -1em;
    padding-left: 0;
  }
}
.cr_question_section--block--form {
  margin: 43px auto 0;
}
@media (max-width: 520px) {
  .cr_question_section--block--form {
    margin-top: 24px;
  }
}
.cr_question_section--block--form--list {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center; /*縦方向（Safari用）*/
  align-items: center; /* 縦方向*/
  -webkit-justify-content: center; /*横方向（Safari用）*/
  justify-content: center; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 8px 60px;
}
@media (max-width: 520px) {
  .cr_question_section--block--form--list {
    gap: 12px 24px;
  }
}
.cr_question_section--block--form--desc {
  font-size: 15px;
  font-weight: 400;
  line-height: 2;
  text-align: center;
  margin-bottom: 48px;
}
@media (max-width: 520px) {
  .cr_question_section--block--form--desc {
    font-size: 14px;
    line-height: 1.8;
    margin-bottom: 24px;
  }
}
.cr_question_section--block--form--imglist {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: stretch; /*縦方向（Safari用）*/
  align-items: stretch; /* 縦方向*/
  -webkit-justify-content: flex-start; /*横方向（Safari用）*/
  justify-content: flex-start; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 48px 24px;
  max-width: 803px;
  margin: 0 auto;
}
@media (max-width: 520px) {
  .cr_question_section--block--form--imglist {
    -webkit-justify-content: space-between;
    justify-content: space-between;
    gap: 10px 0;
  }
}
.cr_question_section--block--form--imglist > li {
  width: calc((100% - 1px - 48px) / 3);
}
@media (max-width: 520px) {
  .cr_question_section--block--form--imglist > li {
    width: calc((100% - 10px) / 2);
  }
}
.cr_question_section--block .cr_btn {
  margin-top: 79px;
}
@media (max-width: 520px) {
  .cr_question_section--block .cr_btn {
    margin-top: 42px;
  }
}

.cr_inpit_check {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center; /*縦方向（Safari用）*/
  align-items: center; /* 縦方向*/
  -webkit-justify-content: center; /*横方向（Safari用）*/
  justify-content: center; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 0 17px;
  min-height: 28px;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.5;
  text-align: left;
  position: relative;
  overflow: hidden;
}
@media (max-width: 520px) {
  .cr_inpit_check {
    gap: 0 8px;
  }
}
.cr_inpit_check input[type=radio], .cr_inpit_check input[type=checkbox] {
  position: absolute;
  top: -100%;
  left: -100%;
}
.cr_inpit_check input[type=radio]:checked + .cr_inpit_check--ico::before, .cr_inpit_check input[type=checkbox]:checked + .cr_inpit_check--ico::before {
  -webkit-transform: translateY(-50%) translateX(-50%) scale(1);
  transform: translateY(-50%) translateX(-50%) scale(1);
}
.cr_inpit_check--ico {
  display: block;
  width: 16px;
  aspect-ratio: 1/1;
  border: 1px solid #000;
  background-color: #fff;
  position: relative;
}
.cr_inpit_check--ico::before {
  content: "";
  display: block;
  width: 28px;
  aspect-ratio: 1/1;
  background-image: url("../img/simuration/ico_check.svg");
  background-size: 100% auto;
  background-position: center center;
  background-repeat: no-repeat;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%) scale(0);
  transform: translateY(-50%) translateX(-50%) scale(0);
  -webkit-transition: transform 0.3s;
  transition: transform 0.3s;
}

.cr_inpit_check_img {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
}
.cr_inpit_check_img input[type=checkbox] {
  position: absolute;
  top: -100%;
  left: -100%;
  display: none;
}
.cr_inpit_check_img input[type=checkbox]:checked + .cr_inpit_check_img--bdr {
  box-shadow: 0px 0px 0 4px #F2EC2B;
}
.cr_inpit_check_img--bdr {
  display: block;
  width: 100%;
  height: 100%;
  box-shadow: 0px 0px 0 0 #F2EC2B;
  border-radius: 11px;
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  pointer-events: none;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.cr_inpit_check_img--inner {
  display: block;
  width: 100%;
  height: 100%;
  box-shadow: 0px 4px 15px rgba(0, 0, 0, 0.25);
  border-radius: 11px;
  background-color: #fff;
  position: relative;
  overflow: hidden;
  cursor: pointer;
}
.cr_inpit_check_img--item {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center; /*縦方向（Safari用）*/
  align-items: center; /* 縦方向*/
  -webkit-justify-content: center; /*横方向（Safari用）*/
  justify-content: center; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 100%;
  aspect-ratio: 252/157;
  font-size: 14px;
  font-weight: 700;
  text-align: center;
  background-color: #EBEBEB;
  overflow: hidden;
}
.cr_inpit_check_img--item img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cr_inpit_check_img--ttl {
  display: block;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
  padding: 15px;
}
@media (max-width: 520px) {
  .cr_inpit_check_img--ttl {
    font-size: 14px;
    padding: 11px;
  }
}

.cr_inpit_text {
  width: 474px;
  max-width: 100%;
  height: 42px;
  margin: 8px auto 0;
  overflow: hidden;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}
@media (max-width: 520px) {
  .cr_inpit_text {
    width: 100%;
    margin-top: 16px;
  }
}
.cr_inpit_text.no_active {
  height: 0;
}
.cr_inpit_text input {
  display: block;
  width: 100%;
  height: 42px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.4;
  padding: 6px 17px;
  background-color: #F4F4F4;
  border: 0;
}
.cr_inpit_text::placeholder {
  color: #B0B0B0;
}

.cr_bg_01 {
  overflow: hidden;
  position: relative;
  /*
      &::before{
          content: '';
          display: block;
          width: 1142px;
          aspect-ratio: 1142.41 / 752.9;
          background-image: url( "../img/simuration/bg_01.svg");
          background-size: 100% auto;
          background-repeat: no-repeat;
          position: absolute;
          top: 0;
          left: 50%;
          -webkit-transform: translateY(9.1%) translateX(-52.4%);
          transform: translateY(9.1%) translateX(-52.4%);
          @include a.mdSP {
              width: 1000px;
          }
      }
  */
}
.cr_bg_01 .wrap_in {
  position: relative;
  z-index: 1;
}

/* 確認
------------------------------- */
.cr_question_section--result {
  max-width: 803px;
  margin: 49px auto 0;
}

.cr_question_table {
  font-size: 15px;
  font-weight: 400;
  line-height: 1.5;
}
@media (max-width: 520px) {
  .cr_question_table {
    font-size: 13px;
  }
}
.cr_question_table thead {
  color: #fff;
  background-color: #000;
}
.cr_question_table tbody th, .cr_question_table tbody td {
  border-bottom: 1px solid #000;
}
.cr_question_table th, .cr_question_table td {
  font-weight: 400;
  vertical-align: top;
  padding-top: 18px;
  padding-bottom: 18px;
}
.cr_question_table th {
  text-align: left;
  padding-left: 46px;
  padding-right: 28px;
}
@media (max-width: 520px) {
  .cr_question_table th {
    padding-left: 8px;
    padding-right: 8px;
  }
}
.cr_question_table td {
  width: 140px;
  text-align: center;
  white-space: nowrap;
  padding-left: 28px;
  padding-right: 28px;
}
@media (max-width: 520px) {
  .cr_question_table td {
    width: 60px;
    padding-left: 8px;
    padding-right: 8px;
  }
}

.cr_question_section--block--dedc._cr_result {
  -webkit-justify-content: center;
  justify-content: center;
  border-bottom: 0;
  padding: 0;
}
.cr_question_section--block--dedc._cr_result .cr_question_section--block--dedc--item {
  width: auto;
  max-width: calc(100% - 95.75px);
  font-size: 16px;
  border-bottom: 0;
  padding-left: 4px;
}
@media (max-width: 520px) {
  .cr_question_section--block--dedc._cr_result .cr_question_section--block--dedc--item {
    width: 100%;
    max-width: none;
    margin: 0;
    padding-left: 0;
  }
}
.cr_question_section--block--dedc._cr_result .cr_question_section--block--dedc--item strong {
  font-size: 24px;
  padding: 0 4px;
}

.cr_question_section--block--form._cr_result {
  margin-top: 28px;
}
.cr_question_section--block--form._cr_result .cr_question_section--block--form--desc {
  margin-top: 36px;
}
@media (max-width: 520px) {
  .cr_question_section--block--form._cr_result .cr_inpit_check {
    font-size: 13px;
  }
}
@media (min-width: 521px) {
  .cr_question_section--block--form._cr_result + .cr_btn {
    margin-top: 27px;
  }
}

/* hidden_area
------------------------------- */
.cr_hidden_area {
  width: 640px;
  max-width: 100%;
  font-size: 14px;
  background-color: #fff;
  padding: 1em;
  overflow: hidden;
  position: fixed;
  bottom: 0;
  right: 0;
  z-index: 10;
}
.cr_hidden_area input {
  width: 100%;
}

/* シミュレーションテスト表示
------------------------------- */
.ss_test_wrap {
  width: 340px;
  max-width: 100%;
  background-color: #fff;
  padding: 1em;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  overflow: hidden;
}
.ss_test_wrap--ttl {
  font-size: 1.1em;
  font-weight: 500;
  margin-bottom: 0.3em;
}

.ss_test {
  font-size: 15px;
  line-height: 1.5;
}

/* シミュレーション遷移設定
------------------------------- */
#cr_question_02, #cr_question_03, #cr_question_04 {
  display: none;
}

.cr_btn._invalid {
  pointer-events: none;
  background-color: #eee;
  opacity: 0.6;
}

/* スピナー非表示
------------------------------- */
input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button {
  -webkit-appearance: none;
}

input[type=number] {
  -moz-appearance: textfield;
}

/* =======================================

 見積もりシミュレーション フォーム

 ======================================= */
.form_block {
  font-size: 15px;
  font-weight: 400;
  line-height: 1.5;
}
@media (max-width: 520px) {
  .form_block {
    font-size: 15px;
  }
}
.form_block .textA {
  font-size: 15px;
  font-weight: 400;
  line-height: 1.6;
  text-align: center;
  margin-bottom: 24px;
}
.form_block .form_edit {
  -webkit-transition: opacity 1s;
  transition: opacity 1s;
}
.form_block .wpcf7-form {
  padding-bottom: 94px;
  position: relative;
}
@media (max-width: 520px) {
  .form_block .wpcf7-form {
    padding-bottom: 48px;
  }
}
.form_block .wpcf7-form dl {
  margin-bottom: 22px;
}
.form_block .wpcf7-form dl dt {
  width: 100%;
  font-weight: 500;
  margin-bottom: 10px;
}
@media (max-width: 520px) {
  .form_block .wpcf7-form dl dt {
    width: 100%;
  }
}
.form_block .wpcf7-form dl dt label {
  display: block;
}
.form_block .wpcf7-form dl dd {
  width: 100%;
}
@media (max-width: 520px) {
  .form_block .wpcf7-form dl dd {
    width: 100%;
  }
}
.form_block .wpcf7-form dl dd.acceptance {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center; /*縦方向（Safari用）*/
  align-items: center; /* 縦方向*/
  -webkit-justify-content: center; /*横方向（Safari用）*/
  justify-content: center; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 9px;
  width: 100%;
  font-weight: 500;
  margin-top: 36px;
  position: relative;
}
.form_block .wpcf7-form dl dd.acceptance .wpcf7-list-item {
  display: block;
  text-align: center;
  padding: 0 !important;
}
.form_block .wpcf7-form dl dd.acceptance .wpcf7-list-item-label {
  display: none;
}
.form_block .wpcf7-form dl dd.acceptance [type=checkbox] {
  position: static;
}
.form_block .wpcf7-form dl dd.acceptance .wpcf7-not-valid-tip {
  width: 100%;
  white-space: nowrap;
  position: absolute;
  top: 100%;
  left: 0;
}
.form_block .wpcf7-form dl dd.acceptance a {
  color: #004898;
}
.form_block .wpcf7-form .hissu::after {
  content: "";
  display: inline-block;
  width: 18px;
  aspect-ratio: 1/1;
  vertical-align: sub;
  border-radius: 18px;
  background-color: #EF5353;
  margin-left: 0.6em;
}
.form_block .wpcf7-form .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}
.form_block .wpcf7-form .wpcf7-form-control-wrap .wpcf7-not-valid-tip {
  font-size: 0.8em;
  line-height: 1.2;
}
.form_block .wpcf7-form .wpcf7-form-control.wpcf7-radio, .form_block .wpcf7-form .wpcf7-form-control.input_radio, .form_block .wpcf7-form .wpcf7-form-control.wpcf7-acceptance, .form_block .wpcf7-form .wpcf7-form-control.wpcf7-checkbox {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start; /*縦方向（Safari用）*/
  align-items: flex-start; /* 縦方向*/
  -webkit-justify-content: flex-start; /*横方向（Safari用）*/
  justify-content: flex-start; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 0.6em 1.2em;
  padding: 0.8em 0;
}
.form_block .wpcf7-form .wpcf7-form-control.wpcf7-radio .wpcf7-list-item, .form_block .wpcf7-form .wpcf7-form-control.input_radio .wpcf7-list-item, .form_block .wpcf7-form .wpcf7-form-control.wpcf7-acceptance .wpcf7-list-item, .form_block .wpcf7-form .wpcf7-form-control.wpcf7-checkbox .wpcf7-list-item {
  display: block;
  margin: 0;
  padding-left: 1.5em;
  position: relative;
}
.form_block .wpcf7-form .wpcf7-form-control.wpcf7-radio input, .form_block .wpcf7-form .wpcf7-form-control.input_radio input, .form_block .wpcf7-form .wpcf7-form-control.wpcf7-acceptance input, .form_block .wpcf7-form .wpcf7-form-control.wpcf7-checkbox input {
  display: block;
  width: 1em;
  margin: 0;
  transform: scale(1.5);
  position: absolute;
  top: 0.32em;
  left: 0;
}
.form_block .wpcf7-form .wpcf7-form-control.wpcf7-acceptance {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center; /*縦方向（Safari用）*/
  align-items: center; /* 縦方向*/
  -webkit-justify-content: center; /*横方向（Safari用）*/
  justify-content: center; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}
.form_block .wpcf7-form input, .form_block .wpcf7-form textarea, .form_block .wpcf7-form select {
  width: 100%;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1em;
  border: 0;
  background-color: #F8F8F8 !important;
  box-shadow: none;
  padding: 0.4em 0.8em;
}
.form_block .wpcf7-form input[type=checkbox], .form_block .wpcf7-form input[type=radio] {
  height: auto;
}
.form_block .wpcf7-form input, .form_block .wpcf7-form select {
  height: 47px;
}
.form_block .wpcf7-form select {
  padding-right: 3em;
  padding-left: 1em;
  cursor: pointer;
  text-indent: 0.01px;
  text-overflow: ellipsis;
  border: none;
  outline: none;
  background-image: url("../img/parts/caret-down-solid.svg");
  background-size: 1.4rem auto;
  background-position: right 2rem center;
  background-repeat: no-repeat;
  box-shadow: none;
  -webkit-appearance: none;
  appearance: none;
  position: relative;
  z-index: 1;
}
.form_block .wpcf7-form select option {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1em;
}
.form_block .wpcf7-form .wpcf7-submit {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center; /*縦方向（Safari用）*/
  align-items: center; /* 縦方向*/
  -webkit-justify-content: center; /*横方向（Safari用）*/
  justify-content: center; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  border: 0;
  width: 192px;
  height: 40px;
  border: 0;
  border-radius: 40px;
  color: #000;
  cursor: pointer;
  background-color: #F2EC2B;
  border: 2px solid #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  letter-spacing: 0.1em;
  font-weight: 700;
}
.form_block .wpcf7-form .wpcf7-submit:hover {
  opacity: 0.8;
}
@media (max-width: 520px) {
  .form_block .wpcf7-form .wpcf7-submit {
    width: 150px;
  }
}
.form_block .wpcf7-form .wpcf7-submit {
  margin: 0 auto;
}
.form_block .wpcf7-form .wpcf7-spinner {
  margin: 0;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateY(-140%) translateX(-50%);
  transform: translateY(-140%) translateX(-50%);
}
.form_block .wpcf7cp-btns {
  margin-top: 3em;
  margin-bottom: 2em;
  position: relative;
}
@media (max-width: 520px) {
  .form_block .wpcf7cp-btns {
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center; /*縦方向（Safari用）*/
    align-items: center; /* 縦方向*/
    -webkit-justify-content: center; /*横方向（Safari用）*/
    justify-content: center; /*横方向*/
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}
.form_block .wpcf7cp-btns > p {
  width: 100%;
}

/* 確認画面
------------------------------- */
.form_block div#wpcf7cpcnf {
  position: relative;
  left: auto;
  text-align: left;
  padding-top: 0;
  animation: fadein 2s both;
}
.form_block div#wpcf7cpcnf {
  position: relative;
  left: auto;
  text-align: left;
  padding-top: 0;
  padding-bottom: 12rem;
  animation: fadein 2s both;
}
.form_block div#wpcf7cpcnf table {
  width: 100%;
}
.form_block div#wpcf7cpcnf table > tr th, .form_block div#wpcf7cpcnf table > tr td {
  text-align: left;
  padding-top: 0.8rem;
  padding-bottom: 0.8rem;
}
@media (max-width: 520px) {
  .form_block div#wpcf7cpcnf table > tr th, .form_block div#wpcf7cpcnf table > tr td {
    display: block;
    width: 100%;
    padding-top: 0.4rem;
    padding-bottom: 0.4rem;
  }
}
.form_block div#wpcf7cpcnf table > tr th p, .form_block div#wpcf7cpcnf table > tr td p {
  padding: 0.8em 0;
}
.form_block div#wpcf7cpcnf table > tr th p:empty, .form_block div#wpcf7cpcnf table > tr td p:empty {
  display: none;
}
.form_block div#wpcf7cpcnf table > tr th {
  width: 20rem;
  vertical-align: top;
  padding-right: 1em;
}
@media (max-width: 520px) {
  .form_block div#wpcf7cpcnf table > tr th {
    width: 100%;
    padding-bottom: 0;
  }
}
@media (max-width: 520px) {
  .form_block div#wpcf7cpcnf table > tr td {
    padding-top: 0;
  }
}
.form_block div#wpcf7cpcnf table > tr td p {
  background-color: #eee;
  padding: 0.8em;
}
.form_block div.wpcf7cp-btns {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center; /*縦方向（Safari用）*/
  align-items: center; /* 縦方向*/
  -webkit-justify-content: center; /*横方向（Safari用）*/
  justify-content: center; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 2rem;
  margin-top: 5em;
  margin-bottom: 3em;
}
@media (max-width: 520px) {
  .form_block div.wpcf7cp-btns {
    margin-top: 2em;
  }
}
.form_block div.wpcf7cp-btns button.wpcf7-form-control {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center; /*縦方向（Safari用）*/
  align-items: center; /* 縦方向*/
  -webkit-justify-content: center; /*横方向（Safari用）*/
  justify-content: center; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  border: 0;
  width: 192px;
  height: 40px;
  border: 0;
  border-radius: 40px;
  color: #000;
  cursor: pointer;
  background-color: #F2EC2B;
  border: 2px solid #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  letter-spacing: 0.1em;
  font-weight: 700;
}
.form_block div.wpcf7cp-btns button.wpcf7-form-control:hover {
  opacity: 0.8;
}
@media (max-width: 520px) {
  .form_block div.wpcf7cp-btns button.wpcf7-form-control {
    width: 150px;
  }
}
.form_block div.wpcf7cp-btns button.wpcf7-form-control.wpcf7cp-cfm-edit-btn {
  background-color: #000000;
}

/* テキスト
------------------------------- */
.form_block .text_edit,
.form_block .text_confirm {
  font-size: 1.2em;
  font-weight: 500;
  text-align: center;
  line-height: 1.8;
  margin-bottom: 2em;
}
@media (max-width: 520px) {
  .form_block .text_edit,
  .form_block .text_confirm {
    font-size: 1em;
    margin: 0 -1em 1.5em;
  }
}
.form_block .text_confirm {
  display: none;
}

/* 画面切り替え時
------------------------------- */
.form_block .wpcf7-form.wpcf7cp-form-hide {
  visibility: visible !important;
  padding: 0;
}
.form_block .wpcf7-form.wpcf7cp-form-hide .form_edit {
  overflow: hidden;
  height: 0;
  padding: 0;
  opacity: 0;
}
.form_block .wpcf7-form.wpcf7cp-form-hide .text_edit {
  display: none;
}
.form_block .wpcf7-form.wpcf7cp-form-hide .text_confirm {
  display: block;
}

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

プラグインなしの確認画面

---------------------------------------- */
.anchor {
  position: relative;
}
.anchor span {
  position: absolute;
  left: 0;
  top: -8rem;
}
@media (max-width: 520px) {
  .anchor span {
    top: -18.667vw;
  }
}

.confirm_btn {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center; /*縦方向（Safari用）*/
  align-items: center; /* 縦方向*/
  -webkit-justify-content: center; /*横方向（Safari用）*/
  justify-content: center; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  border: 0;
  width: 192px;
  height: 40px;
  border: 0;
  border-radius: 40px;
  color: #fff;
  cursor: pointer;
  background-color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  letter-spacing: 0.1em;
  font-weight: 700;
}
.confirm_btn:hover {
  opacity: 0.8;
}
@media (max-width: 520px) {
  .confirm_btn {
    width: 150px;
  }
}
.confirm_btn p {
  letter-spacing: inherit;
}

input.submit_btn01 {
  font-family: "Noto Sans JP", sans-serif;
}

.submit_wrap {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center; /*縦方向（Safari用）*/
  align-items: center; /* 縦方向*/
  -webkit-justify-content: center; /*横方向（Safari用）*/
  justify-content: center; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 53px auto 0;
  position: relative;
}
.submit_wrap.confirm_on {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center; /*縦方向（Safari用）*/
  align-items: center; /* 縦方向*/
  -webkit-justify-content: center; /*横方向（Safari用）*/
  justify-content: center; /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 15px;
}

/* 必須項目に未入力がある場合
------------------------------- */
body:not(.all-required-filled) .js_confirm {
  cursor: not-allowed;
  position: relative;
}
body:not(.all-required-filled) .js_confirm::after {
  content: "必須項目に未入力があります";
  display: block;
  width: 300px;
  font-size: 1em;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.03em;
  text-align: center;
  color: #dc3232;
  padding-bottom: 0.5em;
  position: absolute;
  bottom: 100%;
  left: 50%;
  -webkit-transform: translateY(0) translateX(-50%);
  transform: translateY(0) translateX(-50%);
}

/* 確認前（入力画面）
------------------------------- */
body:not(.verification_screen) .confirm_on {
  display: none !important;
}
body:not(.verification_screen) textarea[name=your-message] {
  min-height: 16em;
}
@media (max-width: 520px) {
  body:not(.verification_screen) textarea[name=your-message] {
    min-height: 16em;
  }
}

/* 確認画面
------------------------------- */
.verification_screen .confirm_off {
  display: none !important;
}
.verification_screen .wpcf7 th.hisu .privacy_table_inner_ttl::after {
  display: none;
}
.verification_screen .wpcf7 td .privacy_table_inner {
  background-color: #ccc !important;
  border: 0 !important;
  pointer-events: none !important;
  padding-left: 1em;
}
.verification_screen .wpcf7 td .privacy_table_inner .wpcf7-list-item {
  margin: 0;
}
.verification_screen .wpcf7 td .fx_contact {
  -webkit-justify-content: flex-start; /*横方向（Safari用）*/
  justify-content: flex-start; /*横方向*/
}
.verification_screen .wpcf7 td .fx_contact .flex_block_child.blockB {
  background-color: #ccc !important;
  border: 0 !important;
  pointer-events: none !important;
  padding-left: 1em;
}
@media (max-width: 520px) {
  .verification_screen .wpcf7 td .fx_contact .flex_block_child.blockB {
    width: 1000%;
  }
}
.verification_screen .wpcf7 td .fx_contact .flex_block_child .privacy_table_inner {
  background-color: transparent !important;
  padding-left: 0 !important;
}
@media (max-width: 520px) {
  .verification_screen .wpcf7 td .fx_contact.typrB > .blockA {
    width: auto;
  }
}
@media (max-width: 520px) {
  .verification_screen .wpcf7 td .fx_contact.typrB > .blockB {
    width: 80%;
  }
}
.verification_screen .wpcf7 [type=text],
.verification_screen .wpcf7 [type=tel],
.verification_screen .wpcf7 [type=email],
.verification_screen .wpcf7 select {
  background-color: #ccc !important;
  border: 0 !important;
  pointer-events: none !important;
}
.verification_screen .wpcf7 textarea {
  background-color: #ccc !important;
  border: 0 !important;
  pointer-events: none !important;
}
.verification_screen .wpcf7 [type=radio],
.verification_screen .wpcf7 [type=checkbox] {
  display: none !important;
}
.verification_screen .wpcf7 [type=radio] + .wpcf7-list-item-label,
.verification_screen .wpcf7 [type=checkbox] + .wpcf7-list-item-label {
  padding-left: 0 !important;
}
@media (max-width: 520px) {
  .verification_screen .wpcf7 [type=radio] + .wpcf7-list-item-label,
  .verification_screen .wpcf7 [type=checkbox] + .wpcf7-list-item-label {
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center; /*縦方向（Safari用）*/
    align-items: center; /* 縦方向*/
    -webkit-justify-content: flex-start; /*横方向（Safari用）*/
    justify-content: flex-start; /*横方向*/
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    height: 10vw;
    font-size: 4.2vw;
  }
}
.verification_screen .wpcf7 [type=radio]:not(:checked) + .wpcf7-list-item-label,
.verification_screen .wpcf7 [type=checkbox]:not(:checked) + .wpcf7-list-item-label {
  display: none;
}

/* アニメーション
------------------------------- */
.add_confirm_form {
  position: relative;
}
.add_confirm_form::before {
  content: "";
  width: 5rem;
  height: 5rem;
  border: 3px solid #fb5b53;
  border-top: 3px solid transparent;
  border-radius: 50%;
  animation: spin 0.5s linear 0s infinite;
  position: fixed;
  top: 50%;
  left: 50%;
  z-index: 1;
  margin-top: -2.5rem;
  margin-left: -2.5rem;
  transition: 0.6s;
  opacity: 0;
}
.add_confirm_loading .add_confirm_form::before {
  opacity: 1;
}
.add_confirm_form .wpcf7-form {
  opacity: 0;
}
.defo_screen .add_confirm_form .wpcf7-form {
  opacity: 1;
}
.edit_screen .add_confirm_form .wpcf7-form, .verification_screen .add_confirm_form .wpcf7-form {
  animation: fadein 0.8s ease both;
}

@keyframes fadein {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes spin {
  from {
    transform: rotate(0);
  }
  to {
    transform: rotate(359deg);
  }
}
/* レイアウト
------------------------------- */
.cr_question_form {
  max-width: 576px;
  margin: 75px auto 0;
}
@media (max-width: 520px) {
  .cr_question_form {
    margin: 36px auto 0;
  }
}

/* 送信完了
------------------------------- */
.cr_question_section--complete_notes {
  font-size: 15px;
  font-weight: 500;
  line-height: 1.8;
  text-align: center;
}
/*# sourceMappingURL=_maps/style.css.map */
