/*=============================================================
 01_base
=============================================================*/
@-webkit-keyframes move-chara1 {
  0%, 100% {
    transform: translateY(10px);
  }
  50% {
    transform: translateY(-10px);
  }
}
@keyframes move-chara1 {
  0%, 100% {
    transform: translateY(10px);
  }
  50% {
    transform: translateY(-10px);
  }
}
@-webkit-keyframes infinity-scroll-01 {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -7099px 0;
  }
}
@keyframes infinity-scroll-01 {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -7099px 0;
  }
}
@-webkit-keyframes hand {
  0% {
    transform: translate(-1vw, 1vw);
  }
  5% {
    transform: translate(0, 0);
  }
  20% {
    transform: translate(-1vw, 1vw);
  }
  40% {
    transform: translate(0, 0);
  }
  80% {
    transform: translate(0, 0);
  }
  100% {
    transform: translate(-1vw, 1vw);
  }
}
@keyframes hand {
  0% {
    transform: translate(-1vw, 1vw);
  }
  5% {
    transform: translate(0, 0);
  }
  20% {
    transform: translate(-1vw, 1vw);
  }
  40% {
    transform: translate(0, 0);
  }
  80% {
    transform: translate(0, 0);
  }
  100% {
    transform: translate(-1vw, 1vw);
  }
}
@-webkit-keyframes pop {
  0% {
    transform: translateY(-1vw);
  }
  5% {
    transform: translate(0, 0);
  }
  20% {
    transform: translateY(-1vw);
  }
  40% {
    transform: translate(0, 0);
  }
  80% {
    transform: translate(0, 0);
  }
  100% {
    transform: translateY(-1vw);
  }
}
@keyframes pop {
  0% {
    transform: translateY(-1vw);
  }
  5% {
    transform: translate(0, 0);
  }
  20% {
    transform: translateY(-1vw);
  }
  40% {
    transform: translate(0, 0);
  }
  80% {
    transform: translate(0, 0);
  }
  100% {
    transform: translateY(-1vw);
  }
}
body.intro-on {
  overflow: hidden;
  width: 100vw;
  height: 100vh;
}

#header {
  opacity: 0;
}

#intro {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 100;
  display: none;
}
#intro .logo-move {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #6f5a87;
}
#intro .logo-move video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 102%;
  transform: translate(-50%, -50%);
}
@media only screen and (max-width: 768px) {
  #intro .logo-move video {
    width: 180%;
    min-width: unset;
    min-height: unset;
    mix-blend-mode: lighten;
  }
}
#intro .logo {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
}
#intro .logo img {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 102%;
  transform: translate(-50%, -50%);
}
@media only screen and (max-width: 768px) {
  #intro .logo img {
    width: 180%;
    min-width: unset;
    min-height: unset;
  }
}

