@charset "UTF-8";
/* CSS Document */
html {
  font-size: 62.5%;
  scroll-behavior: smooth;
}

body {
  font-size: 1.8rem;
  line-height: 1.75;
  line-break: strict;
  word-wrap: break-word;
  overflow-wrap: break-word;
  letter-spacing: 0.2rem;
  font-feature-settings: "palt";
  position: relative;
}
@media screen and (max-width: 840px) {
  body {
    font-size: 1.6rem;
  }
}
body.open {
  overflow: hidden;
}

img {
  width: 100%;
  height: auto;
}

p {
  text-align: justify;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.inner {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  width: 95%;
}

.detail {
  font-size: 1rem;
}

section {
  padding: 150px 0;
}
@media screen and (max-width: 600px) {
  section {
    padding: 50px 0;
  }
}

/*-------------------------*/
body {
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 600;
  font-style: normal;
  letter-spacing: 0.05rem;
}

main {
  position: relative;
  width: 100%;
  height: 100vh;
}

section {
  padding: 0;
}

.fix_back,
.fix_content {
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  min-width: 540px;
  overflow: hidden;
}
@media screen and (max-width: 540px) {
  .fix_back,
  .fix_content {
    min-width: initial;
  }
}

.fix_back {
  background-image: url(images/asset_back.webp);
  background-size: cover;
  background-repeat: no-repeat;
  border: 12px #2e2624 solid;
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
}
@media screen and (max-width: 840px) {
  .fix_back {
    border: none;
  }
}

.hamburger {
  display: none;
  width: 50px;
  aspect-ratio: 1/1;
  flex-flow: column;
  justify-content: center;
  position: fixed;
  top: 15px;
  right: 15px;
  z-index: 100;
  padding: 6px;
  background: linear-gradient(to right, #29c7b0, #1dbff0);
  transition: all ease 0.3s;
  border: 1.5px solid #fff;
  gap: 7px;
}
.hamburger span {
  width: 100%;
  height: 3px;
  background-color: #fff;
  transition: all ease 0.3s;
}
@media screen and (max-width: 840px) {
  .hamburger {
    display: flex;
  }
}
.hamburger.open {
  background: transparent;
  border: none;
}
.hamburger.open span:nth-of-type(1) {
  transform: translateY(5px) rotate(225deg);
}
.hamburger.open span:nth-of-type(2) {
  display: none;
}
.hamburger.open span:nth-of-type(3) {
  transform: translateY(-5px) rotate(135deg);
}

@keyframes fadein {
  0% {
    opacity: 0;
    transform: translateY(100px);
  }
  100% {
    opacity: 1;
    transform: none;
  }
}
[class*=asset_] {
  opacity: 0;
  animation: fadein 1s forwards, move 2.5s infinite;
  animation-delay: 0.5s;
}

[class*=asset_]:nth-child(1) {
  animation-delay: 0s;
}

[class*=asset_]:nth-child(2) {
  animation-delay: 0.1s;
}

[class*=asset_]:nth-child(3) {
  animation-delay: 0.2s;
}

[class*=asset_]:nth-child(4) {
  animation-delay: 0.3s;
}

[class*=asset_]:nth-child(5) {
  animation-delay: 0.4s;
}

[class*=asset_]:nth-child(6) {
  animation-delay: 0.5s;
}

[class*=asset_]:nth-child(7) {
  animation-delay: 0.6s;
}

[class*=asset_]:nth-child(8) {
  animation-delay: 0.7s;
}

[class*=asset_]:nth-child(9) {
  animation-delay: 0.8s;
}

[class*=asset_]:nth-child(10) {
  animation-delay: 0.9s;
}

[class*=asset_]:nth-child(11) {
  animation-delay: 1s;
}

[class*=asset_]:nth-child(12) {
  animation-delay: 1.1s;
}

[class*=asset_]:nth-child(13) {
  animation-delay: 1.2s;
}

[class*=asset_]:nth-child(14) {
  animation-delay: 1.3s;
}

[class*=asset_]:nth-child(15) {
  animation-delay: 1.4s;
}

[class*=asset_]:nth-child(16) {
  animation-delay: 1.5s;
}

[class*=asset_]:nth-child(17) {
  animation-delay: 1.6s;
}

[class*=asset_]:nth-child(18) {
  animation-delay: 1.7s;
}

[class*=asset_]:nth-child(19) {
  animation-delay: 1.8s;
}

[class*=asset_]:nth-child(20) {
  animation-delay: 1.9s;
}

[class*=asset_]:nth-child(21) {
  animation-delay: 2s;
}

[class*=asset_]:nth-child(22) {
  animation-delay: 2.1s;
}

[class*=asset_]:nth-child(23) {
  animation-delay: 2.2s;
}

[class*=asset_]:nth-child(24) {
  animation-delay: 2.3s;
}

[class*=asset_]:nth-child(25) {
  animation-delay: 2.4s;
}

[class*=asset_]:nth-child(26) {
  animation-delay: 2.5s;
}

[class*=asset_]:nth-child(27) {
  animation-delay: 2.6s;
}

[class*=asset_]:nth-child(28) {
  animation-delay: 2.7s;
}

[class*=asset_]:nth-child(29) {
  animation-delay: 2.8s;
}

[class*=asset_]:nth-child(30) {
  animation-delay: 2.9s;
}

[class*=asset_]:nth-child(31) {
  animation-delay: 3s;
}

[class*=asset_]:nth-child(32) {
  animation-delay: 3.1s;
}

[class*=asset_]:nth-child(33) {
  animation-delay: 3.2s;
}

[class*=asset_]:nth-child(34) {
  animation-delay: 3.3s;
}

[class*=asset_]:nth-child(35) {
  animation-delay: 3.4s;
}

[class*=asset_]:nth-child(36) {
  animation-delay: 3.5s;
}

[class*=asset_]:nth-child(37) {
  animation-delay: 3.6s;
}

[class*=asset_]:nth-child(38) {
  animation-delay: 3.7s;
}

[class*=asset_]:nth-child(39) {
  animation-delay: 3.8s;
}

[class*=asset_]:nth-child(40) {
  animation-delay: 3.9s;
}

[class*=asset_]:nth-child(41) {
  animation-delay: 4s;
}

[class*=asset_]:nth-child(42) {
  animation-delay: 4.1s;
}

[class*=asset_]:nth-child(43) {
  animation-delay: 4.2s;
}

[class*=asset_]:nth-child(44) {
  animation-delay: 4.3s;
}

[class*=asset_]:nth-child(45) {
  animation-delay: 4.4s;
}

[class*=asset_]:nth-child(46) {
  animation-delay: 4.5s;
}

[class*=asset_]:nth-child(47) {
  animation-delay: 4.6s;
}

[class*=asset_]:nth-child(48) {
  animation-delay: 4.7s;
}

[class*=asset_]:nth-child(49) {
  animation-delay: 4.8s;
}

[class*=asset_]:nth-child(50) {
  animation-delay: 4.9s;
}

[class*=asset_]:nth-child(51) {
  animation-delay: 5s;
}

[class*=asset_]:nth-child(52) {
  animation-delay: 5.1s;
}

[class*=asset_]:nth-child(53) {
  animation-delay: 5.2s;
}

[class*=asset_]:nth-child(54) {
  animation-delay: 5.3s;
}

[class*=asset_]:nth-child(55) {
  animation-delay: 5.4s;
}

[class*=asset_]:nth-child(56) {
  animation-delay: 5.5s;
}

[class*=asset_]:nth-child(57) {
  animation-delay: 5.6s;
}

[class*=asset_]:nth-child(58) {
  animation-delay: 5.7s;
}

[class*=asset_]:nth-child(59) {
  animation-delay: 5.8s;
}

[class*=asset_]:nth-child(60) {
  animation-delay: 5.9s;
}

[class*=asset_]:nth-child(61) {
  animation-delay: 6s;
}

[class*=asset_]:nth-child(62) {
  animation-delay: 6.1s;
}

[class*=asset_]:nth-child(63) {
  animation-delay: 6.2s;
}

[class*=asset_]:nth-child(64) {
  animation-delay: 6.3s;
}

[class*=asset_]:nth-child(65) {
  animation-delay: 6.4s;
}

[class*=asset_]:nth-child(66) {
  animation-delay: 6.5s;
}

[class*=asset_]:nth-child(67) {
  animation-delay: 6.6s;
}

[class*=asset_]:nth-child(68) {
  animation-delay: 6.7s;
}

[class*=asset_]:nth-child(69) {
  animation-delay: 6.8s;
}

[class*=asset_]:nth-child(70) {
  animation-delay: 6.9s;
}

[class*=asset_]:nth-child(71) {
  animation-delay: 7s;
}

[class*=asset_]:nth-child(72) {
  animation-delay: 7.1s;
}

[class*=asset_]:nth-child(73) {
  animation-delay: 7.2s;
}

[class*=asset_]:nth-child(74) {
  animation-delay: 7.3s;
}

[class*=asset_]:nth-child(75) {
  animation-delay: 7.4s;
}

[class*=asset_]:nth-child(76) {
  animation-delay: 7.5s;
}

[class*=asset_]:nth-child(77) {
  animation-delay: 7.6s;
}

[class*=asset_]:nth-child(78) {
  animation-delay: 7.7s;
}

[class*=asset_]:nth-child(79) {
  animation-delay: 7.8s;
}

[class*=asset_]:nth-child(80) {
  animation-delay: 7.9s;
}

[class*=asset_]:nth-child(81) {
  animation-delay: 8s;
}

[class*=asset_]:nth-child(82) {
  animation-delay: 8.1s;
}

[class*=asset_]:nth-child(83) {
  animation-delay: 8.2s;
}

[class*=asset_]:nth-child(84) {
  animation-delay: 8.3s;
}

[class*=asset_]:nth-child(85) {
  animation-delay: 8.4s;
}

[class*=asset_]:nth-child(86) {
  animation-delay: 8.5s;
}

[class*=asset_]:nth-child(87) {
  animation-delay: 8.6s;
}

[class*=asset_]:nth-child(88) {
  animation-delay: 8.7s;
}

[class*=asset_]:nth-child(89) {
  animation-delay: 8.8s;
}

[class*=asset_]:nth-child(90) {
  animation-delay: 8.9s;
}

[class*=asset_]:nth-child(91) {
  animation-delay: 9s;
}

[class*=asset_]:nth-child(92) {
  animation-delay: 9.1s;
}

[class*=asset_]:nth-child(93) {
  animation-delay: 9.2s;
}

[class*=asset_]:nth-child(94) {
  animation-delay: 9.3s;
}

[class*=asset_]:nth-child(95) {
  animation-delay: 9.4s;
}

[class*=asset_]:nth-child(96) {
  animation-delay: 9.5s;
}

[class*=asset_]:nth-child(97) {
  animation-delay: 9.6s;
}

[class*=asset_]:nth-child(98) {
  animation-delay: 9.7s;
}

[class*=asset_]:nth-child(99) {
  animation-delay: 9.8s;
}

[class*=asset_]:nth-child(100) {
  animation-delay: 9.9s;
}

@keyframes reveal {
  /* 左→右へクリップを広げる */
  to {
    clip-path: inset(0 0 0 0);
  }
}
.menu {
  position: fixed;
  width: 15vw;
  right: 3%;
  top: 42%;
  transition: all ease 0.3s;
  z-index: 1;
}
.menu .inner {
  display: flex;
  flex-flow: column;
  gap: 8px;
}
.menu .inner a {
  font-size: 1.6rem;
  width: 100%;
  background-color: #fff;
  border-radius: 100px;
  padding: 5px 20px;
  position: relative;
  filter: drop-shadow(3px 3px 3px rgba(0, 0, 0, 0.3));
  transition: all ease 0.3s;
}
.menu .inner a::after {
  content: "";
  width: 20px;
  height: 20px;
  background-color: #1aa89e;
  border-radius: 30px;
  position: absolute;
  right: 15px;
  top: calc(50% - 10px);
  background-image: url(images/arrow.webp);
  background-size: 8px;
  background-repeat: no-repeat;
  background-position: center;
  transition: all ease 0.3s;
}
.menu .inner a:hover {
  background-color: #1aa89e;
  color: #fff;
}
.menu .inner a:hover:after {
  transform: translateX(3px);
  background-color: #fff;
  background-image: url(images/arrow_bk.webp);
}
@media screen and (max-width: 840px) {
  .menu {
    opacity: 0;
    transform: translateX(100%);
    width: 100%;
    height: 100vh;
    left: 0;
    top: 0;
    background-color: rgba(26, 168, 158, 0.7);
    z-index: 99;
  }
  .menu .inner {
    max-width: 350px;
    margin-top: 110px;
  }
  .menu.open {
    opacity: 1;
    transform: translateX(0);
  }
}

@media screen and (max-width: 840px) {
  .menu_title {
    width: 60vw;
    margin: 0 auto;
  }
}

.fix_content {
  background-image: url(images/bubble.webp);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  overflow-x: hidden;
}
.fix_content > figure {
  position: absolute;
}
.fix_content .ggx_logo {
  width: 5vw;
  left: 3%;
  top: 4%;
}
@media screen and (max-width: 840px) {
  .fix_content .ggx_logo {
    width: 18vw;
    left: 6%;
    top: 3%;
  }
}
.fix_content .title {
  width: 105%;
  top: 9%;
  left: -5%;
  clip-path: inset(0 100% 0 0);
  animation: reveal 0.5s ease forwards;
  animation-delay: 0.1s;
}
@media screen and (min-width: 1480px) {
  .fix_content .title {
    width: 95%;
  }
}
.fix_content .asset_controller {
  width: 9vw;
  left: 28%;
  top: 5%;
}
@media screen and (max-width: 840px) {
  .fix_content .asset_controller {
    width: 24vw;
    left: 58%;
    top: 7%;
  }
}
.fix_content .title_date {
  width: 24vw;
  left: 3%;
  bottom: 18%;
  z-index: 2;
  height: 23vh;
}
@media screen and (max-width: 840px) {
  .fix_content .title_date {
    width: 56vw;
  }
}
@media screen and (max-width: 540px) {
  .fix_content .title_date {
    width: 61vw;
    left: 4%;
    bottom: 23%;
  }
}
.fix_content .title_date img {
  -o-object-fit: contain;
     object-fit: contain;
  height: 100%;
  -o-object-position: bottom;
     object-position: bottom;
}
.fix_content .asset_tablet {
  width: 10vw;
  left: 24%;
  bottom: 35%;
}
@media screen and (max-width: 840px) {
  .fix_content .asset_tablet {
    width: 23vw;
    left: 10%;
    bottom: 3%;
  }
}
@media screen and (max-width: 540px) {
  .fix_content .asset_tablet {
    width: 25vw;
    left: 30%;
    bottom: 41%;
  }
}
@media screen and (min-width: 1480px) {
  .fix_content .asset_tablet {
    left: 29%;
    bottom: 29%;
  }
}
.fix_content .asset_monitor {
  width: 9vw;
  bottom: 11%;
  left: 24%;
}
@media screen and (max-width: 840px) {
  .fix_content .asset_monitor {
    width: 20vw;
    bottom: 11%;
    left: 50%;
  }
}
@media screen and (max-width: 540px) {
  .fix_content .asset_monitor {
    width: 26vw;
    left: 46%;
  }
}
.fix_content .asset_device {
  width: 8vw;
  left: 1%;
  top: 50%;
}
@media screen and (max-width: 840px) {
  .fix_content .asset_device {
    width: 19vw;
    left: 1%;
    top: 53%;
  }
}
@media screen and (max-width: 540px) {
  .fix_content .asset_device {
    top: 44%;
  }
}
@media screen and (min-width: 1480px) {
  .fix_content .asset_device {
    top: 52%;
  }
}
.fix_content .asset_star3 {
  width: 5vw;
  left: 12%;
}
@media screen and (max-width: 840px) {
  .fix_content .asset_star3 {
    width: 15vw;
    left: 32%;
  }
}
.fix_content .asset_star2 {
  width: 4vw;
  left: 36%;
  top: 2%;
}
@media screen and (max-width: 840px) {
  .fix_content .asset_star2 {
    width: 10vw;
    left: 72%;
    top: 2%;
  }
}
.fix_content .asset_star1 {
  width: 5vw;
  bottom: 8%;
  left: 22%;
}
@media screen and (max-width: 840px) {
  .fix_content .asset_star1 {
    width: 15vw;
    bottom: 6%;
    left: 32%;
  }
}
@media screen and (max-width: 540px) {
  .fix_content .asset_star1 {
    bottom: 13%;
  }
}
.fix_content .stripe {
  width: 550px;
  right: -80px;
  top: 0px;
  mix-blend-mode: screen;
}
.fix_content .asset_joy {
  width: 13vw;
  top: 60px;
  right: 50px;
}
@media screen and (min-width: 1480px) {
  .fix_content .asset_joy {
    width: 14vw;
  }
}
.fix_content .asset_flower {
  width: 6vw;
  right: 1%;
  top: 26%;
}
.fix_content .asset_gamer {
  width: 170px;
  right: 0;
  bottom: 0;
}
.fix_content .link_btn {
  position: absolute;
  left: 3%;
  bottom: 5%;
}
.fix_content .free {
  position: absolute;
  color: #fff;
  font-size: 3rem;
  padding: 0px 20px;
  border: 2px solid #fff;
  background-color: rgba(26, 168, 158, 0.8);
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 600;
  font-style: normal;
  left: 34%;
  top: 18%;
  transform: skew(0deg, -7deg);
}
@media screen and (max-width: 840px) {
  .fix_content .free {
    left: 73%;
    top: 26%;
    font-size: 3rem;
  }
}
@media screen and (max-width: 540px) {
  .fix_content .free {
    left: 66%;
    top: 16%;
    font-size: 2rem;
  }
}
.fix_content .chara {
  display: none;
}
@media screen and (max-width: 840px) {
  .fix_content .chara {
    display: block;
    right: -8%;
    bottom: -3%;
    width: 52vw;
    left: initial;
  }
}
@media screen and (max-width: 540px) {
  .fix_content .chara {
    right: -2%;
  }
}
@media screen and (max-width: 840px) {
  .fix_content {
    position: relative;
  }
  .fix_content .asset_joy,
  .fix_content .asset_stripe,
  .fix_content .asset_flower,
  .fix_content .asset_gamer,
  .fix_content .link_btn {
    display: none;
  }
}

.sp_body {
  max-width: 500px;
  width: 37%;
  background-color: #fff;
  position: absolute;
  left: 45%;
  min-height: 100%;
}
@media screen and (max-width: 840px) {
  .sp_body {
    max-width: 100%;
    width: 100%;
    left: 0;
  }
}
@media screen and (min-width: 1650px) {
  .sp_body {
    left: 52%;
  }
}
.sp_body .inner {
  width: 80%;
}
@media screen and (max-width: 840px) {
  .sp_body .inner {
    width: 85%;
  }
}

@keyframes move {
  0%, 100% {
    transform: none;
  }
  50% {
    transform: translateY(-10px);
  }
}
.chara {
  opacity: 0;
  position: fixed;
  left: 29%;
  bottom: -3%;
  z-index: 1;
  width: 19vw;
  max-width: 396px;
  height: 55vh;
  animation: fadein 0.5s forwards, move 3.5s infinite;
  animation-delay: 1.3s;
}
@media screen and (max-width: 840px) {
  .chara {
    display: none;
  }
}
@media screen and (min-width: 1480px) {
  .chara {
    max-width: 423px;
    left: 35%;
  }
}
.chara img {
  -o-object-fit: contain;
     object-fit: contain;
  height: 100%;
  -o-object-position: bottom;
     object-position: bottom;
}

.link_btn {
  transition: all ease 0.3s;
  font-size: 1.6rem;
  background: linear-gradient(to right, #29c7b0, #1dbff0);
  border: 1px solid #fff;
  border-radius: 50px;
  padding: 20px 58px 20px 25px;
  position: relative;
  filter: drop-shadow(0px 0px 0px #2e2624);
  color: #2e2624;
  display: flex;
  align-items: center;
  justify-content: center;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 300px;
  margin: 20px auto;
}
.link_btn::before {
  content: "";
  width: 20px;
  height: 20px;
  background-color: #2e2624;
  border-radius: 30px;
  position: absolute;
  right: 25px;
  top: calc(50% - 10px);
  background-image: url(images/arrow.webp);
  background-size: 12px;
  background-repeat: no-repeat;
  background-position: center;
  transition: all ease 0.3s;
}
.link_btn.small_btn {
  filter: none;
  color: #fff;
  background: transparent;
  border: none;
  min-width: 230px;
  margin: 50px auto;
  z-index: 1;
}
.link_btn.small_btn::before {
  background-color: #555;
}
.link_btn.small_btn .btn_shadow,
.link_btn.small_btn .btn_back {
  width: 100%;
  height: 100%;
  border-radius: 50px;
  position: absolute;
  z-index: -1;
}
.link_btn.small_btn .btn_shadow {
  background: linear-gradient(to right, #29c7b0, #1dbff0);
  left: 0;
  top: 0;
  transition: all ease 0.3s;
}
.link_btn.small_btn .btn_back {
  background-color: #2e2624;
  left: 0;
  top: 0;
}
.link_btn.back_btn {
  color: #2e2624;
}
.link_btn.back_btn .btn_back {
  background-color: #fff;
  border: 1px solid #2e2624;
}
.link_btn.back_btn::before {
  background-color: #63efdb;
}
.link_btn:hover {
  transform: translate(-8px, -8px);
  filter: drop-shadow(8px 8px 0px #2e2624);
}
.link_btn:hover.small_btn {
  transform: translate(-6px, -6px);
  filter: none;
}
.link_btn:hover .btn_shadow {
  background: linear-gradient(to right, #29c7b0, #1dbff0);
  left: 6px;
  top: 6px;
}
.link_btn:hover::before {
  background-color: #fff;
  background-image: url(images/arrow_bk.webp);
}
.link_btn.active {
  animation: btn 0.3s forwards ease;
}
@keyframes btn {
  0% {
    transform: translateX(-5px);
  }
  50% {
    transform: translateX(5px);
  }
  100% {
    transform: translateX(0);
  }
}

.bc_black {
  background-color: #3d3739;
  background-image: url(images/bc_asset.webp);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

#about_1 {
  padding: 40px 0;
}
#about_1 p {
  font-size: 2rem;
  color: #fff;
  text-align: center;
}
#about_1 p span {
  color: #63efdb;
}

#about_2 {
  padding: 20px 0;
}

h2 {
  color: #2e2624;
  font-size: 6.2rem;
  font-family: "neuzeit-grotesk", "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 700;
  font-style: normal;
  position: relative;
  z-index: 1;
}
h2::after {
  content: "";
  background-image: url(images/asset_h2.webp);
  width: 177px;
  height: 35px;
  position: absolute;
  left: 0;
  bottom: 9px;
  background-size: contain;
  background-repeat: no-repeat;
  z-index: -1;
}

#news {
  position: relative;
}
#news .asset_game {
  position: absolute;
  width: 14vw;
  right: -10%;
  top: -10%;
}
@media screen and (max-width: 840px) {
  #news .asset_game {
    right: 0;
    width: 39vw;
  }
}
@media screen and (min-width: 1480px) {
  #news .asset_game {
    width: 9vw;
  }
}

