@charset "UTF-8";
/*=============================================================
 tools
=============================================================*/
body {
  position: relative;
}

.bg-con {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
  width: 100vw;
  height: 100vh;
  min-width: 2000px;
}
@media only screen and (max-width: 768px) {
  .bg-con {
    min-width: unset;
  }
}
.bg-con::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 400px;
  background: url("../img/parts/bg_rp.png") repeat-y top center #32191C;
  background-size: 100% auto;
  display: block;
}
.bg-con.off-top::after {
  display: none;
}
.bg-con.no-fixed {
  position: absolute;
}

#loading {
  position: fixed;
  top: 0;
  kerning: 0;
  width: 100vw;
  height: 100vh;
  background-color: #32191C;
  z-index: 99;
  transition: all 0.8s 1s ease;
  display: none;
}
#loading .bg {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  pointer-events: none;
}
#loading .bg::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0.9;
  background-color: #32191C;
  mix-blend-mode: multiply;
}
#loading .bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: all 15s ease;
}
#loading .box {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}
#loading .logo {
  width: 600px;
  opacity: 0;
  margin-bottom: 20px;
}
@media only screen and (max-width: 768px) {
  #loading .logo {
    width: 87.5vw;
    margin-bottom: 3.125vw;
  }
}
#loading .logo img {
  filter: blur(8px);
  transition: all 0.6s 0.2s ease;
}
@-webkit-keyframes load-shine {
  0% {
    transform: rotateY(0deg);
  }
  30% {
    transform: rotateY(360deg);
  }
  70% {
    transform: rotateY(0deg);
  }
  100% {
    transform: rotateY(0deg);
  }
}
@keyframes load-shine {
  0% {
    transform: rotateY(0deg);
  }
  30% {
    transform: rotateY(360deg);
  }
  70% {
    transform: rotateY(0deg);
  }
  100% {
    transform: rotateY(0deg);
  }
}
#loading .shine-box {
  display: flex;
  justify-content: center;
}
#loading .shine-box span {
  display: block;
  width: 30px;
  gap: 0 10px;
  -webkit-animation: load-shine 4s ease infinite;
          animation: load-shine 4s ease infinite;
}
@media only screen and (max-width: 768px) {
  #loading .shine-box span {
    width: 6.25vw;
    gap: 0 1.5625vw;
  }
}
#loading .shine-box span:nth-child(2) {
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}
#loading .shine-box span:nth-child(3) {
  -webkit-animation-delay: 0.4s;
          animation-delay: 0.4s;
}
#loading .shine-box svg {
  width: 100%;
  height: auto;
}
#loading .shine-box svg path {
  fill: #FF1A2B;
}
#loading.on .bg img {
  transform: scale(1.2);
}
#loading.on .logo {
  opacity: 1;
}
#loading.on .logo img {
  filter: blur(0px);
}
#loading.off {
  opacity: 0;
  visibility: hidden;
}

#btn-nav, #bnr-ticket {
  display: none;
}

#keyvisual {
  position: relative;
  height: 80.25vw;
  background-color: #32191C;
}
@media only screen and (max-width: 768px) {
  #keyvisual {
    height: 162.1875vw;
  }
}
#keyvisual .bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
#keyvisual .illust {
  position: absolute;
  top: 0px;
  left: 0;
}
#keyvisual h1 {
  position: absolute;
  top: 36.9vw;
  left: 50%;
  transform: translateX(-50%);
  transform-origin: 0 0;
  width: 67.85vw;
}
@media only screen and (max-width: 768px) {
  #keyvisual h1 {
    top: 99.375vw;
    width: 99.21875vw;
  }
}
#keyvisual .catch {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 39.9vw;
  z-index: 2;
}
@media only screen and (max-width: 768px) {
  #keyvisual .catch {
    width: 74.6875vw;
  }
}
#keyvisual .bg {
  transition: all 0.3s 1s ease;
}
#keyvisual .bg img {
  transition: all 0.3s 0.3s ease;
}
#keyvisual .bg {
  transition: all 0.5s 1s ease;
}
#keyvisual .bg span {
  display: block;
  transform: scale(1.3);
  filter: blur(8px) brightness(0);
  transition: all 0.8s 0.3s ease;
}
@media only screen and (max-width: 768px) {
  #keyvisual .bg span {
    transform: scale(1.1);
  }
}
#keyvisual .bg img {
  filter: blur(3px);
  transition: all 0.5s 1s ease;
}
#keyvisual .illust {
  opacity: 0;
  transition: all 0.5s 1.3s ease;
}
#keyvisual .illust img {
  filter: brightness(2);
  transition: all 0.8s 1.4s ease;
}
#keyvisual h1 {
  opacity: 0;
  transform: scale(1.2) translateX(-50%);
  transition: all 0.6s 1.6s ease;
}
#keyvisual .catch {
  opacity: 0;
  transition: all 0.6s 1.8s ease;
}
#keyvisual.move-on h1 {
  opacity: 1;
  transform: scale(1) translateX(-50%);
}
#keyvisual.move-on .catch {
  opacity: 1;
}
#keyvisual.move-on .flash {
  opacity: 0;
}
#keyvisual.move-on .flash span {
  opacity: 1;
}
#keyvisual.move-on .bg {
  transform: scale(1.01);
}
#keyvisual.move-on .bg span {
  transform: scale(0.99);
  filter: blur(2px) brightness(0.8);
}
#keyvisual.move-on .bg img {
  filter: blur(0px);
}
#keyvisual.move-on .illust {
  opacity: 1;
}
#keyvisual.move-on .illust img {
  filter: brightness(1);
}

.bg-wrap {
  background: url("../img/parts/bg_rp.png") repeat-y top center #32191C;
  background-size: 100% auto;
}

section {
  position: relative;
}
section .bg-deco, section .bg-deco1, section .bg-deco2, section .sec-bg {
  pointer-events: none;
}
section .spot {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  min-width: 2000px;
}
section .spot span {
  position: relative;
  display: block;
  width: 110vw;
  height: 34px;
  background-color: #fff;
}
@media only screen and (max-width: 2000px) {
  section .spot span {
    width: 2000px;
  }
}
@media only screen and (max-width: 1250px) {
  section .spot span {
    height: 2.72vw;
  }
}
section .spot.left .blur-wrap {
  filter: blur(15px);
}
section .spot.left span {
  left: -5vw;
  transform-origin: left bottom;
  transform: rotate(12deg);
  -webkit-clip-path: polygon(0 0, 100% 50%, 0 100%);
          clip-path: polygon(0 0, 100% 50%, 0 100%);
}
section .spot.right span {
  right: -5vw;
  transform-origin: right bottom;
  transform: rotate(-17.5deg);
  -webkit-clip-path: polygon(0 50%, 100% 0, 100% 100%);
          clip-path: polygon(0 50%, 100% 0, 100% 100%);
}
section .spot.right .blur-wrap:nth-child(1) {
  filter: blur(20px);
}
section .spot.right .blur-wrap:nth-child(1) span {
  background-color: #0011E3;
}
section .spot.right .blur-wrap:nth-child(2) {
  position: absolute;
  top: 0;
  right: 0;
  filter: blur(9px);
}
section .spot.right .blur-wrap:nth-child(2) span {
  opacity: 0.6;
}
section .inner {
  width: 1200px;
  margin: 0 auto;
}
@media only screen and (max-width: 1250px) {
  section .inner {
    width: 96vw;
  }
}
@media only screen and (max-width: 768px) {
  section .inner {
    width: 87.5vw;
  }
}
section .ttl-box {
  position: relative;
  display: flex;
  align-items: center;
  margin-bottom: 50px;
  margin-left: -30px;
}
@media only screen and (max-width: 1250px) {
  section .ttl-box {
    margin-bottom: 4vw;
    margin-left: -2.4vw;
  }
}
@media only screen and (max-width: 768px) {
  section .ttl-box {
    display: block;
    margin-bottom: 4.6875vw;
    margin-left: -2.34375vw;
  }
}
section .ttl-box h2 {
  position: relative;
  line-height: 1;
}
section .ttl-box h2::before {
  content: "";
  position: absolute;
  top: 30px;
  left: 75%;
  width: 522px;
  height: 189px;
  background: url("../img/news/ttl_deco.png") no-repeat top center;
  background-size: contain;
}
@media only screen and (max-width: 1250px) {
  section .ttl-box h2::before {
    top: 2.4vw;
    width: 41.76vw;
    height: 15.12vw;
  }
}
@media only screen and (max-width: 768px) {
  section .ttl-box h2::before {
    top: 10.9375vw;
    left: -21.5625vw;
    width: 81.5625vw;
    height: 29.53125vw;
  }
}
section .ttl-box h2 span {
  display: block;
}
section .ttl-box h2 .ttl {
  position: absolute;
  top: 45px;
  left: 30px;
}
@media only screen and (max-width: 1250px) {
  section .ttl-box h2 .ttl {
    top: 3.6vw;
    left: 2.4vw;
  }
}
@media only screen and (max-width: 768px) {
  section .ttl-box h2 .ttl {
    top: 7.03125vw;
    left: 4.6875vw;
  }
}
section .ttl-box h2 .ttl svg {
  width: 100%;
  height: auto;
}
section .ttl-box h2 .shine {
  position: absolute;
}
section .ttl-box h2 .shine svg {
  width: 100%;
  height: auto;
}
section .ttl-box .jp {
  position: relative;
  padding-top: 50px;
  font-size: 30px;
  color: #fff;
  text-shadow: 0 0 12px #FF1A2B;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-weight: 500;
}
@media only screen and (max-width: 1250px) {
  section .ttl-box .jp {
    padding-top: 4vw;
    font-size: 2.4vw;
  }
}
@media only screen and (max-width: 768px) {
  section .ttl-box .jp {
    font-size: 4.6875vw;
    padding-top: 0;
    margin-left: 1.5625vw;
  }
}
section .ttl-box .deco {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 160px;
}
@media only screen and (max-width: 1250px) {
  section .ttl-box .deco {
    width: 12.8vw;
  }
}
@media only screen and (max-width: 768px) {
  section .ttl-box .deco {
    width: 25vw;
  }
}
section .spot.left .blur-wrap {
  opacity: 0;
  transform-origin: left center;
  transform: rotate(-15deg);
  transition: all 0.8s 0.5s ease;
}
section .spot.right .blur-wrap {
  opacity: 0;
  transform-origin: right center;
  transform: rotate(15deg);
  transition: all 0.5s 0.5s ease;
}
section .ttl-box h2 {
  opacity: 0;
  transition: all 0.6s 0.5s ease;
}
section .ttl-box h2::before {
  opacity: 0;
  transform: translateX(-50px);
  filter: brightness(0);
  transition: all 0.5s 1.5s ease;
}
@media only screen and (max-width: 768px) {
  section .ttl-box h2::before {
    transform: translateX(-7.8125vw);
  }
}
section .ttl-box h2 .ttl {
  transform: scale(1.1);
  transition: all 0.6s 0.7s ease;
}
section .ttl-box h2 .ttl svg {
  filter: blur(5px);
  transition: all 0.6s 1.1s ease;
}
@media only screen and (max-width: 768px) {
  section .ttl-box h2 .ttl svg {
    filter: blur(0.78125vw);
  }
}
section .ttl-box h2 .shadow {
  opacity: 0;
  transition: all 0.6s 1.8s ease;
}
section .ttl-box h2 .shine {
  opacity: 0;
  transform: translate(-100px, 100px);
}
@media only screen and (max-width: 768px) {
  section .ttl-box h2 .shine {
    transform: translate(-15.625vw, 15.625vw);
  }
}
section .ttl-box .jp {
  opacity: 0;
  transform: translateX(-30px);
  transition: all 0.6s 1.6s ease;
}
@media only screen and (max-width: 768px) {
  section .ttl-box .jp {
    transform: translateX(-4.6875vw);
  }
}
section .ttl-box .deco {
  opacity: 0;
  transition: all 0.6s 1.8s ease;
}
@-webkit-keyframes rotateYAnim {
  from {
    transform: rotateY(0deg);
  }
  to {
    transform: rotateY(360deg);
  }
}
@keyframes rotateYAnim {
  from {
    transform: rotateY(0deg);
  }
  to {
    transform: rotateY(360deg);
  }
}
@-webkit-keyframes moveToFinal {
  0% {
    transform: translate(-120px, 120px); /* 左下スタート */
  }
  60% {
    opacity: 1;
    transform: translate(70px, -40px); /* 右上へ */
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px); /* 最終位置（ちょい左下） */
  }
}
@keyframes moveToFinal {
  0% {
    transform: translate(-120px, 120px); /* 左下スタート */
  }
  60% {
    opacity: 1;
    transform: translate(70px, -40px); /* 右上へ */
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px); /* 最終位置（ちょい左下） */
  }
}
@media only screen and (max-width: 1250px) {
  @-webkit-keyframes moveToFinal {
    0% {
      transform: translate(-18.75vw, 18.75vw); /* 左下スタート */
    }
    60% {
      opacity: 1;
      transform: translate(10.9375vw, -6.25vw); /* 右上へ */
    }
    100% {
      opacity: 1;
      transform: translate(0px, 0px); /* 最終位置（ちょい左下） */
    }
  }
  @keyframes moveToFinal {
    0% {
      transform: translate(-18.75vw, 18.75vw); /* 左下スタート */
    }
    60% {
      opacity: 1;
      transform: translate(10.9375vw, -6.25vw); /* 右上へ */
    }
    100% {
      opacity: 1;
      transform: translate(0px, 0px); /* 最終位置（ちょい左下） */
    }
  }
}
@media only screen and (max-width: 768px) {
  @-webkit-keyframes moveToFinal {
    0% {
      transform: translate(-15.625vw, 15.625vw); /* 左下スタート */
    }
    60% {
      opacity: 1;
      transform: translate(7.8125vw, -3.125vw); /* 右上へ */
    }
    100% {
      opacity: 1;
      transform: translate(0px, 0px); /* 最終位置（ちょい左下） */
    }
  }
  @keyframes moveToFinal {
    0% {
      transform: translate(-15.625vw, 15.625vw); /* 左下スタート */
    }
    60% {
      opacity: 1;
      transform: translate(7.8125vw, -3.125vw); /* 右上へ */
    }
    100% {
      opacity: 1;
      transform: translate(0px, 0px); /* 最終位置（ちょい左下） */
    }
  }
}
@-webkit-keyframes moveToFinal2 {
  0% {
    transform: translate(120px, -120px); /* 左下スタート */
  }
  60% {
    opacity: 1;
    transform: translate(-70px, 40px); /* 右上へ */
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px); /* 最終位置（ちょい左下） */
  }
}
@keyframes moveToFinal2 {
  0% {
    transform: translate(120px, -120px); /* 左下スタート */
  }
  60% {
    opacity: 1;
    transform: translate(-70px, 40px); /* 右上へ */
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px); /* 最終位置（ちょい左下） */
  }
}
@media only screen and (max-width: 1250px) {
  @-webkit-keyframes moveToFinal2 {
    0% {
      transform: translate(18.75vw, -18.75vw); /* 左下スタート */
    }
    60% {
      opacity: 1;
      transform: translate(-10.9375vw, 6.25vw); /* 右上へ */
    }
    100% {
      opacity: 1;
      transform: translate(0px, 0px); /* 最終位置（ちょい左下） */
    }
  }
  @keyframes moveToFinal2 {
    0% {
      transform: translate(18.75vw, -18.75vw); /* 左下スタート */
    }
    60% {
      opacity: 1;
      transform: translate(-10.9375vw, 6.25vw); /* 右上へ */
    }
    100% {
      opacity: 1;
      transform: translate(0px, 0px); /* 最終位置（ちょい左下） */
    }
  }
}
@media only screen and (max-width: 768px) {
  @-webkit-keyframes moveToFinal2 {
    0% {
      transform: translate(12.5vw, -12.5vw); /* 左下スタート */
    }
    60% {
      opacity: 1;
      transform: translate(-7.8125vw, 3.125vw); /* 右上へ */
    }
    100% {
      opacity: 1;
      transform: translate(0px, 0px); /* 最終位置（ちょい左下） */
    }
  }
  @keyframes moveToFinal2 {
    0% {
      transform: translate(12.5vw, -12.5vw); /* 左下スタート */
    }
    60% {
      opacity: 1;
      transform: translate(-7.8125vw, 3.125vw); /* 右上へ */
    }
    100% {
      opacity: 1;
      transform: translate(0px, 0px); /* 最終位置（ちょい左下） */
    }
  }
}
section.move-on .spot.left .blur-wrap {
  opacity: 1;
  transform: rotate(0deg);
}
section.move-on .spot.right .blur-wrap {
  opacity: 1;
  transform: rotate(0deg);
}
section.move-on .ttl-box h2 {
  opacity: 1;
}
section.move-on .ttl-box h2::before {
  opacity: 1;
  filter: brightness(1);
  transform: translateX(0px);
}
section.move-on .ttl-box h2 .ttl {
  opacity: 1;
  transform: scale(1);
}
section.move-on .ttl-box h2 .ttl svg {
  filter: blur(0px);
}
section.move-on .ttl-box h2 .shine {
  -webkit-animation: moveToFinal 0.6s 1.1s ease-in-out forwards;
          animation: moveToFinal 0.6s 1.1s ease-in-out forwards;
}
section.move-on .ttl-box h2 .shine svg {
  -webkit-animation: rotateYAnim 0.7s ease 0.8s 2;
          animation: rotateYAnim 0.7s ease 0.8s 2;
}
section.move-on .ttl-box .jp {
  opacity: 1;
  transform: translateX(0px);
}
section.move-on .ttl-box .deco, section.move-on .ttl-box .shadow {
  opacity: 1;
}

