@charset "UTF-8";
@import url("https://use.typekit.net/olo3hqx.css");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;200;300;400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&display=swap");
header .inner .links {
  padding: 20px;
}
header .inner .links dl:nth-child(3) {
  padding: 0 0 0 20px;
  border-right: none;
}
header .inner .links dl dd a span:nth-child(1) {
  display: none;
}
header .inner .button {
  display: none;
}

main {
  width: 100%;
  margin-bottom: 48px;
  position: relative;
  overflow: hidden;
}
main .chead {
  text-align: left;
  width: 100%;
  position: relative;
  z-index: 1;
}
main .chead:not(:last-child) {
  margin-bottom: 8px;
}
main .chead.on .visual h3 span {
  clip-path: inset(0 0 0 0);
}
main .chead.on .visual .slider-wc .swiper-wrapper .swiper-slide img {
  opacity: 1;
}
main .chead .visual {
  width: 100%;
  padding: 160px 0 0 0;
  position: relative;
}
main .chead .visual h3 {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
  margin-bottom: 16px;
}
main .chead .visual h3 span {
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  text-align: left;
  text-indent: 999%;
  line-height: 1;
  white-space: nowrap;
  display: block;
  overflow: hidden;
  position: relative;
  transition: all 0.3s ease-in 0s;
  clip-path: inset(0 100% 0 0);
}
main .chead .visual h3 span:nth-child(1) {
  width: 46.875%;
  height: 10.21875vw;
  background-image: url(../images/title1.webp);
  transform: translateX(2vw);
}
main .chead .visual h3 span:nth-child(2) {
  width: 98%;
  height: 10.4664vw;
  background-image: url(../images/title2.webp);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin: -40px 0 0 auto;
  transition-delay: 0.25s;
}
main .chead .visual .slider-wc {
  width: 100%;
  overflow: hidden;
}
main .chead .visual .slider-wc .swiper-wrapper {
  width: 100%;
  -webkit-transition-timing-function: linear !important;
  -o-transition-timing-function: linear !important;
  transition-timing-function: linear !important;
  display: flex;
}
main .chead .visual .slider-wc .swiper-wrapper .swiper-slide img {
  transition: all 0.5s ease-in 0s;
  opacity: 0;
}
main .chead .visual .slider-wc .swiper-wrapper .swiper-slide.ss1 img {
  transition-delay: 0.3s;
}
main .chead .visual .slider-wc .swiper-wrapper .swiper-slide.ss2 img {
  transition-delay: 0.6s;
}
main .chead .visual .slider-wc .swiper-wrapper .swiper-slide.ss3 img {
  transition-delay: 0.9s;
}
main .chead .visual .slider-wc .swiper-wrapper .swiper-slide.ss4 img {
  transition-delay: 1.2s;
}
main .chead .visual .slider-wc .swiper-wrapper .swiper-slide.ss5 img {
  transition-delay: 1.5s;
}
main .chead .visual .slider-wc .swiper-wrapper .swiper-slide.ss6 img {
  transition-delay: 1.8s;
}
main .pin-spacer {
  pointer-events: none;
}
main .badge {
  width: 184px;
  height: 184px;
  border-radius: 92px;
  position: absolute;
  top: calc(100vh - 184px - 32px);
  right: 32px;
  z-index: 10;
  transition: clip-path 0.25s ease-in 0s;
  clip-path: circle(0% at 50% 50%);
}
main .badge:hover a {
  background-color: #51489d;
}
main .badge::before {
  content: "";
  width: 20px;
  height: 1px;
  background-color: #FFF;
  position: absolute;
  top: 50%;
  right: 0px;
  z-index: 1;
}
main .badge.on {
  clip-path: circle(50% at 50% 50%);
}
main .badge.on.hide {
  transition: opacity 0.25s ease-in 0s;
  pointer-events: none;
  opacity: 0;
}
main .badge a {
  width: 100%;
  height: 100%;
  background-color: #919bc8;
  pointer-events: auto;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  transition: all 0.25s ease-in 0s;
}
main .badge a dl {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  gap: 8px 0;
}
main .badge a dl dt {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  gap: 8px 0;
}
main .badge a dl dt span {
  color: #FFF;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 2rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0em;
  font-feature-settings: "palt";
  text-align: center;
}
main .badge a dl dt span:nth-child(2) {
  letter-spacing: 0.1em;
}
main .badge a dl dt span:nth-child(3) {
  letter-spacing: 0.5em;
}
main .badge a dl dd {
  color: #FFF;
  font-family: "poppins", sans-serif;
  font-size: 1.4rem;
  font-weight: 300;
  line-height: 1;
  letter-spacing: 0em;
  font-feature-settings: "palt";
}
main .section {
  width: 100%;
  padding: 200px 0 220px 0;
  position: relative;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
}
main .section:not(:last-child) {
  margin-bottom: 80px;
}
main .section.sec0 {
  background-image: url(../images/bg_vision.webp);
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: cover;
  position: relative;
}
main .section.sec0.on .inner .text {
  clip-path: inset(0 0 0 0);
}
main .section.sec0 .inner {
  width: 1000px;
  margin: 0 auto;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
}
main .section.sec0 .inner h3 {
  width: 247px;
}
main .section.sec0 .inner h3 > span {
  width: 100%;
  height: 125px;
  background-image: url(../images/title_vision.png);
}
main .section.sec0 .inner .text {
  text-align: left;
  width: calc(100% - 247px - 128px);
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 24px 0;
  clip-path: inset(0 100% 0 0);
  transition: all 0.3s ease-in 0.6s;
}
main .section.sec0 .inner .text h4 {
  color: #000;
  font-family: "Noto Serif JP", serif;
  font-size: 3rem;
  font-weight: 400;
  line-height: 1.875;
  letter-spacing: 0em;
  font-feature-settings: "palt";
}
main .section.sec0 .inner .text p {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.875;
  letter-spacing: 0em;
  font-feature-settings: "palt";
}
main .section.sec0 .inner .text .btn {
  width: 100%;
}
main .section.sec0 .inner .text .btn a {
  width: 100%;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: stretch;
  background-color: #FFF;
  border: solid 1px #919bc8;
  position: relative;
}
main .section.sec0 .inner .text .btn a:hover::before {
  clip-path: inset(0 0 0 0);
}
main .section.sec0 .inner .text .btn a:hover::after {
  background-image: url(../images/arrow_btn_wh.svg);
}
main .section.sec0 .inner .text .btn a:hover span {
  color: #FFF;
}
main .section.sec0 .inner .text .btn a::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: #919bc8;
  position: absolute;
  top: 0px;
  left: 0px;
  z-index: 1;
  transition: all 0.25s ease-in 0s;
  clip-path: inset(0 100% 0 0);
}
main .section.sec0 .inner .text .btn a::after {
  content: "";
  width: 20px;
  height: 48px;
  background-image: url(../images/arrow_btn.svg);
  background-repeat: no-repeat;
  background-position: left center;
  background-size: 14px;
  display: block;
  position: relative;
  z-index: 2;
  transition: all 0.25s ease-in 0s;
}
main .section.sec0 .inner .text .btn a span {
  color: #919bc8;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0em;
  font-feature-settings: "palt";
  width: calc(100% - 20px);
  height: 48px;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  border-right: solid 1px #919bc8;
  transition: all 0.25s ease-in 0s;
  position: relative;
  z-index: 2;
}
main .section.sec1 {
  padding-top: 0px;
}
main .section.sec1.on .inner .graph {
  clip-path: inset(0 0 0 0);
}
main .section.sec1 .inner h3 {
  width: 290px;
  margin-bottom: 40px;
}
main .section.sec1 .inner h3 > span {
  width: 100%;
  height: 143px;
  background-image: url(../images/title_system.png);
}
main .section.sec1 .inner .graph {
  width: 100%;
  clip-path: inset(0 100% 0 0);
  transition: all 0.3s ease-in 0.6s;
}
main .section.sec1 .inner .graph:not(:last-child) {
  margin-bottom: 80px;
}
main .section.sec1 .inner .graph .explain {
  display: none;
}
main .section.sec1 .inner .systems {
  text-align: left;
  width: 100%;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: stretch;
  gap: 112px 44px;
}
main .section.sec1 .inner .systems .system {
  width: calc(50% - 56px);
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
  opacity: 0;
  transition: all 0.3s ease-in 0s;
}
main .section.sec1 .inner .systems .system:nth-child(2n) {
  transition-delay: 0.3s;
}
main .section.sec1 .inner .systems .system.on {
  opacity: 1;
}
main .section.sec1 .inner .systems .system dl {
  margin-bottom: 40px;
}
main .section.sec1 .inner .systems .system dl dt {
  color: #FFF;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0em;
  font-feature-settings: "palt";
  background-color: #7d83ba;
  padding: 8px 24px;
  margin-bottom: 32px;
  position: relative;
}
main .section.sec1 .inner .systems .system dl dt::before {
  content: "PICK UP!";
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0em;
  font-feature-settings: "palt";
  background-color: #ffff00;
  width: 96px;
  height: 24px;
  border-radius: 8px;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: -32px;
  left: 0px;
  z-index: 1;
}
main .section.sec1 .inner .systems .system dl dt::after {
  content: "";
  width: 16px;
  height: 18px;
  background-color: #ffff00;
  display: block;
  position: absolute;
  top: -10px;
  left: 56px;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
}
main .section.sec1 .inner .systems .system dl dd {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: 0em;
  font-feature-settings: "palt";
}
main .section.sec1 .inner .systems .system dl dd strong {
  color: #51489d;
  font-weight: 700;
}
main .section.sec1 .inner .systems .system .comment {
  width: 100%;
  height: 100%;
  background-color: rgba(125, 131, 186, 0.2);
  padding: 24px 24px 120px 24px;
  margin: auto 0 0 0;
  border-radius: 27px;
  position: relative;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 40px 0;
  flex-shrink: 1;
}
main .section.sec1 .inner .systems .system .comment::after {
  content: "";
  width: 190px;
  height: 190px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  display: block;
  position: absolute;
  right: 24px;
  bottom: -40px;
  z-index: 1;
}
main .section.sec1 .inner .systems .system .comment.c1::after {
  background-image: url(../images/illust_system1.png);
}
main .section.sec1 .inner .systems .system .comment.c2::after {
  background-image: url(../images/illust_system2.png);
}
main .section.sec1 .inner .systems .system .comment.c3::after {
  background-image: url(../images/illust_system3.png);
}
main .section.sec1 .inner .systems .system .comment.c4::after {
  background-image: url(../images/illust_system4.png);
}
main .section.sec1 .inner .systems .system .comment p {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: 0em;
  font-feature-settings: "palt";
}
main .section.sec2 {
  background-image: url(../images/bg_number.webp);
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  padding: 0 0 80px 0;
}
main .section.sec2:not(:last-child) {
  margin-bottom: 0px;
}
main .section.sec2 .inner {
  width: calc(100% - 256px);
  min-width: 1024px;
  max-width: 1280px;
}
main .section.sec2 .inner h3 {
  width: 298px;
  margin-bottom: 40px;
}
main .section.sec2 .inner h3 > span {
  width: 100%;
  height: 126px;
  background-image: url(../images/title_number.png);
}
main .section.sec2 .inner h3 + p span {
  right: calc(-15.6rem - 16px);
}
main .section.sec2 .inner .graphs {
  width: 100%;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: stretch;
  gap: 40px;
  margin-bottom: 104px;
}
main .section.sec2 .inner .graphs .graph {
  width: calc(50% - 20px);
  opacity: 0;
  transition: all 0.3s ease-in 0s;
}
main .section.sec2 .inner .graphs .graph.on {
  opacity: 1;
}
main .section.sec2 .inner .graphs .graph:nth-child(2n) {
  transition-delay: 0.3s;
}
main .section.sec2 .inner .graphs .graph > div {
  width: 100%;
  background-color: #FFF;
  padding: 32px 0 40px;
  border-radius: 27px;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
}
main .section.sec2 .inner .graphs .graph > div:not(:last-child) {
  margin-bottom: 16px;
}
main .section.sec2 .inner .graphs .graph > div p {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0em;
  font-feature-settings: "palt";
  margin-bottom: 40px;
}
main .section.sec2 .inner .graphs .graph > div figure {
  width: calc(100% - 196px);
}
main .section.sec2 .inner .graphs .graph p.notice {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0em;
  font-feature-settings: "palt";
  position: relative;
}
main .section.sec2 .inner .topics {
  width: 100%;
  padding: 32px;
  border-radius: 0 27px 27px 27px;
  background-color: #FFF;
  box-sizing: border-box;
  position: relative;
  opacity: 0;
  transition: all 0.3s ease-in 0s;
}
main .section.sec2 .inner .topics.on {
  opacity: 1;
}
main .section.sec2 .inner .topics::before {
  content: "TOPICS";
  color: #FFF;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0em;
  font-feature-settings: "palt";
  width: 160px;
  height: 48px;
  border-radius: 7px 7px 0 0;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  background-color: #919bc8;
  position: absolute;
  top: -48px;
  left: 0px;
}
main .section.sec2 .inner .topics .intopics {
  width: 100%;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
}
main .section.sec2 .inner .topics .intopics figure {
  width: 155px;
}
main .section.sec2 .inner .topics .intopics figure img {
  width: 100%;
}
main .section.sec2 .inner .topics .intopics div {
  text-align: left;
  width: calc(100% - 155px - 24px);
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
}
main .section.sec2 .inner .topics .intopics div p:nth-child(1) {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0em;
  font-feature-settings: "palt";
}
main .section.sec2 .inner .topics .intopics div p:nth-child(2) {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.875;
  letter-spacing: 0em;
  font-feature-settings: "palt";
}
main .section.sec3 {
  width: 100%;
  padding: 48px 0 128px 0;
  background-image: url(../images/bg_interview.webp);
  background-repeat: no-repeat;
  background-position: center top;
  background-size: 100% auto;
}
main .section.sec3:not(:last-child) {
  margin-bottom: 0px;
}
main .section.sec3.on h5 {
  clip-path: inset(0 0 0 0);
}
main .section.sec3.on .int-link .link {
  opacity: 1;
}
main .section.sec3 h5 {
  color: #FFF;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.2em;
  font-feature-settings: "palt";
  margin-bottom: 40px;
  clip-path: inset(0 100% 0 0);
  transition: all 0.3s ease-in 0s;
}
main .section.sec3 .int-link {
  width: calc(100% - 256px);
  min-width: 1024px;
  max-width: 1280px;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: stretch;
  gap: 0 8px;
  position: relative;
  z-index: 1;
}
main .section.sec3 .int-link .link {
  width: calc((100% - 24px) / 4);
  opacity: 0;
}
main .section.sec3 .int-link .link:nth-child(1) {
  transition: opacity 0.3s ease-in 0.2s;
}
main .section.sec3 .int-link .link:nth-child(2) {
  transition: opacity 0.3s ease-in 0.4s;
}
main .section.sec3 .int-link .link:nth-child(3) {
  transition: opacity 0.3s ease-in 0.6s;
}
main .section.sec3 .int-link .link:nth-child(4) {
  transition: opacity 0.3s ease-in 0.8s;
}
main .section.sec3 .int-link .link a {
  height: 100%;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
}
main .section.sec3 .int-link .link a div {
  width: 100%;
  transition: all 0.25s ease-in 0s;
}
main .section.sec3 .int-link .link a div img {
  border-radius: 3px 3px 0 0;
}
main .section.sec3 .int-link .link a dl {
  text-align: left;
  width: 100%;
  height: 100%;
  padding: 15px 20px;
  background-color: #51489d;
  border-radius: 0 0 3px 3px;
  box-sizing: border-box;
  transition: all 0.25s ease-in 0s;
}
main .section.sec3 .int-link .link a dl dt {
  color: #FFF;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.1rem;
  font-weight: 500;
  line-height: 1.8rem;
  letter-spacing: 0em;
  font-feature-settings: "palt";
}
main .section.sec3 .int-link .link a dl dt:not(:last-child) {
  margin-bottom: 10px;
}
main .section.sec3 .int-link .link a dl dd {
  color: #FFF;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.075em;
  font-feature-settings: "palt";
}
main .section.sec3 .int-link .link a dl dd:not(:last-child) {
  margin-bottom: 5px;
}
main .section.sec3 .int-link .link a:hover div {
  opacity: 0.8;
}
main .section.sec3 .int-link .link a:hover dl {
  background-color: #907aa8;
}
main .section.sec4 {
  width: 100%;
  padding: 0px;
}
main .section.sec4:not(:last-child) {
  margin-bottom: 160px;
}
main .section.sec4 .inner {
  width: calc(100% - 256px);
  position: relative;
  z-index: 1;
}
main .section.sec4 .inner h3 {
  width: 289px;
  margin-bottom: 24px;
}
main .section.sec4 .inner h3 > span {
  width: 100%;
  height: 124px;
  background-image: url(../images/title_event.png);
}
main .section.sec4 .inner .lead {
  margin-bottom: 56px;
  position: relative;
  color: #919bc8;
  z-index: 1;
}
main .section.sec4 .inner .lead p {
  color: #000;
  font-family: "Noto Serif JP", serif;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.2em;
  font-feature-settings: "palt";
}
main .section.sec4 .inner .banner {
  width: calc(100% - 0px);
  margin-bottom: 80px;
  position: relative;
}
main .section.sec4 .inner .banner.on .deco {
  opacity: 1;
}
main .section.sec4 .inner .banner.on span {
  opacity: 1;
}
main .section.sec4 .inner .banner .deco {
  opacity: 0;
  transition: all 0.25s ease-in 0.5s;
  position: absolute;
}
main .section.sec4 .inner .banner .deco.d1 {
  width: 520px;
  top: -320px;
  left: -280px;
}
main .section.sec4 .inner .banner .deco.d2 {
  width: 352px;
  top: -264px;
  right: -250px;
  transition-delay: 0.7s;
}
main .section.sec4 .inner .banner .deco.d3 {
  width: 394px;
  top: calc(100% - 128px);
  left: -172px;
  transition-delay: 0.9s;
}
main .section.sec4 .inner .banner .deco.d4 {
  width: 248px;
  top: calc(100% - 92px);
  right: -175px;
  transition-delay: 1.1s;
}
main .section.sec4 .inner .banner span {
  display: block;
  opacity: 0;
  transition: all 0.3s ease-in 0s;
  position: relative;
  z-index: 1;
}
main .section.sec4 .inner .text {
  text-align: left;
  width: 100%;
  margin-bottom: 48px;
  position: relative;
  z-index: 1;
}
main .section.sec4 .inner .text.on h5, main .section.sec4 .inner .text.on p {
  clip-path: inset(0 0 0 0);
}
main .section.sec4 .inner .text h5 {
  color: #000;
  font-family: "Noto Serif JP", serif;
  font-size: 3rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.2em;
  font-feature-settings: "palt";
  margin-bottom: 32px;
  clip-path: inset(0 100% 0 0);
  transition: all 0.3s ease-in 0s;
}
main .section.sec4 .inner .text p {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0em;
  font-feature-settings: "palt";
  clip-path: inset(0 100% 0 0);
  transition: all 0.3s ease-in 0.3s;
}
main .section.sec4 .inner .voice {
  text-align: left;
  width: 100%;
  position: relative;
  z-index: 1;
}
main .section.sec4 .inner .voice.on h5 {
  clip-path: inset(0 0 0 0);
}
main .section.sec4 .inner .voice.on .combo > div {
  opacity: 1;
}
main .section.sec4 .inner .voice h5 {
  margin-bottom: 24px;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  gap: 0 16px;
  clip-path: inset(0 100% 0 0);
  transition: all 0.3s ease-in 0s;
}
main .section.sec4 .inner .voice h5::before {
  content: "";
  width: 50px;
  height: 44px;
  background-image: url(../images/icon_balloon.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  display: block;
}
main .section.sec4 .inner .voice h5 span {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0em;
  font-feature-settings: "palt";
}
main .section.sec4 .inner .voice .combo {
  width: 100%;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: stretch;
  gap: 0 48px;
}
main .section.sec4 .inner .voice .combo > div {
  width: calc((100% - 96px) / 3);
  padding: 32px 32px 120px 32px;
  border: solid 2px #f3d5ff;
  border-radius: 27px;
  position: relative;
  opacity: 0;
  transition: all 0.3s ease-in 0s;
}
main .section.sec4 .inner .voice .combo > div::before {
  content: "";
  width: 190px;
  height: 190px;
  background-repeat: no-reepat;
  background-position: center;
  background-size: contain;
  display: block;
  position: absolute;
  bottom: -95px;
  left: calc(50% - 95px);
  z-index: 1;
}
main .section.sec4 .inner .voice .combo > div:nth-child(1) {
  transition-delay: 0.25s;
}
main .section.sec4 .inner .voice .combo > div:nth-child(1)::before {
  background-image: url(../images/illust_voice1.png);
}
main .section.sec4 .inner .voice .combo > div:nth-child(2) {
  transition-delay: 0.5s;
}
main .section.sec4 .inner .voice .combo > div:nth-child(2)::before {
  background-image: url(../images/illust_voice2.png);
}
main .section.sec4 .inner .voice .combo > div:nth-child(3) {
  transition-delay: 0.75s;
}
main .section.sec4 .inner .voice .combo > div:nth-child(3)::before {
  background-image: url(../images/illust_voice3.png);
}
main .section.sec4 .inner .voice .combo > div dl {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
  height: 100%;
}
main .section.sec4 .inner .voice .combo > div dl dt {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0em;
  font-feature-settings: "palt";
  margin-bottom: 24px;
}
main .section.sec4 .inner .voice .combo > div dl dd {
  height: 100%;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 40px 0;
}
main .section.sec4 .inner .voice .combo > div dl dd p {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.75;
  letter-spacing: 0em;
  font-feature-settings: "palt";
  flex-shrink: 1;
}
main .section.sec4 .inner .voice .combo > div dl dd p:last-child {
  margin: auto 0 0 0;
}
main .section.sec5 {
  width: 100%;
  padding: 144px 0 160px 0;
  background-image: url(../images/bg_point.webp);
  background-repeat: no-repeat;
  background-position: center top;
  background-size: 100% 100%;
}
main .section.sec5.on .inner .youtube .video {
  opacity: 1;
}
main .section.sec5 .inner {
  position: relative;
  z-index: 1;
}
main .section.sec5 .inner h3 {
  width: 289px;
  margin-bottom: 24px;
}
main .section.sec5 .inner h3 > span {
  width: 100%;
  height: 124px;
  background-image: url(../images/title_point.png);
}
main .section.sec5 .inner h3 + p {
  margin-bottom: 80px;
}
main .section.sec5 .inner h3 + p span {
  right: calc(-8.4rem - 16px);
}
main .section.sec5 .inner .youtube {
  width: 100%;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: stretch;
  margin-bottom: 80px;
}
main .section.sec5 .inner .youtube .video {
  width: calc(50% - 20px);
  opacity: 0;
  transition: all 0.3s ease-in 0.5s;
}
main .section.sec5 .inner .youtube .video:nth-child(2) {
  transition-delay: 0.75s;
}
main .section.sec5 .inner .youtube .video iframe {
  width: 100%;
  height: calc(((100vw - 360px) / 2 - 20px) * 0.5625);
  min-height: 276.75px;
  max-height: 348.75px;
}
main .section.sec5 .inner .number {
  width: 100%;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: stretch;
  margin-bottom: 72px;
}
main .section.sec5 .inner .number.on > div {
  opacity: 1;
}
main .section.sec5 .inner .number.on + .btn {
  clip-path: inset(0 0 0 0);
}
main .section.sec5 .inner .number > div {
  width: calc((100% - 96px) / 3);
  background-color: #FFF;
  padding: 24px 0 48px 0;
  border-radius: 27px;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  gap: 40px 0;
  opacity: 0;
  transition: all 0.3s ease-in 0s;
}
main .section.sec5 .inner .number > div:nth-child(2) {
  transition-delay: 0.25s;
}
main .section.sec5 .inner .number > div:nth-child(3) {
  transition-delay: 0.5s;
}
main .section.sec5 .inner .number > div dl {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  gap: 40px 0;
}
main .section.sec5 .inner .number > div dl dt {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0em;
  font-feature-settings: "palt";
}
main .section.sec5 .inner .number > div dl dd {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: flex-end;
}
main .section.sec5 .inner .number > div dl dd span:nth-child(1) {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 5.6rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0em;
  font-feature-settings: "palt";
}
main .section.sec5 .inner .number > div dl dd span:nth-child(2) {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 3.6rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0em;
  font-feature-settings: "palt";
}
main .section.sec5 .inner .number > div figure {
  width: calc(100% - 128px);
}
main .section.sec5 .inner .btn {
  width: 100%;
  clip-path: inset(0 100% 0 0);
  transition: all 0.3s ease-in 1s;
}
main .section.sec5 .inner .btn a {
  width: 100%;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: stretch;
  background-color: #FFF;
  border: solid 1px #919bc8;
  position: relative;
}
main .section.sec5 .inner .btn a:hover::before {
  clip-path: inset(0 0 0 0);
}
main .section.sec5 .inner .btn a:hover::after {
  background-image: url(../images/arrow_btn_wh.svg);
}
main .section.sec5 .inner .btn a:hover span {
  color: #FFF;
}
main .section.sec5 .inner .btn a::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: #919bc8;
  position: absolute;
  top: 0px;
  left: 0px;
  z-index: 1;
  transition: all 0.25s ease-in 0s;
  clip-path: inset(0 100% 0 0);
}
main .section.sec5 .inner .btn a::after {
  content: "";
  width: 20px;
  height: 48px;
  background-image: url(../images/arrow_btn.svg);
  background-repeat: no-repeat;
  background-position: left center;
  background-size: 14px;
  display: block;
  position: relative;
  z-index: 2;
  transition: all 0.25s ease-in 0s;
}
main .section.sec5 .inner .btn a span {
  color: #919bc8;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0em;
  font-feature-settings: "palt";
  width: calc(100% - 20px);
  height: 48px;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  border-right: solid 1px #919bc8;
  transition: all 0.25s ease-in 0s;
  position: relative;
  z-index: 2;
}
main .section.message {
  width: 100%;
  padding: 176px 0;
}
main .section.message.on .inner h3 {
  opacity: 1;
  clip-path: inset(0 0 0 0);
}
main .section.message .inner h3 {
  color: #000;
  font-family: "Noto Serif JP", serif;
  font-size: 3rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.02em;
  font-feature-settings: "palt";
  opacity: 0;
  clip-path: inset(0 100% 0 0);
  transition: all 0.5s eae-in 0s;
}
main .section.on .inner h3 {
  clip-path: inset(0 0 0 0);
}
main .section.on .inner h3 + p {
  clip-path: inset(0 0 0 0);
}
main .section.on .inner .lead {
  clip-path: inset(0 0 0 0);
}
main .section .inner {
  width: calc(100% - 360px);
  min-width: 1024px;
  max-width: 1280px;
  padding: 0px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
}
main .section .inner h3 {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  clip-path: inset(0 100% 0 0);
  transition: all 0.3s ease-in 0s;
}
main .section .inner h3 > span {
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  text-align: left;
  text-indent: 999%;
  line-height: 1;
  white-space: nowrap;
  display: block;
  overflow: hidden;
  position: relative;
}
main .section .inner h3 + p {
  color: #000;
  font-family: "Noto Serif JP", serif;
  font-size: 3rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.2em;
  font-feature-settings: "palt";
  position: relative;
  clip-path: inset(0 100% 0 0);
  transition: all 0.3s ease-in 0.3s;
}
main .section .inner h3 + p:not(:last-child) {
  margin-bottom: 56px;
}
main .section .inner h3 + p > span {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0em;
  font-feature-settings: "palt";
  text-align: right;
  position: absolute;
  right: 0px;
  bottom: 0px;
}
main .section .inner .lead {
  text-align: left;
  margin-bottom: 16px;
  clip-path: inset(0 100% 0 0);
  transition: all 0.3s ease-in 0.6s;
}
main .section .inner .lead span {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0em;
  font-feature-settings: "palt";
}
main .entry {
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: stretch;
}
main .entry > div {
  width: calc((100% - 12px) / 2);
}
main .entry > div a {
  width: 100%;
  height: 170px;
  background-color: #51489d;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  position: relative;
  transition: all 0.25s ease-in 0s;
}
main .entry > div a:hover {
  background-color: #919bc8;
}
main .entry > div a::before {
  content: "";
  width: 27px;
  height: 1px;
  background-color: #FFF;
  position: absolute;
  right: 0px;
  top: 50%;
  display: block;
}
main .entry > div a span {
  color: #FFF;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.2em;
  font-feature-settings: "palt";
}

