@charset "utf-8";
/*--京contact.css--*/
/* ##########PC########## */
.page_body h4.mt_small{
    margin-top: 1.6em;
}
/*電話でのお問い合わせ*/
.reservation_tel_box{
    display: inline-block;
    padding: 1rem 1.5rem 1rem 1.5rem;
    background: #dfedf8;
    border-radius: 0.8rem;
    margin-bottom: 1rem;
}

.reservation_tel_box dl{
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 1rem;
}

.reservation_tel_box dl dt{
    padding: 0 0.2rem;
    background: #0073b6;
    color: #fff;
    font-size: 0.9rem;
}

.reservation_tel_box dl dd{
    padding-left: 2.5rem;
    position: relative;
    font-size: 2.5rem;
    color: #014d7e;
    font-weight: 600;
    line-height: 1;
}

.reservation_tel_box dl dd a{
    text-decoration: none;
    color: #014d7e;
}

.reservation_tel_box dl dd::before{
    content: "";
    width: 2.25rem;
    height: auto;
    aspect-ratio: 1 / 1;
    background: url(../shared/icon_tell.png) no-repeat;
    background-size: contain;
    position: absolute;
    top: calc(50% - 1.125rem);
    left: 0;
}

.reservation_tel_box p{
    margin-top: 0.3rem;
    margin-bottom: 0;
}

.reservation_tel_box p .r_tel_time{
    padding-right: 1rem;
}

/*お問い合わせボタンリスト*/
.contact_btn_list{
}

.contact_btn_list ul{
    display: flex;
    justify-content: flex-start;
    gap: 1rem;
}

.page_body .contact_btn_list ul li{
    width: calc((100% - 2rem) / 3);
    padding-left: 0;
    margin-bottom: 0;
}

.page_body .contact_btn_list ul li::before{
    display: none;
}

.contact_btn_list ul li a{
    display: block;
    padding: 1.2rem 1.5rem;
    border: 1px solid #e2f0fb;
    background: #e2f0fb;
    color: #000;
    text-decoration: none;
    border-radius: 0.8rem;
    font-size: 1.1rem;
    font-weight: 500;
    position: relative;
    transition: .3s all ease;
}

.contact_btn_list ul li a:hover{
    border: 1px solid #0073b6;
    color: #000;
}

.contact_btn_list ul li a::after{
    content: "";
    width: 1rem;
    height: auto;
    aspect-ratio: 1 / 1;
    background: url(../shared/icon_arrow_blue.png) no-repeat;
    background-size: contain;
    position: absolute;
    top: calc(50% - 0.5rem);
    right: 0.6rem;
}

.page_body ul li.torikeshi{
    text-decoration: line-through;
}

/*アクセス*/
.google_map_box{}

.google_map_box iframe{
    width: 100%;
}

.page_body .page_contents p.fc_red{
    margin: 0 1rem;
    color: #be1c49;
}


/*メールフォーム*/
.mailform_wrapper{
    box-sizing: border-box;
    /*width: 900px;*/
    margin: 0 auto;
    border: 1px solid #04838c;
    border-radius: 1rem;
    padding: 2.5em 0;
    margin-top: 5em;
    margin-bottom: 4em;
}

.mailform_wrapper h3{
    margin-top: 0;
}

.page_body .contact_form_exp{
    text-align: center;
    margin-top: 2em;
}

