main {
  padding-bottom: 23.3333333333vw;
}

.section {
  margin: 0 auto;
  padding: 18vw 2.6666666667vw 26.6666666667vw;
}

.section-heading {
  position: relative;
  margin-bottom: 13.3333333333vw;
}

.text-link {
  display: inline-flex;
  align-items: center;
  gap: 2.1333333333vw;
  font-size: 3.7333333333vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  letter-spacing: normal;
  text-align: left;
  color: #333;
}
.text-link::before {
  content: "";
  width: 2.2666666667vw;
  height: 2.6666666667vw;
  background: url("../img/common/icon-triangle.png") center/contain no-repeat;
}

.text-link--align-right {
  justify-self: end;
}

.hero {
  position: relative;
  width: 100vw;
  height: calc(100dvh - 26.6666666667vw);
  min-height: 133.3333333333vw;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

.hero__content {
  position: relative;
  z-index: 1;
  width: 100vw;
  height: 100%;
  margin: 0 auto;
  color: #fff;
}
.hero__content .hero__box {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2.6666666667vw;
  left: 50%;
  top: 50%;
  transform: translateX(-50%) translateY(-50%);
  margin-top: -4vw;
}
.hero__content .hero__box .hero__box-copy {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44vw;
  height: 44vw;
}
.hero__content .hero__box .hero__text {
  width: 80vw;
  font-size: 3.7333333333vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 1.65;
  letter-spacing: normal;
  text-align: center;
  color: #fff;
}
.hero__content .hero__cards {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 8vw;
  display: flex;
  gap: 3.6vw;
}
.hero__content .hero__cards .hero-card {
  width: 45.3333333333vw;
}
.hero__content .scroll {
  position: absolute;
  left: 2.5333333333vw;
  bottom: 32.4vw;
  width: 2.6666666667vw;
}
.hero__content .scroll a {
  display: block;
}

.value__grid {
  display: grid;
  gap: 10.6666666667vw;
}
.value__grid .value-card {
  padding: 8vw 4vw;
  border: clamp(1px, 0.1333333333vw, 1px) solid #ece7de;
  border-radius: 1.3333333333vw;
  text-align: center;
  background: #fff;
}
.value__grid .value-card h3 {
  margin: 0;
  font-size: 4.5333333333vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: normal;
  letter-spacing: normal;
  text-align: center;
  color: #333;
}
.value__grid .value-card img {
  width: auto;
  height: 18.1333333333vw;
  margin: 4.6666666667vw auto 0;
  object-fit: contain;
}
.value__grid .value-card p {
  margin: 6.4vw 0 0;
  font-size: 3.7333333333vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 1.65;
  letter-spacing: normal;
  text-align: center;
  color: #666;
}

.products {
  background-color: #faf9f6;
  width: 100%;
  padding: 16vw 0 16.6666666667vw;
}
.products .section-heading {
  margin: 0 2.6666666667vw;
}
.products .products__layout {
  margin-top: 16vw;
  display: flex;
  flex-direction: column;
  gap: 26.6666666667vw;
  align-items: start;
  padding-right: 5.3333333333vw;
}
.products .products__visual {
  position: relative;
}
.products .products__visual img {
  width: auto;
  height: 77.3333333333vw;
  object-fit: cover;
}
.products .products__visual .products__vertical-copy {
  position: absolute;
  height: auto;
  bottom: -15.2vw;
  right: 0;
  transform: translateX(70%);
  padding: 4vw 3.3333333333vw;
  background: #c7bc86;
  font-family: "Shippori Mincho", serif;
  font-size: 7.2vw;
  font-weight: 400;
  font-stretch: normal;
  font-style: normal;
  line-height: 0.79;
  letter-spacing: 0.576vw;
  text-align: left;
  color: #fff;
  writing-mode: vertical-rl;
}
.products .products__content {
  padding-left: 2.4vw;
}
.products .products__content .section-heading {
  margin: 0 0 10.6666666667vw;
}
.products .products__category-block {
  border-left: 0.8vw solid #ddaf00;
  padding-left: 2.4vw;
}
.products .products__category-block h3 {
  padding: 2.6666666667vw 0;
  font-size: 5.0666666667vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  letter-spacing: normal;
  text-align: left;
  color: #333;
}
.products .products__category-block p {
  margin-top: 2.6666666667vw;
  font-size: 3.7333333333vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: normal;
  letter-spacing: normal;
  text-align: left;
  color: #666;
}
.products .text-link {
  width: 100%;
  justify-content: flex-end;
  text-align: right;
  margin-top: 9.3333333333vw;
}

.category-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  padding: 0;
  margin-top: 8vw;
  list-style: none;
  border-top: clamp(1px, 0.1333333333vw, 1px) solid #ccc;
  border-bottom: clamp(1px, 0.1333333333vw, 1px) solid #ccc;
  padding: 2.6666666667vw;
}
.category-list li {
  padding: 3.2vw 0vw;
  font-size: 4vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  letter-spacing: normal;
  text-align: left;
  color: #333;
}
.category-list li:nth-child(even) {
  padding-left: 4vw;
}
.category-list li a {
  display: flex;
  align-items: center;
}
.category-list li a span {
  display: block;
  background: url(../img/common/icon-tag.png) left center/2.6666666667vw auto no-repeat;
  padding-left: 4vw;
}