#news {
  padding: 160px 0 0;
}
@media only screen and (max-width: 1250px) {
  #news {
    padding: 12.8vw 0 0;
  }
}
@media only screen and (max-width: 768px) {
  #news {
    padding: 39.84375vw 0 0;
    margin-bottom: 3.125vw;
  }
}
#news .bg-deco {
  position: absolute;
  top: 0px;
  left: 0;
}
@media only screen and (max-width: 768px) {
  #news .bg-deco {
    top: 17.1875vw;
  }
}
#news .spot.left {
  top: 120px;
}
@media only screen and (max-width: 1250px) {
  #news .spot.left {
    top: 9.6vw;
  }
}
#news .spot.left span {
  background-color: #FFA2A2;
}
#news .spot.right {
  top: -100px;
}
@media only screen and (max-width: 1250px) {
  #news .spot.right {
    top: -8vw;
  }
}
#news .spot.right .blur-wrap:nth-child(1) span {
  background-color: #FF1A2B;
}
#news .ttl-box h2 {
  width: 434px;
}
@media only screen and (max-width: 1250px) {
  #news .ttl-box h2 {
    width: 34.72vw;
  }
}
@media only screen and (max-width: 768px) {
  #news .ttl-box h2 {
    width: 41.875vw;
  }
}
#news .ttl-box h2 .ttl {
  width: 375px;
  top: 45px;
  left: 30px;
}
@media only screen and (max-width: 1250px) {
  #news .ttl-box h2 .ttl {
    width: 30vw;
    top: 3.6vw;
    left: 2.4vw;
  }
}
@media only screen and (max-width: 768px) {
  #news .ttl-box h2 .ttl {
    width: 36.25vw;
    top: 4.375vw;
    left: 2.8125vw;
  }
}
#news .ttl-box h2 .shine {
  top: 25px;
  left: 105px;
  width: 99px;
}
@media only screen and (max-width: 1250px) {
  #news .ttl-box h2 .shine {
    top: 2vw;
    left: 8.4vw;
    width: 7.92vw;
  }
}
@media only screen and (max-width: 768px) {
  #news .ttl-box h2 .shine {
    width: 9.53125vw;
    top: 2.8125vw;
    left: 10.15625vw;
  }
}
#news .news__list {
  margin-bottom: 55px;
}
@media only screen and (max-width: 1250px) {
  #news .news__list {
    margin-bottom: 4.4vw;
  }
}
@media only screen and (max-width: 768px) {
  #news .news__list {
    margin-bottom: 6.5625vw;
  }
}
#news .news__list ul li:not(:last-child) {
  margin-bottom: 50px;
}
@media only screen and (max-width: 1250px) {
  #news .news__list ul li:not(:last-child) {
    margin-bottom: 4vw;
  }
}
@media only screen and (max-width: 768px) {
  #news .news__list ul li:not(:last-child) {
    margin-bottom: 7.03125vw;
  }
}
#news .news__list ul li a {
  position: relative;
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 0 50px;
  align-items: center;
  min-height: 160px;
  padding: 50px 42px;
  box-sizing: border-box;
  background-color: rgba(50, 25, 28, 0.8);
  border: 1px solid #FF1A2B;
  text-decoration: none;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 1250px) {
  #news .news__list ul li a {
    grid-template-columns: 12.8vw 1fr;
    min-height: 12.8vw;
    padding: 4vw 3.36vw;
  }
}
@media only screen and (max-width: 768px) {
  #news .news__list ul li a {
    display: block;
    padding: 7.8125vw 7.03125vw;
  }
}
#news .news__list ul li a p {
  color: #fff;
}
#news .news__list ul li a::before, #news .news__list ul li a::after {
  content: "";
  position: absolute;
  display: block;
  width: 50px;
  height: 50px;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 1250px) {
  #news .news__list ul li a::before, #news .news__list ul li a::after {
    width: 4vw;
    height: 4vw;
  }
}
@media only screen and (max-width: 768px) {
  #news .news__list ul li a::before, #news .news__list ul li a::after {
    width: 7.8125vw;
    height: 7.8125vw;
  }
}
#news .news__list ul li a::before {
  bottom: -2px;
  left: -2px;
  border-bottom: 4px solid #FF1A2B;
  border-left: 4px solid #FF1A2B;
}
@media only screen and (max-width: 1250px) {
  #news .news__list ul li a::before {
    bottom: -0.16vw;
    left: -0.16vw;
    border-bottom-width: 0.32vw;
    border-left-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #news .news__list ul li a::before {
    bottom: -0.3125vw;
    left: -0.3125vw;
    border-bottom-width: 0.625vw;
    border-left-width: 0.625vw;
  }
}
#news .news__list ul li a::after {
  top: -2px;
  right: -2px;
  border-top: 4px solid #FF1A2B;
  border-right: 4px solid #FF1A2B;
}
@media only screen and (max-width: 1250px) {
  #news .news__list ul li a::after {
    top: -0.16vw;
    right: -0.16vw;
    border-top-width: 0.32vw;
    border-right-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #news .news__list ul li a::after {
    top: -0.3125vw;
    right: -0.3125vw;
    border-top-width: 0.625vw;
    border-right-width: 0.625vw;
  }
}
#news .news__list ul li a:hover {
  background-color: #FF1A2B;
  border-color: #fff;
}
#news .news__list ul li a:hover::before, #news .news__list ul li a:hover::after {
  border-color: #fff;
}
@media only screen and (max-width: 768px) {
  #news .news__list ul li .date {
    margin-bottom: 1.5625vw;
  }
}
#news .news__list ul li .date p {
  font-size: 20px;
}
@media only screen and (max-width: 1250px) {
  #news .news__list ul li .date p {
    font-size: 1.6vw;
  }
}
@media only screen and (max-width: 768px) {
  #news .news__list ul li .date p {
    font-size: 3.125vw;
    line-height: 1.2;
  }
}
#news .news__list ul li .date p span {
  font-size: 30px;
  margin-left: 0.8em;
}
@media only screen and (max-width: 1250px) {
  #news .news__list ul li .date p span {
    font-size: 2.4vw;
  }
}
@media only screen and (max-width: 768px) {
  #news .news__list ul li .date p span {
    font-size: 5.3125vw;
    margin-left: 0.4em;
  }
}
#news .news__list ul li .txt p {
  font-size: 24px;
}
@media only screen and (max-width: 1250px) {
  #news .news__list ul li .txt p {
    font-size: 1.92vw;
  }
}
@media only screen and (max-width: 768px) {
  #news .news__list ul li .txt p {
    font-size: 4.375vw;
  }
}
#news .bg-deco {
  opacity: 0;
  transform: translateX(-200px);
  transition: all 1.5s ease;
}
@media only screen and (max-width: 768px) {
  #news .bg-deco {
    transform: translateX(-31.25vw);
  }
}
#news .bg-deco img {
  transform: scale(1.1);
  transition: all 1s 0.1s ease;
}
#news .news__list ul li {
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.5s 1.5s ease;
}
@media only screen and (max-width: 768px) {
  #news .news__list ul li {
    transform: translateY(3.125vw);
  }
}
#news .news__list ul li:nth-child(2) {
  transition-delay: 1.6s;
}
#news .news__list ul li:nth-child(3) {
  transition-delay: 1.7s;
}
#news .btn {
  opacity: 0;
  transition: all 0.5s 2s ease;
}
#news.move-on .bg-deco {
  opacity: 1;
  transform: translateX(0px);
}
#news.move-on .bg-deco img {
  transform: scale(1);
}
#news.move-on .news__list ul li {
  opacity: 1;
  transform: translateY(0px);
}
#news.move-on .btn {
  opacity: 1;
}