.contact_form_box{
    width: 90%;
    margin: 0 auto;
}

    .contact_form_box > .box_inner {}

    .contact_form_box > .box_inner .input_box{
        margin-bottom: 2em;
    }

    .contact_form_box > .box_inner .input_box.for_confirm{
        border-top: 1px solid rgba(0, 0, 0, 0.15);
        border-bottom: 1px solid rgba(0, 0, 0, 0.15);
        padding: 1em 0;
    }

    .contact_form_box > .box_inner .input_box > dl {
        display: flex;
        padding: 0.8em 1em;
    }

        .contact_form_box > .box_inner .input_box p{
            margin: 0;
        }

        .contact_form_box > .box_inner .input_box > dl > dt {
            width: 12em;
            font-weight: 500;
            position: relative;
        }


        .contact_form_box > .box_inner .input_box > dl.required dt:after {
            content: "必須";
            display: inline-block;
            font-weight: normal;
            background:#c40026;
            color: #fff;
            line-height: 1;
            font-size: 0.8em;
            position: absolute;
            top: 0.5em;
            right: 0;
            padding: 0.25em 0.4em 0.1em;
            border-radius: 0.25rem;
        }

        .contact_form_box > .box_inner .input_box > dl > dd {
            flex: 1;
            box-sizing: border-box;
            padding-left: 1em;
        }

        .contact_form_box > .box_inner .input_box > dl > dd span.notes{
            margin-left: 0.5em;
        }

        .contact_form_box > .box_inner dl dd input[type="text"],
        .contact_form_box > .box_inner dl dd input[type="tel"],
        .contact_form_box > .box_inner dl dd input[type="email"],
        .contact_form_box > .box_inner dl dd textarea {
            width: 100%;
            border: 2px solid #f5f5f5;
            padding: 0.5em;
            box-sizing: border-box;
            font-size: 1em;
            border-radius: 0.5rem;
            background: #f5f5f5;
            outline: none;
        }

        .contact_form_box > .box_inner dl dd textarea {
            line-height: 1.4;
        }

        .contact_form_box > .box_inner dl dd input[type="text"]:focus,
        .contact_form_box > .box_inner dl dd input[type="tel"]:focus,
        .contact_form_box > .box_inner dl dd input[type="email"]:focus,
        .contact_form_box > .box_inner dl dd textarea:focus{
            background: #fff;
            border-color: #04838c;
        }

        /*.contact_form_box > .box_inner dl dd input[type="text"]:not(:placeholder-shown),
        .contact_form_box > .box_inner dl dd input[type="tel"]:not(:placeholder-shown),
        .contact_form_box > .box_inner dl dd input[type="email"]:not(:placeholder-shown),
        .contact_form_box > .box_inner dl dd textarea:not(:placeholder-shown){
            background: #fff;
            border-color: #ccc;
        }*/

        .contact_form_box > .box_inner dl.r_name dd input[type="text"]{
            width: 20em;
        }

        .contact_form_box > .box_inner dl.r_tel dd input[type="text"],
        .contact_form_box > .box_inner dl.r_fax dd input[type="text"]{
            width: 16em;
        }

        .contact_form_box > .box_inner dl.r_age dd input[type="text"]{
            width: 5em;
            text-align: right;
        }

        .contact_form_box > .box_inner dl.r_zip dd input[type="text"]{
            width: 10em;
        }

    .contact_form_box > .box_inner .submit_box{
        
    }

        .contact_form_box > .box_inner .submit_box .privacy_msg{
            line-height: 1.4;
            font-size: 0.9em;
        }

            .contact_form_box > .box_inner .submit_box ul{
                margin: 1.5em 0 0 0;
                padding: 0;
                display: flex;
                flex-direction: column;
                align-items: center;
                gap: 1em;
            }

                .contact_form_box > .box_inner .submit_box ul li{
                    margin: 0;
                    padding: 0;
                }

                .contact_form_box > .box_inner .submit_box ul li::before{
                    content: none;
                }

                .contact_form_box > .box_inner .submit_box ul li p{
                    margin: 0;
                    position: relative;
                }

                .contact_form_box > .box_inner .submit_box ul li input[type="submit"]{
                    position: relative;
                    width: 16rem;
                    background: #04838c;
                    color: #fff;
                    font-size: 1.1em;
                    padding: 1em 0;
                    border-radius: 100vh;
                    transition: .3s all ease;
                }

                .contact_form_box > .box_inner .submit_box ul li input[type="submit"]:hover{
                    filter: brightness(1.1);
                    box-shadow: 0 0 10px 1px rgba(0, 0, 0, 0.1);
                }

                .contact_form_box > .box_inner .submit_box ul li input[type="button"]{
                    width: 16rem;
                    font-size: 0.9em;
                    padding: 0.6em 0;
                    border-radius: 100vh;
                    background: none;
                    transition: .3s all ease;
                }

                .contact_form_box > .box_inner .submit_box ul li input[type="button"]:hover{
                    background: #eee;
                }

                .contact_form_box > .box_inner .submit_box ul li .wpcf7-spinner{
                    position: absolute;
                    right: -4em;
                }

    .wpcf7-response-output{
        margin: 2em !important;
        border-radius: 0.25rem;
        padding: 0.5em 1em !important;
        border: none !important;
        font-weight: 500;
    }

    .wpcf7 form.sent .wpcf7-response-output {
        background: #e3f7eb;
    }

    .wpcf7 form.failed .wpcf7-response-output,
    .wpcf7 form.aborted .wpcf7-response-output {
        background: #c04823;
    }

    .wpcf7 form.spam .wpcf7-response-output {
        border-color: #925f0c;
    }

    .wpcf7 form.invalid .wpcf7-response-output,
    .wpcf7 form.unaccepted .wpcf7-response-output,
    .wpcf7 form.payment-required .wpcf7-response-output{
        background: #f8d81e;

    }

    .fin_msg{}

        .fin_msg .wp-block-group__inner-container{
            display: flex;
            flex-direction: column;
            align-items: center;
        }

            .fin_msg h2{
                font-size: 1.4em;
                font-weight: 600;
                color: #04838c;
                margin-bottom: 0.5em;
            }

            .fin_msg p{
                text-align: center;
            }

