@charset "utf-8";

.page_main {
    padding-top: 0;
}

/* home_mv
---------------------------------------*/
.home_mv {
    overflow: hidden;
}
.home_mv_inner {
    width: 100%;
    /* max-width: 1520px; */
    margin: 0 auto;
    position: relative;
}
.home_mv_rail {
    /* overflow: hidden; */
    z-index: 2;
    position: relative;
}
.home_mv, .home_mv_item {
    height: 100vh;
    max-height: 69.8rem;
    position: relative;
}
.home_mv_item {
    padding-top: 11rem;
}
.home_mv_item_inner {
    position: relative;
    height: 100%;
}
.home_mv_item::before {
    content: '';
    /* display: block; */
    position: absolute;
    top: 0;
    left: 0;
    width: 50vw;
    height: 100%;
    z-index: -1;
    background: #ffffff;
    background: linear-gradient(90deg,rgba(255, 255, 255, 1) 20%, rgba(255, 255, 255, 0) 100%);
}
.home_mv_item_txt {
    grid-column: 2 / 8;
    position: relative;
    z-index: 3;
}
.home_mv_item_img {
    grid-column: 9 / -2;
    position: relative;
    z-index: 3;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 70%;
    padding: 6rem 0 0;
}
.home_mv_item_img img {
    max-width: 45rem;
    max-height: 30rem;
}
.home_mv_sub {
    font-size: 1.3rem;
    color: #005AFF;
    font-weight: 500;
    letter-spacing: .1rem;
    margin: 0 0 3.5rem;
}
.home_mv_ttl {
    font-size: clamp(4.4rem, 2.8rem + 3.33vw, 6.8rem);
    font-weight: 700;
    line-height: 1.1;
}
.home_mv_desc {
    font-size: clamp(1.8rem, 1.494rem + 0.64vw, 2.1rem);
    line-height: 1.5;
    margin: 3.5rem 0 0;
    max-width: 60rem;
}
.home_mv_btn {
    margin: 6.5rem 0 0;
}

@media screen and (max-width : 1023px) {
    .home_mv_ttl {
        font-size: 4.4rem;
    }
}

@media screen and (max-width : 767px) {
    .home_mv, .home_mv_item {
        max-height: 52rem;
    }
    .home_mv {
        padding-bottom: 8rem;
    }
    .home_mv_item {
        padding-top: 3.5rem;
        height: auto;
        /* min-height: 63vh; */
        min-height: 45rem;
        background-position: right center;
    }
    .home_mv_item_inner {
        padding: 0 2rem;
    }
    .home_mv_item::before {
        background: #ffffff;
        background: linear-gradient(90deg,rgba(255, 255, 255, 1) 40%, rgba(255, 255, 255, 0) 100%);
    }
    .home_mv_item_txt {
        grid-column: 1 / -1;
        display: flex;
        flex-flow: column;
        height: 100%;
    }
    .home_mv_sub {
        font-size: 1.2rem;
    }
    .home_mv_ttl {
        line-height: 1.0;
    }
    .home_mv_item_img {
        display: none;
    }
    .home_mv_btn {
        margin: auto 0 0;
    }
}

/* ヘアラインアニメーション */
.home_mv_wave {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    z-index: -2;
    opacity: .6;
}
.home_mv_wave .element, .home_mv_wave canvas {
  width: 100% !important;
  height: 100%;
  margin: 0;
  overflow: hidden;
}

@media screen and (max-width : 767px) {
    .home_mv_wave {
        height: 100%;
    }
}

/* Swiper ページネーション */
.home_mv .swiper-pagination {
    opacity: .7;
    bottom: 2rem !important;
}
.home_mv .swiper-pagination-bullet {
    background-color: #fff;
    border: solid 1px #0C0C0C;
    width: 1.0rem;
    height: 1.0rem;
    opacity: 1;
    margin: 0 3px !important;
}
.home_mv .swiper-pagination-bullet-active {
    background-color: #0C0C0C;
}

@media screen and (max-width : 767px) {
    .home_mv .swiper-pagination {
        bottom: -4.5rem !important;
    }
}

/* Swiper 一時停止・再生 */
.swiper-pause {
    z-index: 99;
    position: absolute;
    bottom: 1.5rem;
    left: 4rem;
    border: none;
    background: #F5F5F5;
    color: #b1b1b1;
    cursor: pointer;
    font-size: 1.6rem;
    padding: .7rem 1rem .7rem .3rem;
    border-radius: 2rem;
    transition: .2s ease;
}
.swiper-pause:hover {
    color: #E60013;
}
.swiper-pause_inner {
    position: relative;
}
.swiper-pause .pause, .swiper-pause .play {
    display: inline-block;
    padding-left: 3.4rem;
}
.swiper-pause .pause {
    display: block;
    background-image: url(/jp/assets/images/common/icon_slider_pause.svg);
    background-repeat: no-repeat;
    background-position: 0 center;
    background-size: 2.4rem 2.4rem;
}
.swiper-pause .play {
    display: none;
    background-image: url(/jp/assets/images/common/icon_slider_play.svg);
    background-repeat: no-repeat;
    background-position: 0 center;
    background-size: 2.4rem 2.4rem;
}
.swiper-pause.paused .pause {
    display: none;
}
.swiper-pause.paused .play {
    display: block;
}

