/* p-mv
---------------------------------------------------------------------------- */
.p-mv {
  margin-top: 11rem;
  width: 100%;
  height: min(41.6666666667vw, 800px);
  position: relative;
}

.p-mv-imgVideo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.p-mv-imgVideo img,
.p-mv-imgVideo video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

@media screen and (max-width: 767px) {
  .p-mv {
    margin-top: 6rem;
    height: 144vw;
  }
}
/* p-news
---------------------------------------------------------------------------- */
.p-news {
  padding-block: 7.8rem 8rem;
}

.p-news-layout {
  opacity: 0;
}

.p-news-tab-btn-wrap {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  column-gap: 1.1rem;
  margin-bottom: 3.7rem;
}

.p-news-tab-btn {
  display: grid;
  place-content: center;
  font-size: 1.6rem;
  line-height: 1.8125;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #1A1A1A;
  height: 5rem;
  background-color: #ECECEC;
  border-radius: 0.5rem;
  position: relative;
}
.p-news-tab-btn._active {
  background-color: #073190;
  color: #fff;
  pointer-events: none;
}
.p-news-tab-btn._active::after {
  content: "";
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  width: 1.6rem;
  height: 0.9534028741rem;
  background-color: #073190;
  position: absolute;
  bottom: 0%;
  left: 50%;
  transform: translate(-50%, 95%);
}

.p-news-article:not(:last-of-type) {
  margin-bottom: 2rem;
}

.p-news-tab-content-meta {
  display: grid;
  grid-template-columns: repeat(3, auto);
  align-items: center;
  justify-content: start;
  height: 2.2rem;
  margin-bottom: 1rem;
}

.p-news-date {
  font-size: 1.5rem;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #808080;
  margin-right: 2rem;
}

.p-news-category {
  display: grid;
  place-content: center;
  font-size: 1.2rem;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #073190;
  height: 100%;
  background-color: #fff;
  padding-inline: 1.5rem;
  border-radius: 10vmax;
  border: 1px solid;
  margin-right: 1rem;
}

.p-news-new {
  display: grid;
  place-content: center;
  font-size: 1.2rem;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #fff;
  height: 100%;
  background-color: #AF0315;
  padding-inline: 1rem;
  border-radius: 10vmax;
}

