.container,
.container__inner {
  max-width: initial;
  width: 100%;
  overflow: hidden;
}
/* ============================================================
components
============================================================ */
.c-head {
  width: min(80%, 1200px);
  margin: 0 auto;
  padding: 7.32vw 0 80px 0;
}
.c-head__title {
  width: 100%;
  padding-bottom: 0.73vw;
  color: var(--accent);
  font-size: min(1.76vw, 24px);
  font-weight: 700;
  line-height: 1.25;
  border-bottom: 3px solid var(--accent);
}

/* ============================================================
hero
============================================================ */
.hero {
  width: 100%;
  height: calc(100vh - 60px);
}
.hero__inner {
  width: 100%;
  height: 100%;
}
.hero__head {
  position: relative;
  padding-bottom: 5.3333vw;
  width: 100%;
  height: 100%;
}
.hero__img {
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.hero__img img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: bottom;
}
.hero__title {
  position: absolute;
  bottom: 5.3333vw;
  left: 0;
  right: 0;
}
.hero__title__inner {
  display: block;
  margin: 0 auto;
  max-width: 1200px;
  width: 80%;
}
.hero__title-text {
  position: relative;
  color: var(--accent);
  font-size: 4.333vw;
  font-weight: bold;
  letter-spacing: 0.05em;
  padding-left: 0.6em;
  padding-right: 1.8em;
}
.hero__title-text::after {
  content: "";
  display: block;
  width: 100%;
  height: 5.3333vw;
  position: absolute;
  left: 0;
  bottom: -5.3333vw;
  background-color: var(--accent);
}

/* ============================================================
intro
============================================================ */
.intro__bg-content {
  width: 100%;
  height: 26.87vw;
  background-image: url("/assets/img/pages/about/bg-intro.jpg");
  background-repeat: no-repeat;
  background-size: contain;
}
.intro__text {
  width: fit-content;
  padding: 0 3vw 2vw;
  margin-left: calc(50% + 100px);
  background-color: var(--white);
  color: var(--black);
  font-size: min(1.46vw, 20px);
  line-height: 1.875;
}

/* ============================================================
section
============================================================ */

@media screen and (min-width: 768px) {
  /* .section__bg-right:after,
  .section__bg-left:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100%;
    background-color: #ede7d7;
  } */
  .section__bg-left:after {
    left: -20%;
    top: 0;
    height: 100%;
  }
}

/* ============================================================
  area_potential
  ============================================================ */
.area_potential-concept-area {
  width: 100%;
  max-height: 1440px;
  margin: 0 auto;
  text-shadow: #000 0 0 10px;
  color: #fff;
  background: url("../../img/pages/about/bg-potential-concept.png");
  background-size: cover;
  background-position: center 90%;
}

.area_potential-concept-area > .inner {
  padding: 12% 0 42% 0;
  max-width: 620px;
  width: 100%;
  margin: 0 auto;
}

.area_potential-concept-message-ttl {
  font-size: min(1.76vw, 24px);
  font-weight: bold;
  line-height: 1.826;
}

.area_potential-concept-textarea {
  margin: 100px auto 0;
  width: 100%;
}

.area_potential-concept-textarea p {
  margin-top: 30px;
  line-height: 1.833;
  font-size: min(1.46vw, 20px);
}

.area_potential-concept-textarea p:first-child {
  margin-top: 0;
}