.single-news #news,
.archive #news {
  min-height: 80vh;
}

.news_wrap .item {
  border-bottom: 1px solid #999;
  padding: 10px 0;
  display: flex;
  flex-flow: column;
}
.news_wrap .date {
  color: #29c7b0;
  font-size: 1.3rem;
}
.news_wrap .title {
  color: #2e2624;
  font-size: 1.6rem;
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 300;
  font-style: normal;
}

#about {
  position: relative;
}
#about .asset_monitor {
  position: absolute;
  width: 7vw;
  right: 24%;
  top: -13%;
}
@media screen and (max-width: 840px) {
  #about .asset_monitor {
    width: 23vw;
    right: 28%;
    top: -16%;
  }
}
@media screen and (min-width: 1480px) {
  #about .asset_monitor {
    width: 5vw;
    right: 33%;
    top: -19%;
  }
}
#about .asset_gamer {
  width: 10vw;
  position: absolute;
  right: 5%;
  top: -9%;
}
@media screen and (max-width: 840px) {
  #about .asset_gamer {
    width: 34vw;
  }
}
@media screen and (min-width: 1480px) {
  #about .asset_gamer {
    width: 8vw;
    right: 8%;
    top: -15%;
  }
}
#about h2,
#about h4 {
  color: #fff;
}
#about .about_wrap {
  padding: 30px 0;
}
#about .about_wrap h5,
#about .about_wrap p {
  text-align: center;
}
#about .about_wrap h5 {
  color: #1aa89e;
  margin-top: 20px;
}
#about .about_wrap p {
  color: #fff;
}
#about .asset_tablet {
  position: absolute;
  width: 10vw;
  transform: scale(-1, 1);
  bottom: -25%;
  left: -4%;
}
@media screen and (max-width: 840px) {
  #about .asset_tablet {
    width: 33vw;
    bottom: -25%;
    left: -1%;
  }
}
@media screen and (min-width: 1480px) {
  #about .asset_tablet {
    width: 7vw;
  }
}
#about .asset_pen {
  position: absolute;
  width: 7vw;
  bottom: -10%;
  left: 15%;
}
@media screen and (max-width: 840px) {
  #about .asset_pen {
    width: 22vw;
    bottom: -10%;
    left: 22%;
  }
}
@media screen and (min-width: 1480px) {
  #about .asset_pen {
    width: 5vw;
  }
}