#merch {
  padding: 140px 0 0;
  margin-bottom: 146px;
}
@media only screen and (max-width: 1250px) {
  #merch {
    padding: 11.2vw 0 0;
    margin-bottom: 11.68vw;
  }
}
@media only screen and (max-width: 768px) {
  #merch {
    padding: 22.65625vw 0 0;
    margin-bottom: 35.15625vw;
  }
}
#merch .bg-deco1 {
  position: absolute;
  top: -130px;
  left: 0;
  mix-blend-mode: color;
}
@media only screen and (max-width: 1250px) {
  #merch .bg-deco1 {
    top: -10.4vw;
  }
}
@media only screen and (max-width: 768px) {
  #merch .bg-deco1 {
    top: -15.625vw;
  }
}
#merch .bg-deco2 {
  position: absolute;
  top: 224px;
  left: 0;
}
@media only screen and (max-width: 1250px) {
  #merch .bg-deco2 {
    top: -2.4vw;
  }
}
@media only screen and (max-width: 768px) {
  #merch .bg-deco2 {
    top: 113.75vw;
  }
}
#merch .spot.left {
  top: 310px;
}
@media only screen and (max-width: 1250px) {
  #merch .spot.left {
    top: 9.6vw;
  }
}
#merch .spot.left span {
  background-color: #A2D8FF;
}
#merch .spot.right {
  top: 150px;
}
@media only screen and (max-width: 1250px) {
  #merch .spot.right {
    top: -8vw;
  }
}
#merch .spot.right .blur-wrap:nth-child(1) span {
  background-color: #0011E3;
}
#merch .ttl-box h2 {
  width: 471px;
}
@media only screen and (max-width: 1250px) {
  #merch .ttl-box h2 {
    width: 37.68vw;
  }
}
@media only screen and (max-width: 768px) {
  #merch .ttl-box h2 {
    width: 45.78125vw;
  }
}
#merch .ttl-box h2::before {
  background-image: url("../img/merch/ttl_deco.png");
}
#merch .ttl-box h2 .ttl {
  width: 412px;
  top: 45px;
  left: 30px;
}
@media only screen and (max-width: 1250px) {
  #merch .ttl-box h2 .ttl {
    width: 32.96vw;
    top: 3.6vw;
    left: 2.4vw;
  }
}
@media only screen and (max-width: 768px) {
  #merch .ttl-box h2 .ttl {
    width: 40vw;
    top: 4.375vw;
    left: 2.8125vw;
  }
}
#merch .ttl-box h2 .shine {
  top: 25px;
  left: 125px;
  width: 99px;
}
@media only screen and (max-width: 1250px) {
  #merch .ttl-box h2 .shine {
    top: 2vw;
    left: 10vw;
    width: 7.92vw;
  }
}
@media only screen and (max-width: 768px) {
  #merch .ttl-box h2 .shine {
    top: 2.5vw;
    left: 12.03125vw;
    width: 9.53125vw;
  }
}
#merch .ttl-box .jp {
  text-shadow: 0 0 12px #0011E3;
}
#merch .image {
  position: relative;
  margin-bottom: 55px;
  transition: all 0.4s ease;
}
@media only screen and (max-width: 1250px) {
  #merch .image {
    margin-bottom: 4.4vw;
  }
}
#merch .image::before, #merch .image::after {
  content: "";
  position: absolute;
  display: block;
  width: 50px;
  height: 50px;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 1250px) {
  #merch .image::before, #merch .image::after {
    width: 4vw;
    height: 4vw;
  }
}
@media only screen and (max-width: 768px) {
  #merch .image::before, #merch .image::after {
    width: 7.8125vw;
    height: 7.8125vw;
  }
}
#merch .image::before {
  bottom: -2px;
  left: -2px;
  border-bottom: 4px solid #FF1A2B;
  border-left: 4px solid #FF1A2B;
}
@media only screen and (max-width: 1250px) {
  #merch .image::before {
    bottom: -0.16vw;
    left: -0.16vw;
    border-bottom-width: 0.32vw;
    border-left-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #merch .image::before {
    bottom: -0.3125vw;
    left: -0.3125vw;
    border-bottom-width: 0.625vw;
    border-left-width: 0.625vw;
  }
}
#merch .image::after {
  top: -2px;
  right: -2px;
  border-top: 4px solid #FF1A2B;
  border-right: 4px solid #FF1A2B;
}
@media only screen and (max-width: 1250px) {
  #merch .image::after {
    top: -0.16vw;
    right: -0.16vw;
    border-top-width: 0.32vw;
    border-right-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #merch .image::after {
    top: -0.3125vw;
    right: -0.3125vw;
    border-top-width: 0.625vw;
    border-right-width: 0.625vw;
  }
}
#merch .image span::before, #merch .image span::after {
  content: "";
  position: absolute;
  display: block;
  width: 50px;
  height: 50px;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 1250px) {
  #merch .image span::before, #merch .image span::after {
    width: 4vw;
    height: 4vw;
  }
}
@media only screen and (max-width: 768px) {
  #merch .image span::before, #merch .image span::after {
    width: 7.8125vw;
    height: 7.8125vw;
  }
}
#merch .image span::before {
  top: -2px;
  left: -2px;
  border-top: 4px solid #FF1A2B;
  border-left: 4px solid #FF1A2B;
}
@media only screen and (max-width: 1250px) {
  #merch .image span::before {
    top: -0.16vw;
    left: -0.16vw;
    border-top-width: 0.32vw;
    border-left-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #merch .image span::before {
    top: -0.3125vw;
    left: -0.3125vw;
    border-top-width: 0.625vw;
    border-left-width: 0.625vw;
  }
}
#merch .image span::after {
  bottom: -2px;
  right: -2px;
  border-bottom: 4px solid #FF1A2B;
  border-right: 4px solid #FF1A2B;
}
@media only screen and (max-width: 1250px) {
  #merch .image span::after {
    bottom: -0.16vw;
    right: -0.16vw;
    border-bottom-width: 0.32vw;
    border-right-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #merch .image span::after {
    bottom: -0.3125vw;
    right: -0.3125vw;
    border-bottom-width: 0.625vw;
    border-right-width: 0.625vw;
  }
}
#merch .image a {
  position: relative;
  display: block;
  border: 1px solid #FF1A2B;
  transition: all 0.3s ease;
  overflow: hidden;
}
#merch .image a img {
  transition: all 0.4s ease;
}
#merch .image:hover {
  transform: scale(1.02);
}
#merch .image:hover::before, #merch .image:hover::after {
  border-color: #fff;
}
#merch .image:hover span::before, #merch .image:hover span::after {
  border-color: #fff;
}
#merch .image:hover a {
  border-color: #fff;
}
#merch .image:hover a img {
  filter: brightness(1.1);
  transform: scale(0.95);
}
#merch .image.off {
  pointer-events: none;
}
#merch .bg-deco1 {
  opacity: 0;
  transform: scale(1.2);
  transition: all 1.5s ease;
}
#merch .bg-deco2 {
  opacity: 0;
  transform: translateY(50px);
  transition: all 1.5s 0.2s ease;
}
@media only screen and (max-width: 768px) {
  #merch .bg-deco2 {
    transform: translateY(0vw);
    transition: all 1.5s 0.4s ease;
  }
}
#merch .merch__box {
  opacity: 0;
  transform: scale(1.1);
  transition: all 0.7s 1.3s ease;
}
#merch .btn {
  opacity: 0;
  transition: all 0.5s 1.5s ease;
}
#merch.move-on .bg-deco1 {
  opacity: 1;
  transform: scale(1);
}
#merch.move-on .bg-deco2 {
  opacity: 1;
  transform: translateY(0px);
}
#merch.move-on .merch__box {
  transform: scale(1);
  opacity: 1;
}
#merch.move-on .btn {
  opacity: 1;
}

#message {
  padding: 6px 0 70px;
}
@media only screen and (max-width: 1250px) {
  #message {
    padding: 0.48vw 0 5.6vw;
  }
}
@media only screen and (max-width: 768px) {
  #message {
    padding: 11.25vw 0 4.6875vw;
  }
}
#message .bg-deco1 {
  position: absolute;
  top: -70px;
  left: 0;
}
@media only screen and (max-width: 1250px) {
  #message .bg-deco1 {
    top: -5.6vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .bg-deco1 {
    top: 0;
  }
}
#message .bg-deco1 {
  position: absolute;
  top: -42px;
  left: 0;
}
@media only screen and (max-width: 1250px) {
  #message .bg-deco1 {
    top: -3.36vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .bg-deco1 {
    width: 82.1875vw;
    top: 0;
  }
}
#message .bg-deco2 {
  position: absolute;
  top: 108px;
  left: 0;
}
@media only screen and (max-width: 1250px) {
  #message .bg-deco2 {
    top: 8.64vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .bg-deco2 {
    width: 58.90625vw;
    top: 9.375vw;
  }
}
#message .spot.left {
  top: 175px;
}
@media only screen and (max-width: 1250px) {
  #message .spot.left {
    top: 14vw;
  }
}
#message .spot.right {
  top: 16px;
}
@media only screen and (max-width: 1250px) {
  #message .spot.right {
    top: 1.28vw;
  }
}
#message .spot.right .blur-wrap:nth-child(1) span {
  background-color: #BF4CA0;
}
#message .ttl-box {
  margin-bottom: 35px;
}
@media only screen and (max-width: 1250px) {
  #message .ttl-box {
    margin-bottom: 2.8vw;
  }
}
#message .ttl-box h2 {
  width: 1104px;
}
@media only screen and (max-width: 1250px) {
  #message .ttl-box h2 {
    width: 88.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .ttl-box h2 {
    width: 90.46875vw;
  }
}
#message .ttl-box h2::before {
  top: 170px;
  left: 360px;
  background-image: url("../img/message/ttl_deco.png");
}
@media only screen and (max-width: 1250px) {
  #message .ttl-box h2::before {
    top: 13.6vw;
    left: 28.8vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .ttl-box h2::before {
    top: 18.75vw;
    left: -21.5625vw;
  }
}
#message .ttl-box h2 .ttl {
  width: 1045px;
  top: 45px;
  left: 30px;
}
@media only screen and (max-width: 1250px) {
  #message .ttl-box h2 .ttl {
    width: 83.6vw;
    top: 3.6vw;
    left: 2.4vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .ttl-box h2 .ttl {
    width: 85.625vw;
    top: 3.59375vw;
    left: 2.5vw;
  }
}
#message .ttl-box h2 .shine {
  width: 101px;
}
@media only screen and (max-width: 1250px) {
  #message .ttl-box h2 .shine {
    width: 8.08vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .ttl-box h2 .shine {
    width: 8.28125vw;
  }
}
#message .ttl-box h2 .shine.shine1 {
  top: 25px;
  left: 420px;
}
@media only screen and (max-width: 1250px) {
  #message .ttl-box h2 .shine.shine1 {
    top: 2vw;
    left: 33.6vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .ttl-box h2 .shine.shine1 {
    top: 2.03125vw;
    left: 34.53125vw;
  }
}
#message .ttl-box h2 .shine.shine2 {
  top: 120px;
  left: 870px;
}
@media only screen and (max-width: 1250px) {
  #message .ttl-box h2 .shine.shine2 {
    top: 9.6vw;
    left: 69.6vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .ttl-box h2 .shine.shine2 {
    top: 10vw;
    left: 71.25vw;
  }
}
#message .ttl-box .deco {
  top: 76%;
}
#message .ttl-box .jp {
  position: absolute;
  top: 185px;
  left: 460px;
  text-shadow: 0 0 12px #A620B7;
}
@media only screen and (max-width: 1250px) {
  #message .ttl-box .jp {
    top: 14.8vw;
    left: 36.8vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .ttl-box .jp {
    position: relative;
    top: 0;
    left: 0;
  }
}
#message .image {
  position: relative;
  margin-bottom: 55px;
  transition: all 0.4s ease;
}
@media only screen and (max-width: 1250px) {
  #message .image {
    margin-bottom: 4.4vw;
  }
}
#message .image::before, #message .image::after {
  content: "";
  position: absolute;
  display: block;
  width: 50px;
  height: 50px;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 1250px) {
  #message .image::before, #message .image::after {
    width: 4vw;
    height: 4vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .image::before, #message .image::after {
    width: 7.8125vw;
    height: 7.8125vw;
  }
}
#message .image::before {
  bottom: -2px;
  left: -2px;
  border-bottom: 4px solid #FF1A2B;
  border-left: 4px solid #FF1A2B;
}
@media only screen and (max-width: 1250px) {
  #message .image::before {
    bottom: -0.16vw;
    left: -0.16vw;
    border-bottom-width: 0.32vw;
    border-left-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .image::before {
    bottom: -0.3125vw;
    left: -0.3125vw;
    border-bottom-width: 0.625vw;
    border-left-width: 0.625vw;
  }
}
#message .image::after {
  top: -2px;
  right: -2px;
  border-top: 4px solid #FF1A2B;
  border-right: 4px solid #FF1A2B;
}
@media only screen and (max-width: 1250px) {
  #message .image::after {
    top: -0.16vw;
    right: -0.16vw;
    border-top-width: 0.32vw;
    border-right-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .image::after {
    top: -0.3125vw;
    right: -0.3125vw;
    border-top-width: 0.625vw;
    border-right-width: 0.625vw;
  }
}
#message .image span::before, #message .image span::after {
  content: "";
  position: absolute;
  display: block;
  width: 50px;
  height: 50px;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 1250px) {
  #message .image span::before, #message .image span::after {
    width: 4vw;
    height: 4vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .image span::before, #message .image span::after {
    width: 7.8125vw;
    height: 7.8125vw;
  }
}
#message .image span::before {
  top: -2px;
  left: -2px;
  border-top: 4px solid #FF1A2B;
  border-left: 4px solid #FF1A2B;
}
@media only screen and (max-width: 1250px) {
  #message .image span::before {
    top: -0.16vw;
    left: -0.16vw;
    border-top-width: 0.32vw;
    border-left-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .image span::before {
    top: -0.3125vw;
    left: -0.3125vw;
    border-top-width: 0.625vw;
    border-left-width: 0.625vw;
  }
}
#message .image span::after {
  bottom: -2px;
  right: -2px;
  border-bottom: 4px solid #FF1A2B;
  border-right: 4px solid #FF1A2B;
}
@media only screen and (max-width: 1250px) {
  #message .image span::after {
    bottom: -0.16vw;
    right: -0.16vw;
    border-bottom-width: 0.32vw;
    border-right-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #message .image span::after {
    bottom: -0.3125vw;
    right: -0.3125vw;
    border-bottom-width: 0.625vw;
    border-right-width: 0.625vw;
  }
}
#message .image a {
  position: relative;
  display: block;
  border: 1px solid #FF1A2B;
  transition: all 0.3s ease;
  overflow: hidden;
}
#message .image a img {
  transition: all 0.4s ease;
}
#message .image:hover {
  transform: scale(1.02);
}
#message .image:hover::before, #message .image:hover::after {
  border-color: #fff;
}
#message .image:hover span::before, #message .image:hover span::after {
  border-color: #fff;
}
#message .image:hover a {
  border-color: #fff;
}
#message .image:hover a img {
  filter: brightness(1.1);
  transform: scale(0.95);
}
#message .image.off {
  pointer-events: none;
}
#message .bg-deco1 {
  opacity: 0;
  transform: translateY(-100px);
  transition: all 1.5s ease;
}
@media only screen and (max-width: 768px) {
  #message .bg-deco1 {
    transform: translateY(-15.625vw);
  }
}
#message .bg-deco2 {
  opacity: 0;
  transform: scale(1.2);
  transition: all 1.5s 0.2s ease;
}
@media only screen and (max-width: 768px) {
  #message .bg-deco2 {
    transform: scale(1);
  }
}
#message .message__box {
  opacity: 0;
  transform: scale(1.1);
  transition: all 0.7s 1.3s ease;
}
#message .btn {
  opacity: 0;
  transition: all 0.5s 1.5s ease;
}
#message.move-on .bg-deco1 {
  opacity: 1;
  transform: translateY(0px);
}
#message.move-on .bg-deco2 {
  opacity: 1;
  transform: scale(1);
}
#message.move-on .ttl-box h2 .shine2 {
  -webkit-animation: moveToFinal2 0.6s 1.2s ease-in-out forwards;
          animation: moveToFinal2 0.6s 1.2s ease-in-out forwards;
}
#message.move-on .message__box {
  transform: scale(1);
  opacity: 1;
}
#message.move-on .btn {
  opacity: 1;
}