@media screen and (max-width : 767px) {
    .swiper-pause {
        bottom: -5rem;
        left: 2rem;
    }
}

/* スクロールボタン */
.home_scroll_btn {
    z-index: 99;
    position: absolute;
    bottom: 1rem;
    right: 4rem;
}
.home_scroll_btn a {
    display: block;
    background: #F5F5F5;
    color: #b1b1b1;
    cursor: pointer;
    font-size: 1.5rem;
    padding: 1.25rem 5.5rem 1.25rem 1.8rem;
    border-radius: 4rem;
    transition: .2s ease;
    border: none;
    position: relative;
    height: 5rem;
}
.home_scroll_btn a:hover {
    color: #E60013;
}
.home_scroll_btn a::before {
    content: '';
    display: block;
    width: 3.8rem;
    height: 3.8rem;
    border-radius: 50%;
    position: absolute;
    right: .6rem;
    top: 0;
    bottom: 0;
    margin: auto;
    background-color: #fff;
    background-image: url(/jp/assets/images/common/icon_arrow.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: .6rem;
    transform: rotate(90deg);
}

@media screen and (max-width : 767px) {
    .home_scroll_btn {
        display: none;
    }
}

/* form_modal
---------------------------------------*/
.lity {
    z-index: 9999999999;
}

#form_modal {
    width: 90vw;
    height: 78vh;
    max-width: 64rem;
}
.form_modal_box {
    border-radius: .8rem;
    /* background-color: #F5F5F5; */
    background-color: #fff;
    border: solid 1px #E60013;
    height: 100%;
}
.form_modal_head {
    background-color: #E60013;
    text-align: center;
    color: #fff;
    padding: 1.3rem 2rem;
    font-weight: 700;
    border-radius: .7rem .7rem 0 0;
}
.form_modal_body {
    padding: 1.5rem 1rem 1.5rem 3.5rem;
    height: 90%;
}
.form_modal_body iframe {
    height: 100%;
}

@media screen and (max-width : 767px) {
    .form_modal_body {
        padding: 1.5rem .5rem 1.5rem 1.8rem;
    }
}

/* Lity.js */
.lity-close {
    width: 6.2rem;
    height: 6.2rem;
    background-color: #fff;
    border-radius: 50%;
    text-shadow: none;
    color: #4C4948;
    font-size: 6rem;
    top: 2rem;
    right: 2rem;
}
.lity-close:hover {
    background-color: #E60013;
    color: #fff;
    font-size: 6rem;
}

@media screen and (max-width : 767px) {
    .lity-close {
        width: 5.0rem;
        height: 5.0rem;
        top: 1rem;
        right: 1rem;
        font-size: 4.8rem;
    }
}

/* home_products
---------------------------------------*/
.home_products {
    padding-top: 8rem;
    padding-bottom: 12rem;
}
@media screen and (max-width : 767px) {
    .home_products {
        padding-top: 5rem;
        padding-bottom: 10rem;
    }
}

.home_products {
    overflow: hidden;
    position: relative;
}
.home_products_head {
    display: flex;
    align-items: center;
    gap: 2rem;
    margin: 0 0 5rem;
}
@media screen and (max-width : 767px) {
    .home_products_head {
        margin: 0 0 2.5rem;
    }
}

.home_products_item .blk {
    background-color: #F5F5F5;
    padding: 3.5rem 2.5rem 2rem;
    display: flex;
    flex-flow: column;
    gap: 2rem;
    width: 100%;
    height: 100%;
    border-radius: .8rem;
}
.home_products_item .tmb_box {
    height: 20rem;
}
.home_products_item .tmb {
    width: 100%;
    height: 100%;
    object-fit: scale-down;
}
.home_products_item .ttl {
    margin-top: auto;
    font-weight: 700;
    position: relative;
    padding-right: 3rem;
    line-height: 1.45;
}
.home_products_item a .ttl::after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    width: 2.8rem;
    height: 2.8rem;
    background-color: #fff;
    border-radius: 50%;
    background-image: url(/jp/assets/images/common/icon_arrow_rd.svg);
    background-repeat: no-repeat;
    background-size: .6rem;
    background-position: center;
    transition: .2s ease;
}
.home_products_item a:hover .ttl:after {
    background-color: #E60013;
    background-image: url(/jp/assets/images/common/icon_arrow_wh.svg);
}