/* ============================================================
concept
============================================================ */
.concept__logo-wrap {
  /* width: 42%; */
  width: 32%;
  margin: 0 auto;
}
.concept__logo {
  width: 100%;
}
.concept__content {
  display: flex;
  width: min(80%, 1200px);
  margin: 0 auto;
  margin-top: 4.39vw;
}
.concept__img-wrap {
  position: relative;
  width: 57%;

  /* --radius: 3.22vw;
  --radius02: 7.32vw;
  clip-path: polygon(
    var(--radius) 0,
    calc(100% - var(--radius02)) 0,
    calc(100% - var(--radius02)) var(--radius),
    100% var(--radius),
    100% calc(100% - var(--radius)),
    calc(100% - var(--radius02)) calc(100% - var(--radius)),
    calc(100% - var(--radius02)) 100%,
    0 100%,
    0 calc(100% - var(--radius)),
    0 calc(100% - var(--radius)),
    0 0,
    0 0
  ); */
}
/* .concept__img-wrap::before,
.concept__img-wrap::after {
  content: "";
  position: absolute;
  z-index: 1;
  background-color: var(--accent);
}
.concept__img-wrap::before {
  width: 1.17vw;
  height: 5.56vw;
  top: 2.93vw;
  right: 0;
}
.concept__img-wrap::after {
  width: 12.88vw;
  height: 2.27vw;
  bottom: 0;
  right: 7.32vw;
} */
.concept__img {
  /* width: calc(100% - 1.17vw); */
  width: 100%;
  display: block;
  object-fit: cover;
  object-position: bottom;
  /* aspect-ratio: 1 / 0.9752604166666666; */
}
.concept__desc {
  /* width: calc(56% + 1.17vw); */
  flex: 1;
  display: flex;
  align-items: center;
}
.concept__desc__inner {
  padding: 0 0 0 3.22vw;
}
.concept__lead {
  font-size: min(1.46vw, 20px);
  line-height: 1.9;
}
.concept__title {
  font-size: min(1.17vw, 16px);
  font-weight: 700;
  line-height: 2; /* 212.5% */
  margin-top: 2.93vw;
}
.concept__text {
  font-size: min(1.17vw, 16px);
  line-height: 2; /* 200% */
}

/* ============================================================
location
============================================================ */
.location__content {
  width: min(80%, 1200px);
  margin: 0 auto;
}
.location-content__top {
  position: relative;
  /* display: flex;
  justify-content: space-between; */
}
/* .location__desc__inner {} */
.location__lead {
  /* width: 39%; */
  font-size: min(1.46vw, 20px);
  line-height: 1.9;
  margin-bottom: 10%;
  display: flex;
  justify-content: center;
}
.location__img--01 {
  width: 100%;
  display: block;
  object-fit: cover;
}
.location-content__bottom {
  margin-top: 3.37vw;
  position: relative;
  z-index: 2;
  margin-top: 50px;
}
.location__img-wrap--02 {
  display: flex;
}
.location__img-wrap--02 img {
  width: 50%;
  display: block;
  object-fit: cover;
}
.location__img-wrap--02 img:nth-child(even) {
  margin-left: auto;
}

/* ============================================================
building
============================================================ */
/* .building__head {
  padding-bottom: 4.39vw;
} */
/* .building__logo-wrap {
  width: 42%;
  margin: 0 auto;
}
.building__logo {
  width: 100%;
} */
.building__content {
  position: relative;
  width: min(80%, 1200px);
  margin: 0 auto;
  /* margin-top: 4.39vw; */
}
.building__img-wrap {
  position: relative;
  width: 100%;
}
.building__img {
  width: 100%;
  display: block;
  object-fit: contain;
}
.building__desc {
  position: absolute;
  background-color: #fff;
  padding: 0 0 2vw 4vw;
  top: 0;
  left: 56.2%;
  flex: 1;
  display: flex;
  align-items: center;
}
.building__desc__inner {
  padding: 0;
}
.building__lead {
  font-size: min(1.46vw, 20px);
  line-height: 1.9;
  display: flex;
  justify-content: center;
  margin-bottom: 10%;
}
/* .building-bottom { */
/* position: relative; */
/* margin-left: 29.14vw; */
/* padding: 5.86vw 0; */
/* background: #ece7d7; */
/* } */
.building-bottom__lead {
  text-align: center;
  font-size: min(1.46vw, 20px);
  line-height: 2.2;
}
.building-bottom__inner {
  position: relative;
}
.building-bottom__left {
  position: absolute;
  top: 0;
  left: -16.11vw;
  width: 29.28vw;
}
.building-bottom__right {
  display: flex;
  flex-direction: column;
  gap: 4.9vw;
}
.building-bottom__img-wrap {
  display: flex;
  justify-content: center;
  margin-top: 2.93vw;
  margin-bottom: 10%;
}
.building-bottom .building__img {
  object-position: center;
}
.building-bottom__right__img-wrap {
  width: 36.6vw;
  margin-left: 19.77vw;
}
.building-bottom__right__img {
  width: 100%;
  display: block;
}
.building-bottom__right__caption {
  margin-top: 0.73vw;
  font-size: min(1.46vw, 20px);
  line-height: 2;
}

