.sustainability-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: var(--hidden-in-header);
  width: 100%;
  min-height: 100vh;
  background-image: url(/assets/img/sustainability/mv_bg_01.png);
  background-size: contain;
  background-position: center top;
  background-repeat: no-repeat;
  padding-bottom: min(100px, 8.3333333333%);
}
@media only screen and (max-width: 767px) {
  .sustainability-wrap {
    padding-bottom: 15.625%;
  }
}

.sustainability-mv {
  width: 100%;
}
.sustainability-mv > div {
  width: min(1080px, 100% - 120px);
  margin: 0 auto;
  padding-bottom: min(28px, 2.5925925926%);
}
@media only screen and (max-width: 767px) {
  .sustainability-mv > div {
    width: auto;
    padding-bottom: 0;
  }
}
.sustainability-mv__img {
  opacity: 0;
  padding: 2.3148148148% 0 0;
}
@media only screen and (max-width: 767px) {
  .sustainability-mv__img {
    padding: 3.75% 0 0;
  }
}
@media print {
  .sustainability-mv__img {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
.sustainability-mv__img > img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}
.sustainability-mv__copy {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: -5.6569343066% auto 0;
}
@media only screen and (max-width: 767px) {
  .sustainability-mv__copy {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 0.625% auto 0;
    width: 87.5%;
  }
}
.sustainability-mv__copy > img {
  height: auto;
  vertical-align: middle;
  opacity: 0;
}
@media print {
  .sustainability-mv__copy > img {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
.sustainability-mv__copy > img:nth-child(1) {
  width: 22.6851851852%;
}
@media only screen and (max-width: 767px) {
  .sustainability-mv__copy > img:nth-child(1) {
    width: 35.8928571429%;
  }
}
.sustainability-mv__copy > img:nth-child(2) {
  margin-left: 4.3518518519%;
  width: 35.0925925926%;
}
@media only screen and (max-width: 767px) {
  .sustainability-mv__copy > img:nth-child(2) {
    margin-left: 8.3928571429%;
    width: 55.5357142857%;
  }
}
.sustainability-mv__copy > img:nth-child(3) {
  margin-left: 2.6851851852%;
  width: 35.0925925926%;
}
@media only screen and (max-width: 767px) {
  .sustainability-mv__copy > img:nth-child(3) {
    margin-top: 0.7142857143%;
    width: 55.5357142857%;
  }
}
.sustainability-mv__title {
  margin: 2.037037037% auto 0;
  width: 60.1851851852%;
}
@media only screen and (max-width: 767px) {
  .sustainability-mv__title {
    margin: 3.59375% auto 0;
    width: 87.5%;
  }
}
.sustainability-mv__title > img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}

.sustainability-sdgs {
  width: 100%;
  padding-bottom: min(80px, 6.6666666667%);
}
@media only screen and (max-width: 767px) {
  .sustainability-sdgs {
    margin-top: 11.875%;
    padding-bottom: 0;
  }
}
.sustainability-sdgs > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: space-evenly;
      -ms-flex-pack: space-evenly;
          justify-content: space-evenly;
  width: min(1200px, 100%);
  margin: 0 auto;
}
@media only screen and (max-width: 767px) {
  .sustainability-sdgs > div {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    width: 87.5%;
  }
}
.sustainability-sdgs__title {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  width: min(548px, 45.6666666667%);
  line-height: 0;
}
@media only screen and (max-width: 767px) {
  .sustainability-sdgs__title {
    width: 100%;
    margin-top: 5.7142857143%;
  }
}
.sustainability-sdgs__title > img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}
.sustainability-sdgs__col {
  padding-top: min(63px, 5.25%);
  width: min(260px, 21.6666666667%);
  font-size: min(0.08rem + 15.2 * 0.0833333333vw, 1.6rem);
  line-height: 1.75;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media only screen and (max-width: 767px) {
  .sustainability-sdgs__col {
    padding-top: 0;
    width: 100%;
    font-size: min(0.13rem + 24.7 * 0.1333333333vw, 2.6rem);
    line-height: 1.6538461538;
    -webkit-font-feature-settings: normal;
            font-feature-settings: normal;
  }
}
.sustainability-sdgs__col--1 {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.sustainability-sdgs__col--2 {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
}
@media only screen and (max-width: 767px) {
  .sustainability-sdgs__col--2 {
    margin-top: 10.7142857143%;
  }
}
.sustainability-sdgs__col > p {
  margin-top: min(24px, 9.2307692308%);
  text-align: justify;
}
@media only screen and (max-width: 767px) {
  .sustainability-sdgs__col > p {
    margin-top: 7.1428571429%;
  }
}
.sustainability-sdgs__col > p > span {
  font-size: min(0.06rem + 11.4 * 0.0833333333vw, 1.2rem);
}
@media only screen and (max-width: 767px) {
  .sustainability-sdgs__col > p > span {
    font-size: min(0.08rem + 15.2 * 0.1333333333vw, 1.6rem);
  }
}
.sustainability-sdgs__title2 {
  line-height: 0;
}
@media only screen and (max-width: 767px) {
  .sustainability-sdgs__title2 {
    width: 68.5714285714%;
    margin: 0 auto;
  }
}
.sustainability-sdgs__title2 > img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}
.sustainability-sdgs__line {
  line-height: 0;
}
.sustainability-sdgs__line:nth-child(n+2) {
  margin-top: min(40px, 14.6153846154%);
}
@media only screen and (max-width: 767px) {
  .sustainability-sdgs__line:nth-child(n+2) {
    margin-top: 7.6785714286%;
  }
}
.sustainability-sdgs__line > img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}
.sustainability-sdgs__note {
  font-size: min(0.06rem + 11.4 * 0.0833333333vw, 1.2rem);
}
@media only screen and (max-width: 767px) {
  .sustainability-sdgs__note {
    font-size: min(0.1rem + 19 * 0.1333333333vw, 2rem);
  }
}

.sustainability-inochitsunagu-wrap {
  width: 100%;
  background-color: var(--color-red);
  padding-top: min(80px, 5.8565153734vw);
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu-wrap {
    margin-top: 8.4vw;
    padding-top: 13.3333333333vw;
  }
}