@media screen and (max-width : 767px) {
    .home_products_item {
        /* width: 77vw !important; */
    }
    .home_products_item .blk {
        padding: 3rem 2rem 2rem;
    }
    .home_products_item .tmb_box {
        height: 16rem;
        padding: 1rem 2rem;
    }
}

.home_products_controller {
    position: relative;
    height: 6.2rem;
}
@media screen and (max-width : 767px) {
    .home_products_controller {
        display: none;
    }
}
 
/* Swiper 矢印 */
.home_products .swiper-button-prev, .home_products .swiper-button-next {
    position: absolute;
    top: 0;
    right: inherit;
    margin: 0;
    width: 6.2rem;
    height: 6.2rem;
    background-color: #fff;
    border-radius: 50%;
    font-weight: 700;
    border: solid 1px #797574;
}
.home_products .swiper-button-prev::after, .home_products .swiper-button-next::after {
    color: #005AFF;
    font-size: 1.6rem;
}
.home_products_controller .swiper-button-prev {
    left: 0;
}
.home_products_controller .swiper-button-next {
    left: 8rem;
}
.home_products_controller .swiper-button-prev::after, .home_products_controller .swiper-button-next::after {
    color: #0C0C0C;
}

@media screen and (max-width : 767px) {
    .home_products .swiper-button-prev, .home_products .swiper-button-next {
        width: 5rem;
        height: 5rem;
    }
    .home_products .swiper-button-prev::after, .home_products .swiper-button-next::after {
        font-size: 1.6rem;
    }
}

.home_products_list {
    display: grid;
    gap: .8rem !important;
}
@media screen and (min-width : 768px) {
    .home_products_list {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    }
}

/* home_support
---------------------------------------*/
.home_support_inner {
    padding-top: 8rem;
    padding-bottom: 8rem;
}
@media screen and (max-width : 767px) {
    .home_support_inner {
        padding-top: 4rem;
        padding-bottom: 4rem;
    }
}

