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

/* メニュー */
.annotation {
    text-align: center;
    font-size: clamp(16px, 1.3vw, 20px);
    line-height: 1.8;
    margin-bottom: 65px;
    margin-top: 50px;
}

.menu h2 {
    color: #5D7505;
    font-size: clamp(16px, 1.4vw, 22px);
    font-weight: bold;
    border-bottom: solid 2px #5D7505;
    margin-top: 80px;
    padding-bottom: 3px;
    line-height: 1.6;
}

.course {
    position: relative;
    margin-top: 35px;
}

.course_time {
    background-color: #5D7505;
    color: #fff;
    font-size: clamp(15px, 1.2vw, 18px);
    font-weight: bold;
    padding: 31px 13px;
    position: absolute;
    top: 0;
    left: 0;
}

.charge {
    background-color: #E5E7E0;
    font-size: clamp(16px, 1.3vw, 20px);
    font-weight: bold;
    line-height: 2.8;
    padding-left: 70px;
    margin-left: 40px;
}

.charge span {
    font-size: clamp(11px, 0.9vw, 14px);
    color: #A6A6A6;
}

.case {
    background-color: #fff;
    color: #5D7505;
    font-size: clamp(14px, 1.1vw, 17px);
    line-height: 1.6;
    padding: 10px 20px 20px 70px;
    margin-left: 40px;
    box-shadow: -4px 4px 4px rgba(0, 0, 0, .08);
}


/* 出張 */
.visit {
    padding-top: 200px;
    display: flex;
    justify-content: space-around;
    font-size: clamp(15px, 1.2vw, 18px);
    line-height: 1.8;
    text-align: left;
}

.visit h2 {
    justify-content: flex-start;
}

.visit p {
    margin: 15px 0;
}

.quote {
    background-color: #E5E7E0;
    line-height: 2.1;
    padding: 15px;
    text-align: center;
}

.area_map {
    width: 410px;
    max-width: 80%;
    margin: 40px auto 140px;
}


/* 保険治療 */
.insurance {
    background-color: #fff;
    padding-top: 105px;
    padding-bottom: 80px;
    position: relative;
}

.insurance_wrapper {
    width: 775px;
    margin: 0 auto;
    text-align: center;
}

.insurance h2 {
    margin-bottom: 60px;
}

.orange_title .decoration span,
.orange_title .decoration::before,
.orange_title .decoration::after {
    color: #fff;
    background-color: #D18C04;
}

.insurance p {
    font-size: clamp(14px, 1.2vw, 18px);
    line-height: 1.8;
    margin: 20px 0;
}

.pc_able {
    width: 775px;
}

.insurance table {
    margin: 0 auto;
    font-size: clamp(14px, 1.1vw, 16px);
    line-height: 1.6;
}

.sp_check,
.sp_table {
    display: none;
}

.insurance table tr,
.insurance table td {
    border: solid 1px #2F2928;
    font-size: clamp(13px, 1.1vw, 16px);
    line-height: 1.6;
}

table .td_type {
    font-size: clamp(16px, 1.3vw, 20px);
    font-weight: bold;
}


table .gray {
    background-color: #F0F0F0;
}

table .attention {
    background-color: #FFF5F1;
}

.announce {
    font-size: clamp(15px, 1.2vw, 18px);
}

/* 疑問 */

.doubts {
    background-color: #F6EFDD;
    border-radius: 50px;
    font-size: clamp(15px, 1.2vw, 18px);
    line-height: 1.6;
    text-align: center;
    padding: 45px 20px;
    margin-top: 70px;
    position: relative;
}

.doubts h3 {
    display: inline-block;
    font-size: clamp(16px, 1.6vw, 24px);
    font-weight: bold;
    margin: 0 auto 40px;
}

.doubts_wrapper {
    line-height: 2.4;
    margin: 20px 0 30px;
}

.doubts a {
    text-decoration: underline;
}

.doubts .q_right,
.doubts .q_left {
    font-size: clamp(40px, 6.9vw, 110px);
    font-weight: 900;
    color: rgba(255, 255, 255, .6);
    position: absolute;
}

