@charset "utf-8";

.axis {
  width: 100%;
  height: 100lvh;
  grid-template-columns: calc(832 / 1575 * 100%) minmax(0, 1fr);
  grid-template-rows: calc(var(--header-height, 80px) + 30px) minmax(0, 1fr) minmax(0, auto) minmax(0, auto) minmax(0, 1fr) minmax(0, 30px);
  align-content: center;
  align-items: start;
  gap: 0 calc(64 / 1575 * 100%);
}
.axis + .axis {
  position: absolute;
  top: 0;
  left: 0;
}
.axis-heading {
  grid-column: 1;
  grid-row: 3;
}
.axis-heading-en {
  display: inline-block;
  padding-inline: .05em;
  font-size: clamp(22px, calc(32 / 1200 * 100vw), 32px);
  background: rgb(var(--color-red));
  opacity: 0;
}
.axis-heading-ja {
  margin-top: 24px;
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: minmax(0, auto);
  grid-auto-rows: minmax(0, auto);
  justify-items: start;
  align-items: start;
  gap: min(30px, 3.5lvh) 0;
}
.axis-heading-ja span {
  display: block;
  height: 100%;
  max-height: 10lvh;
  opacity: 0;
}
.axis-heading-ja span img {
  height: 100%;
  object-fit: contain;
  object-position: top left;
}
.axis-photo {
  grid-column: 2;
  grid-row: 2 / 6;
  align-self: center;
  position: relative;
  z-index: 1;
  height: 100%;
}
.axis-photo-item {
  height: 100%;
}
.axis-photo-item--default {
  position: relative;
  z-index: 1;
}
.axis-photo-item--active {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
}
.axis-photo-item img {
  height: 100%;
  object-fit: contain;
}
.axis-desc {
  grid-column: 1;
  grid-row: 4;
  margin-top: 48px;
  opacity: 0;
}
.axis-desc-copy {
  font-size: clamp(16px, calc(24 / 1200 * 100vw), 24px);
  line-height: 2.2;
}
@media screen and (max-width: 767px) {
  .axis {
    height: auto;
    grid-template-columns: 100%;
    grid-template-rows: auto;
    align-content: start;
    gap: 0;
  }
  .axis + .axis {
    position: relative;
    margin-top: 60px;
  }
  .axis-heading {
    grid-row: 1;
  }
  .axis-heading-en {
    font-size: 20px;
  }
  .axis-heading-ja {
    margin-top: 15px;
    gap: 12px 0;
  }
  .axis-heading-ja span {
    height: auto;
    max-height: none;
  }
  .axis-heading-ja span img {
    height: auto;
  }
  .axis-photo {
    grid-column: 1;
    grid-row: 2;
    align-self: start;
    height: auto;
    margin-top: 30px;
  }
  .axis-photo-item {
    height: auto;
  }
  .axis-photo-item img {
    height: auto;
  }
  .axis-desc {
    grid-row: 3;
    margin-top: 30px;
  }
  .axis-desc-copy {
    font-size: 18px;
    line-height: 1.8;
  }
}



.about {
  padding-bottom: calc(395 / 1920 * 100%);
}
.about__content {
  position: relative;
  z-index: 1;
  max-width: 1575px;
}
.about__content__group {
  position: relative;
  z-index: 1;
}
/* .about__content__group__heading {
}
.about__content__group__heading__en {
}
.about__content__group__heading__ja {
} */
.about__content__group--mission .about__content__group__heading__ja > span:nth-of-type(1) {
  width: calc(503 / 832 * 100%);
}
.about__content__group--mission .about__content__group__heading__ja > span:nth-of-type(2) {
  width: calc(683 / 832 * 100%);
}
.about__content__group--mission .about__content__group__heading__ja > span:nth-of-type(3) {
  width: calc(434 / 832 * 100%);
}
.about__content__group--vision .about__content__group__heading__ja > span:nth-of-type(1) {
  width: calc(685 / 832 * 100%);
}
.about__content__group--vision .about__content__group__heading__ja > span:nth-of-type(2) {
  width: calc(501 / 832 * 100%);
}
/* .about__content__group__photo {
}
.about__content__group__photo__item {
}
.about__content__group__photo__item--default {
}
.about__content__group__photo__item--active {
}
.about__content__group__desc {
}
.about__content__group__desc__copy {
} */
@media screen and (max-width: 767px){
  .about {
    margin-top: 60px;
    padding-bottom: calc(75 / 380 * 100%);
  }
  .about__content {
    max-width: 560px;
  }
  .about__content__group--mission .about__content__group__heading__ja > span:nth-of-type(1) {
    width: calc(201 / 320 * 100%);
  }
  .about__content__group--mission .about__content__group__heading__ja > span:nth-of-type(2) {
    width: calc(273 / 320 * 100%);
  }
  .about__content__group--mission .about__content__group__heading__ja > span:nth-of-type(3) {
    width: calc(174 / 320 * 100%);
  }
  .about__content__group--vision .about__content__group__heading__ja > span:nth-of-type(1) {
    width: calc(274 / 320 * 100%);
  }
  .about__content__group--vision .about__content__group__heading__ja > span:nth-of-type(2) {
    width: calc(201 / 320 * 100%);
  }
}



