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

	SUSTAINABILITY CSS

-----------------------------------------*/
@media screen and (min-width: 769px) {
  .c-title__wrap:has(.c-title01) {
    padding-block: 240px 0;
  }
}
@media screen and (max-width: 768px) {
  .c-title__wrap:has(.c-title01) {
    padding-block: 30.75vw 0;
  }
}
.c-title__wrap:has(.c-title01) .c-title01 {
  text-align: center;
  margin-inline: auto;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  .c-title__wrap:has(.c-title01) .c-title01 {
    gap: 20px;
  }
}
@media screen and (max-width: 768px) {
  .c-title__wrap:has(.c-title01) .c-title01 {
    gap: 2.5vw;
  }
}
.c-title__wrap:has(.c-title01) .c-title01 .font56_32 {
  grid-row: 1/2;
}
@media screen and (min-width: 769px) {
  .c-title__wrap:has(.c-title01) .c-title01 .font56_32 {
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 768px) {
  .c-title__wrap:has(.c-title01) .c-title01 .font56_32 {
    letter-spacing: 0.02em;
  }
}
.c-title__wrap:has(.c-title01) .c-title01 .font18_12 {
  letter-spacing: 0.01em;
}
.c-title__wrap:has(.c-title01) .txt {
  line-height: 2.5;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .c-title__wrap:has(.c-title01) .txt {
    margin-block-start: 100px;
  }
}
@media screen and (max-width: 768px) {
  .c-title__wrap:has(.c-title01) .txt {
    margin-block-start: 20vw;
  }
}
@media screen and (min-width: 769px) {
  .c-title__wrap:has(.c-title01) .txt span {
    display: inline-block;
  }
}

/*----------------------------------------
	- sampling
-----------------------------------------*/
@media screen and (min-width: 769px) {
  .sampling {
    margin-block-start: 100px;
  }
}
@media screen and (max-width: 768px) {
  .sampling {
    margin-block-start: 15vw;
  }
}
.sampling .c-box {
  background-color: var(--color-soapstone);
  display: grid;
}
@media screen and (min-width: 769px) {
  .sampling .c-box {
    width: min(980px, 90%);
    grid-template-columns: 23.26% 1fr;
    gap: 30px 4.65%;
    padding: 50px 60px;
  }
}
@media screen and (max-width: 768px) {
  .sampling .c-box {
    padding-inline: 0;
    padding-block: 10vw;
  }
}
.sampling .c-box figure {
  position: relative;
  z-index: 1;
  grid-column: 1/2;
  grid-row: 1/3;
  width: 100%;
  aspect-ratio: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-block: auto;
}
@media screen and (max-width: 768px) {
  .sampling .c-box figure {
    width: 45vw;
    margin-inline: auto;
  }
}
.sampling .c-box figure::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  aspect-ratio: 1;
  background-color: var(--color-white);
  border-radius: 50%;
  z-index: -1;
  transition: background-color 0.2s;
}
.sampling .c-box img {
  width: 60%;
}
.sampling .c-box .c-link-area {
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (min-width: 769px) {
  .sampling .c-box .c-link-area {
    gap: 20px;
  }
}
@media screen and (max-width: 768px) {
  .sampling .c-box .c-link-area {
    padding-inline: 6vw;
    margin-block-start: 5vw;
    gap: 2.5vw;
  }
}
.sampling .c-box .font15_13 {
  font-weight: var(--font-regular);
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .sampling .c-box .font15_13 {
    padding-inline: 6vw;
    margin-block-start: 5vw;
  }
}

/*----------------------------------------
	- approach
-----------------------------------------*/
@media screen and (min-width: 769px) {
  .approach {
    margin-block-start: 150px;
  }
}
@media screen and (max-width: 768px) {
  .approach {
    margin-block-start: 21.5vw;
  }
}
.approach .c-title02 {
  margin-inline: auto;
}
.approach .item-list {
  display: grid;
}
@media screen and (min-width: 769px) {
  .approach .item-list {
    margin-block-start: 78px;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
}
@media screen and (max-width: 768px) {
  .approach .item-list {
    margin-block-start: 13.5vw;
    grid-template-columns: 1fr;
    gap: 9vw;
  }
}
.approach .item-list li {
  position: relative;
  width: 100%;
  overflow: hidden;
}
@media screen and (min-width: 769px) {
  .approach .item-list li {
    aspect-ratio: 540/382;
  }
}
@media screen and (max-width: 768px) {
  .approach .item-list li {
    aspect-ratio: 352/249;
  }
}
.approach .item-list li::before {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: top;
  background-repeat: no-repeat;
  transition: scale 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.approach .item-list li:nth-of-type(1)::before {
  background-image: url(/asset/img/sustainability/sustainability-approach_p01.webp);
}
.approach .item-list li:nth-of-type(2)::before {
  background-image: url(/asset/img/sustainability/sustainability-approach_p02.webp);
}
@media (hover: hover) {
  .approach .item-list li:hover::before {
    scale: 1.1;
  }
}
.approach .item-list .c-link-area {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
}
.approach .item-list .font24_20 {
  color: var(--color-white);
  font-weight: var(--font-medium);
}
@media screen and (min-width: 769px) {
  .approach .item-list .c-icon-base {
    right: 24px;
    bottom: 24px;
  }
}
@media screen and (max-width: 768px) {
  .approach .item-list .c-icon-base {
    right: 3vw;
    bottom: 3vw;
  }
}
.approach .governance {
  border-block-start: 1px solid var(--color-americansilver);
}
@media screen and (min-width: 769px) {
  .approach .governance {
    margin-block-start: 100px;
    padding-block-start: 80px;
  }
}
@media screen and (max-width: 768px) {
  .approach .governance {
    margin-block-start: 16vw;
    padding-block-start: 6.5vw;
    padding-inline: 5.75vw;
  }
}
.approach .governance a {
  display: grid;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .approach .governance a {
    grid-template-columns: 400px 1fr;
    gap: 50px;
  }
}
@media screen and (max-width: 768px) {
  .approach .governance a {
    gap: 6vw;
  }
}
.approach .governance a figure {
  overflow: hidden;
}
.approach .governance a img {
  transition: scale 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
@media (hover: hover) {
  .approach .governance a:hover img {
    scale: 1.1;
  }
}
.approach .governance a .font20_16 {
  font-weight: var(--font-medium);
}
@media screen and (min-width: 769px) {
  .approach .governance a .font20_16 {
    line-height: 1.5;
    letter-spacing: 0.03em;
  }
}
@media screen and (max-width: 768px) {
  .approach .governance a .font20_16 {
    line-height: 2;
    letter-spacing: 0;
  }
}
.approach .governance a .font20_16::after {
  content: "";
  display: inline-block;
  background-image: url(/asset/img/common/ic-pdf-pink.svg);
  height: 1.25em;
  aspect-ratio: 1;
  background-position: center;
  background-size: auto 100%;
  background-repeat: no-repeat;
  translate: 0 0.2em;
  margin-inline-start: 0.75em;
}