#sponsor {
  padding: 80px 0;
  background-color: #e6f4f5;
}
#sponsor h4 {
  text-align: center;
}

.sponsor_wrap {
  display: flex;
  flex-flow: row wrap;
  gap: 10px;
  justify-content: center;
  margin: 15px 0 50px;
}
.sponsor_wrap .item {
  width: calc((100% - 10px) / 2);
  background-color: #fff;
  aspect-ratio: 1/0.55;
  border-radius: 12px;
  padding: 15px;
}
.sponsor_wrap .item img {
  -o-object-fit: contain;
     object-fit: contain;
  height: 100%;
  -o-object-position: center;
     object-position: center;
}

#page_title {
  padding: 60px 0 20px;
}
#page_title h1 {
  color: #fff;
  font-size: 3rem;
  text-align: center;
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  gap: 20px;
  position: relative;
}
#page_title h1 span {
  color: #999;
  font-size: 1.9rem;
  font-family: "neuzeit-grotesk", sans-serif;
  font-weight: 700;
  font-style: normal;
}
#page_title h1::before {
  content: "";
  background-image: url(images/h3_asset.webp);
  width: 45px;
  height: 5px;
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  left: 50%;
  bottom: -10px;
  transform: translate(-50%, -50%);
}

#nexusjam {
  position: relative;
}
#nexusjam .inner > p {
  font-size: 1.5rem;
  margin-top: 40px;
}
#nexusjam .asset_display {
  width: 6vw;
  top: -27%;
  position: absolute;
  left: 3%;
}

