@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP|Noto+Serif+JP');

/*
font-family: 'Noto Sans JP', sans-serif;
font-family: 'Noto Serif JP', sans-serif;
*/

.show_pc { display: block !important; }
.show_sp { display: none !important; }

@media only screen and (max-width: 750px) {
  .show_pc { display: none !important; }
  .show_sp { display: block !important; }
}

/* Loading */

#loader-bg {
  display: none;
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
  background: #ffffff;
  z-index: 1;
}

#loader {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  width: 200px;
  height: 200px;
  margin-top: -100px;
  margin-left: -100px;
  text-align: center;
  color: #fff;
  z-index: 2;
}

body {
  width: 100%;
  padding: 0;
  margin: 0;
  background-color: #ffffff;
  font-family: 'Noto Sans JP', sans-serif;
}

/* contents */
.img_none {display: none;}

#wrap {
  background-color: #fbdbde;
  width: 1200px;
  display: block;
  margin: 0 auto;
}

.mv img {
  width: 875px;
  display: block;
  margin: 0 auto;
}

.ses {
  width: 100%;
  display: block;
  margin: 0px auto;
}

.ses p {
  font-size: 14px;
  color: #000000;
  line-height: 1.27;
}

/* session00 */
#session00 {
  width: 749px;
  display: block;
  margin: 0px auto 0;
  padding-top: 40px;
}

/* s01 */
.s01bg {
  background-image: url('../images/201911/s01_bg.png');
  background-repeat: no-repeat;
  background-size: 100%;
}

#s01 {
  width: 804px;
  display: block;
  margin: 0px auto;
  padding-top: 50px;
  position: relative;
  z-index: 0;
}

#s01 .cr {
  position: absolute;
  z-index: 1;
  width: 280px;
  top: 77%;
  margin-left: 60px;
}

/* s02 */
.s02bg {
  background-image: url('../images/201911/s02_bg.png');
  background-repeat: no-repeat;
  background-size: 100%;
}

#s02 {
  width: 780px;
  display: block;
  margin: -100px auto 0 225px;
  padding-top: 120px;
  position: relative;
  z-index: 0;
}

#s02 .cr {
  position: absolute;
  z-index: 1;
  width: 300px;
  top: 84%;
  margin-left: 39px;
}

/* s03 */
.s03bg {
  background-image: url('../images/201911/s03_bg.png');
  background-repeat: no-repeat;
  background-size: 100%;
}

#s03 {
  width: 751px;
  display: block;
  margin: -112px auto 0;
  padding-top: 158px;
  position: relative;
  z-index: 0;
}

#s03 .cr {
  position: absolute;
  z-index: 1;
  width: 280px;
  top: 62.6%;
  margin-left: 30px;
}

/* s04 */
.s04bg {
  background-image: url('../images/201911/s04_bg.png');
  background-repeat: no-repeat;
  background-size: 100%;
  position: relative;
  z-index: 0;
}

#s04 {
  width: 1200px;
  display: block;
  margin-top: -103px;
  padding-top: 190px;
}

#s04 .cr {
  position: absolute;
  z-index: 1;
  width: 280px;
  top: 71%;
  margin-left: 690px;
}

/* s05 */
.s05bg {
  background-image: url('../images/201911/s05_bg.png');
  background-repeat: no-repeat;
  background-size: 100%;
}

#s05 {
  width: 757px;
  display: block;
  margin: -90px auto 0;
  padding-top: 154px;
  padding-bottom: 73px;
  position: relative;
  z-index: 0;
}

#s05 .cr {
  position: absolute;
  z-index: 1;
  width: 280px;
  top: 24.3%;
  margin-left: 524px;
}

/* s06 */
.s06bg {
  background-color: #303139;
}

#s06 {
  width: 757px;
  display: block;
  margin: 0px auto 0 126px;
  padding-top: 13px;
  padding-bottom: 27px;
  position: relative;
  z-index: 0;
}

#s06 .cr {
  position: absolute;
  z-index: 1;
  width: 520px;
  top: 81.5%;
  margin-left: 100px;
}

#s06 .cr p {
  color: #ffffff;
}