#keyvisual {
  position: relative;
  height: 60.85vw;
  overflow: hidden;
  background-color: #fff;
  z-index: 2;
}
@media only screen and (max-width: 1100px) {
  #keyvisual {
    height: 662px;
  }
}
@media only screen and (max-width: 768px) {
  #keyvisual {
    height: 160.15625vw;
  }
}
#keyvisual .inner {
  position: relative;
  height: 100%;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  #keyvisual .inner {
    width: auto;
  }
}
#keyvisual img {
  width: 100%;
}
@media only screen and (max-width: 768px) {
  #keyvisual img {
    width: 100%;
  }
}
#keyvisual .start {
  display: none;
  height: 100%;
  background-color: #64507C;
}
@media only screen and (max-width: 768px) {
  #keyvisual .start {
    display: block;
  }
}
@media only screen and (max-width: 768px) {
  #keyvisual .start::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    background: url("../img/top/keyvisual/fade_bottom-sp.png") repeat-x bottom center;
    background-size: 100%;
  }
}
@media only screen and (max-width: 768px) {
  #keyvisual .start .bg {
    width: 100%;
    height: 100%;
    opacity: 0.6;
    background: url("../img/top/keyvisual/bg-sp.jpg?250516") no-repeat top center #fff;
    background-size: 100% auto;
  }
}
#keyvisual .start .chara {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}
#keyvisual .start .chara img {
  filter: brightness(1);
}
@media only screen and (max-width: 768px) {
  #keyvisual .start .chara .normal {
    opacity: 0;
  }
}
#keyvisual .start .chara .shine {
  position: absolute;
  top: 0;
  left: 0;
  filter: brightness(100) blur(2px);
  opacity: 0;
}
@media only screen and (max-width: 768px) {
  #keyvisual .start .chara .shine {
    opacity: 1;
  }
}
#keyvisual .end {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  transform: rotate(2deg) scale(1.05);
  transition: transform 4s ease;
}
@media only screen and (max-width: 768px) {
  #keyvisual .end {
    display: none;
  }
}
#keyvisual .end.on {
  transform: rotate(0) scale(1);
}
#keyvisual .end .illust {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}
#keyvisual .end .star {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}
@media only screen and (max-width: 768px) {
  #keyvisual .end .star {
    display: none;
  }
}
#keyvisual .ttl-box {
  position: absolute;
  left: 50%;
  top: 33.1vw;
  transform: translateX(-50%);
}
@media only screen and (max-width: 1100px) {
  #keyvisual .ttl-box {
    top: 364px;
  }
}
@media only screen and (max-width: 768px) {
  #keyvisual .ttl-box {
    top: 82.1875vw;
  }
}
#keyvisual .ttl-box h1 {
  position: relative;
  opacity: 0;
  width: 47.65vw;
}
@media only screen and (max-width: 1100px) {
  #keyvisual .ttl-box h1 {
    width: 524px;
  }
}
@media only screen and (max-width: 768px) {
  #keyvisual .ttl-box h1 {
    width: 105.3125vw;
  }
}
#keyvisual .ttl-box .lagu {
  position: absolute;
  top: -4.2vw;
  right: -2.9vw;
  opacity: 0;
  width: 13.3vw;
  -webkit-animation: move-chara1 5s infinite ease both;
          animation: move-chara1 5s infinite ease both;
}
@media only screen and (max-width: 1100px) {
  #keyvisual .ttl-box .lagu {
    width: 146px;
    top: -46px;
    right: -32px;
  }
}
@media only screen and (max-width: 768px) {
  #keyvisual .ttl-box .lagu {
    display: none;
  }
}
#keyvisual .ttl-box .lagu .wh {
  position: absolute;
  top: 0;
  left: 0;
}
#keyvisual .ttl-box .aelu {
  position: absolute;
  top: -4vw;
  left: -3.75vw;
  opacity: 0;
  width: 12.4vw;
  -webkit-animation: move-chara1 5s infinite ease both;
          animation: move-chara1 5s infinite ease both;
}
@media only screen and (max-width: 1100px) {
  #keyvisual .ttl-box .aelu {
    width: 136px;
    top: -44px;
    left: -41px;
  }
}
@media only screen and (max-width: 768px) {
  #keyvisual .ttl-box .aelu {
    display: none;
  }
}
#keyvisual .ttl-box .aelu .wh {
  position: absolute;
  top: 0;
  left: 0;
}
#keyvisual .pop-news {
  position: absolute;
  width: 12.6vw;
  top: 42vw;
  right: calc(50% - 37.25vw);
  opacity: 0;
}
@media only screen and (max-width: 1100px) {
  #keyvisual .pop-news {
    width: 138px;
    top: 462px;
    right: calc(50% - 425px);
  }
}
@media only screen and (max-width: 768px) {
  #keyvisual .pop-news {
    width: 40.625vw;
    top: 122.5vw;
    right: 2.34375vw;
  }
}
#keyvisual .pop-news span {
  position: absolute;
  bottom: 1.2vw;
  left: 5.1vw;
  width: 2.9vw;
  -webkit-animation: hand 2.5s ease infinite;
          animation: hand 2.5s ease infinite;
}
@media only screen and (max-width: 1100px) {
  #keyvisual .pop-news span {
    width: 31px;
    bottom: 13px;
    left: 56px;
  }
}
@media only screen and (max-width: 768px) {
  #keyvisual .pop-news span {
    width: 9.375vw;
    bottom: 4.6875vw;
    left: 17.1875vw;
  }
}
#keyvisual .pop-news a {
  display: block;
  transition: all 0.3s ease;
}
#keyvisual .pop-news a:hover {
  transform: scale(1.1);
}
#keyvisual .pop-news a:hover span {
  -webkit-animation-play-state: paused;
          animation-play-state: paused;
}
#keyvisual .pop-shop {
  position: absolute;
  width: 8.9vw;
  top: 31.5vw;
  right: calc(50% - 35.4vw);
  opacity: 0;
}
@media only screen and (max-width: 1100px) {
  #keyvisual .pop-shop {
    width: 98px;
    top: 342px;
    right: calc(50% - 403px);
  }
}
@media only screen and (max-width: 768px) {
  #keyvisual .pop-shop {
    display: none;
  }
}
#keyvisual .pop-shop span {
  position: absolute;
  bottom: -0.6vw;
  left: 3.2vw;
  width: 2.9vw;
  -webkit-animation: hand 2.5s ease infinite;
          animation: hand 2.5s ease infinite;
}
@media only screen and (max-width: 1100px) {
  #keyvisual .pop-shop span {
    width: 31px;
    bottom: -6px;
    left: 35px;
  }
}
@media only screen and (max-width: 768px) {
  #keyvisual .pop-shop span {
    width: 9.375vw;
    bottom: 4.6875vw;
    left: 17.1875vw;
  }
}
#keyvisual .pop-shop a {
  display: block;
  transition: all 0.3s ease;
}
#keyvisual .pop-shop a:hover {
  transform: scale(1.1);
}
#keyvisual .pop-shop a:hover span {
  -webkit-animation-play-state: paused;
          animation-play-state: paused;
}
#keyvisual .pickup {
  position: absolute;
  width: 15.35vw;
  top: 42.4vw;
  left: calc(50% - 37.2vw);
  opacity: 0;
}
@media only screen and (max-width: 1100px) {
  #keyvisual .pickup {
    width: 168px;
    top: 466px;
    left: calc(50% - 425px);
  }
}
@media only screen and (max-width: 768px) {
  #keyvisual .pickup {
    width: 52.03125vw;
    top: 119.375vw;
    left: 3.75vw;
  }
}
#keyvisual .pickup .frame {
  position: relative;
  z-index: 2;
}
#keyvisual .pickup .frame::after {
  content: "";
  display: block;
  position: absolute;
  top: 3.75vw;
  left: 50%;
  transform: translateX(-50%);
  width: 3.5vw;
  height: 3.5vw;
  background: url("../img/top/keyvisual/pickup_arrow.svg") no-repeat top center;
  background-size: contain;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 1100px) {
  #keyvisual .pickup .frame::after {
    top: 41px;
    width: 38px;
    height: 38px;
  }
}
@media only screen and (max-width: 768px) {
  #keyvisual .pickup .frame::after {
    top: 15.625vw;
    width: 11.5625vw;
    height: 11.25vw;
  }
}
#keyvisual .pickup .thumb {
  position: absolute;
  top: 1.55vw;
  left: 1.35vw;
  width: 12.6vw;
  height: 6.975vw;
  border-radius: 16px;
  overflow: hidden;
}
@media only screen and (max-width: 1100px) {
  #keyvisual .pickup .thumb {
    width: 138px;
    height: 76px;
    top: 16px;
    left: 15px;
  }
}
@media only screen and (max-width: 768px) {
  #keyvisual .pickup .thumb {
    top: 6.875vw;
    left: 1.25vw;
    width: 49.53125vw;
    height: 27.65625vw;
  }
}
#keyvisual .pickup .thumb img {
  width: 100%;
}
#keyvisual .pickup:hover .frame::after {
  transform: translateX(-50%) scale(1.2);
}

.btn-shop {
  display: none;
}
@media only screen and (max-width: 768px) {
  .btn-shop {
    display: block;
    position: relative;
    padding-top: 3.90625vw;
    background-color: #b4eef6;
    z-index: 2;
  }
}
@media only screen and (max-width: 768px) {
  .btn-shop::after {
    content: "";
    display: block;
    width: 100%;
    height: 17.1875vw;
    background-color: #fff;
  }
}
@media only screen and (max-width: 768px) {
  .btn-shop a {
    display: block;
    margin: 0 3.125vw 3.90625vw;
    opacity: 0;
  }
}
.btn-shop img {
  width: 100%;
}

