/* <<<変更不可ここから>>> */
.lp-wrapper {
    -webkit-font-smoothing: antialiased;
    font-weight: 400;
    font-size: 13px;
    letter-spacing: 0em;
    line-height: 1.8;
    color: #000;
    margin-block: 40px 0;
}

@media screen and (min-width: 768px) {
    .lp-wrapper {
        margin-block: 60px 55px;
    }
}

.lp-wrapper *,
.lp-wrapper::before,
.lp-wrapper::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

.lp-wrapper a {
    text-decoration: none;
}

.lp-container,
.lp-container-narrow,
.lp-container-wide {
    width: calc(100% - 32px);
    margin-inline: auto;
}

@media screen and (min-width: 768px) {
    .lp-container {
        width: min(1080px, calc(100% - 120px));
    }
}

@media screen and (min-width: 992px) {
    .lp-container-narrow {
        width: min(840px, calc(100% - 120px));
    }
}

@media screen and (min-width: 992px) {
    .lp-container-wide {
        width: min(1440px, calc(100% - 104px));
    }
}

.lp-h2 {
    font-size: 18px;
    text-align: center;
    margin-bottom: 40px;
    font-weight: 700;
}

@media screen and (min-width: 768px) {
    .lp-h2 {
        font-size: 24px;
    }
}


/* <<<変更不可ここまで>>> */

/*
ここからページ固有のスタイルを記述
ブレイクポイントは、PC：〜992px、Tab：〜768、SP：767〜
*/

div.lp-wrapper,
div.lp-wrapper *{
    font-family: "Archivo", "Noto Sans JP", sans-serif;
}
.lp-wrapper {
    overflow: hidden;
}
.lp-wrapper section.lp-container-large{
    max-width: 1440px;
    margin: 0 auto;
}
@media screen and (min-width: 768px) {
    .lp-wrapper {
        margin-block: 0 55px
    }
}
@media screen and (max-width: 1520px) {
    section.lp-container-large{
        padding: 0 60px;
    }
}
@media screen and (max-width: 768px) {
    .lp-wrapper section.lp-container-large{
        padding: 0;
    }
}

/*section-mv*/
.lp-wrapper section.section-mv{
    margin: 0 auto 23px;
}
.lp-wrapper section.section-mv .mv-video-box video{
    width: 100%;
}
.lp-wrapper section.section-mv .mv-txt-box{
    width: 82%;
    margin: -90px auto 0;
    background: #fff;
    padding: 30px 95px;
    position: relative;
    z-index: 2;
    text-align: center;
}
.lp-wrapper section.section-mv .mv-txt-box h2{
    font-size: 24px;
    font-weight: 700;
    line-height: 26px;
    padding-bottom: 21px;
    text-transform: uppercase;
}
.lp-wrapper section.section-mv .mv-txt-box p{
    margin-bottom: 1.667rem;
    line-height: 1.7;
}
@media screen and (max-width: 768px) {
    .lp-wrapper section.section-mv{
        margin: 0 auto 84px;
    }
    .lp-wrapper section.section-mv .mv-txt-box{
        width: 91.4%;
        margin: -60px auto 0;
        padding: 30px 20px 20px;
    }
}

/*section-title*/
.lp-wrapper section.section-title{
    margin: 0 auto 125px;
}
.lp-wrapper section.section-title h3{
    font-size: 1.25rem;
    font-weight: 500;
    letter-spacing: .42em;
    max-width: 620px;
    margin: 0 auto 20px;
    padding: 0 24px;
    text-align: center;
    text-transform: uppercase;
}
.lp-wrapper section.section01.section-title{
    margin: 0 auto 124px;
}
@media screen and (max-width: 768px) {
    .lp-wrapper section.section-title{
        margin: 0 auto 69px;
    }
    .lp-wrapper section.section01.section-title{
        margin: 0 auto 73px;
    }
    .lp-wrapper section.section-title h3{
        font-size: 1.08rem;
    }
}

