@charset "utf-8";
body {
	margin: 0;
}

img {
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
}
video {
    max-width: 100%;
    height: auto;
    display: block;
}
.over-hidden {
    overflow: hidden;
}

.p_re {
    position: relative;
}

.pc_dsb {
    display: block;
}
.sp_dsb {
    display: none;
}

/*光るアニメーション*/
.btn_anime a {
  display: block;
  position: relative;
  overflow: hidden;
}
.btn_anime a::before {
    position: absolute;
    content: '';
    display: inline-block;
    top: -180px;
    left: 0;
    width: 30px;
    height: 100%;
    background-color: #fbfbfb;
    animation: btn_animation 4s ease-in-out infinite;
}
@-webkit-keyframes btn_animation {
    0% { -webkit-transform: scale(0) rotate(45deg); opacity: 0; }
    80% { -webkit-transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { -webkit-transform: scale(4) rotate(45deg); opacity: 1; }
    100% { -webkit-transform: scale(50) rotate(45deg); opacity: 0; }
}
/*光るアニメーション*/

.inner_block {
    max-width: 1000px;
    width: 100%;
    margin: 0 auto;
}

/*--------header fv---------*/
.pc_dsb .header {
    background: #fff;
}
.pc_dsb .pc_fv {
    background: #fadfd7;
}
.pc_dsb .pc_fv .pc_fv_bg_inner {
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
    background-image: url(../img/pc/fv_bg.jpg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}



/*--------cv01---------*/
.pc_dsb .pc_cv01 {
    background: #ad0227;
}
.pc_dsb .pc_cv01 .pc_cv01_bg_inner {
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
    background-image: url(../img/pc/cv01_bg.jpg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}
.pc_dsb .pc_cv01 .pc_cv01_bg_inner p.btn_anime {
    position: absolute;
    width: 718px;
    bottom: 60px;
    left: 160px;
}
.cv01 .sp_dsb p {
    position: absolute;
    width: 686px;
    bottom: 50px;
    left: 40px;
}
@media screen and (max-width: 1000px) {
    .pc_dsb .pc_cv01 .pc_cv01_bg_inner p.btn_anime {
        width: 71.8vw;
        bottom: 6vw;
        left: 15vw;
    }
}


/*--------cnt01---------*/
.pc_dsb .pc_cnt01 {
    background: #f9f4f1;
}
.pc_dsb .pc_cnt01 .pc_cnt01_bg_inner {
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
    background-image: url(../img/pc/cnt01_bg.jpg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}


/*--------cnt02---------*/
.pc_dsb .pc_cnt02 {
    background: #ebebeb;
}
.cnt02 .pc_dsb {
 z-index: 100;
}


/*--------cnt03---------*/
.pc_dsb .pc_cnt03 {
    background: #f4f5f9;
}
.pc_dsb .pc_cnt03 .pc_cnt03_bg_inner {
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
}
.pc_dsb .pc_cnt03 .pc_cnt03_bg_inner .inner_block .cnt03_ttl {
    position: absolute;
    left: 75px;
    top: 80px;
}
.pc_dsb .pc_cnt03 .pc_cnt03_bg_inner .inner_block .movie {
    position: absolute;
    width: 450px;
    right: 40px;
    bottom: 0;
}
.pc_dsb .pc_cnt03 .pc_cnt03_bg_inner .inner_block .over_cnt03 {
    position: absolute;
    width: 100%;
    left: 0;
    top: 0;
}
.pc_dsb .pc_cnt03 .pc_cnt03_bg_inner .inner_block .cnt02-02 {
    position: absolute;
    width: 100%;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
}
.pc_dsb .pc_cnt03 .pc_cnt03_bg_inner .cnt04_bg01 {
    position: absolute;
    width: 100%;
    height: 72px;
    bottom: -1px;
    left: 0;
    background-image: url(../img/pc/cnt04_bg01.png);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}
@media screen and (max-width: 1000px) {
    .pc_dsb .pc_cnt03 .pc_cnt03_bg_inner .inner_block .cnt03_ttl {
        width: 50.7vw;
        left: 7.5vw;
        top: 8vw;
    }
    .pc_dsb .pc_cnt03 .pc_cnt03_bg_inner .inner_block .movie {
        width: 45vw;
        right: 4vw;
    }
    .pc_dsb .pc_cnt03 .pc_cnt03_bg_inner .cnt04_bg01 {
        height: 7.06vw;
    }
}
.sp_dsb .cnt03_pab {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
}



/*--------cnt04---------*/
.pc_dsb .pc_cnt04 {
    background: #eeedeb;
}
.pc_dsb .pc_cnt04 .pc_cnt04_bg_inner {
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
    background-image: url(../img/pc/cnt04_bg.jpg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}
.sp_dsb .cnt04 {
    position: absolute;
    width: 100%;
    bottom: -1px;
    left: 0;
    z-index: 10;
}


/*--------cv02---------*/
.pc_dsb .pc_cv02 {
    background: #ad0227;
}
.pc_dsb .pc_cv02 .pc_cv02_bg_inner {
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
    background-image: url(../img/pc/cv02_bg.jpg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}
.pc_dsb .pc_cv02 .pc_cv02_bg_inner .cv02_01 {
    position: absolute;
    width: 718px;
    left: 160px;
    top: 620px;
}
.pc_dsb .pc_cv02 .pc_cv02_bg_inner .cv02_02 {
    position: absolute;
    width: 628px;
    left: 200px;
    top: 1025px;
}
.pc_dsb .pc_cv02 .pc_cv02_bg_inner .cv02_03 {
    position: absolute;
    width: 700px;
    left: 150px;
    bottom: 280px;
}
@media screen and (max-width: 1000px) {
    .pc_dsb .pc_cv02 .pc_cv02_bg_inner .cv02_01 {
        width: 71.8vw;
        left: 16vw;
        top: 61vw;
    }
    .pc_dsb .pc_cv02 .pc_cv02_bg_inner .cv02_02 {
        width: 62.8vw;
        left: 20vw;
        top: 100.5vw;
    }
    .pc_dsb .pc_cv02 .pc_cv02_bg_inner .cv02_03 {
        width: 70vw;
        left: 15vw;
        bottom: 28vw;
    }
}
.sp_dsb .cv02_01 {
    position: absolute;
    width: 686px;
    top: 1195px;
    left: 40px;
}
.sp_dsb .cv02_02 {
    position: absolute;
    width: 642px;
    top: 1860px;
    left: 70px;
}
.sp_dsb .cv02_03 {
    position: absolute;
    width: 644px;
    bottom: 480px;
    left: 67px;
}



/*--------cnt05---------*/
.pc_dsb .pc_cnt05-01 {
    background: #f9d9d3;
}
.pc_dsb .pc_cnt05-01 .pc_cnt05-01_bg_inner {
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
    background-image: url(../img/pc/cnt05-01_bg.jpg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}
.pc_dsb .pc_cnt05-01 .pc_cnt05-01_bg_inner .cnt05-01_video01 {
    position: absolute;
    width: 410px;
    top: 815px;
    left: 50%;
    transform: translateX(-50%);
}
.pc_dsb .pc_cnt05-01 .pc_cnt05-01_bg_inner .cnt05-01_video02 {
    position: absolute;
    width: 290px;
    bottom: 120px;
    left: 160px;
}
@media screen and (max-width: 1000px) {
    .pc_dsb .pc_cnt05-01 .pc_cnt05-01_bg_inner .cnt05-01_video01 {
        width: 41vw;
        top: 80vw;
    }
    .pc_dsb .pc_cnt05-01 .pc_cnt05-01_bg_inner .cnt05-01_video02 {
        width: 29vw;
        bottom: 11vw;
        left: 16vw;
    }
}
.pc_dsb .pc_cnt05-02 {
    background: #f9d9d3;
}
.pc_dsb .pc_cnt05-02 .pc_cnt05-02_bg_inner {
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
    background-image: url(../img/pc/cnt05-02_bg.jpg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}
.pc_dsb .pc_cnt05-02 .pc_cnt05-02_bg_inner .cnt05-02_video01 {
    position: absolute;
    width: 350px;
    left: 165px;
    bottom: 120px;
}
@media screen and (max-width: 1000px) {
    .pc_dsb .pc_cnt05-02 .pc_cnt05-02_bg_inner .cnt05-02_video01 {
        width: 35vw;
        left: 16.5vw;
        bottom: 12vw;
    }
}
.pc_dsb .pc_cnt05-03 {
    background: #f9d9d3;
}
.pc_dsb .pc_cnt05-03 .pc_cnt05-03_bg_inner {
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
    background-image: url(../img/pc/cnt05-03_bg.jpg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}
.pc_dsb .pc_cnt05-03 .pc_cnt05-03_bg_inner .cnt05-03_video01 {
    position: absolute;
    width: 290px;
    left: 300px;
    bottom: 96px;
}
@media screen and (max-width: 1000px) {
    .pc_dsb .pc_cnt05-03 .pc_cnt05-03_bg_inner .cnt05-03_video01 {
        width: 28.5vw;
        left: 30vw;
        bottom: 9.5vw;
    }
}

.sp_dsb .cnt05-01_video01 {
    position: absolute;
    width: 600px;
    top: 1550px;
    left: 50%;
    transform: translateX(-50%);
}
.sp_dsb .cnt05-01_video02 {
    position: absolute;
    width: 490px;
    bottom: 72px;
    left: 32px;
}
.sp_dsb .cnt05-01_title {
    position: absolute;
    width: 290px;
    bottom: 195px;
    right: 0;
}
.sp_dsb .cnt05-02_video01 {
    position: absolute;
    width: 600px;
    bottom: 115px;
    left: 32px;
}
.sp_dsb .cnt05-02_title {
    position: absolute;
    width: 505px;
    bottom: 72px;
    right: 0;
}
.sp_dsb .cnt05-03_video01 {
    position: absolute;
    width: 490px;
    bottom: 145px;
    left: 32px;
}
.sp_dsb .cnt05-03_title {
    position: absolute;
    width: 255px;
    bottom: 230px;
    right: 0;
}




/*--------cnt06---------*/
.pc_dsb .pc_cnt06 {
    background: #fcebed;
}
.pc_dsb .pc_cnt06 .pc_cnt06_bg_inner {
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
    background-image: url(../img/pc/cnt06_bg.jpg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}


/*--------cnt07---------*/
.pc_dsb .pc_cnt07 {
    background: #e9eaf2;
}
.pc_dsb .pc_cnt07 .pc_cnt07_bg_inner {
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
    background-image: url(../img/pc/cnt07_bg.jpg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}
.pc_dsb .pc_cnt07 .pc_cnt07_bg_inner .cnt06_bg01 {
    position: absolute;
    width: 100%;
    height: 78px;
    top: 0;
    left: 0;
    background-image: url(../img/pc/cnt06_bg01.png);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}
@media screen and (max-width: 1000px) {
    .pc_dsb .pc_cnt07 .pc_cnt07_bg_inner .cnt06_bg01 {
        height: 7.8vw;
    }
}


/*--------cnt08---------*/
.pc_dsb .pc_cnt08 {
    background-image: url(../img/pc/cnt08_bg01.jpg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}
.pc_dsb .pc_cnt08 .pc_cnt08_bg_inner {
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
    background-image: url(../img/pc/cnt08_bg.jpg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}



/*--------cnt09---------*/
.pc_dsb .pc_cnt09 {
    background: #f3ecec;
}
.pc_dsb .pc_cnt09 .pc_cnt09_bg_inner {
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
    background-image: url(../img/pc/cnt09_bg.jpg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    text-align: center;
}



/*--------cnt10---------*/
.pc_dsb .pc_cnt10 {
    background: #fff;
}
.pc_dsb .pc_cnt10 .pc_cnt10_bg_inner {
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
}
.pc_dsb .pc_cnt10 .pc_cnt10_bg_inner .cnt10_btn {
    position: absolute;
    width: 487px;
    left: 75px;
    bottom: 80px;
}
@media screen and (max-width: 1000px) {
    .pc_dsb .pc_cnt10 .pc_cnt10_bg_inner .cnt10_btn {
        width: 48.7vw;
        left: 7.5vw;
        bottom: 8vw;
    }
}


.sp_dsb .cnt10_btn {
    position: absolute;
    width: 644px;
    bottom: 55px;
    left: 72px;
}

@media screen and (max-width: 768px) {
    img {
        max-width: none;
        width: 100%;
    }
    video {
        max-width: none;
        width: 100%;
    }
    .pc_dsb {
        display: none;
    }
    .sp_dsb {
        display: block;
    }
    .inner_block {
        max-width: none;
        width: 100%;
    }

    .cv01 .sp_dsb p {
        position: absolute;
        width: 91.46vw;
        bottom: 6.66vw;
        left: 5.333vw;
    }

    .sp_dsb .cv02_01 {
        width: 91.46vw;
        top: 159.33vw;
        left: 5.333vw;
    }
    .sp_dsb .cv02_02 {
        width: 85.6vw;
        top: 248vw;
        left: 9.333vw;
    }
    .sp_dsb .cv02_03 {
        width: 85.86vw;
        bottom: 64vw;
        left: 8.93vw;
    }
    .sp_dsb .cnt05-01_video01 {
        width: 80vw;
        top: 206.66vw;
    }
    .sp_dsb .cnt05-01_video02 {
        width: 65.33vw;
        bottom: 9.6vw;
        left: 4.26vw;
    }
    .sp_dsb .cnt05-01_title {
        width: 38.66vw;
        bottom: 26vw;
    }
    .sp_dsb .cnt05-02_video01 {
        width: 80vw;
        bottom: 15.33vw;
        left: 4.26vw;
    }
    .sp_dsb .cnt05-02_title {
        width: 67.33vw;
        bottom: 9.6vw;
    }
    .sp_dsb .cnt05-03_video01 {
        width: 65.33vw;
        bottom: 19.33vw;
        left: 4.26vw;
    }
    .sp_dsb .cnt05-03_title {
        width: 34vw;
        bottom: 30.66vw;
    }
    .sp_dsb .cnt10_btn {
        width: 85.86vw;
        bottom: 7.33vw;
        left: 9.6vw;
    }
}
