@charset "UTF-8";
/*------------------------------------------------------------


  style.css


------------------------------------------------------------*/
@media (orientation: landscape), (min-width: 769px) and (orientation: portrait) {}
@media (max-width: 768px) and (orientation: portrait) {}
@media (-webkit-max-device-pixel-ratio: 1), (max-resolution: 1dppx) {}
@media (hover: hover) {}

/*------------------------------------------------------------


  #top


------------------------------------------------------------*/
/*============================================================
  #top-head
============================================================*/
#top-head {
  position: relative;
  z-index: 0;
}

#top-head .div-gallery {
  aspect-ratio: 16 / 9;
  padding-bottom: calc(var(--grid-3) + var(--grid-4));
}

#top-head .div-gallery .figure-image {
  width: 100%;
  height: 100%;
  position: relative;
}

#top-head .div-gallery .figure-image .picture::after {
  opacity: 0.24;
}

#top-head .div-heading {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: var(--grid-2);
  color: var(--color-white);
  width: var(--grid-84);
  height: var(--grid-4);
  margin-inline: auto;
  position: absolute;
  left: 0;
  right: 0;
  bottom: var(--grid-3);
}

#top-head .div-heading .h-tagline {
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
  white-space: nowrap;
}

#top-head .div-heading .h-tagline .en {
  font-family: var(--font-cormorant);
  font-size: 4rem;
  letter-spacing: 0.02em;
  margin-block: -0.096em;
}

#top-head .div-heading .h-tagline .jp {
  font-family: var(--font-serif);
  font-size: 1.44rem;
  letter-spacing: 0.12em;
  margin-block: -0.096em;
}

#top-head .div-heading .borderline {
  display: block;
  width: 1px;
  height: 100%;
  background-color: var(--color-white);
  opacity: 0.24;
}

#top-head .div-heading .p-tagline {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  flex: 1;
}

#top-head .div-heading .p-tagline .en {
  font-family: var(--font-cormorant);
  font-size: 1.84rem;
  letter-spacing: 0.02em;
}

#top-head .div-heading .p-tagline .jp {
  font-family: var(--font-serif);
  font-size: 1.2rem;
  letter-spacing: 0.08em;
}

@media (max-width: 768px) and (orientation: portrait) {
  #top-head .div-gallery {
    aspect-ratio: 1 / 1;
    padding-bottom: 0;
  }

  #top-head .div-heading {
    flex-direction: column;
    align-items: initial;
    justify-content: initial;
    gap: var(--grid-3);
    width: 100%;
    height: auto;
    background-color: var(--color-darkgray);
    padding: var(--grid-4) var(--grid-2);
    position: static;
  }

  #top-head .div-heading .borderline {
    display: none;
  }

  #top-head .div-heading .p-tagline {
    flex-direction: column;
    align-items: initial;
    justify-content: initial;
    gap: var(--grid);
  }

  #top-head .div-heading .p-tagline .en {
    font-size: 1.28rem;
  }

  #top-head .div-heading .p-tagline .jp {
    font-size: 1.12rem;
  }
}


/*============================================================
  #top-instagram
============================================================*/
#top-instagram {
  background-color: var(--color-darkgray);
  padding-block: var(--grid-3);
  position: relative;
  z-index: 0;
}

#top-instagram .div-head .h-heading-section .en {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.96rem;
  color: var(--color-white);
}

#top-instagram .div-head .h-heading-section .icon-instagram {
  fill: var(--color-white);
  width: 1.6rem;
  height: auto;
  vertical-align: middle;
}

#top-instagram .div-slider {
  margin-top: var(--grid-2);
}

#top-instagram .div-slider .div-slider-content {
  width: var(--grid-78);
  margin-inline: auto;
}

#top-instagram .div-slider .div-slider-content .ul-slider {
  margin-inline: calc(var(--grid-3) * -1);
}

#top-instagram .div-slider .div-slider-content .ul-slider > li {
  width: var(--grid-22);
  margin-inline: var(--grid-3);
}

#top-instagram .div-slider .div-slider-content .ul-slider > li .a-link-article::after {
  background-color: var(--color-white);
}

@media (max-width: 768px) and (orientation: portrait) {
  #top-instagram .div-head .h-heading-section .en {
    gap: 0.8rem;
  }

  #top-instagram .div-slider .div-slider-content {
    width: var(--grid-46);
  }

  #top-instagram .div-slider .div-slider-content .ul-slider {
    margin-inline: calc(var(--grid-2) * -1);
  }

  #top-instagram .div-slider .div-slider-content .ul-slider > li {
    width: var(--grid-46);
    margin-inline: var(--grid-2);
  }
}


/*============================================================
  #top-news
============================================================*/
#top-news {
  padding-block: var(--grid-3);
  position: relative;
  z-index: 0;
}

#top-news .div-list {
  width: var(--grid-78);
  margin-top: var(--grid-2);
  margin-inline: auto;
}

#top-news .div-list .ul-news > li {
  width: var(--grid-22);
}

@media (max-width: 768px) and (orientation: portrait) {
  #top-news .div-list {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #top-news .div-list .ul-news {
    row-gap: calc(var(--grid) * 1.5);
  }

  #top-news .div-list .ul-news > li {
    width: 100%;
  }
}


/*============================================================
  #top-products
============================================================*/
#top-products {
  position: relative;
  z-index: 0;
}

#top-products .div-head {
  align-items: flex-end;
  width: var(--grid-78);
  padding-block: var(--grid-3);
  margin-inline: auto;
}

#top-products .div-head .h-heading-section .jp {
  font-size: 2rem;
  letter-spacing: 0.2em;
  margin-top: var(--grid);
}

#top-products .div-list .ul-products {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  width: 100%;
}

#top-products .div-list .ul-products > li {
  width: 100%;
}

#top-products .div-list .ul-products > li:nth-of-type(n+3) {
  width: 50%;
}

#top-products .div-list .ul-products .div-products-item {
  display: flex;
  flex-direction: column;
  justify-content: end;
  width: 100%;
  height: var(--grid-32);
  padding-block: var(--grid-3);
  position: relative;
  z-index: 0;
  overflow: hidden;
}

#top-products .div-list .ul-products .div-products-item .div-image {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
}

#top-products .div-list .ul-products .div-products-item .div-image::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: var(--color-black);
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
}

#top-products .div-list .ul-products .div-products-item.kibako .div-image::after {
  opacity: 0.16;
}

#top-products .div-list .ul-products .div-products-item.mari .div-image::after {
  opacity: 0.4;
}

#top-products .div-list .ul-products .div-products-item.square .div-image::after {
  opacity: 0.4;
}

#top-products .div-list .ul-products .div-products-item.teabag .div-image::after {
  opacity: 0.16;
}

#top-products .div-list .ul-products .div-products-item .div-heading .a-link-content {
  display: inline-flex;
  flex-direction: column;
  gap: var(--grid-2);
  color: var(--color-white);
  border-bottom: 1px solid rgba(255, 255, 255, 0.16);
  padding-bottom: 1.6rem;
  margin-inline: var(--grid-3);
}

#top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-title {
  display: flex;
  flex-direction: row;
  align-items: baseline;
  gap: var(--grid);
}

#top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-title .en {
  font-family: var(--font-cormorant);
  font-size: 3.2rem;
  letter-spacing: 0.02em;
  margin-block: -0.096em;
}

#top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-title .jp {
  font-family: var(--font-serif);
  font-size: 1.44rem;
  letter-spacing: 0.16em;
  margin-block: -0.096em;
}

#top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-tagline {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--grid);
  margin-top: -0.8em;
}

#top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-tagline .text {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--grid);
}

#top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-tagline .text .jp {
  font-family: var(--font-serif);
  font-size: 1.2rem;
  letter-spacing: 0.08em;
  margin-block: -0.096em;
}

#top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-tagline .text .en {
  font-family: var(--font-cormorant);
  font-size: 1.2rem;
  letter-spacing: 0.02em;
  margin-block: -0.096em;
}

#top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-tagline .icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.6rem;
  height: 1.6rem;
  outline: 1px solid rgba(255, 255, 255, 0.24);
  outline-offset: -1px;
  border-radius: 1.6rem;
}

#top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-tagline .icon svg.icon-arrow {
  fill: var(--color-white);
  width: 0.6rem;
  height: auto;
  margin-right: -0.16rem;
}

@media (hover: hover) {
  #top-products .div-list .ul-products .div-products-item .div-heading .a-link-content:hover {
    border-bottom-color: rgba(255, 255, 255, 0.32);
  }

  #top-products .div-list .ul-products .div-products-item .div-heading .a-link-content:hover .h-tagline .text {
    opacity: 0.8;
  }

  #top-products .div-list .ul-products .div-products-item .div-heading .a-link-content:hover .h-tagline .icon {
    background-color: var(--color-white);
  }

  #top-products .div-list .ul-products .div-products-item .div-heading .a-link-content:hover .h-tagline .icon svg.icon-arrow {
    fill: var(--color-black);
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  #top-products .div-head {
    align-items: flex-end;
    width: auto;
    margin-inline: var(--grid-2);
  }

  #top-products .div-head .h-heading-section .jp {
    font-size: 1.68rem;
    margin-top: 0;
  }

  #top-products .div-list .ul-products > li:nth-of-type(n+3) {
    width: 100%;
  }

  #top-products .div-list .ul-products .div-products-item .div-heading .a-link-content {
    display: flex;
    gap: var(--grid-3);
    width: auto;
    margin-inline: var(--grid-2);
  }

  #top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-title .en {
    font-size: 2.8rem;
  }

  #top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-title .jp {
    font-size: 1.28rem;
  }

  #top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-tagline {
    align-items: flex-end;
    margin-top: -0.4em;
  }

  #top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-tagline .text {
    flex: 1;
    flex-direction: column;
    align-items: initial;
  }

  #top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-tagline .text .jp {
    font-size: 1.12rem;
  }

  #top-products .div-list .ul-products .div-products-item .div-heading .a-link-content .h-tagline .text .en {
    font-size: 1.04rem;
  }
}


/*============================================================
  #top-voice
============================================================*/
#top-voice {
  padding-block: var(--grid-3);
  position: relative;
  z-index: 0;
}

#top-voice .div-slider {
  margin-top: var(--grid-2);
}

#top-voice .div-slider .div-slider-content {
  width: var(--grid-78);
  margin-inline: auto;
}

#top-voice .div-slider .div-slider-content .ul-slider {
  margin-inline: calc(var(--grid-5) * -1);
}

#top-voice .div-slider .div-slider-content .ul-slider > li {
  width: var(--grid-34);
  margin-inline: var(--grid-5);
}

#top-voice .div-slider .div-slider-content .ul-slider > li .a-link-article::after {
  display: none;
}

#top-voice .div-slider .div-slider-content .ul-slider > li .a-link-article .h-text {
  flex: 1;
}

@media (max-width: 768px) and (orientation: portrait) {
  #top-voice .div-slider .div-slider-content {
    width: var(--grid-46);
  }

  #top-voice .div-slider .div-slider-content .ul-slider {
    margin-inline: calc(var(--grid-2) * -1);
  }

  #top-voice .div-slider .div-slider-content .ul-slider > li {
    width: var(--grid-46);
    margin-inline: var(--grid-2);
  }
}


/*============================================================
  #top-media
============================================================*/
#top-media {
  padding-block: var(--grid-2) var(--grid-4);
  position: relative;
  z-index: 0;
}

#top-media > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
}

#top-media .div-article {
  width: var(--grid-78);
  margin-inline: auto;
}

#top-media .div-article .article-link-item .div-1 .div-head .h-title {
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  max-height: calc((1.6rem * 2) + (1.6rem * 1.44));
  font-family: var(--font-serif);
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 1.44;
  margin-block: -0.22em;
  overflow: hidden;
}

#top-media .div-logo {
  width: var(--grid-78);
  margin-inline: auto;
}

#top-media .div-logo .ul-logo {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  grid-template-rows: repeat(3, 1fr);
  column-gap: var(--grid-10);
  row-gap: var(--grid);
}

#top-media .div-logo .ul-logo > li {
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

@media (max-width: 768px) and (orientation: portrait) {
  #top-media {
    padding-block: var(--grid-2) var(--grid-4);
  }

  #top-media .div-article {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #top-media .div-logo {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #top-media .div-logo .ul-logo {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(5, 1fr);
    column-gap: var(--grid-8);
  }
}


/*============================================================
  #top-about
============================================================*/
#top-about .section-about {
  position: relative;
  z-index: 0;
}

#top-about .section-about .div-area-1 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-6);
  padding-block: var(--grid-6);
  position: relative;
  z-index: 0;
}

#top-about .section-about .div-area-1 > .div-background {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
}

#top-about .section-about .div-area-1 > .div-background::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: var(--color-black);
  opacity: 0.72;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
}

#top-about .section-about .div-area-1 > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-8);
  color: var(--color-white);
  width: var(--grid-78);
  margin-inline: auto;
}

#top-about .section-about .div-area-1 > .div-body > .div-head {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
}

#top-about .section-about .div-area-1 > .div-body > .div-content {
  display: flex;
  flex-direction: column;
  gap: var(--grid-8);
  padding-inline: var(--grid-4);
}

#top-about .section-about .div-area-1 > .div-body > .div-content .ul-content {
  display: flex;
  flex-direction: column;
  gap: var(--grid-8);
}

#top-about .section-about .div-area-1 > .div-body > .div-content .div-content-item {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  width: 100%;
}

#top-about .section-about .div-area-1 > .div-body > .div-content .div-content-item .div-1 {
  width: var(--grid-22);
}

#top-about .section-about .div-area-1 > .div-body > .div-content .div-content-item .div-2 .figure-image {
  display: flex;
  flex-direction: column;
  gap: 1.6rem
}

#top-about .section-about .div-area-1 > .div-body > .div-content .div-content-item .div-2 .figure-image .picture {
  width: var(--grid-14);
}

#top-about .section-about .div-area-1 > .div-body > .div-content .div-content-item .div-2 .figure-image .picture::after {
  opacity: 0.16;
}

#top-about .section-about .div-area-1 > .div-body > .div-content .div-content-item .div-2 .figure-image figcaption {
  font-family: var(--font-sans-serif);
  font-size: 0.96rem;
  letter-spacing: 0.12em;
  line-height: 1.28;
  margin-block: -0.14em;
}

#top-about .section-about .div-area-2 {
  width: 100%;
  padding-block: var(--grid-6);
  position: relative;
  z-index: 0;
}

#top-about .section-about .div-area-3 {
  width: 100%;
  padding-block: var(--grid-6);
  position: relative;
  z-index: 0;
}

#top-about .section-about .div-area-2 + .div-area-3 {
  margin-block-start: calc(var(--grid-6) * -1);
}

@media (max-width: 768px) and (orientation: portrait) {
  #top-about .section-about .div-area-1 {
    gap: var(--grid-6);
    padding-block: var(--grid-4);
  }

  #top-about .section-about .div-area-1 > .div-body {
    gap: var(--grid-6);
    width: auto;
    margin-inline: var(--grid-2);
  }

  #top-about .section-about .div-area-1 > .div-body > .div-head {
    gap: var(--grid-4);
  }

  #top-about .section-about .div-area-1 > .div-body > .div-content {
    gap: var(--grid-6);
    padding-inline: 0;
  }

  #top-about .section-about .div-area-1 > .div-body > .div-content .ul-content {
    gap: var(--grid-6);
  }

  #top-about .section-about .div-area-1 > .div-body > .div-content .div-content-item {
    flex-direction: column;
    justify-content: initial;
    gap: var(--grid-3);
  }

  #top-about .section-about .div-area-1 > .div-body > .div-content .div-content-item .div-1 {
    width: 100%;
  }

  #top-about .section-about .div-area-1 > .div-body > .div-content .div-content-item .div-2 .figure-image .picture {
    width: var(--grid-16);
  }

  #top-about .section-about .div-area-1 > .div-body > .div-content .div-content-item .div-2 .figure-image .picture::after {
    opacity: 0.16;
  }

  #top-about .section-about .div-area-1 > .div-body > .div-content .div-content-item .div-2 .figure-image figcaption {
    font-size: 0.8rem;
  }

  #top-about .section-about .div-area-2 {
    padding-block: var(--grid-6);
  }

  #top-about .section-about .div-area-3 {
    padding-block: var(--grid-6);
  }

  #top-about .section-about .div-area-2 + .div-area-3 {
    margin-block-start: calc(var(--grid-6) * -1);
  }
}


/*============================================================
  #top-brand
============================================================*/
#top-brand .div-area-2 > .div-body {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  width: 100%;
  margin-inline: auto;
}

#top-brand .div-area-2 > .div-body > .div-1 {
  display: flex;
  flex-direction: column;
  align-items: normal;
  gap: var(--grid-6);
  width: var(--grid-14);
  margin-block: var(--grid-2);
  margin-inline: auto;
}

#top-brand .div-area-2 > .div-body > .div-1 .ul-content {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
}

#top-brand .div-area-2 > .div-body > .div-2 {
  width: var(--grid-64);
}

