/*
Theme Name: フェニックススイムクラブ オリジナルテーマ
Theme URI: 
Author: フェニックススイムクラブ
Author URI: 
Description: 
Requires at least: 5.9
Tested up to: 6.3
Requires PHP: 5.6
Version: 1.5
License: 
License URI: 
Tags: 

*/





/* 下層　lower フォーム
------------------------------------------------------------*/
#contact .kvArea p,
#contact .mainArea p {
  font-size: 16px;
  font-weight: normal;
  margin-bottom: 20px;
}
#contact .mainArea p.thanks-message {
  font-size: 20px;
}

#contact .form h3 {
  font-size: 16px;
  font-weight: normal;
  margin-bottom: 10px;
}
#contact .form h4 {
  font-size: 14px;
  font-weight: normal;
  padding-bottom: 10px;
  border-bottom: 1px solid #dddddd;
  margin-bottom: 10px;
  margin-top: 10px;
}
#contact .form p {
  font-size: 12px;
  margin-bottom: 30px;
  margin-top: 10px;
}
#contact .form .openhouseText p {
  font-size: 14px;
}
#contact .form .form__ttl p {
  margin-bottom: 0;
}
#contact .form .required {
  color: #ff007b;
  font-size: 12px;
}

#contact .form .form__block {
  margin-bottom: 30px;
}
#contact .form .form__block .form__ttl {
  font-size: 18px;
  font-weight: 700;
  padding-bottom: 10px;
}
#contact .form .form__block dd {
  margin-bottom: 30px;
}
#contact .form .form__block dd input {
  background: #f8f8f8;
  border-radius: 6px;
  min-height: 50px;
  width: 100%;
  padding: 5px 10px;
  font-size: 14px;
  color: inherit;
}
#contact .form .form__block dd.words3 {
  font-size: 14px;
}
#contact .form .form__block dd.words3 input {
  width: 5em;
  margin-right: 10px;
  font-size: 14px;
}
#contact .form .form__block dd input::placeholder {
  color: #cccccc;
  font-size: 14px;
}

#contact .form .form__block dd textarea {
  background: #f8f8f8;
  border-radius: 6px;
  min-height: 70px;
  height: 120px;
  width: 100%;
  padding: 5px 10px;
  font-size: 14px;
  color: inherit;
}
#contact .form ul {
  font-size: 12px;
  font-weight: normal;
}
#contact .form p.no-marginbottom {
  margin-bottom: 0;
}


#contact .form .submitBtn {
  text-align: center;
  margin: 50px 0 100px;
}
#contact .form .submitBtn .submit_inner {
  display: inline-block;
  position: relative;
}

#contact .form .submitBtn .submit_inner:after {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: rotate(45deg);
  position: absolute;
  right: 20px;
  top: 0;
  bottom: 0;
  margin: auto;
}
#contact .form .submitBtn .wpcf7-submit {
  background: #003491;
  border-radius: 50px;
  display: inline-block;
  color: #fff;
  padding: 18px 80px 20px;
  margin: 0 auto;
  transition: .3s opacity ease;
}
#contact .form .submitBtn .wpcf7-submit:hover {
  opacity: 0.7;
  transition: .3s opacity ease;
}
#contact.baby .form .submitBtn .wpcf7-submit {
  background: #ff72b1;
}
#contact.junior .form .submitBtn .wpcf7-submit {
  background: #00c568;
}





#contact .wpcf7-spinner {
  display: none;
}
#contact .wpcf7-response-output {
  border: none;
  color: #dc3232;
  text-align: center;
}
.wpcf7 form.sent .wpcf7-response-output {
  display: none;
}




#contact .kvCopy_lower {
  font-size: 50px;
  font-weight: 900;
  text-align: center;
  margin: 30px auto 60px;
  color: #ff72b1;
}
#contact.junior .kvCopy_lower {
  color: #00c568;
}


#contact .kvCopy_lower .deco01 {
  font-size: 38px;
  color: #fff;
  background: #ff72b1;
  line-height: 1;
  border-radius: 36px;
  display: inline-block;
  padding: 11px 8px 13px;
  vertical-align: 6px;
  letter-spacing: 0;
  margin-right: 5px;
}
#contact.junior .kvCopy_lower .deco01 {
  background: #00c568;
}
#contact .kvCopy_lower .deco02 {
  font-size: 25px;
  vertical-align: 3px;
}
#contact .kvCopy_lower_h2 {
  font-size: 40px;
  font-weight: 900;
  text-align: center;
  margin: 30px auto;
  color: #ff72b1;
}
#contact.junior .kvCopy_lower_h2 {
  color: #00c568;
}
#contact p.explan_01 {
  font-size: 20px;
  text-align: center;
}
#contact p.explan_02 {
  font-size: 12px;
  text-align: center;
  margin-bottom: 80px;
}