.original {
  padding: 0;
  display: block;
}
.original .original__lead {
  position: relative;
}
.original .swiper-button {
  position: absolute;
  display: flex;
  justify-content: space-between;
  bottom: 1.3333333333vw;
  right: 2vw;
}
.original .swiper-button .swiper-button-prev,
.original .swiper-button .swiper-button-next {
  position: static;
  padding: 2vw 1.3333333333vw;
  width: auto;
  height: auto;
  margin: 0;
}
.original .swiper-button .swiper-button-prev::after,
.original .swiper-button .swiper-button-next::after {
  display: block;
  content: "";
  width: 4.2666666667vw;
  height: 0.6666666667vw;
}
.original .swiper-button .swiper-button-prev::after {
  background: url("../img/common/slider-left.png") center/contain no-repeat;
}
.original .swiper-button .swiper-button-next::after {
  background: url("../img/common/slider-right.png") center/contain no-repeat;
}
.original .original__lead-box {
  position: relative;
  align-self: start;
  padding: 6.6666666667vw 1.3333333333vw 8.6666666667vw 4vw;
  background: #ddaf00;
  color: #fff;
  width: 77.3333333333vw;
  z-index: 10;
}
.original .original__lead-box h2 {
  font-size: 6.4vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 1.32;
  letter-spacing: normal;
  text-align: left;
  color: #fff;
}
.original .original__lead-box p:before {
  content: "";
  display: block;
  width: 5.3333333333vw;
  height: clamp(1px, 0.1333333333vw, 1px);
  background-color: #fff;
  margin-top: 4vw;
  margin-bottom: 4vw;
}
.original .original__lead-box p {
  margin: 0;
  font-size: 3.7333333333vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: normal;
  letter-spacing: normal;
  text-align: left;
  color: #fff;
}
.original .original__gallery {
  margin-top: -3.3333333333vw;
  display: flex;
  gap: 20px;
}
.original .original__gallery .original__gallery-item {
  width: 40vw;
  height: 58.6666666667vw;
  overflow: hidden;
  background: #f5f1e9;
}
.original .original__gallery .original__gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.original .text-link {
  margin-top: 6vw;
  justify-content: flex-end;
  width: 100%;
  padding-right: 5.3333333333vw;
}

.banner {
  margin: 16.6666666667vw 0 0;
  background-color: #c7bc86;
}
.banner .banner__inner {
  position: relative;
}
.banner .banner__inner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.88;
}

