.pagetitle__name .label span {
  letter-spacing: -0.15em;
  margin-right: 0.1em;
}

#leading {
  padding-top: calc(180 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #leading {
    padding-top: 18rem;
  }
}
#leading .lead {
  font-size: 2.8rem;
  font-family: var(--ff-shippori);
  line-height: 1.4166666667;
  text-align: center;
}
@media (768px <= width) {
  #leading .lead {
    font-size: 4.8rem;
    line-height: 1.4167;
  }
}
#leading .copy {
  margin-top: calc(55 / var(--spSize) * 100vw);
  margin-left: calc(30 / var(--spSize) * 100vw);
  margin-right: calc(30 / var(--spSize) * 100vw);
  text-align: center;
  font-size: 1.8rem;
  font-weight: 500;
}
@media (768px <= width) {
  #leading .copy {
    margin-top: 60px;
    font-size: 2.4rem;
    line-height: 1.8333333333;
  }
}
#leading .figure {
  margin-top: calc(55 / var(--spSize) * 100vw);
  margin-left: auto;
  margin-right: auto;
  width: calc(690 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #leading .figure {
    margin-top: 4rem;
    width: auto;
    text-align: center;
  }
}
#leading .text {
  margin-top: calc(40 / var(--spSize) * 100vw);
  margin-left: auto;
  margin-right: auto;
  width: calc(690 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #leading .text {
    margin-top: 4.7rem;
    text-align: center;
    font-size: 2rem;
    line-height: 2.2;
  }
}

.headline {
  position: relative;
}
.headline__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (768px <= width) {
  .headline__img img {
    aspect-ratio: 2/1;
  }
}
.headline__label {
  position: absolute;
  left: 0;
  bottom: 20%;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: calc(10 / var(--spSize) * 100vw) 0;
  color: #fff;
  line-height: 1;
}
@media (768px <= width) {
  .headline__label {
    gap: 2rem 0;
    top: 0;
    padding-top: 31.75%;
  }
}
.headline__label .en {
  font-size: 4.4rem;
  font-family: var(--ff-ci);
  letter-spacing: 0.06em;
}
@media (768px <= width) {
  .headline__label .en {
    font-size: 8.8rem;
  }
}
.headline__label .jp {
  font-size: 1.4rem;
  font-family: var(--ff-shippori);
}
@media (768px <= width) {
  .headline__label .jp {
    font-size: 2.8rem;
  }
}

#reasons {
  margin-top: calc(190 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #reasons {
    margin-top: 19rem;
  }
}
#reasons .reasons {
  position: relative;
  padding-top: calc(280 / var(--spSize) * 100vw);
  padding-bottom: calc(180 / var(--spSize) * 100vw);
  padding-left: calc(30 / var(--spSize) * 100vw);
  padding-right: calc(30 / var(--spSize) * 100vw);
  display: grid;
  gap: calc(150 / var(--spSize) * 100vw) 0;
}
@media (768px <= width) {
  #reasons .reasons {
    padding-top: 28rem;
    padding-bottom: 18rem;
    padding-left: max(50% - 800px, 5rem);
    padding-right: 0;
    display: grid;
    grid-template-columns: 41.67% 50%;
    gap: 0 8.33%;
  }
}
#reasons .reasons::after {
  content: "";
  width: 33%;
  height: 1px;
  background-color: var(--clr-blue);
  position: absolute;
  left: calc(30 / var(--spSize) * 100vw);
  top: calc(160 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #reasons .reasons::after {
    width: 30rem;
    left: max(50% - 800px, 5rem);
    right: max(50% - 800px, 5rem);
    top: 16rem;
  }
}
#reasons .reasons::before {
  content: "";
  width: calc(690 / var(--spSize) * 100vw);
  height: 1px;
  position: absolute;
  left: calc(30 / var(--spSize) * 100vw);
  top: calc(160 / var(--spSize) * 100vw);
  border-top: 1px dotted #cac9c4;
}
@media (768px <= width) {
  #reasons .reasons::before {
    width: auto;
    left: max(50% - 800px, 5rem);
    right: max(50% - 800px, 5rem);
    top: 16rem;
  }
}
#reasons .reasons:nth-child(even) {
  background-color: #eceae2;
}
#reasons .heading .label {
  font-size: 1.8rem;
  font-family: var(--ff-shippori);
  border-radius: 5px;
  display: inline-block;
}
@media (768px <= width) {
  #reasons .heading .label {
    font-size: 2.2rem;
  }
}
#reasons .heading .title {
  font-size: 2.8rem;
  font-family: var(--ff-shippori);
  line-height: 1.55;
}
@media (768px <= width) {
  #reasons .heading .title {
    font-size: 4rem;
  }
}
#reasons .text {
  font-size: 1.6rem;
  line-height: 1.8333333333;
  color: #666;
  margin-top: calc(100 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #reasons .text {
    font-size: 2rem;
    margin-top: 10rem;
  }
}