/*section02*/
.lp-wrapper section.section02{
    position: relative;
    margin: 0 auto 101px;
}
.lp-wrapper section.section02 ul.slide-box{
    display: flex;
    width: 100%;
    padding: 0 4px;
}
.lp-wrapper section.section02 ul.slide-box li.slide-box-txt{
    width: 600px;
    height: 650px;
    padding: 70px 70px 90px;
}
.lp-wrapper section.section02 ul.slide-box li.slide-box-txt h4{
    font-size: 22px;
    line-height: 24px;
    margin-bottom: 14px;
}
.lp-wrapper section.section02 ul.slide-box li.slide-box-txt p{
    font-size: 14px;
    line-height: 27.2px;
}
.lp-wrapper section.section02 ul.slide-box li.slide-box-img{
    width: calc(100% - 600px);
    height: 650px;
    min-height: 650px;
    position: relative;
    overflow: hidden;
}
.lp-wrapper section.section02 ul.slide-box li.slide-box-img img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50.0% 50.0%;
}
@media screen and (max-width: 1067px) {
    .lp-wrapper section.section02 ul.slide-box li.slide-box-txt{
        padding: 45px 45px 65px;
    }
}
@media screen and (max-width: 768px) {
    .lp-wrapper section.section02{
        margin: 0 auto 101px;
    }
    .lp-wrapper section.section02 ul.slide-box{
        padding: 0 20px;
        flex-direction: column-reverse;
        align-items: flex-start;
    }
    .lp-wrapper section.section02 ul.slide-box li.slide-box-txt{
        max-width: 700px;
        width: 100%;
        padding: 25px 25px 65px;
        height: auto;
    }
    .lp-wrapper section.section02 ul.slide-box li.slide-box-txt h4{
        font-size: 20px;
        margin-top: 18px;
    }
    .lp-wrapper section.section02 ul.slide-box li.slide-box-img{
        width: 100%;
        height: 350px;
        min-height: 350px;
    }
}

/*section02 slider*/
.lp-wrapper section.section02 .splide__pagination{
    display: block;
    bottom: 63px;
    left: 10px;
    padding: 0 64px;
}
.lp-wrapper section.section02 .splide__pagination li{
    margin: 0 10px;
}
.lp-wrapper section.section02 .splide__pagination li:first-child{
    margin-left: 0;
}
.lp-wrapper section.section02 .splide__pagination__page{
    background: #7e7e7e;
    opacity: 1;
    border-radius: 50%;
}
.lp-wrapper section.section02 .splide__pagination__page:hover{
    border-radius: 50%;
}
.lp-wrapper section.section02 .splide__pagination__page.is-active{
    background: #151515;
    transform: none;
    position: relative;
}
.lp-wrapper section.section02 .splide__pagination__page.is-active:before{
    content: '';
    display: block;
    border: 1px solid #151515;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    position: relative;
    bottom: 6px;
    left: -6px;
}
@media screen and (max-width: 1067px) {
    .lp-wrapper section.section02 .splide__pagination{
        bottom: 37px;
        left: 11px;
        padding: 0 38px;
    }
    .lp-wrapper section.section02 .splide__pagination{
        bottom: 49px;
        padding: 0 35px;
    }
}
@media screen and (max-width: 768px) {
    .lp-wrapper section.section02 .splide__pagination{
        bottom: 0;
        padding: 0 33px;
    }
    /*.lp-wrapper section.section02 .splide__list{
        align-items: flex-start;
    }*/
    .splide__track--fade>.splide__list>.splide__slide {
    height: 0 !important;
}
.splide__track--fade>.splide__list>.splide__slide.is-active {
    height: auto !important;
}
}

