html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline; }

html {
  line-height: 1; }

ol, ul {
  list-style: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle; }

q, blockquote {
  quotes: none; }
  q:before, q:after, blockquote:before, blockquote:after {
    content: "";
    content: none; }

a img {
  border: none; }

  img{
    image-rendering: -webkit-optimize-contrast;
  }
article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block; }

body {
  font-family: 'Kosugi Maru', sans-serif;
  letter-spacing: 0;
  font-size: 29px;
  line-height: 150%;
  min-width: auto; }
  @media (max-width: 1023px) {
    body {
      font-size: 4.2vw;
      overflow-x: hidden; } }

html, body {
  background-image: url(../../share/img/bg.png);
  background-attachment: scroll,fixed;
  background-repeat: repeat;
  margin: 0;
  padding: 0;
  height: 100%;
  width: 100%; }

.bg-img{
  background: url(../../share/img/bg2.png);
  background-size: 100% auto;
}

.font-mplus {
  font-family: 'M PLUS Rounded 1c', sans-serif; }
  .font-mplus.b400 {
    font-weight: 400; }
  .font-mplus.b500 {
    font-weight: 500; }
  .font-mplus.b700 {
    font-weight: 700; }

@media screen and (max-width: 1023px) {
  img {
    width: 100%; } }

.dummy {
  position: relative;
  z-index: 99999999999;
  opacity: 0.6; }
  .dummy img {
    position: absolute;
    left: 50%;
    margin-left: -640px;
    top: -51px; }

.dummy_btn {
  cursor: pointer;
  z-index: 99999999999999999;
  width: 50px;
  height: 50px;
  background-color: #0051f6;
  position: fixed;
  top: 0;
  left: 0;
  display: block; }

.pc {
  display: inline-block !important; }

.sp {
  display: none !important; }

@media (max-width: 769px) {
  .pc {
    display: none !important; }

  .sp {
    display: inline-block !important; }

  img {
    width: 100%; } }
article {
  overflow-x: hidden;
  position: relative; }

#canvas_confetti {
  height: 100vh;
  width: 100%;
  position: fixed;

/* 
  background-image: url(../../share/img/bg2.png),url(../../share/img/bg.png);
  background-attachment:initial,fixed;
background-repeat: repeat-y,repeat; */
}

#confetti {
  position: fixed;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%; }

.kamihubuki {
  color: #ff538d;
  color: #d84b6e;
  color: #8cd5ff;
  color: #4498d8;
  color: #2bebbc;
  color: #40c9c9;
  color: #ffd200;
  color: #f19743; }

#mv {
  height: 55vw;
  position: relative;
  overflow-y: hidden; }
  #mv .btn-official {
    position: absolute;
    top: 15px;
    z-index: 200;
    right: 0; }
    @media screen and (max-width: 1023px) {
      #mv .btn-official {
        width: 35vw; } }
  #mv:after {
    content: "";
    position: absolute;
    width: 100%;
    bottom: 0px;
    height: 60px;
    background-image: url(../../share/img/mv_bottom.png);
    background-position: center;
    background-size: 100% 60px;
    z-index: 120; }
    @media (max-width: 1280px) {
      #mv:after {
        background-size: auto 60px; } }
  @media (max-width: 1023px) {
    #mv {
      height: 100vw; } }
  #mv .loading {
    background-image: url(../../share/img/bg_sakura.jpg);
    background-size: cover;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0; }
  #mv .youtube_wp {
    position: relative;
    width: 100%;
    padding-top: 56.25%; }
    #mv .youtube_wp:before {
      background-image: url(../../share/img/bg_block.png);
      content: "";
      width: 100%;
      height: 100%;
      display: block;
      position: absolute;
      z-index: 100;
      top: 0;
      background-size: 4px auto;
      opacity: 0.7; }
  #mv .youtube_wp iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important; }
  #mv .item {
    display: flex;
    justify-content: center;
    position: absolute;
    align-items: baseline;
    bottom: 49px;
    z-index: 130;
    width: 100%; }
    @media screen and (max-width: 1023px) {
      #mv .item {
        bottom: 46px; } }
    #mv .item img {
      width: 100%; }
    #mv .item .chara01 {
      width: 25%;
      text-align: right; }
      #mv .item .chara01 img {
        max-width: 400px; }
      @media screen and (max-width: 1023px) {
        #mv .item .chara01 {
          width: 30%; } }
    #mv .item .mv_logo {
      margin: 0 -50px;
      width: 36%;
      top: 42px;
      position: relative;
      text-align: center; }
      #mv .item .mv_logo img {
        max-width: 460px; }
      @media screen and (max-width: 1023px) {
        #mv .item .mv_logo {
          width: 43%;
          top: 23px;
          margin: 0 -3vw; } }
    #mv .item .chara02 {
      width: 25%;
      text-align: left; }
      #mv .item .chara02 img {
        max-width: 400px; }
      @media screen and (max-width: 1023px) {
        #mv .item .chara02 {
          width: 30%; } }


  #mv h1 {
    position: absolute;
    top: 30px;
    left: 30px;
    display: inline-block;
    z-index: 2; }
    #mv h1 img {
      opacity: 0;
      transition: all .8s ease 0s;
      max-width: 280px;
      width: 18vw;
      transform: scale(2, 2); }
      #mv h1 img.ikki_logo {
        opacity: 1;
        transform: scale(1, 1); }
    @media screen and (max-width: 767px) {
      #mv h1 {
        top: 10px;
        left: 10px; }
        #mv h1 img {
          width: 18vw;
          max-width: 100px; } }
      
                

