@charset "UTF-8";

/*
Theme Name: AI-call theme
*/

/* フォーム関連 */
#form-summary .container {
    background: url("images/wave_only_03.png") no-repeat 60% 10px;
    background-size: 600px 200px;
    
}

.section#form-summary {
    padding-top: 32px;
}

.section#form-summary h2 {
   margin-bottom: 64px;
}

.section#form-summary p {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.9;
}

.section#form-summary p a {
  color: #009FAD;
  position: relative;
  display: inline-block;
  text-decoration: none;
}

.section#form-summary p a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 1px;
  width: 100%;
  height: 1px;
  background: #009FAD;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.25s ease;
}

.section#form-summary p a:hover::after {
  transform: scaleX(1);
}






.form-sub {
    display: flex;
    justify-content: space-between;
    width: 800px;
    align-items: center;
}

.form-sub h3{
    font-size: 20px;
    margin-top: 14px;
}

.form-sub ul {
    gap: 12px;
   
}

.form-sub li {
    font-size: 18px;
    border-bottom: #e2e2e2 1px solid;
    padding-bottom: 8px;
}
.form-sub li:last-child {
    border: none;
    padding-bottom: 0;
    margin-bottom: 0;
}

.form-sub .check-list li::before {
    width:20px;
    height: 20px;
    margin-top: 6px;
}



.form-sub_L {
    width: 50%;
}

.form-sub_L img {
    width: 100%;
    height: auto;
}

.form-sub_R {
    width: 44%;
    border: #e2e2e2 1px solid;
    border-radius: 12px;
    padding: 0 20px 20px;
    box-sizing: border-box;
}

.inquiry__complete__link {
    
    display: block;
}




@media (max-width: 767px) {
/* フォーム関連 */
#form-summary .container {
    background: url("images/wave_only_03.png") no-repeat 60% 20px;
    background-size: 80% auto;
    
}

.section#form-summary {
    padding-top: 0;
}

.section#form-summary .section-lead {
    margin-bottom: 40px;
}


.section#form-summary h2 {
   margin-bottom: 40px;
}

.section#form-summary p {
    font-size: 14px;
    font-weight: 400;
    line-height: 1.7;
}


.section#form-summary .section-tag {
    padding: 2px 8px;
    margin-bottom: 8px;
}






.form-sub {
    display: flex;
    justify-content: space-between;
    width: 100%;
    align-items: stretch;
    flex-direction: column;
}

.form-sub h3{
    font-size: 16px;
    margin-bottom: 16px;
    margin-top: 8px;
}

.form-sub ul {
    gap: 12px;
   
}

.form-sub li {
    font-size: 14px;
    border-bottom: #e2e2e2 1px solid;
    padding-bottom: 8px;
}
.form-sub li:last-child {
    border: none;
    padding-bottom: 0;
    margin-bottom: 0;
}

.form-sub .check-list li::before {
    width:20px;
    height: 20px;
    margin-top: 6px;
}



.form-sub_L {
    width: 100%;
    margin-bottom: 16px;
}

.form-sub_L img {
    width: 90%;
    height: auto;
}

.form-sub_R {
    width: 100%;
    border: #e2e2e2 1px solid;
    border-radius: 12px;
    padding: 0 20px 20px;
    box-sizing: border-box;
}
}









/* Hubspotフォーム */
.hs-form-custom-m4u {
    max-width:1000px;
    margin: 0 auto 120px;
    padding: 0 40px 0;
  
}


.mv-form .hs-form-custom-m4u {
    max-width:100%;
    width: 100%;
    padding: 0 24px;
    margin: 0 auto;
}



@media (max-width: 767px) {
    .hs-form-custom-m4u {
    width: 100%;
    margin: 24px auto 64px;
    padding: 0 18px;
    box-sizing: border-box;
  
}
.mv-form .hs-form-custom-m4u {
    margin-top: 12px;
}
}


.page-form {
padding-top: 0;
}
.mv-form {
    padding: 0;
}

.hs-form-custom-m4u ul,
.hs-form-custom-m4u ol {
  list-style: none;
  margin: 0;
  padding: 0;
}

.hs-form-custom-m4u .hs-form-field {
    position: relative;
    box-sizing: border-box;
    margin-bottom: 32px;
}

.mv-form .hs-form-custom-m4u .hs-form-field {
    margin-bottom: 12px;
}




