@charset "UTF-8";
/*!
global > color
------------------------------
*/
:root {
  --cl-main: #243D5F;
  --cl-border: #DDE1E5;
  --cl-bg-gray: #F6F6F6;
  --cl-text-dark: #333;
}

/*!
global > content-width
------------------------------
*/
/*!
global > font
------------------------------
*/
:root {
  --base-font-ja: "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック",
      "Yu Gothic", "メイリオ", sans-serif;
  --font-en: "Inter", sans-serif;
  --font-en02: "Afacad", sans-serif;
  --font-en03: "Plus Jakarta Sans", sans-serif;
  --font-mplus: "M PLUS 1", sans-serif;
  --base-font-weight: 500;
  --base-color-txt: #243d5f;
  --header-height-pc: 107px;
  --space-component: 24px;
  --space-h1-content: 60px;
  --space-h2-top: 48px;
  --space-title-text: 20px;
  --space-text: 16px;
  --space-title-title: 32px;
  --space-image-text: 12px;
}
@media screen and (min-width: 768px) {
  :root {
    --space-component: 40px;
    --space-h1-content: 100px;
    --space-h2-top: 80px;
    --space-title-text: 32px;
    --space-text: 24px;
    --space-title-title: 48px;
    --space-image-text: 20px;
  }
}

/*!
global > mixin
------------------------------
*/
.p_top_sus .initiatives_header .figcaption {
  font-size: 0.625rem;
}
@media screen and (min-width: 768px) {
  .p_top_sus .initiatives_header .figcaption {
    font-size: clamp(0.625rem, 0.2976190476vw + 0.4821428571rem, 0.75rem);
  }
}

.p_top_sus .initiatives_header .txt {
  font-size: 0.75rem;
}
@media screen and (min-width: 768px) {
  .p_top_sus .initiatives_header .txt {
    font-size: 0.875rem;
  }
}

.p_top_sus .initiatives_list .item p {
  font-size: 0.75rem;
}
@media screen and (min-width: 768px) {
  .p_top_sus .initiatives_list .item p {
    font-size: 0.9375rem;
  }
}

.p_top_sus .initiatives_list .item_title {
  font-size: 1.625rem;
}
@media screen and (min-width: 768px) {
  .p_top_sus .initiatives_list .item_title {
    font-size: 2.5rem;
  }
}

.p_top_sus .sus_heading {
  font-size: 1.75rem;
}
@media screen and (min-width: 768px) {
  .p_top_sus .sus_heading {
    font-size: clamp(1.75rem, 2.6785714286vw + 0.4642857143rem, 2.875rem);
  }
}

.p_top {
  margin-top: 0;
}