.sustainability-inochitsunagu {
  position: relative;
  width: 100%;
  overflow: hidden;
  background-image: -webkit-gradient(linear, left top, left bottom, color-stop(57.0526315789%, var(--color-red)), color-stop(57.0526315789%, var(--color-white)));
  background-image: linear-gradient(var(--color-red) 57.0526315789%, var(--color-white) 57.0526315789%);
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu {
    background-image: -webkit-gradient(linear, left top, left bottom, from(var(--color-red)), to(var(--color-white)));
    background-image: linear-gradient(var(--color-red) calc(100% - 29.7333333333vw), var(--color-white) calc(100% - 29.7333333333vw));
  }
}
.sustainability-inochitsunagu::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 12.1522693997vw;
  width: 100%;
  height: 100%;
  background-color: var(--color-lightGray);
  border-radius: 2.196193265vw 0 0 2.196193265vw;
}
@media screen {
  .sustainability-inochitsunagu::before {
    -webkit-transform: translateY(100px);
            transform: translateY(100px);
    opacity: 0;
    -webkit-transition: opacity 1s, -webkit-transform 1s ease-out;
    transition: opacity 1s, -webkit-transform 1s ease-out;
    transition: transform 1s ease-out, opacity 1s;
    transition: transform 1s ease-out, opacity 1s, -webkit-transform 1s ease-out;
  }
  .is-inview.sustainability-inochitsunagu::before {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1;
  }
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu::before {
    left: 6vw;
    border-radius: 4vw 0 0 4vw;
  }
}
.sustainability-inochitsunagu__inner {
  position: relative;
  z-index: 2;
}
.sustainability-inochitsunagu__hgrop {
  margin-top: 3.8067349927vw;
  margin-left: 12.1522693997vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1.1713030747vw;
}
@media screen {
  .sustainability-inochitsunagu__hgrop {
    opacity: 0;
    -webkit-transition: opacity 1s 0.5s;
    transition: opacity 1s 0.5s;
  }
  .sustainability-inochitsunagu.is-inview .sustainability-inochitsunagu__hgrop {
    opacity: 1;
  }
}
.sustainability-inochitsunagu__hgrop > p {
  font-size: calc(0.27rem + 15.3 * 0.0732064422vw);
  font-weight: var(--font-weight-medium);
  color: var(--color-black);
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__hgrop {
    margin-top: 9.0666666667vw;
    margin-left: 6vw;
    gap: 2.4vw;
  }
  .sustainability-inochitsunagu__hgrop > p {
    font-size: var(--font-size-sp-30px);
  }
}
.sustainability-inochitsunagu__title {
  width: 54.9048316252vw;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__title {
    width: 82vw;
  }
}
.sustainability-inochitsunagu__title > a {
  position: relative;
  display: block;
}
.sustainability-inochitsunagu__title > a::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
  -webkit-mask-image: url(/assets/img/common/inochitsunagu_title.svg);
          mask-image: url(/assets/img/common/inochitsunagu_title.svg);
  -webkit-mask-position: center center;
          mask-position: center center;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  background-color: var(--color-red);
  opacity: 0;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}
.sustainability-inochitsunagu__title > a > img {
  display: block;
  width: 100%;
  opacity: 1;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}