.explore {
  padding: 13.3333333333vw 2.6666666667vw 21.3333333333vw;
  background-color: #faf9f6;
}
.explore .section-heading {
  margin-bottom: 10vw;
}
.explore .explore__grid {
  display: grid;
  gap: 10.6666666667vw;
  padding-left: 2.6666666667vw;
}
.explore .explore-card {
  position: relative;
}
.explore .explore-card img {
  width: 100%;
  height: 42.6666666667vw;
  object-fit: cover;
}
.explore .explore-card h3 {
  margin-top: 4vw;
  font-size: 5.6vw;
  display: flex;
  justify-content: flex-start;
  gap: 2.6666666667vw;
  align-items: center;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: normal;
  letter-spacing: normal;
  color: #333;
}
.explore .explore-card h3::after {
  content: "";
  display: block;
  width: 5.8666666667vw;
  height: 0.9333333333vw;
  background: url(../img/top/explore-arrow.png) no-repeat;
  background-size: contain;
}
.explore .explore-card p {
  margin-top: 4.2666666667vw;
  font-size: 3.7333333333vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 1.65;
  letter-spacing: normal;
  text-align: left;
  color: #666;
}
.explore .explore-card .explore-card__tag {
  position: absolute;
  width: auto;
  padding: 1.6vw 2.6666666667vw 1.6vw 2.6666666667vw;
  background-color: #ddaf00;
  top: 2.6666666667vw;
  left: -2.6666666667vw;
  display: inline-block;
  font-size: 4.2666666667vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: normal;
  letter-spacing: normal;
  text-align: left;
  color: #fff;
}
.explore .text-link {
  margin-top: 6vw;
  justify-content: flex-end;
  width: 100%;
}

.about {
  padding: 20vw 0 0;
}
.about .about__layout {
  gap: 8vw;
  justify-content: center;
  align-items: start;
}
.about .about__image {
  width: 88vw;
  height: auto;
  object-fit: cover;
}
.about .about__body {
  padding-right: 2.6666666667vw;
  padding-left: 2.6666666667vw;
  margin-top: 10.6666666667vw;
}
.about .about__body p {
  margin: 0;
  font-size: 3.7333333333vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 1.65;
  letter-spacing: normal;
  text-align: left;
  color: #666;
}
.about .section-heading {
  display: block;
  padding-left: 0;
  margin-bottom: 6vw;
}
.about .section-heading .section-heading__en {
  position: relative;
  margin-bottom: 5.3333333333vw;
}
.about .about__links {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-end;
  gap: 3.3333333333vw;
  margin-top: 10.6666666667vw;
}

.news {
  padding: 19.7333333333vw 2.6666666667vw 0;
}
.news .news__layout {
  display: grid;
  gap: 5.3333333333vw;
  align-items: start;
}
.news .news__list {
  display: grid;
}
.news .news-card {
  display: grid;
  gap: 4vw;
  align-items: flex-start;
  padding: 3.4666666667vw 0 6.1333333333vw;
  border-top: clamp(1px, 0.1333333333vw, 1px) solid #ccc;
}
.news .news-card:last-of-type {
  border-bottom: clamp(1px, 0.1333333333vw, 1px) solid #ccc;
}
.news .news-card img {
  width: 100%;
  height: 23.0666666667vw;
  object-fit: cover;
}
.news .news-card h3 {
  margin-top: 2.6666666667vw;
  font-size: 3.7333333333vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: normal;
  letter-spacing: normal;
  text-align: left;
  color: #666;
}
.news .news-card__meta {
  padding-top: 1.3333333333vw;
  display: flex;
  align-items: center;
  gap: 2.6666666667vw;
}
.news .news-card__meta .date {
  font-size: 2.4vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: italic;
  line-height: 1.3;
  letter-spacing: normal;
  text-align: left;
  color: #ddaf00;
  font-family: "Libre Baskerville", serif;
}
.news .news-card__meta .categories .category {
  display: block;
  font-size: 2.6666666667vw;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 1;
  letter-spacing: normal;
  text-align: left;
  color: #333;
}
.news .text-link {
  margin-top: 6vw;
  justify-content: flex-end;
  width: 100%;
}