.home_support_item {
    margin: 0 0 1.6rem;
}
.home_support_item a {
    border: solid 1px #E0E0E0;
    padding: 1rem;
    font-weight: 700;
    position: relative;
    border-radius: 9.0rem;
    transition: .2s ease;
}
.home_support_item a::after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    transition: .2s ease;
}
.home_support_item a::after {
    right: 1.3rem;
    width: 6.2rem;
    height: 6.2rem;
    background-color: #fff;
    border-radius: 50%;
    margin: auto;
    background-image: url(/jp/assets/images/common/icon_arrow_rd.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 1.0rem;
}
.home_support_item .row {
    display: flex;
    align-items: center;
    gap: 2.5rem;
}
.home_support_item .icon {
    background-color: #fff;
    padding: 1.3rem 1.3rem;
    width: 6.2rem;
    height: 6.2rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: .2s ease;
}
.home_support_item .icon img {
    width: 2.0rem;
    height: 2.0rem;
}

.home_support_item a:hover {
    background-color: #fff;
    box-shadow: .2rem .4rem 1.8rem rgba(0,0,0,.1);
}
.home_support_item a:hover:after {
    background-color: #F5F5F5;
    background-image: url(/jp/assets/images/common/icon_arrow.svg);
}
.home_support_item a:hover .icon {
    background-color: #F5F5F5;
}

@media screen and (max-width : 767px) {
    .home_support_item .icon {
        width: 5.0rem;
        height: 5.0rem;
    }
    .home_support_item a::after {
        width: 5.0rem;
        height: 5.0rem;
    }
    .home_support_item .row {
        gap: 1.5rem;
        padding-right: 6.5rem;
    }
}

/* home_topics
---------------------------------------*/
.home_topics {
    padding-top: 3rem;
    padding-bottom: 8rem;
}
@media screen and (max-width : 767px) {
    .home_topics {
        padding-top: 6rem;
        padding-bottom: 8rem;
    }
}

.home_topics_head {
    padding-top: 6rem;
}
.home_topics_body_row {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0 4.8rem;
}
.home_topics_list_item {
    margin-bottom: 2.4rem;
    cursor: default;
}
.home_topics_list_item a {
    transition: .2s ease;
}
.home_topics_list_item .blk {
    display: flex;
    flex-flow: column;
    gap: 2rem;
    height: 100%;
    background-color: #F5F5F5;
    border-radius: .8rem;
    padding: 4.5rem;
}
.home_topics_list_item .icon {
    width: 6.7rem;
    height: 6.7rem;
}
.home_topics_list_item .icon img {
    width: 100% ;
}
.home_topics_list_item .ttl {
    margin: 0;
}
.home_topics_list_item .link {
    margin-top: auto;
}
.home_topics_list_item:hover .blk {
    background-color: #fff;
    box-shadow: .2rem .4rem 2.8rem rgba(0,0,0,.1);
}
.home_topics_list_item:hover .link_arrow01:before {
    transform: scale(1.17);
}
.home_topics_list_item:hover .link_arrow01:before img {
    transform: scale(1);
}

@media screen and (max-width : 1023px) {
    .home_topics_head {
        padding-top: 0;
    }
    .home_topics_body {
        margin: 4rem 0 0;
    }
    .home_topics_body_row {
        display: flex;
        gap: 2rem;
    }
    .home_topics_list {
        display: flex;
        gap: 0 2rem;
    }
    .home_topics_list_item {
        width: 65vw;
        max-width: 28rem;
    }
    .home_topics_list_item .blk {
        padding: 2.5rem;
    }
    .home_topics_list_item .icon {
        width: 5rem;
        height: 5rem;
        margin-bottom: 2rem;
    }
}

@media screen and (min-width : 1024px) {
    .home_topics_body_row {
        width: 100% !important;
    }
    .home_topics_body .home_topics_list:first-child {
        padding-top: 5rem;
    }
}

/* home_news
---------------------------------------*/
.home_news {
    padding-top: 11rem;
    padding-bottom: 14rem;
}
@media screen and (max-width : 767px) {
    .home_news {
        padding-top: 5rem;
        padding-bottom: 6rem;
    }
}
.home_news_row {
    margin: 5rem 0 0;
}
@media screen and (max-width : 767px) {
    .home_news_row {
        margin: 3rem 0 0;
    }
}

/* home_news_featured */
.home_news_featured {
    height: 42rem;
}
.home_news_featured a {
    display: flex;
    flex-flow: column;
    justify-content: space-between;
    width: 100%;
    height: 100%;
    border-radius: .8rem;
    color: #fff;
    position: relative;
    padding: 4rem  3.5rem;
    overflow: hidden;
}
.home_news_featured a > * {
    position: relative;
    z-index: 2;
}
.home_news_featured .ribbon {
    align-self: flex-start;
    background-color: #0C0C0C;
    color: #7BFE97;
    text-align: center;
    padding: .6rem .8rem;
    font-size: 1.2rem;
    letter-spacing: .05rem;
    line-height: 1;
    font-weight: 700;
    border-radius: .4rem;
}
.home_news_featured .ttl {
    margin-top: auto;
    margin-bottom: 0;
    font-size: clamp(2rem, 1.253rem + 3.73vw, 4.8rem);
    font-weight: 700;
    line-height: 1.4;
}
.home_news_featured .date {
    font-size: 1.4rem;
    letter-spacing: .2rem;
}
.home_news_featured a::before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #000;
    border-radius: .8rem;
    opacity: .75;
    transition: .5s ease;
    z-index: 1;
}
.home_news_featured .tmb {
    object-fit: cover;
    width: 740px;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    z-index: 0;
    transition: .5s ease;
}
.home_news_featured a:hover:before {
    opacity: .7;
}
.home_news_featured a:hover .tmb {
    transform: scale(1.07);
}

@media screen and (max-width : 767px) {
    .home_news_featured {
        height: auto;
        min-height: 20rem;
    }
    .home_news_featured a {
        padding: 2rem;
    }
}

/* home_news_list */
.home_news_list_item .tmb_box {
    width: 100%;
    height: 20rem;
    background-color: #fff;
    margin: 0 0 1.5rem;
    border-radius: .8rem;
    overflow: hidden;
}
.home_news_list_item .tmb {
  width: 100%;
  height: 100%;
  object-fit: scale-down;
  transition: .5s ease;
}
.home_news_list_item a {
    color: #005AFF;
}
.home_news_list_item .date {
    font-size: 1.4rem;
    letter-spacing: .2rem;
}
.home_news_list_item .ttl {
   font-size: clamp(2rem, 1.893rem + 0.53vw, 2.4rem);
   font-weight: 700;
   margin: 0;
}
.home_news_list_item .desc {
    color: #4C4948;
    font-size: clamp(1.4rem, 1.347rem + 0.27vw, 1.6rem);
}
.home_news_list_item a:hover .tmb {
    transform: scale(1.07);
}
.home_news_list_item a:hover .ttl {
    text-decoration: underline;
}

@media screen and (max-width : 767px) {
    .home_news_list {
        display: none;
    }
}

.home_news_btn {
    margin-top: 2rem;
}
@media screen and (min-width : 768px) {
    .home_news_btn {
        display: none;
        margin-top: 5rem;
    }
}
    