#album {
  padding: 160px 0 0;
  box-sizing: border-box;
  z-index: 2;
}
@media only screen and (max-width: 1250px) {
  #album {
    padding: 12.8vw 0 0;
  }
}
@media only screen and (max-width: 768px) {
  #album {
    padding: 15.625vw 0 0;
    margin-bottom: 18.75vw;
  }
}
#album .sec-bg {
  position: absolute;
  top: -140px;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
}
@media only screen and (max-width: 2000px) {
  #album .sec-bg {
    min-width: 2000px;
  }
}
@media only screen and (max-width: 1250px) {
  #album .sec-bg {
    min-width: unset;
    width: 164vw;
    top: -11.2vw;
  }
}
@media only screen and (max-width: 768px) {
  #album .sec-bg {
    width: 106.25vw;
    top: 0;
  }
}
#album .ttl-box h2 {
  width: 556px;
}
@media only screen and (max-width: 1250px) {
  #album .ttl-box h2 {
    width: 44.48vw;
  }
}
@media only screen and (max-width: 768px) {
  #album .ttl-box h2 {
    width: 56.5625vw;
  }
}
#album .ttl-box h2::before {
  display: none;
}
#album .ttl-box h2 .ttl {
  width: 435px;
  top: 48px;
  left: 30px;
}
@media only screen and (max-width: 1250px) {
  #album .ttl-box h2 .ttl {
    width: 34.8vw;
    top: 3.84vw;
    left: 2.4vw;
  }
}
@media only screen and (max-width: 768px) {
  #album .ttl-box h2 .ttl {
    width: 44.0625vw;
    top: 5vw;
    left: 3.125vw;
  }
}
#album .ttl-box h2 .shine {
  width: 96px;
  top: 28px;
  left: 424px;
}
@media only screen and (max-width: 1250px) {
  #album .ttl-box h2 .shine {
    width: 7.68vw;
    top: 2.24vw;
    left: 33.92vw;
  }
}
@media only screen and (max-width: 768px) {
  #album .ttl-box h2 .shine {
    width: 9.6875vw;
    top: 3.28125vw;
    left: 42.96875vw;
  }
}
#album .ttl-box .jp {
  text-shadow: none;
  color: #00D1D1;
}
#album .album__box {
  margin-bottom: 65px;
}
@media only screen and (max-width: 1250px) {
  #album .album__box {
    margin-bottom: 5.2vw;
  }
}
@media only screen and (max-width: 768px) {
  #album .album__box {
    margin-bottom: 7.8125vw;
  }
}
#album .album__box .cover {
  position: relative;
  width: 670px;
  margin: 0 auto 45px;
}
@media only screen and (max-width: 1250px) {
  #album .album__box .cover {
    width: 53.6vw;
  }
}
@media only screen and (max-width: 768px) {
  #album .album__box .cover {
    width: 85vw;
    margin: 0 auto 4.0625vw;
  }
}
#album .album__box .cover::before {
  content: "";
  position: absolute;
  top: 0;
  left: 10px;
  display: block;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(0deg, rgb(226, 181, 108), rgb(0, 209, 209));
}
@media only screen and (max-width: 1250px) {
  #album .album__box .cover::before {
    left: 0.8vw;
  }
}
@media only screen and (max-width: 768px) {
  #album .album__box .cover::before {
    left: 1.25vw;
  }
}
#album .album__box .cover img {
  position: relative;
  top: -15px;
  left: -10px;
}
@media only screen and (max-width: 1250px) {
  #album .album__box .cover img {
    top: -1.2vw;
    left: -0.8vw;
  }
}
@media only screen and (max-width: 768px) {
  #album .album__box .cover img {
    top: -1.875vw;
    left: -1.25vw;
  }
}
#album .album__box .logo {
  position: relative;
  width: 586px;
  margin: 0 auto 22px;
  z-index: 2;
}
@media only screen and (max-width: 1250px) {
  #album .album__box .logo {
    width: 46.88vw;
    margin: 0 auto 1.76vw;
  }
}
@media only screen and (max-width: 768px) {
  #album .album__box .logo {
    width: 75.625vw;
    margin: 0 auto 2.34375vw;
  }
}
#album .album__box .txt-box {
  position: relative;
  width: 890px;
  margin: 0 auto;
  padding: 45px 70px;
  border: 1px solid #C39B52;
  background-color: rgba(255, 255, 255, 0.55);
}
@media only screen and (max-width: 1250px) {
  #album .album__box .txt-box {
    width: 71.2vw;
    padding: 3.6vw 5.6vw;
  }
}
@media only screen and (max-width: 768px) {
  #album .album__box .txt-box {
    width: 87.5vw;
    margin: 0 auto;
    padding: 5.46875vw 7.03125vw;
  }
}
#album .album__box .txt-box::before, #album .album__box .txt-box::after {
  content: "";
  position: absolute;
  display: block;
  width: 50px;
  height: 50px;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 1250px) {
  #album .album__box .txt-box::before, #album .album__box .txt-box::after {
    width: 4vw;
    height: 4vw;
  }
}
@media only screen and (max-width: 768px) {
  #album .album__box .txt-box::before, #album .album__box .txt-box::after {
    width: 7.8125vw;
    height: 7.8125vw;
  }
}
#album .album__box .txt-box::before {
  bottom: -2px;
  left: -2px;
  border-bottom: 4px solid #C39B52;
  border-left: 4px solid #C39B52;
}
@media only screen and (max-width: 1250px) {
  #album .album__box .txt-box::before {
    bottom: -0.16vw;
    left: -0.16vw;
    border-bottom-width: 0.32vw;
    border-left-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #album .album__box .txt-box::before {
    bottom: -0.3125vw;
    left: -0.3125vw;
    border-bottom-width: 0.625vw;
    border-left-width: 0.625vw;
  }
}
#album .album__box .txt-box::after {
  top: -2px;
  right: -2px;
  border-top: 4px solid #C39B52;
  border-right: 4px solid #C39B52;
}
@media only screen and (max-width: 1250px) {
  #album .album__box .txt-box::after {
    top: -0.16vw;
    right: -0.16vw;
    border-top-width: 0.32vw;
    border-right-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #album .album__box .txt-box::after {
    top: -0.3125vw;
    right: -0.3125vw;
    border-top-width: 0.625vw;
    border-right-width: 0.625vw;
  }
}
#album .album__box .txt-box p {
  font-size: 16px;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  line-height: 2.4;
  font-weight: bold;
}
@media only screen and (max-width: 1250px) {
  #album .album__box .txt-box p {
    font-size: 1.28vw;
  }
}
@media only screen and (max-width: 768px) {
  #album .album__box .txt-box p {
    font-size: 3.125vw;
  }
}
#album .btn a {
  background-color: transparent;
  border-color: #FF1A2B;
}
#album .btn a span {
  color: #FF1A2B;
}
#album .btn a::after {
  background-image: url("../img/parts/arrow_rd.svg");
}
#album .btn a:hover span {
  color: #fff;
}
#album .btn a:hover::after {
  background-image: url("../img/parts/arrow_wh.svg");
}
#album .ttl-box h2 {
  transition: all 0.6s 0s ease;
}
#album .ttl-box h2::before {
  transition: all 0.5s 1s ease;
}
#album .ttl-box h2 .ttl {
  transition: all 0.6s 0.2s ease;
}
#album .ttl-box h2 .ttl svg {
  transition: all 0.6s 0.6s ease;
}
#album .ttl-box h2 .shadow {
  transition: all 0.6s 0.8s ease;
}
#album .ttl-box .jp {
  transition: all 0.6s 1.1s ease;
}
#album .ttl-box .deco {
  transition: all 0.6s 1.3s ease;
}
#album .cover::before {
  opacity: 0;
  transform: translateX(-10px);
  transition: all 0.6s 1.2s ease;
}
@media only screen and (max-width: 1250px) {
  #album .cover::before {
    transform: translateX(-0.8vw);
  }
}
@media only screen and (max-width: 768px) {
  #album .cover::before {
    transform: translateX(-1.25vw);
  }
}
#album .cover img {
  opacity: 0;
  transform: translateY(15px) translateX(10px);
  transition: all 0.6s 1.3s ease;
}
@media only screen and (max-width: 1250px) {
  #album .cover img {
    transform: translateY(1.2vw) translateX(0.8vw);
  }
}
@media only screen and (max-width: 768px) {
  #album .cover img {
    transform: translateY(1.875vw) translateX(1.25vw);
  }
}
#album .logo {
  opacity: 0;
  transform: translateY(50px);
  transition: all 0.6s 1.5s ease;
}
@media only screen and (max-width: 768px) {
  #album .logo {
    transform: translateY(7.8125vw);
  }
}
#album .txt-box {
  opacity: 0;
  transform: translateY(-50px);
  transition: all 0.6s 1.6s ease;
}
@media only screen and (max-width: 768px) {
  #album .txt-box {
    transform: translateY(-7.8125vw);
  }
}
#album .btn {
  opacity: 0;
  transition: all 0.6s 2s ease;
}
#album.move-on .ttl-box h2 .shine {
  -webkit-animation: moveToFinal 0.6s 0.6s ease-in-out forwards;
          animation: moveToFinal 0.6s 0.6s ease-in-out forwards;
}
#album.move-on .ttl-box h2 .shine svg {
  -webkit-animation: rotateYAnim 0.7s ease 0.3s 2;
          animation: rotateYAnim 0.7s ease 0.3s 2;
}
#album.move-on .cover::before {
  opacity: 1;
  transform: translateX(0px);
}
#album.move-on .cover img {
  opacity: 1;
  transform: translateY(0px) translateX(0px);
}
#album.move-on .logo, #album.move-on .txt-box {
  opacity: 1;
  transform: translateY(0px);
}
#album.move-on .btn {
  opacity: 1;
}

#video {
  padding: 260px 0 100px;
}
@media only screen and (max-width: 1250px) {
  #video {
    padding: 20.8vw 0 8vw;
  }
}
@media only screen and (max-width: 768px) {
  #video {
    padding: 15.9375vw 0 42.1875vw;
  }
}
#video .bg-deco1 {
  position: absolute;
  top: 90px;
  left: 0;
  pointer-events: none;
}
@media only screen and (max-width: 1250px) {
  #video .bg-deco1 {
    top: 7.2vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .bg-deco1 {
    top: 0;
  }
}
#video .bg-deco2 {
  position: absolute;
  top: -204px;
  left: 0;
  z-index: 2;
  pointer-events: none;
}
@media only screen and (max-width: 1250px) {
  #video .bg-deco2 {
    top: -16.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .bg-deco2 {
    top: 10.3125vw;
  }
}
#video .spot.left {
  top: 312px;
}
@media only screen and (max-width: 1250px) {
  #video .spot.left {
    top: 24.96vw;
  }
}
#video .spot.right {
  top: 132px;
}
@media only screen and (max-width: 1250px) {
  #video .spot.right {
    top: 10.56vw;
  }
}
#video .spot.right .blur-wrap:nth-child(1) span {
  background-color: #27A549;
}
#video .ttl-box {
  z-index: 2;
}
#video .ttl-box h2 {
  width: 449px;
}
@media only screen and (max-width: 1250px) {
  #video .ttl-box h2 {
    width: 35.92vw;
  }
}
#video .ttl-box h2::before {
  background-image: url("../img/video/ttl_deco.png");
}
#video .ttl-box h2 .ttl {
  width: 372px;
  top: 48px;
  left: 30px;
}
@media only screen and (max-width: 1250px) {
  #video .ttl-box h2 .ttl {
    width: 29.76vw;
    top: 3.84vw;
    left: 2.4vw;
  }
}
#video .ttl-box h2 .shine {
  width: 96px;
  top: 28px;
  left: 275px;
}
@media only screen and (max-width: 1250px) {
  #video .ttl-box h2 .shine {
    width: 7.68vw;
    top: 2.24vw;
    left: 22vw;
  }
}
#video .ttl-box .jp {
  text-shadow: 0 0 12px #29FF63;
}
#video .video__list {
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  padding-bottom: 75px;
  padding-top: 12px;
  margin-bottom: 60px;
  z-index: 2;
}
@media only screen and (max-width: 2000px) {
  #video .video__list {
    padding-bottom: 3.75vw;
    padding-top: 0.6vw;
    margin-bottom: 3vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list {
    padding: 1.71875vw 6.875vw 0;
    margin-bottom: 9.375vw;
  }
}
#video .video__list .frame {
  position: absolute;
  top: 0.2vw;
  left: 50%;
  transform: translateX(-50%);
  width: 50.25vw;
  height: 27.35vw;
  z-index: 2;
  pointer-events: none;
  border: 1px solid #FF1A2B;
}
@media only screen and (max-width: 2000px) {
  #video .video__list .frame {
    top: 0.2vw;
    width: 50.2vw;
    height: 27.35vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .frame {
    top: 1.71875vw;
    width: 86.5625vw;
    height: 46.875vw;
  }
}
#video .video__list .frame::before, #video .video__list .frame::after {
  content: "";
  position: absolute;
  display: block;
  width: 50px;
  height: 50px;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 1250px) {
  #video .video__list .frame::before, #video .video__list .frame::after {
    width: 4vw;
    height: 4vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .frame::before, #video .video__list .frame::after {
    width: 7.8125vw;
    height: 7.8125vw;
  }
}
#video .video__list .frame::before {
  bottom: -2px;
  left: -2px;
  border-bottom: 4px solid #FF1A2B;
  border-left: 4px solid #FF1A2B;
}
@media only screen and (max-width: 1250px) {
  #video .video__list .frame::before {
    bottom: -0.16vw;
    left: -0.16vw;
    border-bottom-width: 0.32vw;
    border-left-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .frame::before {
    bottom: -0.3125vw;
    left: -0.3125vw;
    border-bottom-width: 0.625vw;
    border-left-width: 0.625vw;
  }
}
#video .video__list .frame::after {
  top: -2px;
  right: -2px;
  border-top: 4px solid #FF1A2B;
  border-right: 4px solid #FF1A2B;
}
@media only screen and (max-width: 1250px) {
  #video .video__list .frame::after {
    top: -0.16vw;
    right: -0.16vw;
    border-top-width: 0.32vw;
    border-right-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .frame::after {
    top: -0.3125vw;
    right: -0.3125vw;
    border-top-width: 0.625vw;
    border-right-width: 0.625vw;
  }
}
#video .video__list .frame span::before, #video .video__list .frame span::after {
  content: "";
  position: absolute;
  display: block;
  width: 50px;
  height: 50px;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 1250px) {
  #video .video__list .frame span::before, #video .video__list .frame span::after {
    width: 4vw;
    height: 4vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .frame span::before, #video .video__list .frame span::after {
    width: 7.8125vw;
    height: 7.8125vw;
  }
}
#video .video__list .frame span::before {
  top: -2px;
  left: -2px;
  border-top: 4px solid #FF1A2B;
  border-left: 4px solid #FF1A2B;
}
@media only screen and (max-width: 1250px) {
  #video .video__list .frame span::before {
    top: -0.16vw;
    left: -0.16vw;
    border-top-width: 0.32vw;
    border-left-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .frame span::before {
    top: -0.3125vw;
    left: -0.3125vw;
    border-top-width: 0.625vw;
    border-left-width: 0.625vw;
  }
}
#video .video__list .frame span::after {
  bottom: -2px;
  right: -2px;
  border-bottom: 4px solid #FF1A2B;
  border-right: 4px solid #FF1A2B;
}
@media only screen and (max-width: 1250px) {
  #video .video__list .frame span::after {
    bottom: -0.16vw;
    right: -0.16vw;
    border-bottom-width: 0.32vw;
    border-right-width: 0.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .frame span::after {
    bottom: -0.3125vw;
    right: -0.3125vw;
    border-bottom-width: 0.625vw;
    border-right-width: 0.625vw;
  }
}
#video .video__list .wrap {
  position: absolute;
  top: 0px;
  left: 50%;
  transform: translateX(-50%);
  width: 47.3vw;
  z-index: 2;
}
@media only screen and (max-width: 2000px) {
  #video .video__list .wrap {
    top: 0vw;
    width: 47.3vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .wrap {
    width: 86.5625vw;
  }
}
#video .video__list .swiper-wrapper {
  width: 100%;
  height: 21.25vw;
  padding: 2.6vw 0;
}
@media only screen and (max-width: 2000px) {
  #video .video__list .swiper-wrapper {
    height: 21.25vw;
    padding: 2.6vw 0;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-wrapper {
    height: 46.875vw;
    padding: 0 0 12.1875vw;
  }
}
#video .video__list .swiper-wrapper .swiper-slide {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: all 0.4s 0.2s ease;
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-wrapper .swiper-slide {
    opacity: 0;
  }
}
#video .video__list .swiper-wrapper .swiper-slide::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(54, 54, 54, 0.7);
}
#video .video__list .swiper-wrapper .swiper-slide a {
  position: relative;
  width: 100%;
  height: 100%;
  filter: blur(3px);
  transition: all 0.5s ease;
}
#video .video__list .swiper-wrapper .swiper-slide a::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  width: 207px;
  height: 207px;
  border-radius: 200px;
  border: 2px solid #FF1A2B;
  transform-origin: center;
  transition: all 0.35s ease;
  opacity: 0;
  z-index: 2;
}
@media only screen and (max-width: 1250px) {
  #video .video__list .swiper-wrapper .swiper-slide a::before {
    width: 16.56vw;
    height: 16.56vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-wrapper .swiper-slide a::before {
    width: 7.5vw;
    height: 7.5vw;
    border-width: 0.3125vw;
    border-radius: 15.625vw;
  }
}
#video .video__list .swiper-wrapper .swiper-slide a::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 51%;
  transform: translate(-50%, -50%);
  width: 106px;
  height: 122px;
  background-image: linear-gradient(90deg, #fac382, #ff1a2b);
  -webkit-clip-path: polygon(0 0, 0 100%, 100% 50%);
          clip-path: polygon(0 0, 0 100%, 100% 50%);
  transition: all 0.35s 0.1s ease;
  transform-origin: center;
  opacity: 0;
}
@media only screen and (max-width: 1250px) {
  #video .video__list .swiper-wrapper .swiper-slide a::after {
    width: 8.48vw;
    height: 9.76vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-wrapper .swiper-slide a::after {
    width: 3.90625vw;
    height: 4.53125vw;
  }
}
#video .video__list .swiper-wrapper .swiper-slide a .image {
  width: 100%;
  height: 100%;
  overflow: hidden;
}
#video .video__list .swiper-wrapper .swiper-slide a .image img {
  transition: all 0.38s ease-out;
}
#video .video__list .swiper-wrapper .swiper-slide.swiper-slide-active {
  transform: scale(1.285);
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-wrapper .swiper-slide.swiper-slide-active {
    transform: scale(1);
    opacity: 1;
  }
}
#video .video__list .swiper-wrapper .swiper-slide.swiper-slide-active a {
  filter: blur(0);
}
#video .video__list .swiper-wrapper .swiper-slide.swiper-slide-active a::before, #video .video__list .swiper-wrapper .swiper-slide.swiper-slide-active a::after {
  transform: scale(1) translate(-50%, -50%);
  opacity: 1;
}
#video .video__list .swiper-wrapper .swiper-slide.swiper-slide-active a:hover .image img {
  transform: scale(1.1);
}
#video .video__list .swiper-wrapper .swiper-slide.swiper-slide-active a:hover::before, #video .video__list .swiper-wrapper .swiper-slide.swiper-slide-active a:hover::after {
  transform: translate(-50%, -50%) scale(0.9);
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-wrapper .swiper-slide.swiper-slide-active a:hover::before, #video .video__list .swiper-wrapper .swiper-slide.swiper-slide-active a:hover::after {
    transform: translate(-50%, -50%) scale(1);
  }
}
#video .video__list .swiper-wrapper .swiper-slide.swiper-slide-active::after {
  opacity: 0;
  visibility: hidden;
}
#video .video__list .swiper-wrapper .swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#video .video__list .swiper-pagination {
  bottom: 15px;
}
@media only screen and (max-width: 2000px) {
  #video .video__list .swiper-pagination {
    bottom: 0.75vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-pagination {
    bottom: 3.125vw;
  }
}
#video .video__list .swiper-pagination .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  border: 1px solid #fff;
  opacity: 1;
  transition: all 0.4s ease;
  background-color: transparent;
}
@media only screen and (max-width: 2000px) {
  #video .video__list .swiper-pagination .swiper-pagination-bullet {
    width: 0.6vw;
    height: 0.6vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-pagination .swiper-pagination-bullet {
    width: 1.875vw;
    height: 1.875vw;
  }
}
#video .video__list .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background-color: #FF1A2B;
  transform: scale(1.3);
  border-color: #FF1A2B;
}
#video .video__list .swiper-button-prev1,
#video .video__list .swiper-button-next1 {
  top: 12.15vw;
  transform: unset;
  width: 2.9vw;
  height: 3.5vw;
  margin: 0;
  background: url("../img/parts/arrow_dot.svg") no-repeat top center;
  background-size: contain;
  border-radius: 100px;
  transition: all 0.35s ease;
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-button-prev1,
#video .video__list .swiper-button-next1 {
    top: 19.84375vw;
    width: 10.3125vw;
    height: 10.3125vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-button-prev1,
