@charset "utf-8";
.page-fv {
  width: 100%;
  position: relative;
  overflow: hidden;
  z-index: 3;
}

.page-fv::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background: rgba(57, 8, 129, 0.29);
  pointer-events: none;
  z-index: 4;
}

.page-fv__bg-logo {
  pointer-events: none;
  position: absolute;
  z-index: 2;
  width: 100%;
  height: 100%;
  bottom: 0;
  left: 0;
}

.page-fv__bg-logo img {
  aspect-ratio: 579 / 164;
  object-fit: cover;
  width: 100%;
  position: relative;
  top: 38%;
  transform: translateY(-50%);
}

@media screen and (min-width: 768px) {
  .page-fv__bg-logo img {
    top: 58%;
  }
}

.page-fv__bg-image {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.page-fv__bg-image img {
  aspect-ratio: 1366/440;
  object-fit: cover;
  width: 100%;
  height: 100%;
  pointer-events: auto;
}

.page-fv__inner {
  position: relative;
  padding-top: 213px;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.page-fv__heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-family: var(--ff-space);
  font-size: 58px;
  letter-spacing: 0.01em;
  line-height: 58px;
  color: var(--white-color);
  padding-bottom: 8px;
  position: relative;
  pointer-events: auto;
}

.page-fv__heading:after {
  position: absolute;
  content: "";
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 72px;
  height: 4px;
  background: var(--white-color);
}

.page-fv__heading-ja {
  text-align: center;
  display: block;
  margin-top: 18px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 20px;
  color: var(--white-color);
}

.page-fv__box {
  display: block;
  margin-inline: auto 0;
  margin-top: 123px;
  background: #efeffa;
  padding: 30px 20px;
  width: 79%;
}

@media screen and (min-width: 768px) {
  .page-fv__box {
    padding: 30px 40px;
  }
}

.page-top__breadcrumbs {
  pointer-events: auto;
  display: flex;
  align-items: center;
  gap: 16px;
}

.page-top__breadcrumbs-link {
  display: block;
}

.page-top__breadcrumbs-link-text,
.page-top__breadcrumbs-arrow,
.page-top__breadcrumbs-page {
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.06em;
  line-height: 20px;
  color: #58428b;
}

/* --------------------
メイン
---------------------- */
.page {
  padding-top: 60px;
  padding-bottom: 80px;
}

@media screen and (min-width: 768px) {
  .page {
    padding-top: 60px;
    padding-bottom: 180px;
  }
}

.page__heading-wrapper {
  max-width: 1182px;
  margin-inline: auto;
  text-align: left;
}

.page__heading {
  font-size: 26px;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 37px;
  color: var(--sub-color);
}

.page__heading-text {
  margin-top: 30px;
  letter-spacing: 0.06em;
  line-height: 2.2;
}

@media screen and (min-width: 768px) {
  .page__heading-text {
    letter-spacing: 0.08em;
  }
}