/*section04*/
.lp-wrapper section.section04{
    margin-bottom: 160px;
}
.lp-wrapper section.section04 ul.sec04-material-list{
    padding: 0 4px;
}
.lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box{
    width: 100%;
    display: flex;
    align-items: center;
    flex-direction: row-reverse;
    margin-bottom: 120px;
}
.lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box:last-child{
    margin-bottom: 0;
}
.lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box:nth-child(2n){
    flex-direction: row;
}
.lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box div.sec04-txt-box{
    width: 100%;
}
.lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box div.sec04-txt-box div{
    padding: 0 100px;
}
.lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box div.sec04-txt-box div h4{
    font-size: 15px;
    margin-bottom: 15px;
    letter-spacing: 6px;
    line-height: 24px;
}
.lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box div.sec04-txt-box div p{
    color: #7B7678;
    line-height: 1.8;
    margin-bottom: 1.45rem;
}
.lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box div.sec04-txt-box div ul{
    color: #7B7678;
    padding-left: 5px;
    /* margin-bottom: 1.67rem; */
}
.lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box div.sec04-txt-box div ul li{
    line-height: 1.7;
    margin-bottom: 1px;
    position: relative;
    padding-left: 14px;
}
.lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box div.sec04-txt-box div ul li:last-child{
    margin-bottom: 0;
}
.lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box div.sec04-txt-box div ul li:before{
    content: "";
    position: absolute;
    top: .7em;
    left: 0;
    width: 4px;
    height: 4px;
    background-color: #7B7678;
    border-radius: 50%;
}
.lp-wrapper section.section04 ul.sec04-material-list li div.sec04-img-box{
    width: 100%;
    position: relative;
}
.lp-wrapper section.section04 ul.sec04-material-list li div.sec04-img-box div{
    position: relative;
    padding-bottom: 75%;
}
.lp-wrapper section.section04 ul.sec04-material-list li div.sec04-img-box div img{
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
@media screen and (max-width: 768px) {
    .lp-wrapper section.section04{
        margin-bottom: 100px;
    }
    .lp-wrapper section.section04 ul.sec04-material-list{
        padding: 0 20px;
    }
    .lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box{
        flex-direction: column;
        margin-bottom: 96px;
    }
    .lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box:nth-child(2n){
        flex-direction: column;
    }
    .lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box div.sec04-txt-box div ul {
        margin-bottom: 1.67rem;
    }
}
@media screen and (max-width: 640px) {
    .lp-wrapper section.section04 ul.sec04-material-list li.sec04-material-box div.sec04-txt-box div{
        padding: 20px 50px;
    }
}

/*section05*/
.lp-wrapper section.section05{
    margin-bottom: 95px;
}
.lp-wrapper section.section05 h3 {
    margin-bottom: 15px;
}
.lp-wrapper section.section05 ul{
    display: flex;
    justify-content: flex-end;
}
.lp-wrapper section.section05 ul li:nth-child(1){
    width: 447px;
    height: auto;
    display: flex;
    flex-direction: column;
    margin-right: 32px;
    margin-top: 132px;
}
.lp-wrapper section.section05 ul li:nth-child(1) img{
    margin: 0 0 20px;
}
.lp-wrapper section.section05 ul li:nth-child(1) h3{
    font-size: 20px;
    line-height: 24px;
    font-weight: 600;
}
.lp-wrapper section.section05 ul li:nth-child(1) p{
    color: #7b7678;
    font-size: 14px;
    margin-bottom: 1.25rem;
    line-height: 1.8;
    text-rendering: optimizeLegibility;
}
.lp-wrapper section.section05 ul li:nth-child(1) a{
    padding: 10px 20px 12px;
    font-style: normal;
    text-transform: uppercase;
    width: 140px;
    height: 45px;
    display: inline-flex;
    cursor: pointer;
    align-items: center;
    justify-content: center;
    letter-spacing: .02em;
    border: 1px solid #000;
    background: #000;
    color: #fff;
    text-align: center;
    position: relative;
    z-index: 1;
    overflow: hidden;
    appearance: none;
    transition: color .25s cubic-bezier(.104,.204,.492,1), background-color .25s cubic-bezier(.104,.204,.492,1), border-color .25s cubic-bezier(.104,.204,.492,1);
    line-height: initial;
}
.lp-wrapper section.section05 ul li:nth-child(1) a:before{
    z-index: -1;
    transition: all .25s cubic-bezier(.104,.204,.492,1);
    content: "";
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    left: -5%;
    width: 125%;
    height: 100%;
    background: #fff;
    opacity: 1;
    border-radius: var(--button-border-radius, 0px);
    transform-origin: bottom left;
    backface-visibility: hidden;
    transform: rotate3d(0, 0, 1, 6deg) translate3d(-1.2em, 110%, 0);
    will-change: transform;
}
.lp-wrapper section.section05 ul li:nth-child(1) a span{
    transition: all .25s cubic-bezier(.104,.204,.492,1);
    position: relative;
    z-index: 8;
    font-size: 12px;
    font-style: normal;
    /* line-height: 18px; */
    text-transform: uppercase;
}
.lp-wrapper section.section05 ul li:nth-child(1) a:hover{
    color: #000;
    transition: 0.3s;
}
.lp-wrapper section.section05 ul li:nth-child(1) a:hover:before{
    transform: rotate3d(0, 0, 1, 0) translateZ(0);
}
.lp-wrapper section.section05 ul li:nth-child(2){
    width: 50%;
    max-width: unset;
}
@media screen and (max-width: 1520px) {
    .lp-wrapper section.section05{
        padding: 0 60px;
    }
}
@media screen and (max-width: 992px) {
    .lp-wrapper section.section05 ul li:nth-child(1){
        margin-top: 40px;
    }
}
@media screen and (max-width: 768px) {
    .lp-wrapper section.section05{
        padding: 0;
        margin-bottom: 93px;
    }
    .lp-wrapper section.section05 ul{
        flex-direction: column;
    }
    .lp-wrapper section.section05 ul li:nth-child(1){
        width: 100%;
        margin: 0;
    }
    .lp-wrapper section.section05 ul li:nth-child(2){
        width: 100%;
        display: none;
    }
    .lp-wrapper section.section05 ul li:nth-child(1) img{
        margin: 0;
    }
    .lp-wrapper section.section05 ul li:nth-child(1) h3,
    .lp-wrapper section.section05 ul li:nth-child(1) p{
        padding: 0 16px;
    }
    .lp-wrapper section.section05 ul li:nth-child(1) h3{
        font-size: 18px;
        margin-top: 20px;
        font-weight: 400;
    }
    .lp-wrapper section.section05 ul li:nth-child(1) p{
        font-size: 13px;
        color: #000;
    }
    .lp-wrapper section.section05 ul li:nth-child(1) a{
        margin-left: 16px;
    }
}

/*section06*/
.lp-wrapper section.section06.section-title {
    margin: 0 auto 60px;
}

@media screen and (max-width: 768px) {
    .lp-wrapper section.section06.section-title {
        margin: 0 auto 30px;
    }
}

/*section07*/
.lp-wrapper section.section07 ul{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-gap: 30px;
    padding: 18px 4px 0;
}
.lp-wrapper section.section07 ul li{
    position: relative;
}
.lp-wrapper section.section07 ul li div{
    padding: 20px 30px;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 20;
    color: #fff;
    display: flex;
    justify-content: flex-start;
    align-items: flex-end;
}
.lp-wrapper section.section07 ul li div span{
    color: #fff;
    font-size: 1.25rem;
    position: relative;
    display: inline-block;
}
.lp-wrapper section.section07 ul li div span:before{
    background: #fff3;
    content: "";
    display: block;
    position: absolute;
    top: calc(100% + 2px);
    left: 0;
    width: 100%;
    height: 1px;
    pointer-events: none;
}
.lp-wrapper section.section07 ul li div span:after{
    background: #fff;
    transition: all .25s cubic-bezier(.104,.204,.492,1);
    content: "";
    display: block;
    position: absolute;
    top: calc(100% + 2px);
    left: 0;
    width: 100%;
    height: 1px;
    pointer-events: none;
    transform-origin: left center;
    transform: scaleX(0);
}
.lp-wrapper section.section07 ul li div span:hover:after,
.lp-wrapper section.section07 ul li div span:focus:after {
    transform: scaleX(1);
}

@media screen and (max-width: 768px) {
    .lp-wrapper section.section07{
        padding: 51px 0 0;
        overflow: scroll;
        scrollbar-width: none;
        border-right: 4px solid #fff;
        border-left: 4px solid #fff;
    }
    .lp-wrapper section.section07::-webkit-scrollbar{
        display: none;
    }
    .lp-wrapper section.section07 ul{
        width: 368%;
        padding: 0;
        scroll-snap-type: x mandatory;
        scrollbar-width: none;
        overflow: scroll;
        -ms-overflow-style: none;
        /*display: grid;
        padding: 0;
        margin: 0;
        width: calc(100% + 30px);
        grid-auto-flow: column;
        grid-auto-columns: minmax(calc(90vw - 15px), 1fr);
        overflow-x: auto;
        grid-template-columns: repeat(auto-fill, minmax(calc(90vw - 15px), 1fr));
        scroll-snap-type: x mandatory;
        scrollbar-width: none;*/
    }
    .lp-wrapper section.section07 ul::-webkit-scrollbar{
        display: none;
    }
    .lp-wrapper section.section07 ul li{
        scroll-snap-align: center;
        scroll-snap-stop: always;
        width: 100%;
    }
    .lp-wrapper section.section07 ul li img{
        width: 100%;
    }
}

/*section08*/
.lp-wrapper section.section08{
}
.lp-wrapper section.section08 p{
    color: #7b7678;
    max-width: 620px;
    margin: 0 auto;
    padding: 0 20px;
    text-align: center;
}
.lp-wrapper section.section08 p span{
    color: #EF8CA5;
    border-bottom: 1px solid #EF8CA5;
    line-height: 1.75;
    letter-spacing: 0.034em;font-style: italic;
}
@media screen and (max-width: 768px) {
    .lp-wrapper section.section08 p{
        padding: 0 37px;
    }
}

/*responciv class*/
.lp-sp{
    display: none;
}
@media screen and (max-width: 768px) {
    .lp-sp{
        display: block;
    }
}


