.SP.div {
  background-color: #000000;
  overflow: hidden;
  width: 100%;
  max-width: 100vw;
  min-height: 4545px;
  position: relative;
  margin: 0 auto;
}

.SP .mask-group {
  position: absolute;
  top: 2900px;
  left: 50%;
  transform: translateX(-50%);
  width: 375px;
  max-width: 100%;
  height: 96px;
}

.SP .image {
  position: absolute;
  top: 2750px;
  left: 50%;
  transform: translateX(-50%);
  width: 302px;
  max-width: 80%;
  height: auto;
  aspect-ratio: 1.01;
}

.SP .keyvisu-wrapper {
  top: 0;
  left: 50%;
  transform: translateX(-50%) rotate(-180.00deg);
  height: 491px;
  display: flex;
  position: absolute;
  width: 100%;
  max-width: 375px;
}

.SP .keyvisu {
  margin-top: 0;
  width: 100%;
  height: 490.66px;
  margin-left: 0;
  transform: rotate(180.00deg);
  object-fit: cover;
}

.SP .grassdsss {
  top: 453px;
  left: 50%;
  transform: translateX(-50%);
  height: 76px;
  aspect-ratio: 4.93;
  position: absolute;
  width: 100%;
  max-width: 375px;
}

.SP .text-wrapper {
  position: absolute;
  top: 628px;
  left: 0;
  right: 0;
  width: 100%;
  font-family: "Labrada", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 24px;
  text-align: center;
  letter-spacing: 4.80px;
  line-height: 11.2px;
  white-space: nowrap;
}

.SP .moss-palace-parade {
  position: absolute;
  top: 677px;
  left: 50%;
  transform: translateX(-50%);
  width: 305px;
  max-width: calc(100% - 64px);
  font-size: 16px;
  text-align: center;
  letter-spacing: 0.64px;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #ffffff;
  line-height: normal;
}

.SP .youtube-embed {
  position: absolute;
  top: 750px;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 375px;
  aspect-ratio: 16/9;
}

.SP .youtube-embed iframe {
  width: 100%;
  height: 100%;
  border: none;
}

.SP .vector {
  position: absolute;
  top: 653px;
  left: 50%;
  transform: translateX(-50%);
  width: 275px;
  max-width: calc(100% - 100px);
  height: 1px;
}

.SP .element {
  position: absolute;
  top: 730px;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 375px;
  height: auto;
  aspect-ratio: 1.78;
  object-fit: cover;
}

.SP .logos-youtube-icon {
  position: absolute;
  top: 830px;
  left: 50%;
  transform: translateX(-50%);
  width: 45px;
  height: 31px;
  aspect-ratio: 1.42;
  background-image: url(./img/vector-1.svg);
  background-size: 100% 100%;
}

.SP .img {
  position: absolute;
  width: 25.91%;
  height: 42.69%;
  top: 28.46%;
  left: 40.01%;
}

.SP .group {
  position: absolute;
  top: 960px;
  left: 50%;
  transform: translateX(-50%);
  width: 305px;
  max-width: calc(100% - 64px);
  height: 62px;
  background-color: #ffffff;
  border-radius: 47.25px;
}

.SP .frame {
  display: flex;
  width: 70.61%;
  height: 30.70%;
  align-items: center;
  gap: 29.44px;
  position: relative;
  top: 33.85%;
  left: 15.47%;
}

.SP .text-wrapper-2 {
  line-height: 15.1px;
  position: relative;
  width: fit-content;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #000000;
  font-size: 24px;
  text-align: center;
  letter-spacing: 1.20px;
  white-space: nowrap;
}

.SP .ooui-new-window-ltr {
  position: relative;
  width: 19.86px;
  height: 19.86px;
  margin-top: -0.43px;
  margin-bottom: -0.43px;
  margin-right: -5.69px;
  overflow: hidden;
  aspect-ratio: 1;
}

.SP .vector-2 {
  position: absolute;
  width: 90.00%;
  height: 90.00%;
  top: -82559.65%;
  left: 44157.49%;
}

.SP .vector-3 {
  position: absolute;
  width: 52.00%;
  height: 52.00%;
  top: -82559.65%;
  left: 44195.49%;
}

.SP .image-2 {
  position: absolute;
  top: 1590px;
  left: 50%;
  transform: translateX(-50%);
  width: 375px;
  max-width: 100%;
  height: 207px;
  aspect-ratio: 1.81;
}

.SP .text-wrapper-3 {
  position: absolute;
  top: 1200px;
  left: 50%;
  transform: translateX(-50%);
  width: 311px;
  max-width: calc(100% - 64px);
  font-family: "Labrada", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 24px;
  text-align: left;
  letter-spacing: 4.80px;
  line-height: 11.3px;
  white-space: nowrap;
}

.SP .text-wrapper-4 {
  position: absolute;
  top: 3094px;
  left: 50%;
  transform: translateX(-50%);
  width: 311px;
  max-width: calc(100% - 64px);
  font-family: "Labrada", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 24px;
  text-align: left;
  letter-spacing: 4.80px;
  line-height: 11.3px;
  white-space: nowrap;
}

.SP .text-wrapper-5 {
  position: absolute;
  top: 1903px;
  left: 50%;
  transform: translateX(-50%);
  width: 311px;
  max-width: calc(100% - 64px);
  font-family: "Labrada", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 24px;
  text-align: left;
  letter-spacing: 4.80px;
  line-height: 11.3px;
  white-space: nowrap;
}