#video .video__list .swiper-button-next1 {
    top: 21.875vw;
    width: 4.6875vw;
    height: 6.5625vw;
  }
}
#video .video__list .swiper-button-prev1 svg,
#video .video__list .swiper-button-next1 svg {
  display: none;
}
#video .video__list .swiper-button-prev1::after,
#video .video__list .swiper-button-next1::after {
  display: none;
}
#video .video__list .swiper-button-prev1 {
  left: calc(50% - 28.5vw);
  transform: rotate(180deg);
  transform-origin: center;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-button-prev1 {
    left: -5.46875vw;
  }
}
#video .video__list .swiper-button-prev1:hover {
  transform: rotate(180deg) translateX(10px);
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-button-prev1:hover {
    transform: rotate(180deg) translateX(0);
  }
}
#video .video__list .swiper-button-next1 {
  right: calc(50% - 28.5vw);
  transition: all 0.3s ease;
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-button-next1 {
    right: -5.46875vw;
  }
}
#video .video__list .swiper-button-next1:hover {
  transform: translateX(10px);
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-button-next1:hover {
    transform: translateX(0);
  }
}
#video .video__list .swiper-button-prev2,
#video .video__list .swiper-button-next2 {
  display: block;
  width: 133px;
  height: 40px;
  top: inherit;
  bottom: 0;
  transition: all 0.4s ease;
}
@media only screen and (max-width: 2000px) {
  #video .video__list .swiper-button-prev2,
#video .video__list .swiper-button-next2 {
    width: 6.65vw;
    height: 2vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-button-prev2,
#video .video__list .swiper-button-next2 {
    width: 21.40625vw;
    height: 7.5vw;
  }
}
#video .video__list .swiper-button-prev2 svg,
#video .video__list .swiper-button-next2 svg {
  display: none;
}
#video .video__list .swiper-button-prev2::after,
#video .video__list .swiper-button-next2::after {
  display: none;
}
#video .video__list .swiper-button-prev2 {
  left: calc(50% - 226px);
  background: url("../img/video/prev.svg") no-repeat top center;
  background-size: contain;
}
@media only screen and (max-width: 2000px) {
  #video .video__list .swiper-button-prev2 {
    left: calc(50% - 11vw);
    padding-left: 1.75vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-button-prev2 {
    left: 18.4375vw;
  }
}
#video .video__list .swiper-button-prev2:hover {
  transform: translateX(-10px);
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-button-prev2:hover {
    transform: translateX(0);
  }
}
#video .video__list .swiper-button-next2 {
  right: calc(50% - 226px);
  background: url("../img/video/next.svg") no-repeat top center;
  background-size: contain;
}
@media only screen and (max-width: 2000px) {
  #video .video__list .swiper-button-next2 {
    right: calc(50% - 11vw);
    padding-right: 1.75vw;
  }
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-button-next2 {
    right: 18.4375vw;
  }
}
#video .video__list .swiper-button-next2:hover {
  transform: translateX(10px);
}
@media only screen and (max-width: 768px) {
  #video .video__list .swiper-button-next2:hover {
    transform: translateX(0);
  }
}
#video .bg-deco1 {
  opacity: 0;
  transform: scale(1.5) translate(-180px, 180px);
  transition: all 1.5s ease;
}
@media only screen and (max-width: 768px) {
  #video .bg-deco1 {
    transform: translate(-28.125vw, 28.125vw);
  }
}
#video .bg-deco2 {
  opacity: 0;
  transform: translateY(-100px);
  filter: blur(6px);
  transition: all 1.5s 0.2s ease;
}
@media only screen and (max-width: 768px) {
  #video .bg-deco2 {
    transform: translateY(-15.625vw);
    filter: blur(0px);
  }
}
#video .video__list {
  opacity: 0;
  transition: all 0.7s 1.3s ease;
}
#video .btn {
  opacity: 0;
  transition: all 0.5s 1.5s ease;
}
#video.move-on .bg-deco1 {
  opacity: 1;
  transform: scale(1) translate(0px, 0px);
}
#video.move-on .bg-deco2 {
  opacity: 1;
  filter: blur(0px);
  transform: translateY(0);
}
#video.move-on .video__list {
  opacity: 1;
}
#video.move-on .btn {
  opacity: 1;
}