/* ============================================================
sustainability
============================================================ */
.sustainability__content {
  margin-top: 4.39vw;
  width: 100%;
  margin: 0 auto;
  padding: 70px 0;
  background-color: #ede7d7;
}
.sustainability__content__inner {
  position: relative;
  width: min(80%, 1200px);
  margin: 0 auto;
}
.sustainability__img-wrap {
  position: relative;
  width: 100%;
  z-index: 1;
}
.sustainability__img {
  width: 100%;
  display: block;
  object-fit: contain;
}
.sustainability__desc {
  position: absolute;
  top: 0;
  left: 56.3%;
  width: 43.7%;
  height: 100%;
  display: flex;
  align-items: center;
  z-index: 1;
}
.sustainability__desc__inner {
  padding-left: 4.39vw;
}
.sustainability__lead {
  font-size: min(1.6vw, 24px);
  font-weight: bold;
  line-height: 1.9;
}
.sustainability__text {
  margin-top: 2.93vw;
  font-size: min(1.46vw, 20px);
  line-height: 2; /* 200% */
}
.sustainability__text:first-of-type {
  margin-top: 2.93vw;
}
.sustainability__text:nth-of-type(n + 2) {
  margin-top: 2.34vw;
}
.sustainability-zebready {
  /* width: calc(100% - 80px); */
  width: 100%;
  /* height: 43.85vw; */
  margin: 0 auto;
  padding: 4.39vw 0;
  background-image: url("/assets/img/pages/about/bg-sustainability-zebready-sp.png");
  background-repeat: no-repeat;
  background-size: cover;
}
.sustainability-zebready__title {
  font-size: min(1.6vw, 24px);
  font-weight: 700;
  line-height: 1.5; /* 150% */
  text-align: center;
}
.sustainability-zebready__main {
  width: 56%;
  margin: 2.93vw auto 0;
  padding: 4.39vw 5.12vw;
  background: var(--white);
}
.sustainability-zebready__main__title {
  text-align: center;
  font-size: min(1.46vw, 20px);
  font-weight: 400;
  line-height: 1.5; /* 166.667% */
}
.sustainability-zebready__main__ul {
  position: relative;
  margin-top: 1.46vw;
  padding-bottom: 1.46vw;
  display: flex;
  flex-direction: column;
  gap: 0.73vw;
}
.sustainability-zebready__main__ul::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 27.09vw;
  height: 3px;
  background-color: #d9c6a7;
}
.sustainability-zebready__main__li {
  position: relative;
  padding-left: 1.54vw;
  font-size: min(1.46vw, 20px);
  line-height: 1.5;
}
.sustainability-zebready__main__li::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 0.81vw;
  height: 0.81vw;
  background-color: #d9c6a7;
}
.sustainability-zebready__main__conclusion {
  margin-top: 1.46vw;
  font-size: min(1.6vw, 24px);
  line-height: 1.5;
  text-align: center;
}
.sustainability-zebready__main__conclusion span {
  color: #0014ff;
}
.sustainability-environment {
  width: 100%;
  padding: 4.39vw 0;
  background-color: #ece7d7;
}
.sustainability-environment__inner {
  width: min(80%, 1200px);
  margin: 0 auto;
}
.sustainability-environment__title {
  font-size: min(1.6vw, 24px);
  font-weight: 700;
  line-height: 1.5; /* 150% */
  text-align: center;
}
.sustainability-environment__main {
  width: 100%;
  margin: 2.93vw auto 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6.59vw;
}
.sustainability-environment__img-wrap {
  width: 29.28vw;
}
.sustainability-environment__ul {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
}
.sustainability-environment__li {
  width: calc(33.3% - 1.94vw);
  min-width: 240px;
  /* height: 15.96vw; */
  /* height: fit-content; */
  background-color: var(--white);
  padding: 20px;
}
.sustainability-environment__label-wrap {
  display: flex;
  align-items: center;
  /* gap: 1.1vw; */
}
.sustainability-environment__label-num {
  font-size: min(1.76vw, 24px);
  font-weight: 300;
  line-height: 1.25;
  margin-right: 1vw;
}
.sustainability-environment__label-tag01 {
  padding: 1px 6px;
  font-size: min(1.46vw, 20px);
  font-weight: 400;
  line-height: 1.5;
  background-color: #d9c6a7;
  margin-right: 0.67vw;
}
.sustainability-environment__label-tag02 {
  padding: 1px 6px;
  font-size: min(1.46vw, 20px);
  font-weight: 400;
  line-height: 1.5;
  background-color: var(--accent);
  color: var(--white);
}
.sustainability-environment__li__title {
  margin-top: 20px;
  font-size: min(1.46vw, 20px);
  font-style: normal;
  font-weight: 400;
  line-height: 1.3;
}
.sustainability-environment__li__text {
  margin-top: 12px;
  font-size: min(1.46vw, 20px);
  font-weight: 400;
  line-height: 1.5;
}
/* ============================================================
bcp
============================================================ */
.bcp__main {
  display: flex;
  gap: 40px;
  width: min(80%, 1200px);
  margin: 0 auto;
}
.bcp__img-wrap {
  width: 30%;
}
.bcp-right {
  flex: 1;
}
.bcp__img {
  width: 100%;
  display: block;
  object-fit: cover;
}
.bcp-rt__lead {
  font-size: min(1.46vw, 20px);
  line-height: 1.6;
}
.bcp-rt__bg-text {
  position: relative;
  margin-top: 40px;
  padding: 20px 0;
  padding-left: 36px;
  background-color: #d9c6a7;
  font-size: min(1.46vw, 20px);
  font-weight: 400;
  line-height: 1.3;
}
.bcp-rt__bg-text span {
  position: absolute;
  top: 50%;
  left: 12px;
  transform: translateY(-55%);
  font-size: min(1.76vw, 24px);
  line-height: 1.25;
}
.bcp-rt__text {
  margin-top: 16px;
  margin-left: 20px;
  font-size: min(1.46vw, 20px);
  font-weight: 400;
  line-height: 1.5;
}
.bcp-rt__2col {
  display: flex;
  gap: 20px;
}
.bcp-rt__2col__col {
  width: 50%;
}
.bcp-rb {
  margin-top: 4.39vw;
  padding: 2.93vw 0;
  border-top: 1px solid #727171;
  border-bottom: 1px solid #727171;
}
.bcp-rb__title {
  text-align: center;
  font-size: min(1.46vw, 20px);
  font-style: normal;
  font-weight: 700;
  line-height: 1.5;
}
.bcp-rb__ul {
  margin-top: 1.46vw;
  display: flex;
  flex-direction: column;
  gap: 0.73vw;
}
.bcp-rb__li {
  position: relative;
  padding-left: 1.54vw;
  font-size: min(1.46vw, 20px);
  line-height: 1.5;
}
.bcp-rb__li::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 0.81vw;
  height: 0.81vw;
  background-color: #d9c6a7;
}