a.hover:hover {
  opacity: 1; }
a.hover img {
  width: 95%; }
  a.hover img:hover {
    animation: big 0.3s;
    animation-fill-mode: forwards; }
  a.hover img:active {
    animation: small 0.2s;
    animation-fill-mode: forwards; }

#navi,#navi_top,#navi_bottom {
  margin-bottom: 30px; }
 #navi_top.marginbottom0 {
    margin-bottom: -30px; }
  #navi ul,#navi_top ul,#navi_bottom ul {
    margin-top: 43px;
    text-align: center;
    display: flex;
    justify-content: center; }
    #navi ul li,#navi_top ul li {
      display: inline-block; }
      #navi,#navi_top{
        margin-left: auto;
        margin-right: auto;
        max-width: 1002px;
      }
      #navi.fixed{
        max-width: inherit;
      }

      #navi_top ul{
        justify-content: space-between;
      }

  #navi.fixed {
    width: 100%;
    z-index: 900;
    position: fixed;
    top: 0;
    background-color: rgba(0, 0, 0, 0.7);
    padding-top: 7px; }
    #navi.fixed ul {
      margin-top: 0; }
@keyframes big {
  0% {
    transform: scale(1); }
  100% {
    transform: scale(1.05); } }
@keyframes small {
  100% {
    transform: scale(0.9); } }
.block-wp {
  font-size: 20px;
  letter-spacing: -0.03em;
  color: #59493f;
  text-align: center;
  max-width: 960px;
  padding: 0 20px;
  margin: 0 auto 0 auto; }
  @media screen and (max-width: 1023px) {
    .block-wp {
      width: 95%;
      padding: 0 0px; } }
  .block-wp:after {
    content: "";
    position: relative;
    bottom: 0;
    background-image: url(../../share/img/block_bottom.png);
    width: 101%;
    height: 34px;
    background-repeat: no-repeat;
    display: block;
    margin: 60px auto 70px auto; }
    @media screen and (max-width: 1023px) {
      .block-wp:after {
        background-size: 100%;
        margin: 4vw auto 5vw auto; } }
  .block-wp .block-inner {
    border: 2px solid #cea43b;
    border-image: linear-gradient(top left, #cea43b 0%, #fffa6e 25%, #fff 50%, #fffa6e 51%, #cea43b 100%);
    border-image-slice: 1;
    background-color: #fdfce7;
    margin-bottom: 40px;
    padding: 70px 50px 20px 50px; }
    @media screen and (max-width: 1023px) {
      .block-wp .block-inner {
        padding: 10vw 4vw 3vw 4vw;
        border: solid 2px #e8cf66;
        margin-bottom: 7vw; } }
  .block-wp h2 {
    text-align: center;
    position: relative; }
    .block-wp h2:after {
      content: "";
      position: relative;
      bottom: 0;
      background-image: url(../../share/img/h2_bottom.png);
      width: 407px;
      height: 28px;
      background-repeat: no-repeat;
      display: block;
      margin: -11px auto 0 auto; }
      @media screen and (max-width: 1023px) {
        .block-wp h2:after {
          width: 50vw;
          background-size: 100%; } }
  .block-wp h3 {
    position: relative;
    top: 135px; }

  
      @media screen and (max-width: 1023px) {
        .block-wp h3:before {
          width: 32vw;
          height: 24vw;
          left: -8vw;
          bottom: 3vw; } }

    @media screen and (max-width: 1023px) {
      .block-wp .block:nth-child(odd) h3:before {
        width: 35vw;
        height: 21vw;
        left: -7vw;
        bottom: 3vw; } }
  .block-wp .block-image img {
    width: 100%; }
  .block-wp .text {
    padding-top: 10px; }
    .block-wp .text P {
      text-align: left;
      line-height: 170%; }
      @media screen and (max-width: 1023px) {
        .block-wp .text P {
          font-size: 3.5vw; } }
    .block-wp .text .img {
      padding: 0 0 0 10px; }
    .block-wp .text.text-img {
      display: flex; }
      .block-wp .text.text-img p {
        max-width: 590px; }
        .block-wp .text.text-img p.w100 {
          max-width:inherit; }
        @media screen and (max-width: 1023px) {
          .block-wp .text.text-img p {
            max-width: 95vw; } }
  .block-wp .btn-link {
    margin-top: 30px; }
    .block-wp .btn-link img {
      max-width: 332px; }
      @media screen and (max-width: 1023px) {
        .block-wp .btn-link img {
          max-width: 50vw; } }

#page_top {
  bottom: -205px;
  right: 15px;
  position: fixed;
  z-index: 100;
  -moz-transition: 0.3s;
  -o-transition: 0.3s;
  -webkit-transition: 0.3s;
  transition: 0.3s; }
  #page_top.fixed {
    bottom: 15px; }
  #page_top.footerscroll {
    position: relative;
    bottom: 0;
    right: 0;
    text-align: right;
    margin: 0 15px 0 0; }
  @media screen and (max-width: 1023px) {
    #page_top img {
      width: 14vw;
      max-width: 50px; } }