#member {
  padding: 190px 0 0;
}
@media only screen and (max-width: 1850px) {
  #member {
    padding: 9.5vw 0 0;
  }
}
@media only screen and (max-width: 768px) {
  #member {
    padding: 0;
  }
}
#member .sec-bg {
  position: absolute;
  top: 0;
  left: 0;
}
@media only screen and (max-width: 768px) {
  #member .sec-bg {
    top: inherit;
    bottom: 0;
  }
}
#member h2 {
  position: relative;
  margin-bottom: -5px;
}
@media only screen and (max-width: 1250px) {
  #member h2 {
    margin-bottom: -0.4vw;
  }
}
@media only screen and (max-width: 768px) {
  #member h2 {
    margin-bottom: -0.3125vw;
  }
}
#member h2 svg {
  width: 100%;
  height: auto;
}
#member h2 .h-txt {
  display: block;
  width: 1000px;
  margin: 0 auto;
}
@media only screen and (max-width: 1850px) {
  #member h2 .h-txt {
    width: 80vw;
  }
}
@media only screen and (max-width: 768px) {
  #member h2 .h-txt {
    width: 87.5vw;
  }
}
#member .member__list {
  display: flex;
  justify-content: center;
  gap: 0 70px;
}
@media only screen and (max-width: 768px) {
  #member .member__list {
    display: grid;
    grid-template-columns: repeat(2, 41.09375vw);
    gap: 6.5625vw 4.6875vw;
  }
}
#member .member__list__box {
  position: relative;
  width: 398px;
}
@media only screen and (max-width: 1850px) {
  #member .member__list__box {
    width: 19.9vw;
  }
}
@media only screen and (max-width: 768px) {
  #member .member__list__box {
    width: auto;
  }
}
#member .member__list__box a {
  display: block;
  height: 100%;
  padding: 10px;
  background-color: #fff;
  transition: all 0.3s ease;
  padding-bottom: 90px;
  box-sizing: border-box;
}
@media only screen and (max-width: 1850px) {
  #member .member__list__box a {
    padding: 0.5vw;
    padding-bottom: 4.5vw;
  }
}
@media only screen and (max-width: 768px) {
  #member .member__list__box a {
    padding: 1.5625vw;
    padding-bottom: 9.375vw;
  }
}
#member .member__list__box a:hover .illust span {
  transform: scale(1.1);
}
@media only screen and (max-width: 768px) {
  #member .member__list__box a:hover .illust span {
    transform: scale(1);
  }
}
#member .member__list__box a:hover .name svg {
  transform: scale(1.08) translateY(-100px);
}
@media only screen and (max-width: 1850px) {
  #member .member__list__box a:hover .name svg {
    transform: scale(1.08) translateY(-8vw);
  }
}
@media only screen and (max-width: 768px) {
  #member .member__list__box a:hover .name svg {
    transform: unset;
  }
}
#member .member__list__box .wrap {
  position: relative;
  height: 760px;
  background-color: #eee;
  overflow: hidden;
}
@media only screen and (max-width: 1850px) {
  #member .member__list__box .wrap {
    height: 38vw;
  }
}
@media only screen and (max-width: 768px) {
  #member .member__list__box .wrap {
    height: 42.96875vw;
  }
}
#member .member__list__box .triangle {
  position: absolute;
  top: 105px;
  left: -110px;
  width: 577px;
  height: 666px;
  transform: rotate(6deg);
  transform-origin: left center;
  -webkit-clip-path: polygon(100% 0, 0 50%, 100% 100%);
          clip-path: polygon(100% 0, 0 50%, 100% 100%);
  background-image: linear-gradient(90deg, #e4faf4, #dddddd);
}
@media only screen and (max-width: 1850px) {
  #member .member__list__box .triangle {
    top: 5.25vw;
    left: -5.5vw;
    width: 28.85vw;
    height: 33.3vw;
  }
}
@media only screen and (max-width: 768px) {
  #member .member__list__box .triangle {
    width: 59.0625vw;
    height: 43.75vw;
    top: -1.875vw;
    left: -13.4375vw;
    transform: rotate(4deg);
  }
}
#member .member__list__box .illust span {
  display: block;
  transform-origin: top center;
  transition: all 0.3s ease;
}
#member .member__list__box .name {
  position: absolute;
  top: 686px;
  left: 0;
}
@media only screen and (max-width: 1850px) {
  #member .member__list__box .name {
    top: 34.3vw;
  }
}
@media only screen and (max-width: 768px) {
  #member .member__list__box .name {
    top: 35.9375vw;
  }
}
#member .member__list__box .name svg {
  width: 100%;
  height: auto;
  transition: all 0.3s 0.1s ease;
}
#member .member__list__box.raden .wrap {
  background-color: #27C487;
}
#member .member__list__box.raden .triangle {
  background-image: linear-gradient(90deg, #e4faf4, #27c487);
}
#member .member__list__box.raden .illust {
  position: absolute;
  top: -20px;
  left: -145px;
  width: 558px;
}
@media only screen and (max-width: 1850px) {
  #member .member__list__box.raden .illust {
    width: 27.9vw;
    top: -1vw;
    left: -7.25vw;
  }
}
@media only screen and (max-width: 768px) {
  #member .member__list__box.raden .illust {
    width: 54.53125vw;
    top: -1.5625vw;
    left: -11.25vw;
  }
}
#member .member__list__box.raden .name {
  width: 358px;
}
@media only screen and (max-width: 1850px) {
  #member .member__list__box.raden .name {
    width: 17.9vw;
  }
}
@media only screen and (max-width: 768px) {
  #member .member__list__box.raden .name {
    width: 37.03125vw;
  }
}
#member .member__list__box.hajime .wrap {
  background-color: #BABEF4;
}
#member .member__list__box.hajime .triangle {
  background-image: linear-gradient(90deg, #f8f9fd, #9ea4eb);
}
#member .member__list__box.hajime .illust {
  position: absolute;
  top: -5px;
  left: -170px;
  width: 558px;
}
@media only screen and (max-width: 1850px) {
  #member .member__list__box.hajime .illust {
    top: -0.25vw;
    left: -8.5vw;
    width: 27.9vw;
  }
}
@media only screen and (max-width: 768px) {
  #member .member__list__box.hajime .illust {
    width: 56.40625vw;
    top: -15.625vw;
    left: -20.78125vw;
  }
}
#member .member__list__box.hajime .name {
  width: 327px;
}
@media only screen and (max-width: 1850px) {
  #member .member__list__box.hajime .name {
    width: 16.35vw;
  }
}
@media only screen and (max-width: 768px) {
  #member .member__list__box.hajime .name {
    width: 33.75vw;
  }
}
#member .member__list__box.kanade .wrap {
  background-color: #FFE267;
}
#member .member__list__box.kanade .triangle {
  background-image: linear-gradient(90deg, #fffefa, #ffd72f);
}
#member .member__list__box.kanade .illust {
  position: absolute;
  top: -15px;
  left: -48px;
  width: 524px;
}
@media only screen and (max-width: 1850px) {
  #member .member__list__box.kanade .illust {
    top: -0.75vw;
    left: -2.4vw;
    width: 26.2vw;
  }
}
@media only screen and (max-width: 768px) {
  #member .member__list__box.kanade .illust {
    width: 49.84375vw;
    top: -9.0625vw;
    left: -4.0625vw;
  }
}
#member .member__list__box.kanade .name {
  width: 298px;
}
@media only screen and (max-width: 1850px) {
  #member .member__list__box.kanade .name {
    width: 14.9vw;
  }
}
@media only screen and (max-width: 768px) {
  #member .member__list__box.kanade .name {
    width: 30.78125vw;
  }
}
#member .member__list__box.ririka .wrap {
  background-color: #FFA5C1;
}
#member .member__list__box.ririka .triangle {
  background-image: linear-gradient(90deg, #fae4e9, #fc6492);
}
#member .member__list__box.ririka .illust {
  position: absolute;
  top: -2px;
  left: -48px;
  width: 471px;
}
@media only screen and (max-width: 1850px) {
  #member .member__list__box.ririka .illust {
    top: -0.1vw;
    left: -2.4vw;
    width: 23.55vw;
  }
}
@media only screen and (max-width: 768px) {
  #member .member__list__box.ririka .illust {
    width: 50.15625vw;
    top: -1.5625vw;
    left: -1.5625vw;
  }
}
#member .member__list__box.ririka .name {
  width: 260px;
}
@media only screen and (max-width: 1850px) {
  #member .member__list__box.ririka .name {
    width: 13vw;
  }
}
@media only screen and (max-width: 768px) {
  #member .member__list__box.ririka .name {
    width: 26.875vw;
  }
}
#member h2 .h-txt {
  opacity: 0;
  transform: translateY(-80px);
  transition: all 0.8s ease;
}
@media only screen and (max-width: 768px) {
  #member h2 .h-txt {
    transform: translateY(-12.5vw);
  }
}
#member h2 .h-txt svg {
  filter: brightness(0);
  transition: all 0.8s 0.5s ease;
}
#member .member__list__box {
  opacity: 0;
  transform: rotateY(360deg) translateY(80px);
  transition: all 0.8s 0.6s ease;
}
@media only screen and (max-width: 768px) {
  #member .member__list__box {
    transform: rotateY(0deg) translateY(12.5vw);
  }
}
#member .member__list__box:nth-child(2) {
  transition-delay: 0.7s;
}
#member .member__list__box:nth-child(3) {
  transition-delay: 0.8s;
}
#member .member__list__box:nth-child(4) {
  transition-delay: 0.9s;
}
#member .member__list__box .wrap {
  opacity: 0;
  transition: all 0.8s 1.4s ease;
}
#member .member__list__box .triangle {
  transform: rotate(6deg) scale(0);
  transition: all 0.6s 1.6s ease;
}
@media only screen and (max-width: 768px) {
  #member .member__list__box .triangle {
    transform: rotate(6deg) scale(1);
  }
}
#member .member__list__box .illust {
  opacity: 0;
  transition: all 0.6s 1.8s ease;
}
#member .member__list__box .illust img {
  filter: brightness(0);
  transition: all 0.4s 2.3s ease;
}
#member .member__list__box .name {
  opacity: 0;
  transform: translateX(-100px);
  transition: all 0.4s 2.2s ease;
}
@media only screen and (max-width: 768px) {
  #member .member__list__box .name {
    transform: translateX(-15.625vw);
  }
}
#member .member__list__box.raden .illust {
  transform: translate(-80px, 80px);
}
@media only screen and (max-width: 768px) {
  #member .member__list__box.raden .illust {
    transform: translate(-12.5vw, 12.5vw);
  }
}
#member .member__list__box.hajime .illust {
  transform: translate(80px, -80px);
}
@media only screen and (max-width: 768px) {
  #member .member__list__box.hajime .illust {
    transform: translate(12.5vw, -12.5vw);
  }
}
#member .member__list__box.kanade .illust {
  transform: translate(80px, 80px);
}
@media only screen and (max-width: 768px) {
  #member .member__list__box.kanade .illust {
    transform: translate(12.5vw, 12.5vw);
  }
}
#member .member__list__box.ririka .illust {
  transform: translate(-80px, -80px);
}
@media only screen and (max-width: 768px) {
  #member .member__list__box.ririka .illust {
    transform: translate(-12.5vw, -12.5vw);
  }
}
#member.move-on h2 .h-txt {
  opacity: 1;
  transform: translateY(0px);
}
#member.move-on h2 .h-txt svg {
  filter: brightness(1);
}
#member.move-on .member__list__box {
  opacity: 1;
  transform: rotateY(0deg) translateY(0px) translateX(0px);
}
#member.move-on .member__list__box .wrap {
  opacity: 1;
}
#member.move-on .member__list__box .triangle {
  opacity: 1;
  transform: rotate(6deg) scale(1);
}
#member.move-on .member__list__box .illust {
  opacity: 1;
  transform: translate(0px, 0px);
}
#member.move-on .member__list__box .illust img {
  filter: brightness(1);
}
#member.move-on .member__list__box .name {
  opacity: 1;
  transform: translateX(0px);
}