@media (hover: hover) and (pointer: fine) {
  .sustainability-inochitsunagu__title > a:hover::after {
    opacity: 1;
  }
  .sustainability-inochitsunagu__title > a:hover > img {
    opacity: 0;
  }
}
.sustainability-inochitsunagu__title > a:focus-visible {
  border-radius: 10px;
  outline: 2px solid var(--color-focus-border, #000);
  outline-offset: 2px;
  background-color: var(--color-focus-bg);
  -webkit-box-shadow: 0 0 0 2px var(--color-focus-bg);
          box-shadow: 0 0 0 2px var(--color-focus-bg);
}
.sustainability-inochitsunagu__carousel {
  margin-top: 3.6603221083vw;
  overflow: hidden;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__carousel {
    margin-top: 3.0666666667vw;
  }
}
.sustainability-inochitsunagu__viewport {
  position: relative;
  margin: 0 0 0 7.3938506589vw;
  width: 86.9692532943vw;
  height: 38.579795022vw;
  -ms-touch-action: pan-y;
      touch-action: pan-y;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__viewport {
    margin: 0;
    width: 100%;
    height: 67.7333333333vw;
  }
}
.sustainability-inochitsunagu__track {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-touch-action: pan-y;
      touch-action: pan-y;
}
.sustainability-inochitsunagu__slide {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 86.9692532943vw;
  height: 38.579795022vw;
  padding: 0 4.39238653vw 0 0;
}
@media screen {
  .sustainability-inochitsunagu__slide:not(:nth-child(3)) {
    opacity: 0;
    -webkit-transition: opacity 1.5s 3.5s;
    transition: opacity 1.5s 3.5s;
  }
  .sustainability-inochitsunagu__carousel.is-inview .sustainability-inochitsunagu__slide:not(:nth-child(3)) {
    opacity: 1;
  }
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__slide {
    width: 100%;
    height: 67.7333333333vw;
    padding: 0 1.3333333333vw;
  }
}
.sustainability-inochitsunagu__card {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  padding: 1.4641288433vw 0 0 1.4641288433vw;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card {
    padding: 1.8666666667vw 0 0 1.8666666667vw;
  }
}
.sustainability-inochitsunagu__card:focus-visible {
  outline: none;
}
.sustainability-inochitsunagu__card:focus-visible::after {
  content: "";
  display: block;
  position: absolute;
  z-index: 10;
  inset: 0;
  width: 100%;
  height: 100%;
  -webkit-box-shadow: inset 0 0 0 2px var(--color-white), inset 0 0 0 5px var(--color-black), inset 0 0 0 7px var(--color-white);
          box-shadow: inset 0 0 0 2px var(--color-white), inset 0 0 0 5px var(--color-black), inset 0 0 0 7px var(--color-white);
  border-radius: 0.7320644217vw;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card:focus-visible::after {
    -webkit-box-shadow: inset 0 0 0 0.2666666667vw var(--color-white), inset 0 0 0 0.6666666667vw var(--color-black), inset 0 0 0 0.9333333333vw var(--color-white);
            box-shadow: inset 0 0 0 0.2666666667vw var(--color-white), inset 0 0 0 0.6666666667vw var(--color-black), inset 0 0 0 0.9333333333vw var(--color-white);
    border-radius: 1.3333333333vw;
  }
}
@media (hover: hover) and (pointer: fine) {
  .sustainability-inochitsunagu__card:hover .sustainability-inochitsunagu__card-link::after {
    opacity: 1;
  }
  .sustainability-inochitsunagu__card:hover .sustainability-inochitsunagu__card-word-1 {
    background-color: var(--color-red);
  }
  .sustainability-inochitsunagu__card:hover .sustainability-inochitsunagu__card-word-1 > span {
    color: var(--color-white);
  }
  .sustainability-inochitsunagu__card:hover .sustainability-inochitsunagu__card-word-2 {
    background-color: var(--color-red);
  }
  .sustainability-inochitsunagu__card:hover .sustainability-inochitsunagu__card-word-2 > span {
    color: var(--color-white);
  }
  .sustainability-inochitsunagu__card:hover .sustainability-inochitsunagu__card-image-inner::after {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .sustainability-inochitsunagu__card:hover .sustainability-inochitsunagu__card-image-inner > img {
    -webkit-filter: brightness(50%);
            filter: brightness(50%);
  }
  .sustainability-inochitsunagu__card:hover .sustainability-inochitsunagu__card-arrow::after {
    width: 100%;
  }
  .sustainability-inochitsunagu__card:hover .sustainability-inochitsunagu__card-arrow > span {
    background-color: var(--color-red);
  }
}
.sustainability-inochitsunagu__card-caption {
  position: absolute;
  z-index: 3;
  top: 10.6881405564vw;
  left: 39.5314787701vw;
  width: 11.5666178624vw;
  height: 11.5666178624vw;
}
@media screen {
  .sustainability-inochitsunagu__card-caption {
    opacity: 0;
    -webkit-transition: opacity 1s 2.5s;
    transition: opacity 1s 2.5s;
  }
  .sustainability-inochitsunagu__carousel.is-inview .sustainability-inochitsunagu__card-caption {
    opacity: 1;
  }
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card-caption {
    top: 35.9333333333vw;
    top: 30.6666666667vw;
    left: 43.1333333333vw;
    width: 20.8vw;
    height: 20.8vw;
  }
}
.sustainability-inochitsunagu__card-link {
  position: relative;
  z-index: 2;
}
.sustainability-inochitsunagu__card-link::after {
  content: "";
  position: absolute;
  inset: -1px;
  display: block;
  border: 0.2928257687vw solid var(--color-red);
  border-radius: 50%;
  opacity: 0;
  -webkit-transition: opacity 0.5s;
  transition: opacity 0.5s;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card-link::after {
    border: 0.5333333333vw solid var(--color-red);
  }
}
.sustainability-inochitsunagu__card-word-1 {
  position: absolute;
  top: calc(50% - 1.9399707174vw);
  right: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-width: 20.4978038067vw;
  height: 3.8799414348vw;
  padding: 0 10.2489019034vw 0 6.2225475842vw;
  background-color: var(--color-white);
  border-radius: 1.9765739385vw;
  white-space: nowrap;
  -webkit-transition: background-color 0.5s;
  transition: background-color 0.5s;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card-word-1 {
    top: calc(50% - 3.4666666667vw);
    min-width: 26.1333333333vw;
    height: 6.9333333333vw;
    padding: 0 13.3333333333vw 0 8.2666666667vw;
    border-radius: 3.4666666667vw;
  }
}
.sustainability-inochitsunagu__card-word-1 > span {
  font-size: calc(0.39rem + 22.1 * 0.0732064422vw);
  font-weight: var(--font-weight-bold);
  color: var(--color-black);
  -webkit-transition: color 0.5s;
  transition: color 0.5s;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card-word-1 > span {
    font-size: var(--font-size-sp-25px);
  }
}
.sustainability-inochitsunagu__card-word-2 {
  position: absolute;
  top: calc(50% - 1.9399707174vw);
  left: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-width: 20.4978038067vw;
  height: 3.8799414348vw;
  padding: 0 6.2225475842vw 0 10.2489019034vw;
  background-color: var(--color-white);
  border-radius: 1.9765739385vw;
  white-space: nowrap;
  -webkit-transition: background-color 0.5s;
  transition: background-color 0.5s;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card-word-2 {
    top: calc(50% - 3.4666666667vw);
    min-width: 26.1333333333vw;
    height: 6.9333333333vw;
    padding: 0 8.2666666667vw 0 13.3333333333vw;
    border-radius: 3.4666666667vw;
  }
}
.sustainability-inochitsunagu__card-word-2 > span {
  font-size: calc(0.39rem + 22.1 * 0.0732064422vw);
  font-weight: var(--font-weight-bold);
  color: var(--color-black);
  -webkit-transition: color 0.5s;
  transition: color 0.5s;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card-word-2 > span {
    font-size: var(--font-size-sp-25px);
  }
}
.sustainability-inochitsunagu__card-image {
  position: relative;
  z-index: 2;
  width: 43.9238653001vw;
  border-radius: 0.7320644217vw;
  background-color: var(--color-lightYellow);
}
@media screen {
  .sustainability-inochitsunagu__card-image {
    opacity: 0;
    -webkit-transform: translateX(-100px);
            transform: translateX(-100px);
    -webkit-transition: opacity 0.5s, -webkit-transform 0.5s ease-out;
    transition: opacity 0.5s, -webkit-transform 0.5s ease-out;
    transition: transform 0.5s ease-out, opacity 0.5s;
    transition: transform 0.5s ease-out, opacity 0.5s, -webkit-transform 0.5s ease-out;
  }
  .sustainability-inochitsunagu__carousel.is-inview .sustainability-inochitsunagu__card-image {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card-image {
    width: 56vw;
    border-radius: 1.3333333333vw;
  }
}
@media screen {
  .sustainability-inochitsunagu__card-image--1 {
    -webkit-transition-delay: 0.5s;
            transition-delay: 0.5s;
  }
}
.sustainability-inochitsunagu__card-image--2 {
  position: absolute;
  z-index: 1;
  right: 0;
  bottom: 1.5373352855vw;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card-image--2 {
    bottom: 4.5333333333vw;
  }
}
.sustainability-inochitsunagu__card-image-inner {
  position: relative;
  overflow: hidden;
  border-radius: 0.7320644217vw;
}
@media screen {
  .sustainability-inochitsunagu__card-image-inner {
    -webkit-mask-image: -webkit-gradient(linear, left top, right top, from(#000), to(#000));
    -webkit-mask-image: linear-gradient(90deg, #000 0%, #000 100%);
            mask-image: -webkit-gradient(linear, left top, right top, from(#000), to(#000));
            mask-image: linear-gradient(90deg, #000 0%, #000 100%);
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
    -webkit-mask-size: 0% 100%;
            mask-size: 0% 100%;
    -webkit-mask-position: left top;
            mask-position: left top;
    -webkit-transition: -webkit-mask-size 0.5s 1.5s ease-out;
    transition: -webkit-mask-size 0.5s 1.5s ease-out;
    transition: mask-size 0.5s 1.5s ease-out;
    transition: mask-size 0.5s 1.5s ease-out, -webkit-mask-size 0.5s 1.5s ease-out;
  }
  .sustainability-inochitsunagu__carousel.is-inview .sustainability-inochitsunagu__card-image-inner {
    -webkit-mask-size: 100% 100%;
            mask-size: 100% 100%;
  }
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card-image-inner {
    border-radius: 1.3333333333vw;
  }
}
.sustainability-inochitsunagu__card-image-inner::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 0.2928257687vw;
  background-color: var(--color-red);
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transition: -webkit-transform 0.4s ease-out;
  transition: -webkit-transform 0.4s ease-out;
  transition: transform 0.4s ease-out;
  transition: transform 0.4s ease-out, -webkit-transform 0.4s ease-out;
  -webkit-transform-origin: left center;
          transform-origin: left center;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card-image-inner::after {
    height: 0.5333333333vw;
  }
}
@media screen {
  .sustainability-inochitsunagu__card-image--1 .sustainability-inochitsunagu__card-image-inner {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
    -webkit-transition: -webkit-mask-size 0.5s 1.5s ease-out, -webkit-transform 0.5s 2.5s ease-out;
    transition: -webkit-mask-size 0.5s 1.5s ease-out, -webkit-transform 0.5s 2.5s ease-out;
    transition: mask-size 0.5s 1.5s ease-out, transform 0.5s 2.5s ease-out;
    transition: mask-size 0.5s 1.5s ease-out, transform 0.5s 2.5s ease-out, -webkit-mask-size 0.5s 1.5s ease-out, -webkit-transform 0.5s 2.5s ease-out;
  }
  .sustainability-inochitsunagu__carousel.is-inview .sustainability-inochitsunagu__card-image--1 .sustainability-inochitsunagu__card-image-inner {
    -webkit-transform: translate(-1.4641288433vw, -1.4641288433vw);
            transform: translate(-1.4641288433vw, -1.4641288433vw);
  }
}
@media print {
  .sustainability-inochitsunagu__card-image--1 .sustainability-inochitsunagu__card-image-inner {
    -webkit-transform: translate(-1.4641288433vw, -1.4641288433vw);
            transform: translate(-1.4641288433vw, -1.4641288433vw);
  }
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card-image--1 .sustainability-inochitsunagu__card-image-inner {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
    -webkit-transition: -webkit-mask-size 0.5s 1.5s ease-out, -webkit-transform 0.5s 2.5s ease-out;
    transition: -webkit-mask-size 0.5s 1.5s ease-out, -webkit-transform 0.5s 2.5s ease-out;
    transition: mask-size 0.5s 1.5s ease-out, transform 0.5s 2.5s ease-out;
    transition: mask-size 0.5s 1.5s ease-out, transform 0.5s 2.5s ease-out, -webkit-mask-size 0.5s 1.5s ease-out, -webkit-transform 0.5s 2.5s ease-out;
  }
  .sustainability-inochitsunagu__carousel.is-inview .sustainability-inochitsunagu__card-image--1 .sustainability-inochitsunagu__card-image-inner {
    -webkit-transform: translate(-1.8666666667vw, -1.8666666667vw);
            transform: translate(-1.8666666667vw, -1.8666666667vw);
  }
}
.sustainability-inochitsunagu__card-image-inner > img {
  -webkit-transition: -webkit-filter 0.3s;
  transition: -webkit-filter 0.3s;
  transition: filter 0.3s;
  transition: filter 0.3s, -webkit-filter 0.3s;
}
.sustainability-inochitsunagu__card-arrow {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: absolute;
  z-index: 3;
  right: 0;
  bottom: 0;
  width: 4.39238653vw;
  height: 4.39238653vw;
  background-color: var(--color-red);
  border: 0.2196193265vw solid var(--color-red);
  border-radius: 50%;
  overflow: hidden;
  -webkit-box-shadow: 0 0 1.317715959vw rgba(0, 0, 0, 0.26);
          box-shadow: 0 0 1.317715959vw rgba(0, 0, 0, 0.26);
}
@media screen {
  .sustainability-inochitsunagu__card-arrow {
    opacity: 0;
    -webkit-transition: opacity 1.5s 3.5s;
    transition: opacity 1.5s 3.5s;
  }
  .sustainability-inochitsunagu__carousel.is-inview .sustainability-inochitsunagu__card-arrow {
    opacity: 1;
  }
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card-arrow {
    width: 12vw;
    height: 12vw;
    border: 0.4vw solid var(--color-red);
    -webkit-box-shadow: 0 0 2.4vw rgba(0, 0, 0, 0.26);
            box-shadow: 0 0 2.4vw rgba(0, 0, 0, 0.26);
  }
}
.sustainability-inochitsunagu__card-arrow::after {
  content: "";
  display: block;
  aspect-ratio: 1/1;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 0;
  border-radius: 50%;
  background-color: var(--color-white);
  -webkit-transition: width 0.3s ease;
  transition: width 0.3s ease;
}
.sustainability-inochitsunagu__card-arrow > span {
  position: relative;
  z-index: 2;
  width: 1.0980966325vw;
  background-color: var(--color-white);
  aspect-ratio: 8/10;
  -webkit-mask-image: url(/assets/img/common/icon_link_right.svg);
          mask-image: url(/assets/img/common/icon_link_right.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center center;
          mask-position: center center;
  -webkit-mask-size: contain;
          mask-size: contain;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__card-arrow > span {
    width: 2.8vw;
  }
}
.sustainability-inochitsunagu__controls {
  margin-top: 1.6837481698vw;
  padding-bottom: 3.0014641288vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.2928257687vw;
}
@media screen {
  .sustainability-inochitsunagu__controls {
    opacity: 0;
    -webkit-transition: opacity 1.5s 3.5s;
    transition: opacity 1.5s 3.5s;
  }
  .sustainability-inochitsunagu__carousel.is-inview .sustainability-inochitsunagu__controls {
    opacity: 1;
  }
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__controls {
    margin-top: 3.0666666667vw;
    padding-bottom: 13.3333333333vw;
    padding-left: 5.3333333333vw;
    gap: 4vw;
  }
}
.sustainability-inochitsunagu__slide-counter {
  padding-right: 1.8301610542vw;
  font-size: calc(0.24rem + 13.6 * 0.0732064422vw);
  font-weight: var(--font-weight-medium);
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__slide-counter {
    padding-right: 4vw;
    font-size: var(--font-size-sp-24px);
  }
}
.sustainability-inochitsunagu__button {
  position: relative;
  outline: none;
  width: 3.074670571vw;
  height: 3.074670571vw;
  background-color: var(--color-red);
  border-radius: 0.2928257687vw;
  overflow: hidden;
  border: 0.1464128843vw solid var(--color-red);
  display: grid;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__button {
    width: 8.4vw;
    height: 8.4vw;
    border-radius: 0.8vw;
    border: 0.4vw solid var(--color-red);
  }
}
.sustainability-inochitsunagu__button::after {
  content: "";
  display: block;
  aspect-ratio: 1/1;
  position: absolute;
  z-index: 1;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 0;
  border-radius: 50%;
  background-color: var(--color-white);
  -webkit-transition: width 0.3s ease;
  transition: width 0.3s ease;
}
.sustainability-inochitsunagu__button > span {
  position: relative;
  z-index: 2;
  display: block;
  width: 1.0248901903vw;
  background-color: var(--color-white);
  aspect-ratio: 8/10;
  -webkit-mask-image: url(/assets/img/common/icon_link_right.svg);
          mask-image: url(/assets/img/common/icon_link_right.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center center;
          mask-position: center center;
  -webkit-mask-size: contain;
          mask-size: contain;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__button > span {
    width: 2.8vw;
  }
}
.sustainability-inochitsunagu__button--prev > span {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}
@media (hover: hover) and (pointer: fine) {
  .sustainability-inochitsunagu__button:hover::after {
    width: 300%;
  }
  .sustainability-inochitsunagu__button:hover > span {
    background-color: var(--color-red);
  }
}
.sustainability-inochitsunagu__button:focus-visible {
  border-color: var(--color-almostBlack);
}
.sustainability-inochitsunagu__button:focus-visible::after {
  width: 300%;
}
.sustainability-inochitsunagu__button:focus-visible > span {
  background-color: var(--color-almostBlack);
}
.sustainability-inochitsunagu__toggle-button {
  position: relative;
  width: 3.074670571vw;
  height: 3.074670571vw;
  background-color: var(--color-black);
  border-radius: 0.2928257687vw;
  overflow: hidden;
  border: 0.1464128843vw solid var(--color-black);
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__toggle-button {
    width: 8.4vw;
    height: 8.4vw;
    border-radius: 0.8vw;
    border: 0.4vw solid var(--color-black);
  }
}
.sustainability-inochitsunagu__toggle-button::after {
  content: "";
  display: block;
  aspect-ratio: 1/1;
  position: absolute;
  z-index: 1;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 0;
  border-radius: 50%;
  background-color: var(--color-white);
  -webkit-transition: width 0.3s ease;
  transition: width 0.3s ease;
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__toggle-button::after {
    border-radius: 0.6vw;
  }
}
.sustainability-inochitsunagu__toggle-button > span {
  position: absolute;
  z-index: 2;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 33.3333333333%;
  background-color: var(--color-white);
  aspect-ratio: 9/10;
  -webkit-mask-image: url(/assets/img/common/icon_play.svg);
          mask-image: url(/assets/img/common/icon_play.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center center;
          mask-position: center center;
  -webkit-mask-size: contain;
          mask-size: contain;
}
.sustainability-inochitsunagu__toggle-button[aria-pressed=true] > span {
  aspect-ratio: 1/1;
  -webkit-mask-image: url(/assets/img/common/icon_stop.svg);
          mask-image: url(/assets/img/common/icon_stop.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center center;
          mask-position: center center;
  -webkit-mask-size: contain;
          mask-size: contain;
}
@media (hover: hover) and (pointer: fine) {
  .sustainability-inochitsunagu__toggle-button:hover::after {
    width: 300%;
  }
  .sustainability-inochitsunagu__toggle-button:hover > span {
    background-color: var(--color-black);
  }
}
.sustainability-inochitsunagu__toggle-button:focus-visible::before {
  content: "";
  display: block;
  position: absolute;
  z-index: 2;
  inset: 0;
  width: 100%;
  height: 100%;
  border-radius: 0.2928257687vw;
  border: 0.1464128843vw solid var(--color-white);
}
@media only screen and (max-width: 767px) {
  .sustainability-inochitsunagu__toggle-button:focus-visible::before {
    border-radius: 0.8vw;
    border: 0.4vw solid var(--color-black);
  }
}

.sustainability-value-chain {
  width: 100%;
  margin-top: min(60px, 5vw);
  background-color: #ffe97b;
  padding-top: min(32px, 2.6666666667%);
  padding-bottom: min(60px, 5%);
}
@media only screen and (max-width: 767px) {
  .sustainability-value-chain {
    margin-top: 8.125%;
    padding-top: 6.09375%;
    padding-bottom: 12.5%;
  }
}
.sustainability-value-chain > div {
  width: min(1080px, 100% - 120px);
  margin: 0 auto;
}
@media only screen and (max-width: 767px) {
  .sustainability-value-chain > div {
    width: 87.5%;
  }
}
.sustainability-value-chain__title {
  font-size: min(40px, 3.3333333333vw);
  line-height: 1.575;
  font-weight: 900;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .sustainability-value-chain__title {
    font-size: 6.25vw;
    line-height: 1.675;
  }
}
.sustainability-value-chain__text {
  margin-top: min(22px, 2.037037037%);
  font-size: min(16px, 1.3333333333vw);
  line-height: 1.75;
  text-align: justify;
}
@media only screen and (max-width: 767px) {
  .sustainability-value-chain__text {
    margin-top: 5.7142857143%;
    font-size: 4.0625vw;
    line-height: 1.6538461538;
  }
}
.sustainability-value-chain__figure {
  margin: min(32px, 2.962962963%) 0 0;
  padding: min(30px, 2.7777777778%);
  background-color: #fff;
  border-radius: 5px;
}
@media only screen and (max-width: 767px) {
  .sustainability-value-chain__figure {
    margin: 9.1071428571% 0 0;
    padding: 5.3571428571%;
  }
}
.sustainability-value-chain__figure > img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}
.sustainability-value-chain__figure > img[src$="--pc.png"] {
  display: block;
}
@media only screen and (max-width: 767px) {
  .sustainability-value-chain__figure > img[src$="--pc.png"] {
    display: none;
  }
}
.sustainability-value-chain__figure > img[src$="--sp.png"] {
  display: none;
}
@media only screen and (max-width: 767px) {
  .sustainability-value-chain__figure > img[src$="--sp.png"] {
    display: block;
  }
}

.sustainability-materiality {
  width: 100%;
  margin-top: min(92px, 7.6666666667vw);
  background-color: #fff;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality {
    margin-top: 9.53125%;
  }
}
.sustainability-materiality > div {
  width: min(1200px, 100%);
  margin: 0 auto;
}
.sustainability-materiality__title {
  font-size: min(40px, 3.3333333333vw);
  line-height: 1.575;
  font-weight: 900;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__title {
    font-size: 6.25vw;
    padding-left: 5.46875vw;
  }
}
.sustainability-materiality__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 3.75%;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__list {
    margin-top: -2.03125%;
    display: block;
  }
}
.sustainability-materiality__item {
  width: 50%;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__item {
    padding-top: 9.375%;
    width: 87.5%;
    margin: 0 auto;
  }
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__item:nth-child(n+2) {
    margin-top: 3.125%;
  }
}
@media screen and (min-width: 768px) {
  .sustainability-materiality__item:nth-child(n+3) {
    margin-top: 8.3333333333%;
  }
}
.sustainability-materiality__header {
  position: relative;
}
.sustainability-materiality__heading {
  position: relative;
  width: 90%;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__heading {
    width: auto;
  }
}
.sustainability-materiality__heading::after {
  position: absolute;
  top: min(80px, 6.6666666667vw);
  left: 20%;
  content: "";
  width: 80%;
  height: 1px;
  border-top: 1px solid #333;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__heading::after {
    top: 12.5vw;
    left: 21.4285714286%;
    width: 75%;
  }
}
.sustainability-materiality__heading-number {
  display: block;
  width: 22.2222222222%;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__heading-number {
    width: 21.4285714286%;
  }
}
.sustainability-materiality__heading-number > img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}
.sustainability-materiality__heading-text {
  margin-top: 4.3333333333%;
  display: block;
  font-size: min(36px, 3vw);
  line-height: 1.3888888889;
  font-weight: 900;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__heading-text {
    margin-top: 7.8571428571%;
    padding-left: 4.4642857143%;
    font-size: 5.2941176471vw;
  }
}
.sustainability-materiality__pictogram {
  position: absolute;
  top: 0;
  left: 38.3333333333%;
  width: 33.3333333333%;
  background-color: #fff;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__pictogram {
    left: 39.6428571429%;
    width: 35.7142857143%;
  }
}
.sustainability-materiality__pictogram > img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}
.sustainability-materiality__body {
  width: 80%;
  margin: 5% auto 0;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__body {
    width: auto;
    margin: 4.1071428571%;
  }
}
.sustainability-materiality__text {
  font-size: min(16px, 1.3333333333vw);
  line-height: 1.75;
  text-align: justify;
}
@media screen and (min-width: 768px) {
  .p-materiality__item--2 .sustainability-materiality__text {
    margin-right: -0.5em;
  }
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__text {
    font-size: 4.0625vw;
    line-height: 1.6538461538;
  }
}
.sustainability-materiality__sdgs-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 5%;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__sdgs-list {
    margin-top: 5.5357142857%;
    padding-left: 4.4642857143%;
  }
}
.sustainability-materiality__sdgs-list > li {
  width: 21.875%;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__sdgs-list > li {
    width: 19.6261682243%;
  }
}
.sustainability-materiality__sdgs-list > li:nth-child(n+2) {
  margin-left: 4.1666666667%;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__sdgs-list > li:nth-child(n+2) {
    margin-left: 3.738317757%;
  }
}
.sustainability-materiality__sdgs-list > li > img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}
.sustainability-materiality__footer {
  margin-top: 5%;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__footer {
    margin-top: 7.1428571429%;
  }
}
.sustainability-materiality__line {
  margin: 0 auto;
  width: 80%;
}
@media only screen and (max-width: 767px) {
  .sustainability-materiality__line {
    width: 100%;
  }
}
.sustainability-materiality__line > img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}

.sustainability-initiatives {
  margin-top: min(80px, 6.6666666667vw);
  width: 100%;
  max-width: var(--design-inner-width-pc);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives {
    margin-top: 12.2666666667vw;
    padding: 0 6vw;
  }
}
.sustainability-initiatives__title {
  font-size: var(--font-size-pc-40px);
  font-weight: var(--font-weight-black);
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__title {
    font-size: var(--font-size-sp-50px);
  }
}
.sustainability-initiatives__lead {
  margin-top: min(21px, 1.75vw);
  font-size: var(--font-size-pc-16px);
  font-weight: var(--font-weight-medium);
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__lead {
    margin-top: 6vw;
    font-size: var(--font-size-sp-26px);
  }
}
.sustainability-initiatives__buttons-area {
  margin-top: min(53px, 4.4166666667vw);
  display: grid;
  grid-template-columns: min(280px, 23.3333333333vw) auto;
  gap: min(10px, 0.8333333333vw);
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__buttons-area {
    margin-top: 9.2vw;
    grid-template-columns: 100%;
    gap: 5.3333333333vw;
  }
}
.sustainability-initiatives__buttons-area-inner:nth-child(2) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 2px;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__buttons-area-inner:nth-child(2) {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 0 4vw;
    gap: 5.3333333333vw;
  }
}
.sustainability-initiatives__all-button {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
  border-radius: min(2px, 0.1666666667vw);
  overflow: hidden;
  background-color: var(--color-lightPink);
  border: min(2px, 0.1666666667vw) solid var(--color-lightPink);
  cursor: pointer;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__all-button {
    height: 13.3333333333vw;
    border-radius: 2vw;
    border-width: 0.2666666667vw;
  }
}
.sustainability-initiatives__all-button::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  display: block;
  aspect-ratio: 1/1;
  border-radius: 50%;
  width: 0;
  background-color: var(--color-white);
  -webkit-transition: width 0.4s;
  transition: width 0.4s;
}
@media (hover: hover) and (pointer: fine) {
  .sustainability-initiatives__all-button:hover::before {
    width: 200%;
  }
}
.sustainability-initiatives__all-button:focus-visible {
  border-radius: min(2px, 0.1666666667vw);
  background-color: var(--color-focus-bg);
  border-color: var(--color-focus-border);
}
.sustainability-initiatives__all-button > span {
  position: relative;
  z-index: 2;
  font-size: min(0.08rem + 15.2 * 0.0833333333vw, 1.6rem);
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  line-height: 1;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__all-button > span {
    font-size: min(0.13rem + 24.7 * 0.1333333333vw, 2.6rem);
  }
}
.sustainability-initiatives__button {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0 min(30px, 2.5vw);
  height: min(30px, 2.5vw);
  border-radius: min(2px, 0.1666666667vw);
  overflow: hidden;
  background-color: var(--color-offWhite);
  cursor: pointer;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__button {
    padding: 0 1em;
    height: 6.6666666667vw;
    border-radius: 0.8vw;
  }
}
.sustainability-initiatives__button[hidden] {
  display: none;
}
.sustainability-initiatives__button.is-selected {
  background-color: var(--color-lightYellow-2);
}
.sustainability-initiatives__button.not-selected {
  background-color: var(--color-lightGray-2);
  color: var(--color-middleGray-6);
  -webkit-transition: color 0.4s;
  transition: color 0.4s;
}
.sustainability-initiatives__button::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  display: block;
  aspect-ratio: 1/1;
  border-radius: 50%;
  width: 0;
  background-color: var(--color-lightYellow-2);
  -webkit-transition: width 0.4s;
  transition: width 0.4s;
}
@media (hover: hover) and (pointer: fine) {
  .sustainability-initiatives__button:hover::before {
    width: 200%;
  }
  .sustainability-initiatives__button:hover > span {
    color: var(--color-default);
  }
}
.sustainability-initiatives__button:focus-visible {
  border-radius: min(2px, 0.1666666667vw);
  background-color: var(--color-focus-bg);
  border-color: var(--color-focus-border);
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__button:focus-visible {
    border-radius: 0.2666666667vw;
  }
}
.sustainability-initiatives__button > span {
  position: relative;
  z-index: 2;
  font-size: min(0.08rem + 15.2 * 0.0833333333vw, 1.6rem);
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  line-height: 1;
  white-space: nowrap;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__button > span {
    font-size: min(0.13rem + 24.7 * 0.1333333333vw, 2.6rem);
  }
}
.sustainability-initiatives__cards {
  margin-top: min(60px, 5vw);
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: min(50px, 4.1666666667vw) min(27px, 2.25vw);
}
.sustainability-initiatives__cards.is-lt4 {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__cards.is-lt4 {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: start;
  }
}
.sustainability-initiatives__cards.is-1 {
  -webkit-box-pack: center !important;
      -ms-flex-pack: center !important;
          justify-content: center !important;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__cards {
    margin-top: 10.6666666667vw;
    gap: 6.6666666667vw 5.3333333333vw;
  }
}
.sustainability-initiatives__card {
  position: relative;
  padding-top: min(30px, 2.5vw);
  width: calc((100% - min(27px, 2.25vw) * 3) / 4);
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__card {
    padding-top: 7.4666666667vw;
    width: calc((100% - 5.3333333333vw) / 2);
  }
}
.sustainability-initiatives__card-tag {
  position: absolute;
  top: 0;
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: min(180px, 15vw);
  height: min(40px, 3.3333333333vw);
  padding-bottom: min(10px, 0.8333333333vw);
  border-radius: min(3px, 0.25vw) min(3px, 0.25vw) 0 0;
  overflow: hidden;
}
.sustainability-initiatives__card-tag--nosan {
  background-color: var(--color-red);
  color: var(--color-white);
}
.sustainability-initiatives__card-tag--livestock {
  background-color: var(--color-sustainability-livestock);
}
.sustainability-initiatives__card-tag--aqua {
  background-color: var(--color-sustainability-aqua);
}
.sustainability-initiatives__card-tag--egg {
  background-color: var(--color-sustainability-egg);
}
.sustainability-initiatives__card-tag--pet-food {
  background-color: var(--color-sustainability-pet-food);
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__card-tag {
    width: 100%;
    height: 9.0666666667vw;
    padding-bottom: 1.6vw;
    border-radius: 0.4vw 0.4vw 0 0;
  }
}
.sustainability-initiatives__card-tag > span {
  font-size: min(0.075rem + 14.25 * 0.0833333333vw, 1.5rem);
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  line-height: 1;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__card-tag > span {
    font-size: min(0.13rem + 24.7 * 0.1333333333vw, 2.6rem);
  }
}
.sustainability-initiatives__card-link {
  position: relative;
  z-index: 2;
  display: block;
}
@media (hover: hover) and (pointer: fine) {
  .sustainability-initiatives__card-link:hover .sustainability-initiatives__card-image::after {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .sustainability-initiatives__card-link:hover .sustainability-initiatives__card-image > img {
    -webkit-filter: brightness(50%);
            filter: brightness(50%);
  }
  .sustainability-initiatives__card-link:hover .sustainability-initiatives__card-text > span {
    color: var(--color-link-marked-hover);
  }
  .sustainability-initiatives__card-link:hover .sustainability-initiatives__card-text > span::after {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: left top;
            transform-origin: left top;
  }
}
.sustainability-initiatives__card-link:focus-visible::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 2px solid var(--color-black);
  border-radius: min(10px, 0.8333333333vw);
}
.sustainability-initiatives__card-image {
  position: relative;
  border-radius: min(10px, 0.8333333333vw);
  overflow: hidden;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__card-image {
    border-radius: 1.3333333333vw;
  }
}
.sustainability-initiatives__card-image::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: min(4px, 0.3333333333vw);
  background-color: var(--color-red);
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: left top;
          transform-origin: left top;
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__card-image::after {
    height: 0.5333333333vw;
  }
}
.sustainability-initiatives__card-image > img {
  width: 100%;
  -webkit-transition: -webkit-filter 0.4s;
  transition: -webkit-filter 0.4s;
  transition: filter 0.4s;
  transition: filter 0.4s, -webkit-filter 0.4s;
}
.sustainability-initiatives__card-text {
  margin-top: min(9px, 0.75vw);
  padding-left: min(7px, 0.5833333333vw);
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__card-text {
    margin-top: 1.3333333333vw;
    padding-left: 1.3333333333vw;
  }
}
.sustainability-initiatives__card-text > span {
  position: relative;
  display: inline-block;
  padding-left: min(17px, 1.4166666667vw);
  font-size: var(--font-size-pc-16px);
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  color: var(--color-link-marked-default);
  -webkit-transition: color 0.4s;
  transition: color 0.4s;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__card-text > span {
    padding-left: 5.0666666667vw;
    font-size: var(--font-size-sp-24px);
  }
}
.sustainability-initiatives__card-text > span::before {
  content: "";
  display: block;
  position: absolute;
  top: 0.5em;
  left: 0;
  width: 0.5625em;
  background-color: var(--color-red);
  aspect-ratio: 8/10;
  -webkit-mask-image: url(/assets/img/common/icon_link_right.svg);
          mask-image: url(/assets/img/common/icon_link_right.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center center;
          mask-position: center center;
  -webkit-mask-size: contain;
          mask-size: contain;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__card-text > span::before {
    top: 0.4166666667em;
    width: 0.6666666667em;
  }
}
.sustainability-initiatives__card-text > span::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: var(--color-link-marked-hover);
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: right top;
          transform-origin: right top;
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
}
.sustainability-initiatives__card-tags {
  margin-top: min(14px, 1.1666666667vw);
  padding-left: min(24px, 2vw);
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__card-tags {
    margin-top: 2.5333333333vw;
    padding-left: 6.4vw;
  }
}
.sustainability-initiatives__card-tags > li {
  font-size: min(0.075rem + 14.25 * 0.0833333333vw, 1.5rem);
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  line-height: 1;
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__card-tags > li {
    font-size: min(0.11rem + 20.9 * 0.1333333333vw, 2.2rem);
  }
}
.sustainability-initiatives__card-tags > li:nth-child(n+2) {
  margin-top: min(10px, 0.8333333333vw);
}
@media only screen and (max-width: 767px) {
  .sustainability-initiatives__card-tags > li:nth-child(n+2) {
    margin-top: 2.1333333333vw;
  }
}