.p-news-ttl {
  display: grid;
  grid-template-columns: 1fr auto;
  column-gap: 3.35rem;
  font-size: 1.6rem;
  line-height: 1.8125;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #1A1A1A;
  padding-bottom: 2rem;
  border-bottom: 1px solid #BEBEBE;
}
.p-news-ttl span {
  display: inline-block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.p-news-ttl::after {
  content: "";
  width: 2.6rem;
  aspect-ratio: 1;
  background-image: url(./../../images/common/icn_arrow_right_circle_blue.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

.js-tab-content {
  display: none;
}

.js-tab-content._active {
  display: block;
}

@media screen and (max-width: 767px) {
  .p-news {
    padding-block: 13.3333333333vw 13.3333333333vw;
  }
  .p-news-tab-btn-wrap {
    overflow-x: scroll;
    column-gap: 2.6666666667vw;
    margin-bottom: 5.3333333333vw;
    margin-right: -5.3333333333vw;
    padding-right: 5.3333333333vw;
  }
  .p-news-tab-btn {
    font-size: 3.7333333333vw;
    height: 10.6666666667vw;
    width: 37.3333333333vw;
    border-radius: 1.3333333333vw;
  }
  .p-news-tab-btn._active::after {
    content: none;
    width: 0vw;
    height: calc(0vw / 2 * 1.1917535926);
  }
  .p-news-article:not(:last-of-type) {
    margin-bottom: 5.3333333333vw;
  }
  .p-news-tab-content-meta {
    height: 5.8666666667vw;
    margin-bottom: 2.6666666667vw;
  }
  .p-news-date {
    font-size: 4vw;
    margin-right: 5.3333333333vw;
  }
  .p-news-category {
    font-size: 3.2vw;
    padding-inline: 4vw;
    margin-right: 2.6666666667vw;
  }
  .p-news-new {
    font-size: 3.2vw;
    padding-inline: 2.6666666667vw;
  }
  .p-news-ttl {
    align-items: end;
    column-gap: 2.4vw;
    font-size: 4.2666666667vw;
    padding-bottom: 5.3333333333vw;
  }
  .p-news-ttl span {
    white-space: normal;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }
  .p-news-ttl::after {
    width: 6.9333333333vw;
  }
}
/* p-corporate
---------------------------------------------------------------------------- */
.p-corporate {
  background-color: #F8F8F8;
  padding-block: 9.8rem 12rem;
  color: #1A1A1A;
}

.p-corporate-inner {
  position: relative;
}

.p-corporate-lead {
  width: 62rem;
  margin-bottom: 8.8rem;
  position: relative;
  opacity: 0;
}

.p-corporate-txt {
  font-size: 1.8rem;
  line-height: 1.8;
  letter-spacing: 0.06em;
  font-weight: 500;
  margin-block: 4rem;
}

.p-corporate-img {
  width: 50.251rem;
  aspect-ratio: 502.51/403.69;
  position: absolute;
  top: 0;
  left: 69.75rem;
}
.p-corporate-img > img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.p-corporate-page {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.9rem 4rem;
  opacity: 0;
}

.p-corporate-link {
  display: grid;
  grid-template-columns: 1fr auto;
  font-size: 1.6rem;
  line-height: 1.8125;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #1A1A1A;
  padding-bottom: 1.2rem;
}

.p-corporate-external-wrap {
  position: absolute;
  bottom: -6rem;
  left: 50%;
  transform: translate(-50%, 100%);
}

.p-corporate-external {
  display: grid;
  grid-template-columns: repeat(2, 46rem);
  gap: 8rem;
  opacity: 0;
}

.p-corporate-external-link {
  display: block;
  width: 100%;
  height: 100%;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1490196078);
}

.p-members-slide-link-img {
  width: 100%;
  aspect-ratio: 460/118;
}
.p-members-slide-link-img > img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

@media screen and (max-width: 767px) {
  .p-corporate {
    padding-block: 92.8vw 52vw;
  }
  .p-corporate-lead {
    width: 100%;
    margin-bottom: 13.3333333333vw;
  }
  .p-corporate-txt {
    font-size: 4.2666666667vw;
    margin-block: 6.6666666667vw 8vw;
  }
  .p-corporate-img {
    width: 89.3333333333vw;
    aspect-ratio: 335/270;
    top: -7.4666666667vw;
    left: 0;
    translate: 0 -100%;
  }
  .p-corporate-page {
    grid-template-columns: repeat(1, 1fr);
    gap: 5.3333333333vw 0;
  }
  .p-corporate-link {
    font-size: 4.2666666667vw;
    padding-bottom: 2.6666666667vw;
  }
  .p-corporate-external-wrap {
    bottom: -13.3333333333vw;
  }
  .p-corporate-external {
    grid-template-columns: 89.3333333333vw;
    gap: 5.3333333333vw;
  }
  .p-members-slide-link-img {
    width: 89.3333333333vw;
    aspect-ratio: 335/85;
  }
}
/* p-business
---------------------------------------------------------------------------- */
.p-business {
  padding-block: 15.5rem 10rem;
}

.p-business-lead-wrap {
  opacity: 0;
}

.p-business-lead {
  display: grid;
  grid-template-columns: auto;
  margin-block: 4rem 8rem;
}

.p-business-contents-wrap {
  overflow: hidden;
}

.p-business-contents {
  width: 84rem;
  position: relative;
  padding-top: 3rem;
}
.p-business-contents::before {
  content: "";
  width: 156rem;
  height: 51rem;
  background-repeat: no-repeat;
  background-size: 156rem 51rem;
  position: absolute;
  top: 5.4rem;
  z-index: -1;
  transition: all 1.5s cubic-bezier(0.77, 0, 0.175, 1);
}
.p-business-contents::after {
  content: "";
  width: 38rem;
  height: 50.6rem;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: 0;
  transition: all 1s ease 0.5s;
  opacity: 0;
  filter: blur(2rem);
}
.p-business-contents.m-start-animation::after {
  filter: blur(0);
  opacity: 1;
}
.p-business-contents:nth-of-type(1) {
  color: #073190;
  margin-bottom: 13rem;
}
.p-business-contents:nth-of-type(1).m-start-animation::before {
  left: -36rem;
}
.p-business-contents:nth-of-type(1)::before {
  background-image: url(./../../images/top/bg_business01_pc.png);
  left: -192rem;
}
.p-business-contents:nth-of-type(1)::after {
  background-image: url(./../../images/top/img_business01.png);
  right: -5.2083333333vw;
  translate: 100%;
}
.p-business-contents:nth-of-type(1) .p-business-contents-group .p-business-contents-ttl a {
  color: #073190;
}
.p-business-contents:nth-of-type(1) .p-business-contents-box {
  height: 24.5rem;
}
.p-business-contents:nth-of-type(1) .p-business-contents-box-img {
  width: 84rem;
  aspect-ratio: 840/245;
}
.p-business-contents:nth-of-type(1) .p-business-contents-box-img > img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}
.p-business-contents:nth-of-type(1) .p-business-contents-company-ttl {
  background-color: #073190;
}
.p-business-contents:nth-of-type(2) {
  color: #F3AE3B;
  margin-bottom: 13rem;
  margin-left: auto;
}
.p-business-contents:nth-of-type(2).m-start-animation::before {
  left: -36rem;
}
.p-business-contents:nth-of-type(2)::before {
  background-image: url(./../../images/top/bg_business02_pc.png);
  left: 120rem;
}
.p-business-contents:nth-of-type(2)::after {
  background-image: url(./../../images/top/img_business02.png);
  left: -5.2083333333vw;
  translate: -100%;
}
.p-business-contents:nth-of-type(2) .p-business-contents-group .p-business-contents-ttl a {
  color: #F3AE3B;
}
.p-business-contents:nth-of-type(2) .p-business-contents-box {
  height: 22rem;
}
.p-business-contents:nth-of-type(2) .p-business-contents-box-img {
  width: 84rem;
  aspect-ratio: 840/220;
}
.p-business-contents:nth-of-type(2) .p-business-contents-box-img > img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}
.p-business-contents:nth-of-type(2) .p-business-contents-company-ttl {
  background-color: #F3AE3B;
}
.p-business-contents:nth-of-type(3) {
  color: #70C0CC;
  margin-bottom: 13rem;
}
.p-business-contents:nth-of-type(3).m-start-animation::before {
  left: -36rem;
}
.p-business-contents:nth-of-type(3)::before {
  background-image: url(./../../images/top/bg_business03_pc.png);
  left: -192rem;
}
.p-business-contents:nth-of-type(3)::after {
  background-image: url(./../../images/top/img_business03.png);
  right: -5.2083333333vw;
  translate: 100%;
}
.p-business-contents:nth-of-type(3) .p-business-contents-group .p-business-contents-ttl a {
  color: #70C0CC;
}
.p-business-contents:nth-of-type(3) .p-business-contents-box {
  height: 23.5rem;
}
.p-business-contents:nth-of-type(3) .p-business-contents-box-img {
  width: 84rem;
  aspect-ratio: 840/235;
}
.p-business-contents:nth-of-type(3) .p-business-contents-box-img > img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}
.p-business-contents:nth-of-type(3) .p-business-contents-company-ttl {
  background-color: #70C0CC;
}
.p-business-contents:nth-of-type(4) {
  color: #3392D1;
  margin-bottom: 19rem;
  margin-left: auto;
}
.p-business-contents:nth-of-type(4).m-start-animation::before {
  left: -36rem;
}
.p-business-contents:nth-of-type(4)::before {
  background-image: url(./../../images/top/bg_business04_pc.png);
  left: 120rem;
}
.p-business-contents:nth-of-type(4)::after {
  background-image: url(./../../images/top/img_business04.png);
  left: -5.2083333333vw;
  translate: -100%;
}
.p-business-contents:nth-of-type(4) .p-business-contents-group .p-business-contents-ttl a {
  color: #3392D1;
}
.p-business-contents:nth-of-type(4) .p-business-contents-box {
  height: 25rem;
}
.p-business-contents:nth-of-type(4) .p-business-contents-box-img {
  width: 84rem;
  aspect-ratio: 840/250;
}
.p-business-contents:nth-of-type(4) .p-business-contents-box-img > img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.p-business-contents-group {
  display: grid;
  grid-template-columns: auto auto;
  align-items: center;
  justify-content: start;
}