@media (max-width: 767px) {
.hs-form-custom-m4u .hs-form-field {
 
    margin-bottom: 24px;
}
.mv-form .hs-form-custom-m4u .hs-form-field {
    margin-bottom: 12px;
}
}




.hs-form-custom-m4u .hs-company,
.hs-form-custom-m4u .hs-lastname,
.hs-form-custom-m4u .hs-email,
.hs-form-custom-m4u .hs-phone{
    width: 48%;
    display: inline-block;
    vertical-align: top;
}


.mv-form .hs-form-custom-m4u .hs-company,
.mv-form .hs-form-custom-m4u .hs-lastname,
.mv-form .hs-form-custom-m4u .hs-email,
.mv-form .hs-form-custom-m4u .hs-phone{
    width: 100%;
    display: block;
    
}






@media (max-width: 767px) {
.hs-form-custom-m4u .hs-company,
.hs-form-custom-m4u .hs-lastname,
.hs-form-custom-m4u .hs-email,
.hs-form-custom-m4u .hs-phone{
    width: 100%;
    display: block;
  
}
}



.hs-form-custom-m4u .hs-company,
.hs-form-custom-m4u .hs-email{
    margin-right: 4%;
}


.mv-form .hs-form-custom-m4u .hs-company,
.mv-form .hs-form-custom-m4u .hs-email{
    margin-right: 0;
}

@media (max-width: 767px) {
.hs-form-custom-m4u .hs-company,
.hs-form-custom-m4u .hs-email{
    margin-right: 0;
}
}


.hs-form-custom-m4u .hs-form-field > label {
    font-family: 'fot-rodin-pron',sans-serif;
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 10px;
    display: block;
}

.mv-form .hs-form-custom-m4u .hs-form-field > label {
    font-size: 13px;
    font-weight: 400;
    margin-bottom: 2px;
}



@media (max-width: 767px) {
.hs-form-custom-m4u .hs-form-field > label {
    font-family: 'fot-rodin-pron',sans-serif;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 4px;
    display: block;
}
}




.hs-form-custom-m4u .hs-fieldtype-text .input input,
.hs-form-custom-m4u .hs-fieldtype-phonenumber .input input{
    border-radius: 6px;
    background: #f2f3f5;
    border: none;
      width:100%;
    height: 48px;
    box-sizing: border-box;
    font-size:16px;
    padding: 4px 8px;
    cursor: auto;
    outline: none;
}



.mv-form .hs-form-custom-m4u .hs-fieldtype-text .input input,
.mv-form .hs-form-custom-m4u .hs-fieldtype-phonenumber .input input{
    border-radius: 6px;
    background: #f2f3f5;
    border: none;
      width:100%;
    height: 36px;
    box-sizing: border-box;
    font-size:14px;
    padding: 2px 4px;
    cursor: auto;
    outline: none;
}




@media (max-width: 767px) {
.hs-form-custom-m4u .hs-fieldtype-text .input input,
.hs-form-custom-m4u .hs-fieldtype-phonenumber .input input{
    height: 36px;
    box-sizing: border-box;
    font-size:14px;
    padding: 4px 8px;
 
}
.mv-form .hs-form-custom-m4u .hs-fieldtype-text .input input,
.mv-form .hs-form-custom-m4u .hs-fieldtype-phonenumber .input input{
    height: 32px;
    box-sizing: border-box;
    font-size:13px;
    padding: 3px 4px;
 
}
}



.hs-form-custom-m4u .hs-fieldtype-textarea .input textarea{
    border-radius: 6px;
    background: #f1f1f1;
    border: none;
      width:100%;
    height: 120px;
    box-sizing: border-box;
    font-size: 16px;
    padding: 4px 8px;
    outline: none;
    
}

@media (max-width: 767px) {
.hs-form-custom-m4u .hs-fieldtype-textarea .input textarea{
    height: 84px;
   
    font-size: 14px;
    padding: 4px 8px;
    outline: none;
    
}
}



.hs-form-custom-m4u .hs-fieldtype-text .input input:focus,
.hs-form-custom-m4u .hs-fieldtype-phonenumber .input input:focus,
.hs-form-custom-m4u .hs-fieldtype-textarea .input textarea:focus{
    background: #fff;
    border: #f1f1f1 1px solid;
    outline: none;
  
}