.js-animation-fade {
  opacity: 0;
  -moz-transform: scale(0.8);
  -ms-transform: scale(0.8);
  -webkit-transform: scale(0.8);
  transform: scale(0.8);
  -moz-transition: 0.3s;
  -o-transition: 0.3s;
  -webkit-transition: 0.3s;
  transition: 0.3s; }

.js-animation-in {
  opacity: 0;
  -moz-transform: scale(0.9);
  -ms-transform: scale(0.9);
  -webkit-transform: scale(0.9);
  transform: scale(0.9);
  -moz-transition: 0.3s;
  -o-transition: 0.3s;
  -webkit-transition: 0.3s;
  transition: 0.3s; }

footer {
  padding-bottom: 10px;
  line-height: 110%; }

footer .footer_inner {
  width: 100%;
  padding: 10px;
  flex-wrap: wrap;
  max-width: 1200px;
  display: flex;
  justify-content: space-between;
  margin: 0 auto; }
  footer .footer_inner .btn_area img {
    vertical-align: bottom; }

@media (max-width: 1160px) {
  .footer_inner.inner01 .app_area, .footer_inner.inner01 .right {
    margin: 0 auto !important; } }
footer .footer_inner.inner03 .left ul li:after {
  font-size: 14px; }

footer .footer_inner.inner01 .app_area .btn_area a:nth-child(2),
footer .footer_inner.inner01 .app_area .btn_area a:nth-child(3) {
  margin-bottom: 8px; }

footer .footer_inner.inner01 .app_area {
  padding: 15px 30px;
  margin-right: 0px; }

footer .footer_inner.inner01 .app_area .app_info {
  margin-right: 5px; }

.footer_inner.inner01 .right {
  padding-left: 10px; }


.block-wp .block-inner {
  border: 2px solid #cea43b;
  border-image: -webkit-linear-gradient(top left, #cea43b 0%, #fffa6e 25%, #fff 50%, #fffa6e 51%, #cea43b 100%);
  border-image: -o-linear-gradient(top left, #cea43b 0%, #fffa6e 25%, #fff 50%, #fffa6e 51%, #cea43b 100%);
  border-image: linear-gradient(to bottom right, #cea43b 0%, #fffa6e 25%, #fff 50%, #fffa6e 51%, #cea43b 100%);
  border-image-slice: 1;
  background-color: #fffbdd;
  padding: 133px 50px 20px 50px;
  position: relative;
  color: #000;
  box-shadow: 0px 5px 11px 0px rgba(113,113,113,0.2);
}

.block-inner .img{
  position: absolute;
  bottom: -226px;
  right: -349px;
  width: 1000px;
  pointer-events: none;
}
#update-05 .block-inner .img{
  right: -190px;
}
#update-27 .block-inner .img{
  right: -111px;
  bottom: -175px;
}
@media screen and (max-width: 1023px) {
  #update-27 .block-inner .img{
        bottom: auto;
        top: -40vw;
        left: -47vw;
        right: 0;
  }
}

.block-inner .img img {

  width: 100%;
}

.block-wp h3 {
  position: relative;
  top: 135px;
  z-index: 10;
}

@media screen and (max-width: 1023px) {
  .block-wp h3 {
    top: 19vw; } }

