@charset "UTF-8";
@media screen and (min-width: 835px) {
  .p-index-title__flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-bottom: min(4.392vw, 66px);
  }
  .p-index-title__flex > * {
    margin: 0;
  }
}
@media screen and (max-width: 834px) {
  .p-index-title__flex {
    margin-bottom: min(10.667vw, 44px);
  }
}
.p-index-title__lead {
  letter-spacing: 0.06em;
}
.p-index-kv {
  width: 100%;
  height: 100svh;
  position: relative;
}
.p-index-kv::before {
  content: "";
  width: 100%;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.45)), color-stop(60%, rgba(0, 0, 0, 0.25)), to(rgba(0, 0, 0, 0)));
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.45) 0%, rgba(0, 0, 0, 0.25) 60%, rgba(0, 0, 0, 0) 100%);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
@media screen and (min-width: 835px) {
  .p-index-kv::before {
    height: min(21.962vw, 330px);
  }
}
@media screen and (max-width: 834px) {
  .p-index-kv::before {
    height: min(72vw, 297px);
  }
}
.p-index-kv__title {
  width: auto;
  position: absolute;
  z-index: 1;
}
@media screen and (min-width: 835px) {
  .p-index-kv__title {
    height: clamp(164.05px, 14.129vw, 212.3px);
    bottom: min(5.637vw, 84.7px);
    left: min(7.321vw, 110px);
  }
}
@media screen and (max-width: 834px) {
  .p-index-kv__title {
    bottom: min(21.333vw, 88px);
    left: min(8vw, 33px);
  }
}
@media screen and (max-width: 834px) and (min-width: 541px) {
  .p-index-kv__title {
    max-width: calc(100% - clamp(102px, 32vw, 132px));
    height: clamp(127.5px, 40vw, 165px);
  }
}
@media screen and (max-width: 540px) {
  .p-index-kv__title {
    width: clamp(209.1px, 65.6vw, 270.6px);
  }
}
.p-index-kv__title img {
  max-width: none;
}
@media screen and (min-width: 835px) {
  .p-index-kv__title img {
    width: auto;
    height: 100%;
  }
}
@media screen and (max-width: 834px) {
  .p-index-kv__title img {
    width: 100%;
  }
}
.p-index-kv__image__slider {
  width: 100%;
  height: 100svh;
  position: relative;
  overflow: hidden;
  z-index: 0;
}
.p-index-kv__image__slider__slide {
  width: 100%;
  height: 100svh;
}
.p-index-kv__image__slider__slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.p-index-kv__scroll {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  position: absolute;
  z-index: 1;
}
@media screen and (min-width: 835px) {
  .p-index-kv__scroll {
    height: min(16.105vw, 242px);
    bottom: min(4.978vw, 74.8px);
    right: min(3.514vw, 52.8px);
  }
}
@media screen and (max-width: 834px) {
  .p-index-kv__scroll {
    height: min(58.667vw, 242px);
    bottom: min(6.4vw, 26.4px);
    right: min(9.6vw, 39.6px);
  }
}
.p-index-kv__scroll__text {
  color: #ffffff;
  font-family: "Inter", "Noto Sans JP", YuGothic, "游ゴシック体", "Yu Gothic Medium", "游ゴシック Medium", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  font-weight: 600;
  letter-spacing: 0.08em;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  text-orientation: sideways;
  position: absolute;
  bottom: 0;
  left: auto;
  right: auto;
}
@media screen and (min-width: 835px) {
  .p-index-kv__scroll__text {
    font-size: clamp(10.2px, 0.878vw, 13.2px);
  }
}
@media screen and (max-width: 834px) {
  .p-index-kv__scroll__text {
    font-size: clamp(10.2px, 3.2vw, 13.2px);
  }
}
.p-index-kv__scroll__line {
  width: 1px;
  background-color: rgba(255, 255, 255, 0.25);
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 835px) {
  .p-index-kv__scroll__line {
    height: min(8.785vw, 132px);
  }
}
@media screen and (max-width: 834px) {
  .p-index-kv__scroll__line {
    height: min(32vw, 132px);
  }
}
.p-index-kv__scroll__line::after {
  content: "";
  position: absolute;
  width: 1px;
  background-color: #ffffff;
  -webkit-animation: scrolldown 2.5s ease-in-out infinite;
          animation: scrolldown 2.5s ease-in-out infinite;
}
@media screen and (min-width: 835px) {
  .p-index-kv__scroll__line::after {
    height: min(4.392vw, 66px);
  }
}
@media screen and (max-width: 834px) {
  .p-index-kv__scroll__line::after {
    height: min(16vw, 66px);
  }
}
@-webkit-keyframes scrolldown {
  0% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  100% {
    -webkit-transform: translateY(200%);
            transform: translateY(200%);
  }
}
@keyframes scrolldown {
  0% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  100% {
    -webkit-transform: translateY(200%);
            transform: translateY(200%);
  }
}
.p-index-products__list {
  display: -ms-grid;
  display: grid;
}
@media screen and (min-width: 835px) {
  .p-index-products__list {
    -ms-grid-columns: 1fr min(1.171vw, 17.6px) 1fr min(1.171vw, 17.6px) 1fr;
    grid-template-columns: repeat(3, 1fr);
    -webkit-column-gap: min(1.171vw, 17.6px);
       -moz-column-gap: min(1.171vw, 17.6px);
            column-gap: min(1.171vw, 17.6px);
    row-gap: min(4.392vw, 66px);
  }
}
@media screen and (max-width: 834px) {
  .p-index-products__list {
    -ms-grid-columns: 1fr min(4.267vw, 17.6px) 1fr;
    grid-template-columns: repeat(2, 1fr);
    -webkit-column-gap: min(4.267vw, 17.6px);
       -moz-column-gap: min(4.267vw, 17.6px);
            column-gap: min(4.267vw, 17.6px);
    row-gap: min(10.667vw, 44px);
  }
}
@media screen and (max-width: 540px) {
  .p-index-products__list {
    -ms-grid-columns: (1fr)[1];
    grid-template-columns: repeat(1, 1fr);
  }
}
.p-index-products__link {
  display: block;
}
@media (hover: hover) {
  .p-index-products__link:hover .p-index-products__image img {
    scale: 1.05;
  }
}
.p-index-products__image {
  border-radius: 12px;
  overflow: hidden;
}
.p-index-products__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: scale 0.45s cubic-bezier(0.25, 0.1, 0.39, 1.06);
  transition: scale 0.45s cubic-bezier(0.25, 0.1, 0.39, 1.06);
}
@media screen and (min-width: 835px) {
  .p-index-products__title {
    font-size: clamp(14.45px, 1.245vw, 18.7px);
    font-weight: 500;
    line-height: 1.7647058824;
    margin-top: min(1.464vw, 22px);
  }
}
@media screen and (max-width: 834px) {
  .p-index-products__title {
    font-size: clamp(20.4px, 6.4vw, 26.4px);
    font-weight: 700;
    line-height: 1.125;
    margin-top: min(4.267vw, 17.6px);
  }
}
.p-index-products__text {
  color: #636b72;
  line-height: 1.8;
}
@media screen and (min-width: 835px) {
  .p-index-products__text {
    font-size: clamp(11.05px, 0.952vw, 14.3px);
    margin-top: min(0.586vw, 8.8px);
  }
}
@media screen and (max-width: 834px) {
  .p-index-products__text {
    font-size: clamp(11.05px, 3.467vw, 14.3px);
    margin-top: min(2.133vw, 8.8px);
  }
}
@media screen and (min-width: 835px) {
  .p-index-archive {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 1fr;
    grid-template-columns: 1fr 1fr;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.p-index-archive > *:first-child {
  margin-top: 0;
}
.p-index-archive > *:last-child {
  margin-bottom: 0;
}
@media screen and (min-width: 835px) {
  .p-index-archive__button {
    margin-left: 0;
    margin-right: auto;
  }
}
@media screen and (max-width: 834px) {
  .p-index-archive__list {
    margin-top: min(10.667vw, 44px);
  }
}