#top-brand .div-area-2 > .div-body > .div-2 .figure-image {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(4, 1fr);
  width: 100%;
  aspect-ratio: 2 / 3;
}

#top-brand .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(1) {
  grid-column: 1;
  grid-row: 1;
}

#top-brand .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(2) {
  grid-column: 2;
  grid-row: 1;
}

#top-brand .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(3) {
  grid-column: 3 / 5;
  grid-row: 1 / 3;
}

#top-brand .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(4) {
  grid-column: 1 / 3;
  grid-row: 2 / 4;
}

#top-brand .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(5) {
  grid-column: 1 / 3;
  grid-row: 4 / 5;
}

#top-brand .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(6) {
  grid-column: 3 / 5;
  grid-row: 3 / 5;
}

#top-brand .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(1)::after {
  opacity: 0.24;
}

#top-brand .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(2)::after {
  opacity: 0.08;
}

#top-brand .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(3)::after {
  opacity: 0.08;
}

#top-brand .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(4)::after {
  opacity: 0.16;
}

#top-brand .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(5)::after {
  opacity: 0.24;
}

#top-brand .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(6)::after {
  opacity: 0.24;
}

#top-brand .div-area-3 > .div-body {
  display: flex;
  flex-direction: row;
  gap: var(--grid-8);
  align-items: center;
  padding-block: var(--grid);
}

#top-brand .div-area-3 > .div-body > .div-1 .figure-image {
  display: flex;
  flex-direction: row;
}

#top-brand .div-area-3 > .div-body > .div-1 .figure-image .picture {
  width: var(--grid-12);
}

#top-brand .div-area-3 > .div-body > .div-1 .figure-image .picture::after {
  opacity: 0.32;
}

#top-brand .div-area-3 > .div-body > .div-2 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
  width: var(--grid-28);
}

@media (max-width: 768px) and (orientation: portrait) {
  #top-brand .div-area-2 > .div-body {
    flex-direction: column;
    align-items: initial;
    gap: var(--grid-4);
  }

  #top-brand .div-area-2 > .div-body > .div-1 {
    width: auto;
    margin-block: 0;
    margin-inline: var(--grid-2);
  }

  #top-brand .div-area-2 > .div-body > .div-1 .ul-content {
    width: var(--grid-36);
  }

  #top-brand .div-area-2 > .div-body > .div-2 {
    width: 100%;
  }

  #top-brand .div-area-3 > .div-body {
    gap: var(--grid-4);
    padding-block: 0;
  }

  #top-brand .div-area-3 > .div-body > .div-1 .figure-image {
    flex-direction: column;
  }

  #top-brand .div-area-3 > .div-body > .div-2 {
    flex: 1;
    width: auto;
    margin-inline: var(--grid-2);
  }
}


/*============================================================
  #top-philosophy
============================================================*/
#top-philosophy {
  color: var(--color-white);
  background-color: var(--color-mossgreen);
}

#top-philosophy .div-area-2 > .div-body {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-end;
  width: 100%;
  margin-inline: auto;
}

#top-philosophy .div-area-2 > .div-body > .div-1 {
  display: flex;
  flex-direction: column;
  align-items: normal;
  gap: var(--grid-6);
  width: var(--grid-14);
  margin-block: var(--grid-2);
  margin-inline: auto;
}

#top-philosophy .div-area-2 > .div-body > .div-1 .ul-content {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
}

#top-philosophy .div-area-2 > .div-body > .div-1 .ul-content .p-label {
  display: flex;
  flex-direction: row;
  gap: 0.4rem;
}

#top-philosophy .div-area-2 > .div-body > .div-2 {
  width: var(--grid-64);
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(3, 1fr);
  width: 100%;
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture {
  height: var(--grid-24);
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(1) {
  grid-column: 1;
  grid-row: 1;
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(2) {
  grid-column: 2;
  grid-row: 1;
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(3) {
  grid-column: 3 / 5;
  grid-row: 1;
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(4) {
  grid-column: 1 / 4;
  grid-row: 2;
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(5) {
  grid-column: 4;
  grid-row: 2;
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(6) {
  grid-column: 1 / 3;
  grid-row: 3;
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(7) {
  grid-column: 3 / 5;
  grid-row: 3;
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(1)::after {
  opacity: 0.32;
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(2)::after {
  opacity: 0.32;
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(3)::after {
  opacity: 0.24;
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(4)::after {
  opacity: 0.24;
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(5)::after {
  opacity: 0.24;
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(6)::after {
  opacity: 0.32;
}

#top-philosophy .div-area-2 > .div-body > .div-2 .figure-image .picture:nth-of-type(7)::after {
  opacity: 0.32;
}

#top-philosophy .div-area-3 > .div-body {
  display: flex;
  flex-direction: row-reverse;
  flex-wrap: wrap;
  column-gap: var(--grid-8);
  row-gap: var(--grid-4);
  align-items: center;
  padding-block: var(--grid);
}

#top-philosophy .div-area-3 > .div-body > .div-1 .figure-image {
  display: flex;
  flex-direction: row;
}

#top-philosophy .div-area-3 > .div-body > .div-1 .figure-image .picture {
  width: var(--grid-12);
}

#top-philosophy .div-area-3 > .div-body > .div-1 .figure-image .picture::after {
  opacity: 0.32;
}

#top-philosophy .div-area-3 > .div-body > .div-2 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
  width: var(--grid-28);
}

#top-philosophy .div-area-3 > .div-body > .div-3 {
  width: var(--grid-78);
  margin-inline: auto;
}

#top-philosophy .div-area-3 > .div-body > .div-3 .ul-activity > li {
  padding-block: var(--grid-2);
}

#top-philosophy .div-area-3 > .div-body > .div-3 .ul-activity > li + li {
  border-top: 1px solid rgba(255, 255, 255, 0.16);
}

@media (max-width: 768px) and (orientation: portrait) {
  #top-philosophy .div-area-2 > .div-body {
    flex-direction: column;
    align-items: initial;
    gap: var(--grid-4);
  }

  #top-philosophy .div-area-2 > .div-body > .div-1 {
    width: auto;
    margin-block: 0;
    margin-inline: var(--grid-2);
  }

  #top-philosophy .div-area-2 > .div-body > .div-1 .ul-content {
    width: var(--grid-36);
  }

  #top-philosophy .div-area-2 > .div-body > .div-1 .ul-content .p-label {
    display: flex;
    flex-direction: row;
    gap: 0.4rem;
  }

  #top-philosophy .div-area-2 > .div-body > .div-2 {
    width: 100%;
  }

  #top-philosophy .div-area-3 > .div-body {
    gap: var(--grid-4);
    padding-block: 0;
  }

  #top-philosophy .div-area-3 > .div-body > .div-1 .figure-image {
    flex-direction: column;
  }

  #top-philosophy .div-area-3 > .div-body > .div-2 {
    flex: 1;
    width: auto;
    margin-inline: var(--grid-2);
  }

  #top-philosophy .div-area-3 > .div-body > .div-3 {
    width: auto;
    margin-inline: var(--grid-2);
  }
}


/*============================================================
  #top-lifestyle
============================================================*/
#top-lifestyle .div-area-2 > .div-body {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  justify-content: space-between;
  width: var(--grid-70);
  margin-inline: auto;
}

#top-lifestyle .div-area-2 > .div-body > .div-1 {
  display: flex;
  flex-direction: column;
  align-items: normal;
  gap: var(--grid-4);
  width: var(--grid-16);
}

#top-lifestyle .div-area-2 > .div-body > .div-2 {
  width: var(--grid-34);
}

#top-lifestyle .div-area-3 > .div-body {
  width: var(--grid-82);
  margin-inline: auto;
}

@media (max-width: 768px) and (orientation: portrait) {
  #top-lifestyle .div-area-2 > .div-body {
    flex-direction: column;
    align-items: initial;
    justify-content: initial;
    gap: var(--grid-4);
    width: auto;
    margin-inline: var(--grid-2);
  }

  #top-lifestyle .div-area-2 > .div-body > .div-1 {
    gap: var(--grid-4);
    width: var(--grid-36);
  }

  #top-lifestyle .div-area-2 > .div-body > .div-2 {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #top-lifestyle .div-area-3 > .div-body {
    width: auto;
    margin-inline: var(--grid-2);
  }
}


/*------------------------------------------------------------


  #about


------------------------------------------------------------*/
/*============================================================
  #about-head
============================================================*/
#about-head {
  position: relative;
  z-index: 0;
}

#about-head .div-image {
  width: var(--grid-86);
  margin-inline: auto;
}

#about-head .div-image .figure-image {
  width: 100%;
  aspect-ratio: 3 / 2;
}

#about-head .div-image .figure-image .picture::after {
  opacity: 0.16;
}

@media (max-width: 768px) and (orientation: portrait) {
  #about-head .div-image {
    width: auto;
    margin-inline: var(--grid);
  }

  #about-head .div-image .figure-image {
    aspect-ratio: 1 / 1;
  }
}


/*============================================================
  #about .section-about
============================================================*/
#about .section-about .header-section {
  position: relative;
  z-index: 0;
}

#about .section-about .header-section > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
  width: var(--grid-78);
  padding-block: var(--grid-4);
  margin-inline: auto;
  border-bottom: 1px solid rgba(0, 0, 0, 0.16);
}

#about .section-about #about-philosophy-header.header-section > .div-body {
  border-bottom-color: rgba(255, 255, 255, 0.16);
}

#about .section-about .header-section .div-theme {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--grid-3);
  width: var(--grid-78);
  text-align: center;
  margin-inline: auto;
}

#about .section-about .div-concept .div-head-concept {
  width: var(--grid-78);
  padding-block-start: var(--grid-4);
  margin-inline: auto;
}

@media (max-width: 768px) and (orientation: portrait) {
  #about .section-about .header-section > .div-body {
    gap: var(--grid-3);
    width: auto;
    padding-block: var(--grid-4);
    margin-inline: var(--grid-2);
  }

  #about .section-about .header-section .div-theme {
    gap: var(--grid-3);
    width: 100%;
  }

  #about .section-about .div-concept .div-head-concept {
    width: auto;
    padding-block-start: var(--grid-4);
    margin-inline: var(--grid-2);
  }
}


/*============================================================
  #about-brand
============================================================*/
#about-brand {
  position: relative;
  z-index: 0;
}

#about-brand .div-concept .div-concept-about {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  justify-content: space-between;
}

#about-brand .div-concept .div-concept-about .div-1 {
  width: var(--grid-22);
}

#about-brand .div-concept .div-concept-about .div-1 .figure-image .picture {
  width: var(--grid-8);
}

#about-brand .div-concept .div-concept-about .div-1 .figure-image .picture::after {
  opacity: 0.16;
}

#about-brand .div-concept .div-concept-about .div-2 {
  width: var(--grid-40);
}

#about-brand .div-concept .div-concept-about .div-2 .figure-image {
  display: flex;
  flex-direction: column-reverse;
  gap: var(--grid);
}

#about-brand .div-concept .div-concept-about .div-2 .figure-image .picture::after {
  opacity: 0.16;
}

#about-brand .div-concept .div-concept-about .div-2 .figure-image figcaption {
  font-family: var(--font-sans-serif);
  font-size: 0.96rem;
  letter-spacing: 0.12em;
  line-height: 1.28;
  margin-block: -0.14em;
}

#about-brand .div-concept .div-content .div-area-1 {
  width: var(--grid-78);
  padding-block: var(--grid-4);
  margin-inline: auto;
}

#about-brand .div-concept .div-content .div-area-2 {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  justify-content: space-between;
  width: var(--grid-78);
  padding-block: var(--grid-2);
  margin-inline: auto;
}

#about-brand .div-concept .div-content .div-area-2 .div-1 {
  width: var(--grid-40);
}

#about-brand .div-concept .div-content .div-area-2 .div-2 {
  width: var(--grid-16);
}

#about-brand .div-concept .div-content .div-area-2 .div-2 .figure-image .picture {
  width: var(--grid-8);
}

#about-brand .div-concept .div-content .div-area-2 .div-2 .figure-image .picture::after {
  opacity: 0.08;
}

#about-brand .div-concept .div-content .div-area-2 .div-2 .figure-image + .h-heading {
  margin-block-start: var(--grid);
}

#about-brand .div-concept .div-content .div-area-3 {
  width: var(--grid-70);
  padding-block: var(--grid-4);
  margin-inline: auto;
}

#about-brand .div-concept .div-content .div-area-4 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 100%;
  aspect-ratio: 3 / 2;
  position: relative;
  z-index: 0;
}

#about-brand .div-concept .div-content .div-area-4 .figure-image {
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: -1;
}

#about-brand .div-concept .div-content .div-area-4 .figure-image .picture::after {
  opacity: 0.4;
}

#about-brand .div-concept .div-content .div-area-4 .ul-description {
  display: flex;
  flex-direction: column;
  gap: var(--grid-6);
  width: var(--grid-70);
  color: var(--color-white);
  margin-inline: auto;
}

#about-brand .div-concept .div-content .div-area-4 .ul-description > li {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: end;
  gap: var(--grid);
  width: 100%;
}

#about-brand .div-concept .div-content .div-area-4 .ul-description > li .line {
  display: block;
  height: 0.6px;
  background-color: var(--color-white);
  opacity: 0.48;
  position: relative;
}

#about-brand .div-concept .div-content .div-area-4 .ul-description > li:nth-of-type(1) .line {
  width: 56%;
}

#about-brand .div-concept .div-content .div-area-4 .ul-description > li:nth-of-type(2) .line {
  width: 32%;
}

#about-brand .div-concept .div-content .div-area-4 .ul-description > li:nth-of-type(3) .line {
  width: 8%;
}

#about-brand .div-concept .div-content .div-area-4 .ul-description > li .line::before {
  content: "";
  display: block;
  width: 4px;
  height: 4px;
  background-color: var(--color-white);
  border-radius: 4px;
  position: absolute;
  left: 0;
  top: 0;
  transform: translate(-50%, -50%);
}

#about-brand .div-concept .div-content .div-area-4 .ul-description > li .text {
  display: flex;
  flex-direction: row;
  align-items: baseline;
  gap: 0.8rem;
}

#about-brand .div-concept .div-content .div-area-4 .ul-description > li .text .en {
  font-family: var(--font-cormorant);
  font-size: 1.2rem;
  letter-spacing: 0.02em;
  margin-block: -0.096em;
  white-space: nowrap;
}

#about-brand .div-concept .div-content .div-area-4 .ul-description > li .text .jp {
  font-family: var(--font-sans-serif);
  font-size: 0.8rem;
  letter-spacing: 0.16em;
  margin-block: -0.096em;
  white-space: nowrap;
}

#about-brand .div-concept .div-content .div-area-5 {
  width: var(--grid-78);
  padding-block: var(--grid-4);
  margin-inline: auto;
  margin-block-start: var(--grid-2);
}

#about-brand .div-concept .div-content .div-area-5 .div-concept-about {
  flex-direction: row-reverse;
}

#about-brand .div-gallery {
  width: 100%;
}

