@media only screen and (max-width: 768px) {
  .home_page .key {
    --height: calc(100vh - 60px);
    --max-height: 156vw;
    --min-height: 320px;
  }
  .home_page .key .key_text .item {
    padding: 10px;
  }
}
@media only screen and (max-width: 640px) {
  .home_page .key {
    font-size: 1.4vmin;
  }
}
@media only screen and (max-width: 768px) and (orientation: landscape) {
  .home_page .key {
    --size-grow-right: 10em;
    --size-w-pic: 50%;
    --height: calc(100vh);
    font-size: 1vmin;
  }
  .home_page .key .key_text {
    top: 1.6em;
    margin-right: calc(var(--size-grow-right) * -1);
    width: calc(100% - var(--size-w-pic) + var(--size-grow-right));
  }
  .home_page .key .key_pic {
    position: relative;
    top: -1.5em;
    left: -2.8em;
    width: var(--size-w-pic);
    max-width: 79.6em;
  }
  .home_page .key .key_decor .item01 {
    font-size: 1.3em;
  }
}
@media only screen and (max-width: 768px) and (orientation: portrait) {
  .home_page .key {
    font-size: min(1.15vw, 6px);
  }
  .home_page .key .key_container {
    padding-top: calc(var(--wrapper) + 5em);
  }
  .home_page .key .key_text {
    padding-left: 0;
    width: 100%;
  }
  .home_page .key .key_en {
    left: 0;
    top: 1em;
    width: 100%;
    font-size: 11em;
    text-align: center;
  }
  .home_page .key h2,
  .home_page .key p {
    text-align: center;
  }
  .home_page .key .key_pic {
    max-width: 79em;
  }
  .home_page .key .key_decor {
    font-size: 0.8em;
  }
  .home_page .key .key_decor .item01 {
    width: 145em;
    height: 47em;
    background-image: url(../images/key_decor01_sp.png);
  }
}
@media only screen and (max-width: 520px) {
  .home_page .key .key_en {
    font-size: 8.5em;
  }
  .home_page .key .key_decor .item02 {
    font-size: 0.85em;
  }
}
@media only screen and (max-width: 430px) {
  .home_page .key {
    --max-height: 160vw;
    --height: 100vh;
  }
  .home_page .key .key_container {
    padding-top: var(--wrapper);
  }
  .home_page .key .ct_area p {
    font-size: 3.5em;
  }
  .home_page .key .key_decor .item01 {
    top: 0;
    width: 121vw;
    height: 43em;
    font-size: min(1.1em, 4px);
    background-position: right bottom;
  }
}
@media only screen and (max-width: 768px) {
  .home_page h3 {
    margin-bottom: 30px;
    font-size: calc(var(--ttl_size));
  }
  .home_page h3 .en {
    font-size: 20px;
  }
}
@media only screen and (max-width: 768px) {
  .idx01 {
    padding: 80px 0 60px;
  }
  .idx01 .card_gr {
    font-size: min(1.3vw, 8px);
  }
  .idx01 .card_gr .card {
    width: calc(50% - 2 * var(--size-mg));
    max-width: 314px;
  }
}
@media only screen and (max-width: 430px) {
  .idx01 .card_gr {
    font-size: min(1.6vw, 6px);
  }
  .idx01 .card_gr .card .label_gr {
    font-size: 1.5em;
  }
  .idx01 .card_gr .card .card_pic {
    width: 100%;
  }
  .idx01 .idx01 .card_gr .card .ct_area p {
    font-size: 12px;
  }
}
@media only screen and (max-width: 390px) {
  .idx01 .card_gr .card .card_pic .bg_decor {
    font-size: 0.9em;
  }
  .idx01 .card_gr .card:nth-child(2n+1) .card_pic .bg_decor {
    left: -2em;
  }
  .idx01 .card_gr .card:nth-child(2n) .card_pic .bg_decor {
    left: auto;
    right: -2em;
  }
}
@media only screen and (max-width: 768px) {
  .idx02 {
    padding: 60px 0 60px;
  }
  .idx02 .idx_box {
    justify-content: center;
  }
  .idx02 .idx_box .box_ct picture {
    max-width: 500px;
    margin: 0 auto 30px;
  }
  .idx02 .idx_box .box_ct .ct_area {
    max-width: 600px;
  }
}
@media only screen and (max-width: 350px) {
  .idx02 h3 br {
    display: none;
  }
}
@media only screen and (max-width: 768px) {
  .idx03 {
    padding-bottom: 60px;
  }
  .idx03 .box_title {
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    margin-bottom: 40px;
  }
  .idx03 .box_title h3 {
    text-align: left;
    background-position: left top 0.7em;
  }
  .idx03 .box_title .box_title_content {
    margin-left: 0;
    min-width: auto;
    max-width: 20em;
    width: 100%;
    font-size: 18px;
    text-align: center;
  }
  .idx03 .card_gr {
    font-size: min(1.4vw, 8px);
  }
  .idx03 .card_gr .card {
    width: calc(50% - 2 * var(--size-mg));
    max-width: 314px;
  }
  .idx03 .card_gr .card .ct_area {
    height: 0;
  }
}
@media only screen and (max-width: 375px) {
  .idx03 .box_title .box_title_content {
    font-size: 16px;
  }
}
@media only screen and (max-width: 768px) {
  .idx04 {
    padding: 60px 0 60px;
    background-image: url(../images/idx04_bg_sp.jpg);
  }
  .idx04 .idx_box {
    justify-content: center;
    padding: 50px 30px;
  }
  .idx04 .idx_box h4 {
    margin-bottom: 25px;
    font-size: 20px;
    text-align: center;
  }
  .idx04 .idx_box picture {
    margin-bottom: 25px;
  }
  .idx04 .idx_box .btn-group {
    margin-top: 30px;
    width: 100%;
  }
  .idx04 .idx_box .btn-group .btn {
    margin-left: auto;
    margin-right: auto;
  }
  .idx04 .idx_box .box_ct {
    display: flex;
    flex-direction: column;
    align-items: center;
    max-width: 600px;
  }
  .idx04 .idx_box.box_st02 .box_ct {
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
  }
  .idx04 .idx_box.box_st02 .btn-group {
    position: relative;
  }
}
@media only screen and (max-width: 430px) {
  .idx04 .idx_box {
    padding: 40px 15px;
  }
}
@media only screen and (max-width: 768px) {
  .idx05 {
    padding: 60px 0 20px;
    background-image: url(../images/idx05_bg_sp.jpg);
    background-position: bottom center;
  }
  .idx05 h3 .en {
    font-size: 0.6875em;
  }
  .idx05 .idx_box {
    flex-direction: column;
    align-items: center;
    font-size: min(1.2vw, 8px);
  }
  .idx05 .idx_box .ct_area {
    max-width: 500px;
  }
  .idx05 .idx_box .box_ct {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
  }
  .idx05 .idx_box .box_ct::after {
    width: calc(100vw + 20px);
    left: -30px;
    mask-size: cover;
  }
  .idx05 .idx_box .box_ct h4 {
    margin-bottom: 20px;
    text-align: center;
  }
  .idx05 .idx_box .box_ct .btn-group {
    margin-top: 35px;
    width: 100%;
    font-size: 8.75px;
  }
  .idx05 .idx_box .box_ct .btn-group .btn {
    margin-left: auto;
    margin-right: auto;
  }
  .idx05 .idx_box:not(:first-of-type) {
    margin-top: 40px;
  }
  .idx05 .idx_box:nth-of-type(2n + 1) .box_ct,
  .idx05 .idx_box:nth-of-type(2n) .box_ct {
    padding-left: 5em;
    padding-right: 5em;
    margin-top: -18em;
  }
  .idx05 .idx_box .box_logo {
    margin-left: auto;
    margin-right: auto;
    max-width: 275px;
  }
}
@media only screen and (max-width: 430px) {
  .idx05 .idx_box:nth-of-type(2n + 1) .box_ct,
  .idx05 .idx_box:nth-of-type(2n) .box_ct {
    padding-left: 0;
    padding-right: 0;
  }
  .idx05 .idx_box:nth-of-type(2n) .box_ct {
    padding-bottom: 40px;
  }
}
@media only screen and (max-width: 768px) {
  .idx06 {
    padding: 60px 0 60px;
  }
  .idx06 .card_gr {
    flex-wrap: wrap;
    font-size: 8px;
  }
  .idx06 .card_gr .card {
    padding: 40px 30px;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
    max-width: 560px;
  }
  .idx06 .card_gr .card:not(:first-of-type) {
    margin-top: calc(4.1em + 40px);
  }
}
@media only screen and (max-width: 768px) {
  .idx07 {
    padding-top: 60px;
    padding-bottom: 20px;
  }
  .idx07 .idx_box_doctor .doctor_name {
    font-size: 1.1em;
  }
  .idx07 .idx07_catch .box_ct {
    padding-left: 20px;
    padding-right: 20px;
    padding-bottom: 40px;
  }
}
@media only screen and (max-width: 520px) {
  .idx07 .box_ct::before {
    background-size: cover;
  }
}
@media only screen and (max-width: 430px) {
  .idx07 .idx07_catch {
    --size-w-doctor01: calc(50% - 7px);
    --size-w-doctor02: calc(50% - 7px);
  }
  .idx07 .idx07_catch .idx_box_doctor {
    font-size: 0.78vw;
  }
  .idx07 .idx07_catch .doctor02 {
    max-width: 55.7em;
  }
  .idx07 .idx_box_doctor .doctor_name {
    font-size: 2.2em;
  }
  .idx07 .idx_box_doctor .doctor_name .name .name_en {
    font-size: 1.4em;
  }
  .idx07 .idx_box_doctor.doctor01 .doctor_name {
    top: -6em;
    left: 1em;
  }
  .idx07 .idx_box_doctor.doctor02 .doctor_name {
    top: -6em;
    right: 0em;
  }
}
@media only screen and (max-width: 375px) {
  .idx07 .box_ct p br {
    display: none;
  }
  .idx07 .idx07_catch .box_ct {
    padding-left: 0;
    padding-right: 0;
  }
}
@media only screen and (max-width: 768px) {
  .idx08 {
    padding: 60px 0 20px;
  }
  .idx08 .feature_gr {
    justify-content: center;
  }
  .idx08 .feature_box {
    margin-bottom: 20px;
  }
  .idx08 .feature_box:last-child {
    margin-bottom: 0;
  }
  .idx08 .feature_box .box_ct {
    padding: 40px 30px;
    width: calc(100% - 20px);
  }
}
@media only screen and (max-width: 430px) {
  .idx08 {
    padding-bottom: 30px;
  }
  .idx08 .feature_box {
    --size-padding-left-box-pic: 15px;
  }
  .idx08 .feature_box .box_ct {
    margin-top: -60px;
    padding: 30px 10px;
  }
}
@media only screen and (max-width: 768px) {
  .idx09 {
    padding: 60px 0 60px;
    background-image: url(../images/idx09_bg_sp.jpg);
  }
  .idx09 .infor_box {
    margin-bottom: 25px;
  }
  .idx09 .idx_box {
    justify-content: center;
  }
  .idx09 .idx_box .box_l,
  .idx09 .idx_box .box_r {
    width: 100%;
    max-width: 565px;
  }
  .idx09 .idx_box .box_l {
    margin-bottom: 25px;
  }
}
@media only screen and (max-width: 768px) {
  .idx_news {
    padding: 60px 0;
  }
  .idx_news .content {
    position: relative;
    padding-bottom: 90px;
  }
  .idx_news .content > div {
    width: 100%;
  }
  .idx_news .content li a {
    --w: 7.5em;
    padding: 25px 30px;
  }
  .idx_news .content .btn-group {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
  }
  .idx_news .content .btn-group .btn {
    margin-left: auto;
    margin-right: auto;
  }
}

/*# sourceMappingURL=index_sp.css.map */