.SP .text-wrapper-6 {
  position: absolute;
  top: 2305px;
  left: 50%;
  transform: translateX(-50%);
  width: 311px;
  max-width: calc(100% - 64px);
  font-family: "Labrada", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 24px;
  text-align: left;
  letter-spacing: 4.80px;
  line-height: 11.3px;
  white-space: nowrap;
}

.SP .vector-4 {
  position: absolute;
  top: 1226px;
  left: 50%;
  transform: translateX(-50%);
  width: 311px;
  max-width: calc(100% - 64px);
  height: 1px;
}

.SP .vector-5 {
  position: absolute;
  top: 3120px;
  left: 50%;
  transform: translateX(-50%);
  width: 311px;
  max-width: calc(100% - 64px);
  height: 1px;
}

.SP .vector-6 {
  position: absolute;
  top: 1929px;
  left: 50%;
  transform: translateX(-50%);
  width: 311px;
  max-width: calc(100% - 64px);
  height: 1px;
}

.SP .vector-7 {
  position: absolute;
  top: 2331px;
  left: 50%;
  transform: translateX(-50%);
  width: 311px;
  max-width: calc(100% - 64px);
  height: 1px;
}

.SP .frame-2 {
  display: flex;
  flex-direction: column;
  width: 311px;
  max-width: calc(100% - 64px);
  align-items: flex-start;
  gap: 25.6px;
  position: absolute;
  top: 1250px;
  left: 50%;
  transform: translateX(-50%);
}

.SP .frame-3 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 15px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.SP .group-2 {
  position: relative;
  width: 89.79px;
  height: 12.5px;
}

.SP .text-wrapper-7 {
  position: absolute;
  top: 1px;
  left: 24px;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  color: #ffffff;
  font-size: 16px;
  line-height: 10.2px;
  white-space: nowrap;
  font-weight: 400;
  letter-spacing: 0;
}

.SP .vector-wrapper {
  position: absolute;
  width: 21.80%;
  height: 97.48%;
  top: 0;
  left: 0;
  transform: rotate(180deg);
}

.SP .vector-8 {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  transform: rotate(-180deg);
}

.SP .text-wrapper-8 {
  position: relative;
  align-self: stretch;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  color: #ffffff;
  font-size: 13px;
  line-height: normal;
  font-weight: 400;
  letter-spacing: 0;
  list-style: circle;
  padding-left: 0;
}

.SP .group-3 {
  position: relative;
  width: 141.79px;
  height: 12.5px;
}

.SP .img-wrapper {
  width: 13.81%;
  height: 97.48%;
  position: absolute;
  top: 0;
  left: 0;
  transform: rotate(180deg);
}

.SP .group-4 {
  position: relative;
  width: 89.79px;
  height: 12.49px;
}

.SP .group-5 {
  width: 21.80%;
  height: 97.50%;
  position: absolute;
  top: 0;
  left: 0;
  transform: rotate(180deg);
}

.SP .frame-4 {
  display: flex;
  flex-direction: column;
  width: 311px;
  max-width: calc(100% - 64px);
  align-items: flex-start;
  gap: 25.6px;
  position: absolute;
  top: 3144px;
  left: 50%;
  transform: translateX(-50%);
}

.SP .group-6 {
  position: relative;
  width: 77.79px;
  height: 12.5px;
}

.SP .group-7 {
  width: 25.17%;
  height: 97.48%;
  position: absolute;
  top: 0;
  left: 0;
  transform: rotate(180deg);
}

.SP .group-8 {
  position: relative;
  width: 192.79px;
  height: 12.5px;
}

.SP .group-9 {
  width: 10.15%;
  height: 97.48%;
  position: absolute;
  top: 0;
  left: 0;
  transform: rotate(180deg);
}

.SP .text-wrapper-9 {
  position: absolute;
  top: 1952px;
  left: 50%;
  transform: translateX(-50%);
  width: 307px;
  max-width: calc(100% - 64px);
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #ffffff;
  font-size: 13px;
  letter-spacing: 0;
  line-height: normal;
}

.SP .text-wrapper-10 {
  position: absolute;
  top: 2355px;
  left: 50%;
  transform: translateX(-50%);
  width: 307px;
  max-width: calc(100% - 64px);
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  color: #ffffff;
  font-size: 13px;
  line-height: normal;
  font-weight: 400;
  letter-spacing: 0;
}

.SP .group-10 {
  position: absolute;
  width: 375px;
  max-width: 100%;
  height: 194px;
  top: 2006px;
  left: 50%;
  transform: translateX(-50%);
}

.SP .mask-group-2 {
  top: 2523px;
  left: 50%;
  transform: translateX(-50%);
  height: 96px;
  position: absolute;
  width: 375px;
  max-width: 100%;
}

.SP .image-3 {
  position: absolute;
  top: 2390px;
  left: calc(50% - 107px);
  width: 105px;
  height: 289px;
  aspect-ratio: 0.27;
}

.SP .image-4 {
  position: absolute;
  top: 2395px;
  left: calc(50% - 177px);
  width: 112px;
  height: 284px;
  aspect-ratio: 0.3;
}

.SP .text-wrapper-11 {
  position: absolute;
  top: 2710px;
  left: calc(50% - 145px);
  width: 80px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  color: #ffffff;
  font-size: 13px;
  text-align: center;
  line-height: 27.9px;
  white-space: nowrap;
  font-weight: 400;
  letter-spacing: 0;
}