.discover {
  height: 0;
}
.discover__desc--2 .discover__desc__copy {
  background: linear-gradient(180deg, #b5b5b5 10%, rgb(var(--color-white)));
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
}



.re {
  margin-top: calc(275 / 1920 * 100%);
  padding-block: calc(395 / 1920 * 100%) 340px;
  background: rgb(var(--color-black2));
}
.re__intro {
  position: relative;
  z-index: 1;
  max-width: 1575px;
}
.re__intro__group {
  position: relative;
  z-index: 1;
}
/* .re__intro__group--value {
}
.re__intro__group__heading {
}
.re__intro__group__heading__en {
}
.re__intro__group__heading__ja {
} */
.re__intro__group--value .re__intro__group__heading__ja > span:nth-of-type(1) {
  width: calc(832 / 832 * 100%);
}
.re__intro__group--value .re__intro__group__heading__ja > span:nth-of-type(2) {
  width: calc(271 / 832 * 100%);
}
/* .re__intro__group__photo {
}
.re__intro__group__photo__item {
}
.re__intro__group__photo__item--default {
}
.re__intro__group__photo__item--active {
}
.re__intro__group__desc {
}
.re__intro__group__desc__copy {
} */
.re__content {
  margin-top: 40px;
  grid-template-columns: minmax(0, 1fr) calc(1262 / 1536 * 100%);
  align-items: start;
}
.re__content__head {
  position: -webkit-sticky;
  position: sticky;
  z-index: 1;
  top: calc(var(--header-height, 80px) + 30px);
  margin-bottom: 40px;
}
.re__content__head__heading {
  font-size: clamp(28px, calc(48 / 1200 * 100vw), 48px);
}
.re__content__head__heading small {
  display: block;
  font-size: calc(32 / 48 * 100%);
  margin-bottom: calc(8 / 32 * 1em);
}
.re__content__head__heading em {
  font-size: calc(80 / 48 * 100%);
  font-weight: 400;
}
/* .re__content__body {
}
.re__content__body__list {
} */
.re__content__body__list__item {
  box-sizing: border-box;
  border-top: 1px solid #555;
  padding-block: 40px;
  grid-template-columns: calc(192 / 1262 * 100%) minmax(0, 1fr);
  align-items: center;
  gap: 0 calc(32 / 1262 * 100%);
}
.re__content__body__list__item:nth-child(1) {
  border-top: none;
  padding-top: 0;
}
/* .re__content__body__list__item__photo {
}
.re__content__body__list__item__desc {
} */
.re__content__body__list__item__desc__num {
  font-size: clamp(14px, calc(20 / 1200 * 100vw), 20px);
}
/* .re__content__body__list__item__desc__heading {
} */
.re__content__body__list__item__desc__heading > span {
  font-size: clamp(28px, calc(48 / 1200 * 100vw), 48px);
  line-height: 1;
}
.re__content__body__list__item__desc__heading > span + span {
  font-size: clamp(16px, calc(24 / 1200 * 100vw), 24px);
  background: rgb(var(--color-white));
  margin-top: calc(8 / 24 * 1em);
}
.re__content__body__list__item__desc__copy {
  margin-top: 16px;
  font-size: clamp(16px, calc(24 / 1200 * 100vw), 24px);
  line-height: 1.4;
}
.re__brand {
  margin-top: 40px;
}
.re__brand__link {
  position: relative;
  z-index: 1;
  display: block;
  width: calc(1262 / 1536 * 100%);
  margin-left: auto;
  background: #fff;
}
.re__brand__link__desc {
  position: absolute;
  z-index: 2;
  inset: 0;
  grid-template-columns: minmax(0, auto);
  justify-content: start;
  align-content: end;
  align-items: end;
  box-sizing: border-box;
  padding: clamp(13px, calc(23 / 1200 * 100vw), 23px) clamp(23px, calc(43 / 1200 * 100vw), 43px);
}
.re__brand__link__desc__jaheading {
  font-size: clamp(16px, calc(24 / 1200 * 100vw), 24px);
  line-height: 1.458333333;
}
.re__brand__link__desc__enheading {
  font-size: clamp(34px, calc(64 / 1200 * 100vw), 64px);
  line-height: 1.25;
}
.re__brand__link__desc__enheading::after {
  content: "";
  display: inline-block;
  vertical-align: top;
  width: calc(20 / 64 * 1em);
  height: 1.25em;
  margin-inline: calc(5 / 64 * 1em);
  background: rgb(var(--color-red));
  -webkit-mask: var(--svg-chevron) no-repeat center/100% auto;
  mask: var(--svg-chevron) no-repeat center/100% auto;
}
.re__brand__link__photo {
  position: relative;
  z-index: 1;
}
.re__brand__link__photo img {
  height: 100%;
  object-fit: cover;
  object-position: center right;
}
@media (any-hover: hover) {
  .re__brand__link:hover .re__brand__link__desc__enheading::after {
    animation: chevronAnimation .5s;
  }
}
@media screen and (max-width: 767px){
  .re {
    margin-top: calc(274 / 380 * 100%);
    padding-block: calc(77 / 380 * 100%) 175px;
  }
  .re__intro {
    max-width: 560px;
  }
  /* .re__intro__group--value .re__intro__group__heading__ja > span:nth-of-type(1) {
    width: calc(206 / 320 * 100%);
  }
  .re__intro__group--value .re__intro__group__heading__ja > span:nth-of-type(2) {
    width: calc(203 / 320 * 100%);
  } */
  .re__content {
    margin-top: 80px;
    grid-template-columns: 100%;
  }
  .re__content__head {
    position: relative;
    top: 0;
    margin-bottom: 30px;
  }
  .re__content__head__heading {
    font-size: 40px;
    text-align: center;
  }
  .re__content__head__heading small {
    font-size: calc(22 / 40 * 100%);
    margin-bottom: calc(6 / 22 * 1em);
  }
  .re__content__head__heading em {
    font-size: calc(54 / 40 * 100%);
  }
  .re__content__body__list__item {
    padding-block: 20px 40px;
    grid-template-columns: 100%;
    align-items: start;
    gap: 0;
  }
  .re__content__body__list__item__photo {
    width: calc(160 / 320 * 100%);
    margin-inline: auto;
  }
  .re__content__body__list__item__desc__num {
    font-size: 20px;
  }
  .re__content__body__list__item__desc__heading > span {
    font-size: 44px;
  }
  .re__content__body__list__item__desc__heading > span + span {
    font-size: 20px;
    margin-top: calc(8 / 20 * 1em);
  }
  .re__content__body__list__item__desc__copy {
    font-size: 22px;
  }
  .re__brand {
    margin-top: 20px;
  }
  .re__brand__link {
    width: 100%;
    margin-left: 0;
  }
  .re__brand__link__desc {
    padding: 16px 20px;
  }
  .re__brand__link__desc__jaheading {
    font-size: 16px;
    line-height: 1.4375;
  }
  .re__brand__link__desc__enheading {
    font-size: 30px;
    line-height: 1;
    margin-top: 5px;
  }
  .re__brand__link__desc__enheading::after {
    width: calc(12 / 30 * 1em);
    height: 1em;
    margin-inline: calc(5 / 30 * 1em);
  }
}