@media only screen and (max-width: 768px) {
  #content img {
    width: 100%;
  }
}
#content .bg-shine {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: url("../img/bg_shine.jpg") repeat-x top center;
  background-size: cover;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  #content .bg-shine {
    background: url("../img/bg_shine-sp.jpg") no-repeat top center;
    background-size: cover;
  }
}
#content .bg-con {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: url("../img/bg.png") repeat-x top center;
  background-size: cover;
}
@media only screen and (max-width: 768px) {
  #content .bg-con {
    background: url("../img/bg-sp.png") no-repeat top center;
    background-size: cover;
  }
}
#content .inner {
  width: 1100px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  #content .inner {
    width: auto;
  }
}
#content section {
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media only screen and (max-width: 768px) {
  #content section {
    left: 0;
    transform: unset;
  }
}
#content section .btn {
  opacity: 0;
}
#content section .sd-chara, #content section .sd-chara1, #content section .sd-chara2 {
  opacity: 0;
}
#content section .ttl-box {
  text-align: center;
}
#content section .ttl-box .deco {
  position: relative;
  top: -20px;
  width: 220px;
  height: 60px;
  margin: 0 auto -12px;
  overflow: hidden;
  width: 0;
}
@media only screen and (max-width: 768px) {
  #content section .ttl-box .deco {
    top: -3.125vw;
    height: 9.375vw;
    margin: 0 auto -1.875vw;
  }
}
#content section .ttl-box .deco img {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  margin-top: 0 !important;
}
#content section .ttl-box .deco svg {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
#content section .ttl-box .deco svg path {
  fill: #fff;
}
#content section .ttl-box .deco.bg-on {
  position: relative;
}
#content section .ttl-box .deco.bg-on::after {
  content: "";
  display: block;
  position: absolute;
  left: 49.5%;
  top: 51.6%;
  transform: translate(-50%, -50%);
  width: 204px;
  height: 50px;
  background: url("../img/bg_txt_deco.svg") no-repeat top center;
  background-size: contain;
}
#content section .ttl-box .deco.bg-on svg {
  z-index: 2;
}
#content section .ttl-box .txt-deco {
  display: inline-block;
  position: relative;
  margin-bottom: 20px;
  opacity: 0;
}
@media only screen and (max-width: 768px) {
  #content section .ttl-box .txt-deco {
    margin-bottom: 4.6875vw;
  }
}
#content section .ttl-box .txt-deco p {
  font-size: 18px;
  font-family: "Fredoka", sans-serif;
  font-weight: 600;
  color: #fff;
}
@media only screen and (max-width: 768px) {
  #content section .ttl-box .txt-deco p {
    font-size: 3.125vw;
  }
}
#content section .ttl-box .txt-deco span {
  position: absolute;
  top: 52%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 380px;
  height: 15px;
  background: url("../img/icon/txt_deco_w.svg") no-repeat top center;
  background-size: contain;
}
@media only screen and (max-width: 768px) {
  #content section .ttl-box .txt-deco span {
    width: 58.4375vw;
  }
}
#content section .ttl-box h2 {
  opacity: 0;
}
@media only screen and (max-width: 768px) {
  #content section .ttl-box h2 {
    margin: 0 auto;
  }
}
#content section .ttl-box .jp {
  font-size: 22px;
  color: #fff;
  font-family: "Zen Maru Gothic", serif;
  font-weight: 600;
  margin-top: 15px;
  opacity: 0;
}
@media only screen and (max-width: 768px) {
  #content section .ttl-box .jp {
    margin-top: 2.34375vw;
    font-size: 3.75vw;
  }
}
#content section .ttl-box.dark .deco svg path {
  fill: #64507C;
}
#content section .ttl-box.dark .txt-deco p {
  color: #64507C;
}
#content section .ttl-box.dark .txt-deco span {
  background: url("../img/icon/txt_deco_d.svg") no-repeat top center;
  background-size: contain;
}
#content section .ttl-box.dark .jp {
  color: #64507C;
}

#about {
  position: relative;
  padding-bottom: 162px;
  margin-top: -6.6vw;
  border-radius: 100px;
  background: url("../img/top/about/bg.jpg") no-repeat bottom center;
  background-size: cover;
  z-index: 3;
  min-width: 1100px;
}
@media only screen and (max-width: 1100px) {
  #about {
    margin-top: -49px;
  }
}
@media only screen and (max-width: 768px) {
  #about {
    margin-top: -11.875vw;
    padding-bottom: 15.15625vw;
    min-width: unset;
    border-radius: 10.9375vw;
    margin-top: -9.375vw;
    background: url("../img/top/about/bg-sp.jpg") no-repeat top center;
    background-size: cover;
  }
}
#about::before {
  content: "";
  display: block;
  position: absolute;
  top: 20px;
  left: 20px;
  width: calc(100% - 40px);
  height: calc(100% - 40px);
  border: 2px solid #fff;
  box-sizing: border-box;
  border-radius: 90px;
}
@media only screen and (max-width: 768px) {
  #about::before {
    top: 0;
    left: 0;
    width: 93.75vw;
    height: calc(100% - 6.2vw);
    margin: 2.8125vw 3.75vw;
    border-radius: 9.375vw;
    border-width: 0.46875vw;
  }
}
#about .inner {
  position: relative;
}
#about .sd-chara {
  width: 124px;
  position: absolute;
  top: 40px;
  left: 213px;
}
@media only screen and (max-width: 768px) {
  #about .sd-chara {
    width: 19.375vw;
    top: -3.28125vw;
    left: 1.25vw;
  }
}
#about .ttl-box {
  margin-bottom: 50px;
}
@media only screen and (max-width: 768px) {
  #about .ttl-box {
    margin-bottom: 9.375vw;
  }
}
@media only screen and (max-width: 768px) {
  #about .ttl-box .deco {
    width: 32.96875vw !important;
    margin-bottom: -0.78125vw !important;
  }
}
#about .ttl-box .deco img {
  margin-top: -22px !important;
}
@media only screen and (max-width: 768px) {
  #about .ttl-box .deco img {
    margin-top: -2.96875vw !important;
  }
}
@media only screen and (max-width: 768px) {
  #about .ttl-box h2 {
    width: 50vw;
    margin: 0 auto;
  }
}
#about .text {
  text-align: center;
  opacity: 0;
}
@media only screen and (max-width: 768px) {
  #about .text {
    margin-bottom: 1.5625vw;
  }
}
#about .text p.txt1 {
  font-size: 42px;
  font-family: "Zen Maru Gothic", serif;
  font-weight: 700;
  color: #FDF303;
  margin-bottom: 25px;
}
@media only screen and (max-width: 768px) {
  #about .text p.txt1 {
    font-size: 5.46875vw;
    margin-bottom: 5vw;
    line-height: 1.4;
  }
}
#about .text p.txt {
  font-size: 22px;
  line-height: 2.4;
  color: #fff;
  font-family: "M PLUS Rounded 1c", sans-serif;
}
@media only screen and (max-width: 768px) {
  #about .text p.txt {
    font-size: 3.4375vw;
    line-height: 2;
  }
}
#about .text p.txt span.bold {
  position: relative;
  font-weight: 700;
}
@media only screen and (max-width: 768px) {
  #about .text p.txt span.bold {
    font-size: 3.75vw;
  }
}
#about .text p.txt span.line {
  position: relative;
}
#about .text p.txt span.line::before {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 13px;
  border-radius: 20px;
  background-color: rgba(255, 250, 137, 0.4);
}
#about .text p.txt span.line:nth-of-type(3) {
  margin-left: -10px;
}
#about .text p.txt span.line:nth-of-type(5) {
  margin-left: -10px;
}

