@charset "utf-8";
/*共通設定*/
/*終わり*/  


/*<section class="under-fv">*/
.under-fv {
    background-image: linear-gradient(rgba(0,0,0,0.1), rgba(0,0,0,0.1)),url(../img/contact/fv.png);
}
/*終わり*/


/*<section class="contact-cta">*/
.contact-cta {
    padding: 80px 5vw 40px 5vw;
}

.contact-cta-in {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 40px;
}

.contact-cta-btn {
    max-width: 420px;
    width: 100%;
    border-radius: 16px;
    padding: 40px 16px;
}

.contact-cta-btn-01 {
    background: linear-gradient(135deg, #81CBC7 4%, #ACDCDA 80%);
}

.contact-cta-btn-02 {
    background: linear-gradient(135deg, #06C755 4%, #01A644 80%);
}

.contact-cta-btn .h2-title-wrap {
    gap: 8px;
    margin-bottom: 48px;
}

.contact-cta-btn .h2-txt {
    color: #fff;
    font-size: 18px;
}

.contact-cta-btn .h2-title {
    color: #fff;
    font-size: 20px;
}

.contact-cta-btn .h2-title::before {
    border-bottom: solid 3px #fff;
    width: 32px;
}

.contact-cta-txt-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    color: #fff;
}

.contact-cta-icon {
    max-width: 32px;
    width: 100%;
}

.contact-cta-txt {
    font-weight: 600;
    font-size: 20px;
}
/*終わり*/


/*<section class="contact">*/
.contact-in {
    padding: 64px 40px;
    border-radius: 16px;
    background-color: #f9f9f9;
}

.contact-lead-txt {
    text-align: center;
}

.contact-lead-txt span {
    color: #81CBC7;
    font-size: 24px;
}

.form-wrap {
    max-width: 880px;
    width: 100%;
    margin: 40px auto 0 auto;
}

.form-area {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    background-color: #fff;
    padding: 24px;
    border-radius: 8px;
}

.form-area dt {
    font-weight: 600;
    width: 30%;
    padding: 24px 0;
}


.form-area .first-dt,
.form-area .first-dd {
    padding-top: 0;
}

.form-area dd {
    width: 70%;
    padding: 24px 0;
}

.required {
    color: #81CBC7;
    font-size: 24px; 
    padding-left: 8px;  
}

.radio-btn {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.input-text,
.message {
    border: solid 1px #999;
    border-radius: 4px;
    width: 100% !important;
    padding: 8px;
    font-family: "Noto Sans JP", sans-serif;
}

.message {
    height: 240px;
}

.submit-btn-area {
    margin-top: 48px;
    text-align: center;
}

.submit-button {
    border: none;
    font-family: "Noto Sans JP", sans-serif;
    transition: 0.2s;
}

.submit-button {
    font-size: 18px;
    text-align: center;
}

.submit-button:hover {
    cursor: pointer;
    opacity: 0.8;
}

    /*contact form7変更*/
.wpcf7-list-item {
    margin: 0 !important;
}

.wpcf7 input::placeholder,
.wpcf7 textarea::placeholder {
    color: #999;
}

.wpcf7-spinner {
    display: none !important;
}
/*終わり*/


/*タブレット*/
@media (max-width: 1024px) {  
/*共通設定*/
/*終わり*/  


/*<section class="contact-cta">*/
    .contact-cta-btn {
        max-width: clamp(340px, 420vw / 10.24, 420px);
    }
/*終わり*/


/*<section class="contact">*/
    .contact-in {
        padding: 64px clamp(24px, 40vw / 10.24, 40px);
    }

    .contact .contact-h2 {
        font-size: clamp(24px, 32vw / 10.24, 32px);
    }

    .form-area {
        flex-direction: column;
    }

    .form-area dt {
        width: 100%;
        padding: 16px 0 0 0;
    }

    .form-area dd {
        width: 100%;
        padding: 16px 0;
    }
/*終わり*/

}
  
  
/*スマホ*/
@media (max-width: 599px) {
/*共通設定*/
/*終わり*/ 


/*<section class="contact-cta">*/
    .contact-cta-in {
        gap: clamp(24px, 40vw / 5.99, 40px);
    }

    .contact-cta-btn {
        max-width: none;
        padding: clamp(24px, 40vw / 5.99, 40px) 16px;
    }

    .contact-cta-btn .h2-title {
        font-size: clamp(18px, 20vw / 5.99, 20px);
    }
/*終わり*/


/*<section class="contact">*/
    .contact-in {
        padding: clamp(40px, 64vw / 5.99, 64px) clamp(16px, 24vw / 5.99, 24px);
    }

    .contact .contact-h2 {
        font-size: clamp(20px, 24vw / 5.99, 24px);
    }

    .form-area {
        padding: clamp(16px, 24vw / 5.99, 24px);
    }

    .form-area dd {
        width: 100%;
        padding: 8px 0 16px 0;
    }

    .message {
        height: clamp(160px, 240vw / 5.99, 240px);
    }

/*終わり*/
}
