@charset "UTF-8";
/* コンテンツ最大幅 */
/* color */
/* ============================================ */
/* font-size */
/* ============================================ */
/* font-family */
/* ============================================ */
/* second */
/* ============================================ */
.second-main {
  padding: 144px 0 64px;
  position: relative;
}
@media all and (max-width: 896px) {
  .second-main {
    padding: 84px 0 52px;
  }
}
.second-main::before {
  content: "";
  display: block;
  width: 66%;
  height: 100%;
  background: url("../images/second/main_bg.png") bottom right/cover no-repeat;
  position: absolute;
  top: 0;
  right: 0;
}
.second-main__figure {
  width: 80%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  filter: drop-shadow(8px 8px 12px rgba(29, 32, 136, 0.1)) drop-shadow(4px 4px 8px rgba(29, 32, 136, 0.2));
}
@media all and (max-width: 896px) {
  .second-main__figure {
    width: 90%;
    filter: drop-shadow(6px 6px 12px rgba(29, 32, 136, 0.1)) drop-shadow(2px 2px 4px rgba(29, 32, 136, 0.2));
  }
}
.second-main__figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: right bottom;
     object-position: right bottom;
}
.second-main__wrapper {
  width: calc(100% - 18.75vw);
  margin-inline: auto;
  position: relative;
  z-index: 10;
}
@media all and (max-width: 1600px) {
  .second-main__wrapper {
    width: calc(100% - 64px);
  }
}
@media all and (max-width: 896px) {
  .second-main__wrapper {
    width: calc(100% - 30px);
  }
}
.second-main__breadcrumb {
  font-size: clamp(0.75rem, 0.6709rem + 0.3376vw, 1rem);
  font-weight: 500;
  display: flex;
  flex-wrap: wrap;
  gap: 12px 3em;
}
.second-main__breadcrumb > li {
  position: relative;
}
.second-main__breadcrumb > li::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1px;
  background: #333333;
  position: absolute;
  top: 50%;
  left: -2em;
  translate: 0 -50%;
}
.second-main__breadcrumb > li a {
  color: #1D2088;
  text-decoration: underline;
  text-underline-offset: 0.2em;
}
.second-main__breadcrumb > li:first-of-type::before {
  content: none;
}
.second-main__en {
  font-size: clamp(2.8125rem, 1.2302rem + 6.7511vw, 7.8125rem);
  font-weight: 500;
  line-height: 1.2;
  margin-top: 48px;
}
@media all and (max-width: 896px) {
  .second-main__en {
    margin-top: 24px;
  }
}
.second-main__ttl {
  font-size: clamp(0.9375rem, 0.6804rem + 1.097vw, 1.75rem);
  font-weight: 500;
  color: #1D2088;
  margin-top: 16px;
}
@media all and (max-width: 896px) {
  .second-main__ttl {
    margin-top: 12px;
  }
}

.second-ttl {
  word-break: keep-all;
  font-size: clamp(1.375rem, 1.2293rem + 0.6218vw, 1.75rem);
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.05em;
  color: #1D2088;
}
.second-ttl.--center {
  text-align: center;
}
.second-ttl.--center .ttl_circle {
  justify-content: center;
}
.second-ttl.--white {
  color: #fff;
}
.second-ttl.--white .ttl_circle > span {
  background: #fff;
}
.second-ttl.--white .ttl_circle::before, .second-ttl.--white .ttl_circle::after {
  background: #fff;
}
.second-ttl .ttl_jp {
  display: block;
}
.second-ttl .ttl_circle {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 20px;
}
@media all and (max-width: 896px) {
  .second-ttl .ttl_circle {
    gap: 6px;
    margin-top: 16px;
  }
}
.second-ttl .ttl_circle > span {
  display: inline-block;
  width: 8px;
  height: 8px;
  background: #7779B8;
  border-radius: 50%;
}
@media all and (max-width: 896px) {
  .second-ttl .ttl_circle > span {
    width: 6px;
    height: 6px;
  }
}
.second-ttl .ttl_circle::before, .second-ttl .ttl_circle::after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  background: #1D2088;
  border-radius: 50%;
}
@media all and (max-width: 896px) {
  .second-ttl .ttl_circle::before, .second-ttl .ttl_circle::after {
    width: 6px;
    height: 6px;
  }
}
.second-ttl .ttl_circle::after {
  background: #BCBDDC;
}

.third-ttl {
  font-size: clamp(1.0625rem, 0.9896rem + 0.3109vw, 1.25rem);
  font-weight: 700;
  color: #7779B8;
  padding-left: 1em;
  position: relative;
}
.third-ttl::before {
  content: "";
  display: inline-block;
  width: 0.5em;
  height: 0.5em;
  background: #7779B8;
  border-radius: 50%;
  position: absolute;
  top: 0.6em;
  left: 0;
}