#poem {
  padding: 375px 0;
  background: url("../img/poem/bg.webp") repeat-x top center;
  background-size: 2000px auto;
}
@media only screen and (max-width: 2000px) {
  #poem {
    padding: 18.75vw 0;
    background-size: 100vw auto;
  }
}
@media only screen and (max-width: 1250px) {
  #poem {
    padding: 30vw 0;
    background-size: 160vw auto;
  }
}
#poem .shine {
  width: 560px;
  margin: 0 auto;
}
@media only screen and (max-width: 1250px) {
  #poem .shine {
    width: 44.8vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .shine {
    width: 56.5625vw;
  }
}
#poem .shine img {
  margin-left: -80px;
}
@media only screen and (max-width: 1250px) {
  #poem .shine img {
    margin-left: -6.4vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .shine img {
    margin-left: 0;
  }
}
#poem .fade {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1485px;
  background: url("../img/poem/fade-pc.png") repeat-x bottom center;
  background-size: auto 100%;
}
@media only screen and (max-width: 2000px) {
  #poem .fade {
    height: 74.25vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .fade {
    height: 118.8vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .fade {
    height: 149.84375vw;
    background-image: url("../img/poem/fade-sp.png");
  }
}
#poem .light {
  position: absolute;
  width: 1292px;
  transform-origin: left top;
  opacity: 0;
  transition: all 0.6s ease;
}
@media only screen and (max-width: 2000px) {
  #poem .light {
    width: 64.6vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .light {
    width: 103.36vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .light {
    width: 103.4375vw;
  }
}
#poem .light.light1 {
  top: 360px;
  left: -168px;
}
@media only screen and (max-width: 2000px) {
  #poem .light.light1 {
    top: 18vw;
    left: -8.4vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .light.light1 {
    top: 28.8vw;
    left: -13.44vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .light.light1 {
    left: -23.4375vw;
    top: 37.5vw;
  }
}
#poem .light.light2 {
  top: 1205px;
  right: -168px;
  transform-origin: right top;
}
@media only screen and (max-width: 2000px) {
  #poem .light.light2 {
    top: 60.25vw;
    right: -8.4vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .light.light2 {
    top: 96.4vw;
    right: -13.44vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .light.light2 {
    top: 127.5vw;
    right: -20vw;
  }
}
#poem .light.light3 {
  top: 1970px;
  left: -168px;
}
@media only screen and (max-width: 2000px) {
  #poem .light.light3 {
    top: 98.5vw;
    left: -8.4vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .light.light3 {
    top: 157.6vw;
    left: -13.44vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .light.light3 {
    width: 109.375vw;
    top: 210.9375vw;
    left: -18.75vw;
  }
}
#poem .light img {
  filter: brightness(0);
  transition: all 0.6s 0.1s ease;
}
#poem .light.move-on {
  opacity: 1;
}
#poem .light.move-on img {
  filter: brightness(1);
}
#poem .photo {
  position: absolute;
}
#poem .photo img {
  filter: blur(15px);
  transition: all 0.6s ease;
}
#poem .photo.photo1 {
  width: 2000px;
  top: 480px;
  left: calc(50% - 1000px);
}
@media only screen and (max-width: 2000px) {
  #poem .photo.photo1 {
    width: 100vw;
    top: 24vw;
    left: calc(50% - 50vw);
  }
}
@media only screen and (max-width: 1250px) {
  #poem .photo.photo1 {
    width: 160vw;
    top: 38.4vw;
    left: calc(50% - 80vw);
  }
}
@media only screen and (max-width: 768px) {
  #poem .photo.photo1 {
    width: 160vw;
    top: 75vw;
    left: -30.625vw;
  }
}
#poem .photo.photo2 {
  width: 617px;
  top: 651px;
  right: calc(50% - 572px);
}
@media only screen and (max-width: 2000px) {
  #poem .photo.photo2 {
    width: 30.85vw;
    top: 32.55vw;
    right: calc(50% - 28.6vw);
  }
}
@media only screen and (max-width: 1250px) {
  #poem .photo.photo2 {
    width: 49.36vw;
    top: 52.08vw;
    right: calc(50% - 45.76vw);
  }
}
@media only screen and (max-width: 768px) {
  #poem .photo.photo2 {
    width: 49.375vw;
    right: 4.21875vw;
    top: 87.8125vw;
  }
}
#poem .photo.photo3 {
  width: 1025px;
  top: 1070px;
  left: calc(50% - 942px);
}
@media only screen and (max-width: 2000px) {
  #poem .photo.photo3 {
    width: 51.25vw;
    top: 53.5vw;
    left: calc(50% - 47.1vw);
  }
}
@media only screen and (max-width: 1250px) {
  #poem .photo.photo3 {
    width: 82vw;
    top: 85.6vw;
    left: calc(50% - 75.36vw);
  }
}
@media only screen and (max-width: 768px) {
  #poem .photo.photo3 {
    width: 82.03125vw;
    top: 120.625vw;
    left: -25.3125vw;
  }
}
#poem .photo.photo4 {
  width: 435px;
  top: 1090px;
  right: calc(50% - 842px);
}
@media only screen and (max-width: 2000px) {
  #poem .photo.photo4 {
    width: 21.75vw;
    top: 54.5vw;
    right: calc(50% - 42.1vw);
  }
}
@media only screen and (max-width: 1250px) {
  #poem .photo.photo4 {
    width: 34.8vw;
    top: 87.2vw;
    right: calc(50% - 67.36vw);
  }
}
@media only screen and (max-width: 768px) {
  #poem .photo.photo4 {
    width: 34.84375vw;
    top: 122.1875vw;
    right: -17.34375vw;
  }
}
#poem .photo.photo5 {
  width: 544px;
  top: 1700px;
  left: calc(50% - 792px);
}
@media only screen and (max-width: 2000px) {
  #poem .photo.photo5 {
    width: 27.2vw;
    top: 85vw;
    left: calc(50% - 39.6vw);
  }
}
@media only screen and (max-width: 1250px) {
  #poem .photo.photo5 {
    width: 43.52vw;
    top: 136vw;
    left: calc(50% - 63.36vw);
  }
}
@media only screen and (max-width: 768px) {
  #poem .photo.photo5 {
    width: 43.59375vw;
    top: 170vw;
    left: -13.28125vw;
  }
}
#poem .photo.photo6 {
  width: 775px;
  top: 1940px;
  left: calc(50% - 1000px);
}
@media only screen and (max-width: 2000px) {
  #poem .photo.photo6 {
    width: 38.75vw;
    top: 97vw;
    left: calc(50% - 50vw);
  }
}
@media only screen and (max-width: 1250px) {
  #poem .photo.photo6 {
    width: 62vw;
    top: 155.2vw;
    left: calc(50% - 80vw);
  }
}
@media only screen and (max-width: 768px) {
  #poem .photo.photo6 {
    width: 62.03125vw;
    top: 188.28125vw;
    left: -30vw;
  }
}
#poem .photo.photo7 {
  width: 925px;
  top: 1525px;
  right: calc(50% - 595px);
}
@media only screen and (max-width: 2000px) {
  #poem .photo.photo7 {
    width: 46.25vw;
    top: 76.25vw;
    right: calc(50% - 29.75vw);
  }
}
@media only screen and (max-width: 1250px) {
  #poem .photo.photo7 {
    width: 74vw;
    top: 122vw;
    right: calc(50% - 47.6vw);
  }
}
@media only screen and (max-width: 768px) {
  #poem .photo.photo7 {
    width: 74.0625vw;
    top: 157.8125vw;
    right: 2.34375vw;
  }
}
#poem .photo.photo8 {
  width: 635px;
  top: 1255px;
  right: calc(50% - 812px);
}
@media only screen and (max-width: 2000px) {
  #poem .photo.photo8 {
    width: 31.75vw;
    top: 62.75vw;
    right: calc(50% - 40.6vw);
  }
}
@media only screen and (max-width: 1250px) {
  #poem .photo.photo8 {
    width: 50.8vw;
    top: 100.4vw;
    right: calc(50% - 64.96vw);
  }
}
@media only screen and (max-width: 768px) {
  #poem .photo.photo8 {
    width: 50.78125vw;
  }
}
#poem .photo.photo9 {
  width: 1039px;
  top: 1948px;
  right: calc(50% - 925px);
}
@media only screen and (max-width: 2000px) {
  #poem .photo.photo9 {
    width: 51.95vw;
    top: 97.4vw;
    right: calc(50% - 46.25vw);
  }
}
@media only screen and (max-width: 1250px) {
  #poem .photo.photo9 {
    width: 83.12vw;
    top: 155.84vw;
    right: calc(50% - 74vw);
  }
}
@media only screen and (max-width: 768px) {
  #poem .photo.photo9 {
    width: 83.125vw;
    top: 188.28125vw;
    right: -24.0625vw;
  }
}
#poem .flare {
  position: absolute;
  top: 150px;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../img/poem/flare.webp") no-repeat top center;
  background-size: contain;
}
@media only screen and (max-width: 2000px) {
  #poem .flare {
    top: 7.5vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .flare {
    top: 12vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .flare {
    width: 156.25vw;
    top: 54.6875vw;
    left: -27.8125vw;
  }
}
#poem .text {
  position: relative;
  text-align: center;
  margin-top: 70px;
}
@media only screen and (max-width: 2000px) {
  #poem .text {
    margin-bottom: 3.5vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .text {
    margin-top: 2.4vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text {
    margin-top: 9.375vw;
  }
}
#poem .text .txt p {
  color: #fff;
  font-weight: 500;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  text-shadow: 0 0 25px #32191C, 0 0 25px #32191C, 0 0 25px #32191C, 0 0 25px #32191C;
  font-feature-settings: "palt" 1;
  letter-spacing: 0.02em;
}
@media only screen and (max-width: 768px) {
  #poem .text .txt p {
    letter-spacing: -0.1em;
  }
}
#poem .text .txt p span::before {
  line-height: 1;
  position: absolute;
  top: 0;
  left: 0;
  text-shadow: none;
}
#poem .text .txt p span.sl {
  font-size: 58px;
}
@media only screen and (max-width: 2000px) {
  #poem .text .txt p span.sl {
    font-size: 2.9vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .text .txt p span.sl {
    font-size: 4.64vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt p span.sl {
    font-size: 6.25vw;
  }
}
#poem .text .txt p span.sr {
  font-size: 46px;
}
@media only screen and (max-width: 2000px) {
  #poem .text .txt p span.sr {
    font-size: 2.3vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .text .txt p span.sr {
    font-size: 3.68vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt p span.sr {
    font-size: 4.6875vw;
  }
}
#poem .text .txt.type2 p {
  color: #32191C;
  font-weight: 700;
  text-shadow: 0 0 25px #fff, 0 0 25px #fff, 0 0 25px #fff, 0 0 25px #fff;
}
#poem .text .txt.type2 p span.sl {
  font-size: 78px;
}
@media only screen and (max-width: 2000px) {
  #poem .text .txt.type2 p span.sl {
    font-size: 3.9vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .text .txt.type2 p span.sl {
    font-size: 6.24vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt.type2 p span.sl {
    font-size: 7.8125vw;
  }
}
#poem .text .txt.type2 p span.sr {
  font-size: 64px;
}
@media only screen and (max-width: 2000px) {
  #poem .text .txt.type2 p span.sr {
    font-size: 3.2vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .text .txt.type2 p span.sr {
    font-size: 5.12vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt.type2 p span.sr {
    font-size: 6.5625vw;
  }
}
#poem .text .txt.txt1 {
  margin-bottom: 180px;
}
@media only screen and (max-width: 2000px) {
  #poem .text .txt.txt1 {
    margin-bottom: 9vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .text .txt.txt1 {
    margin-bottom: 14.4vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt.txt1 {
    margin-bottom: 17.8125vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt.txt1 p span.sl {
    font-size: 5vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt.txt1 p span.sr {
    font-size: 3.75vw;
  }
}
#poem .text .txt.txt2 {
  margin-bottom: 182px;
}
@media only screen and (max-width: 2000px) {
  #poem .text .txt.txt2 {
    margin-bottom: 9.1vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .text .txt.txt2 {
    margin-bottom: 14.56vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt.txt2 {
    margin-bottom: 17.1875vw;
  }
}
#poem .text .txt.txt3 {
  margin-bottom: 10px;
}
@media only screen and (max-width: 2000px) {
  #poem .text .txt.txt3 {
    margin-bottom: 0.5vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .text .txt.txt3 {
    margin-bottom: 0.8vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt.txt3 {
    margin-bottom: 1.25vw;
  }
}
#poem .text .txt.txt4 {
  margin-bottom: 190px;
}
@media only screen and (max-width: 2000px) {
  #poem .text .txt.txt4 {
    margin-bottom: 9.5vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .text .txt.txt4 {
    margin-bottom: 15.2vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt.txt4 {
    margin-bottom: 17.96875vw;
  }
}
#poem .text .txt.txt5 {
  margin-bottom: 17px;
}
@media only screen and (max-width: 2000px) {
  #poem .text .txt.txt5 {
    margin-bottom: 0.85vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .text .txt.txt5 {
    margin-bottom: 1.36vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt.txt5 {
    margin-bottom: 1.25vw;
  }
}
#poem .text .txt.txt6 {
  margin-bottom: 182px;
}
@media only screen and (max-width: 2000px) {
  #poem .text .txt.txt6 {
    margin-bottom: 9.1vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .text .txt.txt6 {
    margin-bottom: 14.56vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt.txt6 {
    margin-bottom: 17.8125vw;
  }
}
#poem .text .txt.txt7 {
  margin-bottom: 20px;
}
@media only screen and (max-width: 2000px) {
  #poem .text .txt.txt7 {
    margin-bottom: 1vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .text .txt.txt7 {
    margin-bottom: 1.6vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt.txt7 {
    margin-bottom: 1.5625vw;
  }
}
#poem .text .txt.txt8 {
  margin-bottom: 762px;
}
@media only screen and (max-width: 2000px) {
  #poem .text .txt.txt8 {
    margin-bottom: 38.1vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .text .txt.txt8 {
    margin-bottom: 12.4vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt.txt8 {
    margin-bottom: 76.25vw;
  }
}
#poem .text .txt.txt9 p span:nth-child(4) {
  position: relative;
  color: transparent;
}
#poem .text .txt.txt9 p span:nth-child(4)::before {
  content: "L";
  top: 28px;
  background-image: linear-gradient(0deg, #32191c, #ff1a2b);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media only screen and (max-width: 2000px) {
  #poem .text .txt.txt9 p span:nth-child(4)::before {
    top: 1.4vw;
  }
}
@media only screen and (max-width: 1250px) {
  #poem .text .txt.txt9 p span:nth-child(4)::before {
    top: 2.24vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt.txt9 p span:nth-child(4)::before {
    top: 3.125vw;
  }
}
@media only screen and (max-width: 768px) {
  #poem .text .txt.txt10 {
    margin-bottom: -0.9375vw;
  }
}
#poem .text .txt p span {
  display: inline-block;
  transform: scale(1.5);
  opacity: 0;
  transform-origin: center;
  transition: all 1.5s ease;
}
#poem .text .txt.txt1 p span:nth-child(1), #poem .text .txt.txt1 p span:nth-child(19) {
  transition-delay: 0.1s;
}
#poem .text .txt.txt1 p span:nth-child(2), #poem .text .txt.txt1 p span:nth-child(18) {
  transition-delay: 0.2s;
}
#poem .text .txt.txt1 p span:nth-child(3), #poem .text .txt.txt1 p span:nth-child(17) {
  transition-delay: 0.3s;
}
#poem .text .txt.txt1 p span:nth-child(4), #poem .text .txt.txt1 p span:nth-child(16) {
  transition-delay: 0.4s;
}
#poem .text .txt.txt1 p span:nth-child(5), #poem .text .txt.txt1 p span:nth-child(15) {
  transition-delay: 0.5s;
}
#poem .text .txt.txt1 p span:nth-child(6), #poem .text .txt.txt1 p span:nth-child(14) {
  transition-delay: 0.6s;
}
#poem .text .txt.txt1 p span:nth-child(7), #poem .text .txt.txt1 p span:nth-child(13) {
  transition-delay: 0.7s;
}
#poem .text .txt.txt1 p span:nth-child(8), #poem .text .txt.txt1 p span:nth-child(12) {
  transition-delay: 0.8s;
}
#poem .text .txt.txt1 p span:nth-child(9), #poem .text .txt.txt1 p span:nth-child(11) {
  transition-delay: 0.9s;
}
#poem .text .txt.txt1 p span:nth-child(10) {
  transition-delay: 1s;
}
#poem .text .txt.txt2 p span:nth-child(1), #poem .text .txt.txt2 p span:nth-child(12) {
  transition-delay: 0.1s;
}
#poem .text .txt.txt2 p span:nth-child(2), #poem .text .txt.txt2 p span:nth-child(11) {
  transition-delay: 0.2s;
}
#poem .text .txt.txt2 p span:nth-child(3), #poem .text .txt.txt2 p span:nth-child(10) {
  transition-delay: 0.3s;
}
#poem .text .txt.txt2 p span:nth-child(4), #poem .text .txt.txt2 p span:nth-child(9) {
  transition-delay: 0.4s;
}
#poem .text .txt.txt2 p span:nth-child(5), #poem .text .txt.txt2 p span:nth-child(8) {
  transition-delay: 0.5s;
}
#poem .text .txt.txt2 p span:nth-child(6), #poem .text .txt.txt2 p span:nth-child(7) {
  transition-delay: 0.6s;
}
#poem .text .txt.txt3 p span:nth-child(1), #poem .text .txt.txt3 p span:nth-child(13) {
  transition-delay: 0.1s;
}
#poem .text .txt.txt3 p span:nth-child(2), #poem .text .txt.txt3 p span:nth-child(12) {
  transition-delay: 0.2s;
}
#poem .text .txt.txt3 p span:nth-child(3), #poem .text .txt.txt3 p span:nth-child(11) {
  transition-delay: 0.3s;
}
#poem .text .txt.txt3 p span:nth-child(4), #poem .text .txt.txt3 p span:nth-child(10) {
  transition-delay: 0.4s;
}
#poem .text .txt.txt3 p span:nth-child(5), #poem .text .txt.txt3 p span:nth-child(9) {
  transition-delay: 0.5s;
}
#poem .text .txt.txt3 p span:nth-child(6), #poem .text .txt.txt3 p span:nth-child(8) {
  transition-delay: 0.6s;
}
#poem .text .txt.txt3 p span:nth-child(7) {
  transition-delay: 0.7s;
}
#poem .text .txt.txt4 p span:nth-child(1), #poem .text .txt.txt4 p span:nth-child(16) {
  transition-delay: 0.1s;
}
#poem .text .txt.txt4 p span:nth-child(2), #poem .text .txt.txt4 p span:nth-child(15) {
  transition-delay: 0.2s;
}
#poem .text .txt.txt4 p span:nth-child(3), #poem .text .txt.txt4 p span:nth-child(14) {
  transition-delay: 0.3s;
}
#poem .text .txt.txt4 p span:nth-child(4), #poem .text .txt.txt4 p span:nth-child(13) {
  transition-delay: 0.4s;
}
#poem .text .txt.txt4 p span:nth-child(5), #poem .text .txt.txt4 p span:nth-child(12) {
  transition-delay: 0.5s;
}
#poem .text .txt.txt4 p span:nth-child(6), #poem .text .txt.txt4 p span:nth-child(11) {
  transition-delay: 0.6s;
}
#poem .text .txt.txt4 p span:nth-child(7), #poem .text .txt.txt4 p span:nth-child(10) {
  transition-delay: 0.7s;
}
#poem .text .txt.txt4 p span:nth-child(8), #poem .text .txt.txt4 p span:nth-child(9) {
  transition-delay: 0.8s;
}
#poem .text .txt.txt5 p span:nth-child(1), #poem .text .txt.txt5 p span:nth-child(9) {
  transition-delay: 0.1s;
}
#poem .text .txt.txt5 p span:nth-child(2), #poem .text .txt.txt5 p span:nth-child(8) {
  transition-delay: 0.2s;
}
#poem .text .txt.txt5 p span:nth-child(3), #poem .text .txt.txt5 p span:nth-child(7) {
  transition-delay: 0.3s;
}
#poem .text .txt.txt5 p span:nth-child(4), #poem .text .txt.txt5 p span:nth-child(6) {
  transition-delay: 0.4s;
}
#poem .text .txt.txt5 p span:nth-child(5) {
  transition-delay: 0.5s;
}
#poem .text .txt.txt6 p span:nth-child(1), #poem .text .txt.txt6 p span:nth-child(14) {
  transition-delay: 0.1s;
}
#poem .text .txt.txt6 p span:nth-child(2), #poem .text .txt.txt6 p span:nth-child(13) {
  transition-delay: 0.2s;
}
#poem .text .txt.txt6 p span:nth-child(3), #poem .text .txt.txt6 p span:nth-child(12) {
  transition-delay: 0.3s;
}
#poem .text .txt.txt6 p span:nth-child(4), #poem .text .txt.txt6 p span:nth-child(11) {
  transition-delay: 0.4s;
}
#poem .text .txt.txt6 p span:nth-child(5), #poem .text .txt.txt6 p span:nth-child(10) {
  transition-delay: 0.5s;
}
#poem .text .txt.txt6 p span:nth-child(6), #poem .text .txt.txt6 p span:nth-child(9) {
  transition-delay: 0.6s;
}
#poem .text .txt.txt6 p span:nth-child(7), #poem .text .txt.txt6 p span:nth-child(8) {
  transition-delay: 0.7s;
}
#poem .text .txt.txt7 p span:nth-child(1), #poem .text .txt.txt7 p span:nth-child(12) {
  transition-delay: 0.1s;
}
#poem .text .txt.txt7 p span:nth-child(2), #poem .text .txt.txt7 p span:nth-child(11) {
  transition-delay: 0.2s;
}
#poem .text .txt.txt7 p span:nth-child(3), #poem .text .txt.txt7 p span:nth-child(10) {
  transition-delay: 0.3s;
}
#poem .text .txt.txt7 p span:nth-child(4), #poem .text .txt.txt7 p span:nth-child(9) {
  transition-delay: 0.4s;
}
#poem .text .txt.txt7 p span:nth-child(5), #poem .text .txt.txt7 p span:nth-child(8) {
  transition-delay: 0.5s;
}
#poem .text .txt.txt7 p span:nth-child(6), #poem .text .txt.txt7 p span:nth-child(7) {
  transition-delay: 0.6s;
}
#poem .text .txt.txt8 p span:nth-child(1), #poem .text .txt.txt8 p span:nth-child(9) {
  transition-delay: 0.1s;
}
#poem .text .txt.txt8 p span:nth-child(2), #poem .text .txt.txt8 p span:nth-child(8) {
  transition-delay: 0.2s;
}
#poem .text .txt.txt8 p span:nth-child(3), #poem .text .txt.txt8 p span:nth-child(7) {
  transition-delay: 0.3s;
}
#poem .text .txt.txt8 p span:nth-child(4), #poem .text .txt.txt8 p span:nth-child(6) {
  transition-delay: 0.4s;
}
#poem .text .txt.txt8 p span:nth-child(5) {
  transition-delay: 0.5s;
}
#poem .text .txt.txt9 p span:nth-child(1), #poem .text .txt.txt9 p span:nth-child(8) {
  transition-delay: 0.1s;
}
#poem .text .txt.txt9 p span:nth-child(2), #poem .text .txt.txt9 p span:nth-child(7) {
  transition-delay: 0.2s;
}
#poem .text .txt.txt9 p span:nth-child(3), #poem .text .txt.txt9 p span:nth-child(6) {
  transition-delay: 0.3s;
}
#poem .text .txt.txt9 p span:nth-child(4), #poem .text .txt.txt9 p span:nth-child(5) {
  transition-delay: 0.4s;
}
#poem .text .txt.txt10 p span:nth-child(1), #poem .text .txt.txt10 p span:nth-child(5) {
  transition-delay: 0.1s;
}
#poem .text .txt.txt10 p span:nth-child(2), #poem .text .txt.txt10 p span:nth-child(4) {
  transition-delay: 0.2s;
}
#poem .text .txt.txt10 p span:nth-child(3) {
  transition-delay: 0.3s;
}
#poem .text .txt.txt11 p span:nth-child(1), #poem .text .txt.txt11 p span:nth-child(10) {
  transition-delay: 0.1s;
}
#poem .text .txt.txt11 p span:nth-child(2), #poem .text .txt.txt11 p span:nth-child(9) {
  transition-delay: 0.2s;
}
#poem .text .txt.txt11 p span:nth-child(3), #poem .text .txt.txt11 p span:nth-child(8) {
  transition-delay: 0.3s;
}
#poem .text .txt.txt11 p span:nth-child(4), #poem .text .txt.txt11 p span:nth-child(7) {
  transition-delay: 0.4s;
}
#poem .text .txt.txt11 p span:nth-child(5), #poem .text .txt.txt11 p span:nth-child(6) {
  transition-delay: 0.5s;
}
#poem .text .txt.move-on p span {
  opacity: 1;
  transform: scale(1);
}