#news {
  padding: 142px 0 142px;
  min-width: 1100px;
}
@media only screen and (max-width: 768px) {
  #news {
    padding: 7.1875vw 0 12.5vw;
    min-width: unset;
  }
}
#news .inner {
  position: relative;
}
#news .sd-chara {
  position: absolute;
  top: 42px;
  right: 194px;
  width: 161px;
}
@media only screen and (max-width: 768px) {
  #news .sd-chara {
    width: 23.125vw;
    top: 6.875vw;
    right: 1.40625vw;
  }
}
#news .sd-chara img {
  width: 100%;
}
#news .ttl-box {
  margin-bottom: 52px;
}
@media only screen and (max-width: 768px) {
  #news .ttl-box h2 {
    width: 40.625vw;
  }
}
#news .news-wrap {
  position: relative;
  opacity: 0;
  width: 100vw;
  left: 50%;
  transform: translateX(-50%);
  width: 72.5vw;
}
@media only screen and (max-width: 768px) {
  #news .news-wrap {
    width: 100vw;
  }
}
#news .news-wrap .swiper-button-prev, #news .news-wrap .swiper-button-next {
  top: 48%;
  width: 80px;
  height: 80px;
  background: url("../img/top/news/arrow.svg") no-repeat top center;
  background-size: contain;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 768px) {
  #news .news-wrap .swiper-button-prev, #news .news-wrap .swiper-button-next {
    width: 12.5vw;
    height: 12.5vw;
    outline: none;
  }
}
#news .news-wrap .swiper-button-prev::after, #news .news-wrap .swiper-button-next::after {
  display: none;
}
#news .news-wrap .swiper-button-prev {
  left: calc(50% - 782px);
  transform: scale(-1, -1);
}
@media only screen and (max-width: 1600px) {
  #news .news-wrap .swiper-button-prev {
    left: -120px;
  }
}
@media only screen and (max-width: 768px) {
  #news .news-wrap .swiper-button-prev {
    left: 2.34375vw;
  }
}
#news .news-wrap .swiper-button-next {
  right: calc(50% - 782px);
}
@media only screen and (max-width: 1600px) {
  #news .news-wrap .swiper-button-next {
    right: -120px;
  }
}
@media only screen and (max-width: 768px) {
  #news .news-wrap .swiper-button-next {
    right: 2.34375vw;
  }
}
#news .news-wrap .swiper-button-disabled {
  opacity: 0;
}
#news .news-list {
  margin-bottom: 58px;
  min-width: 1100px;
}
@media only screen and (max-width: 768px) {
  #news .news-list {
    margin-bottom: 8.75vw;
    min-width: unset;
  }
}
#news .news-list.swiper {
  width: 100%;
  max-width: 1450px;
  margin: 0 auto 58px;
  overflow: inherit !important;
}
@media only screen and (max-width: 768px) {
  #news .news-list.swiper {
    max-width: 57.8125vw;
    margin-bottom: 8.75vw;
  }
}
#news .news-list ul {
  padding: 10px 0;
}
#news .news-list ul.center {
  justify-content: center;
}
@media only screen and (max-width: 768px) {
  #news .news-list ul.center {
    justify-content: left;
  }
}
#news .news-list ul.center li:last-child {
  margin-right: 0 !important;
}
#news .news-list ul li {
  position: relative;
  border: 3px solid #64507C;
  border-radius: 20px;
  padding-bottom: 20px;
  background-color: #fff;
  box-sizing: border-box;
  min-height: 314px;
  transition: all 0.2s ease;
}
@media only screen and (max-width: 768px) {
  #news .news-list ul li {
    margin: 0;
    border-radius: 3.75vw;
    border-width: 0.46875vw;
    min-width: 56.875vw;
  }
}
#news .news-list ul li.active {
  border-color: #EB5A91;
}
#news .news-list ul li.new::before {
  content: "";
  width: 80px;
  height: 80px;
  position: absolute;
  top: -25px;
  left: -25px;
  background: url("../img/icon/new.svg") no-repeat top center;
  background-size: contain;
  z-index: 2;
}
@media only screen and (max-width: 768px) {
  #news .news-list ul li.new::before {
    width: 13.59375vw;
    height: 12.5vw;
    top: -3.90625vw;
    left: -3.90625vw;
  }
}
#news .news-list ul li .thumb {
  position: relative;
  height: 10.6vw;
  max-height: 212px;
  overflow: hidden;
  margin-bottom: 16px;
}
@media only screen and (max-width: 1500px) {
  #news .news-list ul li .thumb {
    height: 156px;
  }
}
@media only screen and (max-width: 768px) {
  #news .news-list ul li .thumb {
    height: 33.125vw;
    margin-bottom: 2.34375vw;
    max-height: unset;
  }
}
#news .news-list ul li .thumb img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: all 0.3s ease;
}
#news .news-list ul li .txt-box {
  padding: 0 18px;
  height: 120px;
}
@media only screen and (max-width: 768px) {
  #news .news-list ul li .txt-box {
    height: 18.28125vw;
  }
}
#news .news-list ul li .txt-box .wrap-flex {
  margin-bottom: 12px;
}
@media only screen and (max-width: 768px) {
  #news .news-list ul li .txt-box .wrap-flex {
    margin-bottom: 1.875vw;
  }
}
#news .news-list ul li .txt-box time {
  font-size: 20px;
  line-height: 1;
  font-family: "Zen Maru Gothic", serif;
  font-weight: 500;
  margin-right: 10px;
}
@media only screen and (max-width: 768px) {
  #news .news-list ul li .txt-box time {
    font-size: 3.75vw;
  }
}
#news .news-list ul li .txt-box .category {
  position: relative;
  width: 108px;
  font-size: 14px;
  line-height: 1;
  padding: 3px 0 4px;
  font-family: "Zen Maru Gothic", serif;
  font-weight: 500;
  border: 1px solid #64507C;
  border-radius: 20px;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  #news .news-list ul li .txt-box .category {
    width: 17.1875vw;
    font-size: 2.1875vw;
  }
}
#news .news-list ul li .txt-box .category::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 4px;
  transform: translateY(-50%);
  width: 9px;
  height: 9px;
  border-radius: 10px;
  background-color: #64507C;
}
@media only screen and (max-width: 768px) {
  #news .news-list ul li .txt-box .category::before {
    left: 0.625vw;
    width: 1.40625vw;
    height: 1.40625vw;
    border-radius: 1.5625vw;
  }
}
#news .news-list ul li .txt-box .category.info {
  border-color: #FD95D4;
}
#news .news-list ul li .txt-box .category.info::before {
  background-color: #FD95D4;
}
#news .news-list ul li .txt-box .category.comic {
  border-color: #79D5B8;
}
#news .news-list ul li .txt-box .category.comic::before {
  background-color: #79D5B8;
}
#news .news-list ul li .txt-box .category.music {
  border-color: #CFB1F8;
  padding-left: 5px;
}
@media only screen and (max-width: 768px) {
  #news .news-list ul li .txt-box .category.music {
    padding-left: 0.78125vw;
  }
}
#news .news-list ul li .txt-box .category.music::before {
  background-color: #CFB1F8;
}
#news .news-list ul li .txt-box .category.movie {
  border-color: #FF9393;
}
#news .news-list ul li .txt-box .category.movie::before {
  background-color: #FF9393;
}
#news .news-list ul li .txt-box .category.goods {
  border-color: #FFAC5A;
}
#news .news-list ul li .txt-box .category.goods::before {
  background-color: #FFAC5A;
}
#news .news-list ul li .txt-box .text {
  font-size: 16px;
  line-height: 1.8;
  text-align: left;
  position: relative;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  margin-right: 0;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