#about-brand .div-gallery .figure-image {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  grid-template-rows: repeat(4, 1fr);
  width: 100%;
  aspect-ratio: 4 / 3;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(1) {
  grid-column: 1;
  grid-row: 1;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(2) {
  grid-column: 2;
  grid-row: 1;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(3) {
  grid-column: 3 / 5;
  grid-row: 1;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(4) {
  grid-column: 1 / 4;
  grid-row: 2;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(5) {
  grid-column: 4;
  grid-row: 2;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(6) {
  grid-column: 1 / 5;
  grid-row: 3 / 5;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(7) {
  grid-column: 5;
  grid-row: 1;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(8) {
  grid-column: 6;
  grid-row: 1;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(9) {
  grid-column: 7 / 9;
  grid-row: 1 / 3;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(10) {
  grid-column: 5 / 7;
  grid-row: 2 / 4;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(11) {
  grid-column: 5 / 7;
  grid-row: 4 / 5;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(12) {
  grid-column: 7 / 9;
  grid-row: 3 / 5;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(1)::after {
  opacity: 0.32;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(2)::after {
  opacity: 0.32;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(3)::after {
  opacity: 0.32;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(4)::after {
  opacity: 0.24;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(5)::after {
  opacity: 0.24;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(6)::after {
  opacity: 0.32;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(7)::after {
  opacity: 0.24;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(8)::after {
  opacity: 0.08;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(9)::after {
  opacity: 0.08;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(10)::after {
  opacity: 0.16;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(11)::after {
  opacity: 0.24;
}

#about-brand .div-gallery .figure-image .picture:nth-of-type(12)::after {
  opacity: 0.24;
}

@media (max-width: 768px) and (orientation: portrait) {
  #about-brand .div-concept .div-concept-about {
    flex-direction: column;
    align-items: initial;
    justify-content: initial;
    gap: var(--grid-4);
  }

  #about-brand .div-concept .div-concept-about .div-1 {
    width: 100%;
  }

  #about-brand .div-concept .div-concept-about .div-1 .figure-image .picture {
    width: var(--grid-8);
  }

  #about-brand .div-concept .div-concept-about .div-2 {
    width: var(--grid-36);
  }

  #about-brand .div-concept .div-concept-about .div-2 .figure-image {
    flex-direction: column;
  }

  #about-brand .div-concept .div-concept-about .div-2 .figure-image figcaption {
    font-size: 0.8rem;
  }

  #about-brand .div-concept .div-content .div-area-1 {
    width: auto;
    padding-block: var(--grid-4);
    margin-inline: var(--grid-2);
  }

  #about-brand .div-concept .div-content .div-area-2 {
    flex-direction: column;
    align-items: initial;
    justify-content: initial;
    width: auto;
    padding-block: var(--grid-4);
    margin-inline: var(--grid-2);
  }

  #about-brand .div-concept .div-content .div-area-2 .div-1 {
    width: var(--grid-40);
    margin-inline: auto;
  }

  #about-brand .div-concept .div-content .div-area-2 .div-2 {
    width: 100%;
    margin-top: calc(var(--grid-8) * -1);
  }

  #about-brand .div-concept .div-content .div-area-3 {
    width: auto;
    padding-block: var(--grid-4);
    margin-inline: var(--grid-4);
  }

  #about-brand .div-concept .div-content .div-area-4 {
    aspect-ratio: 1 / 1;
  }

  #about-brand .div-concept .div-content .div-area-4 .ul-description {
    width: var(--grid-42);
  }

  #about-brand .div-concept .div-content .div-area-4 .ul-description > li:nth-of-type(1) .line {
    width: 40%;
  }

  #about-brand .div-concept .div-content .div-area-4 .ul-description > li:nth-of-type(2) .line {
    width: 24%;
  }

  #about-brand .div-concept .div-content .div-area-4 .ul-description > li:nth-of-type(3) .line {
    width: 8%;
  }

  #about-brand .div-concept .div-content .div-area-4 .ul-description > li .text {
    flex-direction: column;
    align-items: initial;
    gap: 0.96rem;
  }

  #about-brand .div-concept .div-content .div-area-4 .ul-description > li .text .en {
    font-size: 1.04rem;
  }

  #about-brand .div-concept .div-content .div-area-4 .ul-description > li .text .jp {
    font-size: 0.64rem;
  }

  #about-brand .div-concept .div-content .div-area-5 {
    width: auto;
    padding-block: var(--grid-4);
    margin-inline: var(--grid-2);
    margin-block-start: 0;
  }

  #about-brand .div-concept .div-content .div-area-5 .div-concept-about {
    flex-direction: column;
  }

  #about-brand .div-gallery {
    width: 100%;
  }

  #about-brand .div-gallery .figure-image {
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(8, 1fr);
    aspect-ratio: 1 / 3;
  }

  #about-brand .div-gallery .figure-image .picture:nth-of-type(7) {
    grid-column: 1;
    grid-row: 5;
  }

  #about-brand .div-gallery .figure-image .picture:nth-of-type(8) {
    grid-column: 2;
    grid-row: 5;
  }

  #about-brand .div-gallery .figure-image .picture:nth-of-type(9) {
    grid-column: 3 / 5;
    grid-row: 5 / 7;
  }

  #about-brand .div-gallery .figure-image .picture:nth-of-type(10) {
    grid-column: 1 / 3;
    grid-row: 6 / 8;
  }

  #about-brand .div-gallery .figure-image .picture:nth-of-type(11) {
    grid-column: 1 / 3;
    grid-row: 8;
  }

  #about-brand .div-gallery .figure-image .picture:nth-of-type(12) {
    grid-column: 3 / 5;
    grid-row: 7 / 9;
  }
}


/*============================================================
  #about-brand-value
============================================================*/
#about-brand-value {
  padding-block: var(--grid-6);
  position: relative;
  z-index: 0;
}

#about-brand-value > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
  width: var(--grid-70);
  margin-inline: auto;
}

#about-brand-value > .div-body > .div-content {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
  width: 100%;
}

#about-brand-value > .div-body > .div-content .ul-value > li {
  width: var(--grid-18);
}

#about-brand-value > .div-body > .div-content .ul-value > li .div-column-small > .div-2 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
}

@media (max-width: 768px) and (orientation: portrait) {
  #about-brand-value {
    padding-block: var(--grid-4);
  }

  #about-brand-value > .div-body {
    flex-direction: column;
    gap: var(--grid-4);
    width: auto;
    margin-inline: var(--grid-4);
  }

  #about-brand-value > .div-body > .div-content {
    flex-direction: column;
  }

  #about-brand-value > .div-body > .div-content .ul-value {
    row-gap: var(--grid-4);
  }

  #about-brand-value > .div-body > .div-content .ul-value > li {
    width: 100%;
  }

  #about-brand-value > .div-body > .div-content .ul-value > li .div-column-small {
    flex-direction: row-reverse;
    gap: var(--grid-4);
  }

  #about-brand-value > .div-body > .div-content .ul-value > li .div-column-small > .div-1 {
    width: var(--grid-10);
  }

  #about-brand-value > .div-body > .div-content .ul-value > li .div-column-small > .div-2 {
    flex: 1;
  }
}


/*============================================================
  #about-brand-profile
============================================================*/
#about-brand-profile {
  background-color: var(--color-lightgray);
  padding-block: var(--grid-4);
  position: relative;
  z-index: 0;
}

#about-brand-profile > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
  width: 100%;
}

#about-brand-profile .div-area-1 {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-end;
  justify-content: space-between;
  width: var(--grid-70);
  margin-block-start: var(--grid-4);
  margin-inline: auto;
}

#about-brand-profile .div-area-1 .div-1 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
  width: var(--grid-22);
}

#about-brand-profile .div-area-1 .div-1 > .div-content {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: 100%;
}

#about-brand-profile .div-area-1 .div-1 > .div-content .div-brand-profile {
  padding-block-start: var(--grid-2);
  border-top: 1px solid rgba(0, 0, 0, 0.16);
}

#about-brand-profile .div-area-1 .div-2 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: var(--grid-24);
}

#about-brand-profile .div-area-1 .div-2 .div-image .figure-image {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  width: 100%;
}

#about-brand-profile .div-area-1 .div-2 .div-image .figure-image .picture::after {
  opacity: 0.32;
}

#about-brand-profile .div-area-1 .div-2 .div-map .map {
  width: 100%;
  aspect-ratio: 1 / 1;
}

#about-brand-profile .div-area-2 {
  position: relative;
  z-index: 0;
}

#about-brand-profile .div-area-2 .article-featured-staff {
  width: var(--grid-82);
  margin-inline: auto;
}

@media (max-width: 768px) and (orientation: portrait) {
  #about-brand-profile {
    padding-block: var(--grid-4) var(--grid-2);
  }

  #about-brand-profile > .div-body {
    gap: var(--grid-3);
  }

  #about-brand-profile .div-area-1 {
    flex-direction: column;
    align-items: initial;
    justify-content: initial;
    gap: var(--grid-3);
    width: auto;
    margin-block-start: var(--grid-2);
    margin-inline: var(--grid-4);
  }

  #about-brand-profile .div-area-1 .div-1 {
    gap: var(--grid-3);
    width: auto;
  }

  #about-brand-profile .div-area-1 .div-1 > .div-content {
    gap: var(--grid-3);
  }

  #about-brand-profile .div-area-1 .div-1 > .div-content .div-brand-profile {
    padding-block-start: var(--grid-2);
  }

  #about-brand-profile .div-area-1 .div-2 {
    width: 100%;
  }

  #about-brand-profile .div-area-1 .div-2 .div-image .figure-image {
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: unset;
  }

  #about-brand-profile .div-area-2 .article-featured-staff {
    width: auto;
    margin-inline: var(--grid-2);
  }
}


/*============================================================
  #about-philosophy
============================================================*/
#about-philosophy {
  color: var(--color-white);
  background-color: var(--color-mossgreen);
  position: relative;
  z-index: 0;
}

#about-philosophy .div-concept .div-content .div-area-1 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-6);
  width: var(--grid-78);
  padding-block: var(--grid-6);
  margin-inline: auto;
}

#about-philosophy .div-concept .div-content .div-area-1 .ul-concept > li {
  width: var(--grid-22);
}

#about-philosophy .div-concept .div-content .div-area-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: 1fr;
  width: 100%;
}

#about-philosophy .div-concept .div-content .div-area-2 .figure-image {
  width: 100%;
  aspect-ratio: 1 / 1;
}

#about-philosophy .div-concept .div-content .div-area-2 .figure-image .picture::after {
  opacity: 0.24;
}

#about-philosophy .div-concept .div-content .div-area-2 .figure-image figcaption {
  font-family: var(--font-sans-serif);
  font-size: 0.96rem;
  letter-spacing: 0.12em;
  line-height: 1.28;
  margin-block: -0.14em;
  position: absolute;
  left: var(--grid-3);
  bottom: var(--grid-2);
  z-index: 2;
}

#about-philosophy .div-gallery {
  width: 100%;
}

#about-philosophy .div-gallery .figure-image {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(2, 1fr);
  width: 100%;
  aspect-ratio: 2 / 1;
}

#about-philosophy .div-gallery .figure-image .picture:nth-of-type(1) {
  grid-column: 1;
  grid-row: 1;
}

#about-philosophy .div-gallery .figure-image .picture:nth-of-type(2) {
  grid-column: 2 / 4;
  grid-row: 1;
}

#about-philosophy .div-gallery .figure-image .picture:nth-of-type(3) {
  grid-column: 1 / 3;
  grid-row: 2;
}

#about-philosophy .div-gallery .figure-image .picture:nth-of-type(4) {
  grid-column: 3;
  grid-row: 2;
}

#about-philosophy .div-gallery .figure-image .picture:nth-of-type(1)::after {
  opacity: 0.24;
}

#about-philosophy .div-gallery .figure-image .picture:nth-of-type(2)::after {
  opacity: 0.32;
}

#about-philosophy .div-gallery .figure-image .picture:nth-of-type(3)::after {
  opacity: 0.32;
}

#about-philosophy .div-gallery .figure-image .picture:nth-of-type(4)::after {
  opacity: 0.24;
}

@media (max-width: 768px) and (orientation: portrait) {
  #about-philosophy .div-concept .div-content .div-area-1 {
    gap: var(--grid-6);
    width: auto;
    padding-block: var(--grid-6);
    margin-inline: var(--grid-2);
  }

  #about-philosophy .div-concept .div-content .div-area-1 .ul-concept {
    row-gap: var(--grid-4);
  }

  #about-philosophy .div-concept .div-content .div-area-1 .ul-concept > li {
    width: 100%;
  }

  #about-philosophy .div-concept .div-content .div-area-2 {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr;
  }

  #about-philosophy .div-concept .div-content .div-area-2 .figure-image {
    aspect-ratio: 4 / 3;
  }

  #about-philosophy .div-concept .div-content .div-area-2 .figure-image figcaption {
    font-size: 0.8rem;
    left: var(--grid-2);
  }

  #about-philosophy .div-gallery {
    width: 100%;
  }

  #about-philosophy .div-gallery .figure-image {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(3, 1fr);
    aspect-ratio: 3 / 4;
  }

  #about-philosophy .div-gallery .figure-image .picture:nth-of-type(1) {
    grid-column: 1;
    grid-row: 2;
  }

  #about-philosophy .div-gallery .figure-image .picture:nth-of-type(2) {
    grid-column: 1 / 3;
    grid-row: 1;
  }

  #about-philosophy .div-gallery .figure-image .picture:nth-of-type(3) {
    grid-column: 1 / 3;
    grid-row: 3;
  }

  #about-philosophy .div-gallery .figure-image .picture:nth-of-type(4) {
    grid-column: 2;
    grid-row: 2;
  }
}


/*============================================================
  #about-philosophy-vision
============================================================*/
#about-philosophy-vision {
  padding-block: var(--grid-6) var(--grid-4);
  position: relative;
  z-index: 0;
}

#about-philosophy-vision > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
}

#about-philosophy-vision > .div-body > .div-area-1 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
  width: var(--grid-70);
  margin-inline: auto;
}

#about-philosophy-vision > .div-body > .div-area-1 > .div-content {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
  width: 100%;
}

#about-philosophy-vision > .div-body > .div-area-1 > .div-content .ul-vision > li {
  width: var(--grid-18);
}

#about-philosophy-vision > .div-body > .div-area-1 > .div-content .ul-vision > li .div-column-small > .div-2 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
}

#about-philosophy-vision > .div-body > .div-area-1 > .div-content .ul-vision > li .div-column-small .figure-image .picture::after {
  opacity: 0.32;
}

#about-philosophy-vision > .div-body > .div-area-1 > .div-content .ul-vision > li .div-column-small .p-label {
  display: flex;
  flex-direction: row;
  gap: 0.4rem;
}

#about-philosophy-vision > .div-body > .div-area-2 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: var(--grid-70);
  margin-inline: auto;
}

#about-philosophy-vision > .div-body > .div-area-3 {
  width: var(--grid-82);
  margin-inline: auto;
}

#about-philosophy-vision > .div-body > .div-area-3 .article-featured-tabechaba {
  border: 1px solid rgba(255, 255, 255, 0.16);
}

@media (max-width: 768px) and (orientation: portrait) {
  #about-philosophy-vision {
    padding-block: var(--grid-6) var(--grid-4);
  }

  #about-philosophy-vision > .div-body {
    gap: var(--grid-4);
  }

  #about-philosophy-vision > .div-body > .div-area-1 {
    gap: var(--grid-4);
    width: auto;
    margin-inline: var(--grid-4);
  }

  #about-philosophy-vision > .div-body > .div-area-1 > .div-content .ul-vision {
    row-gap: var(--grid-4);
  }

  #about-philosophy-vision > .div-body > .div-area-1 > .div-content .ul-vision > li {
    width: 100%;
  }

  #about-philosophy-vision > .div-body > .div-area-1 > .div-content .ul-vision > li .div-column-small {
    flex-direction: row-reverse;
    gap: var(--grid-4);
  }

  #about-philosophy-vision > .div-body > .div-area-1 > .div-content .ul-vision > li .div-column-small > .div-1 {
    width: var(--grid-10);
  }

  #about-philosophy-vision > .div-body > .div-area-1 > .div-content .ul-vision > li .div-column-small > .div-2 {
    flex: 1;
  }

  #about-philosophy-vision > .div-body > .div-area-2 {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #about-philosophy-vision > .div-body > .div-area-3 {
    width: auto;
    margin-inline: var(--grid-2);
  }
}


/*============================================================
  #about-philosophy-experience
============================================================*/
#about-philosophy-experience {
  color: var(--color-black);
  background-color: var(--color-lightgray);
  padding-block: var(--grid-10) var(--grid-4);
  position: relative;
  z-index: 0;
}

#about-philosophy-experience > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-6);
  width: 100%;
}

#about-philosophy-experience .div-area-1 {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-end;
  justify-content: space-between;
  width: var(--grid-70);
  margin-inline: auto;
}

#about-philosophy-experience .div-area-1 .div-1 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
  width: var(--grid-22);
}

#about-philosophy-experience .div-area-1 .div-1 > .div-content {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: 100%;
}

#about-philosophy-experience .div-area-1 .div-2 {
  width: var(--grid-24);
}

#about-philosophy-experience .div-area-1 .div-2 .figure-image {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  width: 100%;
}

#about-philosophy-experience .div-area-1 .div-2 .figure-image .picture::after {
  opacity: 0.32;
}

#about-philosophy-experience .div-area-2 .div-activity {
  width: var(--grid-82);
  border: 1px solid rgba(0, 0, 0, 0.16);
  padding-inline: var(--grid-6);
  margin-inline: auto;
  position: relative;
  z-index: 0;
}

#about-philosophy-experience .div-area-2 .div-activity .ul-activity > li {
  padding-block: var(--grid-2);
}

#about-philosophy-experience .div-area-2 .div-activity .ul-activity > li + li {
  border-top: 1px solid rgba(0, 0, 0, 0.16);
}

@media (max-width: 768px) and (orientation: portrait) {
  #about-philosophy-experience {
    padding-block: var(--grid-6) var(--grid-4);
  }

  #about-philosophy-experience > .div-body {
    gap: var(--grid-4);
  }

  #about-philosophy-experience .div-area-1 {
    flex-direction: column;
    align-items: initial;
    justify-content: initial;
    gap: var(--grid-4);
    width: auto;
    margin-inline: var(--grid-4);
  }

  #about-philosophy-experience .div-area-1 .div-1 {
    gap: var(--grid-3);
    width: 100%;
  }

  #about-philosophy-experience .div-area-1 .div-1 > .div-content {
    display: flex;
    flex-direction: column;
    gap: var(--grid-2);
    width: 100%;
  }

  #about-philosophy-experience .div-area-1 .div-2 {
    width: 100%;
  }

  #about-philosophy-experience .div-area-1 .div-2 .figure-image {
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: unset;
  }

  #about-philosophy-experience .div-area-2 .div-activity {
    width: auto;
    border: 1px solid rgba(0, 0, 0, 0.16);
    padding-inline: var(--grid-2);
    margin-inline: var(--grid-2);
  }
}