/* --------------------------------------- Media Queries Smartphone ---------------------------------- */
@media screen and (max-width: 768px) {
  @keyframes finger {
    0% {
      transform: translateX(40px);
    }
    100% {
      transform: translateX(-40px);
    }
  }
  header .inner {
    padding: 16px 16px;
    height: auto;
    background-color: rgba(255, 255, 255, 0.8);
    align-items: center;
  }
  header .inner .logo {
    width: 109px;
    padding: 0px;
    background-color: transparent;
  }
  header .inner .logo h1 {
    width: 100%;
  }
  header .inner .logo h1 a {
    height: 34px;
  }
  header .inner .links {
    width: 100%;
    padding: 0px;
    background-color: transparent;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 4px 0;
    position: absolute;
    top: 66px;
    left: 0px;
    z-index: 10;
    clip-path: inset(0 0 100% 0);
    pointer-events: none;
    transition: all 0.25s ease-in 0s;
  }
  header .inner .links.on {
    clip-path: inset(0 0 0 0);
    pointer-events: auto;
  }
  header .inner .links h2 {
    display: none;
  }
  header .inner .links dl {
    width: 100%;
    padding: 0px;
    display: inline-block;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: stretch;
    gap: 4px;
  }
  header .inner .links dl:nth-child(2), header .inner .links dl:nth-child(3) {
    padding: 0px;
  }
  header .inner .links dl:nth-child(2)::before, header .inner .links dl:nth-child(3)::before {
    content: none;
  }
  header .inner .links dl:nth-child(2) dd, header .inner .links dl:nth-child(3) dd {
    margin: 0px;
  }
  header .inner .links dl dt {
    display: none;
  }
  header .inner .links dl dd {
    width: calc(50% - 2px);
    height: 72px;
  }
  header .inner .links dl dd a {
    width: 100%;
    height: 100%;
    background-color: #51489d;
    position: relative;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    gap: 0 8px;
  }
  header .inner .links dl dd a::before {
    content: "";
    width: 16px;
    height: 1px;
    background-color: #FFF;
    position: absolute;
    top: 50%;
    right: 0;
    z-index: 1;
  }
  header .inner .links dl dd a span {
    color: #FFF;
  }
  header .inner .links dl dd a span:nth-child(1) {
    display: inline-block;
  }
  header .inner .button {
    color: #51489d;
    font-family: din-2014-narrow, sans-serif;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.05em;
    font-feature-settings: "palt";
    display: block;
  }

  main {
    width: 100%;
    margin-bottom: 48px;
    position: relative;
  }
  main .chead {
    text-align: left;
    width: 100%;
    position: relative;
    z-index: 1;
  }
  main .chead:not(:last-child) {
    margin-bottom: 8px;
  }
  main .chead .visual {
    width: 100%;
    padding: 96px 0 0 0;
    overflow: hidden;
  }
  main .chead .visual h3 {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-start;
    margin-bottom: 16px;
    position: relative;
    transform: translateX(8px);
  }
  main .chead .visual h3 span {
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    text-align: left;
    text-indent: 999%;
    line-height: 1;
    white-space: nowrap;
    display: block;
    overflow: hidden;
    position: relative;
  }
  main .chead .visual h3 span:nth-child(1) {
    width: 75%;
    height: 16.35vw;
    transform: translateX(8px);
  }
  main .chead .visual h3 span:nth-child(2) {
    width: 100%;
    height: 67.9vw;
    background-image: url(../images_sp/title2_sp.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    margin: -16px 0 0 0;
  }
  main .badge {
    width: 129px;
    height: 129px;
    background-color: #919bc8;
    border-radius: 65px;
    position: absolute;
    top: calc(100vh - 129px - 64px);
    right: 8px;
  }
  main .badge:hover {
    background-color: #51489d;
  }
  main .badge::before {
    content: "";
    width: 20px;
    height: 1px;
    background-color: #FFF;
    position: absolute;
    top: 50%;
    right: 0px;
    z-index: 1;
  }
  main .badge a dl {
    gap: 8px 0;
  }
  main .badge a dl dt {
    gap: 8px 0;
  }
  main .badge a dl dt span {
    color: #FFF;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-size: 1.4rem;
    font-weight: 600;
    line-height: 1;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .badge a dl dt span:nth-child(2) {
    letter-spacing: 0.1em;
  }
  main .badge a dl dt span:nth-child(3) {
    letter-spacing: 0.5em;
  }
  main .badge a dl dd {
    color: #FFF;
    font-family: "poppins", sans-serif;
    font-size: 1.1rem;
    font-weight: 300;
    line-height: 1;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section {
    width: 100%;
    padding: 32px 0 80px 0;
    position: relative;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
  }
  main .section:not(:last-child) {
    margin-bottom: 40px;
  }
  main .section.sec0 {
    background-image: url(../images_sp/bg_vision.webp);
    background-repeat: no-repeat;
    background-position: center bottom;
    background-size: cover;
    position: relative;
  }
  main .section.sec0 .inner {
    width: calc(100% - 32px);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-start;
  }
  main .section.sec0 .inner h3 {
    width: 173px;
    margin-bottom: 32px;
  }
  main .section.sec0 .inner h3 > span {
    height: 87px;
  }
  main .section.sec0 .inner .text {
    text-align: left;
    width: 100%;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 24px 0;
  }
  main .section.sec0 .inner .text h4 {
    color: #000;
    font-family: "Noto Serif JP", serif;
    font-size: 2.4rem;
    font-weight: 500;
    line-height: 1.875;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section.sec0 .inner .text p {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.875;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section.sec0 .inner .text .btn a span {
    color: #919bc8;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section.sec1 {
    padding-top: 0px;
  }
  main .section.sec1 .inner h3 {
    width: 202px;
    margin-bottom: 40px;
  }
  main .section.sec1 .inner h3 > span {
    height: 86px;
  }
  main .section.sec1 .inner .graph {
    width: 100%;
  }
  main .section.sec1 .inner .graph .ingraph {
    width: 100%;
    position: relative;
    overflow: scroll;
  }
  main .section.sec1 .inner .graph .ingraph .explain {
    width: 100%;
    height: 100%;
    background-color: rgba(50, 50, 50, 0.5);
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0px;
    left: 0px;
    z-index: 1;
  }
  main .section.sec1 .inner .graph .ingraph .explain::before {
    content: "";
    width: 62px;
    height: 10px;
    background-image: url(../images_sp/arrow_attention.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    display: block;
    order: 1;
  }
  main .section.sec1 .inner .graph .ingraph .explain::after {
    content: "";
    width: 70px;
    height: 70px;
    background-image: url(../images_sp/icon_finger.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    display: block;
    order: 2;
    animation-name: finger;
    animation-duration: 1s;
    animation-iteration-count: infinite;
    animation-direction: alternate;
    animation-fill-mode: both;
    animation-timing-function: rase;
  }
  main .section.sec1 .inner .graph .ingraph figure {
    width: calc((100vw - 16px) * 1.75);
  }
  main .section.sec1 .inner .graph:not(:last-child) {
    margin-bottom: 56px;
  }
  main .section.sec1 .inner .systems {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 40px 0px;
  }
  main .section.sec1 .inner .systems .system {
    width: 100%;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-start;
  }
  main .section.sec1 .inner .systems .system dl {
    margin-bottom: 16px;
  }
  main .section.sec1 .inner .systems .system dl dt {
    color: #FFF;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0em;
    font-feature-settings: "palt";
    background-color: #7d83ba;
    padding: 8px 16px;
    margin-bottom: 8px;
  }
  main .section.sec1 .inner .systems .system dl dt::before {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.4rem;
    font-weight: 600;
    line-height: 1;
    letter-spacing: 0em;
    font-feature-settings: "palt";
    width: 96px;
    height: 24px;
  }
  main .section.sec1 .inner .systems .system dl dt::after {
    content: "";
    width: 16px;
    height: 18px;
    background-color: #ffff00;
    display: block;
    position: absolute;
    top: -10px;
    left: 56px;
    clip-path: polygon(0 0, 50% 100%, 100% 0);
  }
  main .section.sec1 .inner .systems .system dl dd {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.75;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section.sec1 .inner .systems .system dl dd strong {
    color: #51489d;
    font-weight: 700;
  }
  main .section.sec1 .inner .systems .system .comment {
    padding: 16px 16px 64px 16px;
    margin: auto 0 0 0;
    border-radius: 16px;
    position: relative;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 40px 0;
    flex-shrink: 1;
  }
  main .section.sec1 .inner .systems .system .comment::after {
    width: 88px;
    height: 88px;
    right: 16px;
    bottom: 16px;
    z-index: 1;
  }
  main .section.sec1 .inner .systems .system .comment p {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.75;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section.sec2 {
    background-image: url(../images/bg_number.webp);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: cover;
    padding: 0 0 80px 0;
  }
  main .section.sec2:not(:last-child) {
    margin-bottom: 0px;
  }
  main .section.sec2 .inner {
    width: calc(100% - 32px);
    min-width: calc(100% - 32px);
    max-width: calc(100% - 32px);
  }
  main .section.sec2 .inner h3 {
    width: 208px;
    margin-bottom: 40px;
  }
  main .section.sec2 .inner h3 > span {
    height: 88px;
  }
  main .section.sec2 .inner h3 + p span {
    right: 0px;
  }
  main .section.sec2 .inner .graphs {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: stretch;
    gap: 16px;
    margin-bottom: 64px;
  }
  main .section.sec2 .inner .graphs .graph {
    width: calc(50% - 8px);
  }
  main .section.sec2 .inner .graphs .graph > div {
    height: auto;
    padding: 16px 0;
    border-radius: 16px;
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center;
  }
  main .section.sec2 .inner .graphs .graph > div:not(:last-child) {
    margin-bottom: 16px;
  }
  main .section.sec2 .inner .graphs .graph > div p {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0em;
    font-feature-settings: "palt";
    margin-bottom: 40px;
  }
  main .section.sec2 .inner .graphs .graph > div figure {
    width: calc(100% - 32px);
  }
  main .section.sec2 .inner .graphs .graph p.notice {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.75;
    letter-spacing: 0em;
    font-feature-settings: "palt";
    text-align: left;
    position: relative;
  }
  main .section.sec2 .inner .topics {
    padding: 16px;
    border-radius: 0 16px 16px 16px;
  }
  main .section.sec2 .inner .topics::before {
    color: #FFF;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0em;
    font-feature-settings: "palt";
    width: 120px;
    height: 32px;
    border-radius: 8px 8px 0 0;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    background-color: #919bc8;
    position: absolute;
    top: -32px;
    left: 0px;
  }
  main .section.sec2 .inner .topics .intopics {
    width: 100%;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    gap: 16px 0;
  }
  main .section.sec2 .inner .topics .intopics figure {
    width: 136px;
  }
  main .section.sec2 .inner .topics .intopics div {
    text-align: left;
    width: 100%;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    gap: 8px 0;
  }
  main .section.sec2 .inner .topics .intopics div p:nth-child(1) {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.75;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section.sec2 .inner .topics .intopics div p:nth-child(2) {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.875;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section.sec3 {
    width: 100%;
    padding: 40px 0 64px 0;
    background-image: url(../images/bg_interview.webp);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: 250% auto;
  }
  main .section.sec3:not(:last-child) {
    margin-bottom: 0px;
  }
  main .section.sec3 h5 {
    color: #FFF;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.75;
    letter-spacing: 0.2em;
    font-feature-settings: "palt";
    margin-bottom: 24px;
  }
  main .section.sec3 .int-link {
    width: calc(100% - 32px);
    min-width: calc(100% - 32px);
    max-width: calc(100% - 32px);
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: stretch;
    gap: 8px;
    position: relative;
    z-index: 1;
    opacity: 1;
    transition: opacity 0.5s ease-out 0;
  }
  main .section.sec3 .int-link .link {
    width: calc((100% - 8px) / 2);
  }
  main .section.sec3 .int-link .link a {
    height: 100%;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-start;
  }
  main .section.sec3 .int-link .link a div {
    width: 100%;
    transition: all 0.25s ease-in 0s;
  }
  main .section.sec3 .int-link .link a div img {
    border-radius: 4px 4px 0 0;
  }
  main .section.sec3 .int-link .link a dl {
    text-align: left;
    width: 100%;
    height: 100%;
    padding: 8px 16px;
    border-radius: 0 0 4px 4px;
  }
  main .section.sec3 .int-link .link a dl dt {
    color: #FFF;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.75;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section.sec3 .int-link .link a dl dt:not(:last-child) {
    margin-bottom: 10px;
  }
  main .section.sec3 .int-link .link a dl dd {
    color: #FFF;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.075em;
    font-feature-settings: "palt";
  }
  main .section.sec3 .int-link .link a dl dd:not(:last-child) {
    margin-bottom: 5px;
  }
  main .section.sec3 .int-link .link a:hover div {
    opacity: 1;
  }
  main .section.sec3 .int-link .link a:hover dl {
    background-color: #51489d;
  }
  main .section.sec4 {
    width: 100%;
    padding: 0px;
  }
  main .section.sec4:not(:last-child) {
    margin-bottom: 80px;
  }
  main .section.sec4 .inner {
    width: calc(100% - 32px);
    position: relative;
    z-index: 1;
  }
  main .section.sec4 .inner h3 {
    width: 202px;
    margin-bottom: 16px;
  }
  main .section.sec4 .inner h3 > span {
    width: 100%;
    height: 87px;
    background-image: url(../images/title_event.png);
  }
  main .section.sec4 .inner .lead {
    margin-bottom: 32px;
    position: relative;
    color: #919bc8;
    z-index: 1;
  }
  main .section.sec4 .inner .lead p {
    color: #000;
    font-family: "Noto Serif JP", serif;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.75;
    letter-spacing: 0.2em;
    font-feature-settings: "palt";
    text-align: center;
  }
  main .section.sec4 .inner .banner {
    width: calc(100% - 0px);
    margin-bottom: 24px;
    position: relative;
  }
  main .section.sec4 .inner .banner .deco {
    position: absolute;
  }
  main .section.sec4 .inner .banner .deco.d1 {
    width: 260px;
    top: -160px;
    left: -140px;
  }
  main .section.sec4 .inner .banner .deco.d2 {
    width: 186px;
    top: -132px;
    right: -125px;
  }
  main .section.sec4 .inner .banner .deco.d3 {
    width: 197px;
    top: calc(100% - 64px);
    left: -86px;
  }
  main .section.sec4 .inner .banner .deco.d4 {
    width: 124px;
    top: calc(100% - 46px);
    right: -87px;
  }
  main .section.sec4 .inner .text {
    margin-bottom: 24px;
  }
  main .section.sec4 .inner .text h5 {
    color: #000;
    font-family: "Noto Serif JP", serif;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.75;
    letter-spacing: 0.2em;
    font-feature-settings: "palt";
    text-align: center;
    margin-bottom: 16px;
  }
  main .section.sec4 .inner .text p {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.875;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section.sec4 .inner .voice h5 {
    margin-bottom: 24px;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    gap: 0 8px;
  }
  main .section.sec4 .inner .voice h5::before {
    width: 40px;
    height: 35px;
  }
  main .section.sec4 .inner .voice h5 span {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section.sec4 .inner .voice .combo {
    width: 100%;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 64px 0;
  }
  main .section.sec4 .inner .voice .combo > div {
    width: 100%;
    padding: 16px 16px 64px 16px;
    border-radius: 16px;
  }
  main .section.sec4 .inner .voice .combo > div::before {
    width: 104px;
    height: 104px;
    bottom: -52px;
    left: calc(50% - 52px);
  }
  main .section.sec4 .inner .voice .combo > div dl {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-start;
    height: 100%;
  }
  main .section.sec4 .inner .voice .combo > div dl dt {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.75;
    letter-spacing: 0em;
    font-feature-settings: "palt";
    margin-bottom: 16px;
  }
  main .section.sec4 .inner .voice .combo > div dl dd {
    height: 100%;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 24px 0;
  }
  main .section.sec4 .inner .voice .combo > div dl dd p {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1.75;
    letter-spacing: 0em;
    font-feature-settings: "palt";
    flex-shrink: 1;
  }
  main .section.sec4 .inner .voice .combo > div dl dd p:last-child {
    margin: auto 0 0 0;
  }
  main .section.sec5 {
    padding: 72px 0 80px 0;
    background-repeat: no-repeat;
    background-position: center top;
    background-size: 100% 100%;
  }
  main .section.sec5 .inner {
    position: relative;
    z-index: 1;
  }
  main .section.sec5 .inner h3 {
    width: 202px;
    margin-bottom: 16px;
  }
  main .section.sec5 .inner h3 > span {
    height: 86px;
  }
  main .section.sec5 .inner h3 + p {
    margin-bottom: 40px;
  }
  main .section.sec5 .inner h3 + p span {
    right: 0px;
  }
  main .section.sec5 .inner .youtube {
    width: 100%;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    gap: 16px 0;
    margin-bottom: 40px;
  }
  main .section.sec5 .inner .youtube .video {
    width: 100%;
  }
  main .section.sec5 .inner .youtube .video iframe {
    width: 100%;
    height: calc((100vw - 32px) * 0.5625);
    min-height: calc((100vw - 32px) * 0.5625);
    max-height: calc((100vw - 32px) * 0.5625);
  }
  main .section.sec5 .inner .number {
    width: 100%;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    gap: 24px 0;
    margin-bottom: 32px;
  }
  main .section.sec5 .inner .number > div {
    width: 100%;
    padding: 16px 0;
    border-radius: 16px;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    gap: 16px 0;
  }
  main .section.sec5 .inner .number > div dl {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    gap: 8px 0;
  }
  main .section.sec5 .inner .number > div dl dt {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section.sec5 .inner .number > div dl dd {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: flex-end;
  }
  main .section.sec5 .inner .number > div dl dd span:nth-child(1) {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 4rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section.sec5 .inner .number > div dl dd span:nth-child(2) {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 2.4rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section.sec5 .inner .number > div figure {
    width: calc(100% - 160px);
  }
  main .section.sec5 .inner .btn a span {
    color: #919bc8;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .section.message {
    width: 100%;
    padding: 80px 0;
  }
  main .section.message .inner h3 {
    color: #000;
    font-family: "Noto Serif JP", serif;
    font-size: 2.4rem;
    font-weight: 500;
    line-height: 1.75;
    letter-spacing: 0.02em;
    font-feature-settings: "palt";
  }
  main .section .inner {
    width: calc(100% - 32px);
    min-width: calc(100% - 32px);
    max-width: calc(100% - 32px);
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
  }
  main .section .inner h3 {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
  }
  main .section .inner h3 > span {
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    text-align: left;
    text-indent: 999%;
    line-height: 1;
    white-space: nowrap;
    display: block;
    overflow: hidden;
    position: relative;
  }
  main .section .inner h3 + p {
    color: #000;
    font-family: "Noto Serif JP", serif;
    font-size: 2.4rem;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: 0.2em;
    font-feature-settings: "palt";
    position: relative;
  }
  main .section .inner h3 + p:not(:last-child) {
    margin-bottom: 40px;
  }
  main .section .inner h3 + p > span {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1rem;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0em;
    font-feature-settings: "palt";
    text-align: center;
    position: relative;
    right: auto;
    bottom: auto;
  }
  main .section .inner .lead {
    text-align: left;
    margin-bottom: 16px;
  }
  main .section .inner .lead span {
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0em;
    font-feature-settings: "palt";
  }
  main .entry > div {
    width: calc((100% - 4px) / 2);
  }
  main .entry > div a {
    width: 100%;
    height: 80px;
  }
  main .entry > div a:hover {
    background-color: #51489d;
  }
  main .entry > div a::before {
    width: 24px;
    height: 1px;
  }
  main .entry > div a span {
    color: #FFF;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0.2em;
    font-feature-settings: "palt";
  }
}

/*# sourceMappingURL=style_wc.css.map */
