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

	画面の遷移

==============================================================================*/
/* 最初は非表示 */
.screen-section {
    opacity: 0;
    height: 0;
    overflow: hidden;
    transition: opacity 0.5s ease, height 0.5s ease;
}

.screen-section.active {
    opacity: 1;
    height: auto;
    overflow: visible;
}

/*デフォルトのサンクスメッセージを非表示*/
.wpcf7-response-output{
    display: none;
}

input.error, select.error, textarea.error {
    border: 2px solid red;
}



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

	intro

==============================================================================*/
.intro{
    & .intro-text{
        text-align: left;

        & a{
            color: var(--color-accent);
        }
    }
    /* お電話の場合はこちら */
    & .intro-tel{
        margin-top: 20px;
        border: 2px solid var(--color-main);

        & .intro-tel_label{
            padding: 15px;
            background-color: var(--color-main);
            text-align: center;
            color: #fff;
            font-size: 1.5rem;
            font-family: var(--font-sub);
            font-weight: var(--weight-bold);
        }
        /* 電話番号のとこ */
        & .intro-number_wrap{
            padding: 20px;
            text-align: center;

            & .intro-tel_number a{
                padding-left: 30px;
                position: relative;
                display: inline-block;
                font-size: 2.8rem;
                font-weight: var(--weight-bold);
                line-height: 1;

                &::before{
                    content:"";
                    width: 20px;
                    aspect-ratio: 20 / 24;
                    position: absolute;
                    left: 0;
                    top: 50%;
                    transform: translateY(-50%);
                    background: url(../1_img/contact/icon-tel.svg) no-repeat center / 100% auto;
                }
            }

            & .intro-tel_time{
                margin-top: 5px;
                font-weight: var(--weight-bold);
                font-size: 1.4rem;
            }
        }
    }
}
@media (min-width: 769px) {
    .intro{
        & .intro-text{
            margin: auto;
            width: 600px;
            text-align: center;
        }
        /* お電話の場合はこちら */
        & .intro-tel{
            margin: 20px auto 0;
            width: 600px;
        }
    }
}


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

	form

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

#form-wrap{
    margin-top: 50px;
}
@media (min-width: 769px) {
    #form-wrap{
        margin-right: auto;
        margin-left: auto;
        width: 600px;
    }
}

.wpcf7-form-control-wrap {
    position: relative;
    display: block;
}
.wpcf7-form{
    text-transform: unset
}

/*================ イントロ ================*/
#form-wrap .form-intro{
    margin-bottom: 30px;
}
#form-wrap h2{
    font-size: 1.6rem;
    text-align: center;
}
#form-wrap .h2-sub{
    margin-top: 10px;
    font-size: 1.4rem;
    text-align: center;
}
#form-wrap .h2-sub span{
    color: var(--color-red);
}
@media (min-width: 769px) {
    #form-wrap .form-intro{
        margin-bottom: 100px;
    }
}
/*================ イントロ end ================*/


/*================ 項目名、必須の設定 ================*/
#form-wrap .form-item-label{
    font-size: 1.4rem;
    display: flex;
    flex-direction: column;
    gap: 5px 10px;
    margin-bottom: 5px;
}
#form-wrap .form-item-label .form-item-label-required{
    display: flex;
    align-items: center;
    justify-content: space-between;
}
#form-wrap .form-item-label .form-item-label-required::after{
    content: "必須";
    padding: 5px 10px;
    display: inline-block;
    background-color: var(--color-red);
    color: #fff;
    font-size: 1.2rem;
    line-height: 1;
}
#form-wrap .form-item-label .form-item-label-sub{
    font-size: 80%;
}
/*================ 項目名 end ================*/