.SP .text-wrapper-12 {
  position: absolute;
  top: 2710px;
  left: calc(50% + 50px);
  width: 100px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  color: #ffffff;
  font-size: 13px;
  text-align: center;
  line-height: 27.9px;
  white-space: nowrap;
  font-weight: 400;
  letter-spacing: 0;
}

.SP .text-wrapper-13 {
  position: absolute;
  top: 2870px;
  left: calc(50% + 120px);
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  color: #ffffff;
  font-size: 13px;
  text-align: center;
  line-height: 27.9px;
  white-space: nowrap;
  font-weight: 400;
  letter-spacing: 0;
}

.SP .image-5 {
  position: absolute;
  top: 2477px;
  left: calc(50% + 56px);
  width: 129px;
  height: 196px;
  aspect-ratio: 0.58;
}

.SP .image-6 {
  position: absolute;
  top: 2457px;
  left: calc(50% - 12px);
  width: 114px;
  height: 216px;
  aspect-ratio: 0.43;
}

.SP .group-11 {
  position: absolute;
  top: 4130px;
  left: 0;
  width: 100%;
  height: 415px;
}

.SP .grassdsss-2 {
  top: 0;
  left: 0;
  height: 48px;
  position: absolute;
  width: 100%;
  object-fit: cover;
}

.SP .grassdsss-3 {
  bottom: 366px;
  left: 0;
  height: 50px;
  mix-blend-mode: color-dodge;
  position: absolute;
  width: 100%;
  object-fit: cover;
}

.SP .rectangle {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 369px;
  background-color: #ffffff;
}

.SP .group-12 {
  position: absolute;
  top: 4220px;
  left: 50%;
  transform: translateX(-50%);
  width: 311px;
  max-width: calc(100% - 64px);
  height: 32px;
}

.SP .vector-9 {
  position: absolute;
  top: 4191px;
  left: 50%;
  transform: translateX(-50%);
  width: 91px;
  height: 91px;
}

.SP .frame-5 {
  display: flex;
  flex-direction: column;
  width: 311px;
  max-width: calc(100% - 64px);
  align-items: flex-start;
  gap: 15px;
  position: absolute;
  top: 4312px;
  left: 50%;
  transform: translateX(-50%);
}

.SP .div-wrapper {
  position: relative;
  width: 28px;
  height: 11px;
}

.SP .text-wrapper-14 {
  position: absolute;
  top: 0;
  left: 0;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  color: #000000;
  font-size: 16px;
  line-height: 10.2px;
  white-space: nowrap;
  font-weight: 400;
  letter-spacing: 0;
}

.SP .x-mosspa-official {
  position: relative;
  align-self: stretch;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #000000;
  font-size: 13px;
  letter-spacing: 0;
  line-height: normal;
}

.SP .span {
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #000000;
  font-size: 13px;
  letter-spacing: 0;
}

.SP .text-wrapper-15 {
  text-decoration: underline;
}

.SP .frame-6 {
  display: flex;
  flex-direction: column;
  width: 311px;
  max-width: calc(100% - 64px);
  align-items: flex-start;
  gap: 15px;
  position: absolute;
  top: 4412px;
  left: 50%;
  transform: translateX(-50%);
}

.SP .group-13 {
  position: relative;
  width: 54px;
  height: 11px;
}

.SP .text-wrapper-16 {
  position: relative;
  align-self: stretch;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  color: #000000;
  font-size: 13px;
  line-height: 22px;
  text-decoration: underline;
  font-weight: 400;
  letter-spacing: 0;
}

.SP .ooui-new-window-ltr-2 {
  display: none;
}

.SP .vector-10 {
  position: absolute;
  width: 90.00%;
  height: 90.00%;
  top: 5.00%;
  left: 5.00%;
}

.SP .vector-11 {
  position: absolute;
  width: 52.00%;
  height: 52.00%;
  top: 5.00%;
  left: 43.00%;
}

.SP .ooui-new-window-ltr-3 {
  display: none;
}

.SP .ooui-new-window-ltr-4 {
  display: none;
}

.SP .inline-icon {
  display: inline-block;
  width: 14px;
  height: 13px;
  position: relative;
  margin-left: 4px;
  vertical-align: middle;
}

.SP .inline-icon img {
  position: absolute;
  top: 0;
  left: 0;
}

.SP .inline-icon img:first-child {
  width: 90%;
  height: 90%;
  top: 5%;
  left: 5%;
}

.SP .inline-icon img:last-child {
  width: 52%;
  height: 52%;
  top: 5%;
  left: 43%;
}

.SP .text-wrapper-17 {
  position: absolute;
  top: 4523px;
  left: 0;
  right: 0;
  width: 100%;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #000000;
  font-size: 12px;
  text-align: center;
  letter-spacing: 1.80px;
  line-height: 22px;
  white-space: nowrap;
}

.SP .frame-wrapper {
  position: absolute;
  top: 1042px;
  left: 50%;
  transform: translateX(-50%);
  width: 311px;
  max-width: calc(100% - 64px);
  height: 63px;
  background-color: #ffffff;
  border-radius: 48.05px;
  text-decoration: none;
}

.SP .frame-7 {
  display: flex;
  width: 70.61%;
  height: 30.70%;
  align-items: center;
  gap: 29.95px;
  position: relative;
  top: 33.85%;
  left: 17.25%;
}

.SP .text-wrapper-18 {
  line-height: 15.3px;
  position: relative;
  width: fit-content;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #000000;
  font-size: 24px;
  text-align: center;
  letter-spacing: 1.20px;
  white-space: nowrap;
}