.p-business-contents-group .p-business-contents-ttl a {
  display: grid;
  grid-template-columns: auto auto;
  align-items: center;
  column-gap: 1.5rem;
  font-size: 3.6rem;
  line-height: 1.1111111111;
  letter-spacing: 0.08em;
  font-weight: 700;
  width: max-content;
  position: relative;
}
.p-business-contents-group .p-business-contents-ttl a::before {
  position: absolute;
  left: 0;
  top: calc(100% + 0.5rem);
  content: "";
  width: 100%;
  height: 0.3rem;
  background: currentColor;
  transform: scale(0, 1);
  transform-origin: right center;
  transition: transform 0.4s;
}
@media (any-hover: hover) {
  .p-business-contents-group .p-business-contents-ttl a:hover::before {
    transform: scale(1, 1);
    transform-origin: left center;
  }
}

.p-business-contents-box {
  display: grid;
  place-content: center;
  margin-block: 5.5rem;
  background-color: #fff;
  width: 100%;
}

.p-business-contents-company > :first-child {
  margin-bottom: 1.6rem;
}

.p-business-contents-company-ttl {
  font-size: 1.8rem;
  line-height: 1.5;
  letter-spacing: 0.08em;
  font-weight: 700;
  color: #fff;
  padding-block: 0.61rem 0.69rem;
  padding-inline: 1.83rem;
}

