/* ==========================================================================
   Front Page Styles
   ========================================================================== */

/* --- Hero --- */
.hero {
  position: relative;
  width: 100%;
  aspect-ratio: 1300 / 776.69;
  overflow: hidden;

  .hero-logo {
    position: relative;
    width: calc(1170vw / var(--p) + var(--pc-gutter) * 2);
    padding: 0 var(--pc-gutter);
    margin-inline: auto;

    opacity: 0;
    transition: opacity 0.7s ease, transform 0.7s ease;
    transform: translateY(-20px);
    transition-delay: 1.5s;

    img {
      width: 100%;
    }
  }

  .-scroll {
    position: absolute;
    bottom: calc(26vw / var(--p));
    right: calc(23vw / var(--p));
    font-family: var(--font-en);
    font-size: calc(20vw / var(--p));
    font-weight: bold;
    text-transform: uppercase;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: calc(9.3vw / var(--p));

    opacity: 0;
    transition: opacity 0.7s ease, transform 0.7s ease;
    transform: translateY(20px);
    transition-delay: 1.75s;
  }

  .-scroll::after {
    content: '';
    display: block;
    width: calc(15.73vw / var(--p));
    height: calc(16.72vw / var(--p));
    background: url('../img/top/arrow-down.svg') center center / contain no-repeat;
  }

  .hero-main {
    top: calc(100vw / var(--p));
    position: absolute;
    height: 100%;
    width: 100%;
    overflow: hidden;

    .-cover {
      z-index: 20;
      position: absolute;
      display: flex;
      align-items: center;
      justify-content: center;
      pointer-events: none;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: #fff;
      --progress: 0;
      mask: radial-gradient(circle at 50% 50%, transparent calc(var(--progress) * 100%), #fff calc(var(--progress) * 200%));
      transition: opacity 0.5s ease;
    }

    .-light,
    .-bottle,
    .-back,
    .-scroll {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      transition: opacity 1s ease, transform 1s ease;
      opacity: 0;

      img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
      }
    }

    .-back {
      opacity: 1;
    }

    .-light {
      mix-blend-mode: screen;
      transform: translateY(-20px);
      transition-delay: 1s;
    }

    .-bottle {
      transform: translateY(20px);
      transition-delay: 0.5s;
    }
  }

  &.show {
    &::before {
      opacity: 1;
      transform: translateY(0);
    }

    .hero-logo {
      opacity: 1;
      transform: translateY(0);
    }

    .-light,
    .-bottle {
      opacity: 1;
      transform: translateY(0);
    }

    /* .-back {
      opacity: 1;
      animation: blurExpansion 2.5s ease-in-out 0.3s forwards;
    } */

    .-scroll {
      opacity: 1;
      transform: translateY(0);
      animation: floatVertical 3s ease-in-out infinite;
    }
  }
}

/* 
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('../img/top/hero.jpg') center center / cover no-repeat;
  top: 100px;
  opacity: 0;
  transform: translateY(20px);
  transition-duration: .7s;
  transition-property: opacity, transform;
}

.hero img {
  position: relative;
  max-width: calc(1170vw / var(--p));
  width: 100%;
  padding: 0 var(--pc-gutter);
  transition-delay: 0.3s;
} */

/* --- Concept --- */
.concept {
  padding: 100px 0 0;
}

.concept-inner {
  max-width: 100%;
  width: calc(1170px + 24px * 2);
  margin: 0 auto;
  padding: 0 var(--pc-gutter);
}

.concept-header {
  margin-bottom: 35px;
}

.concept-title {
  font-family: var(--font-en);
  font-size: 40px;
  font-weight: bold;
  text-transform: uppercase;
  color: #000;
}

.concept-catch {
  margin-bottom: 146px;
}

.concept-catch img {
  max-width: 1170px;
  max-width: 100%;
}

.concept-content {
  display: flex;
  align-items: flex-start;
  gap: 168px;
  padding: 0 135px;
}

.concept-ttl {
  flex-shrink: 0;
}

.concept-ttl img {
  width: 312.84px;
}

