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; }

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 {
  margin: 0;
  padding: 0;
  height: 100%;
  width: 100%; }

.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 {
  position: relative; }

#canvas_confetti {
  height: 100vh;
  width: 100%;
  position: fixed;
  background-image: url(../../share/img/bg.png);
  background-attachment: fixed; }

#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: 48vw;
  position: relative;
  overflow-y: hidden;
  box-shadow: 0px 0px 0px 7px rgba(16, 58, 148, 0.4); }
  #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: -14px;
    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: -10px;
    z-index: 130;
    width: 100%; }
    @media screen and (max-width: 1023px) {
      #mv .item {
        bottom: -15px; } }
    #mv .item img {
      width: 100%; }
    #mv .item .chara01 {
      width: 25%;
      text-align: right; }
      #mv .item .chara01 img {
        max-width: 300px; }
      @media screen and (max-width: 1023px) {
        #mv .item .chara01 {
          width: 30%; } }
    #mv .item .mv_logo {
      margin: 0 -50px;
      width: 36%;
      top: -10px;
      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: -10px;
          margin: 0 -3vw; } }
    #mv .item .chara02 {
      width: 25%;
      text-align: left; }
      #mv .item .chara02 img {
        max-width: 300px; }
      @media screen and (max-width: 1023px) {
        #mv .item .chara02 {
          width: 30%; } }

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 {
  margin-bottom: 30px; }
  #navi ul {
    margin-top: 43px;
    text-align: center;
    display: flex;
    justify-content: center; }
    #navi ul li {
      display: inline-block; }
  #navi.fixed {
    width: 100%;
    z-index: 900;
    position: fixed;
    top: 0;
    background-color: rgba(255, 255, 255, 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: 100%;
    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: solid 5px #e8cf66;
    background-color: #fdfce7;
    border-radius: 25px;
    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: 357px;
      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: 60px; }

    .block-wp h3:before {
      position: absolute;
      display: block;
      left: 0;
      content: "";
      bottom: 4px;
      position: absolute;
      display: block;
      content: "";
      background-size: auto 100%;
      background-repeat: no-repeat;
      background-position: bottom;
      width: 180px;
      height: 140px;
      background-image: url(../../share/img/sdimg_sonsaku.png);
      left: 78px;
      bottom: 26px; }
      @media screen and (max-width: 1023px) {
        .block-wp h3:before {
          width: 32vw;
          height: 24vw;
          left: -8vw;
          bottom: 3vw; } }
  .block-wp .block:nth-child(odd) h3:before {
    width: 180px;
    height: 140px;
    background-image: url(../../share/img/sdimg_sonsaku.png);
    left: 78px;
    bottom: 26px; }
    @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; }
        @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) {
  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: solid 5px #e8cf66;
  background-color: #fdfce7;
  border-radius: 25px;
  padding: 70px 50px 20px 50px;
  position: relative;
}

.block-inner .img{
  position: absolute;
  bottom: -50px;
  right: -60px;
  width: 600px;
}

.block-inner .img img {

  width: 100%;
}

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

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

@media screen and (max-width: 1023px) {
  .block-wp .block-inner {
    padding: 10vw 4vw 3vw 4vw;
    border: solid 2px #e8cf66;
    margin-bottom: 7vw;
  }
  .block-inner .img{
    position: relative;
    top:0;
    left: 0;
    bottom: 0;
    right: 0;
    width: 100%;
  }

}

@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;
  }
}