.p-business-contents-company-inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: start;
  gap: 1rem 1.5rem;
}

.p-business-contents-company-link {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  column-gap: 0.8rem;
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0.06em;
  font-weight: 700;
  width: max-content;
  color: #073190;
  border-bottom: 1px solid;
}
.p-business-contents-company-link::after {
  content: "";
  width: 1.5rem;
  aspect-ratio: 1;
  background-image: url(./../../images/common/icn_external_link.svg);
  background-repeat: no-repeat;
  background-size: contain;
}
.p-business-contents-company-link._no_link {
  border-bottom: none;
}
.p-business-contents-company-link._no_link::after {
  content: none;
}

@media screen and (max-width: 767px) {
  .p-business {
    padding-block: 30.1333333333vw 13.3333333333vw;
  }
  .p-business-lead {
    margin-block: 6.6666666667vw 13.3333333333vw;
  }
  .p-business-contents-wrap .l-content {
    display: flex;
    flex-direction: column;
    gap: 18.6666666667vw;
  }
  .p-business-contents {
    width: 100%;
    padding-top: 0;
    padding-bottom: 16vw;
  }
  .p-business-contents::before {
    width: 100vw;
    height: 100%;
    background-size: 100vw 100%;
    top: 3.7333333333vw;
  }
  .p-business-contents::after {
    content: "";
    width: 100%;
    height: 100%;
    filter: blur(5.3333333333vw);
  }
  .p-business-contents:nth-of-type(1) {
    margin-bottom: initial;
  }
  .p-business-contents:nth-of-type(1).m-start-animation::before {
    left: -5.3333333333vw;
  }
  .p-business-contents:nth-of-type(1)::before {
    background-image: url(./../../images/top/bg_business01_sp.png);
    left: -105.3333333333vw;
  }
  .p-business-contents:nth-of-type(1)::after {
    top: 17.3333333333vw;
    right: 0;
    translate: 0;
  }
  .p-business-contents:nth-of-type(1) .p-business-contents-box {
    height: auto;
    justify-content: start;
  }
  .p-business-contents:nth-of-type(1) .p-business-contents-box-img {
    width: 100%;
    aspect-ratio: 335/458;
  }
  .p-business-contents:nth-of-type(2) {
    margin-bottom: initial;
  }
  .p-business-contents:nth-of-type(2).m-start-animation::before {
    left: -5.3333333333vw;
  }
  .p-business-contents:nth-of-type(2)::before {
    background-image: url(./../../images/top/bg_business02_sp.png);
    left: 105.3333333333vw;
  }
  .p-business-contents:nth-of-type(2)::after {
    top: 17.3333333333vw;
    left: 0;
    translate: 0;
  }
  .p-business-contents:nth-of-type(2) .p-business-contents-box {
    height: auto;
  }
  .p-business-contents:nth-of-type(2) .p-business-contents-box-img {
    width: 100%;
    aspect-ratio: 335/458;
  }
  .p-business-contents:nth-of-type(3) {
    margin-bottom: initial;
  }
  .p-business-contents:nth-of-type(3).m-start-animation::before {
    left: -5.3333333333vw;
  }
  .p-business-contents:nth-of-type(3)::before {
    background-image: url(./../../images/top/bg_business03_sp.png);
    left: -105.3333333333vw;
  }
  .p-business-contents:nth-of-type(3)::after {
    top: 17.3333333333vw;
    right: 0;
    translate: 0;
  }
  .p-business-contents:nth-of-type(3) .p-business-contents-box {
    height: auto;
  }
  .p-business-contents:nth-of-type(3) .p-business-contents-box-img {
    width: 100%;
    aspect-ratio: 335/414;
  }
  .p-business-contents:nth-of-type(4) {
    margin-bottom: initial;
  }
  .p-business-contents:nth-of-type(4).m-start-animation::before {
    left: -5.3333333333vw;
  }
  .p-business-contents:nth-of-type(4)::before {
    background-image: url(./../../images/top/bg_business04_sp.png);
    left: 105.3333333333vw;
  }
  .p-business-contents:nth-of-type(4)::after {
    top: 17.3333333333vw;
    left: 0;
    translate: 0;
  }
  .p-business-contents:nth-of-type(4) .p-business-contents-box {
    height: auto;
  }
  .p-business-contents:nth-of-type(4) .p-business-contents-box-img {
    width: 100%;
    aspect-ratio: 335/349;
  }
  .p-business-contents-group {
    grid-template-columns: auto;
    row-gap: 6.6666666667vw;
  }
  .p-business-contents-group .p-business-contents-ttl a {
    column-gap: 4vw;
    font-size: 7.4666666667vw;
  }
  .p-business-contents-group .p-business-contents-ttl a::before {
    top: calc(100% + 1.3333333333vw);
    height: 0.8vw;
  }
  .p-business-contents-box {
    margin-block: 137.8666666667vw 10.6666666667vw;
  }
  .p-business-contents-company > :first-child {
    margin-bottom: 4vw;
  }
  .p-business-contents-company-ttl {
    font-size: 4.8vw;
    line-height: 1.5;
    padding-block: 1.8666666667vw 1.6vw;
    padding-inline: 4.88vw;
  }
  .p-business-contents-company-inner {
    display: grid;
    grid-template-columns: auto;
    grid-auto-flow: row;
    justify-content: start;
    gap: 4vw;
  }
  .p-business-contents-company-link {
    column-gap: 2.6666666667vw;
    font-size: 4.2666666667vw;
    padding-bottom: 1.6vw;
    width: 100%;
  }
  .p-business-contents-company-link::after {
    width: 4vw;
  }
}
/* p-bg
---------------------------------------------------------------------------- */
.p-bg {
  display: flex;
  flex-direction: column;
  row-gap: 9.8rem;
  padding-block: 9.8rem 14rem;
  position: relative;
}
.p-bg::before {
  content: "";
  width: 100%;
  height: 100%;
  background-image: url(./../../images/top/bg_pc.png);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  position: absolute;
  top: 0;
  left: 0;
  translate: 0;
  z-index: -2;
}
.p-bg::after {
  content: "";
  width: calc(100% + 40rem);
  height: 100%;
  background-color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  translate: -17rem;
  transition: all 1.5s cubic-bezier(0.83, 0, 0.17, 1);
  transform: skewX(-17deg);
  z-index: -1;
}
.p-bg.m-start-animation::after {
  translate: 100%;
}