.SP .ooui-new-window-ltr-5 {
  position: relative;
  width: 20.2px;
  height: 20.2px;
  margin-top: -0.43px;
  margin-bottom: -0.43px;
  margin-right: -2.85px;
  aspect-ratio: 1;
}

.SP .group-14 {
  position: absolute;
  top: 530px;
  left: 50%;
  transform: translateX(-50%);
  width: 232px;
  height: 31px;
}

.SP .vector-12 {
  position: absolute;
  top: 352px;
  left: 50%;
  transform: translateX(-50%);
  width: 166px;
  height: 166px;
}

.SP .vector-13 {
  position: absolute;
  top: 25px;
  left: auto;
  width: 18px;
  height: 16px;
}

.SP .menu-toggle {
  position: fixed;
  top: 24.88px;
  left: auto;
  right: 20px;
  width: 17.545px;
  height: 15.561px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  z-index: 100;
  display: none; /* デフォルトでは非表示、メディアクエリで表示 */
}

.SP .menu-toggle img {
  width: 100%;
  height: 100%;
  display: block;
}

.SP.PC {
  background-color: #000000;
  overflow: hidden;
  width: 1920px;
  min-width: 0;
  height: 8411px;
  position: relative;
  display: none; /* デフォルトでは非表示 */
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  border: none;
}

.SP.PC .inline-icon {
  display: inline-block;
  width: 22px;
  height: 22px;
  position: relative;
  margin-left: 6px;
  vertical-align: middle;
}

.SP.PC .inline-icon img {
  position: absolute;
  top: 0;
  left: 0;
}

.SP.PC .inline-icon img:first-child {
  width: 90%;
  height: 90%;
  top: 5%;
  left: 5%;
}

.SP.PC .inline-icon img:last-child {
  width: 52%;
  height: 52%;
  top: 5%;
  left: 43%;
}

.SP .keyvisu-2 {
  position: absolute;
  top: 92px;
  left: 0;
  width: 1920px;
  height: 1080px;
  min-width: 1920px;
  min-height: 1080px;
  aspect-ratio: 1.78;
  object-fit: cover;
}

.SP .rectangle-2 {
  position: absolute;
  top: 90px;
  left: 1298px;
  width: 622px;
  height: 1082px;
  transform: rotate(-180.00deg);
  background: linear-gradient(90deg, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 0) 100%);
}

.SP .rectangle-3 {
  position: absolute;
  top: 0;
  left: 0;
  width: 1920px;
  height: 90px;
  background-color: #000000;
}

.SP .navbar {
  display: inline-flex;
  align-items: center;
  gap: 24px;
  position: fixed;
  top: 31px;
  right: 36px;
  z-index: 100;
}

.SP .text-wrapper-19 {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "Alegreya SC", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 24px;
  text-align: center;
  letter-spacing: 0.72px;
  line-height: 27.9px;
  white-space: nowrap;
}

/* PC版のナビゲーションバーのフォントサイズをスケーリング時も24pxに維持 */
@media screen and (min-width: 768px) {
  .SP.PC .text-wrapper-19 {
    font-size: 24px !important;
    line-height: 27.9px !important;
  }
  
  /* PC版のセクションにスクロールマージンを設定 */
  .SP.PC [id$="-pc"] {
    scroll-margin-top: 100px;
  }
}

.SP .group-15 {
  position: absolute;
  top: 811px;
  left: 1123px;
  width: 700px;
  height: 82px;
}

.SP .vector-14 {
  position: absolute;
  top: 264px;
  left: 1218px;
  width: 509px;
  height: 510px;
}

.SP .text-wrapper-20 {
  position: absolute;
  top: 2411px;
  left: 955px;
  font-family: "Labrada", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 48px;
  letter-spacing: 9.60px;
  line-height: 22px;
  white-space: nowrap;
}

.SP .text-wrapper-21 {
  position: absolute;
  top: 6068px;
  left: 222px;
  font-family: "Labrada", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 48px;
  letter-spacing: 9.60px;
  line-height: 22px;
  white-space: nowrap;
}

.SP .text-wrapper-22 {
  position: absolute;
  top: 3414px;
  left: 214px;
  font-family: "Labrada", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 48px;
  letter-spacing: 9.60px;
  line-height: 22px;
  white-space: nowrap;
}

.SP .text-wrapper-23 {
  position: absolute;
  top: 1308px;
  left: 877px;
  font-family: "Labrada", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 48px;
  text-align: center;
  letter-spacing: 9.60px;
  line-height: 22px;
  white-space: nowrap;
}

.SP .text-wrapper-24 {
  position: absolute;
  top: 4692px;
  left: 214px;
  font-family: "Labrada", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 48px;
  letter-spacing: 9.60px;
  line-height: 22px;
  white-space: nowrap;
}

.SP .vector-15 {
  position: absolute;
  top: 2462px;
  left: 947px;
  width: 539px;
  height: 1px;
}

.SP .vector-16 {
  position: absolute;
  top: 6118px;
  left: 214px;
  width: 539px;
  height: 1px;
}

.SP .vector-17 {
  position: absolute;
  top: 3464px;
  left: 206px;
  width: 539px;
  height: 1px;
}

.SP .vector-18 {
  position: absolute;
  top: 4743px;
  left: 206px;
  width: 539px;
  height: 1px;
}

.SP .frame-8 {
  display: flex;
  flex-direction: column;
  width: 764px;
  align-items: flex-start;
  gap: 50px;
  position: absolute;
  top: 2576px;
  left: 947px;
}