/*============================================================
  #about-lifestyle
============================================================*/
#about-lifestyle {
  position: relative;
  z-index: 0;
}

#about-lifestyle > .div-image {
  width: var(--grid-86);
  aspect-ratio: 16 / 9;
  margin-block-start: var(--grid-2);
  margin-inline: auto;
}

#about-lifestyle > .div-image .figure-image {
  aspect-ratio: 16 / 9;
}

#about-lifestyle .div-concept .div-content .div-area-1 {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  width: var(--grid-78);
  padding-block: var(--grid-6);
  margin-inline: auto;
}

#about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
  width: var(--grid-34);
}

#about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about .div-1 .figure-image {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--grid);
}

#about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about .div-1 .figure-image .picture {
  aspect-ratio: 1 / 1;
}

#about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about .div-1 .figure-image .picture::after {
  opacity: 0.16;
}

#about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about .div-1 .figure-image figcaption {
  font-family: var(--font-sans-serif);
  font-size: 0.96rem;
  letter-spacing: 0.12em;
  line-height: 1.28;
  margin-block: -0.14em;
}

#about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about .div-2 .div-paragraph {
  display: flex;
  flex-direction: row;
  gap: var(--grid-4);
}

#about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about .div-2 .div-paragraph .div-text {
  flex: 1;
}

#about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about .div-2 .div-paragraph .div-image {
  width: var(--grid-6);
}

#about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about .div-2 .div-paragraph .div-image .figure-image .picture::after {
  opacity: 0.08;
}

#about-lifestyle .div-concept .div-area-2 {
  width: 100%;
}

#about-lifestyle .div-concept .div-area-2 .figure-image {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  grid-template-rows: repeat(3, 1fr);
  width: 100%;
  aspect-ratio: 16 / 9;
}

#about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(1) {
  grid-column: 1 / 3;
  grid-row: 1 / 3;
}

#about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(2) {
  grid-column: 3 / 7;
  grid-row: 1;
}

#about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(3) {
  grid-column: 7;
  grid-row: 1;
}

#about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(4) {
  grid-column: 8;
  grid-row: 1;
}

#about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(5) {
  grid-column: 1 / 3;
  grid-row: 3;
}

#about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(6) {
  grid-column: 3 / 5;
  grid-row: 2 / 4;
}

#about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(7) {
  grid-column: 5 / 9;
  grid-row: 2 / 4;
}

#about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(1)::after {
  opacity: 0.24;
}

#about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(2)::after {
  opacity: 0.24;
}

#about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(3)::after {
  opacity: 0.32;
}

#about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(4)::after {
  opacity: 0.32;
}

#about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(5)::after {
  opacity: 0.16;
}

#about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(6)::after {
  opacity: 0.32;
}

#about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(7)::after {
  opacity: 0.16;
}

@media (max-width: 768px) and (orientation: portrait) {
  #about-lifestyle > .div-image {
    width: auto;
    margin-block-start: var(--grid);
    margin-inline: var(--grid);
  }

  #about-lifestyle > .div-image .figure-image {
    aspect-ratio: 1 / 1;
  }

  #about-lifestyle .div-concept .div-content .div-area-1 {
    flex-direction: column;
    justify-content: initial;
    gap: var(--grid-6);
    width: auto;
    padding-block: var(--grid-4);
    margin-inline: var(--grid-2);
  }

  #about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about {
    gap: var(--grid-4);
    width: 100%;
  }

  #about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about .div-1 {
    width: var(--grid-36);
  }

  #about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about .div-1 .figure-image figcaption {
    font-size: 0.8rem;
  }

  #about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about .div-2 .div-paragraph {
    gap: var(--grid-2);
  }

  #about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about .div-2 .div-paragraph .div-text {
    flex: 1;
  }

  #about-lifestyle .div-concept .div-content .div-area-1 .div-concept-about .div-2 .div-paragraph .div-image {
    width: var(--grid-8);
  }

  #about-lifestyle .div-concept .div-area-2 .figure-image {
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(6, 1fr);
    aspect-ratio: 1 / 2;
  }

  #about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(1) {
    grid-column: 1 / 3;
    grid-row: 1 / 3;
  }

  #about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(2) {
    grid-column: 1 / 5;
    grid-row: 4;
  }

  #about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(3) {
    grid-column: 3;
    grid-row: 1;
  }

  #about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(4) {
    grid-column: 4;
    grid-row: 1;
  }

  #about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(5) {
    grid-column: 1 / 3;
    grid-row: 3;
  }

  #about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(6) {
    grid-column: 3 / 5;
    grid-row: 2 / 4;
  }

  #about-lifestyle .div-concept .div-area-2 .figure-image .picture:nth-of-type(7) {
    grid-column: 1 / 5;
    grid-row: 5 / 7;
  }
}


/*============================================================
  #about-lifestyle-relax
============================================================*/
#about-lifestyle-relax {
  display: flex;
  flex-direction: column;
  gap: var(--grid-6);
  width: 100%;
  background-color: var(--color-lightgray);
  padding-block: var(--grid-10) var(--grid-4);
}

#about-lifestyle-relax .div-area-1 > .div-body {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  justify-content: space-between;
  width: var(--grid-70);
  margin-inline: auto;
}

#about-lifestyle-relax .div-area-1 > .div-body > .div-1 {
  display: flex;
  flex-direction: column;
  align-items: normal;
  gap: var(--grid-4);
  width: var(--grid-22);
}

#about-lifestyle-relax .div-area-1 > .div-body > .div-2 {
  width: var(--grid-34);
}

#about-lifestyle-relax .div-area-2 > .div-body {
  width: var(--grid-82);
  margin-inline: auto;
}

@media (max-width: 768px) and (orientation: portrait) {
  #about-lifestyle-relax {
    gap: var(--grid-4);
    padding-block: var(--grid-6) var(--grid-4);
  }

  #about-lifestyle-relax .div-area-1 > .div-body {
    flex-direction: column;
    align-items: initial;
    justify-content: initial;
    gap: var(--grid-4);
    width: auto;
    margin-inline: var(--grid-4);
  }

  #about-lifestyle-relax .div-area-1 > .div-body > .div-1 {
    gap: var(--grid-4);
    width: 100%;
  }

  #about-lifestyle-relax .div-area-1 > .div-body > .div-2 {
    width: 100%;
  }

  #about-lifestyle-relax .div-area-2 > .div-body {
    width: auto;
    margin-inline: var(--grid-2);
  }
}


/*------------------------------------------------------------


  #products


------------------------------------------------------------*/
/*============================================================
  #products-page
============================================================*/
#products-page {
  padding-block-end: var(--grid-4);
  position: relative;
  z-index: 0;
}

#products-page > .div-body {
  width: var(--grid-78);
  margin-inline: auto;
}

#products-page .ul-page > li {
  padding-block: var(--grid-4);
  border-bottom: 1px solid rgba(0, 0, 0, 0.16);
}

@media (max-width: 768px) and (orientation: portrait) {
  #products-page > .div-body {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #products-page .ul-page {
    border-top: 1px solid rgba(0, 0, 0, 0.16);
  }

  #products-page .ul-page > li {
    padding-block: var(--grid-3);
  }
}


/*============================================================
  #products-head
============================================================*/
#products-head {
  position: relative;
  z-index: 0;
}

#products-head > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
}

#products-head .div-head-page-products {
  display: flex;
  flex-direction: column;
  justify-content: end;
  gap: var(--grid-3);
  width: var(--grid-78);
  height: var(--grid-26);
  padding-block: var(--grid-2);
  margin-inline: auto;
  position: relative;
}

#products-head .div-head-page-products .h-heading {
  display: flex;
  flex-direction: row;
  align-items: baseline;
  gap: var(--grid);
}

#products-head .div-head-page-products .h-heading .en {
  font-family: var(--font-cormorant);
  font-size: 6.4rem;
  letter-spacing: 0.02em;
  margin-block: -0.096em;
}

#products-head .div-head-page-products .h-heading .jp {
  font-family: var(--font-serif);
  font-size: 1.44rem;
  letter-spacing: 0.16em;
  margin-block: -0.096em;
}

#products-head .div-head-page-products .p-tagline {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
}

#products-head .div-head-page-products .p-tagline .jp {
  font-family: var(--font-serif);
  font-size: 1.68rem;
  letter-spacing: 0.16em;
  line-height: 1.84;
  margin-block: -0.42em;
}

#products-head .div-head-page-products .p-tagline .en {
  font-family: var(--font-cormorant);
  font-size: 1.36rem;
  letter-spacing: 0.02em;
  line-height: 1.68;
  margin-block: -0.34em;
}

#products-head .div-head-page-products .p-mark {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: calc(var(--grid) * 1.5);
}

#products-head .div-head-page-products .p-mark .logo-sdgs {
  width: auto;
  height: 3.2rem;
}

#products-head .div-head-page-products .p-mark .icon-jitsuyoshinan {
  width: auto;
  height: 3.6rem;
}

#products-head .div-head-page-products .calligraphy {
  width: auto;
  margin-block: auto;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
}

#products-head .div-head-page-products .calligraphy-kibako {
  height: 39.2rem;
}

#products-head .div-head-page-products .calligraphy-mari {
  height: 24rem;
}

#products-head .div-head-page-products .calligraphy-square {
  height: 40.8rem;
}

#products-head .div-head-page-products .calligraphy-teabag {
  height: 38.4rem;
}

#products-head .div-gallery {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--grid);
  width: var(--grid-86);
  margin-inline: auto;
}

#products-head .div-gallery .div-slider-gallery {
  aspect-ratio: 8 / 5;
}

#products-head .div-gallery .div-slider-gallery .figure-image {
  width: 100%;
  height: 100%;
}

#products-head .div-gallery .div-slider-gallery .figure-image .picture::after {
  opacity: 0.24;
}

#products-head .div-gallery .div-slider-gallery .div-slider-navigation {
  width: var(--grid-82);
}

#products-head .div-gallery .p-description {
  font-family: var(--font-sans-serif);
  font-size: 0.96rem;
  letter-spacing: 0.08em;
  line-height: 1.84;
  margin-block: -0.42em;
}

@media (max-width: 768px) and (orientation: portrait) {
  #products-head > .div-body {
    gap: var(--grid-2);
  }

  #products-head .div-head-page-products {
    width: auto;
    height: var(--grid-30);
    padding-block: var(--grid);
    padding-right: var(--grid-12);
    margin-inline: var(--grid-2);
  }

  #products-head .div-head-page-products .h-heading .en {
    font-size: 3.2rem;
  }

  #products-head .div-head-page-products .h-heading .jp {
    font-size: 1.36rem;
  }

  #products-head .div-head-page-products .p-tagline .jp {
    font-size: 1.28rem;
  }

  #products-head .div-head-page-products .p-tagline .en {
    font-size: 1.2rem;
  }

  #products-head .div-head-page-products .p-mark {
    gap: calc(var(--grid) * 1.5);
  }

  #products-head .div-head-page-products .p-mark .logo-sdgs {
    height: calc(3.2rem * 0.72);
  }

  #products-head .div-head-page-products .p-mark .icon-jitsuyoshinan {
    height: calc(3.6rem * 0.72);
  }

  #products-head .div-head-page-products .calligraphy-kibako {
    height: calc(39.2rem * 0.48);
  }

  #products-head .div-head-page-products .calligraphy-mari {
    height: calc(24rem * 0.48);
  }

  #products-head .div-head-page-products .calligraphy-square {
    height: calc(40.8rem * 0.48);
  }

  #products-head .div-head-page-products .calligraphy-teabag {
    height: calc(38.4rem * 0.48);
  }

  #products-head .div-gallery {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: var(--grid);
    width: auto;
    margin-inline: var(--grid);
  }

  #products-head .div-gallery .div-slider-gallery {
    aspect-ratio: 1 / 1;
  }

  #products-head .div-gallery .div-slider-gallery .div-slider-navigation {
    width: calc(100% - var(--grid-2));
  }

  #products-head .div-gallery .p-description {
    font-size: 0.8rem;
  }
}


/*============================================================
  #products-concept
============================================================*/
#products-concept {
  padding-block-start: var(--grid-4);
  position: relative;
  z-index: 0;
}

#products-concept > .div-body > .div-head {
  width: var(--grid-78);
  margin-inline: auto;
}

#products-concept > .div-body > .div-head .div-introduction {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: var(--grid-8);
  padding-block: var(--grid-6);
}

#products-concept > .div-body > .div-head .div-introduction .h-heading {
  width: var(--grid-16);
  font-family: var(--font-serif);
  font-size: 2.4rem;
  letter-spacing: 0.32em;
  line-height: 2;
  margin-block: -0.5em;
}