@media screen and (max-width: 767px) {
  .p-bg {
    row-gap: 15.4666666667vw;
    padding-block: 12.8vw 87.2vw;
  }
  .p-bg::before {
    background-image: url(./../../images/top/bg_sp.png);
  }
  .p-bg::after {
    transition: all 2.5s cubic-bezier(0.83, 0, 0.17, 1);
    width: calc(100% + 242.6666666667vw);
    translate: -170.6666666667vw;
  }
}
/* p-ir
---------------------------------------------------------------------------- */
.p-ir-layout > :first-child {
  margin-bottom: 4rem;
}

.p-ir-page {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: repeat(2, auto);
  grid-column-gap: 2.1rem;
  grid-row-gap: 2rem;
  opacity: 0;
}

.p-ir-page-link {
  color: #fff;
  border-radius: 0.5rem;
  position: relative;
  overflow: hidden;
}
.p-ir-page-link ._txt {
  position: absolute;
  top: 50%;
  left: 3rem;
  translate: 0 -50%;
}
.p-ir-page-link ._icn-position {
  position: absolute;
  top: 50%;
  right: 2.1rem;
  translate: 0 -50%;
}
.p-ir-page-link::before {
  content: "";
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-size: cover;
  position: absolute;
  inset: 0;
  scale: 1;
  transition: scale 0.2s;
}
.p-ir-page-link:nth-of-type(1), .p-ir-page-link:nth-of-type(2), .p-ir-page-link:nth-of-type(3) {
  font-size: 2.6rem;
  line-height: 1.1538461538;
  letter-spacing: 0.06em;
  font-weight: 700;
  height: 16rem;
}
.p-ir-page-link:nth-of-type(4), .p-ir-page-link:nth-of-type(5), .p-ir-page-link:nth-of-type(6), .p-ir-page-link:nth-of-type(7) {
  font-size: 2.4rem;
  line-height: 1.25;
  letter-spacing: 0.06em;
  font-weight: 700;
  height: 12rem;
}
.p-ir-page-link:nth-of-type(1) {
  grid-area: 1/1/2/5;
}
.p-ir-page-link:nth-of-type(1)::before {
  background-image: url(./../../images/top/img_ir_01_pc.png);
}
.p-ir-page-link:nth-of-type(2) {
  grid-area: 1/5/2/9;
}
.p-ir-page-link:nth-of-type(2)::before {
  background-image: url(./../../images/top/img_ir_02_pc.png);
}
.p-ir-page-link:nth-of-type(3) {
  grid-area: 1/9/2/13;
}
.p-ir-page-link:nth-of-type(3)::before {
  background-image: url(./../../images/top/img_ir_03_pc.png);
}
.p-ir-page-link:nth-of-type(4) {
  grid-area: 2/1/3/4;
}
.p-ir-page-link:nth-of-type(4)::before {
  background-image: url(./../../images/top/img_ir_04_pc.png);
}
.p-ir-page-link:nth-of-type(5) {
  grid-area: 2/4/3/7;
}
.p-ir-page-link:nth-of-type(5)::before {
  background-image: url(./../../images/top/img_ir_05_pc.png);
}
.p-ir-page-link:nth-of-type(6) {
  grid-area: 2/7/3/10;
}
.p-ir-page-link:nth-of-type(6)::before {
  background-image: url(./../../images/top/img_ir_06_pc.png);
}
.p-ir-page-link:nth-of-type(7) {
  grid-area: 2/10/3/13;
}
.p-ir-page-link:nth-of-type(7)::before {
  background-image: url(./../../images/top/img_ir_07_pc.png);
}
@media (any-hover: hover) {
  .p-ir-page-link:hover::before {
    scale: 1.1;
  }
}