.SP .frame-9 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 31px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.SP .group-16 {
  position: relative;
  width: 192.45px;
  height: 23.79px;
}

.SP .text-wrapper-25 {
  position: absolute;
  top: 3px;
  left: 46px;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #ffffff;
  font-size: 36px;
  letter-spacing: 0;
  line-height: 20px;
  white-space: nowrap;
}

.SP .group-17 {
  width: 19.86%;
  position: absolute;
  height: 100%;
  top: 0;
  left: 0;
  transform: rotate(180deg);
}

.SP .text-wrapper-26 {
  position: relative;
  align-self: stretch;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #ffffff;
  font-size: 24px;
  letter-spacing: 0.96px;
  line-height: normal;
}

.SP .group-18 {
  position: relative;
  width: 308.45px;
  height: 23.79px;
}

.SP .group-19 {
  width: 12.39%;
  position: absolute;
  height: 100%;
  top: 0;
  left: 0;
  transform: rotate(180deg);
}

.SP .frame-10 {
  display: flex;
  flex-direction: column;
  width: 1497px;
  align-items: flex-start;
  gap: 50px;
  position: absolute;
  top: 6232px;
  left: 214px;
}

.SP .group-20 {
  position: relative;
  width: 164.45px;
  height: 23.79px;
}

.SP .group-21 {
  width: 23.25%;
  position: absolute;
  height: 100%;
  top: 0;
  left: 0;
  transform: rotate(180deg);
}

.SP .group-22 {
  position: relative;
  width: 423.45px;
  height: 23.79px;
}

.SP .group-23 {
  width: 9.03%;
  position: absolute;
  height: 100%;
  top: 0;
  left: 0;
  transform: rotate(180deg);
}

.SP .SNS {
  position: relative;
  align-self: stretch;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #ffffff;
  font-size: 24px;
  letter-spacing: 0.96px;
  line-height: normal;
}

.SP .text-wrapper-27 {
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  letter-spacing: 0.23px;
}

.SP .text-wrapper-28 {
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-size: 20px;
  letter-spacing: 0.16px;
}

.SP .image-7 {
  position: absolute;
  top: 2351px;
  left: 0;
  width: 789px;
  height: 832px;
  aspect-ratio: 0.95;
}

.SP .text-wrapper-29 {
  position: absolute;
  top: 3509px;
  left: 214px;
  width: 863px;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #ffffff;
  font-size: 32px;
  letter-spacing: 1.28px;
  line-height: 22px;
}

.SP .text-wrapper-30 {
  position: absolute;
  top: 1404px;
  left: 529px;
  width: 863px;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #ffffff;
  font-size: 32px;
  text-align: center;
  letter-spacing: 1.28px;
  line-height: 22px;
}

.SP .text-wrapper-31 {
  position: absolute;
  top: 4788px;
  left: 214px;
  width: 863px;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #ffffff;
  font-size: 32px;
  letter-spacing: 1.28px;
  line-height: 22px;
}

.SP .mask-group-3 {
  position: absolute;
  top: 5258px;
  left: 0;
  width: 1920px;
  height: 275px;
}

.SP .image-8 {
  position: absolute;
  top: 4905px;
  left: 1058px;
  width: 827px;
  height: 820px;
  aspect-ratio: 1.01;
}

.SP .image-9 {
  position: absolute;
  top: 5165px;
  left: 847px;
  width: 320px;
  height: 526px;
  aspect-ratio: 0.58;
}

.SP .image-10 {
  position: absolute;
  top: 5105px;
  left: 583px;
  width: 273px;
  height: 587px;
  aspect-ratio: 0.43;
}

.SP .image-11 {
  position: absolute;
  top: 4865px;
  left: 323px;
  width: 257px;
  height: 852px;
  aspect-ratio: 0.27;
}

.SP .image-12 {
  position: absolute;
  top: 4882px;
  left: 67px;
  width: 278px;
  height: 835px;
  aspect-ratio: 0.3;
}

.SP .text-wrapper-32 {
  position: absolute;
  top: 5780px;
  left: 278px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #ffffff;
  font-size: 32px;
  text-align: center;
  letter-spacing: 0;
  line-height: 27.9px;
  white-space: nowrap;
}

.SP .text-wrapper-33 {
  position: absolute;
  top: 5780px;
  left: 758px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #ffffff;
  font-size: 32px;
  text-align: center;
  letter-spacing: 0;
  line-height: 27.9px;
  white-space: nowrap;
}

.SP .text-wrapper-34 {
  position: absolute;
  top: 5780px;
  left: 1455px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #ffffff;
  font-size: 32px;
  text-align: center;
  letter-spacing: 0;
  line-height: 27.9px;
  white-space: nowrap;
}

.SP .grassdsss-4 {
  position: absolute;
  top: 998px;
  left: 0;
  width: 1920px;
  height: 202px;
  aspect-ratio: 9.51;
}

.SP .grassdsss-5 {
  position: absolute;
  top: 3063px;
  left: 0;
  width: 808px;
  height: 144px;
  aspect-ratio: 5.6;
}

.SP .group-24 {
  position: absolute;
  width: 1898px;
  height: 756px;
  top: 3671px;
  left: 85px;
  display: flex;
  gap: 51.9px;
}

.SP .mask-group-4 {
  margin-top: 79.1px;
  width: 338.04px;
  display: flex;
  gap: 10740.1px;
}

.SP .image-13 {
  width: 338.04px;
  height: 602.14px;
  aspect-ratio: 1.78;
  object-fit: cover;
}