/* m01 */
.m02bg,
.m01bg {
  background-image: url('../images/201911/movie01_bg.png');
  background-repeat: no-repeat;
  background-size: 100%;
  padding-top: 80px;
  padding-bottom: 91px;
}

.m02bg {
  background-image: url('../images/201911/movie02_bg.png');
}

.movie02,
.movie01 {
  width: 600px;
  background-color: #303139;
  display: block;
  padding: 10px;
  margin: 0 auto;
}

.movie02 {
  width: 600px;
  background-color: #30345a;
}


/* s07 */
.s07bg {
  background-image: url('../images/201911/s07_bg.png');
  background-repeat: no-repeat;
  background-size: 100%;
  margin-top: -69px;
  padding-top: 52px;
  position: relative;
  z-index: 0;
}

.wrap_07 {
  width: 100%;
  background-color: #ffffff;
  padding-top: 34px;
}

#s07 {
  width: 757px;
  display: block;
  margin: 0 auto 0 267px;
  padding-bottom: 82px;
}

#s07 .cr {
  position: absolute;
  z-index: 1;
  width: 622px;
  top: 87%;
  margin-left: 0px;
}


/* bg */
.btm_bg {
  background-color: #fbdbde;
  background-image: url('../images/201911/btm_bg.png');
  background-repeat: no-repeat;
  background-size: 100%;
  padding-top: 67px;
  padding-bottom: 40px;
}

#bt_area {
  background-color: #ffffff;
}


#btn {
  line-height: 0;
  width: 1125px;
  display: block;
  margin: 50px auto 0;
}

#btn_no {
  width: 750px;
  display: block;
  margin: 50px auto 0;
}

.btnLinkhalf {
  display: inline-flex;
  list-style-type: none;
  width: 100%;
  max-width: 1200px;
  padding: 0;
  margin: 0;
}

.btnLinkHalf img {
  width: 100%;
}

.btnLinkHalf li {
  width: 100%;
}

.ftArea {
  background-color: #ffffff;
  margin-top: -30px;
  padding-top: 30px;
}

.toList {
  width: 473px;
  display: block;
  /* margin: 70px auto 0; */
  margin-left: auto;
  margin-right: auto;
}

.toInsta {
  width: 81px;
  display: block;
  margin: 40px auto 0;
}

.snsLink {
  width: 50%;
  padding: 0;
  list-style-type: none;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  margin: 30px auto 0;
  /* padding-bottom: 35px !important; */
}

.snsLink li {
  width: 80%;
  text-align: center;
}

.snsLink li img {
  height: 81px;
}

.splLogo {
  width: 312px;
  display: block;
  margin: 55px auto 0;
}

.toMain {
  width: 685px;
  display: block;
  margin: 30px auto 0;
}

.stc {
  width: 400px;
  margin-top: 50px;
  display: block;
  margin: 50px auto 0;
}

/* special */
#spe_wrap {
  background-color: #ffffff;
  background-image: url('../images/201911/spe_bg.jpg');
  background-repeat: repeat;
  background-size: 30%;
  width: 1200px;
  display: block;
  margin: 0 auto;
  padding-bottom: 70px;
}

#spe_wrap .spe_top {
  width: 1020px;
  display: block;
  margin: 0 auto;
}

#sp01 {
  width: 1020px;
  display: block;
  margin: 0 auto;
  position: relative;
  z-index: 0;
}

#sp03,
#sp02 {
  width: 100%;
  display: block;
  margin: 0 auto;
  position: relative;
  z-index: 0;
}

#sp02 .r_cmt p,
#sp01 .r_cmt p {
  line-height: 1.6;
  letter-spacing: -0.12em;
}

#sp01 .cr {
  position: absolute;
  z-index: 1;
  width: 620px;
  top: 70.7%;
  margin-left: 133px;
}

#sp01 .r_cmt {
  position: absolute;
  z-index: 1;
  width: 365px;
  top: 83.5%;
  margin-left: 523px;
  text-align: justify;
}

#sp02 .cr {
  position: absolute;
  z-index: 1;
  width: 620px;
  top: 84%;
  margin-left: 593px;
}

#sp02 .r_cmt {
  position: absolute;
  z-index: 1;
  width: 383px;
  top: 68%;
  margin-left: 593px;
}