#products-concept > .div-body > .div-head .div-introduction .p-description {
  width: var(--grid-22);
  font-family: var(--font-serif);
  font-size: 1.36rem;
  letter-spacing: 0.08em;
  line-height: 2;
  margin-block: -0.5em;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-composition {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: var(--grid-2);
  padding-block: var(--grid-2);
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-composition .figure-image:nth-of-type(1) {
  width: calc(var(--grid) * 25);
  margin-right: auto;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-composition .figure-image:nth-of-type(2) {
  width: calc(var(--grid) * 15);
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-composition .figure-image:nth-of-type(3) {
  width: calc(var(--grid) * 40);
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-composition .figure-image .picture {
  aspect-ratio: 2 / 3;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-composition .figure-image .picture::after {
  opacity: 0.24;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-double {
  display: flex;
  flex-direction: row;
  width: var(--grid-86);
  margin-inline: auto;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-double .figure-image:nth-of-type(1) {
  aspect-ratio: 1 / 1;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-double .figure-image .picture::after {
  opacity: 0.16;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-single {
  width: var(--grid-86);
  margin-inline: auto;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-single .figure-image {
  aspect-ratio: 8 / 5;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-single .figure-image .picture::after {
  opacity: 0.16;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-twin {
  display: flex;
  flex-direction: row;
  gap: var(--grid-2);
  width: 100%;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-twin .figure-image {
  aspect-ratio: 1 / 1;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-twin .figure-image .picture::after {
  opacity: 0.16;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-column {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width: var(--grid-70);
  margin-inline: auto;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-column .figure-image:nth-of-type(1) {
  width: var(--grid-34);
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-column .figure-image:nth-of-type(1) .picture {
  aspect-ratio: 8 / 5;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-column .figure-image:nth-of-type(1) .picture::after {
  opacity: 0.16;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-column .figure-image:nth-of-type(2) {
  width: var(--grid-16);
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-column .figure-image:nth-of-type(2) .picture {
  aspect-ratio: 8 / 5;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-column .figure-image:nth-of-type(2) .picture::after {
  opacity: 0.32;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-video {
  display: flex;
  flex-direction: row;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-video > .div-1 {
  width: var(--grid-50);
  align-items: 16 / 9;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-video > .div-1 .figure-image {
  width: 100%;
  height: 100%;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-video > .div-1 .figure-image .picture::after {
  opacity: 0.48;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-video > .div-1 .figure-image .a-link-video {
  position: absolute;
  right: calc(var(--grid) * 1.5);
  bottom: calc(var(--grid) * 1.5);
  z-index: 1;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-video > .div-2 {
  flex: 1;
  position: relative;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-video > .div-2 .figure-image {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  width: 100%;
  height: 100%;
  position: absolute;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-video > .div-2 .figure-image .picture:nth-of-type(1) {
  grid-column: 1;
  grid-row: 1 / 3;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-video > .div-2 .figure-image .picture:nth-of-type(2) {
  grid-column: 2;
  grid-row: 1;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-video > .div-2 .figure-image .picture:nth-of-type(3) {
  grid-column: 2;
  grid-row: 2;
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-video > .div-2 .figure-image .picture::after {
  opacity: 0.32;
}

#products-concept > .div-body > .div-content .div-concept-product .div-description {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  width: var(--grid-70);
  padding-block: var(--grid-6);
  margin-inline: auto;
}

#products-concept > .div-body > .div-content .div-concept-product .div-description .div-column-small {
  width: var(--grid-16);
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-column + .div-description {
  padding-right: var(--grid-36);
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-column + .div-description .figure-image .picture {
  width: var(--grid-8);
  height: var(--grid-8);
}

#products-concept > .div-body > .div-content .div-concept-product .div-image-column + .div-description .figure-image .picture::after {
  opacity: 0.16;
}

#products-concept > .div-body > .div-content .div-concept-product:nth-of-type(odd) .div-description .div-column-small {
  margin-right: auto;
}

#products-concept > .div-body > .div-content .div-concept-product:nth-of-type(even) .div-description .div-column-small {
  margin-left: auto;
}

#products-concept > .div-body > .div-content .div-details-product .div-gallery {
  aspect-ratio: 3 / 2;
}

#products-concept > .div-body > .div-content .div-details-product .div-gallery .figure-image {
  width: 100%;
  height: 100%;
}

#products-concept > .div-body > .div-content .div-details-product .div-gallery .figure-image .picture::after {
  opacity: 0.08;
}

#products-concept > .div-body > .div-content .div-details-product .div-gallery .figure-image figcaption {
  width: var(--grid-84);
  color: var(--color-white);
  font-family: var(--font-sans-serif);
  font-size: 1.04rem;
  letter-spacing: 0.08em;
  line-height: 1.68;
  margin-block: -0.34em;
  margin-inline: auto;
  position: absolute;
  left: 0;
  right: 0;
  bottom: calc((var(--grid-2) * 2) + 2.4rem + var(--grid-2));
}

#products-concept > .div-body > .div-content .div-details-product .div-description {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width: var(--grid-78);
  padding-block: var(--grid-6);
  margin-inline: auto;
}

#products-concept > .div-body > .div-content .div-details-product .div-description > .div-1 .ul-details {
  display: flex;
  flex-direction: column;
  gap: 0.96rem;
}

#products-concept > .div-body > .div-content .div-details-product .div-description > .div-1 .dl-details {
  font-family: var(--font-sans-serif);
  font-size: 1.2rem;
  letter-spacing: 0.08em;
  line-height: 1.84;
  margin-block: -0.42em;
}

#products-concept > .div-body > .div-content .div-details-product .div-description > .div-1 .dl-details > dt,
#products-concept > .div-body > .div-content .div-details-product .div-description > .div-1 .dl-details > dd {
  display: inline;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  font-style: inherit;
  letter-spacing: inherit;
  line-height: inherit;
  white-space: inherit;
}

#products-concept > .div-body > .div-content .div-details-product .div-description > .div-1 .dl-details > dt::after {
  content: "：";
}

#products-concept.products-kibako > .div-body > .div-content .div-details-product .div-description > .div-1 {
  width: var(--grid-26);
}

#products-concept.products-mari > .div-body > .div-content .div-details-product .div-description > .div-1 {
  width: var(--grid-26);
}

#products-concept.products-square > .div-body > .div-content .div-details-product .div-description > .div-1 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--grid-3);
  width: var(--grid-16);
}

#products-concept.products-square > .div-body > .div-content .div-details-product .div-description > .div-1 .div-figure .figure-image .picture {
  height: 10.4rem;
}

#products-concept > .div-body > .div-content .div-details-product .div-description > .div-2 .div-figure {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  gap: var(--grid-2);
}

#products-concept > .div-body > .div-content .div-details-product .div-description > .div-2 .div-figure .figure-image {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: calc(var(--grid) * 1.5);
}

#products-concept.products-kibako > .div-body > .div-content .div-details-product .div-description > .div-2 .div-figure .figure-image .picture {
  height: 13.6rem;
}

#products-concept.products-mari > .div-body > .div-content .div-details-product .div-description > .div-2 .div-figure .figure-image .picture {
  height: 17rem;
}

#products-concept > .div-body > .div-content .div-details-product .div-description > .div-2 .div-figure .figure-image figcaption {
  font-family: var(--font-sans-serif);
  font-size: 0.96rem;
  letter-spacing: 0.08em;
  line-height: 1.68;
  margin-block: -0.34em;
  margin-inline-start: -12.8%;
}

#products-concept > .div-body > .div-content .div-details-product .div-description > .div-2 .ul-description {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
}

#products-concept > .div-body > .div-content .div-details-product .div-description > .div-2 .ul-description > li + li::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: rgba(0 ,0 ,0 ,0.16);
  margin-bottom: var(--grid-2);
}

#products-concept > .div-body > .div-content .div-details-product .div-description > .div-2 .ul-description > li .div-column-small {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--grid-2);
}

#products-concept > .div-body > .div-content .div-details-product .div-description > .div-2 .ul-description > li .div-column-small > .div-1 {
  display: flex;
  flex-direction: column;
  gap: calc(var(--grid) * 1.5);
  width: var(--grid-42);
}

#products-concept > .div-body > .div-content .div-details-product .div-description > .div-2 .ul-description > li .div-column-small > .div-1 .h-heading .jp {
  font-size: 1.36rem;
}

#products-concept > .div-body > .div-content .div-details-product .div-description > .div-2 .ul-description > li .div-column-small > .div-2 {
  width: var(--grid-6);
}

@media (max-width: 768px) and (orientation: portrait) {
  #products-concept {
    padding-block-start: var(--grid-4);
  }

  #products-concept > .div-body > .div-head {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #products-concept > .div-body > .div-head .div-introduction {
    flex-direction: column;
    align-items: initial;
    justify-content: initial;
    gap: var(--grid-4);
    padding-block: var(--grid-4);
  }

  #products-concept > .div-body > .div-head .div-introduction .h-heading {
    width: 100%;
    font-size: 2rem;
  }

  #products-concept > .div-body > .div-head .div-introduction .p-description {
    width: 100%;
    font-size: 1.2rem;
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-composition {
    gap: var(--grid);
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-composition .figure-image:nth-of-type(1) {
    width: var(--grid-12);
    margin-right: auto;
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-composition .figure-image:nth-of-type(2) {
    width: var(--grid-10);
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-composition .figure-image:nth-of-type(3) {
    width: var(--grid-22);
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-double {
    width: auto;
    margin-inline: var(--grid);
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-single {
    width: auto;
    margin-inline: var(--grid);
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-single .figure-image {
    aspect-ratio: 3 / 2;
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-twin {
    gap: var(--grid);
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-column {
    width: auto;
    margin-inline: var(--grid);
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-column .figure-image:nth-of-type(1) {
    width: var(--grid-22);
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-column .figure-image:nth-of-type(2) {
    width: var(--grid-10);
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-video {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: repeat(2, 1fr);
    width: 100%;
    height: calc(100vw * 1.125);
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-video > .div-1 {
    grid-column: 1;
    grid-row: 1;
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-video > .div-2 {
    grid-column: 1;
    grid-row: 2;
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-video > .div-2 .figure-image {
    height: auto;
    position: static;
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-description {
    width: auto;
    padding-block: var(--grid-4);
    margin-inline: var(--grid-2);
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-description .div-column-small {
    width: var(--grid-32);
  }

  #products-concept > .div-body > .div-content .div-concept-product .div-image-column + .div-description {
    flex-direction: column;
    gap: var(--grid-3);
    padding-right: 0;
  }

  #products-concept > .div-body > .div-content .div-details-product .div-gallery {
    aspect-ratio: 1 / 1;
  }

  #products-concept > .div-body > .div-content .div-details-product .div-gallery .figure-image figcaption {
    width: auto;
    font-size: 0.8rem;
    margin-inline: var(--grid-2);
  }

  #products-concept > .div-body > .div-content .div-details-product .div-description {
    flex-direction: column;
    align-items: initial;
    justify-content: initial;
    gap: var(--grid-2);
    width: auto;
    padding-block: var(--grid-4);
    margin-inline: var(--grid-2);
  }

  #products-concept.products-square > .div-body > .div-content .div-details-product .div-description {
    gap: var(--grid-4);
  }

  #products-concept > .div-body > .div-content .div-details-product .div-description > .div-1 .ul-details {
    display: flex;
    flex-direction: column;
    gap: 0.96rem;
  }

  #products-concept > .div-body > .div-content .div-details-product .div-description > .div-1 .dl-details {
    font-size: 1.04rem;
  }

  #products-concept.products-kibako > .div-body > .div-content .div-details-product .div-description > .div-1 {
    width: var(--grid-32);
  }

  #products-concept.products-mari > .div-body > .div-content .div-details-product .div-description > .div-1 {
    width: var(--grid-32);
  }

  #products-concept.products-square > .div-body > .div-content .div-details-product .div-description > .div-1 {
    width: var(--grid-32);
  }

  #products-concept.products-square > .div-body > .div-content .div-details-product .div-description > .div-1 .div-figure .figure-image .picture {
    height: calc(10.4rem * 0.72);
  }

  #products-concept > .div-body > .div-content .div-details-product .div-description > .div-2 .div-figure {
    justify-content: center;
  }

  #products-concept.products-kibako > .div-body > .div-content .div-details-product .div-description > .div-2 .div-figure .figure-image .picture {
    height: calc(13.6rem * 0.72);
  }

  #products-concept.products-mari > .div-body > .div-content .div-details-product .div-description > .div-2 .div-figure .figure-image .picture {
    height: calc(17rem * 0.72);
  }

  #products-concept > .div-body > .div-content .div-details-product .div-description > .div-2 .div-figure .figure-image figcaption {
    font-size: 0.8rem;
  }

  #products-concept > .div-body > .div-content .div-details-product .div-description > .div-2 .ul-description > li .div-column-small > .div-1 {
    flex: 1;
    width: auto;
  }

  #products-concept > .div-body > .div-content .div-details-product .div-description > .div-2 .ul-description > li .div-column-small > .div-1 .h-heading .jp {
    font-size: 1.28rem;
  }

  #products-concept > .div-body > .div-content .div-details-product .div-description > .div-2 .ul-description > li .div-column-small > .div-2 {
    width: var(--grid-8);
  }
}


/*============================================================
  #products-value
============================================================*/
#products-value {
  position: relative;
  z-index: 0;
}

#products-value > .div-body > .div-head {
  width: var(--grid-78);
  border-top: 1px solid rgba(0, 0, 0, 0.16);
  padding-block-start: var(--grid-4);
  margin-inline: auto;
}

#products-value > .div-body > .div-content .div-slider {
  padding-block: var(--grid-4);
}

#products-value > .div-body > .div-content .div-slider .div-slider-content {
  width: var(--grid-70);
  margin-inline: auto;
}

#products-value > .div-body > .div-content .div-slider .div-slider-content .ul-slider {
  margin-inline: calc(var(--grid-4) * -1);
}

#products-value > .div-body > .div-content .div-slider .div-slider-content .ul-slider > li {
  width: var(--grid-18);
  margin-inline: var(--grid-4);
}

#products-value > .div-body > .div-content .div-slider .div-slider-content .ul-slider > li .div-column-small > .div-2 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
}

#products-value > .div-body > .div-content .div-slider .div-slider-navigation {
  width: var(--grid-70);
}

@media (max-width: 768px) and (orientation: portrait) {
  #products-value > .div-body > .div-head {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #products-value > .div-body > .div-content .div-slider .div-slider-content {
    width: var(--grid-42);
  }

  #products-value > .div-body > .div-content .div-slider .div-slider-content .ul-slider > li {
    width: var(--grid-42);
  }

  #products-value > .div-body > .div-content .div-slider .div-slider-content .ul-slider > li .div-column-small {
    flex-direction: row-reverse;
    gap: var(--grid-4);
  }

  #products-value > .div-body > .div-content .div-slider .div-slider-content .ul-slider > li .div-column-small > .div-1 {
    width: var(--grid-10);
  }

  #products-value > .div-body > .div-content .div-slider .div-slider-content .ul-slider > li .div-column-small > .div-2 {
    flex: 1;
  }

  #products-value > .div-body > .div-content .div-slider .div-slider-navigation {
    width: var(--grid-42);
    margin-inline: auto;
  }
}


/*============================================================
  #products-lineup
============================================================*/
#products-lineup {
  background-color: var(--color-lightgray);
  position: relative;
  z-index: 0;
}

#products-lineup > .div-body > .div-head {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
  width: var(--grid-78);
  padding-block: var(--grid-4) var(--grid-2);
  margin-inline: auto;
}

#products-lineup > .div-body > .div-head .p-tagline-section {
  align-items: center;
  text-align: center;
}

#products-lineup > .div-body > .div-head .ul-index {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: calc(var(--grid) * 1.5);
  width: var(--grid-64);
  margin-inline: auto;
}

#products-lineup > .div-body > .div-head .ul-index > li > a {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
}

#products-lineup > .div-body > .div-head .ul-index > li > a .text {
  font-family: var(--font-cormorant);
  font-size: 6.4rem;
  white-space: nowrap;
  margin-block: -0.096em;
}

#products-lineup > .div-body > .div-head .ul-index > li > a .figure-image .picture {
  width: var(--grid-3);
  aspect-ratio: 1 / 1;
  border-radius: var(--grid-3);
}

#products-lineup > .div-body > .div-head .ul-index > li > a .figure-image .picture::after {
  opacity: 0.08;
}

#products-lineup > .div-body > .div-content .ul-lineup {
  width: var(--grid-78);
  margin-inline: auto;
}

#products-lineup > .div-body > .div-content .ul-lineup > li {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  justify-content: space-between;
  width: 100%;
  padding-block: var(--grid-4);
}

#products-lineup > .div-body > .div-content .ul-lineup > li + li {
  border-top: 1px solid rgba(0, 0, 0, 0.16);
}

#products-lineup > .div-body > .div-content .ul-lineup > li .div-1 {
  width: var(--grid-22);
}

#products-lineup > .div-body > .div-content .ul-lineup > li .div-2 {
  width: var(--grid-46);
}

#products-lineup > .div-body > .div-content .div-column-linup {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: 100%;
}

#products-lineup > .div-body > .div-content .div-column-linup .h-heading {
  display: flex;
  flex-direction: column;
  gap: calc(var(--grid) * 1.5);
}

#products-lineup > .div-body > .div-content .div-column-linup .h-heading .en {
  font-family: var(--font-cormorant);
  font-size: 1.28rem;
  letter-spacing: 0.02em;
  line-height: 1.44;
  margin-block: -0.22em;
}

#products-lineup > .div-body > .div-content .div-column-linup .h-heading .jp {
  font-family: var(--font-serif);
  font-size: 2rem;
  letter-spacing: 0.16em;
  line-height: 1.84;
  margin-block: -0.42em;
}

#products-lineup > .div-body > .div-content .div-column-linup .p-caption {
  font-family: var(--font-sans-serif);
  font-size: 0.96rem;
  letter-spacing: 0.12em;
  line-height: 2;
  margin-block: -0.5em;
  margin-bottom: -1.28rem;
}

#products-lineup > .div-body > .div-content .div-column-linup .p-price {
  display: inline-flex;
  flex-direction: row;
  align-items: baseline;
  gap: 1.28rem;
}

#products-lineup > .div-body > .div-content .div-column-linup .p-price .price {
  display: inline-flex;
  flex-direction: row;
  align-items: baseline;
  gap: 0.4em;
  font-family: var(--font-sans-serif);
  font-size: 0.96rem;
  letter-spacing: 0.08em;
  line-height: 1.84;
  margin-block: -0.42em;
}

#products-lineup > .div-body > .div-content .div-column-linup .p-price .price .number {
  font-family: var(--font-inter);
  font-size: 1.36rem;
  letter-spacing: 0.04em;
}

#products-lineup > .div-body > .div-content .div-column-linup .p-price .price .tax {
  font-size: 80%;
}

#products-lineup > .div-body > .div-content .div-column-linup .p-description {
  font-family: var(--font-sans-serif);
  font-size: 1.2rem;
  letter-spacing: 0.08em;
  line-height: 1.84;
  margin-block: -0.42em;
}

#products-lineup > .div-body > .div-content .div-slider-lineup .div-slider-content {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  background-color: var(--color-black);
}

#products-lineup > .div-body > .div-content .div-slider-lineup .div-slider-content .ul-slider {
  width: var(--grid-34);
  aspect-ratio: 4 / 3;
  z-index: 0;
}

#products-lineup > .div-body > .div-content .div-slider-lineup .div-slider-content .ul-slider > li {
  width: 100%;
  height: 100%;
}

#products-lineup > .div-body > .div-content .div-slider-lineup .div-slider-content .ul-slider .figure-image .picture::after {
  opacity: 0.16;
}

#products-lineup > .div-body > .div-content .div-slider-lineup .div-slider-content .p-image {
  flex: 1;
  height: 100%;
  overflow: hidden;
  position: relative;
  z-index: 1;
}

#products-lineup > .div-body > .div-content .div-slider-lineup .div-slider-content .p-image::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: var(--color-black);
  opacity: 0.4;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
}

#products-lineup > .div-body > .div-content .div-slider-lineup .div-slider-navigation .p-caption {
  flex: 1;
  font-family: var(--font-sans-serif);
  font-size: 0.96rem;
  letter-spacing: 0.12em;
  line-height: 1.68;
  margin-block: -0.34em;
  margin-inline: 1.6rem;
}

