@charset "utf-8";
/* *************************************
hamburger
************************************* */
.hamburger {
  width: fit-content;
  text-align: center;
}

@media (any-hover: hover) {
  .hamburger:hover {
    cursor: pointer;
  }
}

.hamburger__btn {
  padding: calc(8 * var(--rem));
}

.hamburger__btn span {
  display: block;
  width: calc(54 * var(--rem));
  height: calc(2 * var(--rem));
  background-color: var(--black);
  transition: 0.3s ease;
  @media (width < 768px) {
    width: calc(36 * var(--rem));
  }
}

.hamburger__btn span:nth-child(2) {
  margin: calc(16 * var(--rem)) 0;
}

/* is-open */
.hamburger.is-open .hamburger__btn span:nth-child(1) {
  transform: translateY(calc(18 * var(--rem))) rotate(45deg);
}
.hamburger.is-open .hamburger__btn span:nth-child(2) {
  opacity: 0;
}
.hamburger.is-open .hamburger__btn span:nth-child(3) {
  transform: translateY(calc(-18 * var(--rem))) rotate(-45deg);
}

/* *************************************
page-hed
************************************* */
.page-head {
  position: relative;
  height: calc(250 * var(--rem));
  margin-block-start: calc(80 * var(--rem));
}

.page-head::before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background-color: #00000030;
  position: absolute;
  inset: 0;
}

.page-head__img {
  height: inherit;
}