#contact .kvArea {
  max-width: 1080px;
  width: 100%;
}
#contact .kvArea .kv_logo {
  margin: 100px auto 20px;
  width: 650px;
}
#contact .inner {
  max-width: 800px;
  width: 100%;
}


#contact .form .form__block dd.form__radio {
  margin-bottom: 10px;
}
#contact .form .wpcf7-checkbox,
#contact .form .wpcf7-radio {
  margin-top: 10px;
  display: block;
}
#contact .form .wpcf7-list-item {
  display: block;
}
#contact .form .form__block dd .customerBox01 {
  margin: 10px 0;
}
#contact .form .form__block dd .customerBox02 {
  margin: 10px 0 20px;
}




#contact .form .form__radio .wpcf7-list-item {
  display: block;
  margin: 0;
  width: calc(100% / 3);
}
#contact .form .form__radio .wpcf7-list-item label {
  cursor: pointer;
}
#contact .form .form__radio input[type="radio"] {
  margin-right: 10px;
  cursor: pointer;
}

#contact .form .wpcf7-validates-as-date,
#contact .form .wpcf7-text,
#contact .form .wpcf7-textarea {
  border: none;
  padding: 10px 15px;
  background: #f8f8f8;
  border-radius: 3px;
}
#contact .form .wpcf7-textarea {
  width: 100%;
}
#contact .form .wpcf7-select {
  border: none;
  padding: 10px 40px 10px 15px;
  background: #f8f8f8;
  border-radius: 3px;
  cursor: pointer;
  font-size: 14px;
  min-width: 250px;
  margin-bottom: 20px;
}


#contact .form .wpcf7-form-control-wrap:has(select) {
  position: relative;
  -webkit-appearance: none;
  appearance: none;
  display: inline-block;
}

#contact .form .wpcf7-form-control-wrap:has(select)::after {
  content: "";
  position: absolute;
  top: 13px;
  right: 15px;
  width: 10px;
  height: 10px;
  border-right: 2px solid #666;
  border-bottom: 2px solid #666;
  transform: rotate(45deg);
}



#contact .form .wpcf7-textarea:has(select) {
  width: 100%;
}

#contact .privacy_policy {
  width: 100%;
  height: 200px;
  background-color: #fff;
  overflow-y: scroll;
  padding: 20px;
  margin: 0 0 30px 0;
  border: 1px solid #ccc;
}

#contact .form input[type=radio],
#contact .form input[type=checkbox] {
  opacity: 0;
  z-index: -1;
  position: absolute;
}
#contact .form label:focus,
#contact .form label:hover,
#contact .form label:active,
#contact .form input:checked + label {
  color: #333;
}
#contact .form label:focus:before,
#contact .form label:hover:before,
#contact .form label:active:before,
#contact .form input:checked + label:before {
  border-color: #333;
  background: #ffffff;
}
#contact .form label {
  line-height: 1;
  position: relative;
  display: block;
  padding: 0 0 5px 20px;
  cursor: pointer;
  transition: all .3s ease;
  width: 100%;
}
#contact .form label span {
  display: block;
  width: 100%;
  font-size: 14px;
  margin-bottom: 20px;
}
#contact .form label:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 15px;
  height: 15px;
  content: '';
  border: 2px solid #cccccc;
  border-radius: 50%;
}
#contact .form .form__checkbox label:before {
  border-radius: 2px;
}
#contact .form .form__radio input:checked + label:before,
#contact .form .form__radio label:has(input:checked):before {
  border-color: #333;
  background: #333;
}
#contact .form .form__radio input:disabled + label {
  cursor: not-allowed;
  color: rgba(0, 0, 0, 0.5);
  background: #f8f8f8;
}
#contact .form .form__radio input:disabled + label:hover {
  border-color: rgba(0, 0, 0, 0.1);
}
#contact .form .form__radio input:disabled + label:before {
  border-color: #ffffff;
  background: #ffffff;
}

#contact .form .wpcf7-submit {
  padding: 10px 15px;
  background: #f8f8f8;
  margin: 0 auto;
  display: block;
  font-size: 16px;
}
#contact .form .wpcf7-submit:hover {
  background: #eeeeee;
}
#contact .wpcf7-spinner {
  display: none;
}
#contact .wpcf7-response-output {
  border: none;
  color: #dc3232;
  text-align: center;
}
.wpcf7 form.sent .wpcf7-response-output {
  display: none;
}

