/* =============================================================
    Page
============================================================= */
/* aboutus
------------------------------------------------------------- */
@media screen and (min-width: 768px) {
  .sponly {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .pconly {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .m-breadcrumb {
    margin-bottom: 1.1rem;
  }
}

.aboutus-top {
  position: relative;
}
.aboutus-top__img img {
  width: 100%;
}
.aboutus-top__text {
  position: absolute;
  bottom: 2rem;
  left: 1.3rem;
  display: grid;
  gap: 1.5rem;
}
.aboutus-top-text__title {
  font-family: var(--font-ja-title);
  font-weight: 500;
  font-size: 2.3rem;
  letter-spacing: 0.08em;
  line-height: 1.6;
  color: var(--color-white);
}
.aboutus-top-text__sub-title {
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 1.6;
  color: var(--color-white);
}
@media screen and (min-width: 768px) {
  .aboutus-top__text {
    top: 50%;
    bottom: unset;
    transform: translateY(-50%);
    left: calc((100vw - var(--container-default)) / 2);
  }
  .aboutus-top-text__title {
    font-size: 2.6rem;
  }
  .aboutus-top-text__sub-title {
    font-size: 1.5rem;
  }
}

.aboutus-what {
  padding: 4rem 1.5rem;
}
.aboutus-what__title {
  font-family: Nunito;
  font-weight: 300;
  font-size: 5rem;
  letter-spacing: 0.08em;
  line-height: 1.52;
  text-align: center;
  color: #4d9a3f;
  opacity: 0.2;
  position: relative;
  z-index: 1;
}
.aboutus-what__img {
  width: 100%;
  position: relative;
  top: -2.8rem;
}
.aboutus-what__sub-title {
  font-family: var(--font-ja-title);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
  text-align: center;
  color: #4d9a3f;
  margin-top: calc(-2.8rem + 1rem);
  margin-bottom: 1rem;
}
.aboutus-what-sub-sub-title {
  font-weight: 600;
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 1.225;
  margin-block: 2rem 0.5rem;
}
.aboutus-what__desc {
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
}
@media screen and (min-width: 768px) {
  .aboutus-what {
    padding: 5.7rem calc((100vw - 90rem) / 2) 8rem;
  }
  .aboutus-what__title {
    font-size: 11rem;
    text-align: center;
  }
  .aboutus-what__img {
    width: 53rem;
    top: -6.1rem;
    margin-inline: auto;
  }
  .aboutus-what__sub-title {
    font-size: 2.4rem;
    margin-top: calc(-6.1rem + 2rem);
    margin-bottom: 2rem;
  }
}

.aboutus-features {
  padding: 4rem 1.5rem;
  background: rgba(155, 183, 119, 0.1);
}
.aboutus-features__title {
  font-family: var(--font-ja-title);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
  text-align: center;
  color: #4d9a3f;
  margin-bottom: 1rem;
}
.aboutus-features__list {
  display: grid;
  gap: 3.5rem;
}
.aboutus-features-item__img {
  width: calc(100% - 3rem);
  margin-inline: auto;
  border-top-right-radius: 3rem;
  border-bottom-left-radius: 3rem;
}
.aboutus-features-item__title {
  font-family: var(--font-ja-title);
  font-weight: 500;
  font-size: 1.8rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
  text-align: center;
  color: var(--color-white);
  background: #4D9A3F;
  width: fit-content;
  height: 3.6rem;
  padding-inline: 2rem;
  display: grid;
  align-items: center;
  margin-inline: auto;
  position: relative;
  margin-top: -1.8rem;
}
.aboutus-features-item__desc {
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
  margin-top: 1.5rem;
}
.aboutus-features-item-desc__list {
  margin-block: 1.5rem;
}
.aboutus-features-item-desc__list li {
  list-style-type: disc;
  padding-left: 1.4rem;
  text-indent: -1.4rem;
  list-style-position: inside;
  font-size: 1.3rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
}
.aboutus-features-item-desc__list li::marker {
  color: #4D9A3F;
}
.aboutus-features__other {
  margin-top: 3.5rem;
}
.aboutus-features-other__title {
  font-weight: 600;
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 1.225;
  color: #4d9a3f;
  margin-bottom: 0.5rem;
}
.aboutus-features-other__list li {
  list-style-type: disc;
  padding-left: 1.4rem;
  text-indent: -1.4rem;
  list-style-position: inside;
  font-size: 1.3rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
}
.aboutus-features-other__list li::marker {
  color: #4D9A3F;
}
@media screen and (min-width: 768px) {
  .aboutus-features {
    padding: 8rem calc((100vw - 108.15rem) / 2);
    background: rgba(155, 183, 119, 0.25);
  }
  .aboutus-features__title {
    font-size: 2.4rem;
  }
  .aboutus-features__list {
    grid-template-columns: 1fr 1fr;
    gap: 6rem;
  }
  .aboutus-features__item {
    background: var(--color-white);
    padding: 4rem;
  }
  .aboutus-features-item__img {
    width: calc(100% - 4rem);
  }
  .aboutus-features-item__title {
    font-size: 2.0rem;
    height: 3.9rem;
    margin-top: -1.95rem;
  }
  .aboutus-features__other {
    width: 90rem;
    margin-inline: auto;
  }
}

.aboutus-production {
  padding: 4rem 1.5rem;
  display: grid;
  gap: 4rem;
}
.aboutus-production-top__img {
  border-top-right-radius: 3rem;
  border-bottom-left-radius: 3rem;
}
.aboutus-production-top-text__title {
  font-family: var(--font-ja-title);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
  color: #4d9a3f;
  margin-top: 1.5rem;
  margin-bottom: 1rem;
}
.aboutus-production-top-text__desc {
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
}
.aboutus-production-bottom__title {
  font-family: var(--font-ja-title);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
  color: #4d9a3f;
  margin-bottom: 1rem;
}
.aboutus-production-bottom__desc {
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
}
.aboutus-production-bottom__step {
  display: grid;
  grid-template-columns: auto 26.4rem;
  gap: 2.5rem 3.1rem;
  margin-top: 2.04rem;
}
.aboutus-production-bottom-step__title {
  position: relative;
}
.aboutus-production-bottom-step__title:after {
  content: '';
  background-image: linear-gradient(0deg, #9dc884, #c7e0a8);
  height: 100%;
  width: 0.5rem;
  position: absolute;
  left: 2.25rem;
}
.aboutus-production-bottom-step__title:nth-of-type(2):after {
  background-image: linear-gradient(0deg, #72B05F, #9dc884);
}
.aboutus-production-bottom-step__title:nth-of-type(3):after {
  background-image: linear-gradient(0deg, #4D9A3F, #72B05F);
}
.aboutus-production-bottom-step__title:nth-of-type(4):after {
  content: unset;
}
.aboutus-production-bottom-step__title span {
  background: #C7E0A8;
  width: 5rem;
  height: 5rem;
  text-align: center;
  display: grid;
  align-items: center;
  border-radius: 9999px;
  font-family: var(--font-ja-title);
  font-weight: bold;
  font-size: 2.4rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
  color: var(--color-white);
}
.aboutus-production-bottom-step__title:nth-of-type(2) span {
  background: #9DC884;
}
.aboutus-production-bottom-step__title:nth-of-type(3) span {
  background: #72B05F;
}
.aboutus-production-bottom-step__title:nth-of-type(4) span {
  background: #4D9A3F;
}
.aboutus-production-bottom-step__desc {
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
}
.aboutus-production-bottom-step-desc__img {
  border-top-right-radius: 3rem;
  border-bottom-left-radius: 3rem;
}
.aboutus-production-bottom-step-desc__title {
  font-weight: 600;
  font-size: 1.5rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
  display: block;
  margin-block: 1rem 0.5rem;
}
@media screen and (min-width: 768px) {
  .aboutus-production {
    padding: 8rem calc((100vw - 114rem) / 2);
    gap: 8rem;
  }
  .aboutus-production__top {
    display: grid;
    grid-template-columns: 61.4% auto;
    gap: 6.14%;
  }
  .aboutus-production-top__img {
    border-top-right-radius: 4rem;
    border-bottom-left-radius: 4rem;
  }
  .aboutus-production-top__text {
    height: fit-content;
    margin-block: auto;
  }
  .aboutus-production-top-text__title {
    font-size: 2.4rem;
    margin-top: 0;
    margin-bottom: 2rem;
  }
  .aboutus-production-bottom-step__title:after {
    background-image: linear-gradient(-90deg, #9dc884, #c7e0a8);
  }
  .aboutus-production-bottom-step__title:nth-of-type(2):after {
    background-image: linear-gradient(-90deg, #72B05F, #9dc884);
  }
  .aboutus-production-bottom-step__title:nth-of-type(3):after {
    background-image: linear-gradient(-90deg, #4D9A3F, #72B05F);
  }
  .aboutus-production-bottom__title {
    font-size: 2.4rem;
    margin-bottom: 2rem;
  }
  .aboutus-production-bottom__step {
    display: grid;
    grid-template-columns: unset;
    grid-auto-flow: column;
    grid-template-rows: repeat(2, auto);
    gap: 1.5rem 2.8rem;
    margin-top: 3rem;
  }
  .aboutus-production-bottom-step__title span {
    margin-inline: auto;
  }
  .aboutus-production-bottom-step__title:after {
    height: 0.5rem;
    width: 100%;
    position: absolute;
    left: calc(50% + 2.25rem);
    top: 2.25rem;
  }
  .aboutus-production-bottom-step-desc__title {
    margin-block: 1rem 1rem;
    text-align: center;
  }
}

.aboutus-bottom {
  padding-inline: 1.5rem;
  position: relative;
}
.aboutus-bottom__img img {
  width: 100%;
  border-top-right-radius: 5rem;
  border-bottom-left-radius: 5rem;
}
.aboutus-bottom__text {
  position: absolute;
  width: 29.5rem;
  bottom: 4rem;
  left: 50%;
  transform: translateX(-50%);
  display: grid;
  gap: 1.5rem;
}
.aboutus-bottom-text__title {
  font-family: var(--font-ja-title);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
  color: var(--color-white);
  text-align: center;
}
.aboutus-bottom-text__sub-title {
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
  color: var(--color-white);
}
@media screen and (min-width: 768px) {
  .aboutus-bottom {
    padding-inline: 3rem;
  }
  .aboutus-bottom__text {
    width: 83.8rem;
    top: 50%;
    bottom: unset;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    gap: 2rem;
  }
  .aboutus-bottom-text__title {
    font-size: 2.4rem;
  }

