@charset "UTF-8";
/*********************************/
/*           共通パーツ           */
/*********************************/
/* ユーティリティクラス */
@media screen and (min-width: 1025px) {
  .u-hide-pc {
    display: none !important;
  }
}

.u-hide-sp {
  display: none !important;
}
@media screen and (min-width: 1025px) {
  .u-hide-sp {
    display: block !important;
  }
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: "Outfit", "Noto Sans JP", sans-serif;
  color: #fff;
  background-color: #000000;
  overflow-x: hidden;
}

body.is-fixed {
  overflow: hidden;
}

@media screen and (min-width: 1025px) {
  a[href^="tel:"] a[href^="tel:"] {
    pointer-events: none;
    text-decoration: none;
    cursor: default;
  }
}

/* INNER */
.inner {
  max-width: 218.6666666667vw;
  width: 100%;
  padding-left: 5.3333333333vw;
  padding-right: 5.3333333333vw;
  margin-inline: auto;
}
@media screen and (min-width: 1025px) {
  .inner {
    max-width: 1640px;
    padding-left: 40px;
    padding-right: 40px;
  }
}

/* SECTION-TITLE */
.section-title {
  text-align: center;
}

.section-title__en {
  font-weight: 900;
  font-size: 13.3333333333vw;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 1025px) {
  .section-title__en {
    font-size: 100px;
  }
}

.section-title__ja {
  font-weight: 700;
  font-size: 4.2666666667vw;
  margin-top: 2.6666666667vw;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 1025px) {
  .section-title__ja {
    font-size: 24px;
    margin-top: 20px;
  }
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 13.3333333333vw;
  z-index: 1000;
  padding-inline: 2.6666666667vw;
  padding-left: 5.3333333333vw;
  padding-right: 5.3333333333vw;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background-color: rgba(9, 9, 9, 0.2);
}
@media screen and (min-width: 1025px) {
  .header {
    height: 100px;
    padding-left: 30px;
    padding-right: clamp(1.875rem, -7.43rem + 14.53vw, 10rem);
  }
}

.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: inherit;
}

