@media only screen and (max-width: 768px) {
  .home_page .key {
    --height: calc(100vh - 60px);
    --max-height: 138vw;
    --min-height: 320px;
    font-size: 6px;
    background-position: top center;
  }
  .home_page .key .key_text .item {
    padding: 10px;
  }
  .home_page .key .key_text h2, .home_page .key .key_text p {
    font-weight: 600;
  }
}
@media only screen and (max-width: 640px) {
  .home_page .key {
    font-size: 1vmin;
  }
}
@media only screen and (max-width: 768px) and (orientation: landscape) {
  .home_page .key {
    font-size: 1.4vmin;
  }
  .home_page .key h2 {
    font-size: 5em;
    margin-bottom: 0.4em;
  }
  .home_page .key .inner {
    padding-left: 30px;
    padding-right: 30px;
  }
  .home_page .key .catch {
    max-width: 70em;
  }
}
@media only screen and (max-width: 768px) and (orientation: portrait) {
  .home_page .key {
    --height: calc(100vh - 120px);
    background-image: url(../images/idx_key_bg_sp.jpg);
  }
  .home_page .key h2,
  .home_page .key p {
    text-align: center;
  }
  .home_page .key h2 {
    font-size: 6em;
  }
  .home_page .key .key_text .item {
    align-items: flex-end;
    padding-bottom: 36em;
  }
  .home_page .key .inner {
    padding: 0;
  }
  .home_page .key .circle_gr {
    top: auto;
    left: 0;
    right: 0;
    margin: auto;
    font-size: 1.2em;
  }
  .home_page .key .circle_gr .circle .ttl {
    font-size: 3.2em;
  }
  .home_page .key .circle_gr {
    --size-mg:3px;
    bottom: calc(7em + 10px);
    width: 100%;
    justify-content: center;
    flex-direction: row;
    height: auto;
  }
  .home_page .key .circle_gr .c1 {
    margin-bottom: var(--size-mg);
  }
  .home_page .key .circle_gr .cicle_gr_bot {
    width: auto;
  }
  .home_page .key .circle_gr .circle_shadow,
  .home_page .key .circle_gr .circle_bg {
    display: flex;
    justify-content: center;
  }
  .home_page .key .circle_gr .circle_shadow .item,
  .home_page .key .circle_gr .circle_bg .item {
    position: unset;
    margin: var(--size-mg);
  }
  .home_page .key .circle_gr .circle_shadow .item::after,
  .home_page .key .circle_gr .circle_bg .item::after {
    display: none;
  }
}
@media only screen and (max-width: 480px) {
  .home_page .key {
    font-size: 1.27vw;
  }
  .home_page .key h2 {
    font-size: 5.5em;
  }
  .home_page .key .key_text .item {
    padding-bottom: 35em;
  }
  .home_page .key .circle_gr {
    bottom: calc(5.5em + 10px);
    font-size: 1.2em;
  }
}
@media only screen and (max-width: 430px) {
  .home_page .key h2 {
    line-height: 1.3;
    margin-bottom: 0.3em;
  }
  .home_page .key .catch p {
    font-size: 3.2em;
  }
}
@media only screen and (max-width: 768px) {
  .home_page h3 {
    margin-bottom: 30px;
    font-size: var(--ttl_size);
    text-align: center;
  }
  .home_page h3 .en {
    font-size: 3em;
  }
}
@media only screen and (max-width: 768px) {
  .idx01 {
    position: relative;
    z-index: 1;
    padding: 60px 0px 125px;
  }
  .idx01 .content {
    justify-content: center;
  }
  .idx01 .content li {
    font-size: 1em;
  }
  .idx01 .content li a {
    --w: 50px;
    --size-padding-top: 20px;
    --size-padding-bottom: 20px;
  }
  .idx01 .content .content_left {
    width: 100%;
  }
  .idx01 .content .box {
    width: 100%;
  }
  .idx01 .btn-news {
    position: absolute;
    bottom: 60px;
    left: 0;
    display: flex;
    justify-content: center;
    width: 100%;
    margin: 0 auto;
  }
}
@media only screen and (max-width: 430px) {
  .idx01 .content li a .title {
    padding-left: 25px;
  }
}
@media only screen and (max-width: 768px) {
  .idx02 {
    padding: 0 20px 60px;
  }
  .idx02 .inner_max {
    padding: 0;
  }
  .idx02 .idx_logo {
    margin-bottom: 30px;
  }
  .idx02 .idx_box {
    border-radius: 30px;
  }
  .idx02 .idx_box .idx_box_cotent {
    padding: 30px 15px;
  }
  .idx02 .idx_box .btn-group {
    margin-top: 35px;
  }
  .idx02 .idx_box_bottom {
    --size-pd-lr: 40px;
    --size-pd-tb: 40px;
    padding: var(--size-pd-tb) var(--size-pd-lr) 0;
    margin: 40px auto 0;
    max-width: 550px;
  }
  .idx02 .idx_box_bottom .idx_calendar {
    display: flex;
    justify-content: center;
    width: 100%;
    height: 450px;
    padding-bottom: var(--size-pd-tb);
  }
  .idx02 .idx_box_bottom .idx_calendar picture {
    display: table;
  }
  .idx02 .idx_box_bottom .idx_map {
    margin: 0 calc(var(--size-pd-lr) * -1);
    width: calc(100% + 2 * var(--size-pd-lr));
  }
}
@media only screen and (max-width: 430px) {
  .idx02 .idx_box_bottom {
    --size-pd-tb: 30px;
    --size-pd-lr: 20px;
  }
}
@media only screen and (max-width: 768px) {
  .idx03 .idx_box .box_pic {
    --size-height-pic-top: 400px;
    width: 100%;
    overflow: hidden;
  }
  .idx03 .idx_box .box_pic picture {
    position: relative;
    height: var(--size-height-pic-top);
  }
  .idx03 .idx_box .box_pic picture img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .idx03 .idx_box .box_ct {
    padding: 40px 20px 40px;
    margin-top: -120px;
    margin-left: auto;
    margin-right: auto;
    width: calc(100% - 40px);
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  }
  .idx03 .idx_box .box_ct .pic_gr {
    margin-bottom: 30px;
  }
  .idx03 .idx_box .box_ct .btn-group {
    margin-top: 30px;
    width: 100%;
  }
  .idx03 .idx_box .box_ct .box_ct_inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-left: auto;
    margin-right: auto;
    max-width: 440px;
  }
}
@media only screen and (min-width: 481px) and (max-width: 768px) {
  .idx03 .idx_box .box_ct .btn-group {
    font-size: 8.5px;
    justify-content: space-between;
    flex-wrap: nowrap;
  }
}
@media only screen and (max-width: 480px) {
  .idx03 .idx_box .box_ct .btn-group {
    --size-mg: 7px;
    justify-content: center;
    margin-bottom: calc(var(--size-mg) * -1);
  }
  .idx03 .idx_box .box_ct .btn-group .btn {
    margin: 7px;
  }
}
@media only screen and (max-width: 430px) {
  .idx03 .idx_box .box_pic {
    --size-height-pic-top: 70vw;
  }
  .idx03 .idx_box .box_ct {
    margin-top: -20vw;
    width: calc(100% - 20px);
  }
}
@media only screen and (max-width: 768px) {
  .idx04 {
    padding: 60px 0;
  }
  .idx04 h4.style01 {
    display: table;
    padding-left: 0;
    padding-top: 25px;
    margin: 0 auto 20px;
    font-size: 20px;
    text-align: center;
  }
  .idx04 h4.style01::before {
    right: 0;
    top: 0;
    margin: 0 auto;
  }
  .idx04 .idx_box::before {
    left: -20px;
    top: calc(100px + 40vw);
    width: calc(100% + 40px);
    height: 100%;
    border-radius: 0;
  }
  .idx04 .box_ct {
    width: 100%;
  }
  .idx04 .box_ct > picture {
    margin-bottom: 30px;
    overflow: hidden;
  }
  .idx04 .box_ct .ct_area {
    margin-left: auto;
    margin-right: auto;
    max-width: 510px;
  }
  .idx04 .box_ct .btn-group {
    display: table;
    margin: 30px auto 0;
  }
  .idx04 .idx04_slider {
    --size-mg-slide: 5px;
    margin-top: 30px;
    width: 100%;
  }
  .idx04 .idx04_slider:not(.slick-slider) {
    --size-width-slide-img: calc(50% - var(--size-mg-slide) * 2);
  }
  .idx04 .idx04_slider.slick-slider {
    --size-width-slide-img: calc((100vw - 40px - var(--size-mg-slide) * 2) / 2);
  }
}
@media only screen and (max-width: 768px) {
  .idx05 {
    padding: 60px 0;
  }
  .idx05 .idx_box {
    justify-content: center;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
  }
  .idx05 .idx_box h4 {
    margin-bottom: 25px;
    text-align: center;
    font-size: 24px;
  }
  .idx05 .idx_box .btn-group {
    display: table;
    margin: 30px auto 0;
  }
  .idx05 .idx_box .left {
    width: 100%;
  }
  .idx05 .idx_box .left picture {
    margin-bottom: 30px;
    overflow: hidden;
  }
  .idx05 .idx_box .right::after {
    top: -10px;
    right: calc((100vw - 450px) / -2);
    font-size: min(1.5vw, 6px);
  }
  .idx05 .idx_box .right .ct_area {
    max-width: 444px;
    margin-left: auto;
    margin-right: auto;
  }
  .idx05 .idx_box .right .ct_area p br {
    display: none;
  }
  .idx05 .card_gr {
    padding-top: 40px;
    padding-bottom: 40px;
    font-size: min(1.7vw, 9px);
  }
  .idx05 .TabContainer {
    margin-top: 40px;
  }
}
@media only screen and (max-width: 430px) {
  .idx05 .idx_box .left picture {
    position: relative;
    min-height: 200px;
  }
  .idx05 .idx_box .left picture img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .idx05 .card_gr .card {
    padding-left: 2em;
    width: calc(50% - 2 * var(--size-mg));
  }
  .idx05 .card_gr .card .card_ttl {
    font-size: 2.2em;
  }
  .idx05 .idx_box .right::after {
    right: 0;
  }
}
@media only screen and (max-width: 768px) {
  .idx06 {
    padding: 0 0 60px;
  }
  .idx06 .btn-news {
    margin: 35px auto 0;
  }
  .idx06 .idx_box_gr {
    --size-w-box: calc((100vw - 40px - var(--size-mg) * 2) / 2);
    width: 100%;
  }
}
@media only screen and (max-width: 480px) {
  .idx06 .idx_box_gr {
    --size-w-box: calc(100vw - 100px);
  }
  .idx06 .idx_box_gr .idx_box .pic_gr .pic {
    font-size: 12px;
    width: calc(50% - 1.5px);
    min-height: 6em;
  }
  .idx06 .idx_box_gr .idx_box .pic_gr .pic::before {
    left: 1em;
  }
  .idx06 .idx_box_gr.slick-initialized .idx_box {
    max-width: 350px;
  }
}
@media only screen and (max-width: 430px) {
  .idx06 .idx_box_gr .idx_box {
    padding-left: 10px;
    padding-right: 10px;
  }
}
@media only screen and (max-width: 768px) {
  .idx07 {
    padding: 60px 0;
    background-image: url(../images/idx07_bg_sp.jpg);
  }
  .idx07 .circle_gr {
    font-size: 0.8vw;
  }
  .idx07 .circle_gr .circle .ct_area p {
    font-size: 2.6em;
  }
}
@media only screen and (max-width: 430px) {
  .idx07 .circle_gr {
    font-size: 1.2vw;
  }
  .idx07 .circle_gr .circle {
    padding-top: 0.5em;
    padding-left: 4em;
    padding-right: 4em;
  }
  .idx07 .circle_gr .circle .btn-group {
    font-size: 1.3em;
    margin-top: 0.5em;
  }
  .idx07 .circle_gr .circle .btn-group .btn a {
    padding-left: 2em;
    padding-top: 0;
    padding-bottom: 0;
    min-height: 2em;
  }
  .idx07 .circle_gr .circle .btn-group .btn a::before {
    width: 1.7em;
    height: 1.7em;
  }
  .idx07 .circle_gr .circle:nth-of-type(3) {
    margin-top: calc(var(--size-mg) * 3);
  }
  .idx07 .circle_gr .circle .circle_ttl {
    font-size: 3em;
    margin-bottom: 0.4em;
  }
  .idx07 .circle_gr .circle .ct_area p {
    font-size: 3em;
    line-height: 1.6;
  }
  .idx07 .circle_gr .circle .ct_area p br {
    display: none;
  }
}
@media only screen and (max-width: 768px) {
  .idx08 {
    padding: 60px 0 60px;
  }
  .idx08 .idx_box {
    max-width: 550px;
    margin-left: auto;
    margin-right: auto;
  }
  .idx08 .idx_box h4 {
    margin-bottom: 25px;
    text-align: center;
  }
  .idx08 .idx_box .box_pic {
    margin-bottom: 30px;
    overflow: hidden;
  }
  .idx08 .idx_box .card_gr {
    font-size: min(1.5vw, 8.5px);
  }
  .idx08 .idx_box .card_gr .card {
    padding-right: 3em;
    padding-left: 3em;
    width: calc(50% - var(--size-mg) * 2);
  }
  .idx08 .idx_box .card_gr .card::after {
    width: 9.8em;
  }
  .idx08 .idx_box .card_gr .card .card_ttl {
    font-size: 2.5em;
  }
  .idx08 .banner_gr {
    font-size: min(1.2vw, 8.5px);
  }
}
@media only screen and (min-width: 431px) and (max-width: 768px) {
  .idx08 .banner_gr .banner {
    min-height: 18em;
  }
}
@media only screen and (max-width: 430px) {
  .idx08 .banner_gr {
    font-size: 2vw;
  }
  .idx08 .banner_gr .banner {
    min-height: 22em;
  }
  .idx08 .idx_box .card_gr .card {
    min-height: 19em;
  }
  .idx08 .idx_box .card_gr .card .card_ttl {
    font-size: 3em;
  }
}
@media only screen and (max-width: 768px) {
  .idx09 {
    padding: 60px 0 100px;
    background-image: url(../images/idx09_bg_sp.jpg);
  }
  .idx09::before {
    content: "";
    display: block;
    position: absolute;
    transition: all 0.3s;
    z-index: -1;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: url(../images/idx09_fillter_gradient.png) no-repeat center/cover;
  }
  .idx09::after {
    content: "";
    display: block;
    position: absolute;
    transition: all 0.3s;
    z-index: -2;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: #000;
    opacity: 0.2;
  }
  .idx09 h3 {
    width: 100%;
    margin-bottom: 35px;
  }
  .idx09 .pic_sp {
    margin: 0 auto 35px;
    max-width: 500px;
    border-radius: 20px;
    overflow: hidden;
  }
  .idx09 .btn-group {
    margin-top: 40px;
    width: 100%;
  }
  .idx09 .btn-group .btn {
    margin-left: auto;
    margin-right: auto;
  }
  .idx09 .idx_box {
    justify-content: center;
  }
  .idx09 .circle_gr {
    --size-space-top-circle-sm: 17em;
    --size-space-lr-circle-sm: 20em;
    width: 90em;
    height: 73em;
    font-size: min(1vw, 7px);
  }
  .idx09 .circle_gr .circle_big {
    right: 0;
    margin: 0 auto;
  }
  .idx09 .circle_gr .circle_nav .c1 {
    left: 0;
    top: var(--size-space-top-circle-sm);
  }
  .idx09 .circle_gr .circle_nav .c2 {
    left: var(--size-space-lr-circle-sm);
    top: 0;
  }
  .idx09 .circle_gr .circle_nav .c3 {
    right: var(--size-space-lr-circle-sm);
    top: 0;
  }
  .idx09 .circle_gr .circle_nav .c4 {
    right: 0;
    top: var(--size-space-top-circle-sm);
  }
}
@media only screen and (max-width: 430px) {
  .idx09 .circle_gr {
    display: flex;
    justify-content: center;
    flex-direction: column;
    width: 100%;
    height: auto;
    font-size: min(1.7vw, 6px);
  }
  .idx09 .circle_gr .circle_nav {
    --size-mg: 3px;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }
  .idx09 .circle_gr .circle_nav .circle_nav_item {
    position: relative;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    margin: var(--size-mg);
  }
  .idx09 .circle_gr .circle_big {
    --size-circle-big: 51em;
    position: relative;
    width: var(--size-circle-big);
    height: var(--size-circle-big);
  }
  .idx09 .circle_gr .circle_big .circle_big_ct {
    width: var(--size-circle-big);
    height: var(--size-circle-big);
  }
  .idx09 .circle_gr .circle_big .circle_big_ct .feature_txt {
    margin-bottom: 0.3em;
    font-size: 2.5em;
  }
  .idx09 .circle_gr .circle_big .circle_big_ct .circle_big_ct_ttl {
    margin-bottom: 0.5em;
    font-size: 3em;
  }
  .idx09 .circle_gr .circle_big .circle_big_ct .ct_area p {
    font-size: 14px;
    letter-spacing: 0;
  }
  .idx09 .circle_gr .circle_big .circle_big_ct .ct_area p br {
    display: none;
  }
  .idx09 .circle_gr .circle_nav .circle_nav_item .feature_txt {
    font-size: 2em;
  }
  .idx09 .circle_gr .circle_nav .circle_nav_item .circle_nav_item_ttl {
    font-size: 2.4em;
  }
}

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