.p_top_kv {
  height: 100vh;
  height: 80svh;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 1400px) {
  .p_top_kv {
    height: 56.25vw;
  }
}
.p_top_kv__bg {
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  max-width: 2000px;
}
.p_top_kv__bg video,
.p_top_kv__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: bottom left;
     object-position: bottom left;
}
.p_top_kv__body {
  position: relative;
  z-index: 1;
  height: 100%;
  max-width: 2000px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.p_top_kv__content {
  height: 100%;
  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;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-top: 90px;
  padding-bottom: 58px;
  padding-left: 20px;
  padding-right: 25px;
}
@media screen and (min-width: 768px) {
  .p_top_kv__content {
    padding-top: 153px;
    padding-bottom: 90px;
    padding-left: 20px;
    padding-right: 32px;
  }
}
.p_top_kv__links {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 1;
}

.p_top_about {
  margin-top: 69px;
}
@media screen and (min-width: 768px) {
  .p_top_about {
    margin-top: 93px;
  }
}
.p_top_about__head .p_top_mttl__title {
  margin-top: 11px;
}
@media screen and (min-width: 768px) {
  .p_top_about__head .p_top_mttl__title {
    margin-top: 0;
  }
}
.p_top_about__desc {
  line-height: 1.8;
  font-weight: 400;
  font-size: 1rem;
  margin-top: 16px;
}
@media screen and (min-width: 768px) {
  .p_top_about__desc {
    line-height: 1.6;
    font-size: 1.0625rem;
    margin-left: 31px;
    margin-top: 4px;
  }
}
.p_top_about__body {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 22px;
}
@media screen and (min-width: 768px) {
  .p_top_about__body {
    gap: 15px;
    grid-template-columns: repeat(4, 1fr);
    margin-top: 44px;
  }
}
.p_top_about__card {
  overflow: hidden;
  border-radius: 8px;
}
@media screen and (min-width: 768px) {
  .p_top_about__card {
    aspect-ratio: 289/328;
  }
}
.p_top_about__card .btn_image {
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 768px) {
  .p_top_about__card .btn_image__body {
    padding-inline: clamp(0.875rem, 0.8928571429vw + 0.4464285714rem, 1.25rem);
    padding-block: clamp(0.625rem, 1.0416666667vw + 0.125rem, 1.0625rem);
    gap: 14px;
    padding-bottom: clamp(0.625rem, 1.9345238095vw + -0.3035714286rem, 1.4375rem);
  }
}
@media screen and (min-width: 768px) {
  .p_top_about__card .btn_image__body::after {
    bottom: 3px;
  }
}
.p_top_about__card .btn_image__ttl {
  line-height: 1.5;
  letter-spacing: 0em;
  margin-right: 12px;
}
@media screen and (min-width: 768px) {
  .p_top_about__card .btn_image__ttl {
    font-size: clamp(1.25rem, 0.2976190476vw + 1.1071428571rem, 1.375rem);
  }
}
@media screen and (max-width: 767px) {
  .p_top_about__card .btn_image::before {
    background: rgba(26, 59, 75, 0.4);
    height: 100%;
  }
}
@media screen and (max-width: 767px) {
  .p_top_about__card {
    aspect-ratio: 342/120;
    grid-column: span 2;
  }
  .p_top_about__card .btn_image__body::after {
    width: 15.86px;
    bottom: 2px;
  }
  .p_top_about__card .btn_image__ttl {
    font-size: 1.125rem;
  }
}
@media screen and (max-width: 767px) {
  .p_top_about__card.size-s {
    aspect-ratio: 165/120;
    grid-column: auto;
  }
  .p_top_about__card.size-s .btn_image__body {
    padding-inline: clamp(0.625rem, 20vw + -4.0625rem, 0.8125rem);
    padding-block: 8px;
    gap: 8px;
  }
  .p_top_about__card.size-s .btn_image__ttl {
    font-size: 0.875rem;
    letter-spacing: 0.04em;
  }
}
@media screen and (min-width: 768px) {
  .p_top_about__card.size-s {
    aspect-ratio: 593/120;
    grid-column: span 2;
  }
  .p_top_about__card.size-s .btn_image__ttl {
    font-size: clamp(1.125rem, 0.5952380952vw + 0.8392857143rem, 1.375rem);
  }
}

.p_top_investor {
  margin-top: 32px;
}
@media screen and (min-width: 768px) {
  .p_top_investor {
    margin-top: 64px;
  }
}
.p_top_investor__main {
  background-color: #fff;
  padding-top: 16px;
  padding-inline: clamp(1rem, 33.3333333333vw + -6.8125rem, 1.3125rem);
  padding-bottom: 20px;
}
@media screen and (min-width: 768px) {
  .p_top_investor__main {
    border-radius: 8px;
    padding-inline: 36px;
    padding-top: 29px;
    padding-bottom: 31px;
  }
}
.p_top_investor__title {
  letter-spacing: 0em;
  line-height: 1.5;
  font-size: 1.125rem;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .p_top_investor__title {
    font-weight: 300;
    font-size: 1.875rem;
  }
}
.p_top_investor__links {
  padding-top: 22px;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  row-gap: 15px;
}
@media screen and (min-width: 768px) {
  .p_top_investor__links {
    padding-top: 22px;
  }
}
.p_top_investor__link {
  border: 0;
  background-color: var(--cl-bg-gray);
  min-height: 63.67px;
  font-size: 0.875rem;
}
@media screen and (min-width: 768px) {
  .p_top_investor__link {
    min-height: 72px;
    font-size: 1.25rem;
    padding-inline: 26px;
  }
}
@media screen and (max-width: 767px) {
  .p_top_investor__link {
    width: calc(50% - 6px);
    line-height: 1.5;
    padding: 11px 14px;
  }
}

.p_top_business {
  position: relative;
  background-color: var(--cl-main);
  z-index: 1;
  overflow: hidden;
  color: #fff;
  margin-top: 55px;
  padding: 76px 23px 110px;
  border-radius: 16px 16px 0 0;
}
@media screen and (min-width: 768px) {
  .p_top_business {
    margin-top: 81px;
    padding: 111px 0 145px;
    border-radius: 40px 40px 0 0;
  }
}
.p_top_business::before {
  background: url(../images/common/img_bg_pattern.webp);
  content: "";
  height: 100%;
  left: 0;
  opacity: 0.2;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .p_top_business__mttl {
    row-gap: 9px;
  }
}
.p_top_business__mttl .p_top_mttl__sub {
  color: #fff;
}
@media screen and (min-width: 768px) {
  .p_top_business__mttl .p_top_mttl__sub {
    padding-left: 24px;
  }
}
.p_top_business__mttl .p_top_mttl__title {
  letter-spacing: -0.05em;
  font-size: 2.375rem;
}
@media screen and (min-width: 768px) {
  .p_top_business__mttl .p_top_mttl__title {
    letter-spacing: -0.08em;
    font-size: 3.25rem;
  }
}
.p_top_business__main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media screen and (min-width: 768px) {
  .p_top_business__main {
    max-width: calc(50% + 720px);
  }
}
.p_top_business__list_media {
  width: 50vw;
  margin-left: calc(50% - 50vw);
  display: none;
  position: relative;
  aspect-ratio: 712/480;
}
@media screen and (min-width: 768px) {
  .p_top_business__list_media {
    padding-right: 8px;
    margin-top: 14px;
    display: block;
  }
}
.p_top_business__media {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  z-index: 0;
  -webkit-transition: opacity 0.5s linear;
  transition: opacity 0.5s linear;
}
.p_top_business__media img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 0 10px 10px 0;
}
.p_top_business__media.default {
  z-index: 1;
  opacity: 1;
}
.p_top_business__media.default.hide {
  z-index: -1;
  opacity: 0;
}
.p_top_business__media.show {
  z-index: 1;
  opacity: 1;
}
.p_top_business__content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media screen and (min-width: 768px) {
  .p_top_business__content {
    padding-left: clamp(0.625rem, 4.7619047619vw + -1.6607142857rem, 2.625rem);
    padding-right: clamp(3.125rem, 11.6071428571vw + -2.4464285714rem, 8rem);
  }
}
.p_top_business__clone {
  position: absolute;
  right: 0;
  width: 160px;
  height: 179px;
  z-index: 0;
  display: none;
}
@media screen and (min-width: 768px) {
  .p_top_business__clone {
    top: 395px;
    display: block;
  }
}
.p_top_business__clone figure {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p_top_business__clone img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p_top_business__clone .default_image {
  z-index: 1;
  opacity: 1;
}
.p_top_business__clone .default_image.hide {
  z-index: -1;
  opacity: 0;
}
.p_top_business__clone .acc_thumb_clone {
  opacity: 0;
  z-index: 0;
  -webkit-transition: opacity 0.5s linear;
  transition: opacity 0.5s linear;
}
.p_top_business__clone .acc_thumb_clone.show {
  z-index: 1;
  opacity: 1;
}
.p_top_business .business_accordion {
  margin-top: 38px;
}
@media screen and (min-width: 768px) {
  .p_top_business .business_accordion {
    margin-top: 37px;
  }
}
.p_top_business .business_accordion__item {
  -webkit-transition: background 0.3s ease-in-out;
  transition: background 0.3s ease-in-out;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-top: 1px solid #84868c;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  padding-block: 9px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding-bottom: 82px;
}
@media screen and (min-width: 768px) {
  .p_top_business .business_accordion__item {
    margin-top: 9px;
    border-radius: 6px;
    padding: 0;
    border: 0;
    display: block;
    position: static;
    background: rgba(73, 95, 126, 0.6);
    backdrop-filter: blur(6px);
  }
}
.p_top_business .business_accordion__item:last-child {
  border-bottom: 1px solid #84868c;
}
@media screen and (min-width: 768px) {
  .p_top_business .business_accordion__item:last-child {
    border: 0;
  }
}
.p_top_business .business_accordion__item.is_open .business_accordion__trigger::after {
  opacity: 0;
}
@media screen and (max-width: 767px) {
  .p_top_business .business_accordion__item.is_open .business_accordion__header {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .p_top_business .business_accordion__item.is_open {
    background: rgba(172, 124, 64, 0.6);
  }
  .p_top_business .business_accordion__item.is_open .business_accordion__links {
    border-top-color: #92837a;
  }
}
@media screen and (max-width: 767px) {
  .p_top_business .business_accordion__item.is_open .business_accordion__item {
    padding-right: 3px;
  }
  .p_top_business .business_accordion__item.is_open .business_accordion__trigger {
    -webkit-transition-delay: 0ms;
            transition-delay: 0ms;
  }
  .p_top_business .business_accordion__item.is_open .business_accordion__trigger::before {
    right: -5px;
  }
}
.p_top_business .business_accordion__header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: calc(100% - 101px);
  padding: 8px 0;
}
@media screen and (min-width: 768px) {
  .p_top_business .business_accordion__header {
    width: 100%;
    padding: 18px 5.4347826087%;
  }
}
.p_top_business .business_accordion__image {
  display: block;
  top: 9px;
  bottom: 9px;
  width: 101px;
  right: 3px;
  opacity: 1;
  -webkit-transition: translate 0.3s linear, opacity 0.2s linear;
  transition: translate 0.3s linear, opacity 0.2s linear;
  position: absolute;
}
@media screen and (min-width: 768px) {
  .p_top_business .business_accordion__image {
    display: none;
  }
}
.p_top_business .business_accordion__image.trigger {
  position: absolute;
  translate: 100% 0;
  opacity: 0;
}
.p_top_business .business_accordion__trigger {
  position: relative;
  width: 40px;
  height: 40px;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  background: none;
  border: none;
  cursor: pointer;
  margin-right: 12px;
}
@media screen and (min-width: 768px) {
  .p_top_business .business_accordion__trigger {
    padding: 18px 5.4347826087%;
  }
}
.p_top_business .business_accordion__trigger::after, .p_top_business .business_accordion__trigger::before {
  content: "";
  position: absolute;
  width: 13px;
  height: 1px;
  top: 50%;
  right: 0;
  translate: -50% -50%;
  background-color: #fff;
}
@media screen and (min-width: 768px) {
  .p_top_business .business_accordion__trigger::after, .p_top_business .business_accordion__trigger::before {
    width: 14px;
    height: 2px;
  }
}
.p_top_business .business_accordion__trigger::after {
  rotate: 90deg;
}
.p_top_business .business_accordion__text {
  font-weight: 300;
  font-size: 1.25rem;
  color: #fff;
  text-decoration: none;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  display: inline-block;
}
.p_top_business .business_accordion__text:hover {
  text-decoration: underline;
}
@media screen and (min-width: 768px) {
  .p_top_business .business_accordion__text {
    font-size: 1.5rem;
  }
}
.p_top_business .business_accordion__body {
  display: none;
}
@media screen and (min-width: 768px) {
  .p_top_business .business_accordion__body {
    padding-inline: 5.4347826087%;
  }
}
.p_top_business .business_accordion__links {
  --item-gap: 10px;
  border-top: 1px solid transparent;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  width: 100%;
  padding-top: 7px;
  row-gap: 10px;
}
@media screen and (min-width: 768px) {
  .p_top_business .business_accordion__links {
    padding-top: 14px;
    row-gap: 9px;
    padding-bottom: 24px;
  }
}
.p_top_business .business_accordion__link {
  border: 0;
  min-height: 48px;
}
@media screen and (max-width: 767px) {
  .p_top_business .business_accordion__link {
    width: calc(50% - 5px);
    font-size: 0.875rem;
    padding-block: 10px;
    padding-inline: 13px;
  }
}
@media screen and (min-width: 768px) {
  .p_top_business .business_accordion__link {
    font-size: 0.9375rem;
    padding-left: 13px;
    padding-right: 15px;
  }
}
.p_top_business .business_accordion__link::after {
  width: 14px;
}
@media screen and (min-width: 768px) {
  .p_top_business .business_accordion__link::after {
    width: 18px;
  }
}

.p_top_news {
  background-color: #fff;
  padding-top: 80px;
  padding-bottom: 64px;
}
@media screen and (min-width: 768px) {
  .p_top_news {
    padding-top: 128px;
    padding-bottom: 85px;
  }
}
.p_top_news__head .p_top_mttl {
  row-gap: 7px;
}
@media screen and (min-width: 768px) {
  .p_top_news__head .p_top_mttl {
    row-gap: 3px;
  }
}
.p_top_news__head .p_top_mttl__title {
  letter-spacing: 0em;
}
.p_top_news__main {
  position: relative;
}
.p_top_news__cats {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 8px;
  row-gap: 6px;
  margin-top: 48px;
}
@media screen and (min-width: 768px) {
  .p_top_news__cats {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    row-gap: 8px;
    margin-top: 30px;
  }
}
.p_top_news__cat_item {
  width: calc(25% - 6px);
  min-height: 37px;
}
@media screen and (min-width: 768px) {
  .p_top_news__cat_item {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    width: auto;
    min-height: 40px;
  }
}
.p_top_news__cat_item:nth-child(1), .p_top_news__cat_item:nth-child(2) {
  width: clamp(25% - 6px, (600px - 100vw) * 1000, 50% - 4px);
}
@media screen and (min-width: 768px) {
  .p_top_news__cat_item:nth-child(1), .p_top_news__cat_item:nth-child(2) {
    width: auto;
  }
}
.p_top_news__cat_item button {
  background-color: #fff;
  border: 1px solid #ced0d6;
  width: 100%;
  height: 100%;
  text-align: center;
  font-weight: 500;
  border-radius: 4px;
  line-height: 1.4;
}
@media screen and (min-width: 768px) {
  .p_top_news__cat_item button {
    line-height: 1.23;
    border-radius: 5px;
    font-size: 0.875rem;
    -webkit-transition: background 0.3s ease-in-out, color 0.3s ease-in-out;
    transition: background 0.3s ease-in-out, color 0.3s ease-in-out;
  }
  .p_top_news__cat_item button:hover {
    background: var(--cl-main);
    color: #fff;
  }
}
.p_top_news__cat_item button.is_active {
  background: var(--cl-main);
  color: #fff;
}
.p_top_news__content {
  margin-top: 14px;
}
@media screen and (min-width: 768px) {
  .p_top_news__content {
    margin-top: 12px;
  }
}
.p_top_news__content .p_top_list {
  display: none;
}
.p_top_news__content .p_top_list:first-child {
  display: block;
}

.p_top_ir {
  padding-top: 54px;
  padding-bottom: 56px;
}
@media screen and (min-width: 768px) {
  .p_top_ir {
    padding-top: 67px;
    padding-bottom: 100px;
  }
}
.p_top_ir__head {
  padding-left: 5px;
}
@media screen and (min-width: 768px) {
  .p_top_ir__head {
    padding-left: 0;
  }
}
@media screen and (max-width: 767px) {
  .p_top_ir__head .p_top_mttl {
    row-gap: 8px;
  }
}
.p_top_ir__head .p_top_mttl__title {
  letter-spacing: -0.03em;
}
.p_top_ir__main {
  position: relative;
}
.p_top_ir__content {
  margin-top: 31px;
}
@media screen and (min-width: 768px) {
  .p_top_ir__content {
    margin-top: 29px;
  }
}
@media screen and (min-width: 768px) {
  .p_top_ir .p_top_more {
    top: 45px;
  }
}
.p_top_ir .p_top_more a {
  -webkit-column-gap: 8px;
     -moz-column-gap: 8px;
          column-gap: 8px;
}

.p_top_related {
  background-color: #fff;
  padding-block: 50px;
}
.p_top_related.is-en {
  padding-top: 80px;
}
@media screen and (min-width: 768px) {
  .p_top_related {
    padding-top: 58px;
    padding-bottom: 64px;
  }
  .p_top_related.is-en {
    padding-top: 100px;
  }
}
.p_top_related__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  row-gap: 12px;
}
.p_top_related__item {
  width: clamp((100% - 24px) / 3, (600px - 100vw) * 1000, 100%);
  aspect-ratio: 342/109;
}
@media screen and (min-width: 768px) {
  .p_top_related__item {
    width: calc((100% - 72px) / 3);
    aspect-ratio: 376/120;
  }
}
.p_top_related__item a {
  width: 100%;
  display: block;
  border: 1px solid #ced0d6;
  height: 100%;
  border-radius: 4px;
  overflow: hidden;
}
.p_top_related__item a picture,
.p_top_related__item a img {
  width: 100%;
  display: block;
  height: 100%;
}