.SP .rectangle-4 {
  margin-top: -18613.3px;
  width: 338.04px;
  height: 602.14px;
}

.SP .mask-group-5 {
  width: 338.04px;
  height: 602.14px;
}

.SP .mask-group-6 {
  margin-top: 153.4px;
  width: 338.04px;
  display: flex;
  gap: 10740.1px;
}

.SP .rectangle-5 {
  width: 338.04px;
  height: 602.14px;
  object-fit: cover;
}

.SP .group-25 {
  width: 340.04px;
  height: 602.14px;
  position: relative;
}

.SP .mask-group-7 {
  position: absolute;
  top: 0;
  left: 0;
  width: 338px;
  height: 602px;
  background: linear-gradient(
    180deg,
    rgba(173, 194, 150, 1) 0%,
    rgba(36, 42, 29, 1) 100%
  );
}

.SP .AND-MORE {
  position: absolute;
  top: 290px;
  left: 89px;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #000000;
  font-size: 32px;
  text-align: center;
  line-height: 22px;
  white-space: nowrap;
}

.SP .text-wrapper-35 {
  letter-spacing: 1.54px;
}

.SP .text-wrapper-36 {
  letter-spacing: 0;
}

.SP .group-26 {
  position: absolute;
  top: 7621px;
  left: 0;
  width: 1920px;
  height: 790px;
}

.SP .grassdsss-6 {
  position: absolute;
  top: 0;
  left: 0;
  width: 1920px;
  height: 144px;
  aspect-ratio: 13.31;
}

.SP .grassdsss-7 {
  position: absolute;
  top: 0;
  left: 0;
  width: 1920px;
  height: 144px;
  mix-blend-mode: color-dodge;
  aspect-ratio: 13.31;
}

.SP .rectangle-6 {
  position: absolute;
  top: 141px;
  left: 0;
  width: 1920px;
  height: 649px;
  background-color: #ffffff;
}

.SP .group-27 {
  position: absolute;
  top: 7883px;
  left: 214px;
  width: 366px;
  height: 38px;
}

.SP .vector-19 {
  position: absolute;
  top: 7848px;
  left: 340px;
  width: 107px;
  height: 107px;
}

.SP .text-wrapper-37 {
  position: absolute;
  top: 8389px;
  left: 876px;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #000000;
  font-size: 20px;
  text-align: center;
  letter-spacing: 3.00px;
  line-height: 22px;
  white-space: nowrap;
  margin: 0;
  padding: 0;
  height: 22px;
  overflow: visible;
}

.SP .frame-11 {
  display: flex;
  flex-direction: column;
  width: 563px;
  align-items: flex-start;
  gap: 31px;
  position: absolute;
  top: 8025px;
  left: 214px;
}

.SP .group-28 {
  position: relative;
  width: 60px;
  height: 20px;
}

.SP .text-wrapper-38 {
  position: absolute;
  top: 0;
  left: 0;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #000000;
  font-size: 36px;
  letter-spacing: 0;
  line-height: 20px;
  white-space: nowrap;
}

.SP .p {
  position: relative;
  align-self: stretch;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #000000;
  font-size: 24px;
  letter-spacing: 0.96px;
  line-height: normal;
}

.SP .text-wrapper-39 {
  letter-spacing: 0.23px;
  text-decoration: underline;
}

.SP .ooui-new-window-ltr-6 {
  position: absolute;
  top: 58px;
  left: 190px;
  width: 22px;
  height: 22px;
  aspect-ratio: 1;
}

.SP .frame-12 {
  display: flex;
  flex-direction: column;
  width: 563px;
  align-items: flex-start;
  gap: 31px;
  position: absolute;
  top: 8209px;
  left: 214px;
}

.SP .group-29 {
  position: relative;
  width: 118px;
  height: 20px;
}

.SP .ooui-new-window-ltr-7 {
  position: absolute;
  top: 58px;
  left: 130px;
  width: 22px;
  height: 22px;
  aspect-ratio: 1;
}

.SP .ooui-new-window-ltr-8 {
  position: absolute;
  top: 96px;
  left: 112px;
  width: 22px;
  height: 22px;
  aspect-ratio: 1;
}

.SP .text-wrapper-40 {
  position: relative;
  align-self: stretch;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #000000;
  font-size: 24px;
  letter-spacing: 0.96px;
  line-height: normal;
  text-decoration: underline;
}

.SP .vector-20 {
  position: absolute;
  top: 1359px;
  left: 691px;
  width: 539px;
  height: 1px;
}

.SP .element-2 {
  display: none;
}

.SP .logos-youtube-icon-2 {
  display: none;
}

.SP.PC .youtube-embed-pc {
  position: absolute;
  top: 1526px;
  left: 209px;
  width: 994px;
  height: 559px;
}

.SP.PC .youtube-embed-pc iframe {
  width: 100%;
  height: 100%;
  border: none;
  border-radius: 8px;
}

.SP .group-30 {
  position: absolute;
  top: calc(50.00% - 2465px);
  left: calc(50.00% + 308px);
  width: 446px;
  height: 90px;
  background-color: #ffffff;
  border-radius: 69px;
  text-decoration: none;
}

.SP .frame-13 {
  display: flex;
  width: 70.61%;
  height: 30.70%;
  align-items: center;
  gap: 43px;
  position: relative;
  top: 33.85%;
  left: 15.47%;
}