.page-head__img img {
  aspect-ratio: 1440/250;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.page-head__title {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  display: grid;
  row-gap: calc(8 * var(--rem));
  width: 100%;
  padding: calc(16 * var(--rem));
}

.page-head__title-jp {
  font-size: calc(40 * var(--rem));
  line-height: 1.5;
  letter-spacing: 0.05em;
  text-align: center;
  color: var(--white);
  @media (width < 768px) {
    font-size: calc(30 * var(--rem));
  }
}

.page-head__title-en {
  font-size: calc(20 * var(--rem));
  font-weight: bold;
  line-height: 1;
  text-align: center;
  text-wrap: balance;
  color: var(--white);
  text-transform: uppercase;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

/* *************************************
sns-list
************************************* */
.sns-list {
  display: inline-grid;
  grid-template-columns: repeat(2, auto);
  gap: calc(17 * var(--rem));
}

.sns-list__item a {
  display: block;
  padding: calc(16 * var(--rem));
  width: calc(78 * var(--rem));
}

.sns-list__item a img {
  aspect-ratio: 151/150;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* *************************************
infinite-swiper
************************************* */
.infinite-swiper {
  .swiper-wrapper {
    transition-timing-function: linear;
  }

  .swiper-slide img {
    aspect-ratio: 1200/ 814;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}

.infinite-swiper.infinite-swiper--bottom .swiper-slide img {
  aspect-ratio: 1200 / 475;
}

/* *************************************
3col-swiper
************************************* */
.col3-swiper {
  .swiper-slide {
    width: calc(850 * var(--rem));
    @media (width < 768px) {
      width: 100%;
    }
  }

  .swiper-slide img {
    aspect-ratio: 350 /261;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .swiper-button-prev,
  .swiper-button-next {
    width: calc(100 * var(--rem));
    @media (width < 768px) {
      width: calc(30 * var(--rem));
    }
  }

  .swiper-button-prev {
    left: calc(90 * var(--rem));
    @media (width < 768px) {
      left: calc(20 * var(--rem));
    }
  }

  .swiper-button-next {
    right: calc(90 * var(--rem));
    @media (width < 768px) {
      right: calc(20 * var(--rem));
    }
  }

  .swiper-button-prev::after,
  .swiper-button-next::after {
    color: transparent;
    background: url(../../library/images/common/swiper-arrow.svg) no-repeat center / contain;
    width: inherit;
    aspect-ratio: 1;
  }

  .swiper-button-prev::after {
    rotate: 180deg;
  }
}

/* *************************************
thumbnail-swiper
************************************* */
.thumbnail-swiper {
  .slider-thumbnail .swiper-wrapper {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: calc(4 * var(--rem));
  }
  .slider-thumbnail .swiper-slide.swiper-slide-thumb-active {
    border: 3px solid var(--accent-color);
  }

  /* レイアウトのためのスタイル */
  .swiper {
    max-width: calc(490 * var(--rem));
    width: 100%;
  }
  .swiper-slide img {
    aspect-ratio: 200/199;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .slider-thumbnail {
    margin-block-start: calc(12 * var(--rem));
  }
}

/* *************************************
btn1
************************************* */
.btn1 {
  display: grid;
  place-content: center;
  border: 2px solid var(--border-color);
  padding: calc(40 * var(--rem)) calc(10 * var(--rem));

  @media (width < 768px) {
    min-width: calc(300 * var(--rem));
    padding-block: calc(20 * var(--rem));
  }
}

.btn1__en {
  font-size: calc(40 * var(--rem));
  font-weight: bold;
  letter-spacing: 0.15em;
  text-align: center;
  text-transform: uppercase;
  @media (width < 768px) {
    font-size: calc(30 * var(--rem));
  }
}

.btn1__jp {
  font-size: calc(20 * var(--rem));
  letter-spacing: 0.05em;
  text-align: center;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

/* *************************************
btn2
************************************* */
.btn2 {
  border: 1px solid var(--border-color);
  display: inline-block;
  min-width: calc(300 * var(--rem));
  padding: calc(16 * var(--rem));
  font-size: calc(16 * var(--rem));
  text-align: center;
}

/* *************************************
title1
************************************* */
.title1 {
  display: grid;
  place-content: center;
  gap: calc(8 * var(--rem));
  @media (width < 768px) {
    gap: 0;
  }
}

.title1__en {
  font-size: calc(40 * var(--rem));
  font-weight: bold;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-align: center;
  line-height: 1;
  @media (width < 768px) {
    font-size: calc(30 * var(--rem));
  }
}

.title1__jp {
  text-align: center;
  font-size: calc(20 * var(--rem));
  letter-spacing: 0.02em;
  text-transform: capitalize;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

/* *************************************
card1-list
************************************* */
.card1-list {
  display: grid;
  gap: calc(40 * var(--rem));
  @media (width < 768px) {
    gap: calc(24 * var(--rem));
  }
}

.card1-list__item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: calc(74 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
    gap: calc(16 * var(--rem));
  }
}

.card1-list__wrap {
}

.card1-list__img {
  width: calc(310 * var(--rem));
  @media (width < 768px) {
    width: 100%;
  }
}

.card1-list__img img {
  aspect-ratio: 128 /92;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.card1-list__time {
  font-size: calc(20 * var(--rem));
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 1;
  @media (width < 768px) {
    font-size: calc(18 * var(--rem));
  }
}

.card1-list__text {
  margin-block-start: calc(8 * var(--rem));
  letter-spacing: 0.17em;
  line-height: 1.8;
}

.card1-list__text a {
  color: var(--accent-color);
  @media (width < 768px) {
    display: block;
    width: fit-content;
    margin-inline: auto;
    padding: calc(16 * var(--rem));
  }
}

/* *************************************
card2-list
************************************* */
.card2-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(80 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
    gap: calc(40 * var(--rem));
  }
}

.card2-list__item {
}

.card2-list__img {
  height: calc(330 * var(--rem));
}

.card2-list__img img {
  aspect-ratio: 128 /92;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.card2-list__title {
  text-align: center;
  margin-block-start: calc(24 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(16 * var(--rem));
  }
}

.card2-list__title-jp {
  font-size: calc(28 * var(--rem));
  @media (width < 768px) {
    font-size: calc(20 * var(--rem));
  }
}

.card2-list__title-en {
  font-weight: bold;
  text-transform: capitalize;
  letter-spacing: 0.05em;
}

.card2-list__text {
  margin-block-start: calc(16 * var(--rem));
  line-height: 1.8;
  @media (width < 768px) {
    margin-block-start: 0;
  }
}

/* *************************************
card3-list
************************************* */
.card3-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  width: min(100%, calc(900 * var(--rem)));
  margin-inline: auto;
  gap: calc(80 * var(--rem)) calc(132 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
    @media (width < 768px) {
      gap: calc(40 * var(--rem));
    }
  }
}

.card3-list__img {
  border: 1px solid var(--border-color);
}

.card3-list__img img {
  aspect-ratio: 200 / 147;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.card3-list__title {
  text-align: center;
  font-size: calc(20 * var(--rem));
  font-weight: 500;
  letter-spacing: 0.15em;
  margin-block-start: calc(24 * var(--rem));
  @media (width < 768px) {
    font-size: calc(18 * var(--rem));
  }
}

.card3-list__address {
  text-align: center;
  font-weight: 500;
  letter-spacing: 0.2em;
  margin-block-start: calc(10 * var(--rem));
}

.card3-list__tel {
  display: block;
  width: fit-content;
  margin-inline: auto;
  font-weight: 500;
  letter-spacing: 0.25em;
  margin-block-start: calc(3 * var(--rem));
  padding: calc(8 * var(--rem)) calc(24 * var(--rem));
  text-transform: uppercase;
}

/* *************************************
card4-list
************************************* */
.card4-list {
  display: grid;
  gap: calc(150 * var(--rem));
  @media (width < 768px) {
    gap: calc(80 * var(--rem));
  }
}

.card4-list__item {
  display: grid;
  grid-template-columns: repeat(2, auto);
  align-items: center;
  gap: calc(90 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
    gap: calc(24 * var(--rem));
  }
}

.card4-list__img {
  width: 70%;
  margin-inline-start: auto;
  @media (width < 768px) {
    margin-inline: auto;
  }
}

.card4-list__img img {
  aspect-ratio: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.card4-list__wrap {
  padding-block: calc(32 * var(--rem)) calc(16 * var(--rem));
  @media (width < 768px) {
    padding: 0;
  }
}

.card4-list__name {
  font-size: calc(20 * var(--rem));
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.05em;
  @media (width < 768px) {
    font-size: calc(18 * var(--rem));
    text-align: center;
  }
}

.card4-list__position {
  font-size: calc(20 * var(--rem));
  font-weight: bold;
  margin-block-start: calc(8 * var(--rem));
  @media (width < 768px) {
    font-size: calc(18 * var(--rem));
    text-align: center;
  }
}

.card4-list__favorites {
  margin-block-start: calc(24 * var(--rem));
  font-size: calc(20 * var(--rem));
  font-weight: bold;
  letter-spacing: 0.001em;
  line-height: 1;
  @media (width < 768px) {
    margin-block-start: calc(24 * var(--rem));
    font-size: calc(18 * var(--rem));
    text-align: center;
  }
}

.card4-list__title {
  font-size: calc(20 * var(--rem));
  letter-spacing: 0.1em;
  margin-block-start: calc(8 * var(--rem));
  @media (width < 768px) {
    font-size: calc(18 * var(--rem));
    text-align: center;
  }
}

.card4-list__text {
  margin-block-start: calc(24 * var(--rem));
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.9;
  width: min(100%, 510px);
  @media (width < 768px) {
    margin-block-start: calc(24 * var(--rem));
  }
}

/* *************************************
image-parts1
************************************* */
.image-parts1 {
}

.image-parts1__img {
  height: calc(488 * var(--rem));
  @media (width < 768px) {
    height: calc(244 * var(--rem));
  }
}

.image-parts1__img img {
  aspect-ratio: 596 /202;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.image-parts1.image-parts1--l .image-parts1__img {
  height: 100%;
}

.image-parts1.image-parts1--l .image-parts1__img img {
  aspect-ratio: 596 /240;
}

.image-parts1.image-parts1--position img {
  object-position: 50% 87%;
  @media (width < 768px) {
    object-position: 65% 87%;
  }
}

/* *************************************
product-list
************************************* */
.product-list {
  display: grid;
  gap: calc(240 * var(--rem));
  @media (width < 768px) {
    gap: calc(140 * var(--rem));
  }
}

.product-list__item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: calc(107 * var(--rem));
  max-width: calc(1135 * var(--rem));
  margin-inline: auto;
  position: relative;
  @media (width < 768px) {
    grid-template-columns: 1fr;
    gap: calc(24 * var(--rem));
  }
}

.product-list__item:not(:first-child)::before {
  content: '';
  display: block;
  width: 98%;
  height: 3px;
  background-color: #6fba2b;
  position: absolute;
  top: -18%;
  top: -120px;
  left: 50%;
  transform: translate(-50%, 0);
  @media (width < 768px) {
    /* top: -8%; */
    top: -77px;
  }
}

.product-list__image-item + .product-list__item::before {
  display: none;
}

.product-list__image-item {
  margin-inline: calc(50% - 50vw);
  margin-block-start: calc(-55 * var(--rem));
}

.product-list__wrap {
  padding-block-start: calc(46 * var(--rem));
  @media (width < 768px) {
    padding-block-start: 0;
  }
}

.product-list__title-jp {
  font-size: calc(26 * var(--rem));
  letter-spacing: 0.2em;
  @media (width < 768px) {
    font-size: calc(20 * var(--rem));
  }
}

.product-list__title-en {
  font-size: calc(22 * var(--rem));
  font-weight: bold;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  @media (width < 768px) {
    font-size: calc(20 * var(--rem));
  }
}

.product-list__capacity {
  margin-block-start: calc(10 * var(--rem));
  font-size: calc(22 * var(--rem));
  font-weight: bold;
  letter-spacing: 0.01em;
  @media (width < 768px) {
    font-size: calc(20 * var(--rem));
    margin-block-start: 0;
  }
}

.product-list__capacity span {
  font-size: calc(20 * var(--rem));
  @media (width < 768px) {
    font-size: calc(18 * var(--rem));
  }
}

.product-list__price {
  font-size: calc(20 * var(--rem));
  font-weight: bold;
  letter-spacing: 0.1em;
}

.product-list__text-jp {
  margin-block-start: calc(34 * var(--rem));
  font-size: calc(18 * var(--rem));
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.05em;
  @media (width < 768px) {
    margin-block-start: calc(26 * var(--rem));
    font-size: calc(16 * var(--rem));
  }
}

.product-list__text-en {
  margin-block-start: calc(24 * var(--rem));
  line-height: 1.8;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}

/* *************************************
.olive-japan
************************************* */
.olive-japan {
  padding-inline: calc(125 * var(--rem));
  background-color: var(--black);
  @media (width < 768px) {
    padding: calc(40 * var(--rem)) calc(16 * var(--rem));
  }
}

.olive-japan__container {
  display: grid;
  grid-template-columns: auto 1fr auto;
  width: min(100%, calc(1200 * var(--rem)));
  margin-inline: auto;
  @media (width < 768px) {
    grid-template-columns: 1fr;
  }
}

.olive-japan__img-left {
  width: calc(200 * var(--rem));
  height: calc(274 * var(--rem));
  margin-block-start: calc(34 * var(--rem));
  margin-inline-start: calc(20 * var(--rem));
  @media (width < 768px) {
    margin-block: 0;
    margin-inline: auto;
    width: min(80%, calc(400 * var(--rem)));
    height: 100%;
    transform: translateX(calc(-13 * var(--rem)));
  }
}

.olive-japan__img-left img {
  aspect-ratio: 82 /112;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.olive-japan__wrap {
  margin-block-start: calc(58 * var(--rem));
  padding-inline: calc(8 * var(--rem));
  @media (width < 768px) {
    margin: 0;
    padding: 0;
  }
}

.olive-japan__subtitle1 {
  color: var(--white);
  text-align: center;
  font-size: calc(24 * var(--rem));
  letter-spacing: 0.17em;
  @media (width < 768px) {
    font-size: calc(20 * var(--rem));
  }
}

.olive-japan__title {
  color: var(--white);
  text-align: center;
  font-size: calc(50 * var(--rem));
  font-weight: 400;
  letter-spacing: 0.2em;
  line-height: 1;
  margin-block-start: calc(11 * var(--rem));
  @media (width < 768px) {
    line-height: 1.5;
  }
}

.olive-japan__title span {
  display: block;
  font-size: calc(16 * var(--rem));
  letter-spacing: 0.2em;
  margin-block-start: calc(10 * var(--rem));
}

.olive-japan__subtitle2 {
  color: var(--white);
  text-align: center;
  font-size: calc(24 * var(--rem));
  letter-spacing: 0.17em;
  margin-block-start: calc(10 * var(--rem));
  @media (width < 768px) {
    font-size: calc(20 * var(--rem));
  }
}

.olive-japan__img-right {
  width: calc(226 * var(--rem));
  @media (width < 768px) {
    width: min(80%, calc(400 * var(--rem)));
    margin-inline: auto;
    margin-block-start: calc(24 * var(--rem));
  }
}

.olive-japan__img-right img {
  aspect-ratio: 47 / 65;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* *************************************
olive-banner
************************************* */
.olive-banner {
}

.olive-banner__img img {
  aspect-ratio: 2700 /580;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* *************************************
table1
************************************* */
.table1 {
  border: 1px solid var(--border-color);
}

.table1__item {
  display: grid;
  grid-template-columns: calc(220 * var(--rem)) 1fr;
  border-bottom: 1px solid var(--border-color);
  @media (width < 768px) {
    grid-template-columns: 1fr;
  }
}

.table1__item:last-child {
  border-bottom: none;
}

.table1__item dt {
  padding-block: calc(20 * var(--rem)) calc(10 * var(--rem));
  padding-inline-start: calc(20 * var(--rem));
  @media (width < 768px) {
    text-align: center;
    padding: calc(16 * var(--rem)) calc(8 * var(--rem));
  }
}

.table1__item dd {
  border-left: 1px solid var(--border-color);
  padding-block: calc(17 * var(--rem)) calc(10 * var(--rem));
  padding-inline: calc(24 * var(--rem));
  line-height: 2.2;
  letter-spacing: 0.04em;
  @media (width < 768px) {
    border-left: none;
    padding: calc(8 * var(--rem)) calc(16 * var(--rem));
  }
}

/* *************************************
pagination
************************************* */
.pagination {
}

.pagination > ul {
  display: flex;
  justify-content: center;
  gap: calc(24 * var(--rem));
  @media (width < 768px) {
    gap: calc(16 * var(--rem));
  }
}

.pagination > ul li a,
.pagination > ul li span {
  display: grid;
  place-content: center;
  padding: calc(5 * var(--rem)) calc(10 * var(--rem));
  border: 1px solid var(--border-color);
  font-size: calc(20 * var(--rem));
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.pagination > ul li span {
  background-color: var(--border-color);
  color: var(--white);
}

.pagination .page-numbers li:has(.page-numbers.dots) {
  display: none;
}

/* *************************************
news-single
************************************* */
.news-single {
  margin-block-start: calc(100 * var(--rem));
  padding-block-end: calc(80 * var(--rem));
}

.news-single__inner.inner {
  max-width: calc(850 * var(--rem));
}

.news-single__title {
  text-align: center;
}

.news-single__content {
  margin-block-start: calc(40 * var(--rem));
}

.news-single__btn {
  text-align: center;
  margin-block-start: calc(80 * var(--rem));
}

/* *************************************
the-content
************************************* */
.the-content {
  img.alignright {
    display: block;
    margin: 0 0 0 auto;
  }
  img.alignleft {
    display: block;
    margin: 0 auto 0 0;
  }
  img.aligncenter {
    display: block;
    margin: 0 auto;
  }

  p {
    margin-block-end: 1em;
  }

  img {
    height: auto;
  }

  img.emoji {
    width: calc(16 * var(--rem));
  }
}

/* *************************************
card5-list
************************************* */
.card5-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: calc(24 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
    gap: calc(40 * var(--rem));
  }
}

.card5-list[data-modifier='col3'] {
  grid-template-columns: repeat(3, 1fr);
  @media (width < 768px) {
    grid-template-columns: 1fr;
    gap: calc(40 * var(--rem));
  }
}

.card5-list__item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 4;
}

.card5-list__link {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 4;
  gap: calc(4 * var(--rem));
}

.card5-list__img img {
  aspect-ratio: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.card5-list__time {
  font-size: calc(14 * var(--rem));
}

.card5-list__title {
  font-size: calc(18 * var(--rem));
  color: #6fba2b;
}

.card5-list__tags {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: calc(4 * var(--rem)) calc(8 * var(--rem));
  margin-block-start: calc(8 * var(--rem));
}

.card5-list__tag {
  background-color: var(--main-color);
  font-size: calc(12 * var(--rem));
  padding: calc(4 * var(--rem)) calc(8 * var(--rem));
  line-height: 1;
}

/* *************************************
cat-list
************************************* */
.cat-list {
  display: flex;
  flex-wrap: wrap;
  gap: calc(8 * var(--rem)) calc(24 * var(--rem));
  @media (width < 768px) {
    gap: calc(12 * var(--rem));
  }
}

.cat-list__item {
  display: grid;
  line-height: 1;
}

.cat-list__item a {
  padding: calc(12 * var(--rem));
  background-color: var(--main-color);
  line-height: 1;
  @media (width < 768px) {
    font-size: calc(14 * var(--rem));
    padding: calc(12 * var(--rem)) calc(8 * var(--rem));
  }
}

.cat-list__item a.current {
  background-color: #6fba2b;
  color: var(--white);
}
