.sp440 {
    display: none
}
@media screen and (min-width: 751px) {
    .sp {
        display: none !important
    }
    body.is_nav {
        overflow: hidden;
    }
    .image_l {
        float: left;
        margin: 0 40px 0 0
    }
    .image_r {
        float: right;
        margin: 0 0 0 40px
    }
    /* NAV */
    nav {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        z-index: 101;
        display: none;
        height: 100vh;
        background: url('../images/nav_bg.jpg') no-repeat center /cover;
    }
    .nav_box {
        display: flex;
        justify-content: space-between;
        height: 100%;
        max-width: 1920px;
        margin: 0 auto;
    }
    .nav_pick {
        width: 30%;
        height: 100%;
        z-index: 2;
        position: relative;
    }
    .nav_pick::after {
        content: '';
        position: absolute;
        width: 100%;
        height: 100%;
        background: url('../images/nav_img1.jpg') no-repeat center /cover;
        min-width: 30vw;
        right: 0;
    }
    .nav_site {
        width: 70%;
        padding: 112px 4%;
    }
    .nav_list {
        background-color: #FFF;
        padding: 66px 9% 60px;
        margin-bottom: 80px;
    }
    .nav_list .rows {
        display: flex;
        justify-content: space-between;
    }
    .nav_list .rows > ul:nth-of-type(2) {
        margin-right: 4%;
    }
    .nav_list .home {
        margin-bottom: 34px;
    }
    .nav_box .sec01_time {
        padding-left: 0;
        margin-right: 20px;
    }
    .is_nav .hamburger {
        right: 2%;
    }
    .is_nav .h_insta {
        right: 7.2%;
    }
    /* CUSTOM */
    .find_a, .find_out {
        cursor: pointer;
    }
    .pdb_30pc {
        padding-bottom: 30px;
    }
    .sec08_list li:nth-of-type(1) .box .image_r {
        padding-top: 30px;
    }
    .sec08_list li:nth-of-type(2) .box .image_r {
        padding-top: 5px;
    }
    .sec08_list li:nth-of-type(3) .box .image_r {
        padding-top: 35px;
    }
    .sec08_list li:nth-of-type(4) .tt {
        padding-top: 10px;
    }
    .sec08_list li:nth-of-type(5) .tt {
        padding-top: 30px;
    }
    .sec08_list li:nth-of-type(5) .box .image_r {
        padding-top: 20px;
    }
    .sec08_list li .tt {
        margin-top: 0 !important;
    }
    /* HOVER */
    .nav_list > li:hover > a {
        color: var(--scolor);
        text-decoration: none;
    }
    .nav_list li a:hover, .home a:hover {
        text-decoration: underline;
        text-underline-offset: 3px;
    }
    .parent:hover .sub {
        opacity: 1;
        transform: translate(0, 0);
        visibility: visible
    }
    .sub a:hover {
        background-color: var(--scolor);
        text-decoration: none;
    }
    .hamburger-box:hover,
    .to_top img:hover,
    .btn a:hover, .find_a:hover {
        opacity: .8
    }
    .ft_bot_logo:hover {
        opacity: 1;
    }
    .s_treatment_accordion dl dt:hover {
        background: var(--scolor);
    }
}
@media screen and (min-width: 1920px) {
    .nav_pick::after {
        min-width: 40vw;
    }
}
@media screen and (min-width: 1850px) {
    .mv_pick_img img {
        max-width: 900px;
    }
}
@media screen and (min-width: 751px) and (max-width: 1800px) {
    img {
        height: auto;
    }
    .mv {
        height: 800px;
    }
    .mv_h2 img {
        height: 94px;
        width: auto;
    }
    .mv_head, .h_inner {
        padding-left: 3%;
    }
    .mv_h2 img {
        height: 95px;
    }
    .mv_h2::before {
        height: calc(100% + 10px);
        bottom: -10px;
    }
    .mv_h2.done::after, .mv_h2::before {
        width: calc(100% + 40px);
        background-size: calc(100% + 10px);
    }
    .mv_tt1, .mv_tt2 {
        font-size: 50px;
    }
}
@media screen and (min-width: 751px) and (max-width: 1500px) {
    .mv {
        height: 100%;
        padding-bottom: 50px;
    }
    .h_btn a {
        font-size: 17px;
    }
    .mv_pick_price::before {
        transform: scale(0.7);
        left: -130px;
    }
    .mv_tt1, .mv_tt2 {
        font-size: 50px;
    }
    .mv_head {
        padding-top: 140px;
    }
    .mv_tt1 {
        margin-bottom: 40px;
    }
    .sec06_box.st1 .sec06_tt::before {
        left: calc(100% + 10px);
    }
    .sec06_box.st2 .sec06_tt:before {
        right: calc(100% + 49px);
    }
    .logo_slogan, .h_contact_tt {
        font-size: 14px;
    }
    .mv_pick_price .tt {
        font-size: 25px;
    }
    h1 {
        font-size: 10px;
    }
    #logo img {
        width: 280px;
    }
    .h_box .h_btn a, .nav_box .h_btn a {
        width: 180px;
        height: 45px;
    }
    .h_box .h_contact_tt > span::before, .h_box .h_contact_tt > span::after,
    .nav_box .h_contact_tt > span::before, .nav_box .h_contact_tt > span::after {
        width: 70px;
    }
    .h_box .h_btn a {
        font-size: 17px;
    }
    .nav_list {
        padding: 40px 30px;
        margin-bottom: 50px;
    }
    .nav_list li a {
        font-size: 14px;
    }
    .nav_list li:not(:last-child) {
        margin-bottom: 5px;
    }
    .nav_box .sec01_cta .tt {
        font-size: 14px;
    }
    .nav_box .calendar_box dl dt {
        width: 100px;
    }
    .nav_box .calendar_box dl dt, .nav_box .calendar_box dl dd {
        font-size: 13px;
    }
    .nav_box .sec01_time .calendar_box {
        width: 320px;
    }
    .nav_box .sec01_add .img {
        width: 220px;
    }
    .nav_box .sec01_add .add, .calendar_note {
        font-size: 12px;
    }
    .nav_site {
        padding: 105px 2%;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    .nav_list .home {
        margin-bottom: 10px;
    }
    .sec06_box.st2 .sec06_des {
        margin-left: auto;
    }
    .sec06_des {
        max-width: 80%;
    }
    .sec06_tt::after {
        width: 3000px;
    }
    .sec06_tt {
        font-size: 80px;
    }
    .sec06_box.st2 .sec06_tt {
        text-align: right;
    }
}
@media screen and (min-width: 1890px) {
    .sec05_top {
        display: flex;
        justify-content: center;
        align-items: center;
        overflow: hidden;
    }
    .sec05_top img {
        max-width: 1920px;
    }
}
/* screen-min:750px */
@media screen and (max-width: 750px) {
    img {
        max-width: 100%;
        height: auto;
    }
    #wrapper, header, main, footer, .inner {
        width: 100% !important;
        min-width: unset !important
    }
    .pc {
        display: none !important
    }
    .image_l, .image_r {
        margin: 0 auto 20px;
        text-align: center;
    }
    /* NAV */
    nav {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh;
        overflow: auto;
        padding-bottom: 80px;
        z-index: 100;
        display: none;
        background: url('../images/nav_bg_sp.jpg') no-repeat center /750px
    }
    nav .inner {
        padding: 0;
    }
    .nav_box {
        padding: 58px 20px;
    }
    .nav_list {
        margin-bottom: 55px;
    }
    .nav_list li {
        margin-bottom: 15px;
    }
    .hamburger {
        right: 7px;
        top: 14px;
    }
    .hamburger-inner, .hamburger-inner::after, .hamburger-inner::before {
        background-color: var(--mcolor);
        height: 1px;
    }
    .hamburger-txt {
        color: var(--mcolor);
        font-size: 14px;
        transform: translateY(-2px);
    }
    .hamburger-inner {
        top: 9px;
        width: 37px;
    }
    .hamburger-inner::before {
        top: -9px;
        width: 42px;
    }
    .hamburger-inner::after {
        bottom: -9px;
        width: 28px;
    }
    .hamburger--3dxy.is_active .hamburger-inner::before {
        transform: translate3d(0, 9px, 0) rotate(25deg);
    }
    .hamburger--3dxy.is_active .hamburger-inner::after {
        transform: translate3d(0, -9px, 0) rotate(-25deg);
        width: 42px;
    }
    /*=====================================================
                          C U S T O M
    ======================================================*/
    /*============ HEADER ============*/
    h1 {
        font-size: 14px;
        max-width: 60vw;
        margin-top: 10px;
        transition: all 0.3s;
    }
    .h_box {
        height: 75px
    }
    #logo {
        width: 220px;
    }
    .h_insta {
        width: 35px;
        right: 69px;
        top: 18px;
    }
    .h_insta .df {
        display: none;
    }
    .is-scroll #logo {
        margin-top: 15px;
    }
    .is-scroll .h_box {
        height: 67px;
    }
    .h_btn a {
        width: 300px;
        height: 50px;
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
    }
    .h_btn.h_ctn_btn a {
        border-radius: 0;
    }
    .btn.btn_anchor a::after {
        width: 18px;
        height: 10px;
        bottom: 10px;
    }
    /*============ Main ============*/
    .ttl_h3 {
        margin-bottom: 25px;
    }
    .ttl_h3 .en {
        font-size: 40px;
        margin-bottom: 20px;
    }
    .ttl_h3 .en {
        transform: rotate(-5deg)
    }
    .ttl_h3 .ja {
        font-size: 20px;
        line-height: 1.6;
    }
    .ttl_h3 .ja .sm {
        font-size: 27px;
    }
    .line {
        background-position: top 26px left;
    }
    .s_head {
        margin-bottom: 47px;
    }
    /* MAIN VISUAL */
    .mv {
        background: url('../images/mv_sp.jpg') no-repeat center /750px;
        height: 812px;
    }
    .mv_h2.done::after {
        width: 100%;
    }
    .mv_box {
        padding: 102px 20px 0;
        ;
    }
    .mv_head {
        max-width: 335px;
        margin-left: auto;
        margin-right: auto;
    }
    .mv_txt h2 {
        font-size: 25px;
    }
    .mv_tt1 {
        font-size: 35px;
        margin-bottom: 6px;
        text-align: center;
    }
    .mv_tt2 {
        font-size: 30px;
        letter-spacing: 0;
        text-align: center;
    }
    .mv_des {
        font-size: 15px;
        margin-bottom: 7px;
        text-align: center;
    }
    .mv_des > span {
        padding: 0 5px 17px;
    }
    .mv_h2 {
        text-align: center;
        margin-bottom: 22px;
        margin-left: -9px;
    }
    .mv_h2 img {
        height: 58px;
        width: auto;
    }
    .mv_h2::before {
        width: 100%;
        height: calc(100% - 3px);
        bottom: -5px;
        left: 2px;
    }
    .mv_h2::after {
        background: url('../images/mv_h2_line_sp.svg') no-repeat center left;
        height: 26px;
        left: 5px;
        bottom: -12px;
    }
    .mv_pick_price {
        padding: 20px 20px 15px;
        max-width: 285px;
        margin: 193px auto 0;
    }
    .mv_pick_price::before {
        width: 160px;
        left: -9px;
        top: -92px;
    }
    .mv_pick_price .tt {
        font-size: 16px;
        letter-spacing: 0.1rem;
        margin-bottom: 21px;
    }
    .mv_pick_price .price {
        margin-bottom: 17px;
    }
    .mv_pick_price .price span {
        white-space: nowrap;
    }
    .mv_pick_price .price .ic1 {
        font-size: 14px;
        width: 39px;
        height: 39px;
        margin-right: 5px;
    }
    .mv_pick_price .price .ic2 {
        font-size: 60px;
    }
    .mv_pick_price .price .ic2 span {
        font-size: 50px;
    }
    .mv_pick_price .price .ic3 span:nth-of-type(1) {
        font-size: 12px;
    }
    .mv_pick_price .price .ic3 span:nth-of-type(2) {
        font-size: 16px;
    }
    .mv_pick_price .note {
        font-size: 14px;
    }
    /* sec01 */
    .sec01 {
        padding: 52px 0 64px;
    }
    .sec01_box {
        max-width: 335px;
        margin-left: auto;
        margin-right: auto;
    }
    .sec01_tt {
        margin-bottom: 37px;
    }
    .sec01_tt .ja {
        font-size: 25px;
        letter-spacing: 0.28rem;
        text-align: center;
        line-height: 1.95;
        margin-bottom: 25px;
    }
    .sec01_tt .en {
        font-size: 30px;
    }
    .sec01_head .img {
        width: calc(100% + 20px);
        margin-bottom: 40px;
        text-align: right;
    }
    .sec01_add {
        margin-bottom: 27px;
    }
    .sec01_add .img {
        width: 279px;
        margin-bottom: 23px;
    }
    .sec01_add .add {
        letter-spacing: 0;
        margin-bottom: 8px;
    }
    .calendar_box, .calendar_note {
        margin-bottom: 18px;
        max-width: 335px;
        margin-left: auto;
        margin-right: auto;
    }
    .calendar_box dl dt, .calendar_box dl dd {
        font-size: 14px;
        letter-spacing: 0;
    }
    .calendar_box dl:first-child dt {
        font-size: 16px
    }
    .calendar_box dl:first-child dd span {
        font-size: 15px;
    }
    .calendar_box dl {
        padding: 8px 0 7px;
    }
    .calendar_box dl dt {
        width: 90px;
        margin-right: 10px;
    }
    .calendar_note {
        margin-bottom: 20px;
    }
    .calendar_note * {
        font-size: 15px;
    }
    .calendar_note .close {
        margin-bottom: 4px;
    }
    .sec01_cta .tt {
        margin-bottom: 24px;
    }
    .sec01_cta > .h_btn:not(:last-child) {
        margin-bottom: 19px;
    }
    .sec01_cta .tt > span {
        letter-spacing: 0;
    }
    /* sec02 */
    .sec02 .ttl_h3 .ja .sm {
        font-size: 35px;
    }
    .sec02_qes {
        margin-bottom: 36px;
    }
    .sec02_qes dt {
        font-size: 20px;
        line-height: 1.3;
        letter-spacing: 0;
        margin-bottom: 25px;
    }
    .sec02_qes dt .sm {
        font-size: 30px;
    }
    .sec02_qes dt > span::before, .sec02_qes dt > span::after {
        width: 40px;
        height: 40px;
        background-size: 400px;
        bottom: -2px;
    }
    .sec02_qes dt > span::before {
        left: -50px;
    }
    .sec02_qes dt > span::after {
        right: -50px;
    }
    .sec02_qes ul {
        justify-content: space-between;
        max-width: 335px;
        margin: 0 auto 20px;
    }
    .sec02_qes ul li:nth-of-type(2) > span {
        transform: translateY(40px);
    }
    .sec02_qes ul li:nth-of-type(1) {
        margin-bottom: 40px;
    }
    .sec02_qes ul li:nth-of-type(3) > span {
        transform: translateY(-45px);
    }
    .sec02_qes ul li > span {
        font-size: 14px;
        width: 160px;
        height: 160px;
    }
    .sec02_qes ul li > span::before {
        font-size: 25px;
        margin-bottom: 10px;
    }
    .sec02_qes ul li > span span span {
        font-size: 16px;
        width: 150px;
        height: 150px;
    }
    .sec02_qes img {
        width: 335px;
    }
    .sec02_qes ul li > span::after {
        width: 240px;
        height: 240px;
    }
    .sec02_asw {
        position: relative;
    }
    .sec02_asw::after {
        content: "";
        position: absolute;
        width: 100vw;
        height: 100%;
        left: -20px;
        background-color: #F0FAF5;
        z-index: -1;
        top: 50px;
    }
    .sec02_asw .asw {
        display: flex;
        padding-top: 127px;
        z-index: 2;
        margin-bottom: 30px;
        max-width: 335px;
        margin-left: auto;
        margin-right: auto;
    }
    .sec02_asw .asw::before {
        content: "";
        position: absolute;
        width: 115px;
        height: 128px;
        background: url('../images/sec02_asw_doc.png') no-repeat center /contain;
        left: calc(50% - 60px);
        top: 0;
        z-index: -1;
    }
    .sec02_asw .asw dt {
        font-size: 30px;
        margin-right: 0;
    }
    .sec02_asw .asw dd > span {
        font-size: 20px;
    }
    .sec02_asw .asw dd .sm {
        font-size: 25px;
    }
    .sec02_asw .asw dd span.bg_sp {
        display: inline-block;
        background-color: #74B4B4;
        color: #FFF;
        line-height: 1.65;
        padding-left: 8px;
        letter-spacing: 0;
    }
    .sec02_asw .asw dd .sm span.bg_sp:first-child {
        padding-right: 8px;
    }
    .sec02_asw .asw dd span:not(:last-child) {
        margin-bottom: 7px;
    }
    .sec02_asw .frame {
        padding: 35px 15px 31px;
        width: 100%;
    }
    .sec02_asw .frame dt {
        font-size: 22px;
        letter-spacing: -.05rem;
        margin-bottom: 11px;
    }
    .sec02_asw .list01 {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        max-width: 335px;
    }
    .sec02_asw .list01 li {
        width: 48%;
    }
    .sec02_asw .list01 li:nth-of-type(3) {
        order: 2;
    }
    .sec02_asw .list01 li:nth-of-type(2) {
        order: 3;
    }
    .sec02_asw .list01 li:nth-of-type(4) {
        order: 4;
    }
    .sec02_asw .frame::before {
        width: 182px;
        height: 50px;
        font-size: 16px;
        top: calc(100% - 10px);
    }
    .linefr_left::before, .linefr_left::after {
        left: -10px;
    }
    .linefr_right::before, .linefr_right::after {
        right: -10px;
    }
    .list01:not(:last-child) {
        margin-bottom: 20px;
    }
    .list01 li {
        letter-spacing: 0;
    }
    .list_check li {
        padding-left: 20px;
    }
    .list_check li:not(:last-child) {
        margin-bottom: 4px;
    }
    .list_check li::before {
        width: 14px;
        height: 14px;
    }
    /* sec03 */
    .sec03 {
        padding: 59px 0;
    }
    .sec03_tt {
        font-size: 32px;
        line-height: 1.5;
        margin-bottom: 18px;
    }
    .sec03_slogan {
        font-size: 30px;
    }
    .sec03_slogan .org {
        font-size: 40px;
    }
    /* .sec03_slogan > span{padding: 17px 20px;margin-bottom: 20px;letter-spacing: 0;min-width: 335px;} */
    .sec03_slogan > span {
        padding: 17px 10px;
        margin-bottom: 20px;
        letter-spacing: 0;
        min-width: 335px;
    }
    .sec03_head {
        margin-bottom: 30px;
    }
    .sec03_head dt {
        font-size: 20px;
        letter-spacing: -0.1rem;
        text-align: center;
        margin-bottom: 30px;
        line-height: 1.45;
    }
    .sec03_head span {
        font-size: 30px;
    }
    .sec03_head .line2, .sec03_head .line2_sp {
        background: none;
        position: relative;
        z-index: 2;
    }
    .sec03_head .line2::after, .sec03_head .line2_sp::after {
        content: "";
        position: absolute;
        height: 10px;
        width: 100%;
        left: 0;
        bottom: 0px;
        z-index: -1;
        background-color: #FFACC9;
    }
    .line2_sp {
        background-image: linear-gradient(0deg, rgba(0, 0, 0, 0) 0, rgba(0, 0, 0, 0) 80%, #FFACC9 80%, #FFACC9 100%);
    }
    .line2_sp, .line2 {
        background-position: top 28px left;
        background-size: 40px;
    }
    .line2_pc {
        background: none;
    }
    .sec03_frame {
        padding: 30px 10px;
        margin-bottom: 76px;
    }
    .sec03_frame_tt {
        font-size: 18px;
        letter-spacing: 0;
        margin-bottom: 42px;
    }
    .sec03_frame_tt .bg_sp {
        display: inline-block;
        padding: 3px 10px;
        background-color: #74B4B4;
    }
    .sec03_frame_tt .bg_sp:not(:last-child) {
        margin-bottom: 8px;
    }
    .sec03_frame_tt .sm {
        font-size: 20px;
    }
    .sec03_frame_step {
        margin-bottom: 25px;
        max-width: 335px;
        margin-left: auto;
        margin-right: auto;
    }
    .sec03_frame_step dl {
        display: flex;
        justify-content: space-between;
        align-items: center;
        max-width: 335px;
        margin-left: auto;
        margin-right: auto;
        position: relative;
    }
    .sec03_frame_step dl:not(:last-child) {
        margin-bottom: 28px;
    }
    .sec03_frame_step dl dt {
        font-size: 16px;
        width: 118px;
        height: 118px;
    }
    .sec03_frame_step:after {
        content: "";
        position: absolute;
        width: 2px;
        bottom: 0;
        left: 59px;
        z-index: -1;
        background: url('../images/sec03_frame_step_line_sp.png') repeat top left /2px;
        z-index: -1;
        transition: all 0.3s;
        height: 0;
    }
    .sec03_frame_step.aos-animate:after {
        height: calc(100% - 100px);
    }
    .sec03_frame_step dl dt img {
        transform: scale(0.7);
        margin-bottom: -4px;
        margin-top: 10px;
    }
    .sec03_frame_step dl dd {
        padding-left: 40px;
        width: 62%;
        min-height: 118px;
    }
    .sec03_frame_step dl dd .tt {
        font-size: 15px;
        margin-bottom: 16px;
    }
    .sec03_frame_step dl dd::before {
        content: "";
        position: absolute;
        width: 20px;
        height: 100%;
        border: 1px solid #A4A8A7;
        border-left: 0;
        left: 0;
        top: 0;
    }
    .sec03_frame_box .des {
        padding: 0 10px;
    }
    .sec03_bnn {
        width: 100%;
        padding: 32px 21px;
    }
    .sec03_bnn .tt {
        font-size: 28px;
        margin-bottom: 12px;
    }
    .sec03_bnn .tt > span {
        padding: 45px 0 0 0;
        letter-spacing: 0;
        line-height: 1.5;
    }
    .sec03_bnn .tt > span::after {
        display: none;
    }
    .sec03_bnn .tt > span::before {
        left: calc(50% - 20px);
        width: 40px;
    }
    .sec03_bnn dt {
        margin-bottom: 25px;
        text-align: center;
    }
    /* sec04 */
    .sec04 {
        padding: 0 0 50px;
    }
    .sec04_head {
        margin-bottom: 37px;
    }
    .sec04 .ttl_h3 .ja {
        line-height: 1.9;
        font-size: 24px;
        letter-spacing: 0;
    }
    .sec04_list dl:not(:last-child) {
        margin-bottom: 50px;
    }
    .sec04_list dl dt {
        position: relative;
        z-index: 3;
        position: relative;
        width: calc(100% + 20px);
        margin-left: -20px;
        text-align: center;
    }
    .sec04_list dl dt .ic {
        font-size: 15px;
        width: 150px;
        height: 150px;
    }
    .sec04_list dl dt .ic01 {
        top: -9px;
        right: 10px;
        line-height: 1.5;
        padding-top: 16px;
        letter-spacing: 0;
    }
    .sec04_list dl dt .ic02 {
        bottom: -20px;
        left: 10px;
    }
    .sec04_list dl:nth-of-type(1) dt {
        background-color: #74B4B4;
    }
    .sec04_list dl dt .box {
        max-width: 335px;
        margin: 0 auto;
        position: relative;
        height: 100%;
        padding: 98px 13px 60px;
    }
    .sec04_list dl dd {
        padding: 42px 20px 35px;
    }
    .sec04_list dl dd::after {
        width: calc(100% + 20px);
        left: 0;
        height: calc(100% + 80px);
        top: -80px;
    }
    .sec04_cat {
        margin-bottom: 35px;
        width: calc(100% + 20px);
        max-width: 355px;
        margin-left: auto;
        margin-right: auto;
    }
    .sec04_cat li {
        font-size: 15px;
        width: 60px;
        height: 30px;
    }
    .sec04_cat li:not(:nth-of-type(-n+4)) {
        margin-top: 15px;
    }
    .sec04_cat li:not(:nth-of-type(4n)) {
        margin-right: 15px;
    }
    .sec04_cat li:nth-of-type(5) {
        margin-left: 30px;
    }
    .sec04_list .tt {
        text-align: center;
        font-size: 21px;
        letter-spacing: 0;
        padding-bottom: 20px;
        margin-bottom: 23px;
    }
    .sec04_list .tt::after {
        left: calc(50% - 50px);
    }
    .s_treatment {
        padding: 50px 0 0;
    }
    .s_treatment .ttl_h3 .ja {
        font-size: 22px;
    }
    .s_treatment_accordion dl dt span {
        font-size: 20px;
    }
    .s_treatment_accordion dl dt span::after {
        border-right-width: 8px;
        border-left-width: 8px;
        border-top-width: 7px;
        top: calc(50% - 4px);
        right: -35px;
    }
    .s_treatment_accordion dl dt.active span::after {
        border-bottom-width: 7px;
    }
    .s_treatment_accordion dl dt {
        height: 60px;
        padding: 10px;
    }
    .s_treatment_accordion dl dd {
        padding: 20px 10px;
    }
    .s_treatment_list ul li span {
        font-size: 18px;
        margin-bottom: 8px;
    }
    .s_treatment_list ul li.bf {
        margin-bottom: 70px;
    }
    .s_treatment_list ul li.bf::after {
        bottom: -50px;
        left: calc(50% - 30px);
        border-right: 30px solid transparent;
        border-left: 30px solid transparent;
        border-top: 18px solid #D64577;
        border-bottom: unset;
    }
    .s_treatment_accordion dl dd tr td ul li span {
        display: block;
    }
    .s_treatment_list {
        margin-bottom: 45px;
    }
    .s_treatment table th, .s_treatment table td {
        font-size: 16px;
    }
    .s_treatment table.tb_block tr:not(:last-child) {
        margin-bottom: 0px;
    }
    .s_contact {
        padding: 70px 0 60px;
    }
    .s_contact_box {
        padding: 15px;
        background-image: linear-gradient(to left bottom, #fff4ee, #fef6ed, #fbf8ee, #f8fbf0, #f5fdf3, #f2fcf3, #eefcf4, #ebfbf5, #e6f8f2, #e0f5ef, #dbf2ed, #d5efea);
    }
    .s_contact_frame {
        padding: 0 20px 36px;
    }
    .s_contact_frame .tt {
        font-size: 18px;
        letter-spacing: 0;
        line-height: 2;
        margin-bottom: 26px;
    }
    .s_contact_frame .tt > span span {
        font-size: 30px;
        line-height: 1.4;
    }
    .s_contact_frame .en {
        font-size: 40px;
        transform: rotate(-5deg) translateY(-20px);
        margin-bottom: 9px;
    }
    .s_contact_frame::before, .s_contact_frame::after {
        width: calc(50% - 80px);
    }
    .s_contact_frame .tt .key {
        width: 85px;
        height: 85px;
        font-size: 20px;
        left: -53px;
        top: -85px;
    }
    .s_contact2 .s_contact_frame .tt .key {
        left: -42px;
    }
    /* .h_contact_cta{margin-bottom: 30px;} */
    .h_contact_cta {
        margin-bottom: 0px;
    }
    .h_contact_cta .h_btn:not(:last-child) {
        margin-bottom: 20px;
    }
    .s_contact_insta dt {
        margin-right: 10px;
        width: 45px;
    }
    .s_contact_insta dd {
        letter-spacing: 0;
        line-height: 1.6;
    }
    .ttl_slogan {
        text-align: center;
        font-size: 20px;
    }
    .ttl_slogan span {
        padding-bottom: 5px;
        letter-spacing: 0;
    }
    .ttl_slogan span::after {
        height: 8px;
        background: url(../images/ttl_slogan_line_sp.png) no-repeat center /500px;
    }
    .btn a {
        height: 70px;
        font-size: 25px;
        margin-left: auto;
        margin-right: auto;
    }
    /* sec05 */
    .sec05 {
        padding-bottom: 20px;
    }
    #nav_ttl03 {
        position: absolute;
        top: 70px;
    }
    .sec05_head {
        margin-top: -82px;
    }
    .sec05_top {
        max-height: 420px;
        display: flex;
        justify-content: center;
        align-items: center;
        overflow: hidden;
    }
    .sec05_top::after {
        height: 181px;
    }
    .sec05 .ttl_h3 .en {
        letter-spacing: -.01rem;
        transform: rotate(-5deg) translateX(2px);
    }
    .sec05 .ttl_h3 .ja {
        font-size: 22px;
    }
    .sec05_slogan {
        margin-bottom: 20px;
    }
    .sec05_tt2 {
        font-size: 20px;
        padding-left: 40px;
        position: relative;
        text-align: center;
        max-width: 290px;
        margin: 0 auto;
        margin-bottom: 20px;
        letter-spacing: 0;
        line-height: 1.6;
    }
    .sec05_tt2 .min {
        font-size: 29px;
    }
    .sec05_tt2 .lg {
        font-size: 37px;
        display: inline-block;
    }
    .sec05_tt2 .num {
        font-size: 100px;
        position: absolute;
        left: 6px;
        top: -10px;
    }
    .sec05_list {
        padding-top: 20px;
        justify-content: center;
    }
    .sec05_list dl {
        padding-left: 45px;
        max-width: 445px;
    }
    .sec05_list dl:not(:last-child) {
        margin-bottom: 45px;
    }
    .sec05_list dl dd .tt {
        font-size: 18px;
        width: calc(100% - 20px);
        margin-bottom: 16px;
    }
    .sec05_list dl dt .ic {
        font-size: 14px;
    }
    .sec05_list dl dt .ic span {
        font-size: 22px;
        margin-top: 5px;
    }
    .sec05_list dl dt {
        margin-bottom: -20px;
    }
    /* sec06 */
    .sec06 {
        padding: 115px 0 93px;
        clip-path: polygon(100% 0, 100% calc(100% - 57px), 50% 100%, 0 calc(100% - 57px), 0% 0%);
    }
    .sec09::before, .sec10::before, .sec06::before {
        height: 54px;
    }
    .sec06 .ttl_h3 .en {
        letter-spacing: -.03rem;
        white-space: nowrap;
    }
    .sec06 .ttl_h3 .ja .sm {
        line-height: 1.4;
    }
    .sec06_frame {
        padding: 0 10px 53px;
        margin-bottom: 25px;
    }
    .sec06_frame .tt {
        font-size: 25px;
        letter-spacing: 0;
        transform: translateY(-40px);
        line-height: 1.6;
        margin-bottom: -13px;
    }
    .sec06_frame .tt > span {
        display: inline-block;
        background-color: #E1F5EF;
        padding: 0 10px;
    }
    .sec06_frame::after {
        border-width: 1px;
        clip-path: polygon(15px 0%, calc(100% - 15px) 0%, 100% 15px, 100% calc(100% - 15px), calc(100% - 15px) 100%, 15px 100%, 0% calc(100% - 15px), 0% 15px);
    }
    .sec06_frame ul li:not(:last-child) {
        margin-bottom: 46px;
    }
    .sec06_frame ul li .img {
        width: 200px;
        margin: 0 auto 20px;
        height: auto;
    }
    .sec06_head:not(:last-child) {
        margin-bottom: 83px;
    }
    .sec06_frame .ic span {
        width: 20px;
        height: 1px;
    }
    .sec06_frame .ic span:nth-of-type(1) {
        top: 7px;
        left: -2px;
        transform: rotate(-45deg);
    }
    .sec06_frame .ic span:nth-of-type(2) {
        top: 7px;
        right: -2px;
        transform: rotate(45deg);
    }
    .sec06_frame .ic span:nth-of-type(3) {
        bottom: 7px;
        left: -2px;
        transform: rotate(-135deg);
    }
    .sec06_frame .ic span:nth-of-type(4) {
        bottom: 7px;
        right: -2px;
        transform: rotate(135deg);
    }
    .sec06_arr {
        font-size: 16px;
        margin-bottom: 50px;
    }
    .sec06_arr::after {
        width: 182px;
        height: 52px;
        top: -5px;
    }
    .sec06_slogan {
        font-size: 20px;
        margin-bottom: 40px;
    }
    .sec06_slogan span {
        padding-bottom: 10px;
    }
    .sec06_tt {
        font-size: 50px;
        letter-spacing: -.05rem;
        white-space: nowrap;
        margin-bottom: 134px;
        max-width: 335px;
        margin-left: auto;
        margin-right: auto;
    }
    .sec06_tt::after {
        height: 125px;
    }
    .sec06_tt::before {
        width: 230px;
        height: 204px;
        left: calc(50% - 80px);
        top: calc(100% - 40px);
    }
    .sec06_box {
        margin-bottom: 77px;
    }
    .sec06_list {
        max-width: 510px;
        margin-left: auto;
        margin-right: auto;
    }
    .sec06_list:not(:last-child) {
        margin-bottom: 50px;
    }
    .sec06_list dl:not(:last-child) {
        margin-bottom: 75px;
    }
    .sec06_list dl dt .feature .txt {
        font-size: 14px;
        line-height: 1.2;
    }
    .sec06_list dl dt .feature .num {
        font-size: 60px;
    }
    .sec06_list dl dd {
        padding: 27px 20px;
    }
    .sec06_list dl dd .tt {
        font-size: 20px;
        padding-bottom: 17px;
        margin-bottom: 20px;
        line-height: 1.6;
        letter-spacing: 0;
    }
    .sec06_list dl dd .tt::after {
        width: 80px;
        left: calc(50% - 40px);
    }
    .sec06_list dl dt {
        max-width: calc(100% - 40px);
        margin-bottom: -12px;
    }
    .sec06_list dl dt .feature {
        padding: 0;
        top: -41px;
    }
    .sec06_box.st2 .sec06_tt:before {
        left: calc(50% - 140px);
    }
    /* sec07 */
    .sec07 {
        padding: 77px 0 10px;
    }
    .sec07_frame {
        width: calc(100% + 10px);
        margin-left: -10px;
    }
    .sec07_frame .tt {
        margin-bottom: -15px;
        font-size: 25px;
        line-height: 1.6;
        transform: translateY(-42px);
    }
    .sec07_frame .tt span {
        padding: 0 27px;
        letter-spacing: 0;
    }
    .sec07_frame_box {
        padding-bottom: 35px;
    }
    .sec07_frame_box dl {
        display: flex;
        flex-direction: column;
    }
    .sec07_frame_box dl dd {
        order: 1;
        margin-bottom: 23px;
        text-align: center;
    }
    .sec07_frame_box dl dt {
        order: 2;
        margin-bottom: 20px;
    }
    .sec07_slogan {
        margin-bottom: 15px;
    }
    .sec07_frame .list_check {
        max-width: 225px;
        margin: 0 auto 3px;
    }
    .sec07_frame .list_check li {
        padding-left: 30px;
        letter-spacing: 0;
    }
    .s_contact2 .s_contact_frame .tt {
        font-size: 18px;
        letter-spacing: 0;
        width: calc(100% + 20px);
        margin-left: -10px;
    }
    /* sec08 */
    .sec08 {
        padding: 57px 0 38px;
    }
    .sec08_tt {
        margin-bottom: 47px;
    }
    .sec08_tt .ja {
        line-height: 1.4;
    }
    .sec08_list {
        width: calc(100% + 20px);
        margin-left: -10px;
    }
    .sec08_list li {
        margin-right: 10px;
    }
    .sec08_list li:not(:last-child) {
        margin-bottom: 45px;
    }
    .sec08_list li:not(:last-child):after {
        left: calc(50% - 6px);
    }
    .sec08_list li .tt {
        text-align: center;
        margin-bottom: 15px;
    }
    .sec08_list li .box {
        padding: 33px 27px 30px;
    }
    .sec08_list li .ic {
        width: 45px;
        height: 45px;
    }
    .sec08_list li .ic::after {
        width: 60px;
        height: 60px;
    }
    .sec08_list li .ic .num {
        font-size: 35px;
    }
    .sec08_list li .ic .step {
        font-size: 14px;
    }
    .sec08_list li .sec08_check {
        padding: 30px 27px 35px;
        margin-top: 130px;
        width: calc(100% - 10px);
        transform: translateX(-10px);
    }
    .sec08_list li .sec08_check::before {
        transform: rotate(90deg);
        left: calc(50% - 22px);
        top: -25px;
        width: 47px;
    }
    .sec08_list li .sec08_check .key {
        font-size: 37px;
        top: -32px;
    }
    .sec08_list li .sec08_check .key span {
        padding: 0 28px;
    }
    .sec08_list li .sec08_check .key span::before, .sec08_list li .sec08_check .key span::after {
        width: 30px;
        height: 39px;
        background-size: auto 100%;
    }
    .sec08_list li .sec08_check::after {
        left: calc(50% - 25px);
        top: -100px;
        width: 50px;
        height: 50px;
    }
    .sec08_list li .sec08_check .tt {
        font-size: 25px;
        margin-bottom: 10px;
    }
    .sec08_list li .sec08_check .tt .icon1 {
        transform: scale(0.7) translate(-8px, -5px);
        margin-right: -7px;
    }
    .sec08_list li .sec08_check .tt .icon2 {
        transform: scale(0.6) translate(-36px, -5px);
        margin-right: -25px;
    }
    .nowrap_sp {
        white-space: nowrap;
    }
    /* sec09 */
    .sec09 {
        padding: 107px 0 32px;
    }
    .sec09_tt {
        margin-bottom: 34px;
    }
    .sec09_tt .ja {
        line-height: 1.4;
    }
    .tb_note {
        font-size: 20px;
        margin-bottom: 13px;
        letter-spacing: 0;
    }
    .sec09_box {
        width: calc(100% + 6px);
        margin-left: -3px;
    }
    table:not(:last-child) {
        margin-bottom: 35px;
    }
    table.tb_block tr {
        display: flex;
        flex-direction: column
    }
    table.tb_block tr:not(:last-child) {
        margin-bottom: 18px;
    }
    table.tb_block th,
    table.tb_block td {
        width: 100%;
        border-width: 3px;
    }
    table.tb_block td {
        padding: 11px 10px;
        line-height: 1.4;
    }
    table.tb_block th {
        border-bottom: none;
        border-top: none;
        padding: 7px 10px;
    }
    table.tb_block td + td {
        border-top: none;
    }
    /* sec10 */
    .sec10 {
        padding: 97px 0 70px;
    }
    .sec10_head {
        margin-bottom: 35px;
    }
    .sec10_tt .ja {
        font-size: 25px;
    }
    .sec10_list dl {
        padding: 29px 17px 32px;
    }
    .sec10_list dl:not(:last-child) {
        margin-bottom: 40px;
    }
    .sec10_list dl dt {
        margin-bottom: 26px;
    }
    .sec10_list dl .tt {
        text-align: center;
        margin-bottom: 34px;
    }
    .sec10_list dl:nth-of-type(2) .tt {
        margin-bottom: 13px;
    }
    .sec10_list dl:nth-of-type(3) dt {
        margin-bottom: 62px;
    }
    .sec10_list dl:nth-of-type(3) .tt {
        font-size: 25px;
        margin-bottom: 22px;
    }
    .sec10_list dl:nth-of-type(3) .img img {
        width: 230px;
        margin: 0 auto;
        display: block;
    }
    .sec10_list dl .tt .icon {
        display: block;
        margin: 0 auto -4px;
        transform: scale(0.65);
    }
    .sec10_list dl .price {
        margin-bottom: 20px;
        justify-content: center;
    }
    .sec10_list dl .price .ic1 {
        font-size: 26px;
        padding: 5px;
        margin-right: 15px;
    }
    .sec10_list dl .price .ic2 {
        font-size: 61px;
        margin-right: 11px;
    }
    .sec10_list dl .price .ic3 span:nth-of-type(1) {
        font-size: 18px;
        line-height: 1.4;
    }
    .sec10_list dl .price .ic3 span:nth-of-type(2) {
        font-size: 25px;
    }
    .sec10_list dl .price2 {
        text-align: center;
        letter-spacing: 0;
        font-size: 26px;
        margin-bottom: 16px;
    }
    .sec10_list dl .price2 .org {
        font-size: 30px;
    }
    .sec10_list dl .price2 .num {
        font-size: 62px;
    }
    .sec10_list dl .tag {
        justify-content: center;
    }
    .sec10_list dl .tag li {
        width: 140px;
        height: 30px;
        font-size: 15px;
    }
    .sec10_list dl .tag li:not(:last-child) {
        margin-right: 17px;
    }
    .sec10_list dl .note {
        width: max-content;
        margin: 0 auto;
    }
    /*============ FOOTER ============*/
    footer .h_btn a {
        width: 335px;
    }
    address {
        padding: 10px 10px 75px;
        letter-spacing: 0;
    }
    .ft_contact {
        padding: 0 0 38px;
        background-image: linear-gradient(to left bottom, #fff4ee, #fef6ed, #fbf8ee, #f8fbf0, #f5fdf3, #f2fcf3, #eefcf4, #ebfbf5, #e6f8f2, #e0f5ef, #dbf2ed, #d5efea);
    }
    .ft_contact .ttl_h3 {
        margin-bottom: 35px;
    }
    .ft_contact .ttl_h3 .box_en .en {
        transform: rotate(-5deg) translate(10px, -20px);
        font-size: 50px;
        display: block;
        margin-bottom: 7px;
    }
    .ft_contact .ttl_h3 .box_en .icon {
        width: 85px;
        height: 85px;
        font-size: 20px;
        top: -35px;
        left: -94px;
        line-height: 1.3;
        padding-top: 6px;
    }
    .ft_contact .ttl_h3 .sm {
        margin-top: 10px;
        display: inline-block;
    }
    .ft_bot {
        padding: 60px 0 38px;
    }
    .ft_bot_col_r .map iframe {
        width: calc(100% + 40px);
        margin-left: -20px;
        height: 299px;
    }
    .ft_bot_logo .img {
        width: 193px;
        margin: 0 auto 16px;
    }
    .ft_bot .ttl_h3 {
        margin-bottom: 44px;
    }
    .ft_bot .ttl_h3 .ja {
        font-size: 25px;
        letter-spacing: 0.25rem;
    }
    .ft_bot_slogan .sm {
        font-size: 22px;
    }
    .ft_bot_slogan > span {
        font-size: 14px;
        line-height: 1.6;
        padding-bottom: 30px;
    }
    .ft_bot_slogan > span::after {
        width: 335px;
    }
    .ft_bot_insta, .ft_bot_col_l {
        margin-bottom: 36px;
    }
    .ft_bot_col_r .map {
        margin-bottom: 8px;
    }
    .ft_bot_col_r .add {
        letter-spacing: 0;
        white-space: nowrap;
    }
    .ft_bot_col_r .add, .ft_bot_col_r .local {
        max-width: 335px;
        margin-left: auto;
        margin-right: auto;
    }
    /* SP CONTACT */
    .ctn_btn_wrapper .ctn_btn_text{
        position: fixed;
        left: 0;
        right: 0;
        text-align: center;
        font-size: 14px;
        background-color:  rgba(223, 240, 240, 0.95);
        padding: 5px 0;
        z-index: 100;
        font-weight: 700;
        width: 90%;
        margin: 0 auto;
        bottom: -55px;
        border-radius: 50px;
        transition: all 0.3s;
    }
    .ctn_btn_wrapper .ctn_btn_text.show {
        bottom: 43px; /* ボタンの上にテキストを配置 */
    }
    .ctn_btn_wrapper .ctn_btn_text span{
        color: #d64578;
    }
    .sp_contact {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        height: 50px;
        position: fixed;
        left: 0;
        z-index: 99;
        bottom: -55px;
        transition: all 0.3s;
    }
    .sp_contact.show {
        bottom: 0;
    }
    .sp_contact li {
        width: 50%;
        height: 100%;
    }
    .sp_contact li a {
        width: 100%;
        height: 100%;
        border-radius: 0;
        height: 55px;
        font-size: 17px;
    }
    .sp_contact li a span {
        font-size: 16px;
    }
    .sp_contact .h_contact_mail a {
        border-top-left-radius: 15px;
    }
    .sp_contact.ctn-btn .h_contact_mail a {
        border-top-left-radius: 0;
    }
    .sp_contact .h_contact_tel a {
        border-top-right-radius: 15px;
    }
    .sp_contact.ctn-btn .h_contact_tel a {
        border-top-right-radius: 0;
    }
    .h_contact_tel a > span::before {
        width: 17px;
        height: 17px;
        margin-right: 5px;
    }
    .h_contact_mail a > span span {
        font-size: 17px;
    }
    .h_contact_mail a > span::before {
        width: 20px;
        height: 15px;
    }
    /* TO TOP */
    .to_top {
        width: 50px;
        height: 50px;
        right: 10px
    }
    /*============ END 750 ============ */
}
/* screen-max:440px */
@media screen and (max-width: 440px) {
    .sp440 {
        display: block !important;
    }
    .pc440 {
        display: none !important
    }
    .sec04_cat {
        margin-left: -10px;
    }
    .sec06_tt {
        margin-left: -8px;
    }
    .ft_bot_col_r .map iframe {
        height: 200px;
    }
}
/* screen-max: 360px */
@media screen and (max-width: 360px) {}