@charset "UTF-8";
@media only screen and (max-width: 768px) {
  @-webkit-keyframes idxKeyInTopSP {
  0% {
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
    clip-path: inset(0 0 0 100%);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    clip-path: inset(0 0 0 0);
  }
}
@keyframes idxKeyInTopSP {
  0% {
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
    clip-path: inset(0 0 0 100%);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    clip-path: inset(0 0 0 0);
  }
}
@-webkit-keyframes idxKeyInBottomSP {
  0% {
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
    clip-path: inset(0 100% 0 0);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    clip-path: inset(0 0 0 0);
  }
}
@keyframes idxKeyInBottomSP {
  0% {
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
    clip-path: inset(0 100% 0 0);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    clip-path: inset(0 0 0 0);
  }
}
@-webkit-keyframes mvSlide_left_sp {
  0% {
    clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
    -webkit-transform: scale(1) translateX(0);
            transform: scale(1) translateX(0);
  }
  50% {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  }
  100% {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
    -webkit-transform: scale(1.05) translateX(0);
            transform: scale(1.05) translateX(0);
  }
}
@keyframes mvSlide_left_sp {
  0% {
    clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
    -webkit-transform: scale(1) translateX(0);
            transform: scale(1) translateX(0);
  }
  50% {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  }
  100% {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
    -webkit-transform: scale(1.05) translateX(0);
            transform: scale(1.05) translateX(0);
  }
}
@-webkit-keyframes mvSlide_before_left_sp {
  0% {
    -webkit-transform: scale(1.05) translateX(0);
            transform: scale(1.05) translateX(0);
  }
  100% {
    -webkit-transform: scale(1) translateX(10px);
            transform: scale(1) translateX(10px);
  }
}
@keyframes mvSlide_before_left_sp {
  0% {
    -webkit-transform: scale(1.05) translateX(0);
            transform: scale(1.05) translateX(0);
  }
  100% {
    -webkit-transform: scale(1) translateX(10px);
            transform: scale(1) translateX(10px);
  }
}
@-webkit-keyframes mvSlide_right_sp {
  0% {
    clip-path: polygon(100% 0%, 100% 0%, 100% 100%, 100% 100%);
    -webkit-transform: scale(1) translateX(0);
            transform: scale(1) translateX(0);
  }
  50% {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  }
  100% {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
    -webkit-transform: scale(1.05) translateX(0);
            transform: scale(1.05) translateX(0);
  }
}
@keyframes mvSlide_right_sp {
  0% {
    clip-path: polygon(100% 0%, 100% 0%, 100% 100%, 100% 100%);
    -webkit-transform: scale(1) translateX(0);
            transform: scale(1) translateX(0);
  }
  50% {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  }
  100% {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
    -webkit-transform: scale(1.05) translateX(0);
            transform: scale(1.05) translateX(0);
  }
}
@-webkit-keyframes mvSlide_before_right_sp {
  0% {
    -webkit-transform: scale(1.05) translateX(0px);
            transform: scale(1.05) translateX(0px);
  }
  100% {
    -webkit-transform: scale(1) translateX(-10px);
            transform: scale(1) translateX(-10px);
  }
}
@keyframes mvSlide_before_right_sp {
  0% {
    -webkit-transform: scale(1.05) translateX(0px);
            transform: scale(1.05) translateX(0px);
  }
  100% {
    -webkit-transform: scale(1) translateX(-10px);
            transform: scale(1) translateX(-10px);
  }
}
  .home_page .key {
    --height: calc(100vh - 60px);
    --max-height: 156vw;
    --min-height: 320px;
  }
  .home_page .key .key_text {
    font-size: min(8px, 1.5vw);
  }
  .home_page .key .key_text .item {
    padding: 10px;
  }
  .home_page .key .catch h2 {
    font-size: 5em;
  }
  .home_page .key .catch p {
    font-size: 2.8em;
  }
  .home_page .key .mv_bg {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    /* background-image: url(../images/idx_mv3_1_sp.jpg), url(../images/idx_mv3_2_sp.jpg); */
    background-position: top left, bottom right;
    background-size: 100% 50%;
  }
  .home_page .key .mv_bg .mv_bg_left,
  .home_page .key .mv_bg .mv_bg_right {
    width: 100%;
    height: calc(var(--height) / 2);
    min-height: calc(var(--min-height) / 2);
    max-height: calc(var(--max-height) / 2);
  }
  .home_page .key .mv_bg .mv_bg_img {
    height: calc(var(--height) / 2);
    min-height: calc(var(--min-height) / 2);
    max-height: calc(var(--max-height) / 2);
  }
  .home_page .key .mv_bg .mv_bg_left .mv_bg_item.before .mv_bg_img {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  }
  /* .home_page .key .mv_bg .mv_bg_left .mv_bg_item.active .mv_bg_img {
    -webkit-animation-name: mvSlide_left_sp_sp;
            animation-name: mvSlide_left_sp_sp;
  }
  .home_page .key .mv_bg .mv_bg_right .mv_bg_item.active .mv_bg_img {
    -webkit-animation-name: mvSlide_right_sp;
            animation-name: mvSlide_right_sp;
  } */

  
  .home_page .key .mv_bg .mv_bg_left .mv_bg_item.before:not(.hide) .mv_bg_img {
    -webkit-animation-name: mvSlide_before_left_sp;
            animation-name: mvSlide_before_left_sp;
  }
  .home_page .key .mv_bg .mv_bg_right .mv_bg_item.before:not(.hide) .mv_bg_img {
    -webkit-animation-name: mvSlide_before_right_sp;
            animation-name: mvSlide_before_right_sp;
  }
    .home_page .key .mv_bg .mv_bg_left .mv_bg_item.active:not(.hide) .mv_bg_img {
      -webkit-animation-name: mvSlide_left_sp;
              animation-name: mvSlide_left_sp;
    }
    .home_page .key .mv_bg .mv_bg_right .mv_bg_item.active:not(.hide) .mv_bg_img {
    -webkit-animation-name: mvSlide_right_sp;
            animation-name: mvSlide_right_sp;
    }



  .home_page .fixed-bnr {
    bottom: 20px;
    left: 15px;
    font-size: 6px;
    height: 12.2em;
    position: absolute;
  }
  .home_page .fixed-bnr figure {
    width: 35%;
  }
  .home_page .fixed-bnr.active {
    position: fixed;
    bottom: 60px;
  }
  .home_page .fixed-bnr.ac {
    bottom: 111px;
  }
  .home_page .fixed-bnr .ic-close {
    width: 3.2em;
    height: 3.2em;
    background-size: 1.4em auto;
  }
  .home_page .fixed-bnr_cont::after {
    width: 2.5em;
    height: 1em;
  }
  .home_page .fixed-bnr_tt {
    width: 65%;
  }
  .home_page .fixed-bnr_tt .tt-en {
    font-size: 1.2em;
    letter-spacing: 0.05em;
  }
}
@media only screen and (max-width: 360px) {
  .home_page .fixed-bnr.ac {
    bottom: 134px;
  }
}
@media only screen and (max-width: 768px) and (orientation: landscape) {
  .home_page .key .key_text {
    font-size: 1.4vmin;
  }
}
@media only screen and (max-width: 768px) {
  .wrap-h3 h3 {
    padding-left: 0;
    padding-right: 0;
    font-size: 26px;
    margin-bottom: 10px;
  }
  .wrap-h3 h3.tt36 {
    font-size: 28px;
    margin-bottom: 10px;
  }
  .wrap-h3 h3 .tt-lg {
    font-size: 32px;
  }
  .wrap-h3 h3.mb {
    margin-bottom: 12px;
  }
  .wrap-h3 .h-en {
    font-size: 18px;
  }
  .idx01 {
    padding: 50px 0px;
  }
  .idx01 .wrap-h3 {
    margin-bottom: 25px;
  }
  .idx01 .block-news {
    margin-top: 0;
    padding: 0 0% 40px;
  }
  .idx01 .block-news::before {
    width: calc(100% + 40px);
    height: calc(100% - 25px);
    left: -20px;
  }
  .idx01 .tab-content, .idx01 .tab-btn {
    margin-right: auto;
  }
  .idx01 .tab-btn {
    margin-bottom: 35px;
  }
  .idx01 .tab-btn .tab-it {
    padding: 8px 6px 8px;
    margin: 0 3px;
  }
  .idx01 .tab-btn .tab-it p{font-size: min(16px, 4.5vw);}
  .idx01 .btn-group {
    margin-top: 25px;
    margin-left: auto;
    margin-right: auto;
  }
  .idx01 .list-post a {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    --w: 108px;
    padding: 10px 0px 10px 5px;
  }
  .idx01 .list-post a .title {
    width: 100%;
    padding-left: 0;
    line-height: 1.5;
  }
  .idx01 .list-post a .cate {
    width: 105px;
    font-size: 14px;
    top: 0;
  }
  .idx02 {
    padding: 75px 0 55px;
  }
  .idx02 .wrap-h3 {
    padding-bottom: 4.166667em;
    margin-bottom: 0;
  }
  .idx02 .wrap-h3::before {
    font-size: 0.8em;
  }
  .idx02 .wrap-h3 h3::before {
    font-size: 0.8em;
  }
  .idx02 .bnr_seft-check {
    font-size: min(7px, 2vw);
  }
  .idx03 {
    padding: 85px 0 120px;
  }
  .idx03:before {
    font-size: 4px;
    background-image: url(../images/idx03_bf.png), url(../images/idx03_bg_sp.jpg);
    background-position: top 5% center, center;
    background-size: 100% auto, cover;
  }
  .idx03 .wrap-h3 {
    margin-bottom: min(400px, 61vw);
  }
  .idx03 .box-checklist {
    width: 100%;
    max-width: 550px;
    margin-left: auto;
    margin-right: auto;
    padding: 20px 5% 35px;
  }
  .idx03 .btn {
    margin: 25px auto 0;
    width: 100%;
  }
  .idx03 .listcheck li {
    font-size: 18px;
    padding-left: 40px;
  }
  .idx03 .listcheck li::before {
    left: 5px;
    width: 20px;
    height: 20px;
  }
  .idx04 {
    padding-bottom: 55px;
  }
  .idx04::before {
    font-size: min(4px, 0.8vw);
  }
  .idx04::after {
    height: min(300px, 78vw);
  }
  .idx04 .wrap-h3 {
    margin-bottom: 25px;
  }
  .idx04 .b-grid {
    max-width: 650px;
    width: 100%;
    margin: 0 auto;
  }
  .idx04 .osteoporosis-content {
    margin-top: 25px;
    padding: 0;
  }
  .idx04 .osteoporosis-content .cont {
    padding: 0;
    margin-bottom: 30px;
  }
  .idx04 .osteoporosis-bnr {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .idx04 .osteoporosis-bnr .bnr-it {
    max-width: 28em;
    width: calc((100% - 1em) / 2);
    margin-right: 1em;
    margin-bottom: 1em;
    font-size: min(8px, 1.8vw);
    padding: 2.6em 1.5em;
  }
  .idx04 .osteoporosis-bnr .bnr-it:nth-child(2n+2), .idx04 .osteoporosis-bnr .bnr-it:last-child {
    margin-right: 0;
  }
  .idx05 {
    padding: 60px 0 0;
  }
  .idx05 .block-treatment {
    padding-bottom: 55px;
  }
  .idx05 .block-treatment::before {
    width: 100%;
    max-height: calc(100% - 163px);
    height: calc(100% - 9vw);
    top: unset;
    bottom: 0;
    left: 0;
    background-image: url(../images/idx05_bg_sp.jpg);
  }
  .idx05 .wrap-title {
    display: table;
    margin: 0 auto;
    padding-bottom: 4.444444em;
  }
  .idx05 .wrap-title::before {
    height: 20em;
  }
  .idx05 .wrap-title::after {
    bottom: 2.6em;
  }
  .idx05 .wrap-title .h-en {
    font-size: min(75px, 18vw);
    text-align: center;
    margin-bottom: 0.06666667em;
  }
  .idx05 .wrap-title .h-en::before {
    margin-bottom: 0.05em;
  }
  .idx05 .wrap-title h3 {
    padding-left: 0;
    text-align: center;
    font-size: 28px;
  }
  .idx05 .treatment-img {
    width: calc(100% - 20px);
    margin-right: 0;
    margin-left: auto;
  }
  .idx05 .treatment-cont {
    padding: 0 20px;
  }
  .idx05 .treatment-cont h4 {
    font-size: min(24px, 6.5vw);
    text-align: center;
    margin-bottom: 15px;
    padding-bottom: 7px;
    padding-left: 0;
  }
  .idx05 .treatment-cont p {
    padding-left: 0;
  }
  .idx05 .treatment-cont .btn {
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 25px;
  }
  .idx06 {
    padding: 110px 0 60px;
  }
  .idx06 .wrap-h3 {
    margin-bottom: 25px;
  }
  .idx06 .box-title {
    padding-left: 0;
    padding-top: 60px;
    margin-bottom: 20px;
    margin-bottom: 15px;
    text-align: center;
  }
  .idx06 .box-title::before {
    top: 0;
    width: 47px;
    height: 47px;
    left: 0;
    right: 0;
    margin: auto;
  }
  .idx06 .box-title .en {
    font-size: 14px;
    margin-bottom: 0;
  }
  .idx06 .box-title h4 {
    font-size: 22px;
  }
  .idx06 .block-support {
    max-width: 650px;
    width: 100%;
    margin: 0 auto 45px;
  }
  .idx06 .support-img {
    width: calc(100% - 40px);
    margin: 0 auto 40px;
  }
  .idx06 .support-img::before {
    left: -10px;
    bottom: -10px;
  }
  .idx06 .support-cont .btn-group {
    margin-top: 25px;
  }
  .idx06 .support-cont .btn-group .btn {
    margin-left: auto;
    margin-right: auto;
  }
  .idx06 .b-grid {
    max-width: 650px;
    width: 100%;
    margin: 0 auto;
  }
  .idx06 .b-grid h4 {
    font-size: 20px;
    text-align: center;
    padding-left: 0;
    padding-top: 0;
  }
  .idx06 .b-grid .b-img {
    margin: 0 auto 25px;
  }
  .idx06 .b-grid .b-cont {
    max-width: 100%;
  }
  .idx06 .b-grid .b-cont > p {
    padding: 0;
  }
  .idx06 .b-grid .b-cont .btn {
    margin: 25px auto 0;
  }
  .idx06 .tab2 .btn {
    margin-top: 30px;
  }
  .idx06 .block-flow {
    margin-top: -35px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .idx06 .block-flow .flow-it {
    width: calc((100% - 2em) / 2);
    margin-right: 2em;
    margin-top: 2em;
    font-size: min(10px, 1.8vw);
  }
  .idx06 .block-flow .flow-it:nth-child(2n+2) {
    margin-right: 0;
  }
  .idx06 .block-flow .flow-it:nth-child(2n+2)::after {
    display: none;
  }
  .idx06 .block-flow .flow-txt {
    padding: 0;
  }
  .idx07 {
    padding: 75px 20px 80px;
  }
  .idx07:before {
    font-size: 3px;
    background-image: url(../images/idx07_bg_sp.jpg);
  }
  .idx07 .b-grid {
    max-width: 650px;
    width: 100%;
    margin: 0 auto;
  }
  .idx07 .importance-img {
    margin: 25px auto 20px;
  }
  .idx07 .importance-img .txt-en {
    font-size: min(90px, 12vw);
  }
  .idx07 .btn-group {
    margin-top: 25px;
  }
  .idx07 .btn-group .btn {
    margin: 6px;
    width: 100%;
  }
  .idx08 {
    padding: 55px 0;
  }
  .idx08::before {
    height: calc(100% + 30px);
    background-image: url(../images/idx08_bg_sp.jpg);
  }
  .idx08 .box-title {
    text-align: center;
  }
  .idx08 .box-title .h-en {
    margin: 0 auto 5px;
    font-size: min(18px, 5vw);
    letter-spacing: 0.05em;
    display: table;
  }
  .idx08 .box-title .h-en::before {
    left: -0.8em;
  }
  .idx08 .box-title h3 {
    font-size: 24px;
  }
  .idx08 .b-grid {
    max-width: 650px;
    width: 100%;
    margin: 0 auto;
  }
  .idx08 .block-img {
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 20px;
    position: relative;
    padding-right: 10px;
    padding-bottom: 10px;
    max-width: calc(100% - 40px);
    width: auto;
    display: table;
  }
  .idx08 .block-img::before {
    content: "";
    position: absolute;
    width: calc(100% - 10px);
    height: calc(100% - 10px);
    bottom: 0;
    right: 0;
    border-radius: 12px;
    background-color: rgba(255, 255, 255, 0.3);
    z-index: -1;
  }
  .idx08 .block-img figure {
    width: 100%;
    margin: 0;
    overflow: hidden;
  }
  .idx08 .block-img figure img {
    border-radius: 0;
  }
  .idx08 .block-img figure::before {
    display: none;
  }
  .idx08 .block-img .img01 {
    border-radius: 12px;
  }
  .idx08 .block-img .img01, .idx08 .block-img .img02 {
    margin-top: 0;
  }
  .idx08 .block-cont .btn {
    margin: 25px auto 0;
  }
  .idx09 {
    padding: 55px 0 0;
    margin-bottom: 55px;
    background-image: url(../images/idx09_bg_sp.jpg);
    background-position: top right;
  }
  .idx09 .slide-nav {
    max-width: 100%;
    margin-bottom: 35px;
    font-size: min(10px, 1.5vw);
  }
  .idx09 .slide-nav .slick-track {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .idx09 .slide-nav .slick-track {
    -webkit-transform: unset !important;
            transform: unset !important;
  }
  .idx09 .slide-nav .f-tt {
    width: calc(50% - 1em);
    margin: 0.5em;
    display: block;
    text-align: center;
    height: auto;
  }
  .idx09 .slide-nav .f-tt_point {
    width: auto;
    padding-right: 0;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 0.3em;
    line-height: 1;
    display: table;
    font-size: 5em;
  }
  .idx09 .slide-nav .f-tt_point::after {
    height: 1px;
    width: 100%;
    top: unset;
    bottom: 0;
  }
  .idx09 .slide-nav .f-tt_txt {
    width: 100%;
    font-size: 2em;
  }
  .idx09 .slide-thumb .f-content_img {
    width: calc(100% + 20px);
    margin-left: -20px;
    max-height: 400px;
    height: 60vw;
  }
  .idx09 .slide-thumb .f-content_img img {
    border-top-right-radius: 30px;
  }
  .idx09 .slide-thumb .f-content_point {
    font-size: 85px;
  }
  .idx09 .slide-thumb .f-content_ct {
    padding: 35px 5%;
    margin-top: -8vw;
    margin-right: auto;
    width: calc(100% - 40px);
  }
  .idx09 .slide-thumb .f-content_ct > p:not(.f-content_point) {
    max-width: 100%;
  }
  .idx09 .slide-thumb .f-content h4 {
    font-size: min(22px, 5.5vw);
    letter-spacing: 0.05em;
  }
  .idx09 .btn01 a {
    padding: 0 10px 8px 29px;
  }
  .idx09 .btn01 a::before {
    left: 10px;
  }
  .idx09 .f-btn {
    padding-right: 0;
    padding-top: 0;
    margin-bottom: 15px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .idx09 .slider-pagination {
    font-size: 7px;
    margin-right: 0;
  }
  .idx09 .f-arrow {
    width: 100%;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 20px;
  }
  .idx09 .f-arrow .slide-arrow {
    width: 40px;
    height: 40px;
    margin: 0 5px;
  }
  .idx09 .f-arrow .slide-arrow.next-arrow {
    margin-bottom: 0;
    background-position: calc(50% + 0px) calc(50% + 1px);
    background-image: url(../images/ic_next_sp.svg);
  }
  .idx09 .f-arrow .slide-arrow.prev-arrow {
    background-position: calc(50% + 1px) calc(50% + 0px);
    background-image: url(../images/ic_prev_sp.svg);
  }
  .idx09 .btn01 {
    margin-top: 20px;
  }
  .idx10 {
    padding: 55px 0;
    background-image: url(../images/idx10_bg_sp.jpg);
  }
  .idx10 .box-title {
    margin-bottom: 20px;
    display: block;
    text-align: center;
    position: relative;
    z-index: 1;
  }
  .idx10 .box-title .h-en {
    font-size: 18px;
    padding-right: 0;
    padding-bottom: 10px;
    display: table;
    margin-left: auto;
    margin-right: auto;
  }
  .idx10 .box-title .h-en::after {
    width: 50px;
    right: 0;
    left: 0;
    top: unset;
    margin: auto;
  }
  .idx10 .box-title h3 {
    font-size: 28px;
  }
  .idx10 .b-grid {
    padding-left: 0;
  }
  .idx10 .greeting-img {
    max-width: 470px;
    padding-left: 1.5em;
    padding-top: 0;
    margin: 0 auto 30px;
    font-size: min(10px, 2vw);
  }
  .idx10 .greeting-img figure {
    max-width: 27.6em;
  }
  .idx10 .greeting-img figure::before {
    left: -4.1em;
  }
  .idx10 .greeting-cont {
    position: relative;
    z-index: 1;
  }
  .idx10 .box-name {
    right: 0;
    top: 16.1em;
  }
  .idx10 .box-name::before {
    font-size: 0.8em;
  }
  .idx10 .btn-group {
    margin-top: 25px;
  }
  .idx10 .btn-group .btn {
    width: 100%;
    margin: 10px;
  }
  .idx11 {
    padding: 55px 0;
    background-image: url(../images/idx11_bg_sp.jpg);
    background-position: top center;
    background-size: 100% auto;
    background-color: #ae8d75;
  }
  .idx11 .inner_big {
    max-width: 650px;
  }
  .idx11 .box-title {
    padding-left: 0;
    padding-top: 78px;
    text-align: center;
    margin-bottom: 15px;
  }
  .idx11 .box-title::before {
    left: 0;
    right: 0;
    margin: auto;
    width: 80px;
    height: 80px;
  }
  .idx11 .box-title .h-en {
    font-size: 18px;
    padding-left: 0;
  }
  .idx11 .box-title h3 {
    font-size: 28px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 12px;
  }
  .idx11 .box-info {
    padding-left: 0;
    margin-bottom: 15px;
  }
  .idx11 .ft_tracffic{
    padding-left: 0;
    margin-bottom: 25px;
  }
  .idx11 .box-info a {
    font-size: 24px;
  }
  .idx11 .box-info dl {
    margin-bottom: 12px;
  }
  .idx11 .box-info dl.mb-a {
    margin-bottom: 12px;
  }
  .idx11 .box-info dt {
    width: 90px;
  }
  .idx11 .box-info dd {
    width: calc(100% - 90px);
  }
  .idx11 .btn-group {
    margin-top: 25px;
  }
  .idx11 .btn-group .btn {
    width: 100%;
    margin: 6px;
  }
  .idx_map {
    height: 299px;
    margin-top: 30px;
  }
  .block-instagram {
    padding: 45px 0 15px;
  }
  .block-instagram .box-title {
    padding-left: 0;
    padding-top: 38px;
    text-align: center;
  }
  .block-instagram .box-title::before {
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 30px;
    height: 30px;
  }
  .block-instagram .box-title h3 {
    font-size: 16px;
    padding-left: 0;
  }
  .block-instagram .box-title .en {
    font-size: 30px;
    margin-bottom: 0;
  }
  .block-instagram .btn01 {
    margin-right: auto;
  }
  .block-instagram .l-insta {
    margin-top: 35px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .block-instagram .l-insta .it {
    width: calc(50% - 10px);
    margin: 5px;
    max-width: 312px;
  }
}
@media only screen and (max-width: 768px) and (min-width: 640px) {
  .idx02 .block-problem {
    font-size: min(8px, 1vw);
    margin-top: 15px;
    margin-bottom: 15px;
  }
  .idx02 .block-problem .problem-item {
    width: calc(25% - 2em);
    margin: 1em;
  }
  .idx02 .block-problem .problem-item.it03::before, .idx02 .block-problem .problem-item.it04::before, .idx02 .block-problem .problem-item.it06::before {
    -webkit-transform: scaleX(-1);
            transform: scaleX(-1);
  }
  .idx02 .block-problem .problem-item.it01 {
    top: 7.7em;
    left: 1.5em;
  }
  .idx02 .block-problem .problem-item.it02 {
    left: 0.2em;
  }
  .idx02 .block-problem .problem-item.it03 {
    left: -0.5em;
  }
  .idx02 .block-problem .problem-item.it04 {
    top: 7.7em;
    right: 1.5em;
  }
  .idx02 .block-problem .problem-item.it05 {
    top: -0.3em;
    left: -2.3em;
  }
  .idx02 .block-problem .problem-item.it06 {
    top: -1.7em;
    right: -0.4em;
  }
}
@media only screen and (max-width: 639px) {
  .idx02 .block-problem {
    margin: 20px auto 25px;
    max-width: 500px;
    font-size: min(8px, 2vw);
  }
  .idx02 .block-problem .problem-item {
    width: calc(50% - 1em);
    margin: 0.5em;
  }
  .idx02 .block-problem .problem-item:nth-child(2n+2)::before {
    -webkit-transform: scaleX(-1);
            transform: scaleX(-1);
  }
}
@media only screen and (max-width: 450px) {
  .idx02 .wrap-h3::before {
    right: -6em;
  }
  .idx02 .wrap-h3 .h-en {
    padding-right: 0;
  }
  .idx03::before {
    background-position: top 24% center, center;
    background-size: 115% auto, cover;
  }
  .idx05 .block-treatment::before {
    max-height: calc(100% - 38.5vw);
    height: calc(100% - 7vw);
  }
  .idx09 .slide-nav {
    font-size: min(10px, 1.55vw);
  }
  .idx09 .slide-nav .slick-track {
    margin: 0 -0.5em;
  }
  .idx09 .slide-nav .f-tt {
    padding: 2.2em 1em 2.4em;
  }
  .idx09 .slide-nav .f-tt_txt {
    font-size: 2.3em;
    letter-spacing: 0.01em;
  }
  .idx09 .slide-nav .f-tt_txt .br {
    display: none;
  }
}
@media only screen and (max-width: 350px) {
  .idx08 .btn .sp_450 {
    display: none;
  }
}