@media only screen and (max-width: 768px) {
  #news .news-list ul li .txt-box .text {
    font-size: 2.8125vw;
    line-height: 1.5;
  }
}
#news .news-list ul li a {
  width: 100%;
  display: block;
  text-decoration: none;
  color: #64507C;
  overflow: hidden;
  border-radius: 18px;
}
#news .news-list ul li:hover {
  border-color: #EB5A91;
}
#news .news-list ul li:hover .thumb img {
  transform: scale(1.1);
}
#news .news-list .swiper {
  width: 100%;
  height: 100%;
}
#news .news-list .swiper-slide {
  text-align: center;
  font-size: 18px;
  background: #fff;
  display: flex;
  justify-content: center;
  align-items: flex-start;
}
#news .news-list .swiper-slide img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

#comic {
  position: relative;
  padding-bottom: 95px;
  border-radius: 100px;
  border: 20px solid #fff;
  background: url("../img/top/comic/bg.jpg") repeat-x top center;
  background-size: cover;
  z-index: 2;
  min-width: 1100px;
  -webkit-animation: infinity-scroll-01 100s infinite linear both;
          animation: infinity-scroll-01 100s infinite linear both;
}
@media only screen and (max-width: 768px) {
  #comic {
    min-width: unset;
    padding-bottom: 25vw;
    border-radius: 10.9375vw;
    border-width: 3.75vw;
  }
}
#comic .inner {
  position: relative;
}
#comic .sd-chara1 {
  position: absolute;
  top: 38px;
  left: 220px;
}
@media only screen and (max-width: 768px) {
  #comic .sd-chara1 {
    width: 20.9375vw;
    top: 3.75vw;
    left: 0vw;
  }
}
#comic .sd-chara2 {
  position: absolute;
  bottom: -40px;
  right: 62px;
  width: 135px;
}
@media only screen and (max-width: 768px) {
  #comic .sd-chara2 {
    width: 21.09375vw;
    bottom: -22.1875vw;
    right: -2.65625vw;
  }
}
#comic .sd-chara2 img {
  width: 100%;
}
#comic .pop {
  position: absolute;
  bottom: 102px;
  right: 15px;
  opacity: 0;
  transform-origin: bottom left;
}
@media only screen and (max-width: 768px) {
  #comic .pop {
    width: 21.25vw;
    bottom: 0.78125vw;
    right: -3.125vw;
  }
}
#comic .pop img {
  -webkit-animation: pop 2.5s ease infinite;
          animation: pop 2.5s ease infinite;
}
#comic .ttl-box {
  margin-bottom: 48px;
}
#comic .ttl-box .deco {
  margin-top: -25px !important;
}
@media only screen and (max-width: 768px) {
  #comic .ttl-box .deco {
    top: -1.875vw !important;
    margin-top: -6.875vw !important;
  }
}
@media only screen and (max-width: 768px) {
  #comic .ttl-box h2 {
    width: 44.6875vw;
  }
}
#comic .box {
  opacity: 0;
  position: relative;
  width: 860px;
  margin: 0 auto;
  padding: 25px 0 50px;
  border-radius: 40px;
  border: 4px solid #64507C;
  background-color: #fff;
}
@media only screen and (max-width: 1100px) {
  #comic .box {
    left: 50%;
    transform: translateX(-52.2%);
    margin: 0;
  }
}
@media only screen and (max-width: 768px) {
  #comic .box {
    width: 93.75vw;
    left: 0;
    transform: unset;
    border-radius: 6.25vw;
    border-width: 0.625vw;
    padding: 3.75vw 0 7.03125vw;
  }
}
#comic .box .new {
  position: absolute;
  top: -12px;
  left: 40px;
  z-index: 3;
}
@media only screen and (max-width: 768px) {
  #comic .box .new {
    width: 13.59375vw;
    height: 13.59375vw;
    top: -1.25vw;
    left: 3.75vw;
    overflow: hidden;
    border-radius: 15.625vw;
  }
}
@media only screen and (max-width: 768px) {
  #comic .box .new img {
    transform: scale(1.1);
  }
}
#comic .box .update {
  position: relative;
  display: inline-block;
  font-size: 20px;
  font-family: "Fredoka", sans-serif;
  font-weight: 600;
  padding: 2px 20px 2px 54px;
  color: #FE4D92;
  border: 3px solid #FE4D92;
  border-radius: 50px;
  background-color: #fff;
  margin-left: 100px;
  z-index: 2;
}
@media only screen and (max-width: 768px) {
  #comic .box .update {
    font-size: 3.75vw;
    margin-left: 11.875vw;
    padding: 0.3125vw 3.90625vw 0.3125vw 5.3125vw;
  }
}
#comic .box .image {
  position: relative;
  width: 724px;
  height: 480px;
  margin: 0 auto 44px;
  overflow: hidden;
  margin-top: -20px;
}
@media only screen and (max-width: 768px) {
  #comic .box .image {
    width: 79.0625vw;
    height: 62.8125vw;
    margin-bottom: 5.15625vw;
    margin-top: -3.125vw;
  }
}
#comic .box .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  transition: all 0.3s ease;
}