.p_top_mttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.p_top_mttl__sub {
  width: 100%;
  font-family: var(--font-en02);
  letter-spacing: 0em;
  font-weight: 400;
  font-size: 0.625rem;
  color: #767e98;
  margin-bottom: 0;
}
@media screen and (min-width: 768px) {
  .p_top_mttl__sub {
    color: var(--cl-main);
    font-weight: 500;
    font-size: 1.25rem;
  }
}
.p_top_mttl__sub::before {
  width: 8px;
}
@media screen and (min-width: 768px) {
  .p_top_mttl__sub::before {
    width: 12px;
  }
}
.p_top_mttl__title {
  font-weight: 300;
  line-height: 1.1;
  letter-spacing: -0.12em;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 2.375rem;
}
@media screen and (min-width: 768px) {
  .p_top_mttl__title {
    letter-spacing: -0.1em;
    font-size: 3.125rem;
  }
}

.p_top_list__item {
  border-top: 1px solid #ced0d6;
}
@media screen and (min-width: 768px) {
  .p_top_list__item {
    padding-inline: 3px;
  }
}
.p_top_list__item:last-child {
  border-bottom: 1px solid #ced0d6;
}
.p_top_list .no-link, .p_top_list__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding-top: 13px;
  padding-bottom: 14px;
  row-gap: 7px;
}
@media screen and (min-width: 768px) {
  .p_top_list .no-link, .p_top_list__link {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    padding-top: 9px;
    padding-bottom: 12px;
  }
}
.p_top_list .no-link[href$=".xls"], .p_top_list .no-link[href$=".xlsx"], .p_top_list .no-link[href$=".doc"], .p_top_list .no-link[href$=".docx"], .p_top_list .no-link[href$=".pdf"], .p_top_list__link[href$=".xls"], .p_top_list__link[href$=".xlsx"], .p_top_list__link[href$=".doc"], .p_top_list__link[href$=".docx"], .p_top_list__link[href$=".pdf"] {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  text-decoration: none;
}
.p_top_list__date {
  font-family: var(--font-en);
  font-weight: 400;
  width: 78px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-size: 0.75rem;
}
@media screen and (min-width: 768px) {
  .p_top_list__date {
    width: 96px;
    font-size: 0.875rem;
  }
}
.p_top_list__ttl {
  font-weight: 400;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-word;
  width: 100%;
  font-size: 0.875rem;
  line-height: 1.7;
}
@media screen and (min-width: 768px) {
  .p_top_list__ttl {
    line-height: 1.5;
    -webkit-line-clamp: 1;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    width: auto;
    font-size: 1rem;
  }
}