.concept-content .-text {
  font-family: var(--font-jp);
  font-size: 23px;
  line-height: 2.2;
  color: #000;
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding-top: 58px;
  width: 581px;
  white-space: nowrap;
  font-weight: 600;
  letter-spacing: 0.1em;

  sup {
    font-size: 10px;
  }
}

/* --- Movie --- */
.movie {
  margin-top: 100px;
}

.movie-inner {
  width: calc(977px + 24px * 2);
  max-width: 100%;
  margin: 0 auto;
  padding: 0 var(--pc-gutter);

  video {
    width: 100%;
    aspect-ratio: 977 / 550;
  }
}

/* --- Slider --- */
.slider {
  padding: 200px 0 80px;
  background-color: #fff;
}

.slider-inner {
  position: relative;
  margin: 0 auto;
  /* padding: 0 calc(40vw / var(--p)); */
  overflow: hidden;
}

.slider-number {
  position: absolute;
  top: -10px;
  left: 0;
  right: 0;
  margin: auto;
  width: 113px;
  height: 122.86px;
  z-index: 2;
  transition-delay: 0.3s;
  transform: translate(calc(1170px / 2 - 113px), 0);

  &::after {
    content: "";
    display: block;
    width: 64px;
    height: 89px;
    background: url('../img/top/slider/slash.svg') center center / contain no-repeat;
    position: absolute;
    top: 33px;
    left: 41px;
  }
}

.slider-number .current {
  font-size: 65px;
  line-height: 1.2;
  font-family: var(--font-en);
  font-weight: bold;
  position: absolute;
  top: 0;
  left: 0;
}

.slider-number .total {
  font-size: 39px;
  line-height: 1;
  font-family: var(--font-en);
  position: absolute;
  bottom: 0;
  right: 0;
}

.slider-number .next {
  width: 14.46px;
  height: 28.92px;
  background: url('../img/top/slider/arrow.svg') center center / contain no-repeat;
  position: absolute;
  top: 0;
  bottom: 0;
  right: -24.46px;
  margin: auto 0;
  cursor: pointer;
}

.slider-number .prev {
  width: 14.46px;
  height: 28.92px;
  background: url('../img/top/slider/arrow.svg') center center / contain no-repeat;
  position: absolute;
  top: 0;
  bottom: 0;
  left: -24.46px;
  margin: auto 0;
  transform: rotate(180deg);
  cursor: pointer;
}

.slider-swiper .swiper-item {
  position: relative;
  transition: transform 0.4s ease;
  transform: scale(0.6);
  width: 100%;
  max-width: 870px;
  padding-top: 44px;
  padding-bottom: 108.9px;
}

.slider-swiper .swiper-item.swiper-slide-active {
  transform: scale(1);
}

.slider-title {
  max-height: 82.37px;
  height: 100%;
  position: absolute;
  top: 0;
  left: -110px;
  display: flex;
  flex-direction: column;
  opacity: 0;
  transition: opacity 0.5s ease;
  z-index: 1;

  pointer-events: none;
}

.slider-swiper .swiper-item.swiper-slide-active .slider-title {
  opacity: 1;
}

.slider-title img {
  height: 100%;
}

.slider-image {
  width: 870px;
  max-width: 100%;
  display: block;
}

.slider-image img {
  width: 100%;
  height: auto;
  display: block;
}

.slider-text {
  display: flex;
  position: absolute;
  left: -110px;
  bottom: 0;
  flex-direction: column;
  gap: 30.4px;
  opacity: 0;
  transition: opacity 0.5s ease;
  pointer-events: none;
}

.slider-swiper .swiper-item.swiper-slide-active .slider-text {
  opacity: 1;
}

.slider-text img {
  width: calc(var(--pc-width) * 1px);
  height: auto;
}

.slider-text a:hover {
  opacity: 0.6;
}

.slider-memo {
  display: flex;
  position: absolute;
  bottom: 0;
  left: auto;
  right: 0;
  margin: auto;
  opacity: 0;
  transition: opacity 0.5s ease;
  max-width: 589px;

  small {
    font-size: 10px;
    line-height: 1.5;
    color: #B7B7B7;
  }
}