@media (hover: hover) {
  #products-lineup > .div-body > .div-head .ul-index > li > a:hover .text {
    text-decoration: underline;
    text-decoration-color: rgba(0, 0, 0, 0.4);
    text-decoration-thickness: 1px;
    text-underline-offset: 0.08em;
  }

  #products-lineup > .div-body > .div-head .ul-index > li > a:hover .figure-image img {
    filter: brightness(0.88);
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  #products-lineup > .div-body > .div-head {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #products-lineup > .div-body > .div-head .ul-index {
    width: 100%;
  }

  #products-lineup > .div-body > .div-head .ul-index > li > a {
    gap: 0.64rem;
    font-size: 3.2rem;
  }

  #products-lineup > .div-body > .div-head .ul-index > li > a .figure-image .picture {
    width: 3.2rem;
    border-radius: 3.2rem;
  }

  #products-lineup > .div-body > .div-content .ul-lineup {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #products-lineup > .div-body > .div-content .ul-lineup > li {
    flex-direction: column;
    align-items: initial;
    justify-content: initial;
    gap: var(--grid-3);
    padding-block: var(--grid-3);
  }

  #products-lineup > .div-body > .div-content .ul-lineup > li .div-1 {
    width: 100%;
  }

  #products-lineup > .div-body > .div-content .ul-lineup > li .div-2 {
    width: 100%;
  }

  #products-lineup > .div-body > .div-content .div-column-linup .h-heading .en {
    font-size: 1.12rem;
  }

  #products-lineup > .div-body > .div-content .div-column-linup .h-heading .jp {
    font-size: 1.84rem;
  }

  #products-lineup > .div-body > .div-content .div-column-linup .p-caption {
    font-size: 0.8rem;
  }

  #products-lineup > .div-body > .div-content .div-column-linup .p-price .price .tax {
    font-size: 80%;
  }

  #products-lineup > .div-body > .div-content .div-column-linup .p-description {
    font-size: 1.12rem;
  }

  #products-lineup > .div-body > .div-content .div-slider-lineup .div-slider-content .ul-slider {
    width: var(--grid-34);
  }

  #products-lineup > .div-body > .div-content .div-slider-lineup .div-slider-navigation .p-caption {
    font-size: 0.8rem;
  }
}


/*============================================================
  #products-information
============================================================*/
#products-information {
  padding-block: var(--grid-6);
  position: relative;
  z-index: 0;
}

#products-information > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-6);
  width: var(--grid-70);
  margin-inline: auto;
}

@media (max-width: 768px) and (orientation: portrait) {
  #products-information {
    padding-block: var(--grid-4);
  }

  #products-information > .div-body {
    width: auto;
    margin-inline: var(--grid-4);
  }
}


/*------------------------------------------------------------


  #experience


------------------------------------------------------------*/
#experience {
  background-color: var(--color-mossgreen);
}

#experience .section-experience > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-6);
  width: 100%;
}

#experience .section-experience > .div-body > .div-head {
  width: var(--grid-78);
  padding-top: var(--grid-6);
  margin-inline: auto;
}

#experience .section-experience > .div-body > .div-content {
  display: flex;
  flex-direction: column;
  gap: var(--grid-6);
  width: 100%;
}

@media (max-width: 768px) and (orientation: portrait) {
  #experience .section-experience > .div-body {
    gap: var(--grid-6);
  }

  #experience .section-experience > .div-body > .div-head {
    width: auto;
    padding-top: var(--grid-4);
    margin-inline: var(--grid-2);
  }

  #experience .section-experience > .div-body > .div-head + .div-content {
    margin-top: calc(var(--grid-2) * -1);
  }

  #experience .section-experience > .div-body > .div-content {
    gap: var(--grid-4);
  }
}


/*============================================================
  #experience-page
============================================================*/
#experience-page {
  color: var(--color-white);
  padding-block-end: var(--grid-4);
  position: relative;
  z-index: 0;
}

#experience-page > .div-body {
  width: var(--grid-78);
  margin-inline: auto;
}

#experience-page .ul-page > li {
  padding-block: var(--grid-4);
  border-bottom: 1px solid rgba(255, 255, 255, 0.16);
}

@media (max-width: 768px) and (orientation: portrait) {
  #experience-page > .div-body {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #experience-page .ul-page {
    border-top: 1px solid rgba(255, 255, 255, 0.16);
  }

  #experience-page .ul-page > li {
    padding-block: var(--grid-3);
  }
}


/*============================================================
  #experience-head
============================================================*/
#experience-head {
  color: var(--color-white);
  position: relative;
  z-index: 0;
}

#experience-head .div-head-page-experience {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: var(--grid-78);
  padding-block: var(--grid-2);
  margin-inline: auto;
}

#experience-head .div-head-page-experience .h-heading-page .jp > em {
  font-size: 64%;
}

#experience-head .div-head-page-experience .p-mark {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: calc(var(--grid) * 1.5);
}

#experience-head .div-head-page-experience .p-mark .sdgs {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.8rem;
}

#experience-head .div-head-page-experience .p-mark .logo-sdgs {
  width: auto;
  height: 3.2rem;
}

#experience-head .div-head-page-experience .p-mark .icon-sdgs {
  width: auto;
  height: 3.2rem;
}

#experience-head .div-subject {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--grid-3);
  text-align: center;
}

#experience-head .div-subject .p-subject {
  font-family: var(--font-cormorant);
  font-size: 6.4rem;
  letter-spacing: 0.02em;
  line-height: 1.28;
  margin-block: -0.24em;
}

#experience-head .div-subject .h-subject {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--grid-3);
}

#experience-head .div-subject .h-subject .jp {
  font-family: var(--font-serif);
  font-size: 3.2rem;
  letter-spacing: 0.24em;
  line-height: 2;
  margin-block: -0.5em;
}

#experience-head .div-subject .h-subject .jp > em {
  font-size: 48%;
}

#experience-head .div-subject .h-subject .en {
  font-family: var(--font-cormorant);
  font-size: 1.36rem;
  letter-spacing: 0.02em;
  margin-block: -0.096em;
}

#experience-head .div-theme {
  width: var(--grid-78);
  margin-inline: auto;
  position: relative;
}

#experience-head .div-theme .p-theme {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.36rem;
  width: var(--grid-10);
  aspect-ratio: 1 / 1;
  font-family: var(--font-serif);
  font-size: 1.12rem;
  letter-spacing: 0.24em;
  text-align: center;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1;
  transform: translateY(-100%);
}

#experience-head .div-theme .p-theme em {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}

#experience-head .div-theme .p-theme em .jp {
  font-size: 1.6rem;
  margin-block: -0.096em;
}

#experience-head .div-theme .p-theme em .en {
  font-family: var(--font-cormorant);
  font-size: 2.8rem;
  letter-spacing: 0.02em;
  margin-block: -0.096em;
}

#experience-head .div-theme .p-theme .frame {
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
}

#experience-head .div-image {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  width: 100%;
  margin-top: var(--grid-6);
}

#experience-head .div-image > .div-1 {
  width: var(--grid-50);
  align-items: 16 / 9;
}

#experience-head .div-image > .div-1 .figure-image {
  width: 100%;
  height: 100%;
}

#experience-head .div-image > .div-1 .figure-image .picture::after {
  opacity: 0.32;
}

#experience-head .div-image > .div-2 {
  flex: 1;
  position: relative;
}

#experience-head .div-image > .div-2 .figure-image {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}

#experience-head .div-image > .div-2 .figure-image .picture:nth-of-type(1) {
  grid-column: 1;
  grid-row: 1 / 3;
}

#experience-head .div-image > .div-2 .figure-image .picture:nth-of-type(2) {
  grid-column: 2;
  grid-row: 1;
}

#experience-head .div-image > .div-2 .figure-image .picture:nth-of-type(3) {
  grid-column: 2;
  grid-row: 2;
}

#experience-head .div-image > .div-2 .figure-image .picture::after {
  opacity: 0.32;
}

@media (max-width: 768px) and (orientation: portrait) {
  #experience-head .div-head-page-experience {
    gap: var(--grid-2);
    width: auto;
    padding-block: var(--grid-3);
    margin-inline: var(--grid-2);
  }

  #experience-head .div-head-page-experience .h-heading-page .bar {
    display: block;
    width: 0;
    height: 0;
    overflow: hidden;
  }

  #experience-head .div-head-page-experience .p-mark .logo-sdgs {
    height: calc(3.2rem * 0.72);
  }

  #experience-head .div-head-page-experience .p-mark .icon-sdgs {
    height: calc(3.2rem * 0.72);
  }

  #experience-head .div-subject {
    gap: var(--grid-3);
  }

  #experience-head .div-subject .p-subject {
    font-size: 3.2rem;
  }

  #experience-head .div-subject .h-subject {
    gap: var(--grid-3);
  }

  #experience-head .div-subject .h-subject .jp {
    font-size: 1.84rem;
  }

  #experience-head .div-subject .h-subject .en {
    font-size: 1.2rem;
  }

  #experience-head .div-theme {
    width: auto;
    margin-inline: var(--grid-2);
    position: static;
  }

  #experience-head .div-theme .p-theme {
    gap: 0.64rem;
    width: var(--grid-10);
    height: var(--grid-10);
    aspect-ratio: 1 / 1;
    font-size: 0.64rem;
    right: var(--grid-2);
    top: var(--grid-3);
    transform: none;
  }

  #experience-head .div-theme .p-theme em {
    gap: 0.64rem;
  }

  #experience-head .div-theme .p-theme em .jp {
    font-size: 0.8rem;
  }

  #experience-head .div-theme .p-theme em .en {
    font-size: 1.44rem;
  }

  #experience-head .div-image  {
    flex-direction: column;
    margin-top: var(--grid-4);
  }

  #experience-head .div-image  > .div-1 {
    width: 100%;
  }

  #experience-head .div-image  > .div-2 {
    width: 100%;
    aspect-ratio: 16 / 9;
  }
}


/*============================================================
  #experience-concept
============================================================*/
#experience-concept {
  background-color: var(--color-white);
  position: relative;
  z-index: 0;
}

#experience-concept .div-concept-experience {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width: var(--grid-78);
  margin-inline: auto;
}

#experience-concept.experience-general .div-concept-experience:nth-of-type(odd) {
  flex-direction: row-reverse;
}

#experience-concept.experience-education .div-concept-experience:nth-of-type(even) {
  flex-direction: row-reverse;
}

#experience-concept .div-concept-experience > .div-1 {
  width: var(--grid-38);
}

#experience-concept .div-concept-experience > .div-1 .div-column-medium {
  gap: var(--grid-2);
}

#experience-concept .div-concept-experience > .div-1 .div-head {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
}

#experience-concept .div-concept-experience > .div-1 .div-head .div-text {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
}

#experience-concept .div-concept-experience > .div-1 .div-head .div-text .p-tagline {
  font-family: var(--font-serif);
  font-size: 1.2rem;
  letter-spacing: 0.16em;
  line-height: 1.84;
  margin-block: -0.42em;
}

#experience-concept .div-concept-experience > .div-1 .div-head .div-text .h-heading .text {
  width: auto;
  height: 6.64rem;
}

#experience-concept .div-concept-experience > .div-1 .div-head .div-image .illustration {
  width: 13.6rem;
  height: auto;
}

#experience-concept .div-concept-experience > .div-2 {
  width: var(--grid-28);
}

#experience-concept .div-concept-experience > .div-2 .figure-image {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
}

#experience-concept .div-concept-experience > .div-2 .figure-image .picture {
  width: var(--grid-10);
}

#experience-concept .div-concept-experience > .div-2 .figure-image .picture:after {
  opacity: 0.16;
}

#experience-concept .div-link {
  display: flex;
  flex-direction: column;
  gap: var(--grid);
  width: var(--grid-70);
  margin-inline: auto;
}

#experience-concept .div-information {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: var(--grid-70);
  margin-inline: auto;
}

#experience-concept .div-information .article-featured-sdgs,
#experience-concept .div-information .article-featured-vision {
  border: 1px solid rgba(0, 0, 0, 0.16);
}

#experience-concept .div-gallery {
  display: flex;
  flex-direction: row-reverse;
  align-items: stretch;
  width: 100%;
}

#experience-concept .div-gallery > .div-1 {
  width: var(--grid-50);
  align-items: 16 / 9;
}

#experience-concept .div-gallery > .div-1 .figure-image {
  width: 100%;
  height: 100%;
}

#experience-concept .div-gallery > .div-1 .figure-image .picture::after {
  opacity: 0.24;
}

#experience-concept .div-gallery > .div-2 {
  flex: 1;
  position: relative;
}

#experience-concept .div-gallery > .div-2 .figure-image {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}

#experience-concept .div-gallery > .div-2 .figure-image .picture:nth-of-type(1) {
  grid-column: 1;
  grid-row: 1;
}

#experience-concept .div-gallery > .div-2 .figure-image .picture:nth-of-type(2) {
  grid-column: 1;
  grid-row: 2;
}

#experience-concept .div-gallery > .div-2 .figure-image .picture:nth-of-type(3) {
  grid-column: 2;
  grid-row: 1 / 3;
}

#experience-concept .div-gallery > .div-2 .figure-image .picture::after {
  opacity: 0.32;
}

@media (orientation: landscape), (min-width: 769px) and (orientation: portrait) {
  #experience-concept .div-information .article-featured-sdgs .div-area-2 {
    gap: var(--grid-6);
  }

  #experience-concept .div-information .article-featured-sdgs .div-area-2 > .div-2 {
    width: var(--grid-28);
  }

  #experience-concept .div-information .article-featured-vision .div-1 {
    width: var(--grid-32);
  }

  #experience-concept .div-information .article-featured-vision .div-2 {
    width: var(--grid-28);
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  #experience-concept .div-concept-experience {
    flex-direction: column;
    justify-content: initial;
    gap: var(--grid-4);
    width: auto;
    margin-inline: var(--grid-2);
  }

  #experience-concept.experience-general .div-concept-experience:nth-of-type(odd) {
    flex-direction: column;
  }

  #experience-concept.experience-education .div-concept-experience:nth-of-type(even) {
    flex-direction: column;
  }

  #experience-concept .div-concept-experience > .div-1 {
    width: 100%;
  }

  #experience-concept .div-concept-experience > .div-1 .div-column-medium {
    gap: var(--grid-3);
  }

  #experience-concept .div-concept-experience > .div-1 .div-head {
    flex-direction: column-reverse;
    justify-content: initial;
    gap: var(--grid-3);
  }

  #experience-concept .div-concept-experience > .div-1 .div-head .div-text {
    align-items: flex-start;
    width: 100%;
  }

  #experience-concept .div-concept-experience > .div-1 .div-head .div-text .p-tagline {
    font-size: 1.12rem;
  }

  #experience-concept .div-concept-experience > .div-1 .div-head .div-text .h-heading .text {
    height: calc(6.64rem * 0.72);
  }

  #experience-concept .div-concept-experience > .div-1 .div-head .div-image .illustration {
    width: calc(13.6rem * 0.72);
  }

  #experience-concept .div-concept-experience > .div-2 {
    width: auto;
  }

  #experience-concept .div-concept-experience > .div-2 .figure-image {
    gap: var(--grid-2);
    justify-content: center;
  }

  #experience-concept .div-concept-experience > .div-2 .figure-image .picture {
    width: calc(50% - var(--grid));
  }

  #experience-concept .div-concept-experience > .div-2 .figure-image .picture:after {
    opacity: 0.16;
  }

  #experience-concept .div-link {
    gap: var(--grid);
    width: auto;
    margin-inline: var(--grid-4);
  }

  #experience-concept .div-information {
    gap: var(--grid-2);
    width: auto;
    margin-inline: var(--grid-2);
  }

  #experience-concept .div-gallery  {
    flex-direction: column-reverse;
  }

  #experience-concept .div-gallery  > .div-1 {
    width: 100%;
  }

  #experience-concept .div-gallery  > .div-2 {
    width: 100%;
    aspect-ratio: 16 / 9;
  }
}


/*============================================================
  #experience-flow
============================================================*/
#experience-flow {
  color: var(--color-white);
  position: relative;
  z-index: 0;
}

#experience-flow .div-flow {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width: var(--grid-70);
  margin-inline: auto;
}

#experience-flow .div-flow > .div-1 {
  width: var(--grid-46);
}

#experience-flow .div-flow > .div-1 .div-column-medium {
  gap: var(--grid-2);
}

#experience-flow .div-flow > .div-1 .div-head {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
}

#experience-flow .div-flow > .div-1 .div-head .p-tagline {
  font-family: var(--font-serif);
  font-size: 1.2rem;
  letter-spacing: 0.16em;
  line-height: 1.84;
  margin-block: -0.42em;
}

#experience-flow .div-flow > .div-1 .div-head .h-heading {
  align-items: flex-start;
}

#experience-flow .div-flow > .div-1 .div-head .h-heading .text {
  width: auto;
  height: 2.24rem;
}

#experience-flow .div-flow > .div-1 .div-head .div-image .illustration {
  width: 13.6rem;
  height: auto;
}

#experience-flow .div-flow > .div-2 {
  width: var(--grid-10);
}

#experience-flow .div-flow > .div-2 .figure-image {
  width: 100%;
  aspect-ratio: 1 / 1;
  background-color: var(--color-white);
  border-radius: 50%;
  overflow: hidden;
}

#experience-flow .div-step .ol-step {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: center;
  gap: var(--grid-4);
}

#experience-flow .div-step .ol-step > li {
  width: var(--grid-10);
}

#experience-flow .div-step .ol-step .dl-step {
  display: flex;
  flex-direction: column;
  align-items: center;
}