@media screen and (max-width: 767px) {
  .p-ir-layout > :first-child {
    margin-bottom: 8vw;
  }
  .p-ir-page {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    grid-template-rows: repeat(7, 1fr);
    grid-column-gap: 0;
    grid-row-gap: 5.3333333333vw;
  }
  .p-ir-page-link {
    border-radius: 1.3333333333vw;
  }
  .p-ir-page-link ._txt {
    left: 4.8vw;
  }
  .p-ir-page-link ._icn-position {
    right: 5.3333333333vw;
  }
  .p-ir-page-link:nth-of-type(1), .p-ir-page-link:nth-of-type(2), .p-ir-page-link:nth-of-type(3), .p-ir-page-link:nth-of-type(4), .p-ir-page-link:nth-of-type(5), .p-ir-page-link:nth-of-type(6), .p-ir-page-link:nth-of-type(7) {
    font-size: 5.3333333333vw;
    line-height: 1.2;
    height: 26.6666666667vw;
  }
  .p-ir-page-link:nth-of-type(1) {
    grid-area: 1/1/2/2;
  }
  .p-ir-page-link:nth-of-type(1)::before {
    background-image: url(./../../images/top/img_ir_01_sp.png);
  }
  .p-ir-page-link:nth-of-type(2) {
    grid-area: 2/1/3/2;
  }
  .p-ir-page-link:nth-of-type(2)::before {
    background-image: url(./../../images/top/img_ir_02_sp.png);
  }
  .p-ir-page-link:nth-of-type(3) {
    grid-area: 3/1/4/2;
  }
  .p-ir-page-link:nth-of-type(3)::before {
    background-image: url(./../../images/top/img_ir_03_sp.png);
  }
  .p-ir-page-link:nth-of-type(4) {
    grid-area: 4/1/5/2;
  }
  .p-ir-page-link:nth-of-type(4)::before {
    background-image: url(./../../images/top/img_ir_04_sp.png);
  }
  .p-ir-page-link:nth-of-type(5) {
    grid-area: 5/1/6/2;
  }
  .p-ir-page-link:nth-of-type(5)::before {
    background-image: url(./../../images/top/img_ir_05_sp.png);
  }
  .p-ir-page-link:nth-of-type(6) {
    grid-area: 6/1/7/2;
  }
  .p-ir-page-link:nth-of-type(6)::before {
    background-image: url(./../../images/top/img_ir_06_sp.png);
  }
  .p-ir-page-link:nth-of-type(7) {
    grid-area: 7/1/8/2;
  }
  .p-ir-page-link:nth-of-type(7)::before {
    background-image: url(./../../images/top/img_ir_07_sp.png);
  }
}
/* p-sustainability
---------------------------------------------------------------------------- */
.p-sustainability-layout {
  width: 62rem;
  margin-left: auto;
  position: relative;
  opacity: 0;
}