#modal-block .member-modal {
  width: 100vw;
  min-height: 100vh;
  background-color: #eee;
  margin: 0 auto;
  padding: 0;
}
#modal-block .member-modal .wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 100vh;
  overflow: hidden;
}
#modal-block .member-modal .triangle {
  position: absolute;
  top: 50%;
  right: -50px;
  width: 1440px;
  height: 1660px;
  transform: translateY(-50%);
  transform-origin: 0 0;
  -webkit-clip-path: polygon(100% 0, 0 50%, 100% 100%);
          clip-path: polygon(100% 0, 0 50%, 100% 100%);
  background-image: linear-gradient(90deg, #e4faf4, #dddddd);
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .triangle {
    right: -4vw;
    width: 115.2vw;
    height: 132.8vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .triangle {
    width: 100vw;
    height: 115.3125vw;
    top: 25vw;
    left: 0;
    transform: unset;
  }
}
#modal-block .member-modal .inner {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 567px;
  align-items: center;
  justify-content: right;
  width: 1140px;
  margin: 0 auto;
  padding: 100px 0;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .inner {
    width: 91.2vw;
    padding: 8vw 0;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .inner {
    display: block;
    width: 100%;
    padding: 12.5vw 0 18.75vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .illust {
    position: relative;
  }
}
#modal-block .member-modal .detail {
  margin-right: 120px;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .detail {
    margin-right: 9.6vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .detail {
    width: 87.5vw;
    margin: 0 auto;
  }
}
#modal-block .member-modal .detail .name {
  display: flex;
  flex-direction: column;
  align-items: end;
  padding-bottom: 28px;
  margin-bottom: 24px;
  background-image: repeating-linear-gradient(to right, black, black 1px, transparent 1px, transparent 6px);
  background-size: 6px 1px;
  background-repeat: repeat-x;
  background-position: bottom;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .detail .name {
    padding-bottom: 2.24vw;
    margin-bottom: 1.92vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .detail .name {
    align-items: baseline;
    padding-bottom: 4.375vw;
    margin-bottom: 4.375vw;
    background-image: repeating-linear-gradient(to right, black, black 0.3125vw, transparent 0.3125vw, transparent 0.9375vw);
    background-size: 0.9375vw 0.3125vw;
  }
}
#modal-block .member-modal .detail .name .jp {
  display: inline-block;
  color: #fff;
  font-size: 20px;
  padding: 0.3em 0.5em;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  background-color: #32191C;
  margin-bottom: 28px;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .detail .name .jp {
    font-size: 1.6vw;
    margin-bottom: 2.24vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .detail .name .jp {
    font-size: 3.75vw;
    margin-bottom: 4.375vw;
    padding: 0.05em 0.6em;
  }
}
#modal-block .member-modal .detail .name .eng svg {
  width: 100%;
  height: auto;
}
#modal-block .member-modal .detail .link {
  display: flex;
  justify-content: right;
  gap: 0 30px;
  margin-bottom: 35px;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .detail .link {
    gap: 0 2.4vw;
    margin-bottom: 2.8vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .detail .link {
    justify-content: left;
    gap: 0 6.25vw;
    margin-bottom: 6.25vw;
  }
}
#modal-block .member-modal .detail .link li {
  position: relative;
  width: 143px;
  border: 1.5px solid #32191C;
  border-radius: 50px;
  overflow: hidden;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .detail .link li {
    width: 11.44vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .detail .link li {
    width: 25vw;
  }
}
#modal-block .member-modal .detail .link li::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-color: #32191C;
  width: 0;
  transform: skewX(-10deg);
  transition: all 0.3s ease;
}
#modal-block .member-modal .detail .link li a {
  position: relative;
  display: block;
  font-size: 20px;
  color: #32191C;
  line-height: 48px;
  text-align: center;
  text-decoration: none;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .detail .link li a {
    font-size: 1.6vw;
    line-height: 3.84vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .detail .link li a {
    font-size: 3.75vw;
    line-height: 7.5vw;
  }
}
#modal-block .member-modal .detail .link li:hover::before {
  width: 100%;
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .detail .link li:hover::before {
    width: 0;
  }
}
#modal-block .member-modal .detail .link li:hover a {
  color: #fff;
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .detail .link li:hover a {
    color: #32191C;
  }
}
#modal-block .member-modal .detail .catch {
  font-size: 24px;
  margin-bottom: 30px;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .detail .catch {
    font-size: 1.92vw;
    margin-bottom: 2.4vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .detail .catch {
    font-size: 4.375vw;
    margin-bottom: 3.125vw;
  }
}
#modal-block .member-modal .detail .txt {
  font-size: 16px;
  line-height: 1.8;
  margin-bottom: 35px;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .detail .txt {
    font-size: 1.28vw;
    margin-bottom: 2.8vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .detail .txt {
    font-size: 3.125vw;
    margin-bottom: 3.90625vw;
  }
}
#modal-block .member-modal .detail dl {
  display: grid;
  grid-template-columns: 172px 1fr;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .detail dl {
    grid-template-columns: 13.76vw 1fr;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .detail dl {
    grid-template-columns: 27.1875vw 1fr;
  }
}
#modal-block .member-modal .detail dl dt, #modal-block .member-modal .detail dl dd {
  display: flex;
  align-items: center;
  height: 48px;
  line-height: 2;
  border-bottom: 1.5px solid #32191C;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .detail dl dt, #modal-block .member-modal .detail dl dd {
    height: 3.84vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .detail dl dt, #modal-block .member-modal .detail dl dd {
    height: 7.8125vw;
  }
}
#modal-block .member-modal .detail dl dt {
  font-size: 16px;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .detail dl dt {
    font-size: 1.28vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .detail dl dt {
    font-size: 3.125vw;
  }
}
#modal-block .member-modal .detail dl dd {
  font-size: 20px;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .detail dl dd {
    font-size: 1.6vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .detail dl dd {
    font-size: 3.75vw;
  }
}
#modal-block .member-modal .btns .prev {
  position: absolute;
  top: 50%;
  left: 0;
  width: 66px;
  transform: rotate(-180deg);
  transform-origin: center right;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .btns .prev {
    width: 5.28vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .btns .prev {
    top: 79.375vw;
    left: 0;
    width: 5.625vw;
    transform-origin: center;
  }
}
#modal-block .member-modal .btns .prev:hover {
  transform: rotate(-180deg) translateX(20px);
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .btns .prev:hover {
    transform: rotate(-180deg) translateX(0);
  }
}
#modal-block .member-modal .btns .next {
  position: absolute;
  top: 50%;
  right: 0;
  width: 66px;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 1250px) {
  #modal-block .member-modal .btns .next {
    width: 5.28vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .btns .next {
    top: 79.375vw;
    right: 0;
    width: 5.625vw;
  }
}
#modal-block .member-modal .btns .next:hover {
  transform: translateX(20px);
}
@media only screen and (max-width: 768px) {
  #modal-block .member-modal .btns .next:hover {
    transform: translateX(0);
  }
}
#modal-block #raden {
  background-color: #27C487;
}
#modal-block #raden .triangle {
  background-image: linear-gradient(90deg, #e4faf4, #27c487);
}
#modal-block #raden .illust {
  width: 573px;
  margin-left: -20px;
}
@media only screen and (max-width: 1250px) {
  #modal-block #raden .illust {
    width: 45.84vw;
    margin-left: -1.6vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block #raden .illust {
    width: 89.53125vw;
    left: 5.3125vw;
  }
}
#modal-block #raden .detail .name .eng {
  width: 443px;
}
@media only screen and (max-width: 1250px) {
  #modal-block #raden .detail .name .eng {
    width: 35.44vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block #raden .detail .name .eng {
    width: 69.0625vw;
  }
}
#modal-block #hajime {
  background-color: #BABEF4;
}
#modal-block #hajime .triangle {
  background-image: linear-gradient(90deg, #f8f9fd, #9ea4eb);
}
#modal-block #hajime .illust {
  width: 711px;
  margin-left: -170px;
}
@media only screen and (max-width: 1250px) {
  #modal-block #hajime .illust {
    width: 56.88vw;
    margin-left: -13.6vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block #hajime .illust {
    width: 111.09375vw;
    left: -5.3125vw;
    margin-bottom: 5.46875vw;
  }
}
#modal-block #hajime .detail .name .eng {
  width: 404px;
}
@media only screen and (max-width: 1250px) {
  #modal-block #hajime .detail .name .eng {
    width: 32.32vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block #hajime .detail .name .eng {
    width: 62.34375vw;
  }
}
#modal-block #kanade {
  background-color: #FFE267;
}
#modal-block #kanade .triangle {
  background-image: linear-gradient(90deg, #fffefa, #ffd72f);
}
#modal-block #kanade .illust {
  width: 561px;
  margin-left: -14px;
}
@media only screen and (max-width: 1250px) {
  #modal-block #kanade .illust {
    width: 44.88vw;
    margin-left: -1.12vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block #kanade .illust {
    width: 87.65625vw;
    left: 6.25vw;
    margin-bottom: -1.09375vw;
  }
}
#modal-block #kanade .detail .name .eng {
  width: 360px;
}
@media only screen and (max-width: 1250px) {
  #modal-block #kanade .detail .name .eng {
    width: 28.8vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block #kanade .detail .name .eng {
    width: 56.25vw;
  }
}
#modal-block #ririka {
  background-color: #FFA5C1;
}
#modal-block #ririka .triangle {
  background-image: linear-gradient(90deg, #fae4e9, #fc6492);
}
#modal-block #ririka .illust {
  width: 582px;
}
@media only screen and (max-width: 1250px) {
  #modal-block #ririka .illust {
    width: 46.56vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block #ririka .illust {
    width: 90.9375vw;
    left: 4.6875vw;
    margin-bottom: -20.3125vw;
  }
}
#modal-block #ririka .detail .name .eng {
  width: 318px;
}
@media only screen and (max-width: 1250px) {
  #modal-block #ririka .detail .name .eng {
    width: 25.44vw;
  }
}
@media only screen and (max-width: 768px) {
  #modal-block #ririka .detail .name .eng {
    width: 48.75vw;
  }
}

#footer {
  background: url("../img/parts/bg_rp.png") repeat-y top center #32191C;
  background-size: 100% auto;
}