#experience-flow .div-step .ol-step .dl-step > dt {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-inter);
  font-size: 1.2rem;
  font-weight: 300;
  width: var(--grid-3);
  height: var(--grid-3);
  background-color: var(--color-gray);
  border-radius: var(--grid-3);
  overflow: hidden;
}

#experience-flow .div-step .ol-step .dl-step > dd {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.6rem;
}

#experience-flow .div-step .ol-step .dl-step > dd::before {
  content: "";
  display: block;
  width: 1px;
  height: var(--grid-2);
  background-color: var(--color-white);
  opacity: 0.16;
}

#experience-flow .div-step .ol-step .dl-step > dd .figure-image {
  width: 100%;
}

#experience-flow .div-step .ol-step .dl-step > dd .figure-image .picture::after {
  opacity: 0.32;
}

#experience-flow .div-step .ol-step .dl-step > dd .h-heading {
  display: flex;
  flex-direction: column;
  gap: calc(var(--grid) * 1.5);
  text-align: center;
  margin-top: 1.6rem;
}

#experience-flow .div-step .ol-step .dl-step > dd .h-heading .en {
  font-family: var(--font-cormorant);
  font-size: 2rem;
  letter-spacing: 0.02em;
  line-height: 1.44;
  margin-block: -0.22em;
}

#experience-flow .div-step .ol-step .dl-step > dd .h-heading .jp {
  font-family: var(--font-serif);
  font-size: 1.28rem;
  letter-spacing: 0.12em;
  line-height: 1.6;
  margin-block: -0.3em;
}

#experience-flow .div-description {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: space-between;
  width: var(--grid-70);
  margin-inline: auto;
}

#experience-flow .div-description .div-column-small {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--grid-2);
  width: var(--grid-32);
}

#experience-flow .div-description .div-column-small > .div-1 {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: calc(var(--grid) * 1.5);
}

#experience-flow .div-description .div-column-small > .div-1 .h-heading {
  font-family: var(--font-serif);
  font-size: 1.36rem;
  letter-spacing: 0.16em;
  line-height: 1.84;
  margin-block: -0.42em;
}

#experience-flow .div-description .div-column-small > .div-2 {
  width: var(--grid-6);
}

#experience-flow .div-description .div-column-small > .div-2 .figure-image .picture::after {
  opacity: 0.16;
}

@media (max-width: 768px) and (orientation: portrait) {
  #experience-flow .div-flow {
    flex-direction: column-reverse;
    align-items: center;
    justify-content: initial;
    gap: var(--grid-4);
    width: auto;
    margin-inline: var(--grid-2);
  }

  #experience-flow .div-flow > .div-1 {
    width: 100%;
  }

  #experience-flow .div-flow > .div-1 .div-column-medium {
    gap: var(--grid-3);
  }

  #experience-flow .div-flow > .div-1 .div-head {
    gap: var(--grid-2);
  }

  #experience-flow .div-flow > .div-1 .div-head .p-tagline {
    font-size: 1.12rem;
  }

  #experience-flow .div-flow > .div-1 .div-head .h-heading .text {
    height: calc(2.24rem * 0.72);
  }

  #experience-flow .div-flow > .div-1 .div-head .div-image .illustration {
    width: calc(13.6rem * 0.72);
  }

  #experience-flow .div-flow > .div-2 {
    width: var(--grid-12);
  }

  #experience-flow .div-step {
    padding-block: var(--grid-2);
  }

  #experience-flow .div-step .ol-step {
    flex-direction: column;
    justify-content: initial;
    gap: var(--grid-3);
    width: auto;
    margin-inline: var(--grid-2);
  }

  #experience-flow .div-step .ol-step > li {
    width: 100%;
  }

  #experience-flow .div-step .ol-step .dl-step {
    flex-direction: row;
    width: 100%;
  }

  #experience-flow .div-step .ol-step .dl-step > dt {
    font-size: 1.04rem;
  }

  #experience-flow .div-step .ol-step .dl-step > dd {
    flex-direction: row;
    width: 100%;
  }

  #experience-flow .div-step .ol-step .dl-step > dd::before {
    width: var(--grid-2);
    height: 1px;
    margin-inline: 0;
  }

  #experience-flow .div-step .ol-step .dl-step > dd .figure-image {
    width: var(--grid-8);
  }

  #experience-flow .div-step .ol-step .dl-step > dd .h-heading {
    flex: 1;
    flex-direction: row;
    align-items: center;
    gap: 0;
    margin-top: 0;
  }

  #experience-flow .div-step .ol-step .dl-step > dd .h-heading .en {
    flex: 1;
    font-size: 1.44rem;
  }

  #experience-flow .div-step .ol-step .dl-step > dd .h-heading .jp {
    flex: 1;
    font-size: 1.12rem;
  }

  #experience-flow .div-description {
    flex-direction: column;
    justify-content: initial;
    gap: var(--grid-3);
    width: auto;
    margin-inline: var(--grid-2);
  }

  #experience-flow .div-description .div-column-small {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--grid-2);
    width: 100%;
  }

  #experience-flow .div-description .div-column-small > .div-1 {
    gap: var(--grid-2);
  }

  #experience-flow .div-description .div-column-small > .div-1 .h-heading {
    font-size: 1.28rem;
  }

  #experience-flow .div-description .div-column-small > .div-2 {
    width: var(--grid-8);
  }
}


/*============================================================
  #experience-guide
============================================================*/
#experience-guide {
  margin-block: var(--grid-6);
  position: relative;
  z-index: 0;
}

#experience-guide > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: var(--grid-78);
  margin-inline: auto;
}

#experience-guide .div-guide-experience {
  display: flex;
  flex-direction: column;
  gap: var(--grid);
  background-color: var(--color-white);
  padding-block: var(--grid-3);
  padding-inline: var(--grid-4);
}

#experience-guide .div-guide-experience > .div-area-1 {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  gap: var(--grid-6);
}

#experience-guide .div-guide-experience > .div-area-1 > .div-1,
#experience-guide .div-guide-experience > .div-area-1 > .div-2 {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
}

#experience-guide .div-guide-experience > .div-area-1 .div-head {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  justify-content: space-between;
  padding-block: var(--grid);
}

#experience-guide .div-guide-experience > .div-area-1 .div-head .div-heading {
  display: flex;
  flex-direction: column;
  gap: calc(var(--grid) * 1.5);
}

#experience-guide .div-guide-experience > .div-area-1 .div-head .div-heading .h-title {
  display: flex;
  flex-direction: column;
  gap: var(--grid);
}

#experience-guide .div-guide-experience > .div-area-1 .div-head .div-heading .h-title .en {
  font-family: var(--font-cormorant);
  font-size: 3.2rem;
  letter-spacing: 0.02em;
  line-height: 1.28;
  margin-block: -0.14em;
}

#experience-guide .div-guide-experience > .div-area-1 .div-head .div-heading .h-title .jp {
  font-family: var(--font-serif);
  font-size: 1.28rem;
  letter-spacing: 0.16em;
  line-height: 1.6;
  margin-block: -0.3em;
}

#experience-guide .div-guide-experience > .div-area-1 .div-head .div-heading .h-theme {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--grid);
}

#experience-guide.experience-general .div-guide-experience > .div-area-1 .div-head .div-heading .h-theme img.text {
  width: auto;
  height: 2.64rem;
}

#experience-guide.experience-education .div-guide-experience > .div-area-1 .div-head .div-heading .h-theme img.text {
  width: auto;
  height: 2.64rem;
}

#experience-guide.experience-general .div-guide-experience > .div-area-1 .div-head .div-image .illustration {
  width: auto;
  height: 12.8rem;
}

#experience-guide.experience-education .div-guide-experience > .div-area-1 .div-head .div-image .illustration {
  width: auto;
  height: 9.2rem;
}

#experience-guide .div-guide-experience > .div-area-1 .div-guide {
  margin-top: auto;
}

#experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-examples {
  display: flex;
  flex-direction: column;
  gap: var(--grid);
  background-color: #f8f8f8;
  padding: var(--grid);
}

#experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-examples > dt,
#experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-examples > dd {
  font-family: var(--font-sans-serif);
  font-size: 1.2rem;
  letter-spacing: 0.08em;
  line-height: 1.68;
  margin-block: -0.34em;
}

#experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-guide {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: var(--grid);
  padding-block: var(--grid);
}

#experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-guide {
  border-top: 1px solid rgba(0, 0, 0, 0.16);
}

#experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-examples + .dl-guide {
  margin-top: var(--grid-2);
}

#experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-guide > dt,
#experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-guide > dd {
  font-family: var(--font-sans-serif);
  font-size: 1.28rem;
  letter-spacing: 0.08em;
  line-height: 1.68;
  margin-block: -0.34em;
}

#experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-guide > dt {
  width: var(--grid-6);
}

#experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-guide > dd {
  flex: 1;
}

#experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-guide > dd > span {
  font-size: 88%;
}

#experience-guide .div-guide-studio {
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  justify-content: space-between;
  color: var(--color-white);
  border: 1px solid rgba(255, 255, 255, 0.24);
  padding-block: var(--grid-3);
  padding-inline: var(--grid-4);
}

#experience-guide .div-guide-studio .div-area-1 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: var(--grid-28);
}

#experience-guide .div-guide-studio .div-area-1 .div-brand-profile .ul-profile,
#experience-guide .div-guide-studio .div-area-1 .div-brand-profile .ul-profile > li {
  border-color: rgba(255, 255, 255, 0.16);
}

#experience-guide .div-guide-studio .div-area-1 .div-brand-profile .div-details {
  display: flex;
  flex-direction: column;
  gap: var(--grid);
  width: 100%;
}

#experience-guide .div-guide-studio .div-area-1 .div-brand-profile .ul-sns .icon {
  fill: var(--color-white);
}

#experience-guide .div-guide-studio .div-area-2 {
  width: var(--grid-28);
}

#experience-guide .div-guide-studio .div-area-2 .div-map .map {
  width: 100%;
  aspect-ratio: 1 / 1;
}

@media (max-width: 768px) and (orientation: portrait) {
  #experience-guide {
    margin-block: var(--grid-4);
  }

  #experience-guide > .div-body {
    gap: var(--grid-2);
    width: auto;
    margin-inline: var(--grid-2);
  }

  #experience-guide .div-guide-experience {
    padding-block: var(--grid-3);
    padding-inline: var(--grid-2);
  }

  #experience-guide .div-guide-experience > .div-area-1 {
    flex-direction: column;
    justify-content: initial;
    gap: 0;
  }

  #experience-guide .div-guide-experience > .div-area-1 > .div-1,
  #experience-guide .div-guide-experience > .div-area-1 > .div-2 {
    gap: var(--grid-2);
  }

  #experience-guide .div-guide-experience > .div-area-1 .div-head {
    padding-block: 0;
  }

  #experience-guide .div-guide-experience > .div-area-1 .div-head .div-heading {
    gap: var(--grid-2);
  }

  #experience-guide .div-guide-experience > .div-area-1 .div-head .div-heading .h-title .en {
    font-size: 2.4rem;
  }

  #experience-guide .div-guide-experience > .div-area-1 .div-head .div-heading .h-title .jp {
    font-size: 1.12rem;
  }

  #experience-guide.experience-general .div-guide-experience > .div-area-1 .div-head .div-heading .h-theme img.text {
    height: calc(2.64rem * 0.72);
  }

  #experience-guide.experience-education .div-guide-experience > .div-area-1 .div-head .div-heading .h-theme img.text {
    height: calc(6.42rem * 0.72);
  }

  #experience-guide.experience-general .div-guide-experience > .div-area-1 .div-head .div-image .illustration {
    height: calc(12.8rem * 0.72);
  }

  #experience-guide.experience-education .div-guide-experience > .div-area-1 .div-head .div-image .illustration {
    height: calc(9.2rem * 0.72);
  }

  #experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-examples > dt,
  #experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-examples > dd {
    font-size: 1.12rem;
  }

  #experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-guide {
    padding-block: calc(var(--grid) * 1.5);
  }

  #experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-examples + .dl-guide {
    margin-top: var(--grid-2);
  }

  #experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-guide > dt,
  #experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-guide > dd {
    font-size: 1.12rem;
  }

  #experience-guide .div-guide-experience > .div-area-1 .div-guide .dl-guide > dt {
    width: var(--grid-10);
  }

  #experience-guide .div-guide-studio {
    flex-direction: column;
    justify-content: initial;
    gap: var(--grid-3);
    padding-block: var(--grid-2);
    padding-inline: var(--grid-2);
  }

  #experience-guide .div-guide-studio .div-area-1 {
    width: 100%;
  }

  #experience-guide .div-guide-studio .div-area-2 {
    width: 100%;
  }
}


/*============================================================
  #experience-article
============================================================*/
#experience-article {
  color: var(--color-white);
  margin-block: var(--grid-6);
  position: relative;
  z-index: 0;
}

#experience-article .div-list {
  width: var(--grid-78);
  margin-top: var(--grid-2);
  margin-inline: auto;
}

#experience-article .div-list .ul-news > li {
  width: var(--grid-22);
}

#experience-article .div-list .ul-news > li .a-link-article::after {
  background-color: var(--color-white);
}

#experience-article .div-list .ul-news > li .article-news-item {
  color: var(--color-white);
}

@media (max-width: 768px) and (orientation: portrait) {
  #experience-article {
    margin-block: var(--grid-4);
  }

  #experience-article .div-list {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #experience-article .div-list .ul-news {
    row-gap: calc(var(--grid) * 1.5);
  }

  #experience-article .div-list .ul-news > li {
    width: 100%;
  }
}


/*============================================================
  #experience-information
============================================================*/
#experience-information {
  background-color: var(--color-white);
  padding-block: var(--grid-6);
  position: relative;
  z-index: 0;
}

#experience-information > .div-body {
  display: flex;
  flex-direction: column;
  width: var(--grid-70);
  margin-inline: auto;
}

@media (max-width: 768px) and (orientation: portrait) {
  #experience-information {
    padding-block: var(--grid-4);
  }

  #experience-information > .div-body {
    width: auto;
    margin-inline: var(--grid-2);
  }
}


/*------------------------------------------------------------


  #news


------------------------------------------------------------*/
/*============================================================
  #news-head
============================================================*/
#news-head .ul-menu-select .li-category .div-select select {
  width: 4.8em;
}

#news-head .ul-menu-select .li-tag .div-select select {
  width: 4.8em;
}

#news-head .ul-menu-select .li-date .div-select select {
  width: 7.2em;
}


/*============================================================
  #news-list
============================================================*/
#news-list {
  padding-block: var(--grid-4);
  position: relative;
  z-index: 0;
}

#news-list > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
}

#news-list .ul-news {
  display: flex;
  align-items: stretch;
  width: var(--grid-78);
  margin-block-start: calc(var(--grid-2) * -1);
  margin-inline: auto;
}

#news-list .ul-news::after {
  content: "";
  display: block;
  width: var(--grid-22);
  height: 0;
}

#news-list .ul-news > li {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  width: var(--grid-22);
  padding-block: var(--grid-2);
}

#news-list .ul-news > li .a-link-article {
  width: 100%;
  height: 100%;
  position: relative;
}

#news-list .ul-news > li .a-link-article .article-news {
  width: 100%;
  height: 100%;
}

#news-list .ul-news > li .a-link-article .article-news .dl-news {
  display: flex;
  flex-direction: column-reverse;
  gap: var(--grid-2);
  width: 100%;
  height: 100%;
}

#news-list .ul-news > li .a-link-article .article-news .dl-news > dt {
  font-family: var(--font-inter);
  font-size: 1.12rem;
  font-weight: 300;
  letter-spacing: 0.064em;
  white-space: nowrap;
  margin-top: auto;
}

#news-list .ul-news > li .a-link-article .article-news .dl-news > dd {
  display: flex;
  flex-direction: column;
  gap: calc(var(--grid) * 1.5);
}

#news-list .ul-news > li .a-link-article .article-news .dl-news .figure-image {
  width: var(--grid-8);
}

#news-list .ul-news > li .a-link-article .article-news .dl-news .figure-image .picture::after {
  opacity: 0.04;
}

#news-list .ul-news > li .a-link-article .article-news .dl-news .label-category {
  font-family: var(--font-cormorant);
  font-size: 1.28rem;
  letter-spacing: 0.02em;
  margin-block: -0.096em;
}

#news-list .ul-news > li .a-link-article .article-news .dl-news .figure-image + .label-category {
  margin-block-start: var(--grid);
}

#news-list .ul-news > li .a-link-article .article-news .dl-news .h-title {
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  max-height: calc((1.44rem * 2) + (1.44rem * 1.68));
  font-family: var(--font-serif);
  font-size: 1.44rem;
  letter-spacing: 0.08em;
  line-height: 1.68;
  margin-block: -0.34em;
  overflow: hidden;
}

#news-list .ul-news > li .a-link-article .icon-arrow {
  fill: var(--color-black);
  width: 0.8rem;
  height: auto;
  float: right;
  transform: translateY(-50%);
  position: absolute;
  right: 0;
  bottom: 1.68rem;
}