.slider-swiper .swiper-item.swiper-slide-active .slider-memo {
  opacity: 1;
}

/* text-01: blur 12.5px / text-02: 22.5px / text-03: 17.5px / text-04: 22.5px opacity:0.435 */
.slider-swiper .swiper-wrapper .swiper-item:nth-child(4n+1) .slider-text img {
  filter: drop-shadow(0 0 12.5px #fff);
}

.slider-swiper .swiper-wrapper .swiper-item:nth-child(4n+2) .slider-text img {
  filter: drop-shadow(0 0 22.5px #fff);
}

.slider-swiper .swiper-wrapper .swiper-item:nth-child(4n+3) .slider-text img {
  filter: drop-shadow(0 0 17.5px #fff);
}

.slider-swiper .swiper-wrapper .swiper-item:nth-child(4n) .slider-text img {
  filter: drop-shadow(0 0 22.5px #fff);
}


/* --- Products Line Up --- */
.product-lineup {
  padding: 80px 0 152px;
  background-color: #fff;
}

.product-inner {
  max-width: calc(1170px + var(--pc-gutter) * 2);
  margin: 0 auto;
  padding: 0 var(--pc-gutter);
}

.product-lineup-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 40px;
}

.product-lineup-title {
  font-family: var(--font-en);
  font-size: 40px;
  font-weight: 700;
  text-transform: uppercase;
  color: #000;
}

.product-lineup-header .product-lineup-link {}

.product-lineup-header .product-lineup-link:hover {
  opacity: 0.6;
}


.product-lineup-headline {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  max-width: calc(1080px + var(--pc-gutter) * 2);
  margin: 0 auto;
  padding: 0 var(--pc-gutter);
}

.product-lineup-headline+.product-lineup-list {
  margin-top: 76px;
}

.product-lineup-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 76px 24px;
  max-width: calc(1080px + var(--pc-gutter) * 2);
  margin: 0 auto;
  padding: 0 var(--pc-gutter);
}

.product-lineup-item {
  display: flex;
  flex-direction: column;
  gap: 30px;
  position: relative;
}

.product-lineup-image {
  position: relative;
  display: block;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  background-color: #f5f5f5;
}

.product-lineup-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.product-lineup-item:hover .product-lineup-image img {
  transform: scale(1.04);
}

.product-lineup-image .product-lineup-link {
  position: absolute;
  bottom: 18.2px;
  right: 18.7px;
  font-size: 15px;
}


.product-lineup-name {
  font-family: var(--font-en);
  font-size: 55px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: #000;
  position: absolute;
  top: -19px;
  left: -23px;
  writing-mode: vertical-rl;
}

.product-lineup-list .product-lineup-item .product-lineup-name {
  font-size: 30px;
  top: -7px;
  left: -14px;
}

.product-lineup-description {
  font-family: var(--font-jp);
  font-size: 15px;
  line-height: 23px;
}

/* --- Belt --- */
.belt {
  overflow: hidden;
}

.belt-track {
  display: flex;
  width: max-content;
  animation: belt-marquee 15s linear infinite;
  will-change: transform;
}

@keyframes belt-marquee {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

.belt-track img {
  height: 156.13px;
  width: auto;
  display: block;
  flex-shrink: 0;
  margin-right: 57.4px;
}

/* --- News --- */
.news {
  margin-top: 160px;
  width: 100vw;
  overflow: hidden;
}

.news-inner {
  max-width: calc(calc(1170vw / var(--p)) + var(--pc-gutter) * 2);
  margin: 0 auto;
  padding: 0 var(--pc-gutter) calc(70vw / var(--p)) calc(70vw / var(--p));
  position: relative;

  &::before {
    content: "";
    background-color: black;
    position: absolute;
    bottom: 0;
    left: calc((100% - calc(1170vw / var(--p))) / 2);
    right: calc(-9999vw / var(--p));
    height: calc(100% - 156px);
  }
}

.news-body {
  padding-left: calc(60vw / var(--p));
}

.news-swiper {
  overflow: visible;
}

.news-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: calc(40vw / var(--p));
}

.news-header h2 {
  font-family: var(--font-en);
  font-size: calc(40vw / var(--p));
  font-weight: 700;
  text-transform: uppercase;
}

.news-header a {
  padding-bottom: calc(2vw / var(--p));
}

.news-header a:hover {
  opacity: 0.6;
}

.news-swiper .swiper-item {
  display: flex;
  flex-direction: column;
  cursor: pointer;
  flex-shrink: 0;
  width: calc(50% - calc(44vw / var(--p)));
}

.news-thumbnail {
  aspect-ratio: 432 / 267;
  overflow: hidden;
  background-color: #333;

  img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}

.news-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.news-placeholder {
  width: 100%;
  height: 100%;
  background-color: #ccc;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.news-placeholder::before {
  content: "";
  position: absolute;
  width: calc(40vw / var(--p));
  height: calc(40vw / var(--p));
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='18' height='18' rx='2' ry='2'/%3E%3Ccircle cx='8.5' cy='8.5' r='1.5'/%3E%3Cpolyline points='21,15 16,10 5,21'/%3E%3C/svg%3E");
  background-size: contain;
  opacity: 0.4;
}

.news-body .swiper-item:hover .news-thumbnail img {
  transform: scale(1.04);
}

.news-info {
  display: flex;
  justify-content: space-between;
  margin-top: calc(21.7vw / var(--p));
  gap: calc(10vw / var(--p));
}

.news-title {
  font-family: var(--font-jp);
  font-size: calc(15vw / var(--p));
  line-height: calc(22.5vw / var(--p));
  color: #fff;
}

.news-date {
  font-family: var(--font-en);
  font-size: calc(15vw / var(--p));
  color: #fff;
}

@media screen and (max-width: 1170px) {
  .hero::before {
    top: calc(100vw / var(--p));
  }

  .concept {
    padding: calc(100vw / var(--p)) 0 0;
  }

  .concept-inner {
    width: calc((1170vw + 24vw * 2) / var(--p));
  }

  .concept-header {
    margin-bottom: calc(35vw / var(--p));
  }

  .concept-title {
    font-size: calc(40vw / var(--p));
  }

  .concept-catch {
    margin-bottom: calc(146vw / var(--p));
  }

  .concept-content {
    gap: calc(168vw / var(--p));
    padding: 0 calc(135vw / var(--p));

    .-text {
      font-size: calc(23vw / var(--p));
      gap: calc(24vw / var(--p));
      padding-top: calc(58vw / var(--p));
      width: calc(581vw / var(--p));

      sup {
        font-size: calc(10vw / var(--p));
      }
    }
  }

  .concept-ttl img {
    width: calc(312.84vw / var(--p));
  }

  .concept-text {
    font-size: calc(23vw / var(--p));
    gap: calc(24vw / var(--p));
    padding-top: calc(58vw / var(--p));
    width: calc(581vw / var(--p));

    sup {
      font-size: calc(10vw / var(--p));
    }
  }

  .movie {
    margin-top: calc(100vw / var(--p));
  }

  .movie-inner {
    width: calc((977vw + 24vw * 2) / var(--p));
  }

  .slider {
    padding: calc(200vw / var(--p)) 0 calc(80vw / var(--p));
  }

  .slider-number {
    width: calc(113vw / var(--p));
    height: calc(122.86vw / var(--p));
    transform: translate(calc(1170vw / var(--p) / 2 - 113vw / var(--p)), 0);

    &::after {
      width: calc(64vw / var(--p));
      height: calc(89vw / var(--p));
      top: calc(33vw / var(--p));
      left: calc(41vw / var(--p));
    }
  }

  .slider-number .current {
    font-size: calc(65vw / var(--p));
  }

  .slider-number .total {
    font-size: calc(39vw / var(--p));
  }

  .slider-number .next {
    width: calc(14.46vw / var(--p));
    height: calc(28.92vw / var(--p));
    right: calc(-24.46vw / var(--p));
  }

  .slider-number .prev {
    width: calc(14.46vw / var(--p));
    height: calc(28.92vw / var(--p));
    left: calc(-24.46vw / var(--p));
  }

  .slider-swiper .swiper-item {
    padding-top: calc(24vw / var(--p));
    padding-bottom: calc(170vw / var(--p));
    margin-inline: calc(-15vw / var(--p));
    max-width: calc(870vw / var(--p));
  }

  .slider-title {
    max-height: calc(82.37vw / var(--p));
    left: calc(-110vw / var(--p));
  }

  .slider-image {
    width: calc(870vw / var(--p));
  }

  .slider-text {
    left: calc(-110vw / var(--p));
    gap: calc(30.4vw / var(--p));
  }

  .slider-text img {
    width: calc(var(--pc-width) * 1vw / var(--p));
  }

  .slider-memo {
    max-width: calc(589vw / var(--p));

    small {
      font-size: calc(10vw / var(--p));
    }
  }

  .slider-swiper .swiper-wrapper .swiper-item:nth-child(4n+1) .slider-text img {
    filter: drop-shadow(0 0 calc(12.5vw / var(--p)) #fff);
  }

  .slider-swiper .swiper-wrapper .swiper-item:nth-child(4n+2) .slider-text img {
    filter: drop-shadow(0 0 calc(22.5vw / var(--p)) #fff);
  }

  .slider-swiper .swiper-wrapper .swiper-item:nth-child(4n+3) .slider-text img {
    filter: drop-shadow(0 0 calc(17.5vw / var(--p)) #fff);
  }

  .slider-swiper .swiper-wrapper .swiper-item:nth-child(4n) .slider-text img {
    filter: drop-shadow(0 0 calc(22.5vw / var(--p)) #fff);
  }

  .belt-track img {
    height: calc(156.13vw / var(--p));
    margin-right: calc(57.4vw / var(--p));
  }

  .news {
    margin-top: calc(160vw / var(--p));
  }

  .news-inner::before {
    height: calc(100% - calc(156vw / var(--p)));
  }

  .product-lineup {
    padding: calc(80vw / var(--p)) 0 calc(152vw / var(--p));
  }

  .product-lineup-header {
    margin-bottom: calc(40vw / var(--p));
  }

  .product-lineup-title {
    font-size: calc(40vw / var(--p));
  }

  .product-lineup-headline {
    gap: calc(40vw / var(--p));
  }

  .product-lineup-headline+.product-lineup-list {
    margin-top: calc(76vw / var(--p));
  }

  .product-lineup-list {
    gap: calc(76vw / var(--p)) calc(24vw / var(--p));
  }

  .product-lineup-item {
    gap: calc(30vw / var(--p));
  }

  .product-lineup-image .product-lineup-link {
    bottom: calc(18.2vw / var(--p));
    right: calc(18.7vw / var(--p));
    font-size: calc(15vw / var(--p));
  }

  .product-lineup-name {
    font-size: calc(55vw / var(--p));
    top: calc(-19vw / var(--p));
    left: calc(-23vw / var(--p));
  }

  .product-lineup-list .product-lineup-item .product-lineup-name {
    font-size: calc(30vw / var(--p));
    top: calc(-7vw / var(--p));
    left: calc(-14vw / var(--p));
  }

  .product-lineup-description {
    font-size: calc(15vw / var(--p));
    line-height: calc(23vw / var(--p));
  }
}

@media screen and (max-width: 768px) {
  .hero {
    aspect-ratio: 4 / 6;

    .hero-logo {
      width: calc(256.8vw / var(--s));
    }
  }

  .hero::before {
    top: calc(62vw / var(--s));
    background-image: url('../img/top/hero-sp.jpg');
  }

  .hero img {
    width: calc(256.8vw / var(--s));
    max-width: none;
  }

  .hero .-scroll {
    bottom: calc(9.7vw / var(--s));
    right: calc(15vw / var(--s));
    font-size: calc(18vw / var(--s));
    gap: calc(8.3vw / var(--s));
  }

  .hero .-scroll::after {
    width: calc(15.73vw / var(--s));
    height: calc(16.72vw / var(--s));
  }

  .movie {
    margin-top: calc(55vw / var(--s));
  }

  .movie-inner {
    width: 100%;
    padding: 0 var(--sp-gutter);
  }

  .slider {
    padding: calc(100vw / var(--s)) 0 calc(80vw / var(--s));
  }

  .slider-inner {
    overflow: hidden;
    padding-top: calc(29.4vw / 2 / var(--s));
  }

  .slider-number {
    top: 0;
    width: calc(43.57vw / var(--s));
    height: calc(51.87vw / var(--s));
    transform: translate(calc(400vw / var(--s) / 2 - 43.57vw / var(--s)), 0);

    &::after {
      width: calc(24.93vw / var(--s));
      height: calc(34.67vw / var(--s));
      top: calc(13.6vw / var(--s));
      left: calc(15.9vw / var(--s));
    }
  }

  .slider-number .current {
    font-size: calc(24vw / var(--s));
  }

  .slider-number .total {
    font-size: calc(15vw / var(--s));
  }

  .slider-number .next {
    width: calc(5.63vw / var(--s));
    height: calc(11.27vw / var(--s));
    right: calc(-8.4vw / var(--s));
  }

  .slider-number .prev {
    width: calc(5.63vw / var(--s));
    height: calc(11.27vw / var(--s));
    left: calc(-8.4vw / var(--s));
  }

  .slider-swiper .swiper-item {
    position: relative;
    transition: transform 0.4s ease;
    transform: scale(0.7) translate(0, calc(-30vw / var(--s)));
    width: calc(329vw / var(--s));
    max-width: none;
    padding-top: calc(24vw / var(--s));
    padding-bottom: calc(170vw / var(--s));
    margin-inline: calc(-15vw / var(--s));
  }

  .slider-title {
    max-height: calc(32.95vw / var(--s));
    left: calc(-19.4vw / var(--s));
  }

  .slider-image {
    width: calc(329vw / var(--s));
  }

  .slider-text {
    left: 0;
    gap: calc(80.4vw / var(--s));
  }

  .slider-text img {
    width: calc(var(--sp-width) / var(--s));
  }

  .slider-memo {
    max-width: calc(329vw / var(--s));
    top: calc(320vw / var(--s));
    bottom: auto;

    small {
      font-size: calc(10vw / var(--s));
    }
  }

  .product-lineup {
    padding: 0 0 calc(70vw / var(--s));
  }

  .product-inner {
    padding: 0 calc(15vw / var(--s));
  }

  .product-lineup-header {
    margin-bottom: calc(46.5vw / var(--s));
  }

  .product-lineup-title {
    font-size: calc(20vw / var(--s));
  }

  .product-lineup-header .product-lineup-link {
    font-size: calc(16vw / var(--s));
    gap: calc(18.1vw / var(--s));

    &::after {
      width: calc(12.47vw / var(--s));
      height: calc(9.54vw / var(--s));
    }
  }

  .product-lineup-headline {
    display: flex;
    flex-direction: column;
    gap: calc(70vw / var(--s));
    padding: 0 calc(20vw / var(--s));
  }

  .product-lineup-headline+.product-lineup-list {
    margin-top: calc(70vw / var(--s));
  }


  .product-lineup-item {
    gap: calc(23vw / var(--s));

    &:nth-child(1) {
      order: 1;
    }

    &:nth-child(2) {
      order: 2;
    }

    &:nth-child(3) {
      order: 4;
    }

    &:nth-child(4) {
      order: 3;
    }

    &:nth-child(5) {
      order: 5;
    }

    &:nth-child(6) {
      order: 6;
    }
  }


  .product-lineup-name {
    font-size: calc(32vw / var(--s));
    top: calc(-20vw / var(--s));
    left: calc(-11vw / var(--s));
  }

  .product-lineup-description {
    font-size: calc(13vw / var(--s));
    line-height: calc(18vw / var(--s));
    letter-spacing: 0.01em;
  }

  .product-lineup-image .product-lineup-link {
    font-size: calc(16vw / var(--s));
    gap: calc(18.1vw / var(--s));

    &::after {
      width: calc(12.47vw / var(--s));
      height: calc(9.54vw / var(--s));
    }
  }

  .product-lineup-list {
    display: flex;
    flex-wrap: wrap;
    gap: calc(35.1vw / var(--s)) calc(20vw / var(--s));
    padding: 0 calc(20vw / var(--s));

    .product-lineup-item {
      width: calc(50% - calc(20vw / var(--s) / 2));
      gap: calc(17.3vw / var(--s));

      .product-lineup-name {
        font-size: calc(15vw / var(--s));
        top: calc(-9.7vw / var(--s));
        left: calc(-6.7vw / var(--s));
      }

      .product-lineup-image .product-lineup-link {
        font-size: calc(14vw / var(--s));
        gap: calc(5.3vw / var(--s));
        bottom: calc(5.6vw / var(--s));
        right: calc(3.8vw / var(--s));

        &::after {
          width: calc(8.89vw / var(--s));
          height: calc(6.79vw / var(--s));
        }

        &.-soldout,
        &.-comingsoon {
          font-size: calc(11vw / var(--s));
          right: calc(7.3vw / var(--s));
          bottom: calc(7.2vw / var(--s));
        }
      }
    }

  }

  .concept {
    padding: calc(55vw / var(--s)) 0 0;
  }

  .concept-inner {
    position: relative;
    width: 100%;
    padding: 0 var(--sp-gutter);
    padding-right: 0;
  }

  .concept-header {
    margin-bottom: calc(22.2vw / var(--s));
  }

  .concept-catch {
    position: relative;
    margin-bottom: calc(44.7vw / var(--s));

    img {
      width: calc(217.56vw / var(--s));
    }
  }

  .concept-title {
    font-size: calc(20vw / var(--s));
  }

  .concept-ttl {
    position: absolute;
    top: calc(45vw / var(--s));
    right: calc(24.3vw / var(--s));
    width: calc(62.44vw / var(--s));

    img {
      width: 100%;
    }
  }

  .concept-content {
    display: block;
    position: static;
    padding: 0;

    .-text {
      font-size: calc(13vw / var(--s));
      line-height: calc(23vw / var(--s));
      width: 100%;
      letter-spacing: 0.1em;
      padding: 0;

      sup {
        font-size: calc(8vw / var(--s));
      }
    }
  }

  .belt-track {
    animation-duration: 10s;
  }

  .belt-track img {
    height: calc(50.03vw / var(--s));
    margin-right: calc(20vw / var(--s));
  }

  .news {
    margin-top: calc(75vw / var(--s));
  }

  .news-inner {
    padding: 0 0 calc(26.4vw * 2 / var(--s));

    &::before {
      width: 100vw;
      left: 0;
      right: 0;
      height: calc(100% - calc(100vw / var(--s)));
    }
  }

  .news-header {
    margin-bottom: calc(40vw / var(--s));
    padding: 0 calc(15vw / var(--s));
  }

  .news-header h2 {
    font-size: calc(20vw / var(--s));
  }

  .news-swiper .swiper-item {
    width: calc(229.73vw / var(--s));
    aspect-ratio: auto;
  }


  .news-body {
    padding: 0 calc(35vw / var(--s));
  }

  .news-info {
    flex-direction: column;
    align-items: flex-start;
    gap: calc(7.1vw / var(--s));
    margin-top: calc(12.9vw / var(--s));
  }

  .news-title {
    font-size: calc(12vw / var(--s));
    line-height: calc(20vw / var(--s));
  }

  .news-date {
    font-size: calc(12vw / var(--s));
  }
}

/* --- Float Vertical Animation --- */
@keyframes floatVertical {
  0% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-10px);
  }

  100% {
    transform: translateY(0);
  }
}