.SP .text-wrapper-41 {
  position: relative;
  width: fit-content;
  font-family: "Kaisotai-NextUP B", "Kaisotai-Regular", Helvetica, sans-serif;
  font-weight: 400;
  color: #000000;
  font-size: 36px;
  text-align: center;
  letter-spacing: 1.80px;
  line-height: 22px;
  white-space: nowrap;
}

.SP .ooui-new-window-ltr-9 {
  position: relative;
  width: 29px;
  height: 29px;
  margin-top: -0.62px;
  margin-bottom: -0.62px;
  margin-right: -14.13px;
  aspect-ratio: 1;
}

/* メディアクエリ: 768pxを境に切り替え */
@media screen and (max-width: 767px) {
  .SP.PC {
    display: none !important;
  }
  .SP.div {
    display: block;
  }
  
  /* スマホ版ではメニュートグルボタンを表示 */
  .SP .menu-toggle,
  .SP.div .menu-toggle {
    display: block !important;
    position: fixed;
    top: 24.88px;
    left: auto;
    right: 20px;
    width: 17.545px;
    height: 15.561px;
    z-index: 1000;
  }
}

@media screen and (min-width: 768px) {
  .SP.div {
    display: none !important;
  }
  .SP.PC {
    display: block;
  }
  
  /* PC版ではスマホ版メニュートグルボタンを非表示 */
  .SP .menu-toggle,
  .SP.div .menu-toggle {
    display: none !important;
  }
}

/* PC版のスケーリング機能 - JavaScriptで制御 */
@media screen and (min-width: 768px) and (max-width: 1919px) {
  .SP.PC {
    width: 1920px;
    transform-origin: top left;
  }
}

@media screen and (min-width: 1920px) {
  .SP.PC {
    width: 1920px;
    margin: 0 auto;
  }
}

/* スマホ版のレスポンシブ対応 */
@media screen and (max-width: 767px) {
  .SP.div {
    width: 100%;
    max-width: 100vw;
    overflow-x: hidden;
  }
  
  .SP.div img {
    max-width: 100%;
    height: auto;
    object-fit: contain;
  }
  
  /* スマホ版で画像がはみ出さないように */
  .SP.div .keyvisu-wrapper,
  .SP.div .keyvisu {
    max-width: 100%;
  }
}

/* PC版の画像レスポンシブ対応 */
@media screen and (min-width: 768px) {
  .SP.PC img {
    max-width: none;
  }
  
  /* keyvisu-2は固定サイズを維持 */
  .SP.PC .keyvisu-2 {
    width: 1920px !important;
    height: 1080px !important;
    max-width: none !important;
    max-height: none !important;
  }
}

/* 全体のオーバーフロー制御 */
html, body {
  overflow-x: hidden;
  width: 100%;
  margin: 0;
  padding: 0;
  background-color: #000000;
}

@media screen and (min-width: 768px) {
  html, body {
    background-color: #000000;
  }
  
  .SP.PC {
    height: 8411px;
    overflow: hidden;
  }
}

/* ナビゲーションリンクのスタイル */
.nav-link {
  cursor: pointer;
  transition: opacity 0.3s ease;
}

.nav-link:hover {
  opacity: 0.7;
}

.nav-link:active {
  opacity: 0.5;
}

/* スマホ版メニューのスタイル */
.SP.div.menu {
position: fixed;
  top: 20px;
  right: 20px;
  left: auto;
  width: auto;
  min-width: 160px;
  height: auto;
  max-height: 80vh;
  background-color: rgba(0, 0, 0, 0.95);
  z-index: 1000;
  display: flex;
  flex-direction: column;
  padding: 35px 25px 20px;
  border-radius: 6px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5);
  opacity: 0;
  visibility: hidden;
  transform: scale(0.8) translateY(-10px);
  transform-origin: top right;
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s ease;
  pointer-events: none;
}

.SP.div.menu.active {
  opacity: 1;
  visibility: visible;
  transform: scale(1) translateY(0);
  pointer-events: auto;
}

.SP.div.menu .menu-background {
  display: none;
}

.SP.div.menu .menu-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 14px;
  height: 14px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  z-index: 1001;
}

.SP.div.menu .menu-close img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
}

.SP.div.menu .menu-nav {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-start;
  justify-content: flex-start;
  margin-top: 0;
}

.SP.div.menu .menu-item {
  font-family: "Alegreya SC", Helvetica;
  font-weight: 500;
  font-size: 16px;
  color: #ffffff;
  text-align: left;
  letter-spacing: 0.5px;
  line-height: 1.3;
  white-space: nowrap;
  cursor: pointer;
  transition: opacity 0.2s ease;
  text-decoration: none;
}

.SP.div.menu .menu-item:hover {
  opacity: 0.7;
}

.SP.div.menu .menu-item:active {
  opacity: 0.5;
}

/* メニュートグルボタンのスタイル（スマホ版用） */
.SP.div .menu-toggle {
  position: fixed;
  top: 10px;
  bottom: 50px;
  left: auto;
  right: 35px;
  width: 17.545px;
  height: 15.561px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  z-index: 100;
}

.SP.div .menu-toggle img {
  width: 100%;
  height: 100%;
  display: block;
}

/* リンクのホバー効果 */
a {
  transition: opacity 0.3s ease;
}

a:hover {
  opacity: 0.8;
}

/* PC版ナビゲーションのリンクスタイル */
.SP.PC .navbar a {
  color: #ffffff;
  text-decoration: none;
}

.SP.PC .navbar a:hover {
  opacity: 0.7;
}