#sp03 .cr p {
  line-height: 1.6;
  color: #ffffff;
}

#sp03 .cr {
  position: absolute;
  z-index: 1;
  width: 620px;
  top: 50%;
  margin-left: 611px;
}

.logo {
  width: 324px;
  display: block;
  margin: 0 auto;
}

#sp_bt_area {
  width: 100%;
  margin-top: -12px;
}

.toWinter {
  width: 732px;
  display: block;
  margin: 42px auto 0;
}

.mt00 {
  margin-top: 0 !important;
}

@media screen and (max-width: 767px) {
  .show_pc {display: none;}
  .show_sp {display: block;}

  #wrap {
    width: 100%;
    display: block;
    margin: 0 auto;
  }

  .top img {
    width: 100%;
  }
  
  .mv img {
    width: 100%;
  }

  #session00 {
    width: 86%;
    padding-top:15px;
  }
  
  #session00 img {
    width: 100%;
  }

  .ses p {
    font-size: 10px;
    line-height: 1.4;
  }



  /* s01 */
  .s01bg {
    background-image: url('../images/201911/s01sp_bg.png');
  }

  #s01 {
    width: 100%;
    padding-top: 20px;
  }

  #s01 img {
    width: 100%;
  }
  
  #s01 .cr {
    width: 53.3333%;
    top: 77.5%;
    margin-left: 6%;
  }
  
  /* s02 */
  .s02bg {
    background-image: url('../images/201911/s02sp_bg.png');
    background-repeat: no-repeat;
    background-size: 100%;
  }

  #s02 {
    width: 100%;
    display: block;
    margin: -24px auto 0;
    padding-top: 68px;
  }

  #s02 img {
    width: 100%;
  }
  
  #s02 .cr {
    width: 80%;;
    top: 83.7%;
    margin-left: 12%;
  }

  /* s03 */
  .s03bg {
    background-image: url('../images/201911/s03sp_bg.png');
  }

  #s03 {
    width: 100%;
    display: block;
    margin: -39px auto 0;
    padding-top: 57px;
  }

  #s03 img {
    width: 86%;
    display: block;
    margin: 0 auto;
    padding-bottom: 30px;
  }
  
  #s03 .cr {
    width: 53.3333%;
    top: 55%;
    margin-left: 10%;
  }
  
  #s03 .cr p {
    letter-spacing: -0.02em;
  }
  
  /* s04 */
  .s04bg {
    background-image: none;
  }

  #s04 {
    width: 100%;
    display: block;
    margin-top: 0px;
    padding-top: 0px;
  }

  #s04 img {
    width: 100%;
  }
  
  #s04 .cr {
    width: 45.333%;
    top: 43%;
    margin-left: 49.5%;
  }
  
  /* s05 */
  .s05bg {
    background-image: none;
  }

  #s05 {
    width: 100%;
    display: block;
    margin: -9px auto 0;
    padding-top: 0px;
    padding-bottom: 13px;
  }

  #s05 img {
    width: 100%;
  }

  #s05 .cr {
    width: 45.333%;
    top: 11%;
    margin-left: 53%;
  }

  /* s06 */
  #s06 {
    width: 100%;
    display: block;
    margin: 0px auto;
    padding-top: 0px;
    padding-bottom: 0px;
  }

  #s06 img {
    width: 100%;
  }

  #s06 .cr {
    width: 53.333%;
    top: 69%;
    margin-left: 6%;
  }
  
  .m02bg,
  .m01bg {
    background-image: url('../images/201911/movie01sp_bg.png');
    background-repeat: no-repeat;
    background-size: 100%;
    padding-top: 24px;
    padding-bottom: 24px;
  }

  .movie01 {
    width: 68.8%;
    display: block;
    padding: 5px;
    margin: 0 auto;
  }

  /* s07 */
  .s07bg {
    background-image: none;
    margin-top: -56px;
  }
  
  .wrap_07 {
    padding-top: 0px;
  }

  #s07 {
    width: 100%;
    display: block;
    background-color: #ffffff;
    margin: 0 auto;
    padding-top: 16px;
    padding-bottom: 0px;
  }

  #s07 img {
    width: 74.2666%;
    display: block;
    margin: 0 auto;
    padding-bottom: 49px;
  }

  #s07 .cr {
    width: 50%;
    top: 85%;
    margin-left: 16%;
  }

  /* bg */
  .btm_bg {
    background-image: url('../images/201911/btmsp_bg.png');
    padding-top: 30px;
    padding-bottom: 35px;
  }
  
  .splLogo {
    margin-top: 25px;
  }
  
  .toList {
    width: 52%;
    margin-top: 0px;
  }
  
  .toList img {
    width: 100%;
  }
  
  .toInsta {
    width: 10.9333%;
    margin-top: 28px;
  }
  
  .toInsta img {
    width: 100%;
  }
  
  .toApli {
    margin-top: 12px;
  }

  .snsLink {
    width: 73%;
    margin-top: 0px;
  }

  .snsLink li img {
    height: 40px;
  }

  .splLogo {
    width: 38.666%;
  }
  
  .toMain {
    width: 85.6%;
    margin-top: 18px;
  }

  .stc {
    width: 82.4%;
    margin: 35px auto 40px;
  }
  

  .stc img {
    width: 100%;
  }

  #btn {
    line-height: 0;
    width: 100%;
    margin-top: 42px;
  }
  
  #btn_no {
    line-height: 0;
    width: 100%;
    margin-top: 42px;
  }

  .btnLinkhalf li {
    width: 100%;
  }

  /* special */
  #spe_wrap {
    width: 100%;
    display: block;
    margin: 0 auto;
    padding-bottom: 30px;
  }
 
  #spe_wrap .spe_top {
    width: 100%;
  }
 
  #spe_wrap .spe_top img,
  #spe_wrap img,
  #sp03 imgp,
  #sp02 img,
  #sp01 img {
    width: 100%;
  }

  #sp01 {
    width: 100%;
  }

  #sp01 .cr {
    width: 50%;
    top: 68.2%;
    margin-left: 6.66%;
  }

  #sp01 .r_cmt {
    width: 42.4%;
    top: 79.5%;
    margin-left: 50%;
  }

  #sp02 .cr {
    width: 90%;
    top: 87.5%;
    margin-left: 6.66%;
  }

  #sp02 .r_cmt {
    width: 42.4%;
    top: 60%;
    margin-left: 50%;
  }

  #sp03 {
    margin-top: -41px;
  }

  #sp03 .cr {
    width: 46.4%;
    top: 44%;
    margin-left: 50%;
  }

  .m02bg {
    background-image: url('../images/201911/movie02_bg_sp.png');
  }

  .logo {
    width: 38.6%;
    margin-top: 28px;
  }
  
  .toWinter {
    width: 85.6%;
    margin-top: 19px;
  }
  
  #sp_bt_area .stc {
    margin-bottom: 0px;
  }
}