@media screen and (min-width:1px) and (max-width:1400px) {
}

/*ipad*/
@media screen and (min-width:1px) and (max-width:1024px){
    /*電話でのお問い合わせ*/
    .reservation_tel_box p{
        font-size: 0.95em;
    }

}

/* ##########SP横向き########## */
@media screen and (min-width:1px) and (max-width:768px) {


}

/* ##########SP########## */
@media screen and (min-width:1px) and (max-width:575px) {
    /*電話でのお問い合わせ*/
    .reservation_tel_box{
        display: block;
        padding: 3vw;
    }

    .reservation_tel_box dl dt{
        text-align: center;
        padding: 0 0.4rem;
    }

    .reservation_tel_box dl dd{
        font-size: 2.2rem;
    }

    .reservation_tel_box p{
        font-size: 1.05em;
        margin:0.3rem 0 0 5rem;
    }

    .reservation_tel_box p .r_tel_time{
        padding-right: 0;
    }

    /*メールでのお問い合わせ*/
    .page_body .contact_btn_list ul{
        flex-wrap: wrap;
    }
    .page_body .contact_btn_list ul li{
        width: 100%;
    }

    .google_map_box iframe{
        height: 95vw;
    }


    /*メールフォーム*/
    .mailform_wrapper{
        padding: 1.5em;
    }

    .page_body .contact_form_exp{
        text-align: left;
    }

    .contact_form_box{
        width: 100%;
    }

    .contact_form_box > .box_inner .input_box > dl{
        flex-direction: column;
        padding: 0.5em 0;
    }

    .contact_form_box > .box_inner .input_box > dl > dt{
        width: auto;
        margin-bottom: 0.2em;
    }

        .contact_form_box > .box_inner .input_box > dl > dt p{
            display: inline-block;
        }

        .contact_form_box > .box_inner .input_box > dl.required dt:after{
            position: relative;
            right: auto;
            margin-left: 0.3em;
            top: 0;
        }

    .contact_form_box > .box_inner .input_box > dl > dd{
        padding: 0;
    }

    .contact_form_box > .box_inner .submit_box .privacy_msg{
        text-align: left;
    }

    .contact_form_box > .box_inner .submit_box ul li{
        width: 70%;
    }

    .contact_form_box > .box_inner .submit_box ul li input[type="submit"],
    .contact_form_box > .box_inner .submit_box ul li input[type="button"]{
        width: 100%;
    }

    .fin_msg p{
        text-align: left;
    }

}


/* ##########印刷用########## */
@media print{

}