.pre-footer {
  margin-top: 7.32vw;
  width: 100%;
  height: 32.58vw;
  background-image: url("/assets/img/pages/about/img-smart-visual-bottom.png");
  background-repeat: no-repeat;
  background-size: cover;
  background-color: var(--accent);
}

@media screen and (max-width: 767px) {
  /* ============================================================
components
============================================================ */
  .c-head {
    width: calc(100% - 40px);
    margin: 0 20px;
    padding: 32px 0 24px;
  }
  .c-head__title {
    padding-bottom: 4px;
    font-size: 24px;
  }

  /* ============================================================
hero
============================================================ */
  .hero {
    height: calc(100vh - 45px);
  }
  .hero__head {
    padding-bottom: 24px;
  }
  .hero__img img {
    height: 100%;
    object-fit: cover;
  }
  .hero__title {
    bottom: 24px;
    font-size: 3.2rem;
  }
  .hero__title__inner {
    width: 100%;
    padding: 0 20px;
  }
  .hero__title-text {
    font-size: 3.2rem;
  }
  .hero__title-text::after {
    height: 24px;
    bottom: -24px;
  }

  /* ============================================================
  intro
  ============================================================ */
  .intro__bg-content {
    height: 180px;
    background-size: cover;
    background-position: center;
    margin-top: 20px;
  }
  .intro__text {
    width: initial;
    height: initial;
    min-height: initial;
    padding: 0;
    margin: 0 20px;
    font-size: 2rem;
    text-align: center;
  }

  /* ============================================================
  area_potential
  ============================================================ */
  .area_potential-concept-area > .inner {
    padding: 12% 20px 42% 20px;
  }

  .area_potential-concept-textarea {
    margin: 50px auto 0;
  }
  .area_potential-concept-message-ttl {
    font-size: 24px;
  }
  .area_potential-concept-textarea p {
    font-size: 2rem;
  }

  /* ============================================================
  concept
  ============================================================ */
  /* .concept__head {
    padding-bottom: 4.39vw;
  } */
  .concept__logo-wrap {
    width: 220px;
  }
  .concept__content {
    width: calc(100% - 40px);
    flex-direction: column-reverse;
    margin-top: 16px;
  }
  .concept__img-wrap {
    width: calc(100% + 5px);
    margin-top: 20px;
  }
  .concept__desc {
    display: block;
  }
  .concept__desc__inner {
    padding: 0;
  }
  .concept__lead {
    font-size: 2rem;
    line-height: 1.5;
  }
  .concept__title {
    font-size: 2rem;
    margin-top: 8px;
    line-height: 1.5;
  }
  .concept__text {
    font-size: 2rem;
    line-height: 1.5;
  }

  /* ============================================================
location
============================================================ */
  .location__content {
    width: calc(100% - 40px);
  }
  .location-content__top {
    flex-direction: column;
    position: initial;
    margin-left: 0;
  }
  .location__lead {
    width: initial;
    font-size: 2rem;
  }
  .location__img-wrap {
    margin-top: 20px;
  }
  .location__img-wrap--01 {
    width: 100%;
    position: initial;
  }
  .location-content__bottom {
    margin-top: 0;
    position: initial;
  }
  .location__img-wrap--02 {
    width: 100%;
  }
  /* ============================================================
building
============================================================ */
  .building__content {
    width: calc(100% - 40px);
    position: initial;
    margin-top: 0;
  }
  .building__img-wrap {
    height: 287px;
  }
  .building__img {
    height: 100%;
    object-fit: cover;
    object-position: 39%;
  }
  .building__desc {
    position: initial;
    display: block;
    margin-top: 20px;
    padding-left: 0;
  }
  .building__lead {
    font-size: 2rem;
    line-height: 1.5;
  }
  .building-bottom {
    /* margin-top: 29.14vw; */
    /* margin-top: calc(106.67vw / 4); */
    margin-left: 0;
    padding: 20px 0;
    /* padding: calc(5.86vw + 55.2vw) 0 5.86vw; */
    /* padding: 5.86vw 0; */
  }
  .building-bottom__inner {
    position: relative;
    padding: calc(106.67vw / 4) 20px 0;
  }
  .building-bottom__lead {
    font-size: 2rem;
  }
  .building-bottom__img-wrap {
    margin-left: 20px;
    margin-right: 20px;
  }
  .building-bottom__img-wrap img {
    width: 100%;
  }
  .building-bottom__left {
    left: 50%;
    transform: translate(-50%, -50%);
    width: 60%;
  }
  .building-bottom__right {
    gap: 16px;
    padding-top: 40px;
  }
  .building-bottom__right__img-wrap {
    width: 100%;
    margin-left: 0;
  }
  .building-bottom__right__caption {
    margin-top: 4px;
    font-size: 1.4rem;
  }

  /* ============================================================
sustainability
============================================================ */
  .sustainability__content {
    width: 100%;
    padding: 0;
  }
  .sustainability__content__inner {
    width: 100%;
    padding: 40px 0;
  }
  .sustainability__img-wrap {
    padding: 0 10px 0 20px;
  }
  .sustainability__desc {
    position: initial;
    width: initial;
    height: initial;
    background-color: #ece7d7;
  }
  .sustainability__desc__inner {
    margin: 0 20px;
    padding: 20px 0;
  }
  .sustainability__lead {
    font-size: 2rem;
    line-height: 1.5;
  }
  .sustainability__text {
    font-size: 2rem;
    line-height: 1.5;
  }
  .sustainability__text:nth-of-type(n + 2) {
    margin-top: 20px;
  }
  .sustainability-zebready {
    width: 100%;
    height: initial;
    padding: 20px;
    background-image: url("/assets/img/pages/about/bg-sustainability-zebready-sp.png");
  }
  .sustainability-zebready__title {
    font-size: 2rem;
  }
  .sustainability-zebready__main {
    width: 100%;
    margin: 20px auto 0;
  }
  .sustainability-zebready__main__title {
    font-size: 1.8rem;
  }
  .sustainability-zebready__main__ul {
    margin-top: 16px;
    padding-bottom: 16px;
    gap: 4px;
  }
  .sustainability-zebready__main__ul::after {
    width: 90%;
  }
  .sustainability-zebready__main__li {
    padding-left: 2.1rem;
    font-size: 1.4rem;
  }
  .sustainability-zebready__main__li::before {
    width: 1.1rem;
    height: 1.1rem;
  }
  .sustainability-zebready__main__conclusion {
    margin-top: 20px;
    font-size: 1.8rem;
  }
  .sustainability-environment {
    padding: 20px;
  }
  .sustainability-environment__inner {
    width: 100%;
  }
  .sustainability-environment__title {
    font-size: 2rem;
  }
  .sustainability-environment__main {
    margin-top: 20px;
    gap: 20px;
    flex-direction: column;
    align-items: center;
  }
  .sustainability-environment__img-wrap {
    width: 80%;
  }
  .sustainability-environment__ul {
    gap: 16px;
  }
  .sustainability-environment__li {
    width: 100%;
    min-height: 210px;
    padding: 20px;
  }
  .sustainability-environment__label-num {
    width: 2.6rem;
    font-size: 2.4rem;
    margin-right: 1.6rem;
  }
  .sustainability-environment__label-tag01 {
    padding: 1px 10px;
    font-size: 1.2rem;
    margin-right: 1rem;
  }
  .sustainability-environment__label-tag02 {
    padding: 1px 10px;
    font-size: 1.2rem;
  }
  .sustainability-environment__li__title {
    margin-top: 8px;
    font-size: 1.8rem;
  }
  .sustainability-environment__li__text {
    margin-top: 4px;
    font-size: 1.4rem;
  }
  /* ============================================================
bcp
============================================================ */
  .bcp__main {
    flex-direction: column;
    align-items: center;
    gap: 20px;
    padding: 0 20px;
    width: 100%;
  }
  .bcp__img-wrap {
    width: 60%;
  }
  .bcp-rt__lead {
    font-size: 1.8rem;
  }
  .bcp-rt__bg-text {
    margin-top: 16px;
    padding: 4px 0;
    padding-left: 4.7rem;
    font-size: 1.8rem;
  }
  .bcp-rt__bg-text span {
    width: 3rem;
    font-size: 2.4rem;
  }
  .bcp-rt__text {
    margin-top: 4px;
    margin-left: 0;
    font-size: 1.4rem;
  }
  .bcp-rt__2col {
    gap: 0;
    flex-direction: column;
  }
  .bcp-rt__2col__col {
    width: 100%;
  }
  .bcp-rb {
    margin-top: 20px;
    padding: 8px 0;
  }
  .bcp-rb__title {
    font-size: 2rem;
  }
  .bcp-rb__ul {
    margin-top: 16px;
    gap: 4px;
  }
  .bcp-rb__li {
    padding-left: 2.1rem;
    font-size: 1.4rem;
  }
  .bcp-rb__li::before {
    width: 1.1rem;
    height: 1.1rem;
  }
  .pre-footer {
    margin-top: 40px;
  }
}