#contact .wpcf7-not-valid-tip {
  font-size: 13px;
}

.thanks-message {
  margin: 100px 0 200px !important;
}

#contact .flowArea {
  padding: 50px 40px 50px 90px;
  width: 765px;
  border: 5px dotted #0094ff;
  border-radius: 20px;
  margin-bottom: 100px;
}
#contact .flowArea .flowTittle {
  text-align: center;
  font-size: 28px;
  color: #0094ff;
  position: relative;
  cursor: pointer;
  padding-right: 50px;
}
#contact .flowArea .flowTittle .accBtn {
  width: 36px;
  height: 36px;
  border-radius: 18px;
  background: #0094ff;
  position: absolute;
  right: 0;
  top: 0;
}
#contact .flowArea .flowTittle .accBtn:after {
  content: "Open";
  display: block;
  position: absolute;
  bottom: -22px;
  left: -12px;
  right: 0;
  margin: auto;
  color: #0094ff;
  font-size: 14px;
  width: 60px;
  letter-spacing: 0;
}
#contact .flowArea .flowTittle .accBtn.is-open:after {
  content: "Close";
}
#contact .flowArea .flowTittle .accBtn span {
  display: block;
  width: 18px;
  height: 1px;
  border-top: 3px solid #fff;
  position: absolute;
  top: 0;
  bottom: -2px;
  left: 0;
  right: 0;
  margin: auto;
}
#contact .flowArea .flowTittle .accBtn span:after {
  content: "";
  display: block;
  width: 18px;
  height: 1px;
  border-top: 3px solid #fff;
  position: absolute;
  top: -3px;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  transform: rotate(90deg);
  transition: .3s transform ease;
}
#contact .flowArea .flowTittle .accBtn.is-open span:after {
  transform: rotate(360deg);
  transition: .3s transform ease;
}
#contact .flowArea .flow_step {
  padding-top: 60px;
  display: none;
}
#contact .flowArea .flow_step li {
  position: relative;
  padding-left: 100px;
  margin-bottom: 100px;
}
#contact .flowArea .flow_step li:nth-child(3) {
  margin-bottom: 0;
}
#contact .flowArea .flow_step li:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 14px solid transparent;
  border-left: 14px solid transparent;
  border-top: 24px solid #0094ff;
  border-bottom: 0;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -60px;
  margin: auto;
}
#contact .flowArea .flow_step li:nth-child(3):after {
  content: unset;
}
#contact .flowArea .flow_step li img {
  width: 70px;
  display: block;
  position: absolute;
  left: 0;
  top: -15px;
}