.header.is-open {
  background-color: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.header__list {
  position: relative;
  z-index: 1;
}

.header__logo {
  position: relative;
  max-width: 13.3333333333vw;
  width: 100%;
  z-index: 5000;
}
.header__logo a {
  transition: 0.3s;
}
.header__logo a:hover {
  opacity: 0.5;
}
@media screen and (min-width: 1025px) {
  .header__logo {
    max-width: 125px;
    width: 100%;
  }
}

.header__nav {
  overflow: auto;
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  width: 100%;
  transform: translateY(-100%);
  transition: transform 0.4s ease;
  z-index: 1000;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-left: 21vw;
  padding-right: 21vw;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background-color: rgba(0, 0, 0, 0.7);
}
@media screen and (min-width: 1025px) {
  .header__nav {
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    top: 0;
    right: 0%;
    transition: none;
    transform: translateY(0%);
    height: auto;
    width: auto;
    background-color: transparent;
    padding-left: 0;
    padding-right: 0;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
}

.header__nav.is-open {
  transform: translateY(0%);
  background-color: rgba(0, 0, 0, 0.3);
  overflow: auto;
}
@media screen and (min-width: 1025px) {
  .header__nav.is-open {
    background-color: none;
  }
}

@media screen and (min-width: 1025px) {
  .header__list {
    display: flex;
    align-items: center;
    gap: 30px;
  }
}

.header__item {
  margin-top: 5.3333333333vw;
  text-align: center;
}
@media screen and (min-width: 1025px) {
  .header__item {
    margin-top: 0;
  }
}

.header__item:first-child {
  margin-top: 0;
}

.header__link {
  font-size: clamp(1.5rem, 0.922rem + 2.47vw, 2.5rem);
  letter-spacing: 0.05em;
  position: relative;
  font-weight: 900;
  transition: 0.3s;
}
@media screen and (min-width: 1025px) {
  .header__link {
    font-size: 18px;
  }
}
.header__link:hover {
  text-shadow: 0px 2px 4px rgba(255, 255, 255, 0.6), 0px -2px 4px rgba(255, 255, 255, 0.6);
}

/* ハンバーガーアイコン */
.header__hamburger {
  width: 5.3333333333vw;
  height: 4vw;
  position: absolute;
  top: 4.6666666667vw;
  right: 4vw;
  cursor: pointer;
  z-index: 1001;
}
.header__hamburger span {
  position: absolute;
  left: 0;
  width: 5.3333333333vw;
  height: 0.5333333333vw;
  transition: 0.3s;
  background-color: #fff;
}
.header__hamburger span:nth-child(1) {
  top: 0;
}
.header__hamburger span:nth-child(2) {
  top: 1.7333333333vw;
}
.header__hamburger span:nth-child(3) {
  bottom: 0vw;
}
.header__hamburger.is-open span:nth-child(1) {
  transform: translate(-50%, -50%) rotate(45deg);
  top: 50%;
  left: 50%;
}
.header__hamburger.is-open span:nth-child(2) {
  opacity: 0;
}
.header__hamburger.is-open span:nth-child(3) {
  transform: translate(-50%, -50%) rotate(-45deg);
  bottom: auto;
  top: 50%;
  left: 50%;
}

.footer {
  background-color: #fff;
}

.footer__inner {
  padding-top: 10.6666666667vw;
  padding-bottom: 14.6666666667vw;
}
@media screen and (min-width: 1025px) {
  .footer__inner {
    padding-top: 80px;
    padding-bottom: 110px;
  }
}

.footer__logo {
  max-width: 40vw;
  width: 100%;
  margin-inline: auto;
}
@media screen and (min-width: 1025px) {
  .footer__logo {
    max-width: 300px;
  }
}

.footer__copyright {
  margin-top: 10.6666666667vw;
}
@media screen and (min-width: 1025px) {
  .footer__copyright {
    font-size: 16px;
    margin-top: 80px;
  }
}
.footer__copyright p {
  font-weight: 700;
  text-align: center;
  font-size: 3.7333333333vw;
  color: #000000;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 1025px) {
  .footer__copyright p {
    font-size: 16px;
  }
}

.fixedText {
  position: fixed;
  bottom: 0;
  background-color: #000000;
  overflow: hidden;
  white-space: nowrap;
  display: flex;
  flex-direction: column;
  z-index: 1000;
}
.fixedText p {
  display: flex;
  align-items: center;
  gap: 2.6666666667vw;
  font-size: 3.7333333333vw;
  letter-spacing: 0.1em;
  font-weight: 900;
  white-space: nowrap;
}
@media screen and (min-width: 1025px) {
  .fixedText p {
    gap: 20px;
    font-size: 18px;
  }
}
.fixedText p img {
  max-width: 4vw;
  width: 100%;
}
@media screen and (min-width: 1025px) {
  .fixedText p img {
    max-width: 30px;
  }
}

.fixedText__inner {
  display: flex;
  width: max-content;
  animation: scrollText 40s linear infinite;
}

@keyframes scrollText {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
/****************************************************
 *  glitch effect
 ****************************************************/
.u-glitch {
  position: relative;
  color: #fff;
}

.u-glitch::before,
.u-glitch::after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.u-glitch::before {
  left: 2px;
  text-shadow: -2px 0 rgb(21, 255, 40);
  clip: rect(44px, 450px, 56px, 0);
  animation: glitch-anim 5s infinite linear alternate-reverse;
}

.u-glitch::after {
  left: -2px;
  text-shadow: -2px 0 #ff00c1, 2px 2px #ff00c1;
  clip: rect(44px, 450px, 56px, 0);
  animation: glitch-anim2 5s infinite linear alternate-reverse;
}

@keyframes glitch-anim {
  0% {
    clip: rect(78px, 9999px, 45px, 0);
    transform: skew(0.74deg);
  }
  5% {
    clip: rect(20px, 9999px, 69px, 0);
    transform: skew(0.03deg);
  }
  10% {
    clip: rect(69px, 9999px, 75px, 0);
    transform: skew(0.33deg);
  }
  15% {
    clip: rect(53px, 9999px, 85px, 0);
    transform: skew(0.9deg);
  }
  20% {
    clip: rect(50px, 9999px, 94px, 0);
    transform: skew(0.27deg);
  }
  25% {
    clip: rect(23px, 9999px, 17px, 0);
    transform: skew(0.64deg);
  }
  30% {
    clip: rect(66px, 9999px, 18px, 0);
    transform: skew(0.71deg);
  }
  35% {
    clip: rect(6px, 9999px, 65px, 0);
    transform: skew(0.72deg);
  }
  40% {
    clip: rect(75px, 9999px, 85px, 0);
    transform: skew(0.63deg);
  }
  45% {
    clip: rect(6px, 9999px, 88px, 0);
    transform: skew(0.06deg);
  }
  50% {
    clip: rect(36px, 9999px, 63px, 0);
    transform: skew(0.22deg);
  }
  55% {
    clip: rect(90px, 9999px, 31px, 0);
    transform: skew(0.76deg);
  }
  60% {
    clip: rect(97px, 9999px, 73px, 0);
    transform: skew(0.83deg);
  }
  65% {
    clip: rect(18px, 9999px, 88px, 0);
    transform: skew(0.11deg);
  }
  70% {
    clip: rect(29px, 9999px, 68px, 0);
    transform: skew(0.76deg);
  }
  75% {
    clip: rect(91px, 9999px, 70px, 0);
    transform: skew(0.56deg);
  }
  80% {
    clip: rect(6px, 9999px, 75px, 0);
    transform: skew(0.26deg);
  }
  85% {
    clip: rect(43px, 9999px, 37px, 0);
    transform: skew(0.25deg);
  }
  90% {
    clip: rect(69px, 9999px, 7px, 0);
    transform: skew(0.2deg);
  }
  95% {
    clip: rect(36px, 9999px, 74px, 0);
    transform: skew(0.93deg);
  }
}
@keyframes glitch-anim2 {
  0% {
    clip: rect(8px, 9999px, 79px, 0);
    transform: skew(0.74deg);
  }
  5% {
    clip: rect(38px, 9999px, 62px, 0);
    transform: skew(0.07deg);
  }
  10% {
    clip: rect(97px, 9999px, 69px, 0);
    transform: skew(0.78deg);
  }
  15% {
    clip: rect(65px, 9999px, 52px, 0);
    transform: skew(0.86deg);
  }
  20% {
    clip: rect(20px, 9999px, 89px, 0);
    transform: skew(0.53deg);
  }
  25% {
    clip: rect(3px, 9999px, 41px, 0);
    transform: skew(0.09deg);
  }
  30% {
    clip: rect(49px, 9999px, 45px, 0);
    transform: skew(0.13deg);
  }
  35% {
    clip: rect(24px, 9999px, 39px, 0);
    transform: skew(0.03deg);
  }
  40% {
    clip: rect(13px, 9999px, 22px, 0);
    transform: skew(0.84deg);
  }
  45% {
    clip: rect(47px, 9999px, 32px, 0);
    transform: skew(0.02deg);
  }
  50% {
    clip: rect(88px, 9999px, 62px, 0);
    transform: skew(0.86deg);
  }
  55% {
    clip: rect(52px, 9999px, 60px, 0);
    transform: skew(0.62deg);
  }
  60% {
    clip: rect(53px, 9999px, 66px, 0);
    transform: skew(0.67deg);
  }
  65% {
    clip: rect(59px, 9999px, 52px, 0);
    transform: skew(0.09deg);
  }
  70% {
    clip: rect(17px, 9999px, 90px, 0);
    transform: skew(0.18deg);
  }
  75% {
    clip: rect(53px, 9999px, 24px, 0);
    transform: skew(0.56deg);
  }
  80% {
    clip: rect(47px, 9999px, 24px, 0);
    transform: skew(0.29deg);
  }
  85% {
    clip: rect(42px, 9999px, 42px, 0);
    transform: skew(0.63deg);
  }
  90% {
    clip: rect(28px, 9999px, 11px, 0);
    transform: skew(1deg);
  }
  95% {
    clip: rect(48px, 9999px, 5px, 0);
    transform: skew(0.79deg);
  }
}
@keyframes glitch-skew {
  0% {
    transform: skew(1deg);
  }
  10% {
    transform: skew(2deg);
  }
  20% {
    transform: skew(5deg);
  }
  30% {
    transform: skew(4deg);
  }
  40% {
    transform: skew(3deg);
  }
  50% {
    transform: skew(4deg);
  }
  60% {
    transform: skew(2deg);
  }
  70% {
    transform: skew(-2deg);
  }
  80% {
    transform: skew(-3deg);
  }
  90% {
    transform: skew(-2deg);
  }
}/*# sourceMappingURL=common.css.map */