/* Hubspotフォームチェックボックス */
 .hs-form-checkbox label {
    display: block; }
    
  .hs-form-checkbox .hs-form-checkbox-display span {
    position: relative;
    margin-right:0;
    padding-left: 28px; }
    
    
    
    

@media (max-width: 767px) {
  .hs-form-checkbox .hs-form-checkbox-display span {

    padding-left: 24px; }
}


  .hs-form-booleancheckbox .hs-form-booleancheckbox-display > span {
      padding-left: 8px;
     
  }
  .hs-form-booleancheckbox .hs-form-booleancheckbox-display p {
     font-size: 16px !important;  
  } 
  
  
.mv-form .hs-form-booleancheckbox .hs-form-booleancheckbox-display p {
     font-size: 12px !important;  
  } 
  
  @media (max-width: 767px) {
  .hs-form-booleancheckbox .hs-form-booleancheckbox-display p {
     font-size: 14px !important;  
  } 
  }
  
    

    .hs-form-checkbox .hs-form-checkbox-display span:before,
    .hs-form-booleancheckbox .hs-form-booleancheckbox-display span:before {
      content: "";
      display: block;
      position: absolute;
      top: 2px;
      left: 0;
      width: 20px;
      height: 20px;
      border: 2px solid #009FAD;
      border-radius: 4px; }


  .hs-form-booleancheckbox .hs-form-booleancheckbox-display span:before {
       top: 2px;
  }


    .mv-form .hs-form-checkbox .hs-form-checkbox-display span:before,
    .mv-form .hs-form-booleancheckbox .hs-form-booleancheckbox-display span:before {

      width: 16px;
      height: 16px;
   }


  .mv-form .hs-form-booleancheckbox .hs-form-booleancheckbox-display span:before {
       top: 6px;
  }