@media screen and (max-width:1080px) {

  /* 下層　lower フォーム
  ------------------------------------------------------------*/
  #contact .form h3 {
    font-size: 1.6vw;
    font-weight: normal;
    margin-bottom: 1vw;
  }
  #contact .form h4 {
    font-size: 1.4vw;
    font-weight: normal;
    padding-bottom: 1vw;
    border-bottom: 1px solid #dddddd;
    margin-bottom: 1vw;
    margin-top: 1vw;
  }

  #contact .form p {
    font-size: 1.2vw;
    margin-bottom: 3vw;
    margin-top: 1vw;
  }
  #contact .form .openhouseText p {
    font-size: 1.4vw;
  }
  #contact .form .form__ttl p {
    margin-bottom: 0;
  }

  #contact .form .required {
    color: #ff007b;
    font-size: 1.2vw;
  }
  #contact .form .form__block {
    margin-bottom: 3vw;
  }
  #contact .form .form__block .form__ttl {
    font-size: 1.6vw;
    font-weight: 700;
    padding-bottom: 1vw;
  }
  #contact .form .form__block dd {
    margin-bottom: 3vw;
  }
  #contact .form .form__block dd input {
    background: #f8f8f8;
    border-radius: 6px;
    min-height: 5vw;
    width: 100%;
    padding: .5vw 1vw;
    font-size: 1.4vw;
    color: inherit;
  }
  #contact .form .form__block dd.words3 {
    font-size: 1.4vw;
  }
  #contact .form .form__block dd.words3 input {
    width: 5em;
    margin-right: 1vw;
    font-size: 1.4vw;
  }
  #contact .form .form__block dd input::placeholder {
    color: #cccccc;
    font-size: 1.4vw;
  }

  #contact .form .form__block dd textarea {
    background: #f8f8f8;
    border-radius: 6px;
    min-height: 7vw;
    height: 12vw;
    width: 100%;
    padding: .5vw 1vw;
    font-size: 1.4vw;
    color: inherit;
  }
  #contact .form ul {
    font-size: 1.2vw;
  }
  #contact .form p.no-marginbottom {
    margin-bottom: 0;
  }


  #contact .form .submitBtn {
    text-align: center;
    margin: 5vw 0 10vw;
  }
  #contact .form .submitBtn .submit_inner {
    display: inline-block;
    position: relative;
  }

  #contact .form .submitBtn .submit_inner:after {
    content: "";
    display: block;
    width: 1vw;
    height: 1vw;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: rotate(45deg);
    position: absolute;
    right: 2vw;
    top: 0;
    bottom: 0;
    margin: auto;
  }
  #contact .form .submitBtn .wpcf7-submit {
    background: #003491;
    border-radius: 5vw;
    display: inline-block;
    color: #fff;
    padding: 1.8vw 8vw 2vw;
    margin: 0 auto;
    transition: .3s opacity ease;
  }
  #contact .form .submitBtn .wpcf7-submit:hover {
    opacity: 0.7;
    transition: .3s opacity ease;
  }





  #contact .wpcf7-spinner {
    display: none;
  }
  #contact .wpcf7-response-output {
    border: none;
    color: #dc3232;
    text-align: center;
  }
  .wpcf7 form.sent .wpcf7-response-output {
    display: none;
  }



  #contact .kvCopy_lower {
    font-size: 4.5vw;
    font-weight: 900;
    text-align: center;
    margin: 3vw auto 6vw;
    color: #ff72b1;
  }
  #contact.junior .kvCopy_lower {
    color: #00c568;
  }

  #contact .kvCopy_lower .deco01 {
    font-size: 3.8vw;
    color: #fff;
    background: #ff72b1;
    line-height: 1;
    border-radius: 3.6vw;
    display: inline-block;
    padding: 1.1vw .8vw 1.3vw;
    vertical-align: .6vw;
    letter-spacing: 0;
    margin-right: .5vw;
  }
  #contact.junior .kvCopy_lower .deco01 {
    background: #00c568;
  }


  #contact .kvCopy_lower .deco02 {
    font-size: 2.5vw;
    vertical-align: .3vw;
  }
  #contact .kvCopy_lower_h2 {
    font-size: 3.6vw;
    font-weight: 900;
    text-align: center;
    margin: 3vw auto;
    color: #ff72b1;
  }
  #contact.junior .kvCopy_lower_h2 {
    color: #00c568;
  }

  #contact p.explan_01 {
    font-size: 2vw;
    text-align: center;
  }
  #contact p.explan_02 {
    font-size: 1.2vw;
    text-align: center;
    margin-bottom: 8bvw;
  }

  #contact .kvArea {
    max-width: 1080px;
    width: 90%;
  }
  #contact .kvArea .kv_logo {
    margin: 10vw auto 2vw;
    width: 60vw;
  }
  #contact .inner {
    max-width: 800px;
    width: 80%;
  }



  #contact .form .form__block dd.form__radio {
    margin-bottom: 1vw;
  }
  #contact .form .wpcf7-checkbox,
  #contact .form .wpcf7-radio {
  }
  #contact .form .form__block dd .customerBox01 {
    margin: 1vw 0;
  }
  #contact .form .form__block dd .customerBox02 {
    margin: 1vw 0 2vw;
  }


  #contact .form .form__radio .wpcf7-list-item {
    display: block;
    margin: 0;
    width: calc(100% / 3);
  }
  #contact .form .form__radio .wpcf7-list-item label {
    cursor: pointer;
  }
  #contact .form .form__radio input[type="radio"] {
    margin-right: 1vw;
    cursor: pointer;
  }

  #contact .form .wpcf7-validates-as-date,
  #contact .form .wpcf7-text,
  #contact .form .wpcf7-textarea {
    border: none;
    padding: 1vw 1.5vw;
    background: #f8f8f8;
    border-radius: 3px;
  }
  #contact .form .wpcf7-textarea {
    width: 100%;
  }
  #contact .form .wpcf7-select {
    border: none;
    padding: 1vw 4vw 1vw 1.5vw;
    background: #f8f8f8;
    border-radius: 3px;
    cursor: pointer;
    min-width: 25vw;
    margin-bottom: 2vw;
    font-size: 1.4vw;
  }


  #contact .form .wpcf7-form-control-wrap:has(select) {
      position: relative;
      -webkit-appearance: none;
      appearance: none;
  }

  #contact .form .wpcf7-form-control-wrap:has(select)::after {
      content: "";
      position: absolute;
      top: 1.3vw;
      right: 1.5vw;
      width: 1vw;
      height: 1vw;
      border-right: 2px solid #666;
      border-bottom: 2px solid #666;
      transform: rotate(45deg);
      pointer-events: none;
  }



  #contact .form .wpcf7-textarea:has(select) {
    width: 100%;
  }

  #contact .privacy_policy {
    width: 100%;
    height: 20vw;
    background-color: #fff;
    overflow-y: scroll;
    padding: 2vw;
    margin: 0 0 3vw 0;
  }

  #contact .form input[type=radio],
  #contact .form input[type=checkbox] {
    opacity: 0;
    z-index: -1;
    position: absolute;
  }
  #contact .form label:focus,
  #contact .form label:hover,
  #contact .form label:active,
  #contact .form input:checked + label {
    color: #333;
  }
  #contact .form label:focus:before,
  #contact .form label:hover:before,
  #contact .form label:active:before,
  #contact .form input:checked + label:before {
    border-color: #333;
    background: #ffffff;
  }
  #contact .form label {
    line-height: 1;
    position: relative;
    display: block;
    padding: 0 0 .5vw 2vw;
    cursor: pointer;
    transition: all .3s ease;
    width: 100%;
  }
  #contact .form label span {
    display: block;
    width: 100%;
    font-size: 1.4vw;
  }
  #contact .form label:before {
    position: absolute;
    top: 0;
    left: 0;
    width: 1.5vw;
    height: 1.5vw;
    content: '';
    border: 2px solid #cccccc;
    border-radius: 50%;
  }
  #contact .form .form__checkbox label:before {
    border-radius: 2px;
  }
  #contact .form input:checked + label:before,
  #contact .form label:has(input:checked):before {
    border-color: #333;
    background: #333;
  }
  #contact .form input:disabled + label {
    cursor: not-allowed;
    color: rgba(0, 0, 0, 0.5);
    background: #f8f8f8;
  }
  #contact .form input:disabled + label:hover {
    border-color: rgba(0, 0, 0, 0.1);
  }
  #contact .form input:disabled + label:before {
    border-color: #ffffff;
    background: #ffffff;
  }

  #contact .form .wpcf7-submit {
    padding: 1vw 1.5vw;
    background: #f8f8f8;
    margin: 0 auto;
    display: block;
    font-size: 1.6vw;
  }
  #contact .form .wpcf7-submit:hover {
    background: #eeeeee;
  }
  #contact .wpcf7-spinner {
    display: none;
  }
  #contact .wpcf7-response-output {
    border: none;
    color: #dc3232;
    text-align: center;
  }
  .wpcf7 form.sent .wpcf7-response-output {
    display: none;
  }

  #contact .wpcf7-not-valid-tip {
    font-size: 1.3vw;
  }


  .thanks-message {
    margin: 6vw 0 20vw !important;
  }


  #contact .flowArea {
    padding: 5vw 4vw 5vw 9vw;
    width: 100%;
    border: 5px dotted #0094ff;
    border-radius: 2vw;
    margin-bottom: 10vw;
  }
  #contact .flowArea .flowTittle {
    text-align: center;
    font-size: 2.8vw;
    color: #0094ff;
    position: relative;
    cursor: pointer;
    padding-right: 5vw;
  }
  #contact .flowArea .flowTittle .accBtn {
    width: 3.6vw;
    height: 3.6vw;
    border-radius: 1.8vw;
    background: #0094ff;
    position: absolute;
    right: 0;
    top: 0;
  }
  #contact .flowArea .flowTittle .accBtn:after {
    content: "Open";
    display: block;
    position: absolute;
    bottom: -2.2vw;
    left: -1.2vw;
    right: 0;
    margin: auto;
    color: #0094ff;
    font-size: 1.4vw;
    width: 6vw;
    letter-spacing: 0;
  }
  #contact .flowArea .flowTittle .accBtn.is-open:after {
    content: "Close";
  }
  #contact .flowArea .flowTittle .accBtn span {
    display: block;
    width: 1.8vw;
    height: 1px;
    border-top: 3px solid #fff;
    position: absolute;
    top: 0;
    bottom: -2px;
    left: 0;
    right: 0;
    margin: auto;
  }
  #contact .flowArea .flowTittle .accBtn span:after {
    content: "";
    display: block;
    width: 1.8vw;
    height: 1px;
    border-top: 3px solid #fff;
    position: absolute;
    top: -3px;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    transform: rotate(90deg);
    transition: .3s transform ease;
  }
  #contact .flowArea .flowTittle .accBtn.is-open span:after {
    transform: rotate(360deg);
    transition: .3s transform ease;
  }
  #contact .flowArea .flow_step {
    padding-top: 6vw;
    display: none;
  }
  #contact .flowArea .flow_step li {
    position: relative;
    padding-left: 10vw;
    margin-bottom: 10vw;
  }
  #contact .flowArea .flow_step li:nth-child(3) {
    margin-bottom: 0;
  }
  #contact .flowArea .flow_step li:after {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 1.4vw solid transparent;
    border-left: 1.4vw solid transparent;
    border-top: 2.4vw solid #0094ff;
    border-bottom: 0;
    position: absolute;
    left: 0;
    right: 0;
    bottom: -6vw;
    margin: auto;
  }
  #contact .flowArea .flow_step li:nth-child(3):after {
    content: unset;
  }
  #contact .flowArea .flow_step li img {
    width: 7vw;
    display: block;
    position: absolute;
    left: 0;
    top: -1.5vw;
  }



}







