.main .bgYe {
  border-image-source: linear-gradient(#FFFEF3, #FFFEF3);
  border-image-slice: 0 fill;
  border-image-outset: 0 40px;
  padding: 40px 0;
}
@media only screen and (max-width: 767px) {
  .main .bgYe {
    border-image-outset: 0;
    padding: 20px 0;
  }
}
.main .formWrap .introBox {
  margin-bottom: 40px;
}
.main .formWrap .tabWrap{
  width: min(90%,800px);
  margin: 0 auto;
  display: flex;
  gap: 20px;
  margin-bottom: 40px;
}
.main .formWrap .tabWrap li{
  flex-basis: calc((100% - 30px)/2);
}
.main .formWrap .tabWrap li a{
  display: block;
  border: 2px solid #1C9CD3;
  color: #1C9CD3;
  background: white;
  text-align: center;
  padding: 0.5em;
  font-size: min(4.5vw,18px);
}
.main .formWrap .tabWrap li a span{
  color: inherit;
  font-size: inherit;
}
.main .formWrap .tabWrap li a:hover,
.main .formWrap .tabWrap li a.current{
  background: #1C9CD3;
  color: white;
  opacity: 1;

}
.main .formWrap .tabWrap li a.current{ pointer-events: none;}
.main .formWrap .formBox table tr th.subth{
  background: #fffef3;
  text-align: center;
}
.main .formWrap .formBox table tr th.subth div{
  display: flex;
  align-items: center;
  font-size: 18px;
  width: 100%;
  gap: 0.5em;
}
.main .formWrap .formBox table tr th.subth div span{
  /* flex-basis: 15em; */
  color: #1C9CD3;
  font-size: inherit;
  font-weight: bold;
  word-break: auto-phrase;
  white-space: nowrap;
}
.main .formWrap .formBox table tr th.subth div::before,
.main .formWrap .formBox table tr th.subth div::after{
  content: '';
  border-bottom: 1px solid #1C9CD3;
  /* flex-basis: calc((100% - 17em)/2); */
  flex-basis: 100%;
}
.main .formWrap .formBox input[type="checkbox"] {
    width: 14px;
    margin: 0 5px 0 0;
}
.main .account-box{
  margin: min(7vw,40px) auto;
  border: 1px solid #1C9CD3;
  max-width: 400px;
  text-align: center;
  background: white;
}
.main .account-box p{
  font-size: min(4vw,18px);
}
.main .account-box .tit{
  background: #1C9CD3;
  color: white;
  font-weight: bold;
  padding: 0.5em;
}
.main .account-box .txt{
  padding: 1em;
  text-align: left;
  display: inline-block;
}
#flow{
  margin: 60px auto;
  background: white;
}
#flow .inner{
  border: 1px solid #1C9CD3;
  padding: 30px;
  gap: 30px;
}
.privacy-box {
  text-align: center;
  margin-bottom: 40px;
}
.privacy-box a{
  font-size: 16px;
  text-decoration: underline;
  text-underline-offset: 0.2em;
  color: #1C9CD3;
}
.privacy-box label{
  display: flex;
  align-items: center;
  font-size: 16px;
  margin-top: 10px;
}
@media only screen and (max-width: 767px) {
  .main .formWrap .introBox {
    padding: 0 20px;
  }
  .main .formWrap .tabWrap{ gap: 10px;}
  .main .formWrap .tabWrap li {
    flex-basis: calc((100% - 10px) / 2);
  }
  #flow{
    margin: 40px auto;
  }
  #flow .inner{
    width: min(80vw,600px);
    margin: 0 auto;
    padding: 20px 15px;
    text-align: center;
  }
  #flow .inner div+ div{
    margin-top: 30px;
  }
}
.main .formWrap .formBox {
  margin-top: 40px;
}
@media only screen and (max-width: 767px) {
  .main .formWrap .formBox {
    margin-top: 20px;
  }
}
.main .formWrap .formBox input,
.main .formWrap .formBox select,
.main .formWrap .formBox textarea {
  background: #EFEFEF;
  padding: 5px;
}
.main .formWrap .formBox input[type=text],
.main .formWrap .formBox input,
.main .formWrap .formBox td:not(.birthday_area) select {
  width: calc(100% - 20em);
}
.main .formWrap .formBox .short input[type=number]{
  width: 70px;
}
@media only screen and (max-width: 767px) {
  .main .formWrap .formBox input[type=text],
.main .formWrap .formBox input,
.main .formWrap .formBox td:not(.birthday_area) select {
    width: 100%;
  }
}
.main .formWrap .formBox textarea {
  width: 100%;
}
.main .formWrap .formBox input[type=radio] {
  margin: 0 5px 0 0;
  width: auto;
}
.privacy-box label input[type=radio] { order: 1;}
.privacy-box label .wpcf7-list-item-label { order: 2;}
.privacy-box label .wpcf7-not-valid-tip { order: 3;}
.main .formWrap .formBox textarea {
  width: 100%;
}
.main .formWrap .formBox table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 10px;
  margin: 0 -10px 40px;
}
@media only screen and (max-width: 767px) {
  .main .formWrap .formBox table {
    border-spacing: 0 10px;
    margin: 0 0 20px;
  }
}
.main .formWrap .formBox table tr th,
.main .formWrap .formBox table tr td
.main .formWrap .cf7-confirm-dialog .cf7-confirm-list dt,
.main .formWrap .cf7-confirm-dialog .cf7-confirm-list dd {
  font-size: 17px;
  padding: 10px 15px;
}
@media only screen and (max-width: 767px) {
  .main .formWrap .formBox table tr th,
  .main .formWrap .formBox table tr td,
.main .formWrap .cf7-confirm-dialog .cf7-confirm-list dt,
.main .formWrap .cf7-confirm-dialog .cf7-confirm-list dd {
    display: block;
  }
}
.main .formWrap .formBox table tr th,
.main .formWrap .cf7-confirm-dialog .cf7-confirm-list dt{
  background: #1C9CD3;
  color: white;
  position: relative;
  text-align: left;
  vertical-align: top;
  width: 290px;
}
.main .formWrap .formBox table tr th p {
  color: white;
  font-size: inherit;
}
@media only screen and (max-width: 767px) {
  .main .formWrap .formBox table tr th,
  .main .formWrap .cf7-confirm-dialog .cf7-confirm-list dt {
    width: 100%;
  }
}
.main .formWrap .cf7-confirm-dialog .cf7-confirm-list dt {
    width: auto;
    padding: 1em;
}
.main .formWrap .cf7-confirm-dialog .cf7-confirm-list dt p {
    color: inherit;
    font-size: inherit;
}
.main .formWrap .cf7-confirm-dialog .cf7-confirm-list dd {
  margin: 0 0 0.5em;
  display: block;
  min-height: 3em;
}
.main .formWrap .cf7-confirm-dialog .cf7-confirm-list dd * {
  font-size: inherit;
}
.main .formWrap .formBox table tr th .req {
  background: #FFAB4C;
  color: white;
  font-size: 14px;
  padding: 0 10px;
  position: absolute;
  right: 5px;
  /* top: 50%; */
  top: 22px;
  transform: translateY(-50%);
}
.main .formWrap .formBox table tr td {
  background: white;
  vertical-align: middle;
  padding: 5px;
}
.main .formWrap .formBox table tr td div p{
  display: flex;
  align-items: center;
  word-break: auto-phrase;
}
.main .formWrap .formBox table tr td.h-adr div p span {
    width: 100%;
}
.main .formWrap .formBox table tr td div + div {
    margin-top: 5px;
}
.main .formWrap .formBox table tr td .wpcf7-list-item label {
  font-size: inherit;
  margin-right: 10px;
  display: flex;
}
.main .formWrap .formBox table tr td p label input[type="number"]{
  width: 70px;
}
.main .formWrap .formBox table tr td label input[type="radio"]{ order: 1;}
.main .formWrap .formBox table tr td label .wpcf7-not-valid-tip{ order: 3;}
.main .formWrap .formBox table tr td label .wpcf7-list-item-label{ order: 2;}
.main .formWrap .formBox table tr td span:not(.wpcf7-form-control-wrap,.errorTxt) {
  display: inline-block;
}
.main .formWrap .formBox span.cf7err {
    color: #dc3232;
}
.main .formWrap .formBox table tr td .note {
  margin: 0 0 0 10px; 
}
.wpcf7-form-control-wrap {
    vertical-align: middle;
}
@media only screen and (max-width: 767px) {
  .main .formWrap .formBox table tr td .note {
    margin: 10px 0 0;
    display: block;
  }
}
.main .formWrap .formBox table input[type=file] {
  display: inline-block;
}
.main .formWrap .formBox .submitBtnWrap {
  text-align: center;
}
.main .formWrap .formBox .submitBtnWrap input + input,
.main .formWrap .formBox .submitBtnWrap input + button{
  margin-top: 15px;
}