#movie {
  padding: 230px 0 142px;
  margin-top: -85px;
  min-width: 1100px;
}
@media only screen and (max-width: 768px) {
  #movie {
    padding: 18.125vw 0 14.84375vw;
    margin-top: -10.15625vw;
    min-width: unset;
  }
}
#movie .bg-movie {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  background: url("../img/top/movie/bg.png") no-repeat top center;
  background-size: cover;
}
@media only screen and (max-width: 768px) {
  #movie .bg-movie {
    background: url("../img/top/movie/bg-sp.png") no-repeat top center;
    background-size: cover;
  }
}
#movie .inner {
  position: relative;
}
#movie .sd-chara {
  position: absolute;
  top: 35px;
  left: 220px;
}
@media only screen and (max-width: 768px) {
  #movie .sd-chara {
    width: 18.75vw;
    top: 6.25vw;
    left: 0.78125vw;
  }
}
#movie .ttl-box {
  margin-bottom: 55px;
}
@media only screen and (max-width: 768px) {
  #movie .ttl-box h2 {
    width: 44.6875vw;
  }
}
#movie .list {
  position: relative;
  overflow: hidden;
  margin: 0 auto 44px;
  display: flex;
  justify-content: center;
  z-index: 3;
  opacity: 0;
}
@media only screen and (max-width: 768px) {
  #movie .list {
    display: block;
    max-width: unset;
    margin-bottom: 6.875vw;
    overflow: unset;
  }
}
#movie .list ul li.slide {
  margin: 0 55px;
  text-align: center;
  transition: all 1s ease;
  opacity: 0.5;
}
@media only screen and (max-width: 768px) {
  #movie .list ul li.slide {
    width: auto;
    margin: 0 4.6875vw;
  }
}
#movie .list ul li.slide a {
  text-decoration: none;
  color: #64507C;
}
#movie .list ul li.slide .thumb {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 30px;
  overflow: hidden;
  margin-bottom: 14px;
}
@media only screen and (max-width: 768px) {
  #movie .list ul li.slide .thumb {
    border-radius: 4.6875vw;
    margin-bottom: 2.1875vw;
  }
}
#movie .list ul li.slide .thumb img {
  width: 100%;
}
@media only screen and (max-width: 768px) {
  #movie .list ul li.slide .thumb img {
    width: 120%;
  }
}
#movie .list ul li.slide .thumb::after {
  content: "";
  position: absolute;
  top: 46%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 132px;
  height: 132px;
  background: url("../img/top/movie/play.svg") no-repeat top center;
  background-size: contain;
  opacity: 0;
  transition: all 0.3s 0.5s ease;
}
@media only screen and (max-width: 768px) {
  #movie .list ul li.slide .thumb::after {
    top: 52%;
    width: 15vw;
    height: 15vw;
  }
}
#movie .list ul li.slide .title {
  opacity: 0;
  width: 600px;
  padding: 4px 0;
  margin: 0 auto;
  border-radius: 100px;
  text-align: center;
  background-color: #fff;
  transform: scale(0.6);
  transition: all 0.6s 0.1s ease;
}
@media only screen and (max-width: 768px) {
  #movie .list ul li.slide .title {
    width: 64.0625vw;
    padding: 0.625vw 1.5625vw;
  }
}
#movie .list ul li.slide .title p {
  font-size: 16px;
  line-height: 1.3;
}
@media only screen and (max-width: 768px) {
  #movie .list ul li.slide .title p {
    font-size: 3.125vw;
  }
}
#movie .list ul li.slide.slick-current, #movie .list ul li.slide.is-active-next {
  opacity: 1;
  transform: scale(1.15);
}
#movie .list ul li.slide.slick-current .thumb::after, #movie .list ul li.slide.is-active-next .thumb::after {
  opacity: 1;
}
#movie .list ul li.slide.slick-current .title, #movie .list ul li.slide.is-active-next .title {
  opacity: 1;
  transform: scale(1);
}
#movie .list ul.only .slick-track {
  transform: translate3d(0px, 0px, 0px) !important;
}
@-webkit-keyframes onText {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
    transform: scale(1.1);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes onText {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
    transform: scale(1.1);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
#movie .list .slick-list {
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  width: 2986px;
  margin: 0 auto;
  padding: 42px 1089px !important;
  overflow: unset;
}
@media only screen and (max-width: 768px) {
  #movie .list .slick-list {
    width: 100%;
    padding: 5.3125vw 12.5vw !important;
  }
}
#movie .list .slick-arrow {
  position: absolute;
  top: 37%;
  width: 80px;
  height: 80px;
  font-size: 0;
  border: none;
  background: url("../img/top/news/arrow.svg") no-repeat top center;
  background-size: contain;
  transition: all 0.3s ease;
  z-index: 2;
}
@media only screen and (max-width: 768px) {
  #movie .list .slick-arrow {
    top: 27%;
    width: 12.5vw;
    height: 12.5vw;
  }
}
#movie .list .slick-arrow::after {
  display: none;
}
@media only screen and (max-width: 768px) {
  #movie .list .slick-arrow {
    display: block;
  }
}
#movie .list .slick-prev {
  left: calc(50% - 470px);
  transform: scale(-1, -1);
}
@media only screen and (max-width: 768px) {
  #movie .list .slick-prev {
    left: 3.125vw;
  }
}
#movie .list .slick-next {
  right: calc(50% - 470px);
}
@media only screen and (max-width: 768px) {
  #movie .list .slick-next {
    right: 3.125vw;
  }
}
#movie .list .slick-dots {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 15px;
}
@media only screen and (max-width: 768px) {
  #movie .list .slick-dots {
    margin-top: 2.34375vw;
  }
}
#movie .list .slick-dots li button {
  display: block;
  width: 14px;
  height: 14px;
  font-size: 0;
  border-radius: 20px;
  border: 2px solid #fff;
  background-color: transparent;
  margin: 0 4px;
  transition: all 0.25s ease;
}
@media only screen and (max-width: 768px) {
  #movie .list .slick-dots li button {
    width: 1.5625vw;
    height: 1.5625vw;
    border-radius: 3.125vw;
    margin: 0 0.625vw;
  }
}
#movie .list .slick-dots li.slick-active button {
  background-color: #EB5A91;
}