@media (max-width: 767px) {
    .hs-form-checkbox .hs-form-checkbox-display span:before,
    .hs-form-booleancheckbox .hs-form-booleancheckbox-display span:before {
      top: 2px;
      left: 0;
      width: 18px;
      height: 18px;
      border: 2px solid #009FAD;
      border-radius: 4px; }


  .hs-form-booleancheckbox .hs-form-booleancheckbox-display span:before {
       top: 4px;
  }
}







 .hs-form-checkbox input,
 .hs-form-booleancheckbox input {
    display: none; }
    
 .hs-form-checkbox input:checked + span:before,
  .hs-form-booleancheckbox input:checked + span:before{
      background: #009FAD; }
      
 .hs-form-checkbox input:checked + span:after,
 .hs-form-booleancheckbox input:checked + span:after{
      content: "";
      display: block;
      position: absolute;
      top: 6px;
      left: 7px;
      width: 6px;
      height: 10px;
      
      transform: rotate(45deg);
      border-bottom: 2px solid #fff;
      border-right: 2px solid #fff; }


 .hs-form-booleancheckbox input:checked + span:after {
      top: 6px;
 }
 
 
 .mv-form .hs-form-checkbox input:checked + span:after,
 .mv-form .hs-form-booleancheckbox input:checked + span:after{
      content: "";
      display: block;
      position: absolute;
      top: 6px;
      left: 5px;
      width: 6px;
      height: 8px;
      
      transform: rotate(45deg);
      border-bottom: 2px solid #fff;
      border-right: 2px solid #fff; }


 .mv-form .hs-form-booleancheckbox input:checked + span:after {
      top: 8px;
 }
 
 
 
 
 
 
 @media (max-width: 767px) {
  .hs-form-checkbox input:checked + span:after,
 .hs-form-booleancheckbox input:checked + span:after{
  
      top: 7px;
      left: 5px;
 }


 .hs-form-booleancheckbox input:checked + span:after {
      top: 7px;
 }
  .mv-form .hs-form-booleancheckbox input:checked + span:after {
      top: 9px;
 }
}
 
 
 

.legal-consent-container .hs-form-booleancheckbox-display>span {
    margin-left: 16px !important;
}

.mv-form .legal-consent-container .hs-form-booleancheckbox-display>span {
    margin-left: 12px !important;
}




@media (max-width: 767px) {
.legal-consent-container .hs-form-booleancheckbox-display>span {
    margin-left: 14px !important;
}
}


li.hs-form-checkbox {
    margin-bottom: 10px;
}

@media (max-width: 767px) {
li.hs-form-checkbox {
    margin-bottom: 8px;
}
}


li.hs-form-checkbox:last-child {
    margin-bottom:0;
}


li.hs-form-checkbox label {
    margin-bottom: 0;

}

li.hs-form-checkbox label span {
   font-size: 16px;
   font-weight: normal;
}

@media (max-width: 767px) {
li.hs-form-checkbox label span {
   font-size: 14px;
   font-weight: normal;
}
}


/* Hubspotフォーム注釈 */
.hs-field-desc {
    position: absolute;
    font-size: 12px;
    right: 0;
    top:6px;
     display: inline-block;
     text-align: right;
}

.mv-form .hs-field-desc {
    
    font-size: 11px;
    right: 0;
    top:2px;
     display: inline-block;
     text-align: right;
}





@media (max-width: 767px) {
.hs-field-desc {
  
    font-size: 11px;
     top:4px;
}
}




.hs-richtext {
    margin-bottom: 2px;
}

.hs-richtext p{
    font-size: 16px;
}

.mv-form .hs-richtext {
    margin-bottom: 0;
}

.mv-form .hs-richtext p{
    font-size: 12px;
    line-height: 1.4;
    margin: 8px auto;
}




@media (max-width: 767px) {
.hs-richtext p{
    font-size: 14px;
}
}




/* Hubspotフォームボタン */
.actions {
     width: 30%;
    margin: 32px auto 0;
}

.mv-form .actions {
     width: 40%;
    margin: 16px auto 0;
}

@media (max-width: 767px) {
.actions {
     width: 100%;
    margin: 24px auto 0;
}
}


.hs-button {
    border: none;
    width: 100%;
    border-radius: 8px;
    background: radial-gradient(80.12% 56.86% at 2.78% 11.9%, #20C9D8 0%, #009FAD 100%);
    transition: .3s;
    color: #fff;
    padding: 14px 0;
    font-size: 22px;
    font-weight: bold;
    cursor: pointer;
    
    text-align: center;
    
}

.mv-form .hs-button {
   
    
    padding: 8px 0;
    font-size: 18px;
 
    
}


@media (max-width: 767px) {
.hs-button {
    
    padding: 16px 0;
    font-size: 20px;
 
    
}
}





.hs-button:hover {
    background: radial-gradient(80.12% 56.86% at 2.78% 11.9%, #1BA7B4 0%, #006E77 100%);
}



/* ボタンここまで */



/* 必須項目 */
.hs-form-custom-m4u .hbspt-form .hs-form-field label .hs-form-required {
font-size:0;
position: relative;
}
.hs-form-custom-m4u .hbspt-form .hs-form-field label .hs-form-required:before {
font-size:12px;
content:'必須';
position: absolute;
background: #fff;
border-radius: 504px;
color: #f05e5e;
border: 1px solid #f05e5e;
box-sizing: border-box;
padding: 2px 0 2px;
display: inline-block;
min-width: 38px;
text-align: center;
margin-left: 8px;
bottom:-4px;
line-height: 1.4;
 min-height: 20px;
 height: 20px;
font-weight: 400;
}
.hs-form-custom-m4u .hbspt-form .hs-form-field label.hs-form-booleancheckbox-display .hs-form-required:before {
   top:-15px;
   border: 1px solid #f05e5e;
   display: inline-block;
   padding: 0px 0 2px;
   min-height: 20px;
   height: 20px;
}



.mv-form .hs-form-custom-m4u .hbspt-form .hs-form-field label .hs-form-required:before {
font-size:10px;

border-radius: 50px;

padding: 4px 0 0;
display: inline-block;
min-width: 38px;
text-align: center;
margin-left: 4px;
bottom:-4px;
line-height: 1;
 min-height: 18px;
 height: 18px;
 box-sizing: border-box;
}
.mv-form .hs-form-custom-m4u .hbspt-form .hs-form-field label.hs-form-booleancheckbox-display .hs-form-required:before {
   top:-14px;
   border: 1px solid #f05e5e;
   display: inline-block;
   padding: 3px 0 0;
   min-height: 18px;
   height: 18px;
   box-sizing: border-box;
}





@media (max-width: 767px) {
.hs-form-custom-m4u .hbspt-form .hs-form-field label .hs-form-required:before {
font-size:11px;

padding: 2px 0 0;
min-width: 38px;

margin-left: 4px;
bottom:-5px;

 min-height: 20px;
 height: 20px;
}
.hs-form-custom-m4u .hbspt-form .hs-form-field label.hs-form-booleancheckbox-display .hs-form-required:before {
   top:-16px;
  
   padding: 1px 0 2px;;
   min-height: 20px;
   height: 20px;
}
}

/* 必須項目ここまで */



/* エラー */
label.hs-error-msg {
    font-size: 14px !important;
    margin-top: 8px !important;
    font-weight: bold !important;
    display: inline-block !important;
    color: #f05e5e !important;

}

.mv-form label.hs-error-msg {
    font-size: 11px !important;
    margin-top: 0 !important;
    font-weight: bold !important;
    display: inline-block !important;
    color: #f05e5e !important;

}
.mv-form ul li {
    margin-top: 0;
}

@media (max-width: 767px) {
label.hs-error-msg {
    font-size: 12px !important;
    margin-top: 4px !important;
  
}
}



label.hs-error-msg:before {
  content: "※" !important;
  display: inline-block !important;
  color: #f05e5e !important;
}


.hs-form-custom-m4u .hbspt-form .hs-form-field .hs-form-booleancheckbox label{
    margin-bottom: 0 !important;
}

.hs_error_rollup label {
    background: #fff;
    display: block;
    width: 75%;
    box-sizing: border-box;
    color: #f05e5e;
    border: #f05e5e 1px solid;
    font-weight: bold;
    text-align: center;
    padding: 8px 0;
    border-radius: 50px;
    
    font-size: 16px;
    
    margin: 24px auto 0;
}


.mv-form .hs_error_rollup label {
    background: #fff;
    display: block;
    width: 100%;
    box-sizing: border-box;
    color: #f05e5e;
    border: #f05e5e 1px solid;
    font-weight: bold;
    text-align: center;
    padding: 2px 0 4px;
    border-radius: 50px;
    
    font-size: 12px;
    
    margin: 8px auto 0;
}

@media (max-width: 767px) {
.hs_error_rollup label {

    width: 100%;
   
    padding: 8px 0;
    border-radius: 50px;
    
    font-size: 14px;
    
    margin: 24px auto 0;
}
}
/* エラーここまで */




/* ---------- 演出 ---------- */

/* 初期状態（非表示） */
.fade-up,
.fade-left {
  opacity: 0;
  transition: all 0.6s ease;
}

/* 下からふわ */
.fade-up {
  transform: translateY(30px);
}

/* 左からシュッ */
.fade-left {
  transform: translateX(-40px);
}

/* 表示されたら */
.fade-up.is-show,
.fade-left.is-show {
  opacity: 1;
  transform: translate(0, 0);
}

/* 遅延（ここで差をつける） */
.fade-left.is-show {
  transition-delay: 0.15s;
}

.fade-up.is-show {
  transition-delay: 0.35s;
}




/* ---------- ここから追加（汎用順番） ---------- */

/* 同じ親の中で順番に出す */
.stagger > *:nth-child(1).is-show { transition-delay: 0.1s; }
.stagger > *:nth-child(2).is-show { transition-delay: 0.2s; }
.stagger > *:nth-child(3).is-show { transition-delay: 0.3s; }
.stagger > *:nth-child(4).is-show { transition-delay: 0.4s; }
.stagger > *:nth-child(5).is-show { transition-delay: 0.5s; }
.stagger > *:nth-child(6).is-show { transition-delay: 0.6s; }




/* ---------- インライン用臨時 ---------- */
@media (max-width: 767px) {

  .inline-01 {
    font-size: 18px !important;
  }

  .inline-02 {
    font-size: 22px !important;
    margin-bottom: 12px !important;
  }

}





/* 追従CTA */
@media (min-width: 768px) {
.sp-cta {
  display: none;
}
}

/* スマホだけ表示 */
@media (max-width: 767px) {
  .sp-cta {
    display: block;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background: rgba(0, 42, 46, 0.8);
    backdrop-filter: blur(8px);
  
    
    z-index: 1500;
    padding: 16px;
    
    transform: translateY(100%);
    opacity: 0;
    transition: all 0.3s ease;
  }
  
   /* 表示状態 */
  .sp-cta.is-show {
    transform: translateY(0);
    opacity: 1;
  }
  
   .sp-cta .sp-btn-inner {
       padding-top:8px;
       padding-bottom: 8px;
       font-size: 20px;
   }
}