.sc_logo {
  display: none;
}

.page h2,
.archive h2 {
  font-size: 3.4rem;
  text-align: center;
}
.page h2::after,
.archive h2::after {
  left: 50%;
  bottom: -17%;
  transform: translateX(-50%);
}
.page .tape02:nth-last-of-type(1),
.archive .tape02:nth-last-of-type(1) {
  position: absolute;
  bottom: 0;
}
@media screen and (max-width: 840px) {
  .page .fix_content,
  .archive .fix_content {
    display: none;
  }
}
.page .sc_logo,
.archive .sc_logo {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 28vw;
  aspect-ratio: 1/0.85;
  max-width: 300px;
  z-index: 100;
  padding: 10px;
  transition: all ease 0.3s;
}
@media screen and (min-width: 840px) {
  .page .sc_logo,
  .archive .sc_logo {
    display: none;
  }
}
.page .sc_logo.active,
.archive .sc_logo.active {
  background-image: url(images/sc_logo_back.webp);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: left top;
}
.page #sponsor,
.archive #sponsor {
  min-height: 80vh;
}

.game_title_wrap {
  display: flex;
  flex-flow: column;
  gap: 15px;
  margin: 40px auto;
}
.game_title_wrap .item {
  width: 100%;
  position: relative;
  flex-flow: row;
}
.game_title_wrap .item .shadow {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 5px;
  top: 5px;
  background: linear-gradient(to right, #fffac2, #22e6e4);
}
.game_title_wrap .item .back {
  background: linear-gradient(to right, #22e6e4, #fffac2);
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
}
.game_title_wrap .item .back::before {
  content: "";
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  background-color: #fff;
  position: absolute;
  top: 1px;
  left: 1px;
}
.game_title_wrap .item .ph {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  background: linear-gradient(to right, #fffac2, #22e6e4);
}
.game_title_wrap .item .ph img {
  -o-object-fit: contain;
     object-fit: contain;
  height: 100%;
}
.game_title_wrap .item .txt {
  padding: 5px 10px;
  flex: 1;
  position: relative;
}
.game_title_wrap .item .txt .title {
  font-size: 2rem;
  margin-bottom: 8px;
  line-height: 1.4;
}
.game_title_wrap .item .txt a {
  display: inline-flex;
  align-items: center;
}
@media screen and (max-width: 540px) {
  .game_title_wrap .item .txt .title {
    font-size: 1.6rem;
  }
  .game_title_wrap .item .txt .team_name {
    font-size: 1.2rem;
  }
}

.team_name {
  color: #1aa89e;
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-size: 1.6rem;
  line-height: 1.4;
}
.team_name .tab_img {
  width: 20px;
}

.modal_layer {
  z-index: 100;
  background-color: rgba(0, 0, 0, 0.5);
  position: fixed;
  top: 0;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  left: 0;
}
.modal_layer .modal_inner {
  width: 90%;
  height: 90%;
  position: relative;
  max-width: 600px;
  max-height: 1000px;
}
.modal_layer .modal_inner .close {
  width: 30px;
  height: 30px;
  position: absolute;
  right: -15px;
  top: -15px;
  background-image: url(images/close.webp);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  cursor: pointer;
  z-index: 1;
}
.modal_layer .modal_inner .wrap {
  width: 100%;
  height: 100%;
  position: relative;
}
.modal_layer .modal_inner .wrap .back {
  background: linear-gradient(to right, #fffac2, #22e6e4);
  position: absolute;
  top: 10px;
  left: 10px;
  width: 100%;
  height: 100%;
}
.modal_layer .modal_inner .wrap .modal-content {
  border: 1px solid #22e6e4;
  background-color: #fff;
  height: 100%;
  position: relative;
  overflow-y: scroll;
  /*IE(Internet Explorer)・Microsoft Edgeへの対応*/
  -ms-overflow-style: none;
  /*Firefoxへの対応*/
  scrollbar-width: none;
}
.modal_layer .modal_inner .wrap .modal-content .content,
.modal_layer .modal_inner .wrap .modal-content .title,
.modal_layer .modal_inner .wrap .modal-content .team_name {
  padding: 25px;
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 300;
  font-style: normal;
}
.modal_layer .modal_inner .wrap .modal-content .content a,
.modal_layer .modal_inner .wrap .modal-content .title a,
.modal_layer .modal_inner .wrap .modal-content .team_name a {
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #5793d8;
}
.modal_layer .modal_inner .wrap .modal-content .content {
  text-align: justify;
}
.modal_layer .modal_inner .wrap .modal-content .title {
  font-size: 2.2rem;
  padding-bottom: 0;
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 600;
  font-style: normal;
}
.modal_layer .modal_inner .wrap .modal-content .team_name {
  color: #1aa89e;
  padding-top: 0;
}
.modal_layer .modal_inner .wrap .modal-content .ph {
  background: linear-gradient(to right, #fffac2, #22e6e4);
  width: 100%;
  aspect-ratio: 16/9;
  padding: 10px;
}
.modal_layer .modal_inner .wrap .modal-content .ph img {
  -o-object-fit: contain;
     object-fit: contain;
  height: 100%;
}
.modal_layer .modal_inner .wrap .modal-content::-webkit-scrollbar {
  display: none;
}
.modal_layer.is-guest .ph {
  padding: 0 !important;
}
.modal_layer.is-guest .ph img {
  -o-object-fit: contain;
     object-fit: contain;
  height: 100%;
}

.js-modal {
  display: none;
}
.js-modal.is-active {
  display: flex;
}

#company {
  padding-bottom: 10px;
}
#company h2 {
  color: #fff;
}

#cgp {
  padding-bottom: 120px;
}

.single-news .news_content .date {
  color: #29c7b0;
  font-size: 1.3rem;
  margin-top: 5px;
}
.single-news .news_content .title {
  color: #2e2624;
  font-size: 2.2rem;
  margin-bottom: 5px;
}
.single-news .news_content .content {
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-size: 1.5rem;
}

.nolink {
  pointer-events: none;
  background: #9e9e9e;
}

.menu_x {
  display: inline-flex;
  background: #fff;
  border: 1px solid #000;
  border-radius: 999px;
  margin-top: 16px;
  padding: 5px;
}

.menu_x img {
  width: 15px;
  height: 15px;
  display: block;
}

.map {
  margin: 40px 0 10px;
  aspect-ratio: 16/9;
}
.map iframe {
  width: 100%;
  height: 100%;
}

.floormap p {
  font-size: 1.6rem;
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 300;
  font-style: normal;
  margin-bottom: 30px;
}

.access {
  padding-bottom: 50px;
}
.access p {
  font-size: 1.6rem;
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 300;
  font-style: normal;
}
.access h4 {
  margin-top: 30px;
  background-color: #1aa89e;
  color: #fff;
  border-radius: 50px;
  padding: 5px 20px;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 1.6rem;
  margin-bottom: 10px;
}

.contents_wrap .item {
  background-color: #dbf8f5;
  margin-bottom: 20px;
}
.contents_wrap .item .time_wrap {
  display: flex;
  flex-flow: row wrap;
}
.contents_wrap .item .time_wrap .time {
  width: -moz-fit-content;
  width: fit-content;
  background: linear-gradient(to right, #29c7b0, #1dbff0);
  font-family: "neuzeit-grotesk", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 2rem;
  padding: 3px 26px 3px 8px;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 600px) {
  .contents_wrap .item .time_wrap .time {
    font-size: 1.5rem;
    padding-right: 14px;
  }
}
.contents_wrap .item .time_wrap .title {
  font-size: 1.6rem;
  line-height: 1.5;
  background-color: #2e2624;
  color: #fff;
  padding: 3px 8px;
  flex: 1;
  position: relative;
  display: flex;
  align-items: center;
}
.contents_wrap .item .time_wrap .title::before {
  content: "";
  height: 100%;
  aspect-ratio: 0.3/1;
  clip-path: polygon(0 100%, 100% 0, 100% 100%);
  background: #2e2624;
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(-90%);
}
@media screen and (max-width: 600px) {
  .contents_wrap .item .time_wrap .title {
    font-size: 1.5rem;
    letter-spacing: 0;
  }
}
.contents_wrap .item .txt {
  font-size: 1.6rem;
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 300;
  font-style: normal;
  width: 90%;
  margin: 20px auto;
}
.contents_wrap .item.no_link {
  background: linear-gradient(to right, #736ec2, #5793d8);
  color: #fff;
  text-align: center;
  padding: 5px;
  display: flex;
  position: relative;
}
.contents_wrap .item.no_link::before, .contents_wrap .item.no_link::after {
  content: "";
  height: 100%;
  aspect-ratio: 0.3/1;
  clip-path: polygon(0 100%, 100% 0, 100% 100%);
  background: #fff;
  position: absolute;
  top: 0;
}
.contents_wrap .item.no_link::before {
  left: 0;
  transform: translateX(-5%) rotate(180deg);
}
.contents_wrap .item.no_link::after {
  right: 0;
  transform: translateX(5%);
}

.guest_wrap {
  padding: 20px;
  display: flex;
  flex-flow: row wrap;
  gap: 20px;
  width: 100%;
  justify-content: center;
}

.guest_item {
  width: 155px;
}
.guest_item .photo {
  aspect-ratio: 1/1.2;
  position: relative;
  margin-bottom: 12px;
}
.guest_item .photo img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: relative;
}
.guest_item .photo .shadow {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 5px;
  top: 5px;
  background: linear-gradient(to right, #fffac2, #22e6e4);
}
.guest_item .photo .back {
  background: linear-gradient(to right, #22e6e4, #fffac2);
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
}
.guest_item .photo .back::before {
  content: "";
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  background-color: #fff;
  position: absolute;
  top: 1px;
  left: 1px;
}
.guest_item .name {
  background-color: #2e2624;
  color: #fff;
  padding: 0px 10px;
  margin-bottom: 6px;
  font-size: 1.6rem;
}
.guest_item .name::before, .guest_item .name::after {
  content: "";
  height: 100%;
  aspect-ratio: 0.3/1;
  clip-path: polygon(0 100%, 100% 0, 100% 100%);
  background: #2e2624;
  position: absolute;
  top: 0;
}
.guest_item .name::before {
  left: 0;
  transform: translateX(-90%);
}
.guest_item .name::after {
  right: 0;
  transform: translateX(90%) rotate(180deg);
}
.guest_item .shoulder {
  color: #1aa89e;
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-size: 1.2rem;
  line-height: 1.2;
}

.game_Swiper .swiper-slide {
  cursor: pointer;
}
.game_Swiper .swiper-slide.ph {
  padding: 0 !important;
}

.game_Swiper2 {
  margin-bottom: 5px;
  pointer-events: none;
}

.time_table .inner {
  width: 90%;
}/*# sourceMappingURL=style.css.map */