#character {
  position: relative;
  padding-bottom: 142px;
  min-width: 1100px;
}
@media only screen and (max-width: 768px) {
  #character {
    padding-bottom: 14.84375vw;
    min-width: unset;
  }
}
#character .bg-round {
  position: absolute;
  top: 8px;
  left: 50%;
  width: 100%;
  height: 100%;
  min-width: 2000px;
  transform: translateX(-50%);
  background: url("../img/bg_round.png") no-repeat top center;
  background-size: 100% auto;
}
@media only screen and (max-width: 768px) {
  #character .bg-round {
    top: 0;
    min-width: unset;
    background: url("../img/bg_round-sp.png") no-repeat top center;
    background-size: 100% auto;
  }
}
#character .bg-round img {
  width: 100%;
}
#character .bg-round::before {
  content: "";
  width: 100%;
  height: 50%;
  position: absolute;
  bottom: 0;
  left: 0;
  background-color: #fff;
}
#character .bg-round::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../img/top/character/bg-pc.png") no-repeat bottom center;
  background-size: 100% auto;
}
@media only screen and (max-width: 768px) {
  #character .bg-round::after {
    bottom: 0;
    background: url("../img/top/character/bg-sp.png") no-repeat bottom center;
    background-size: 100% auto;
  }
}
#character .inner {
  position: relative;
}
#character .ttl-box {
  margin-bottom: 115px;
}
@media only screen and (max-width: 768px) {
  #character .ttl-box {
    margin-bottom: 8.59375vw;
  }
}
#character .ttl-box .deco {
  margin-top: -25px !important;
  margin-bottom: -8px !important;
}
@media only screen and (max-width: 768px) {
  #character .ttl-box .deco {
    top: 1.09375vw !important;
    margin-top: -3.90625vw !important;
    margin-bottom: 1.25vw !important;
  }
}
#character .ttl-box .txt-deco {
  margin-bottom: 26px !important;
}
@media only screen and (max-width: 768px) {
  #character .ttl-box h2 {
    width: 86.71875vw;
  }
}
#character .sd-chara {
  position: absolute;
  top: 84px;
  right: 68px;
}
@media only screen and (max-width: 768px) {
  #character .sd-chara {
    width: 18.75vw;
    top: -2.03125vw;
    right: 1.25vw;
    z-index: 2;
  }
}
@media only screen and (max-width: 768px) {
  #character .slick-list {
    width: 100%;
    overflow: inherit;
  }
}
#character .slick-arrow {
  position: absolute;
  top: 40%;
  width: 80px;
  height: 80px;
  font-size: 0;
  border: none;
  background: url("../img/top/news/arrow.svg") no-repeat top center;
  background-size: contain;
  transition: all 0.3s ease;
  z-index: 2;
}
@media only screen and (max-width: 768px) {
  #character .slick-arrow {
    width: 12.5vw;
    height: 12.5vw;
  }
}
#character .slick-arrow::after {
  display: none;
}
@media only screen and (max-width: 768px) {
  #character .slick-arrow {
    display: block;
  }
}
#character .slick-prev {
  transform: scale(-1, -1);
}
@media only screen and (max-width: 768px) {
  #character .slick-prev {
    left: 3.125vw;
  }
}
@media only screen and (max-width: 768px) {
  #character .slick-next {
    right: 3.125vw;
  }
}
#character .slick-disabled {
  opacity: 0;
}
#character .wrap {
  position: relative;
  width: 100%;
  height: 541px;
  max-width: 1758px;
  margin: 0 auto 72px;
}
@media only screen and (max-width: 1200px) {
  #character .wrap {
    width: 100vw;
  }
}
@media only screen and (max-width: 768px) {
  #character .wrap {
    width: auto;
  }
}
#character .change-arrow {
  position: absolute;
  top: 40%;
  transform: translateY(-50%);
  width: 80px;
  z-index: 5;
}
@media only screen and (max-width: 768px) {
  #character .change-arrow {
    display: none;
  }
}
#character .change-arrow.right {
  opacity: 0;
  right: 0;
}
@media only screen and (max-width: 1200px) {
  #character .change-arrow.right {
    right: 10px;
  }
}
#character .change-arrow.left {
  display: none;
  left: 0;
}
@media only screen and (max-width: 1200px) {
  #character .change-arrow.left {
    left: 10px;
  }
}
#character .change-arrow.left img {
  transform: rotate(180deg);
}
#character .change-arrow a {
  display: block;
}
#character .change-arrow img {
  width: 100%;
}
#character .list {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
}
@media only screen and (max-width: 768px) {
  #character .list {
    position: static;
    margin-bottom: 11.25vw;
  }
}
#character .list.list2 {
  display: none;
  opacity: 0;
}
#character .list.list2 .list-wrap {
  justify-content: center;
}
#character .list .list-wrap {
  position: relative;
  display: flex;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  max-width: 1758px;
  min-width: 980px;
  margin: 0 auto 72px;
}
@media only screen and (max-width: 768px) {
  #character .list .list-wrap {
    max-width: unset;
    min-width: unset;
  }
}
#character .list .chara-box {
  width: 17%;
  position: relative;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box {
    opacity: 0.5;
  }
}
#character .list .chara-box.sp {
  display: none;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.sp {
    display: block;
  }
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.slick-current {
    opacity: 1;
  }
}
#character .list .chara-box .chara-img {
  position: relative;
  width: 100%;
  height: 462px;
  margin-bottom: 50px;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box .chara-img {
    height: 72.1875vw;
  }
}
#character .list .chara-box .chara-img .chara {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
}
#character .list .chara-box .chara-img .chara img {
  width: 100%;
  transition: all 0.3s ease;
}
#character .list .chara-box .chara-img .shadow {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
#character .list .chara-box .chara-img .shadow img {
  transition: all 0.3s ease;
}
#character .list .chara-box .name {
  position: relative;
  width: 166px;
  padding: 2px 0 3px;
  margin: 0 auto;
  font-size: 16px;
  font-family: "Zen Maru Gothic", serif;
  color: #fff;
  font-weight: 500;
  background-color: #fff;
  border-radius: 20px;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box .name {
    width: 28.125vw;
    font-size: 3.75vw;
    padding: 0.3125vw 0 0.46875vw;
    border-radius: 3.75vw;
  }
}
#character .list .chara-box.amane .chara-img .chara {
  width: 241px;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.amane .chara-img .chara {
    width: 37.65625vw;
  }
}
#character .list .chara-box.amane .chara-img .shadow {
  top: 95%;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.amane .chara-img .shadow {
    width: 37.65625vw;
  }
}
#character .list .chara-box.amane .name {
  background-color: #9ED8FD;
}
#character .list .chara-box.sakura .chara-img .chara {
  width: 375px;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.sakura .chara-img .chara {
    width: 58.59375vw;
  }
}
#character .list .chara-box.sakura .chara-img .shadow {
  top: 96%;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.sakura .chara-img .shadow {
    width: 58.59375vw;
  }
}
#character .list .chara-box.sakura .name {
  background-color: #FA9FB5;
}
#character .list .chara-box.himemori .chara-img .chara {
  width: 291px;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.himemori .chara-img .chara {
    width: 45.46875vw;
  }
}
#character .list .chara-box.himemori .chara-img .shadow {
  top: 96%;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.himemori .chara-img .shadow {
    width: 45.46875vw;
  }
}
#character .list .chara-box.himemori .name {
  background-color: #FE84C3;
}
#character .list .chara-box.houshou .chara-img .chara {
  width: 255px;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.houshou .chara-img .chara {
    width: 39.84375vw;
  }
}
#character .list .chara-box.houshou .chara-img .shadow {
  top: 95%;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.houshou .chara-img .shadow {
    width: 39.84375vw;
  }
}
#character .list .chara-box.houshou .name {
  background-color: #C54132;
}
#character .list .chara-box.shirakami .chara {
  width: 332px;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.shirakami .chara {
    width: 51.875vw;
  }
}
#character .list .chara-box.shirakami .chara-img .shadow {
  top: 98%;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.shirakami .chara-img .shadow {
    width: 37.8125vw;
  }
}
#character .list .chara-box.shirakami .name {
  background-color: #A1DFFD;
}
#character .list .chara-box.yukihana .chara {
  width: 327px;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.yukihana .chara {
    width: 51.09375vw;
  }
}
#character .list .chara-box.yukihana .chara-img .shadow {
  top: 98%;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.yukihana .chara-img .shadow {
    width: 37.8125vw;
  }
}
#character .list .chara-box.yukihana .name {
  background-color: #47A3F4;
}
#character .list .chara-box.murasaki .chara {
  width: 242px;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.murasaki .chara {
    width: 37.8125vw;
  }
}
#character .list .chara-box.murasaki .chara-img .shadow {
  top: 98%;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.murasaki .chara-img .shadow {
    width: 37.8125vw;
  }
}
#character .list .chara-box.murasaki .name {
  background-color: #A971DD;
}
#character .list .chara-box.sakamata .chara {
  width: 238px;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.sakamata .chara {
    width: 37.1875vw;
  }
}
#character .list .chara-box.sakamata .chara-img .shadow {
  top: 99.5%;
}
@media only screen and (max-width: 768px) {
  #character .list .chara-box.sakamata .chara-img .shadow {
    width: 37.1875vw;
  }
}
#character .list .chara-box.sakamata .name {
  background-color: #CA514E;
}
#character .list .chara-box a {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  z-index: 3;
}
#character .btn {
  position: relative;
  z-index: 2;
}

@-webkit-keyframes chara-pop {
  40% {
    transform: translateY(-15%);
  }
  100% {
    transform: translateY(-10%);
  }
}

@keyframes chara-pop {
  40% {
    transform: translateY(-15%);
  }
  100% {
    transform: translateY(-10%);
  }
}
@-webkit-keyframes shadow-pop {
  40% {
    transform: translateY(15%) translateX(-50%);
  }
  100% {
    transform: translateY(10%) translateX(-50%);
  }
}
@keyframes shadow-pop {
  40% {
    transform: translateY(15%) translateX(-50%);
  }
  100% {
    transform: translateY(10%) translateX(-50%);
  }
}