:where(.contents) {
  line-height: 1.8;
  color: #191616;
  font-family: "Noto Sans JP";
}
:where(.contents) *,
:where(.contents) *::before,
:where(.contents) *::after {
  letter-spacing: var(--letter-spacing, 0.08em);
  box-sizing: border-box;
}
@media screen and (max-width: 767px) {
  :where(.contents) *,
  :where(.contents) *::before,
  :where(.contents) *::after {
    letter-spacing: var(--sp-letter-spacing, var(--letter-spacing, 0.08em));
  }
}
:where(.contents) a {
  text-decoration: none;
  color: inherit;
}
:where(.contents) sup {
  font-size: 60%;
}
:where(.contents) ul, :where(.contents) ol {
  list-style-type: none;
}
:where(.contents) strong {
  font-weight: 500;
}
:where(.contents) button {
  appearance: none;
  background: none;
  box-shadow: none;
  border: none;
  padding: 0;
  margin: 0;
  cursor: pointer;
  transition: opacity 0.3s;
  color: inherit;
}
@media (any-hover: hover) {
  :where(.contents) button:hover {
    opacity: 0.7;
  }
}
:where(.contents) img {
  width: 100%;
  height: auto;
}
:where(.contents) .js-fadein {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1s cubic-bezier(0.33, 1, 0.68, 1) 0.1s, transform 1s cubic-bezier(0.33, 1, 0.68, 1) 0.1s;
}
:where(.contents) .js-fadein.is-show {
  opacity: 1;
  transform: translateY(0);
}

:where(.contents) .section {
  padding: min(7.2463768116vw, 80px) min(3.6231884058vw, 40px);
}
@media screen and (max-width: 767px) {
  :where(.contents) .section {
    padding: 13.3333333333vw 5.3333333333vw;
  }
}
:where(.contents) .section__inner {
  max-width: min(92.7536231884vw, 1024px);
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  :where(.contents) .section__inner {
    max-width: 100%;
  }
}
:where(.contents) .flex {
  display: flex;
  gap: var(--gap, min(3.6231884058vw, 40px));
}
@media screen and (max-width: 767px) {
  :where(.contents) .flex {
    gap: var(--sp-gap, 2.6666666667vw);
  }
}
@media screen and (max-width: 767px) {
  :where(.contents) .flex.sp-column {
    align-items: flex-start;
    flex-direction: column;
    gap: var(--sp-gap, 5.3333333333vw);
  }
}
:where(.contents) .flex.align-center {
  align-items: center;
}
:where(.contents) .flex > * {
  flex: var(--grow, 1) 0 var(--flex-basis, 0);
}
@media screen and (max-width: 767px) {
  :where(.contents) .flex > * {
    flex: var(--grow, 1) 0 var(--flex-basis, 0);
  }
}

@media screen and not (max-width: 767px) {
  :where(.contents) .is-sp {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  :where(.contents) .is-pc {
    display: none !important;
  }
}

#pageTopBtn {
  display: none !important;
}