/* 固定要素のスタイル */
.SP.PC .rectangle-3 {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 90px;
  background-color: #000000;
  z-index: 50;
}

.SP.PC .navbar {
  position: fixed;
  right: 100px;
  top: 31px;
  z-index: 100;
}

@media screen and (min-width: 1920px) {
  .SP.PC .rectangle-3 {
    width: 1920px;
    left: 50%;
    transform: translateX(-50%);
  }
}

/* ===== アニメーション ===== */

/* キーフレーム定義 */
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(40px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeInLeft {
  from {
    opacity: 0;
    transform: translateX(-40px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes fadeInRight {
  from {
    opacity: 0;
    transform: translateX(40px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(0.9);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes float {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px);
  }
}

@keyframes pulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.05);
  }
}

/* ===== スマホ版アニメーション（レイアウト崩れ防止） ===== */

/* スクロールアニメーション - opacityのみでフェードイン */
.SP .animate-on-scroll {
  opacity: 0;
  transition: opacity 0.8s ease-out;
}

.SP .animate-on-scroll.visible {
  opacity: 1;
}

/* 遅延クラス */
.SP .animate-delay-1 { transition-delay: 0.1s; }
.SP .animate-delay-2 { transition-delay: 0.2s; }
.SP .animate-delay-3 { transition-delay: 0.3s; }
.SP .animate-delay-4 { transition-delay: 0.4s; }
.SP .animate-delay-5 { transition-delay: 0.5s; }

/* 初期ロードアニメーション */
.SP .keyvisu,
.SP .keyvisu-2 {
  animation: fadeIn 1.5s ease-out forwards;
}

/* ホバーエフェクト - ボタン（box-shadowのみ使用） */
.SP .group,
.SP .frame-wrapper,
.SP .group-30 {
  transition: box-shadow 0.3s ease;
}

.SP .group:hover,
.SP .frame-wrapper:hover,
.SP .group-30:hover {
  box-shadow: 0 10px 30px rgba(255, 255, 255, 0.2);
}

/* ホバーエフェクト - キャラクター画像 */
.SP .image-3,
.SP .image-4,
.SP .image-5,
.SP .image-6 {
  transition: filter 0.4s ease;
}

.SP .image-3:hover,
.SP .image-4:hover,
.SP .image-5:hover,
.SP .image-6:hover {
  filter: brightness(1.1);
}

/* ホバーエフェクト - YouTubeアイコン */
.SP .logos-youtube-icon {
  transition: filter 0.3s ease;
}

.SP .logos-youtube-icon:hover {
  filter: drop-shadow(0 0 10px rgba(255, 0, 0, 0.5));
}

/* セクションタイトルのホバー */
.SP .text-wrapper,
.SP .text-wrapper-3,
.SP .text-wrapper-4,
.SP .text-wrapper-5,
.SP .text-wrapper-6 {
  transition: text-shadow 0.3s ease;
}

.SP .text-wrapper:hover,
.SP .text-wrapper-3:hover,
.SP .text-wrapper-4:hover,
.SP .text-wrapper-5:hover,
.SP .text-wrapper-6:hover {
  text-shadow: 0 0 20px rgba(255, 255, 255, 0.5);
}

/* マップ・ステージ画像のホバー */
.SP .group-10 {
  transition: box-shadow 0.5s ease;
}

.SP .group-10:hover {
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}

/* ===== PC版アニメーション ===== */

/* 遅延アニメーション用ユーティリティ */
/* 遅延アニメーション用ユーティリティ */
.delay-100 { animation-delay: 0.1s; }
.delay-200 { animation-delay: 0.2s; }
.delay-300 { animation-delay: 0.3s; }
.delay-400 { animation-delay: 0.4s; }
.delay-500 { animation-delay: 0.5s; }

/* スムーズなページ遷移 */
html {
  scroll-behavior: smooth;
}

/* PC版追加アニメーション */
.SP.PC .keyvisu-2 {
  animation: fadeIn 1.5s ease-out forwards;
}

.SP.PC .navbar {
  animation: fadeIn 1s ease-out 0.5s backwards;
}

.SP.PC .image-8,
.SP.PC .image-9,
.SP.PC .image-10,
.SP.PC .image-11,
.SP.PC .image-12 {
  transition: transform 0.4s ease, filter 0.4s ease;
}

.SP.PC .image-8:hover,
.SP.PC .image-9:hover,
.SP.PC .image-10:hover,
.SP.PC .image-11:hover,
.SP.PC .image-12:hover {
  transform: scale(1.05);
  filter: brightness(1.1);
}

.SP.PC .logos-youtube-icon {
  transition: transform 0.3s ease, filter 0.3s ease;
}

.SP.PC .logos-youtube-icon:hover {
  transform: scale(1.15);
  filter: drop-shadow(0 0 10px rgba(255, 0, 0, 0.5));
}

.SP.PC .text-wrapper-20,
.SP.PC .text-wrapper-21,
.SP.PC .text-wrapper-22,
.SP.PC .text-wrapper-23 {
  transition: text-shadow 0.3s ease;
}

.SP.PC .text-wrapper-20:hover,
.SP.PC .text-wrapper-21:hover,
.SP.PC .text-wrapper-22:hover,
.SP.PC .text-wrapper-23:hover {
  text-shadow: 0 0 20px rgba(255, 255, 255, 0.5);
}

.SP.PC .frame-7 img {
  transition: transform 0.5s ease, box-shadow 0.5s ease;
}

.SP.PC .frame-7 img:hover {
  transform: scale(1.02);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}