@media (max-width: 768px) and (orientation: portrait) {
  #news-list > .div-body {
    gap: var(--grid-2);
  }

  #news-list .ul-news {
    column-gap: var(--grid-4);
    width: auto;
    margin-inline: var(--grid-2);
  }

  #news-list .ul-news::after {
    width: calc(50% - var(--grid-2));
  }

  #news-list .ul-news > li {
    width: calc(50% - var(--grid-2));
  }

  #news-list .ul-news > li .a-link-article .icon-arrow {
    bottom: 1.44rem;
  }

  #news-list .ul-news > li .article-news .dl-news {
    gap: var(--grid-3);
  }

  #news-list .ul-news > li .article-news .dl-news > dt {
    font-size: 1.04rem;
  }

  #news-list .ul-news > li .article-news .dl-news .figure-image {
    width: var(--grid-10);
  }

  #news-list .ul-news > li .article-news .dl-news .label-category {
    font-family: var(--font-cormorant);
    font-size: 1.28rem;
    letter-spacing: 0.02em;
    margin-block: -0.096em;
  }

  #news-list .ul-news > li .article-news .dl-news .h-title {
    -webkit-line-clamp: 3;
    max-height: calc((1.28rem * 3) + (1.28rem * 1.68));
    font-size: 1.28rem;
  }
}


/*============================================================
  #news-article
============================================================*/
#news-article {
  padding-block: var(--grid-6);
  position: relative;
  z-index: 0;
}

#news-article > .div-body {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: space-between;
  width: var(--grid-78);
  margin-inline: auto;
}

#news-article .article-news {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: space-between;
  width: var(--grid-62);
}

#news-article .article-news .div-article-header {
  width: var(--grid-20);
}

#news-article .article-news .div-article-header .header-article {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
}

#news-article .article-news .div-article-header .header-article .dl-category > dt {
  font-family: var(--font-serif);
  font-size: 0.96rem;
  letter-spacing: 0.064em;
  line-height: 1.6;
  margin-block: -0.3em 0.8rem;
}

#news-article .article-news .div-article-header .header-article .dl-category > dd {
  font-family: var(--font-serif);
  font-size: 1.28rem;
  letter-spacing: 0.064em;
  line-height: 1.6;
  margin-block: -0.3em;
}

#news-article .article-news .div-article-header .header-article .h-title-post {
  font-family: var(--font-serif);
  font-size: 1.84rem;
  letter-spacing: 0.16em;
  line-height: 1.84;
  margin-block: var(--grid);
}

#news-article .article-news .div-article-header .header-article .dl-keywords > dt {
  font-family: var(--font-serif);
  font-size: 0.96rem;
  letter-spacing: 0.064em;
  line-height: 1.6;
  margin-block: -0.3em 0.8rem;
}

#news-article .article-news .div-article-header .header-article .dl-keywords > dd {
  font-family: var(--font-serif);
  font-size: 1.04rem;
  letter-spacing: 0.064em;
  line-height: 1.6;
  margin-block: -0.3em;
  white-space: nowrap;
}

#news-article .article-news .div-article-header .header-article .dl-keywords > dd a {
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  font-style: inherit;
  letter-spacing: inherit;
  line-height: inherit;
  margin-block: inherit;
  white-space: inherit;
}

#news-article .article-news .div-article-header .header-article .dl-keywords .ul-keywords {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 0.48rem;
  column-gap: 0.48rem;
  row-gap: 0.8rem;
}

#news-article .article-news .div-article-header .header-article .dl-keywords .ul-keywords > li {
  font-family: var(--font-serif);
  font-size: 1.04rem;
  letter-spacing: 0.064em;
  line-height: 1.6;
  margin-block: -0.3em;
  white-space: nowrap;
}

#news-article .article-news .div-article-header .header-article .dl-keywords .ul-keywords > li + li:not(:last-of-type)::after {
  content: ",";
}

#news-article .article-news .div-article-header .header-article .time-post {
  font-family: var(--font-inter);
  font-size: 1.12rem;
  font-weight: 300;
  letter-spacing: 0.064em;
  white-space: nowrap;
}

#news-article .article-news .div-article-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--grid-4);
  width: var(--grid-34);
}

#news-article .article-news .div-article-content p {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  font-family: var(--font-serif);
  font-size: 1.36rem;
  letter-spacing: 0.08em;
  line-height: 2;
  text-align: left;
  margin-block: -0.5em;
}

#news-article .article-news .div-article-content img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 48rem;
  object-fit: contain;
}

#news-article .nav-archives {
  width: var(--grid-8);
}

#news-article .nav-archives .ul-menu-archives {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
}

@media (max-width: 768px) and (orientation: portrait) {
  #news-article {
    padding-block: var(--grid-4);
  }

  #news-article > .div-body {
    flex-direction: column;
    justify-content: initial;
    gap: var(--grid-4);
    width: auto;
    margin-inline: var(--grid-2);
  }

  #news-article .article-news {
    flex-direction: column;
    justify-content: initial;
    gap: var(--grid-4);
    width: 100%;
  }

  #news-article .article-news .div-article-header {
    width: 100%;
  }

  #news-article .article-news .div-article-header .header-article .dl-category > dt {
    font-size: 0.8rem;
  }

  #news-article .article-news .div-article-header .header-article .dl-category > dd {
    font-size: 1.04rem;
  }

  #news-article .article-news .div-article-header .header-article .h-title-post {
    font-size: 1.6rem;
  }

  #news-article .article-news .div-article-header .header-article .dl-keywords > dt {
    font-size: 0.8rem;
  }

  #news-article .article-news .div-article-header .header-article .dl-keywords .ul-keywords > li {
    font-size: 0.96rem;
  }

  #news-article .article-news .div-article-header .header-article .time-post {
    font-size: 1.04rem;
  }

  #news-article .article-news .div-article-content {
    gap: var(--grid-4);
    width: 100%;
  }

  #news-article .article-news .div-article-content p {
    font-size: 1.2rem;
  }

  #news-article .article-news .div-article-content img {
    max-height: 40rem;
  }

  #news-article .nav-archives {
    width: 100%;
    border-top: 1px solid rgba(0, 0, 0, 0.16);
    border-bottom: 1px solid rgba(0, 0, 0, 0.16);
    padding-block: var(--grid-2);
  }

  #news-article .nav-archives .ul-menu-archives {
    gap: var(--grid-3);
  }

  #news-article .nav-archives .ul-menu-archives .button-pulldown {
    width: 100%;
  }
}


/*============================================================
  #news-links
============================================================*/
#news-links {
  padding-block: var(--grid-2);
  position: relative;
  z-index: 0;
}

#news-links > .div-body {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width: var(--grid-78);
  margin-inline: auto;
}

#news-links .a-link-prev,
#news-links .a-link-next,
#news-links .a-link-index {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: 0.8rem;
  font-family: var(--font-cormorant);
  font-size: 1.28rem;
  letter-spacing: 0.02em;
  margin-block: -0.096em;
}

#news-links .a-link-prev .icon-arrow,
#news-links .a-link-next .icon-arrow {
  fill: var(--color-black);
  width: 0.8rem;
  height: auto;
}

#news-links .a-link-prev .icon-arrow {
  transform: scaleX(-1);
}

@media (hover: hover) {
  #news-links .a-link-prev:hover,
  #news-links .a-link-next:hover,
  #news-links .a-link-index:hover {
    opacity: 0.64;
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  #news-links {
    padding-block: var(--grid);
  }

  #news-links > .div-body {
    width: auto;
    margin-inline: var(--grid-2);
  }
}


/*============================================================
  #news-arcives
============================================================*/
#news-arcives {
  padding-block: var(--grid-4);
  position: relative;
  z-index: 0;
}

#news-arcives > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: var(--grid-78);
  margin-inline: auto;
}

#news-arcives .ul-news > li {
  width: var(--grid-22);
}

@media (max-width: 768px) and (orientation: portrait) {
  #news-arcives {
    padding-block: var(--grid-4) var(--grid-2);
  }

  #news-arcives > .div-body {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #news-arcives .ul-news {
    row-gap: calc(var(--grid) * 1.5);
  }

  #news-arcives .ul-news > li {
    width: 100%;
  }
}


/*------------------------------------------------------------


  #contact


------------------------------------------------------------*/
/*============================================================
  #contact-form
============================================================*/
#contact-form {
  width: var(--grid-78);
  padding-block: var(--grid-2) var(--grid-4);
  margin-inline: auto;
}

#contact-form .div-input {
  display: flex;
  flex-direction: column;
  gap: var(--grid);
  width: 100%;
}

#contact-form .div-input .p-text {
  font-family: var(--font-serif);
  font-size: 1.36rem;
  letter-spacing: 0.12em;
  line-height: 1.6;
  padding-block: 0.8rem;
  margin-block: -0.3em;
}

#contact-form .div-input .ul-form > li {
  padding-block: var(--grid);
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

#contact-form .div-input .ul-form:nth-of-type(2) {
  background-color: var(--color-lightgray);
  padding: var(--grid) var(--grid-2);
}

#contact-form .div-input .ul-form:nth-of-type(2) > li:last-of-type {
  border-bottom: none;
}

#contact-form .div-input .dl-form {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  gap: var(--grid-2);
}

#contact-form .div-input .dl-form > dt {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width: var(--grid-20);
  height: 4rem;
  font-family: var(--font-serif);
  font-size: 1.36rem;
  letter-spacing: 0.12em;
}

#contact-form .div-input .dl-form > dt .label-required {
  display: inline-block;
  color: var(--color-white);
  font-family: var(--font-sans-serif);
  font-size: 0.96rem;
  letter-spacing: 0.24em;
  text-indent: 0.24em;
  background-color: var(--color-black);
  padding: 0.48em 0.4em;
}

#contact-form .div-input .dl-form > dd {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--grid);
}

#contact-form .div-input .dl-form > dd input[type="text"],
#contact-form .div-input .dl-form > dd input[type="email"],
#contact-form .div-input .dl-form > dd input[type="tel"],
#contact-form .div-input .dl-form > dd select,
#contact-form .div-input .dl-form > dd textarea {
  width: 100%;
  font-family: var(--font-serif);
  font-size: 1.36rem;
  letter-spacing: 0.064em;
  line-height: 1.6;
  background-color: #f8f8f8;
}

#contact-form .div-input .dl-form > dd input[type="text"],
#contact-form .div-input .dl-form > dd input[type="email"],
#contact-form .div-input .dl-form > dd input[type="tel"],
#contact-form .div-input .dl-form > dd select {
  height: 4rem;
  padding-inline: var(--grid);
}

#contact-form .div-input .dl-form > dd select {
  cursor: pointer;
}

#contact-form .div-input .dl-form > dd textarea {
  height: calc(1.6 * 8em);
  line-height: 1.6;
  padding: var(--grid);
}

#contact-form .div-input .dl-form > dd input::placeholder,
#contact-form .div-input .dl-form > dd textarea::placeholder {
  color: #b8b8b8;
}

#contact-form .div-input .dl-form > dd .div-select {
  position: relative;
}

#contact-form .div-input .dl-form > dd .div-select::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border: 0.28rem solid transparent;
  border-top: 0.8rem solid var(--color-black);
  position: absolute;
  right: 1.28rem;
  top: 2.14rem;
  transform: translateY(-50%);
}

#contact-form .div-check {
  text-align: center;
  margin-block: var(--grid-2);
}

#contact-form .div-check .div-check-confirm label span {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: 0.8rem;
  font-family: var(--font-serif);
  font-size: 1.28rem;
  letter-spacing: 0.08em;
  position: relative;
  cursor: pointer;
}

#contact-form .div-check .div-check-confirm label span::before {
  content: "";
  display: block;
  width: 1.6rem;
  height: 1.6rem;
  background-color: var(--white);
  border: 1px solid rgba(0, 0, 0, 0.48);
  border-radius: 0.2rem;
}

#contact-form .div-check .div-check-confirm label span::after {
  content: "";
  display: block;
  width: 1.04rem;
  height: 0.64rem;
  border-left: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
  margin: auto 0;
  opacity: 0;
  position: absolute;
  left: 0.64rem;
  top: 0;
  bottom: 0;
  transform: rotate(-45deg) translateY(-40%);
}

#contact-form .div-check .div-check-confirm input:checked + span::after {
  opacity: 1;
}

#contact-form .div-submit {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  margin-top: var(--grid);
}

#contact-form .div-submit input[type="submit"],
#contact-form .div-submit input[type="button"] {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 0.88rem;
  color: var(--color-black);
  font-family: var(--font-serif);
  font-size: 1.12rem;
  letter-spacing: 0.08em;
  outline: 1px solid rgba(0, 0, 0, 0.24);
  outline-offset: -1px;
  border-radius: 0.4rem;
  padding: 0.8rem 1.6rem 0.72rem;
}

#contact-form .div-submit input[type="submit"]:disabled,
#contact-form .div-submit input[type="button"]:disabled {
  opacity: 0.2;
  cursor: default;
}

#contact-form .div-input .wpcf7-not-valid-tip {
  font-family: var(--font-sans-serif);
  font-size: 1.12rem;
  letter-spacing: 0.08em;
  margin-top: 0.8em;
}

#contact-form .div-input .wpcf7-list-item {
  margin: 0 !important;
}

#contact-form .div-input .wpcf7-spinner {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}

#contact-form .div-input .wpcf7-response-output {
  color: var(--red);
  font-size: 1.2rem;
  line-height: 1.6;
  letter-spacing: 0.02em;
  background-color: transparent;
  border: none;
  border-radius: 0.2rem;
  padding: 0.2em 0.4em;
}

@media (hover: hover) {
  #contact-form .div-submit input[type="submit"]:not(:disabled):hover,
  #contact-form .div-submit input[type="button"]:not(:disabled):hover {
    color: var(--color-white);
    background-color: var(--color-black);
    outline-color: transparent;
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  #contact-form {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #contact-form .div-input .p-text {
    font-size: 1.2rem;
  }

  #contact-form .div-input .ul-form > li {
    padding-block: calc(var(--grid) * 1.5);
  }

  #contact-form .div-input .dl-form {
    flex-direction: column;
    justify-content: initial;
    gap: var(--grid-2);
  }

  #contact-form .div-input .dl-form > dt {
    width: 100%;
    height: auto;
    font-size: 1.2rem;
  }

  #contact-form .div-input .dl-form > dt .label-required {
    font-size: 0.88rem;
    padding: 0.48em 0.4em;
  }

  #contact-form .div-input .dl-form > dd {
    gap: var(--grid);
    width: 100%;
  }

  #contact-form .div-input .dl-form > dd input[type="text"],
  #contact-form .div-input .dl-form > dd input[type="email"],
  #contact-form .div-input .dl-form > dd input[type="tel"],
  #contact-form .div-input .dl-form > dd select,
  #contact-form .div-input .dl-form > dd textarea {
    font-size: 1.2rem;
  }

  #contact-form .div-check .div-check-confirm label span {
    font-size: 1.2rem;
  }

  #contact-form .div-submit {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    margin-top: var(--grid);
  }

  #contact-form .div-submit input[type="submit"],
  #contact-form .div-submit input[type="button"] {
    padding: 0.88rem 1.6rem;
  }

  #contact-form .div-input .wpcf7-not-valid-tip {
    font-size: 1.12rem;
  }

  #contact-form .div-input .wpcf7-response-output {
    font-size: 1.12rem;
  }
}


/*============================================================
  #contact-thanks
============================================================*/
#contact-thanks {
  padding-block: var(--grid-2);
  position: relative;
  z-index: 0;
}

#contact-thanks > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: var(--grid-78);
  margin-inline: auto;
}

#contact-thanks .h-heading {
  font-family: var(--font-serif);
  font-size: 1.84rem;
  letter-spacing: 0.16em;
  line-height: 1.84;
  margin-block: -0.42em;
}

#contact-thanks .p-message {
  font-family: var(--font-serif);
  font-size: 1.36rem;
  letter-spacing: 0.08em;
  line-height: 2;
  margin-block: -0.5em;
}

@media (max-width: 768px) and (orientation: portrait) {
  #contact-thanks > .div-body {
    gap: var(--grid-3);
    width: auto;
    margin-inline: var(--grid-2);
  }

  #contact-thanks .h-heading {
    font-size: 1.44rem;
  }

  #contact-thanks .p-message {
    font-size: 1.12rem;
  }
}


/*------------------------------------------------------------


  #error


------------------------------------------------------------*/
/*============================================================
  #error-message
============================================================*/
#error-message {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: var(--grid-78);
  padding-block: var(--grid-2);
  margin-inline: auto;
}

#error-message .p-message {
  font-family: var(--font-serif);
  font-size: 1.36rem;
  letter-spacing: 0.08em;
  line-height: 2;
  margin-block: -0.5em;
}

@media (max-width: 768px) and (orientation: portrait) {
  #error-message {
    width: auto;
    margin-inline: var(--grid-2);
  }

  #error-message .p-message {
    font-size: 1.12rem;
  }
}