.contents {
  overflow: hidden;
}
@keyframes shine {
  0% {
    scale: 0;
    opacity: 0;
  }
  80% {
    scale: 0;
    opacity: 0.5;
  }
  81% {
    scale: 4;
    opacity: 1;
  }
  100% {
    scale: 30;
    opacity: 0;
  }
}
.contents .text-blue {
  color: #7788a3;
}
.contents .text-light-blue {
  color: #6095cf;
}
.contents .heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 1.5em;
}
@media screen and (max-width: 767px) {
  .contents .heading {
    line-height: 1.2;
    margin-bottom: 0.7em;
  }
}
.contents .heading__jp {
  font-size: min(2.8985507246vw, 32px);
  font-weight: 600;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .contents .heading__jp {
    font-size: 6.4vw;
  }
}
.contents .heading__en {
  font-size: min(1.268115942vw, 14px);
  color: #b0b8bf;
  line-height: 2.5;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .contents .heading__en {
    font-size: 2.6666666667vw;
  }
}
.contents .note {
  font-size: min(1.0869565217vw, 0.75rem);
  color: #191616;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .contents .note {
    font-size: 2.1333333333vw;
    line-height: 4vw;
  }
}
.contents .note.indent1 {
  text-indent: -1em;
  padding-left: 1em;
}
.contents .note.indent2 {
  text-indent: -2em;
  padding-left: 2em;
}
.contents .card {
  position: relative;
  text-align: center;
  display: flex;
  flex-direction: column;
}
.contents .card__img {
  width: 100%;
  max-width: min(22.6449275362vw, 250px);
  margin-inline: auto;
  margin-bottom: min(1.8115942029vw, 20px);
  position: relative;
}
@media screen and (max-width: 767px) {
  .contents .card__img {
    max-width: 59.2vw;
    max-height: 65.2vw;
    margin-bottom: 1.3333333333vw;
  }
}
@media screen and (max-width: 767px) {
  .contents .card__img:has(.swiper) {
    max-height: unset;
    max-width: 73.3333333333vw;
    padding-bottom: 8vw;
  }
}
.contents .card__img__item {
  position: relative;
}
.contents .card__img__note {
  position: absolute;
  bottom: 2em;
  left: 62%;
}
@media screen and (max-width: 767px) {
  .contents .card__img__note {
    bottom: 0;
    left: 50%;
    translate: -50% 0;
    font-size: 3.6vw;
  }
}
.contents .card__img {
  --swiper-pagination-bottom: -4px;
  --swiper-pagination-color: #b0b8bf;
  --swiper-pagination-bullet-inactive-color: #b0b8bf;
  --swiper-pagination-bullet-inactive-opacity: 0.5;
}
@media screen and (max-width: 767px) {
  .contents .card__img {
    --swiper-pagination-bullet-horizontal-gap: 1.4666666667vw;
    --swiper-pagination-bullet-size: 2.4vw;
    --swiper-pagination-bottom: 0;
  }
}
.contents .card__img .swiper-button-prev,
.contents .card__img .swiper-button-next {
  --swiper-navigation-size: 30px;
  background: none;
}
.contents .card__img .swiper-button-prev::after,
.contents .card__img .swiper-button-next::after {
  content: "";
  width: min(1.3586956522vw, 15px);
  height: min(1.3586956522vw, 15px);
  border-right: min(0.0905797101vw, 1px) solid #b0b8bf;
  border-top: min(0.0905797101vw, 1px) solid #b0b8bf;
  rotate: 45deg;
}
@media screen and (max-width: 767px) {
  .contents .card__img .swiper-button-prev::after,
  .contents .card__img .swiper-button-next::after {
    width: 4vw;
    height: 4vw;
    border-width: 0.2666666667vw;
  }
}
.contents .card__img .swiper-button-prev {
  left: calc(-1 * min(0.9057971014vw, 10px));
}
@media screen and (max-width: 767px) {
  .contents .card__img .swiper-button-prev {
    left: -2.6666666667vw;
  }
}
.contents .card__img .swiper-button-prev::after {
  rotate: -135deg;
}
.contents .card__img .swiper-button-next {
  right: calc(-1 * min(0.9057971014vw, 10px));
}
@media screen and (max-width: 767px) {
  .contents .card__img .swiper-button-next {
    right: -2.6666666667vw;
  }
}
.contents .card__txt {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2em;
  order: -1;
}
.contents .card__txt__jp {
  font-size: min(2.1739130435vw, 24px);
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  .contents .card__txt__jp {
    font-size: 4.2666666667vw;
  }
}
.contents .card__txt__en {
  display: flex;
}
.contents .card__txt__en img {
  width: auto;
  height: min(0.9057971014vw, 10px);
}
@media screen and (max-width: 767px) {
  .contents .card__txt__en img {
    height: 2vw;
  }
}
.contents .card__txt__price {
  font-size: min(1.9927536232vw, 22px);
  font-weight: 500;
  margin-top: 0.75em;
}
@media screen and (max-width: 767px) {
  .contents .card__txt__price {
    font-size: 4.2666666667vw;
  }
}
.contents .card__txt__price .tax {
  font-size: 70%;
}
.contents .card__btn {
  width: min(24.5471014493vw, 271px);
  height: min(4.4239130435vw, 48.84px);
  background: #33669d;
  border-radius: min(2.2119565217vw, 24.42px);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: auto;
  margin-inline: auto;
  gap: 0.2em;
  font-size: min(1.4492753623vw, 16px);
  letter-spacing: 0.15em;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .contents .card__btn {
    width: 59.2vw;
    height: 10.6666666667vw;
    border-radius: 5.3333333333vw;
    font-size: 3.6vw;
    margin-top: 2.6666666667vw;
  }
}
.contents .card__btn::before {
  content: "";
  width: min(2.7173913043vw, 30px);
  height: 100%;
  background-color: #fff;
  animation: shine 6s ease-in-out infinite;
  position: absolute;
  top: calc(-1 * min(16.3043478261vw, 180px));
  left: 0;
  scale: 0;
  opacity: 0;
  rotate: 45deg;
  will-change: scale, opacity;
}
@media screen and (max-width: 767px) {
  .contents .card__btn::before {
    width: 6.6666666667vw;
    top: -40vw;
  }
}
.contents .card__btn::after {
  content: "";
  width: min(0.8152173913vw, 9px);
  height: min(0.8152173913vw, 9px);
  border-right: min(0.0905797101vw, 1px) solid #fff;
  border-top: min(0.0905797101vw, 1px) solid #fff;
  rotate: 45deg;
}
@media screen and (max-width: 767px) {
  .contents .card__btn::after {
    width: 2.1333333333vw;
    height: 2.1333333333vw;
    border-width: 0.2666666667vw;
  }
}
.contents .card.-lg {
  display: grid;
  grid-template-columns: auto min(47.1014492754vw, 520px);
  column-gap: min(6.7934782609vw, 75px);
  align-items: center;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .contents .card.-lg {
    display: flex;
    flex-direction: column;
  }
}
.contents .card.-lg .card__img {
  grid-row: 1/3;
  grid-column: 1;
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .contents .card.-lg .card__img {
    margin-top: 6.6666666667vw;
    width: 29.3333333333vw;
    max-width: unset;
    max-height: unset;
    margin-bottom: 0;
  }
}
.contents .card.-lg .card__txt {
  text-align: left;
  align-items: flex-start;
  gap: 0.2em;
  order: unset;
}
@media screen and (max-width: 767px) {
  .contents .card.-lg .card__txt {
    order: -1;
    align-items: center;
    gap: 0.4em;
  }
}
.contents .card.-lg .card__txt__jp {
  font-size: min(2.4456521739vw, 27px);
}
@media screen and (max-width: 767px) {
  .contents .card.-lg .card__txt__jp {
    font-size: 4.5333333333vw;
  }
}
.contents .card.-lg .card__txt__en img {
  height: min(1.0869565217vw, 12px);
}
@media screen and (max-width: 767px) {
  .contents .card.-lg .card__txt__en img {
    height: 2vw;
  }
}
.contents .card.-lg .card__btn {
  grid-row: 2;
  grid-column: 2;
  align-self: start;
  margin-top: 0;
  margin-left: 0;
}
@media screen and (max-width: 767px) {
  .contents .card.-lg .card__btn {
    margin-inline: auto;
    margin-top: 5.3333333333vw;
  }
}
.contents .solution-card__problem {
  text-align: center;
  margin-bottom: min(2.1739130435vw, 24px);
}
@media screen and (max-width: 767px) {
  .contents .solution-card__problem {
    margin-bottom: 4.6666666667vw;
  }
}
.contents .solution-card__problem__tag {
  width: min(14.4927536232vw, 160px);
  height: min(3.4420289855vw, 38px);
  display: inline-grid;
  place-content: center;
  background: #8794a8;
  color: #fff;
  font-size: min(1.4492753623vw, 16px);
  font-weight: 500;
  margin-bottom: 0.75em;
}
@media screen and (max-width: 767px) {
  .contents .solution-card__problem__tag {
    width: 24.1333333333vw;
    height: 7.7333333333vw;
    font-size: 3.6vw;
    margin-bottom: 0.3em;
  }
}
.contents .solution-card__problem__txt {
  font-size: min(1.9927536232vw, 22px);
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .contents .solution-card__problem__txt {
    font-size: 3.6vw;
  }
}
.contents .solution-card__problem__txt span {
  font-weight: 600;
}
.contents .solution-card__solution {
  position: relative;
  padding-top: min(3.1702898551vw, 35px);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .contents .solution-card__solution {
    padding-top: 6.6666666667vw;
  }
}
.contents .solution-card__solution::before {
  content: "";
  width: min(2.4121376812vw, 26.63px);
  height: min(1.285326087vw, 14.19px);
  clip-path: polygon(50% 100%, 0 0, 100% 0);
  background: #8794a8;
  opacity: 0.3;
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% 0;
}
@media screen and (max-width: 767px) {
  .contents .solution-card__solution::before {
    width: 4.7253333333vw;
    height: 2.5213333333vw;
  }
}
.contents .solution-card__solution__tag {
  width: min(10.8695652174vw, 120px);
  height: min(3.4420289855vw, 38px);
  display: inline-grid;
  place-content: center;
  border: min(0.0905797101vw, 1px) solid #6095cf;
  background: #fff;
  color: #6095cf;
  font-size: min(1.4492753623vw, 16px);
  font-weight: 500;
  margin-bottom: 0.75em;
}
@media screen and (max-width: 767px) {
  .contents .solution-card__solution__tag {
    width: 24.1333333333vw;
    height: 7.7333333333vw;
    font-size: 3.6vw;
    margin-bottom: 0.3em;
    border-width: 0.2666666667vw;
  }
}
.contents .solution-card__solution__txt {
  font-size: min(1.9927536232vw, 22px);
  line-height: min(3.3514492754vw, 37px);
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .contents .solution-card__solution__txt {
    font-size: 4.2666666667vw;
    line-height: 7.4666666667vw;
  }
}
.contents .solution-card__solution__contents {
  margin-top: min(2.7173913043vw, 30px);
  display: grid;
  grid-template-columns: min(44.5652173913vw, 492px) 1fr;
  column-gap: min(3.6231884058vw, 40px);
}
@media screen and (max-width: 767px) {
  .contents .solution-card__solution__contents {
    margin-top: 4vw;
    grid-template-columns: 1fr;
    gap: 4vw;
  }
}
.contents .solution-card__solution__contents__body {
  text-align: left;
}
.contents .solution-card__solution__contents__txt {
  font-size: min(1.4492753623vw, 16px);
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .contents .solution-card__solution__contents__txt {
    font-size: 3.4666666667vw;
  }
}
.contents .solution-card__solution__contents__note {
  margin-top: 1.2em;
}
.contents .floating-btn {
  position: fixed;
  bottom: 0;
  left: 50%;
  z-index: 100;
  padding-bottom: min(1.8115942029vw, 20px);
  translate: -50% 0;
}
@media screen and (max-width: 767px) {
  .contents .floating-btn {
    width: 100%;
    padding-bottom: 0;
  }
}
.contents .floating-btn a {
  background: #33669d;
  width: min(30.1630434783vw, 333px);
  height: min(5.4347826087vw, 60px);
  gap: 0.2em;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: min(2.7173913043vw, 30px);
  font-size: min(1.7826086957vw, 19.68px);
  letter-spacing: 0.1em;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .contents .floating-btn a {
    width: 100%;
    height: 13.3333333333vw;
    border-radius: 0;
    font-size: 4.5333333333vw;
  }
}
.contents .floating-btn a::before {
  content: "";
  width: min(2.7173913043vw, 30px);
  height: 100%;
  background-color: #fff;
  animation: shine 6s ease-in-out infinite;
  position: absolute;
  top: calc(-1 * min(16.3043478261vw, 180px));
  left: 0;
  scale: 0;
  opacity: 0;
  rotate: 45deg;
  will-change: scale, opacity;
}
@media screen and (max-width: 767px) {
  .contents .floating-btn a::before {
    width: 6.6666666667vw;
    top: -40vw;
  }
}
.contents .floating-btn a::after {
  content: "";
  width: min(0.9963768116vw, 11px);
  height: min(0.9963768116vw, 11px);
  border-right: min(0.0905797101vw, 1px) solid #fff;
  border-top: min(0.0905797101vw, 1px) solid #fff;
  rotate: 45deg;
  position: relative;
  top: 0.05em;
}
@media screen and (max-width: 767px) {
  .contents .floating-btn a::after {
    width: 2.8626666667vw;
    height: 2.8626666667vw;
    border-width: 0.2666666667vw;
  }
}
.contents .floating-btn.is-hide {
  translate: -50% 100%;
}
.contents .kv {
  background: url(../img/bg-kv.jpg) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .contents .kv {
    background: url(../img/bg-kv-sp.jpg) no-repeat center/cover;
    padding-bottom: 6.4vw;
  }
}
.contents .kv__inner {
  max-width: min(100vw, 1104px);
  height: min(45.2898550725vw, 500px);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr min(49.0942028986vw, 542px);
  align-items: center;
}
@media screen and (max-width: 767px) {
  .contents .kv__inner {
    max-width: 100%;
    height: auto;
    grid-template-columns: 1fr;
    gap: 8vw;
  }
}
.contents .kv__copy {
  padding-left: min(3.6231884058vw, 40px);
}
@media screen and (max-width: 767px) {
  .contents .kv__copy {
    padding-left: 0;
    padding-top: 9.3333333333vw;
  }
}
.contents .kv__copy__main {
  display: block;
  width: min(43.6594202899vw, 482px);
}
@media screen and (max-width: 767px) {
  .contents .kv__copy__main {
    width: 82.1333333333vw;
    margin-inline: auto;
    padding-left: 0;
  }
}
.contents .kv__copy__sub {
  display: block;
  font-size: min(2.0833333333vw, 23px);
  background: linear-gradient(90deg, #6095cf, #99acc2);
  color: #fff;
  padding: 0.5em 1em;
  margin-top: 1.5em;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .contents .kv__copy__sub {
    font-size: 4.2666666667vw;
    margin-left: 5.3333333333vw;
    padding: 0.2em 0.75em;
    margin-top: 1.25em;
  }
}
.contents .kv__img {
  position: relative;
  box-shadow: 0 0 min(0.9057971014vw, 10px) rgba(94, 96, 102, 0.2);
  margin-top: min(5.4347826087vw, 60px);
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .contents .kv__img {
    margin: 0 5.3333333333vw 0 0;
    box-shadow: 0 0 4vw rgba(94, 96, 102, 0.3);
  }
}
.contents .kv__img::after {
  content: "";
  width: min(46.3768115942vw, 512px);
  height: min(33.3333333333vw, 368px);
  position: absolute;
  background: #e6e6e6;
  top: min(3.6231884058vw, 40px);
  right: calc(-1 * min(2.7173913043vw, 30px));
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .contents .kv__img::after {
    width: 94.6666666667vw;
    height: 55.8666666667vw;
    top: 50%;
    right: -5.3333333333vw;
    translate: 0 -50%;
  }
}
.contents .intro {
  padding-top: min(8.152173913vw, 90px);
  padding-bottom: min(7.2463768116vw, 80px);
}
@media screen and (max-width: 767px) {
  .contents .intro {
    padding-top: 9.3333333333vw;
    padding-bottom: 9.3333333333vw;
  }
}
.contents .intro__heading {
  text-align: center;
}
.contents .intro__heading__sub {
  font-size: min(1.7210144928vw, 19px);
  display: block;
  margin-bottom: 0.75em;
}
@media screen and (max-width: 767px) {
  .contents .intro__heading__sub {
    font-size: 3.7333333333vw;
    margin-bottom: 0.6em;
  }
}
.contents .intro__heading__sub::after {
  content: "";
  width: min(38.768115942vw, 428px);
  height: min(1.268115942vw, 14px);
  background: url(../img/im-balloon.jpg) no-repeat center/contain;
  display: block;
  margin-top: min(0.4528985507vw, 5px);
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .contents .intro__heading__sub::after {
    width: 89.3333333333vw;
    height: 2.9333333333vw;
    margin-top: 1.3333333333vw;
  }
}
.contents .intro__heading__main {
  display: block;
  font-size: min(2.8985507246vw, 32px);
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  .contents .intro__heading__main {
    font-size: 6.4vw;
    line-height: 1.6;
  }
}
.contents .intro__note {
  text-align: center;
  margin-top: 0.5em;
}
@media screen and (max-width: 767px) {
  .contents .intro__note {
    margin-top: 1em;
  }
}
.contents .intro__contents {
  margin-top: min(5.4347826087vw, 60px);
  display: grid;
  grid-template-columns: min(38.0434782609vw, 420px) 1fr;
  gap: min(4.5289855072vw, 50px);
}
@media screen and (max-width: 767px) {
  .contents .intro__contents {
    grid-template-columns: 1fr;
    gap: 0;
  }
}
.contents .intro__contents__body {
  margin-top: min(1.8115942029vw, 20px);
}
@media screen and (max-width: 767px) {
  .contents .intro__contents__body {
    display: flex;
    flex-direction: column-reverse;
    margin-top: 0;
  }
}
.contents .intro__contents__txt {
  font-size: min(1.4492753623vw, 1rem);
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .contents .intro__contents__txt {
    font-size: 3.4666666667vw;
    margin-top: 1.5em;
  }
}
.contents .intro__contents__notes {
  margin-top: 1em;
  display: grid;
  gap: 0.1m;
}
@media screen and (max-width: 767px) {
  .contents .intro__contents__notes {
    gap: 0;
  }
}
.contents .insight {
  background: #f4f7f9;
  padding-top: min(9.9637681159vw, 110px);
  padding-bottom: min(7.2463768116vw, 80px);
  position: relative;
}
@media screen and (max-width: 767px) {
  .contents .insight {
    padding-top: 17.3333333333vw;
    padding-bottom: 9.3333333333vw;
  }
}
.contents .insight::before {
  content: "";
  width: min(24.0942028986vw, 266px);
  height: min(5.4347826087vw, 60px);
  background: #fff;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
  position: absolute;
  top: -1px;
  left: 50%;
  translate: -50% 0;
}
@media screen and (max-width: 767px) {
  .contents .insight::before {
    width: 35.4666666667vw;
    height: 8vw;
  }
}
.contents .insight__inner {
  max-width: min(85.5072463768vw, 944px);
  display: grid;
  grid-template-columns: 50% 1fr;
}
@media screen and (max-width: 767px) {
  .contents .insight__inner {
    max-width: 100%;
    grid-template-columns: 1fr;
  }
}
.contents .insight__heading {
  text-align: center;
  font-weight: 600;
  --letter-spacing: 0.1em;
  line-height: 1.45;
  font-family: "Geom", "Noto Sans JP", sans-serif;
}
@media screen and (max-width: 767px) {
  .contents .insight__heading {
    line-height: 1.4;
  }
}
.contents .insight__heading__line1 {
  font-size: min(3.768115942vw, 41.6px);
}
@media screen and (max-width: 767px) {
  .contents .insight__heading__line1 {
    font-size: 6.4vw;
  }
}
.contents .insight__heading__line1 .num {
  font-size: 125%;
}
.contents .insight__heading__line1 sup {
  font-size: 45%;
  top: -1.3em;
  left: -0.3em;
}
.contents .insight__heading__line2 {
  font-size: min(2.7536231884vw, 30.4px);
}
@media screen and (max-width: 767px) {
  .contents .insight__heading__line2 {
    font-size: 4.6933333333vw;
  }
}
.contents .insight__heading__line2 strong {
  font-size: 125%;
}
.contents .insight__notes {
  grid-column: 1;
  grid-row: 2;
  width: min(37.3188405797vw, 412px);
  margin-top: 1.75em;
  margin-inline: auto;
  font-feature-settings: "palt" 0;
}
@media screen and (max-width: 767px) {
  .contents .insight__notes {
    width: 100%;
    grid-row: 3;
    grid-column: 1;
    margin-top: 6.6666666667vw;
  }
}
.contents .insight__chart {
  grid-row: span 2;
  width: min(30.7971014493vw, 340px);
  margin-left: min(9.2391304348vw, 102px);
  margin-right: min(6.3405797101vw, 70px);
}
@media screen and (max-width: 767px) {
  .contents .insight__chart {
    width: 53.3333333333vw;
    margin-inline: auto;
    grid-row: 2;
    grid-column: 1;
    margin-top: 6.6666666667vw;
  }
}
.contents .chart {
  position: relative;
  aspect-ratio: 1/1;
  display: grid;
  place-content: center;
}
.contents .chart__donut {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
}
.contents .chart__text {
  z-index: 2;
  text-align: center;
  margin-bottom: 0.3em;
}
.contents .chart__text__label {
  font-size: min(2.0833333333vw, 23px);
  font-weight: 500;
  line-height: 1.23;
  display: grid;
  place-content: center;
  color: #558ec5;
}
@media screen and (max-width: 767px) {
  .contents .chart__text__label {
    font-size: 3.7333333333vw;
  }
}
.contents .chart__text__num {
  font-size: min(8.152173913vw, 5.625rem);
  line-height: 1;
  font-weight: 700;
  color: #558ec5;
  --letter-spacing: 0;
  font-family: "Geom", sans-serif;
  position: relative;
  left: 0.1em;
}
@media screen and (max-width: 767px) {
  .contents .chart__text__num {
    font-size: 14.6666666667vw;
  }
}
.contents .chart__text__num .percent {
  font-size: 40%;
}
.contents .award {
  padding-top: min(6.3405797101vw, 70px);
  border-bottom: min(0.1811594203vw, 2px) solid #f4f7f9;
}
@media screen and (max-width: 767px) {
  .contents .award {
    padding-top: 13.3333333333vw;
    border-width: 0.2666666667vw;
  }
}
.contents .award__lead {
  text-align: center;
  font-size: min(1.4492753623vw, 16px);
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .contents .award__lead {
    font-size: 3.4666666667vw;
  }
}
.contents .award__contents {
  margin-top: min(2.7173913043vw, 30px);
  display: grid;
  grid-template-columns: min(52.5362318841vw, 580px) 1fr;
}
@media screen and (max-width: 767px) {
  .contents .award__contents {
    margin-top: 6.6666666667vw;
    grid-template-columns: 1fr;
    gap: 10.6666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .contents .award__contents__img {
    margin-left: -5.3333333333vw;
    margin-right: -5.3333333333vw;
  }
}
.contents .award__contents__embrem {
  display: grid;
  place-content: center;
}
.contents .award__contents__embrem img {
  width: min(22.7355072464vw, 251px);
}
@media screen and (max-width: 767px) {
  .contents .award__contents__embrem img {
    width: 46.9333333333vw;
  }
}
.contents .award__notes {
  margin-top: 1.5em;
}
@media screen and (max-width: 767px) {
  .contents .award__notes {
    margin-top: 10.6666666667vw;
  }
}
.contents .cta {
  padding-top: min(7.2463768116vw, 80px);
  padding-bottom: min(6.3405797101vw, 70px);
  background: #fbfcfd;
}
@media screen and (max-width: 767px) {
  .contents .cta {
    padding-top: 13.3333333333vw;
    padding-bottom: 16vw;
  }
}
.contents .cta.-no-bg {
  background: transparent;
}
.contents .cta__inner {
  max-width: min(66.2137681159vw, 731px);
}
@media screen and (max-width: 767px) {
  .contents .cta__inner {
    max-width: 100%;
  }
}
.contents .problem {
  padding-top: min(7.2463768116vw, 80px);
  border-top: min(0.1811594203vw, 2px) solid #f4f7f9;
}
@media screen and (max-width: 767px) {
  .contents .problem {
    border-width: 0.2666666667vw;
    padding-top: 14vw;
    padding-bottom: 18.6666666667vw;
  }
}
.contents .problem__heading {
  text-align: center;
  font-size: min(2.8985507246vw, 32px);
  font-weight: 600;
  letter-spacing: 0.1em;
  margin-bottom: 1em;
}
@media screen and (max-width: 767px) {
  .contents .problem__heading {
    font-size: 6.4vw;
    line-height: 1.5;
  }
}
.contents .problem__contents {
  position: relative;
  width: fit-content;
  margin-inline: auto;
}
.contents .problem__contents__img {
  width: min(35.0652173913vw, 387.12px);
}
@media screen and (max-width: 767px) {
  .contents .problem__contents__img {
    width: 45.4186666667vw;
  }
}
.contents .problem__item {
  position: absolute;
  width: max-content;
  font-size: min(1.9927536232vw, 22px);
  line-height: min(3.3514492754vw, 37px);
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .contents .problem__item {
    font-size: 3.6vw;
    line-height: 5.7333333333vw;
  }
}
.contents .problem__item__heading {
  display: block;
  width: fit-content;
  font-size: min(2.1739130435vw, 24px);
  line-height: min(2.7173913043vw, 30px);
  font-weight: 600;
  padding-bottom: 0.1em;
  margin-bottom: 0.5em;
  border-bottom: min(0.1811594203vw, 2px) solid #8794a8;
}
@media screen and (max-width: 767px) {
  .contents .problem__item__heading {
    font-size: 3.6vw;
    line-height: 4vw;
    border-width: 0.2666666667vw;
  }
}
.contents .problem__item.-item1 {
  top: min(3.6231884058vw, 40px);
  left: calc(-1 * min(9.3297101449vw, 103px));
}
@media screen and (max-width: 767px) {
  .contents .problem__item.-item1 {
    top: 1.0666666667vw;
    left: -22.2666666667vw;
  }
}
.contents .problem__item.-item2 {
  top: 50%;
  left: min(32.1557971014vw, 355px);
  translate: 0 -50%;
}
@media screen and (max-width: 767px) {
  .contents .problem__item.-item2 {
    left: 42.6666666667vw;
  }
}
.contents .problem__item.-item3 {
  bottom: min(4.2572463768vw, 47px);
  right: min(32.6992753623vw, 361px);
}
@media screen and (max-width: 767px) {
  .contents .problem__item.-item3 {
    bottom: -10.6666666667vw;
    right: 24.4vw;
  }
}
.contents .solution {
  background: #f4f7f9;
  padding-top: min(11.7753623188vw, 130px);
  padding-bottom: min(7.2463768116vw, 80px);
  position: relative;
}
@media screen and (max-width: 767px) {
  .contents .solution {
    padding-top: 17.3333333333vw;
    padding-bottom: 13.3333333333vw;
  }
}
.contents .solution::before {
  content: "";
  width: min(24.0942028986vw, 266px);
  height: min(5.4347826087vw, 60px);
  background: #fff;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
  position: absolute;
  top: -1px;
  left: 50%;
  translate: -50% 0;
}
@media screen and (max-width: 767px) {
  .contents .solution::before {
    width: 35.4666666667vw;
    height: 8vw;
  }
}
.contents .solution__heading {
  text-align: center;
  font-size: min(2.3188405797vw, 25.6px);
  letter-spacing: 0.1em;
  font-weight: 600;
  margin-bottom: 1em;
}
@media screen and (max-width: 767px) {
  .contents .solution__heading {
    font-size: 4.5333333333vw;
  }
}
.contents .solution__heading strong {
  font-size: 125%;
}
.contents .solution__problems {
  max-width: min(61.5036231884vw, 679px);
  margin-inline: auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  column-gap: min(1.8115942029vw, 20px);
}
@media screen and (max-width: 767px) {
  .contents .solution__problems {
    max-width: 100%;
    column-gap: 2.1333333333vw;
  }
}
.contents .solution__problems__item {
  text-align: center;
  border: min(0.0905797101vw, 1px) solid #898989;
  background: #fff;
  font-size: min(1.4492753623vw, 16px);
  line-height: min(2.7173913043vw, 30px);
  font-weight: 500;
  min-height: min(19.9275362319vw, 220px);
  --letter-spacing: 0.02em;
}
@media screen and (max-width: 767px) {
  .contents .solution__problems__item {
    font-size: 2.9333333333vw;
    line-height: 4.8vw;
    min-height: 38.1333333333vw;
    border-width: 0.1333333333vw;
  }
}
.contents .solution__problems__item__heading {
  font-size: min(1.8115942029vw, 20px);
  line-height: 1.5;
  font-weight: 600;
  display: block;
  width: fit-content;
  margin-inline: auto;
  padding-bottom: 0.1em;
  margin-bottom: 0.5em;
  border-bottom: min(0.1811594203vw, 2px) solid #8794a8;
  --letter-spacing: 0.08em;
}
@media screen and (max-width: 767px) {
  .contents .solution__problems__item__heading {
    font-size: 3.6vw;
  }
}
.contents .solution__problems__item a {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: min(2.0833333333vw, 23px);
}
@media screen and (max-width: 767px) {
  .contents .solution__problems__item a {
    padding: 2.6666666667vw 1.3333333333vw;
  }
}
.contents .solution__problems__item a::after {
  content: "";
  width: min(1.9927536232vw, 22px);
  height: min(1.9927536232vw, 22px);
  background: url(../img/ic-arrow-bottom.png) no-repeat center/contain;
  display: block;
  margin-top: auto;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .contents .solution__problems__item a::after {
    padding-top: 4vw;
    width: 4.5333333333vw;
    height: 4.5333333333vw;
  }
}
.contents .solution__list {
  margin-top: min(5.4347826087vw, 60px);
  display: grid;
  gap: min(7.2463768116vw, 80px);
}
@media screen and (max-width: 767px) {
  .contents .solution__list {
    margin-top: 11.4666666667vw;
    gap: 14.6666666667vw;
  }
}
.contents .solution__interview {
  margin-top: min(7.2463768116vw, 80px);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .contents .solution__interview {
    margin-top: 13.3333333333vw;
  }
}
.contents .solution__interview__heading {
  font-size: min(2.1739130435vw, 24px);
  font-weight: 500;
  margin-bottom: 1em;
}
@media screen and (max-width: 767px) {
  .contents .solution__interview__heading {
    font-size: 4.2666666667vw;
  }
}
.contents .solution__interview__movie {
  width: min(28.9855072464vw, 320px);
  aspect-ratio: 9/16;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .contents .solution__interview__movie {
    width: 64vw;
  }
}
.contents .solution__interview__movie fw-storyblock {
  height: 100% !important;
}
.contents .solution__interview__movie fw-storyblock > div {
  height: 100% !important;
}
.contents .evidence {
  margin-top: min(3.6231884058vw, 40px);
  background: #fff;
  padding: min(6.3405797101vw, 70px) min(5.4347826087vw, 60px) min(5.4347826087vw, 60px);
  display: none;
}
@media screen and (max-width: 767px) {
  .contents .evidence {
    margin-top: 8vw;
    padding: 10.6666666667vw 5.3333333333vw;
  }
}
.contents .evidence__heading {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 2.5em;
}
@media screen and (max-width: 767px) {
  .contents .evidence__heading {
    margin-bottom: 1.5em;
  }
}
.contents .evidence__heading__en {
  display: flex;
}
.contents .evidence__heading__en img {
  width: auto;
  height: min(0.9963768116vw, 11px);
}
@media screen and (max-width: 767px) {
  .contents .evidence__heading__en img {
    height: 2vw;
  }
}
.contents .evidence__heading__jp {
  font-size: min(1.9927536232vw, 22px);
  line-height: 1;
  color: #8794a8;
  font-weight: 600;
  border-left: min(0.1811594203vw, 2px) solid #8794a8;
  padding-left: 0.75em;
  margin-left: 0.75em;
}
@media screen and (max-width: 767px) {
  .contents .evidence__heading__jp {
    font-size: 3.6vw;
    border-width: 0.2666666667vw;
  }
}
.contents .evidence__list {
  display: grid;
  gap: min(3.6231884058vw, 40px);
}
@media screen and (max-width: 767px) {
  .contents .evidence__list {
    gap: 8vw;
  }
}
.contents .evidence__item__heading {
  text-align: center;
  font-size: min(1.9927536232vw, 22px);
  font-weight: 500;
  margin-bottom: 0.75em;
}
@media screen and (max-width: 767px) {
  .contents .evidence__item__heading {
    font-size: 4.2666666667vw;
  }
}
.contents .evidence__item__contents {
  display: grid;
  grid-template-columns: min(39.1304347826vw, 432px) 1fr;
  gap: min(3.6231884058vw, 40px);
}
@media screen and (max-width: 767px) {
  .contents .evidence__item__contents {
    grid-template-columns: 1fr;
    gap: 2.6666666667vw;
  }
}
.contents .evidence__item__body {
  font-size: min(1.4492753623vw, 16px);
}
@media screen and (max-width: 767px) {
  .contents .evidence__item__body {
    font-size: 2.9333333333vw;
  }
}
.contents .evidence__notes {
  margin-top: 1.5em;
}
.contents .evidence__open, .contents .evidence__close {
  width: min(18.0253623188vw, 199px);
  height: min(4.0760869565vw, 45px);
  margin-inline: auto;
  display: block;
  border: min(0.0905797101vw, 1px) solid #191616;
  border-radius: min(2.2644927536vw, 25px);
  position: relative;
  background: #fff;
  font-size: min(1.4492753623vw, 16px);
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px) {
  .contents .evidence__open, .contents .evidence__close {
    width: 36.5333333333vw;
    height: 8.2666666667vw;
    border-width: 0.2666666667vw;
    border-radius: 4.1333333333vw;
  }
}
.contents .evidence__open::before, .contents .evidence__open::after, .contents .evidence__close::before, .contents .evidence__close::after {
  content: "";
  width: min(0.9963768116vw, 11px);
  height: min(0.0905797101vw, 1px);
  background: #191616;
  position: absolute;
  top: 50%;
  right: min(1.5398550725vw, 17px);
}
@media screen and (max-width: 767px) {
  .contents .evidence__open::before, .contents .evidence__open::after, .contents .evidence__close::before, .contents .evidence__close::after {
    width: 2.6666666667vw;
    height: 0.2666666667vw;
    right: 4vw;
  }
}
.contents .evidence__open::before, .contents .evidence__close::before {
  rotate: -45deg;
}
.contents .evidence__open::after, .contents .evidence__close::after {
  rotate: 45deg;
}
.contents .evidence__close {
  margin-top: min(4.5289855072vw, 50px);
}
@media screen and (max-width: 767px) {
  .contents .evidence__close {
    margin-top: 9.3333333333vw;
    font-size: 2.9333333333vw;
  }
}
.contents .evidence__open {
  margin-top: min(3.6231884058vw, 40px);
  width: min(30.3442028986vw, 335px);
  height: min(4.5289855072vw, 50px);
  border-radius: min(2.2644927536vw, 25px);
}
@media screen and (max-width: 767px) {
  .contents .evidence__open {
    margin-top: 5.3333333333vw;
    width: 53.8666666667vw;
    height: 11.4666666667vw;
    border-radius: 5.7333333333vw;
    font-size: 3.4666666667vw;
  }
}
.contents .evidence__open::before {
  rotate: 0deg;
}
.contents .evidence__open::after {
  rotate: 90deg;
}
.contents .related {
  padding-top: 0;
}
@media screen and (max-width: 767px) {
  .contents .related {
    padding-top: 13.3333333333vw;
  }
}
.contents .related__heading {
  width: 100%;
  background: #f4f7f9;
  height: min(19.4746376812vw, 215px);
  justify-content: center;
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .contents .related__heading {
    height: 38.6666666667vw;
  }
}
.contents .related__heading .heading__jp {
  font-size: min(2.3550724638vw, 26px);
  line-height: min(3.9855072464vw, 44px);
}
@media screen and (max-width: 767px) {
  .contents .related__heading .heading__jp {
    font-size: 4.2666666667vw;
    line-height: 7.4666666667vw;
  }
}
.contents .related__cols {
  background: #f4f7f9;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(5, auto);
  gap: min(0.5434782609vw, 6px);
  border: min(0.5434782609vw, 6px) solid #f4f7f9;
  border-top: 0;
}
@media screen and (max-width: 767px) {
  .contents .related__cols {
    grid-template-columns: 1fr;
    grid-template-rows: unset;
    gap: 0;
    border-width: 0.6666666667vw;
  }
}
.contents .related__col {
  background: #fff;
  padding: min(5.4347826087vw, 60px) min(3.6231884058vw, 40px);
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 5;
}
@media screen and (max-width: 767px) {
  .contents .related__col {
    padding: 8vw 5.3333333333vw;
  }
}
@media screen and (max-width: 767px) {
  .contents .related__col:not(:last-child) {
    border-bottom: 0.2666666667vw solid #f4f7f9;
  }
}
.contents .related__col__lead {
  text-align: center;
  margin-top: 2.75em;
  font-weight: 500;
  font-size: min(1.5398550725vw, 17px);
}
@media screen and (max-width: 767px) {
  .contents .related__col__lead {
    margin-top: 2em;
    --letter-spacing: 0.02em;
    font-size: 3.4666666667vw;
  }
}
.contents .related__col__img {
  margin-top: 1em;
}
.contents .related__col__body {
  margin-top: 0.5em;
}
@media screen and (max-width: 767px) {
  .contents .related__col__body {
    margin-top: 1em;
  }
}
.contents .related__col__txt {
  font-size: min(1.4492753623vw, 16px);
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .contents .related__col__txt {
    font-size: 2.9333333333vw;
    line-height: 4.8vw;
  }
}
.contents .related__col__note {
  margin-top: 0.5em;
}