.p_top_more {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 22px;
}
@media screen and (min-width: 768px) {
  .p_top_more {
    margin-top: 0;
    display: initial;
    position: absolute;
    right: 0;
    top: 48px;
  }
}
.p_top_more a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 22px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: var(--cl-main);
  border-radius: 999px;
  color: #fff;
  width: 165px;
  height: 36px;
  font-size: 0.8125rem;
  font-weight: 400;
  padding-inline: 11px;
}
@media screen and (min-width: 768px) {
  .p_top_more a {
    gap: 14px;
    font-weight: 500;
    width: 166px;
    height: 40px;
    font-size: 0.9375rem;
    padding-inline: 14px;
  }
}
.p_top_more a::after {
  content: "";
  aspect-ratio: 1;
  background: url("../images/common/icon_arrow_circle.svg");
  background-size: 100% 100%;
  background-repeat: no-repeat;
  width: 16px;
}
@media screen and (min-width: 768px) {
  .p_top_more a::after {
    width: 18px;
  }
}

.p_top_sus {
  background-color: #ebf7f1;
  border-radius: 16px;
  position: relative;
  z-index: 1;
  margin-block: -40px;
  padding-top: 40px;
  padding-bottom: 40px;
}
@media screen and (min-width: 768px) {
  .p_top_sus {
    border-radius: 36px;
    margin-top: -40px;
    padding-top: 90px;
    padding-bottom: 125px;
  }
}
.p_top_sus_decoration {
  width: 100%;
  max-width: 1440px;
  height: 100%;
  position: absolute;
  z-index: -1;
  left: 50%;
  top: 0;
  translate: -50% 0;
}
.p_top_sus_decoration .shape {
  --tw: 375;
  --w: 0;
  --h: 0;
  --x: 0px;
  --x2: 0px;
  --y: 0px;
  width: calc(var(--w) / var(--tw) * 100%);
  max-width: calc(var(--w) * 1px);
  height: calc(var(--h) * 1px);
  position: absolute;
  aspect-ratio: calc(var(--w) / var(--h));
  top: var(--y);
  left: var(--x);
  right: var(--x2);
}
@media screen and (min-width: 768px) {
  .p_top_sus_decoration .shape {
    --tw: 1440;
  }
}
.p_top_sus_decoration .shape:nth-child(1) {
  --w: 100;
  --h: 100;
  --x: -11px;
  --y: 58px;
}
@media screen and (min-width: 768px) {
  .p_top_sus_decoration .shape:nth-child(1) {
    --w: 243;
    --h: 243;
  }
}
.p_top_sus_decoration .shape:nth-child(2) {
  --w: 200;
  --h: 60;
  --x: unset;
  --x2: -94px;
  --y: 4px;
}
@media screen and (min-width: 768px) {
  .p_top_sus_decoration .shape:nth-child(2) {
    --w: 336;
    --h: 98;
    --y: 54px;
  }
}
.p_top_sus_decoration .shape:nth-child(3) {
  --w: 50;
  --h: 40;
  --x: 30px;
  --y: calc(100% - 60px);
}
@media screen and (min-width: 768px) {
  .p_top_sus_decoration .shape:nth-child(3) {
    --w: 101;
    --h: 90;
    --x: 108px;
    --y: calc(100% - 168px);
  }
}
.p_top_sus_decoration .shape:nth-child(4) {
  --w: 100;
  --h: 100;
  --x: unset;
  --x2: 20px;
  --y: calc(100% - 110px);
}
@media screen and (min-width: 768px) {
  .p_top_sus_decoration .shape:nth-child(4) {
    --w: 224;
    --h: 224;
    --y: calc(100% - 246px);
    --x2: 51px;
  }
}
.p_top_sus .sus_heading {
  font-family: var(--font-mplus);
  font-weight: 800;
  letter-spacing: 0.09em;
  line-height: 1.5;
  color: #3b5c52;
  text-align: center;
}
.p_top_sus .sus_heading::after {
  content: "";
  width: 75px;
  height: 5px;
  background-image: url("./../images/sustainability/img_about_title_dot.webp");
  background-size: 100%;
  display: block;
  margin-top: 13px;
  margin-left: auto;
  margin-right: auto;
}
.p_top_sus .initiatives_header {
  max-width: 940px;
  background-color: #fff;
  border: 1px solid #000;
  border-radius: 8px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px 46px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 30px;
  margin-inline: auto;
  padding: 28px 32px 29px;
}
@media screen and (min-width: 768px) {
  .p_top_sus .initiatives_header {
    margin-top: 50px;
    padding: 28px 28px 29px;
  }
}
.p_top_sus .initiatives_header .column {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p_top_sus .initiatives_header .column:nth-child(1) {
    width: 515px;
  }
}
.p_top_sus .initiatives_header .column:nth-child(2) {
  width: 240px;
}
@media screen and (min-width: 768px) {
  .p_top_sus .initiatives_header .column:nth-child(2) {
    width: 272px;
    padding-top: 7px;
  }
}
.p_top_sus .initiatives_header .figcaption {
  font-family: var(--font-mplus);
  font-weight: 800;
  letter-spacing: 0.09em;
  text-align: center;
  color: #034a8a;
  margin-bottom: 7px;
}
.p_top_sus .initiatives_header .txt {
  font-family: var(--font-mplus);
  font-weight: 800;
  line-height: 1.9;
  letter-spacing: 0.11em;
  color: #3b5c52;
}
.p_top_sus .initiatives_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 35px;
}
@media screen and (min-width: 768px) {
  .p_top_sus .initiatives_list {
    gap: 22px;
  }
}
.p_top_sus .initiatives_list .item {
  width: 100%;
  background-color: #fff;
  border: 1px solid #3b5c52;
  border-radius: 12px;
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p_top_sus .initiatives_list .item {
    width: calc(33.33% - 13.3333333333px);
    width: clamp(33.33% - 14.6666666667px, (1160px - 100vw) * 1000, 50% - 11px);
  }
}
.p_top_sus .initiatives_list .item p {
  font-family: var(--font-mplus);
  font-weight: 700;
  letter-spacing: 0.05em;
  color: #3b5c52;
}
.p_top_sus .initiatives_list .item_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.p_top_sus .initiatives_list .item_link vs-icon {
  width: 27px;
  aspect-ratio: 1;
  background-color: #3b5c52;
  border-radius: 99px;
  position: absolute;
  right: 22px;
  bottom: 19px;
}
.p_top_sus .initiatives_list .item_link vs-icon::after {
  content: "";
  width: 6px;
  height: 6px;
  position: absolute;
  top: 50%;
  left: 50%;
  rotate: 45deg;
  translate: -50% -50%;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}