/* Animation base */

.animated {
  -webkit-animation-duration: 3s;
  opacity: 0;
  
  animation-duration: 3s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}


.imgClear {
  line-height: 0;
  filter: grayscale(100); 
  /* transition: filter 0.2s; */
}

.imgClear.on {
  filter: grayscale(0); 
  transition: filter 1.5s;
}

.imgMain {
  line-height: 0;
  filter: grayscale(100); 
  transition: filter 4s;
}

.imgMain.on {
  filter: grayscale(0); 
  transition: filter 4s;
}

.animated.infinite {
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
}

.animated.once {
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

.blur-img {
  -webkit-animation-name: imageBlur;
  animation-name: imageBlur;

  transition: 3s;
}


@-webkit-keyframes imageBlur {
  from {
    opacity: 0;
    -webkit-filter: blur(15px);
    -moz-filter: blur(15px);
    -ms-filter: blur(15px);
    -o-filter: blur(15px);
    filter: blur(15px);
  }

  to {
    opacity: 1;
    -webkit-filter: blur(0px);
    -moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
    filter: blur(0px);
  }
}

@keyframes imageBlur {
  from {
    opacity: 0;
    -webkit-filter: blur(15px);
    -moz-filter: blur(15px);
    -ms-filter: blur(15px);
    -o-filter: blur(15px);
    filter: blur(15px);
  }

  to {
    opacity: 1;
    -webkit-filter: blur(0px);
    -moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
    filter: blur(0px);
  }
}




/* Animation End */