.doubts .q_right {
    top: 10%;
    right: 5%;
    transform: rotate(15deg);
}

.doubts .q_left {
    bottom: 20%;
    left: 5%;
    transform: rotate(-20deg);
}

.lookdown {
    color: #D18C04;
    font-size: clamp(16px, 1.3vw, 20px);
    text-align: center;
    z-index: 2;
    position: absolute;
    bottom: -50px;
    left: 50%;
    transform: translateX(-50%);
}

.sankaku_white {
    width: 100%;
    height: 400px;
    margin-top: -120px;
}

/* 無料体験 */

.trial {
    background-color: #F6EFDD;
    margin-top: -280px;
    padding-top: 400px;
    padding-bottom: 150px;
    line-height: 1.6;
}

.trial_banner {
    background-color: #fff;
    border: solid 4px #E4A607;
    border-radius: 20px;
    padding: 35px 10px;
    font-size: clamp(15px, 1.2vw, 18px);
    margin-top: 35px;
    margin-bottom: 40px;
    text-align: center;
}

.banner_title {
    font-size: clamp(20px, 1.8vw, 27px);
    font-weight: bold;
    color: #E4A607;
    margin-bottom: 10px;
}

.trial_bottom {
    margin: 0 50px;
}

.trial_bottom p {
    text-align: left;
}

.line-through {
    position: relative;
}

.line-through::after {
    content: '';
    position: absolute;
    width: 100%;
    height: 1px;
    background-color: red;
    left: 0;
    top: 50%;
}

.red {
    color: red;
    font-size: clamp(23px, 2vw, 30px);
}

.announce_mini {
    font-size: clamp(12px, 1.0vw, 15px);
}

.trial ul {
    margin-top: clamp(17px, 1.8vw, 26px);
}

.trial li {
    font-size: clamp(15px, 1.2vw, 18px);
    margin-top: 11px;
}

.facility_wrapper {
    display: flex;
    justify-content: space-around;
    margin-top: 43px;
}

.facility {
    border: solid 2px #cac1a9;
    border-radius: 20px;
    padding: 27px 35px;
    position: relative;
    font-size: clamp(15px, 1.2vw, 18px);
}

.facility h4 {
    background-color: #F6EFDD;
    font-size: clamp(15px, 1.2vw, 18px);
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    white-space: nowrap;
}

/* 以下レスポンシブ */

@media screen and (max-width: 900px) {

    .insurance_wrapper {
        width: 90%;
        max-width: 340px;
    }

    .insurance .announce {
        text-align: left;
    }


    .doubts {
        padding: 45px 20px 60px;
    }

    .doubts h3 {
        margin: 0 auto 15px;
    }

    .pc_table {
        display: none;
    }



    .sp_check,
    .sp_table {
        display: block;
    }

    .sp_check {
        text-align: left;
        display: inline-block;
    }

    .sp_table table {
        margin-top: 20px;
    }


}


@media screen and (max-width: 750px) {

    .visit {
        padding-top: 50px;
        flex-direction: column;
        max-width: 85%;
    }

    .delivery {
        margin-top: 50px;
    }

    .area_map {
        margin-top: 20px;
        margin-bottom: 60px;
    }

    .sankaku_white {
        height: 200px;
        margin-top: -60px;
    }

    .lookdown {
        bottom: -20px;
    }

    .insurance {
        padding-top: 50px;
    }

    .trial {
        margin-top: -320px;
        padding-bottom: 10px;
    }

}

@media screen and (max-width: 650px) {

    .trial h2 {
        margin-bottom: 30px;
    }

    .trial .announce {
        margin-top: 20px;
    }

    .announce_mini {
        margin-bottom: 20px;
    }

    .trial_banner {
        width: 95%;
        margin: 0 auto;
    }

    .facility_wrapper {
        width: 95%;
        margin: 0 auto;
        flex-direction: column;
        text-align: center;
    }

    .facility {
        margin-top: 40px;
    }
}


@media screen and (max-width: 428px) {

    .sankaku_white {
        height: 100px;
        margin-top: -20px;
    }

    .lookdown {
        bottom: -40px;
    }

}