.main .formWrap .formBox .submitBtnWrap input[type=submit],
.main .formWrap .cf7-confirm-dialog .cf7-confirm-ok  {
  /* margin: 10px; */
  display: inline-block;
  padding: 10px;
  max-width: 375px;
  width: 70%;
  font-size: 17px;
  color: white;
  background: #FFAB4C;
  cursor: pointer;
}
.main .formWrap .formBox .submitBtnWrap input.wpcf7-previous,
.main .formWrap .formBox .submitBtnWrap input[type=reset],
.main .formWrap .formBox .submitBtnWrap button[type=button],
.main .formWrap .cf7-confirm-dialog .cf7-confirm-back {
  display: inline-block;
  padding: 10px;
  max-width: 375px;
  width: 70%;
  font-size: 17px;
  color: white;
  background: #aaa;
  cursor: pointer;
}
.main .formWrap .formBox .submitBtnWrap .wpcf7-spinner{
    position: absolute;
    top: 0;
    left: calc(50% - 10px);
}
.main .formWrap .formBox .submitBtnWrap input[type=submit]:hover {
  opacity: 0.8;
}
.main .formWrap .formBox .submitBtnWrap p {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.main .formWrap .formBox .submitBtnWrap button.cf7-open-confirm,
.main .formWrap .formBox .submitBtnWrap button.wpcf7-confirm-btn{
  /* margin: 0 0 10px; */
  display: inline-block;
  padding: 10px;
  max-width: 375px;
  width: 80%;
  font-size: 17px;
  color: white;
  background: #FFAB4C;
  cursor: pointer;
  margin: 0 auto;
}

.lowerpage .main {
  padding-top: 40px;
}
@media only screen and (max-width: 767px) {
  .lowerpage .main {
    padding-top: 20px;
  }
}
.radio_area .errorTxt,
.birthday_area .errorTxt {
  display: none;
  color: #dc3232;
  margin-left: 8px;
  font-size: 1em;
  font-weight: normal;
}
.lowerpage .product-form .lower-tit01{
  display: block;
  width: fit-content;
  padding: 0 2em;
}


/*.CF7用調整 */
.cf7-confirm-modal { z-index: 100;}
/* 確認ボタンを隠す → 送信ボタンを表示 */
/* .wpcf7-confirm-btn { display: none !important; }
.wpcf7-submit-btn  { display: inline-block !important; } */

.wpcf7-not-valid-tip{display:inline-block !important;margin-left:8px;color:#c00;font-size:12px;}
/* acceptance をUIから隠す */
.wpcf7-form input[name="confirm-ok"],
.wpcf7-form label[for="confirm-ok"] { display:none !important; }

/* モーダル体裁（必要に応じて調整） */
.cf7-confirm-modal { position:fixed; inset:0; z-index:9999; }
.cf7-confirm-backdrop { position:absolute; inset:0; background:rgba(0,0,0,.45); }
.cf7-confirm-dialog { position:relative; max-width:760px; margin:6vh auto; padding:24px; background:#fff; border-radius:10px; }
.cf7-confirm-list { display:grid; grid-template-columns: 180px 1fr; gap:8px 16px; }
.cf7-confirm-list dt { font-weight:600; }
/* .main .formWrap .formBox .submitBtnWrap input[type=submit] { display: none;} */

.cf7-confirm-dialog { max-height: 90vh; overflow-y: scroll; border-radius: 0; margin: 5vh auto;}
/* 同意チェックを視覚的に隠す（アクセシブルに残す） */
.wpcf7-acceptance { position: absolute; left: -9999px;}
.cf7-confirm-actions p { display: flex; gap: 12px; justify-content: center; width: 100%; flex-wrap: wrap;}
.wpcf7-list-item{ margin: 0 1em 0 0;}
/* ---------- 
  MEDIA 
---------- */

@media only screen and (max-width: 1100px) and (min-width: 768px) {
.lowerpage .product-form .lower-tit01{
    transform: translateX(-40px);

}
}
@media only screen and (min-width: 768px) {
  .cf7-confirm-actions { display:flex; gap:12px; /*justify-content:flex-end;*/ margin-top:16px; }
}
@media only screen and (max-width: 767px) {
  .cf7-confirm-list{ display: block;}
  .lowerpage .product-form .lower-tit01{
    padding: 0 1.2em;
  }
}