@charset "utf-8";

body {
  line-height: 1;
  font-family: "dnp-shuei-mincho-pr6n", "Noto Serif JP", sans-serif;
  font-weight: 500;
  font-style: normal;
  color: #231815;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

.wrapper {
  width: 100%;
  max-width: 1920px;
  margin: 0 auto;
}

/* メインビジュアル */
.main-visual {
  position: relative;
}

.logo {
  position: absolute;
  top: 13%;
  left: 50%;
  transform: translateX(-50%);
}

.logo-image {
  width: clamp(74px, 23.2vw, 180px);
}

.catch {
  font-size: clamp(15px, 4.8vw, 37px);
  line-height: 2;
  letter-spacing: clamp(6px, 1.87vw, 14px);
  text-align: center;
  position: absolute;
  top: 25%;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
}

.release1 {
  font-size: clamp(11px, 3.47vw, 27px);
  letter-spacing: clamp(4px, 1.3vw, 12px);
  border-top: 1px solid #595757;
  border-bottom: 1px solid #595757;
  text-align: center;
  position: absolute;
  top: 78%;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  padding: clamp(8.5px, 2.6vw, 20px) 0;
}

/* セクション1 */
.section1 {
  position: relative;
}

.lead1 {
  font-size: clamp(15px, 4.8vw, 37px);
  line-height: 2;
  color: #fff;
  text-align: center;
  position: absolute;
  top: 15%;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  letter-spacing: clamp(6px, 2.1vw, 14px);
}

/* セクション2 */
.section2 {
  position: relative;
}

.lead2 {
  font-size: clamp(10px, 3.2vw, 25px);
  text-align: center;
  line-height: 2.6;
  position: absolute;
  top: 10%;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
}

/* セクション3 */
.section3 {
  background-image: url(img/section3_sp.jpg);
  background-size: cover;
  aspect-ratio: 768/1745;
  width: 100%;
  padding-top: clamp(51px, 16vw, 123px);
  position: relative;
}

.image-grid-wrapper {
  position: relative;
  display: grid;
  grid-template-columns: 13vw 1fr 1fr;
  align-items: end;
  gap: 2.6vw;
  margin-bottom: clamp(51px, 16vw, 123px);
}

.grid-image1 {
  grid-row: 1/2;
  grid-column: 1/3;
}

.grid-image2 {
  grid-row: 1/3;
  grid-column: 3/4;
}

.grid-image3 {
  grid-row: 2/3;
  grid-column: 2/3;
}

.vertical1 {
  position: absolute;
  top: 0;
  right: 7%;
  writing-mode: vertical-rl;
  font-size: clamp(10px, 3.2vw, 25px);
  line-height: 2.3;
}

.image-wrapper {
  position: relative;
}

.image4 {
  display: block;
}

.vertical2 {
  position: absolute;
  top: 36%;
  left: 7%;
  writing-mode: vertical-rl;
  font-size: clamp(10px, 3.2vw, 25px);
  line-height: 2.3;
}

.release2 {
  font-size: clamp(11px, 3.47vw, 27px);
  letter-spacing: clamp(4px, 1.3vw, 12px);
  border-top: 1px solid #595757;
  border-bottom: 1px solid #595757;
  text-align: center;
  position: absolute;
  bottom: 8%;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  padding: clamp(8.5px, 2.6vw, 20px) 0;
}

/* フッター */
.footer {
  text-align: center;
  display: grid;
  justify-content: center;
  gap: clamp(36px, 11.2vw, 88px);
  padding: clamp(49px, 15.2vw, 120px) 0 clamp(29px, 9vw, 71px);
}

.page-top {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.triangle {
  width: 0;
  height: 0;
  border-right: clamp(4px, 1.3vw, 10px) solid transparent;
  border-left: clamp(4px, 1.3vw, 10px) solid transparent;
  border-bottom: clamp(5px, 1.6vw, 31px) solid #231815;
}

.page-top-button {
  width: 100%;
  font-size: clamp(12px, 4vw, 31px);
}

.shop-logo {
  width: clamp(181px, 56.5vw, 436px)
}

@media screen and (min-width:769px) {

  /* メインビジュアル */
  .main-visual {
    position: relative;
  }

  .logo {
    top: 15%;
  }

  .logo-image {
    width: clamp(102px, 13.4vw, 257px);
  }

  .catch {
    font-size: clamp(19px, 2.5vw, 48px);
    line-height: 1.75;
    letter-spacing: clamp(9px, 1.25vw, 24px);
    top: 37%;
  }

  .release1 {
    font-size: clamp(15px, 1.98vw, 38px);
    letter-spacing: clamp(4px, 1.3vw, 12px);
    top: 60%;
    padding: clamp(12px, 1.56vw, 30px) 0;
  }

  /* セクション1 */
  .lead1 {
    font-size: clamp(16px, 2.08vw, 40px);
    top: 15%;
    letter-spacing: clamp(8px, 1.14vw, 22px);
  }

  /* セクション2 */
  .lead2 {
    font-size: clamp(12px, 1.5vw, 30px);
    line-height: 2.2;
  }

  /* セクション3 */
  .section3 {
    background-image: url(img/section3_pc.jpg);
    aspect-ratio: 1920/3264;
    padding-top: calc(12vw + 1.56vw);
  }

  .image-grid-wrapper {
    grid-template-columns: 12vw 1fr 1fr;
    gap: 1.56vw;
    margin-right: calc(12vw + 1.56vw);
    margin-bottom: clamp(51px, 16vw, 123px);
  }

  .vertical1 {
    right: 8%;
    font-size: clamp(17px, 2.3vw, 44px);
    letter-spacing: clamp(1px, .26vw, 5px);
    line-height: 2.2;
  }

  .vertical2 {
    top: 45%;
    left: 13%;
    font-size: clamp(17px, 2.3vw, 44px);
    letter-spacing: clamp(1px, .26vw, 5px);
    line-height: 2.2;
  }

  .release2 {
    font-size: clamp(15px, 1.98vw, 38px);
    letter-spacing: clamp(4px, 1.3vw, 12px);
    padding: clamp(12px, 1.56vw, 30px) 0;
    bottom: 8%;
  }

  /* フッター */
  .footer {
    gap: clamp(26px, 3.6vw, 70px);
    padding: clamp(25px, 3.4vw, 67px) 0 clamp(40px, 5vw, 96px);
  }

  .triangle {
    border-right: clamp(6px, .41vw, 8px) solid transparent;
    border-left: clamp(6px, .41vw, 8px) solid transparent;
    border-bottom: clamp(7px, .52vw, 10px) solid #231815;
  }

  .page-top-button {
    font-size: clamp(11px, 1.45vw, 28px);
  }

  .shop-logo {
    width: clamp(137px, 17.8vw, 342px)
  }
}

/* アニメーション */
.blur {
  transition: all 0.5s;
  filter: blur(10px);
}

.blur.scrollin {
  filter: blur(0);
}

.fadein {
  opacity: 0;
  transform: translate(0, 0);
  transition: all 1.5s;
}

.fadein.fadein-left {
  transform: translate(-30px, 0);
}

.fadein.fadein-right {
  transform: translate(30px, 0);
}

.fadein.fadein-up {
  transform: translate(0, -30px);
}

.fadein.fadein-bottom {
  transform: translate(0, 30px);
}

.fadein.scrollin {
  opacity: 1 !important;
  transform: translate(0, 0) !important;
}

/* ローディング画面 */
.lock {
  overflow-y: hidden;
}

.loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 99999;
  background: #fff;
  text-align: center;
}

.loading-box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.loading-image {
  max-width: 100%;
  height: auto;
}

.fade-out {
  animation-name: fadeOutAnime;
  animation-duration: 1.5s;
  animation-delay: 1.5s;
  animation-fill-mode: forwards;
  opacity: 1;
}

/* フェードアウトアニメーション */
@keyframes fadeOutAnime {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}