.p-sustainability-layout::before {
  content: "";
  width: 53.336rem;
  aspect-ratio: 533.36/396.48;
  background-image: url(./../../images/top/img_sustainability.png);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: 0;
  left: -8rem;
  translate: -100%;
}

.p-sustainability-txt {
  font-size: 1.8rem;
  line-height: 1.8;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #1A1A1A;
  margin-block: 3rem;
}

.p-sustainability-page {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem 2rem;
  margin-bottom: 4rem;
}

.p-sustainability-link {
  display: grid;
  grid-template-columns: auto auto;
  justify-content: space-between;
  align-items: center;
  font-size: 1.6rem;
  line-height: 1.5;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #1A1A1A;
  padding-bottom: 1.15rem;
}

@media screen and (max-width: 767px) {
  .p-sustainability-layout {
    width: 100%;
  }
  .p-sustainability-layout::before {
    width: 89.3333333333vw;
    aspect-ratio: 335/249.02;
    top: initial;
    left: 0;
    bottom: -73.8666666667vw;
    translate: 0;
  }
  .p-sustainability-txt {
    font-size: 4.2666666667vw;
    line-height: 29/16;
    margin-block: 6.6666666667vw 8vw;
  }
  .p-sustainability-page {
    grid-template-columns: repeat(1, 1fr);
    gap: 5.3333333333vw 0;
    margin-bottom: 8vw;
  }
  .p-sustainability-link {
    font-size: 4.2666666667vw;
    padding-bottom: 3.0666666667vw;
  }
}
/* p-cta
---------------------------------------------------------------------------- */
.p-cta {
  position: relative;
}
.p-cta::after {
  content: "";
  width: calc(100% + 40rem);
  height: 100%;
  background-color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  translate: -17rem;
  transition: all 1.5s cubic-bezier(0.83, 0, 0.17, 1);
  transform: skewX(-17deg);
  z-index: 2;
}
.p-cta.m-start-animation::after {
  translate: 100%;
}
.p-cta.m-start-animation .p-cta-img {
  opacity: 1;
  filter: blur(0);
}