.p_top_sus .initiatives_list .item_photo {
  width: 100%;
  aspect-ratio: 2.4743589744;
  position: relative;
  margin: 0;
}
.p_top_sus .initiatives_list .item_photo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p_top_sus .initiatives_list .item_context {
  padding: 10px 50px 13px 24px;
}
.p_top_sus .initiatives_list .item_context.en {
  padding: 10px 50px 32px 24px;
}
.p_top_sus .initiatives_list .item_title {
  font-family: var(--font-en02);
  font-weight: 700;
  line-height: 1;
  color: #3b5c52;
  letter-spacing: -1px;
}
.p_top_sus .initiatives_list .item_title::first-letter {
  text-transform: uppercase;
  color: var(--ft);
}
.p_top_sus .initiatives_list .item p {
  margin: 0;
}
.p_top_sus .initiatives_more {
  margin-top: 34px;
}
@media screen and (min-width: 768px) {
  .p_top_sus .initiatives_more {
    margin-top: 34px;
  }
}
.p_top_sus .initiatives_more .btn {
  width: 164px;
  height: 36px;
  background-color: #3b5c52;
  border-radius: 99px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  padding: 4px 24px 4px 10px;
  margin-inline: auto;
  font-size: 0.8125rem;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .p_top_sus .initiatives_more .btn {
    width: 240px;
    height: 56px;
    font-size: 1rem;
  }
}
.p_top_sus .initiatives_more .btn vs-icon {
  width: 16px;
  aspect-ratio: 1;
  background-color: #fff;
  border-radius: 99px;
  position: absolute;
  top: 50%;
  right: 10px;
  translate: 0 -50%;
}
@media screen and (min-width: 768px) {
  .p_top_sus .initiatives_more .btn vs-icon {
    width: 23px;
    right: 20px;
  }
}
.p_top_sus .initiatives_more .btn vs-icon::after {
  content: "";
  width: 5px;
  height: 5px;
  position: absolute;
  top: 50%;
  left: 50%;
  rotate: 45deg;
  translate: -50% -50%;
  border-top: 1px solid #3b5c52;
  border-right: 1px solid #3b5c52;
}
@media screen and (min-width: 768px) {
  .p_top_sus .initiatives_more .btn vs-icon::after {
    width: 6px;
    height: 6px;
  }
}

.p_top_video {
  padding-top: 50px;
  padding-bottom: 20px;
}
@media screen and (min-width: 768px) {
  .p_top_video {
    padding-top: 45px;
    padding-bottom: 80px;
  }
}
.p_top_video__heading {
  margin: 0 0 20px;
  font-weight: 300;
  font-size: 1.625rem;
  text-align: center;
  letter-spacing: -0.01em;
}
@media screen and (min-width: 768px) {
  .p_top_video__heading {
    font-size: 3.25rem;
    margin-bottom: 32px;
  }
}
.p_top_video__video {
  display: block;
  width: 100%;
  max-width: 960px;
  height: auto;
  margin: 0 auto;
  aspect-ratio: 16/9;
}
.p_top_video iframe {
  width: 100% !important;
  height: 100% !important;
}