@media screen and (max-width: 1023px) {
  .block-wp .block-inner {
    padding: 20vw 4vw 3vw 4vw;
    border: solid 2px #e8cf66;
    margin-bottom: 7vw;
  }
 #update-05 .block-inner .img{
    left: -38vw;
  }
  .block-inner .img{
    position: relative;
    top: -33vw;
    left: -23vw;
    bottom: 0;
    right: 0;
    width: 153vw;
    margin-bottom: -66vw;
  }

}
.block{
  margin-top: -70px;
}

@media screen and (max-width: 1023px) {
.block{
  margin-bottom: 30px;
}.block:last-child{
  margin-bottom: 0px;
}
}
.sns_area,footer .footer_inner.inner01 .sns_area .box{
  width: 100%;
  justify-content: center;
  flex-wrap: wrap;
  text-align: center;
}
.sns_area p{
  width: 100%;
  margin-bottom: 10px;
}
footer .footer_inner.inner01 .app_area{
  background: #111111;
  border-radius: 0;
  border: solid 2px #fff;
}
footer .footer_inner.inner01 .app_area{
  align-items: flex-start;
}
.bnr_area{
  margin-bottom: 0;
}
footer .footer_inner{
  justify-content: center;
}
.logo_area{
  max-width: 940px;
  text-align: left;
  display: block;
  width: 100%;
}
footer .footer_inner.inner02 .bnr_area ul li{
 margin: 0; 
}
footer .footer_inner.inner03{
  max-width: 990px;
  text-align: left;
  display: block;
  width: 100%;
  margin-top: 5px;
}
footer .footer_inner.inner03 .copyright{
  text-align: left;
  line-height: 1.3;
}
footer .footer_inner.inner03 .left ul li:first-child a{
  padding: 0 14px 0 0;
}
footer .footer_inner.inner03 .left ul li:last-child{
  width: 100%;
}
footer .footer_inner.inner03 .left ul li:last-child a{
  padding: 0 14px 0 0;
}

footer .footer_inner.inner03 .left ul li:last-child{
  width: 100%;
  top: -10px;
  position: relative;
}
@media screen and (max-width: 1023px) {

footer .footer_inner.inner01 .sns_area .box img{
  width: 12vw;
  max-width: 60px;
}
footer .footer_inner.inner01 .app_area{
  padding: 15px 4vw;
  max-width: 430px;
}
footer .footer_inner.inner01 .app_area .app_info dl dd,
footer .footer_inner.inner01 .app_area .app_info dl dt{
  font-size: 14px;
  vertical-align: top;
}
footer .footer_inner.inner01 .app_area .app_icon{
  width: 100%;
}
footer .footer_inner.inner01 .app_area .app_icon img{
  width: 40%; 
  margin: 0 auto 10px auto;
}
footer .footer_inner.inner01 .app_area .btn_area{
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
footer .footer_inner.inner01 .app_area .btn_area a{
  width: 48%;
}
footer .footer_inner.inner02 .bnr_area ul li{
margin: 0 auto;
}
footer .footer_inner.inner03 .left ul li a{
  font-size: 13px;
}
footer .footer_inner.inner03 .left ul li:after{
  vertical-align: bottom;
}

}

@media screen and (max-width: 768px) {
  footer .footer_inner.inner01 .app_area .app_info dl dd,
  footer .footer_inner.inner01 .app_area .app_info dl dt{
    font-size: 3.2vw;
    vertical-align: top;
  }
  footer .footer_inner.inner03 .left ul {
    margin-bottom: 20px;
  }
  footer .footer_inner.inner03 .left ul li{
    margin-bottom: 5px;
    width: 100%;
  }
  footer .footer_inner.inner03 .left ul li a{
    font-size: 3.5vw;
  }
  footer .footer_inner.inner03 .left ul li:after{
    display: none;
  }
  footer .footer_inner.inner03 .left ul li:last-child{
    top: 0px;
  }
  
}
.block-image.iframe{
  position:relative;
  width:100%;
  height:0;
  padding-top:60%;
  }
  .block-image.iframe iframe{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  }

  #update-13 .block-inner .img{
    position: absolute;
    bottom: -131px;
    right: -148px;
    width: 1000px;
    pointer-events: none;
  }
@media screen and (max-width: 1023px) {
  #update-13 .block-inner .img{
    position: relative;
    top: -39vw;
    left: -35vw;
    bottom: 0;
    right: 0;
    width: 139vw;
    margin-bottom: -58vw;
  }
}
@media screen and (min-width: 1024px) {
  .title_sp {
    display: none;
  }
  .title_pc {
    display: block;
  }
}

@media screen and (max-width: 1023px) {
  .title_pc {
    display: none;
  }
  .title_sp {
    display: block;
  }
}