.p-cta-layout {
  height: 51.6rem;
  padding-block: 9.38rem 9.48rem;
  position: relative;
}
.p-cta-layout::before {
  content: "";
  width: 100%;
  height: 100%;
  background-image: url(./../../images/top/img_cta_pc.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: right top;
  position: absolute;
  top: 0;
  right: 0rem;
  translate: -36rem;
  z-index: 1;
  mix-blend-mode: multiply;
}

.p-cta-inner {
  position: relative;
  z-index: 3;
}

.p-cta-txt {
  font-size: 1.8rem;
  line-height: 1.8;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #fff;
  margin-block: 3.05rem 4.05rem;
}

.p-cta-img {
  position: absolute;
  top: 4rem;
  right: -2rem;
  width: 56.6rem;
  aspect-ratio: 566/412;
  transition: all 1s ease 0.5s;
  opacity: 0;
  filter: blur(2rem);
}
.p-cta-img > img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

@media screen and (max-width: 767px) {
  .p-cta::after {
    content: "";
    width: calc(100% + 37.3333333333vw);
    height: 100%;
    background-color: #fff;
    position: absolute;
    top: 0;
    left: 0;
    translate: -32vw;
  }
  .p-cta.m-start-animation::after {
    translate: calc(100% + 5.3333333333vw);
  }
  .p-cta-layout {
    height: calc(175.2vw + 21.3333333333vw);
    padding-block: 12.8vw 0;
    padding-inline: 5.3333333333vw;
  }
  .p-cta-layout::before {
    background-image: url(./../../images/top/img_cta_sp.png);
    background-size: 100% 152vw;
    top: 0;
    right: 0vw;
    translate: 0;
    mix-blend-mode: multiply;
  }
  .p-cta-txt {
    font-size: 4.2666666667vw;
    line-height: 1.8125;
    margin-block: 5.3333333333vw 8vw;
  }
  .p-cta-img {
    top: 120vw;
    right: 5.3333333333vw;
    width: 89.3333333333vw;
    aspect-ratio: 335/244;
    filter: blur(5.3333333333vw);
    z-index: 1;
  }
  .p-cta-img > img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
  }
}