/*================ カラムの設定 ================*/
#form-wrap .flex-wrap{
    display: flex;
    flex-direction: column;
    gap: 20px 0;
}
#form-wrap .flex-wrap + .flex-wrap{
    margin-top: 20px;
}
@media (min-width: 769px) {
    #form-wrap .flex-wrap{
        flex-direction: row;
        gap: 20px;
    }
    #form-wrap .flex-wrap + .flex-wrap{
        margin-top: 40px;
    }
    #form-wrap .flex-wrap.column-one > div{
        width: 100%;
    }
    #form-wrap .flex-wrap.column-two > div{
        width: calc((100% - 20px) / 2);
    }

}
/*================ カラムの設定 end ================*/

/*================ input,textarea ================*/
#form input[type="date"] {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-color: white;
}
#form input:not([type="radio"]):not([type="button"]):not([type="checkbox"]),
#form select,
#form textarea{
    padding: 10px 15px;
    width: 100%;
    height: 45px;
    font-size: 1.4rem;
    letter-spacing: 0.15em;
    line-height: 1.5;
    background-color: #e6e6e6;
    box-shadow: unset;
}
#form input:focus,
#form select:focus,
#form textarea:focus{
    outline: 1px solid var(--color-main)!important;
    border-color: transparent!important;
    box-shadow: none;
}
#form textarea{
    height: 240px;
}
#form input::placeholder,
#form textarea::placeholder {
    color: #999999;
}
/*================ input,textarea end ================*/


/*================ radio ================*/
#form .wpcf7-radio{
    display: flex;
    gap: 10px;
}
#form .wpcf7-radio .wpcf7-list-item,
#form .wpcf7-radio .wpcf7-list-item label{
    margin: 0;
}
#form .wpcf7-radio .wpcf7-list-item input{
    display: none;
}
#form .wpcf7-radio .wpcf7-list-item .wpcf7-list-item-label {
    display: inline-block;
    padding: 8px 16px;
    border: 1px solid var(--color-accent);
    border-radius: 4px;
    cursor: pointer;
    user-select: none;
    transition: background-color 0.3s, border-color 0.3s;
}
#form .wpcf7-radio input[type="radio"]:checked + .wpcf7-list-item-label {
    background-color: var(--color-main);
    color: white;
}
#form .wpcf7-radio .wpcf7-list-item-label:hover {
    border-color: var(--color-main);
}
/*================ radio end ================*/

/*================ checkbox ================*/
#form .wpcf7-checkbox{
    display: flex;
    gap: 10px;
}
#form .wpcf7-checkbox .wpcf7-list-item,
#form .wpcf7-checkbox .wpcf7-list-item label{
    margin: 0;
}
#form .wpcf7-checkbox .wpcf7-list-item label{
    display: flex;
    align-items: center;
    gap: 0 7px;
}
#form .wpcf7-checkbox input{
    margin: 0;
    appearance: none; /* ブラウザ独自の見た目をリセット */
    -webkit-appearance: none; /* Safari用 */
    -moz-appearance: none; /* Firefox用 */
    outline: unset;
    width: 20px;
    height: 20px;
    cursor: pointer;
    vertical-align: middle;
    transition: background-color 0.3s, border-color 0.3s;
    background-color: #e6e6e6;
}
#form .wpcf7-checkbox input:checked {
    background: url(../1_img/base/icon-check.svg) var(--color-main);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 80% auto;
}
/*================ checkbox end ================*/



/*================ select ================*/
.wpcf7-form-control-wrap:has(> .wpcf7-select){
    position: relative;
}
.wpcf7-form-control-wrap:has(> .wpcf7-select)::after{
    content:"";
    width: 10px;
    aspect-ratio: 1 / 1;
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%) rotate(135deg);
    border-top: 2px solid var(--color-main);
    border-right: 2px solid var(--color-main);
}
#form .wpcf7-select{
    /* デフォルトの矢印を消す */
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    /* 見た目の調整 */
    padding-right: 50px; /* 矢印と文字が重ならないように右余白を確保 */
}
/*================ checkbox end ================*/