.sustainability-faq {
  width: 100%;
  background-color: #fff;
  margin-top: min(82px, 6.8333333333%);
}
@media only screen and (max-width: 767px) {
  .sustainability-faq {
    margin-top: 13.7333333333vw;
  }
}
.sustainability-faq > div {
  width: min(1080px, 100% - 120px);
  margin: 0 auto;
}
@media only screen and (max-width: 767px) {
  .sustainability-faq > div {
    width: 87.5%;
  }
}
.sustainability-faq__title {
  font-size: min(40px, 3.3333333333vw);
  line-height: 1.575;
  font-weight: 900;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__title {
    font-size: 6.25vw;
  }
}
.sustainability-faq__list {
  margin-top: 2.3148148148%;
  border-bottom: 1px solid #c8c8c8;
  padding-bottom: 3.7037037037%;
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__list {
    margin-top: 8.75%;
    padding-bottom: 7.1428571429%;
  }
}
.sustainability-faq__question {
  border-top: 1px solid #c8c8c8;
  position: relative;
  padding: 3.6111111111% 2.3148148148% 0 8.7962962963%;
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__question {
    padding: 5.7142857143% 0 0 17.5%;
  }
}
.sustainability-faq__question:nth-child(n+2) {
  margin-top: 3.7037037037%;
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__question:nth-child(n+2) {
    margin-top: 7.1428571429%;
  }
}
.sustainability-faq__answer {
  position: relative;
  padding: 2.6851851852% 2.3148148148% 0 8.7962962963%;
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__answer {
    margin-top: 12px;
    padding: 0;
  }
}
.sustainability-faq__icon {
  position: absolute;
  top: min(30px, 2.5vw);
  left: 2.7777777778%;
  width: 4.1666666667%;
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__icon {
    left: 0;
    width: 10.3571428571%;
  }
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__icon--question {
    top: 6.25vw;
  }
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__icon--answer {
    top: 1.09375vw;
  }
}
.sustainability-faq__icon > img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}
.sustainability-faq__text--question {
  font-size: min(18px, 1.5vw);
  font-weight: 700;
  line-height: 1.5;
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__text--question {
    font-size: 4.375vw;
    line-height: 1.5714285714;
  }
}
.sustainability-faq__text--answer {
  font-size: min(16px, 1.3333333333vw);
  font-weight: 400;
  line-height: 1.5625;
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__text--answer {
    padding: 0 0 0 17.5%;
    font-size: 4.0625vw;
    line-height: 1.6538461538;
  }
}
.sustainability-faq__text--answer > sup {
  vertical-align: super;
  font-size: min(12px, 1vw);
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__text--answer > sup {
    font-size: 2.8125vw;
  }
}
.sustainability-faq__text--note {
  margin-top: min(24px, 2vw);
  font-size: min(14px, 1.1666666667vw);
  font-weight: 400;
  line-height: 1.5625;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__text--note {
    padding: 0 0 0 17.5%;
    margin-top: 7.8571428571%;
    font-size: 2.8125vw;
  }
}
.sustainability-faq__btn-wrap {
  margin-top: 3.1481481481%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__btn-wrap {
    margin-top: 5.5357142857%;
    display: block;
  }
}
.sustainability-faq__btn {
  position: relative;
  height: min(45px, 3.75vw);
  padding: 0 min(40px, 3.3333333333vw) 0 min(30px, 2.5vw);
  background-color: #ffd800 !important;
  border-radius: 100vh;
  display: grid;
  place-items: center;
}
@media (hover: hover) {
  .sustainability-faq__btn {
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
  }
  .sustainability-faq__btn:hover {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__btn {
    place-items: center start;
    width: 100%;
    height: 14.0625vw;
    padding-left: 6.4285714286%;
  }
}
@media screen and (min-width: 768px) {
  .sustainability-faq__btn:nth-child(n+2) {
    margin-left: min(20px, 1.6666666667vw);
  }
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__btn:nth-child(n+2) {
    margin-top: 7.1428571429%;
  }
}
.sustainability-faq__btn::after {
  position: absolute;
  top: min(18px, 1.5vw);
  right: min(20px, 1.6666666667vw);
  content: "";
  display: block;
  width: min(8px, 0.6666666667vw);
  height: min(10px, 0.8333333333vw);
  background-color: #333;
  -webkit-mask-image: url(/assets/img/sustainability/icon_mask_arrow_01.svg);
          mask-image: url(/assets/img/sustainability/icon_mask_arrow_01.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center center;
          mask-position: center center;
  -webkit-mask-size: cover;
          mask-size: cover;
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__btn::after {
    top: 5.46875vw;
    right: 4.6875vw;
    width: 2.65625vw;
    height: 3.125vw;
  }
}
.sustainability-faq__btn > span {
  font-size: min(18px, 1.5vw);
  line-height: 1;
  font-weight: 400;
  color: #333;
  -webkit-transform: translateY(min(-1px, -0.0833333333vw));
          transform: translateY(min(-1px, -0.0833333333vw));
}
@media only screen and (max-width: 767px) {
  .sustainability-faq__btn > span {
    font-size: 3.75vw;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}/*# sourceMappingURL=sustainability.css.map */