/* スマートフォン
-----------------------------------------------*/
@media only screen and (max-width: 767px) {



  /* 下層　lower フォーム
  ------------------------------------------------------------*/
  #contact .kvArea p,
  #contact .mainArea p {
    font-size: 2.8vw;
    font-weight: normal;
    margin-bottom: 4vw;
  }
  #contact .mainArea p.thanks-message {
    font-size: 3.6vw;
    font-weight: normal;
    margin-bottom: 6vw;
  }
  #contact .form h3 {
    font-size: 3.2vw;
    font-weight: normal;
    margin-bottom: 2vw;
  }
  #contact .form h4 {
    font-size: 2.8vw;
    font-weight: normal;
    padding-bottom: 2vw;
    border-bottom: 1px solid #dddddd;
    margin-bottom: 2vw;
    margin-top: 2vw;
  }

  #contact .form p {
    font-size: 2.4vw;
    margin-bottom: 6vw;
    margin-top: 2vw;
  }
  #contact .form .openhouseText p {
    font-size: 2.8vw;
  }

  #contact .form .form__ttl p {
    margin-bottom: 0;
  }

  #contact .form .required {
    color: #ff007b;
    font-size: 2.4vw;
  }
  #contact .form .form__block {
    margin-bottom: 6vw;
  }
  #contact .form .form__block .form__ttl {
    font-size: 3.2vw;
    font-weight: 700;
    padding-bottom: 2vw;
  }
  #contact .form .form__block dd {
    margin-bottom: 6vw;
  }
  #contact .form .form__block dd input {
    background: #f8f8f8;
    border-radius: 6px;
    min-height: 7vw;
    width: 100%;
    padding: 1vw 2vw;
    font-size: 3.6vw;
    color: inherit;
  }
  #contact .form .form__block dd.words3 {
    font-size: 3.6vw;
  }
  #contact .form .form__block dd.words3 input {
    width: 5em;
    margin-right: 2vw;
    font-size: 3.6vw;
  }
  #contact .form .form__block dd input::placeholder {
    color: #cccccc;
    font-size: 2.8vw;
  }

  #contact .form .form__block dd textarea {
    background: #f8f8f8;
    border-radius: 6px;
    min-height: 12vw;
    height: 20vw;
    width: 100%;
    padding: 1vw 2vw;
    font-size: 3.6vw;
    color: inherit;
  }
  #contact .form ul {
    font-size: 2.4vw;
  }
  #contact .form p.no-marginbottom {
    margin-bottom: 0;
  }


  #contact .form .submitBtn {
    text-align: center;
    margin: 10vw 0 16vw;
  }
  #contact .form .submitBtn .submit_inner {
    display: inline-block;
    position: relative;
  }

  #contact .form .submitBtn .submit_inner:after {
    content: "";
    display: block;
    width: 2vw;
    height: 2vw;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: rotate(45deg);
    position: absolute;
    right: 4vw;
    top: 0;
    bottom: 0;
    margin: auto;
  }
  #contact .form .submitBtn .wpcf7-submit {
    background: #003491;
    border-radius: 10vw;
    display: inline-block;
    color: #fff;
    padding: 3.6vw 20vw 4vw;
    font-size: 4.5vw;
    margin: 0 auto;
    transition: .3s opacity ease;
  }
  #contact .form .submitBtn .wpcf7-submit:hover {
    opacity: 0.7;
    transition: .3s opacity ease;
  }





  #contact .wpcf7-spinner {
    display: none;
  }
  #contact .wpcf7-response-output {
    border: none;
    color: #dc3232;
    text-align: center;
  }
  .wpcf7 form.sent .wpcf7-response-output {
    display: none;
  }



  #contact .kvCopy_lower {
    font-size: 10vw;
    font-weight: 900;
    text-align: center;
    margin: 6vw auto 12vw;
    color: #ff72b1;
  }
  #contact.junior .kvCopy_lower {
    color: #00c568;
  }
  #contact .kvCopy_lower .deco01 {
    font-size: 6vw;
    color: #fff;
    background: #ff72b1;
    line-height: 1;
    border-radius: 7vw;
    display: inline-block;
    padding: 2.2vw 1.6vw 2.6vw;
    vertical-align: .5vw;
    letter-spacing: 0;
    margin-right: 1vw;
  }
  #contact.junior .kvCopy_lower .deco01 {
    background: #00c568;
  }

  #contact .kvCopy_lower .deco02 {
    font-size: 4vw;
    vertical-align: .6vw;
  }
  #contact .kvCopy_lower_h2 {
    font-size: 6.5vw;
    font-weight: 900;
    text-align: center;
    margin: 6vw auto 2vw;
    color: #ff72b1;
  }
  #contact.junior .kvCopy_lower_h2 {
    color: #00c568;
  }

  #contact p.explan_01 {
    font-size: 4vw;
    text-align: center;
    margin-bottom: 2vw;
  }
  #contact p.explan_02 {
    font-size: 2.4vw;
    text-align: center;
    margin-bottom: 10vw;
  }

  #contact .kvArea {
    max-width: 1080px;
    width: 100%;
  }
  #contact .kvArea .kv_logo {
    margin: 20vw auto 4vw;
    width: 80%;
  }
  #contact .inner {
    max-width: 800px;
    width: 100%;
  }



  #contact .form .form__block dd.form__radio {
    margin-bottom: 2vw;
    overflow-x: hidden;
  }
  #contact .form .wpcf7-checkbox,
  #contact .form .wpcf7-radio {
  }

  #contact .form .form__block dd .customerBox01 {
    margin: 2vw 0;
  }
  #contact .form .form__block dd .customerBox02 {
    margin: 2vw 0 4vw;
  }


  #contact .form .form__radio .wpcf7-list-item {
    display: block;
    margin: 0;
    width: 100%;
  }
  #contact .form .form__radio .wpcf7-list-item label {
    cursor: pointer;
  }
  #contact .form .form__radio input[type="radio"] {
    margin-right: 2vw;
    cursor: pointer;
  }

  #contact .form .wpcf7-validates-as-date,
  #contact .form .wpcf7-text,
  #contact .form .wpcf7-textarea {
    border: none;
    padding: 2vw 3vw;
    background: #f8f8f8;
    border-radius: 3px;
  }
  #contact .form .wpcf7-textarea {
    width: 100%;
  }
  #contact .form .wpcf7-select {
    border: none;
    padding: 2vw 8vw 2vw 3vw;
    background: #f8f8f8;
    border-radius: 3px;
    cursor: pointer;
    min-width: 50vw;
    margin-bottom: 4vw;
    font-size: 3.6vw;
  }


  #contact .form .wpcf7-form-control-wrap:has(select) {
      position: relative;
      -webkit-appearance: none;
      appearance: none;
  }

  #contact .form .wpcf7-form-control-wrap:has(select)::after {
      content: "";
      position: absolute;
      top: 2.6vw;
      right: 3vw;
      width: 2vw;
      height: 2vw;
      border-right: 2px solid #666;
      border-bottom: 2px solid #666;
      transform: rotate(45deg);
  }



  #contact .form .wpcf7-textarea:has(select) {
    width: 100%;
  }

  #contact .privacy_policy {
    width: 100%;
    height: 40vw;
    background-color: #fff;
    overflow-y: scroll;
    padding: 4vw;
    margin: 0 0 6vw 0;
  }

  #contact .form input[type=radio],
  #contact .form input[type=checkbox] {
    opacity: 0;
    z-index: -1;
    position: absolute;
  }
  #contact .form label:focus,
  #contact .form label:hover,
  #contact .form label:active,
  #contact .form input:checked + label {
    color: #333;
  }
  #contact .form label:focus:before,
  #contact .form label:hover:before,
  #contact .form label:active:before,
  #contact .form input:checked + label:before {
    border-color: #333;
    background: #ffffff;
  }
  #contact .form label {
    line-height: 1;
    position: relative;
    display: block;
    padding: 0 0 1vw 6vw;
    cursor: pointer;
    transition: all .3s ease;
    width: 100%;
  }
  #contact .form label span {
    display: block;
    width: 100%;
    line-height: 1.4;
    font-size: 2.8vw;
  }
  #contact .form label:before {
    position: absolute;
    top: .8vw;
    left: 0;
    width: 3vw;
    height: 3vw;
    content: '';
    border: 2px solid #cccccc;
    border-radius: 50%;
  }
  #contact .form .form__checkbox label:before {
    border-radius: 2px;
  }
  #contact .form input:checked + label:before,
  #contact .form label:has(input:checked):before {
    border-color: #333;
    background: #333;
  }
  #contact .form input:disabled + label {
    cursor: not-allowed;
    color: rgba(0, 0, 0, 0.5);
    background: #f8f8f8;
  }
  #contact .form input:disabled + label:hover {
    border-color: rgba(0, 0, 0, 0.1);
  }
  #contact .form input:disabled + label:before {
    border-color: #ffffff;
    background: #ffffff;
  }

  #contact .form .wpcf7-submit {
    padding: 4vw 8vw;
    background: #f8f8f8;
    margin: 0 auto 10vw;
    display: block;
    font-size: 3.2vw;
  }
  #contact .form .wpcf7-submit:hover {
    background: #eeeeee;
  }
  #contact .wpcf7-spinner {
    display: none;
  }
  #contact .wpcf7-response-output {
    border: none;
    color: #dc3232;
    text-align: center;
  }
  .wpcf7 form.sent .wpcf7-response-output {
    display: none;
  }

  #contact .wpcf7-not-valid-tip {
    font-size: 2.6vw;
  }


  .thanks-message {
    margin: 10vw 0 15vw !important;
  }

  #contact .kvCopy_lower {
    font-size: 7.5vw;
    line-height: 1.4;
    text-align: center;
    margin: 0 auto 8vw;
  }
  #contact .kvArea {
    max-width: 1080px;
    width: 100%;
  }
  #contact .kvArea .kv_logo {
    margin: 8vw auto 2vw;
  }
  #contact .inner {
    max-width: 800px;
    width: 100%;
  }


  #contact .flowArea {
    padding: 8vw 3vw;
    width: 100%;
    border: 1vw dotted #0094ff;
    border-radius: 4vw;
    margin-bottom: 12vw;
  }
  #contact .flowArea .flowTittle {
    text-align: center;
    font-size: 5vw;
    color: #0094ff;
    position: relative;
    cursor: pointer;
    padding-right: 10vw;
  }
  #contact .flowArea .flowTittle .accBtn {
    width: 7vw;
    height: 7vw;
    border-radius: 3.6vw;
    background: #0094ff;
    position: absolute;
    right: 0;
    top: 0;
  }
  #contact .flowArea .flowTittle .accBtn:after {
    content: "Open";
    display: block;
    position: absolute;
    bottom: -4.4vw;
    left: -2.4vw;
    right: 0;
    margin: auto;
    color: #0094ff;
    font-size: 2.8vw;
    width: 12vw;
    letter-spacing: 0;
  }
  #contact .flowArea .flowTittle .accBtn.is-open:after {
    content: "Close";
  }
  #contact .flowArea .flowTittle .accBtn span {
    display: block;
    width: 3.6vw;
    height: 1px;
    border-top: 3px solid #fff;
    position: absolute;
    top: 0;
    bottom: -2px;
    left: 0;
    right: 0;
    margin: auto;
  }
  #contact .flowArea .flowTittle .accBtn span:after {
    content: "";
    display: block;
    width: 3.6vw;
    height: 1px;
    border-top: 3px solid #fff;
    position: absolute;
    top: -3px;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    transform: rotate(90deg);
    transition: .3s transform ease;
  }
  #contact .flowArea .flowTittle .accBtn.is-open span:after {
    transform: rotate(360deg);
    transition: .3s transform ease;
  }
  #contact .flowArea .flow_step {
    padding-top: 12vw;
    display: none;
  }
  #contact .flowArea .flow_step li {
    position: relative;
    padding-left: 13vw;
    margin-bottom: 14vw;
    font-size: 3.2vw;
  }
  #contact .flowArea .flow_step li:nth-child(3) {
    margin-bottom: 0;
  }
  #contact .flowArea .flow_step li:after {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 2.8vw solid transparent;
    border-left: 2.8vw solid transparent;
    border-top: 4.8vw solid #0094ff;
    border-bottom: 0;
    position: absolute;
    left: 0;
    right: 0;
    bottom: -10vw;
    margin: auto;
  }
  #contact .flowArea .flow_step li:nth-child(3):after {
    content: unset;
  }
  #contact .flowArea .flow_step li img {
    width: 11vw;
    display: block;
    position: absolute;
    left: 0;
    top: -2vw;
  }


}