/*================ input[type="button"],input[type="submit"] ================*/
/* ボタンの共通 */
.button-wrap{
    margin-top: 50px;
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 5px 20px;

    &.last{
        gap: 15px 20px;
    }

    & .confirm-button-wrap{
        display: inline-block;
        position: relative;

        &::before,&::after{
            content: "";
            aspect-ratio: 1 / 1;
            position: absolute;
            top: 50%;
            transition: 500ms;
            z-index: 2;
        }

        &::before {
            width: 20px;
            aspect-ratio: 1 / 1;
            right: 20px;
            border: 1px solid #fff;
            border-radius: 100%;
            transform: translateY(-50%);
        }
        &::after {
            width: 5px;
            right: 28px;
            border-top: 1px solid #fff;
            border-right: 1px solid #fff;
            transform: translateY(-50%) rotate(45deg);
        }
    }
    
    & input[type="button"],
    & input[type="submit"]{
        margin: 0;
        width: 280px;
        max-width: 100%;
        padding: 15px 0 17px;
        display: inline-block;
        text-align: center;
        font-size: 1.6rem;
        font-weight: var(--weight-bold);
        color: #fff;
        background-color: var(--color-font);
        line-height: 1.6;
        transition: 500ms;
        clip-path: polygon(20px 0%, calc(100% - 20px) 0%, 100% 50%, calc(100% - 20px) 100%, 20px 100%, 0% 50%);
    }


    /* 戻るボタン */
    & .confirm-button-wrap.back {
        &::before {
            right: unset;
            left: 20px;
        }
        &::after {
            right: unset;
            left: 28px;
            transform: translateY(-50%) rotate(-135deg);
        }
    }

    /* 送信するボタン */
    & .confirm-button-wrap.submit {

        &::before {
            border-color: var(--color-font);
        }
        &::after {
            border-color: var(--color-font);
        }

        & input[type="submit"]{
            color: var(--color-font);
            background-color: var(--color-accent);
        }
    }
}

.wpcf7-spinner{
    display: none;
}
@media (min-width: 769px) {
    .button-wrap{
        margin-top: 100px;
    }
}
/*================ input[type="button"] end ================*/


/*================ エラーメッセージ ================*/
.wpcf7-not-valid-tip {
    display: none !important;
}
#form .confirm-error-message,
#form .error-message{
    margin-top: 5px;
    width: 100%;
    color: var(--color-red);
    font-weight: var(--weight-bold);
}
/*================ エラーメッセージ end ================*/



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

	確認画面

==============================================================================*/
.confirm_area span[class^="confirm_form_"] {
    font-size: 1.6rem;
    font-weight: var(--weight-medium);
}


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

	完了画面

==============================================================================*/
.thanks_area .thanks-text {
    margin-top: 30px;
    font-size: 1.8rem;
    text-align: center;
    font-weight: var(--weight-regular);
}
@media (min-width: 769px) {
    .thanks_area .thanks-text {
        margin-top: 100px;
        font-size: 2rem;
    }
}


/*================ 個人情報保護方針 ================*/
#form .privacy-wrap{

    & .privacy-title{
        font-size: 1.5rem;
        margin-bottom: 5px;
    }
    
    & .privacy{
        margin-bottom: 20px;
        height: 200px;
        padding: 10px 15px;
        background-color: #e6e6e6;
        overflow-y: scroll;

        & dl{
            
            & dt{
                font-size: 1.4rem;
                margin-bottom: 10px;
            }

            & + dl{
                margin-top: 20px;
            }
        }

        & .privacy-intro{
            margin-bottom: 20px;

            & .intro-h{
                font-size: 1.5rem;
                margin-bottom: 10px;
            }
        }
        & dl + .privacy-intro{
            margin-top: 25px;
        }
    }
    
    & .wpcf7-checkbox{
        justify-content: center;
    }
    & .error-message{
        text-align: center;
    }
}