/* 
font-family: "Zen Kaku Gothic New", sans-serif;
*/
body {
  font-size: 4vw;
  font-family: "Zen Kaku Gothic New", sans-serif;
  line-height: 1.5;
  letter-spacing: 0.1em;
  font-weight: 400;
  margin: 0 auto;
  position: relative;
  color: #0a3191;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}

/*--------------------cmn--------------------*/
/*--------------------cmn--------------------*/
/*--------------------header--------------------*/
.header {
  width: 100%;
  padding: 4vw;
  background: #fff;
}
.header_logo {
  width: 60%;
}
.header_logo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.header_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}
.header_box {
  display: none;
  flex-wrap: wrap;
  align-items: center;
  gap: 20px;
  margin-bottom: 20px;
}
.header_tel {
  text-align: right;
}
.header_tel p {
  display: inline-block;
  font-size: 30px;
  line-height: 1;
  letter-spacing: 0.04em;
  font-weight: 900;
  color: #0a3191;
  position: relative;
  z-index: 1;
  padding-left: 1em;
}
.header_tel p::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 0.7333333333em;
  height: 0.7333333333em;
  transform: translate(0%, -40%);
  background: url(/img/common/telicon.png) no-repeat center center/contain;
}
.header_tel span {
  margin-left: auto;
  display: block;
  width: 86%;
  margin-top: -7px;
}
.header_mail {
  width: 260px;
  background: #0a3191;
  border-radius: 999px;
  text-align: center;
  padding: 18px;
}
.header_mail p {
  display: inline-block;
  font-size: 15px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #fff;
  position: relative;
  z-index: 1;
  padding-left: 2.1333333333em;
}
.header_mail p::before {
  background: url(/img/top/mailicon.png) no-repeat center center/contain;
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 1.6em;
  height: 1.1333333333em;
  transform: translate(0%, -50%);
}
.header_nav {
  display: none;
}
.header_nav_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 30px;
}
.header_nav_item {
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
}

.line_btn {
  width: 260px;
  background: #d5f2ff;
  border-radius: 999px;
  text-align: center;
  padding: 18px;
}
.line_btn p {
  display: inline-block;
  font-size: 15px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #0a3191;
  position: relative;
  z-index: 1;
  padding-left: 2.9333333333em;
}
.line_btn p::before {
  background: url(/img/common/line.png) no-repeat center center/contain;
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 2em;
  height: 2em;
  transform: translate(0%, -50%);
}
.line_btn_sns {
  width: 30px;
  height: 30px;
}
.line_btn_sns img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/*--------------------header--------------------*/
/*--------------------footer--------------------*/
.cmn_tel p {
  border-bottom: 0.8vw solid #1981ec;
  padding-bottom: 2.1333333333vw;
  font-size: 8vw;
  line-height: 1;
  letter-spacing: 0.04em;
  font-weight: 900;
  color: #0a3191;
  position: relative;
  z-index: 1;
  display: inline-block;
  padding-left: 1em;
}
.cmn_tel p::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 0.75em;
  height: 0.75em;
  transform: translate(0%, -60%);
  background: url(/img/common/telicon.png) no-repeat center center/contain;
}

.footer {
  width: 100%;
  padding: 16vw 0;
  border-top: 1.0666666667vw solid #77c0f8;
}
.footer_box {
  margin-bottom: 8vw;
}
.footer_logo {
  width: 60%;
  margin: 0 auto;
  margin-bottom: 8vw;
}
.footer_logo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.footer_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: center;
  margin-bottom: 8vw;
  text-align: center;
}
.footer_tel {
  margin-bottom: 4vw;
}
.footer_tel_sub {
  margin-bottom: 1.3333333333vw;
}
.footer_care {
  text-align: center;
  width: 80%;
  margin: 0 auto 8vw;
}
.footer_care img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.footer_mail {
  width: 100%;
  background: #0a3191;
  border-radius: 999px;
  text-align: center;
  padding: 4.8vw;
  margin-bottom: 4vw;
}
.footer_mail p {
  display: inline-block;
  font-size: 4vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #fff;
  position: relative;
  z-index: 1;
  padding-left: 2.1333333333em;
}
.footer_mail p::before {
  background: url(/img/top/mailicon.png) no-repeat center center/contain;
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 1.6em;
  height: 1.1333333333em;
  transform: translate(0%, -50%);
}
.footer .line_btn {
  width: 100%;
  background: #d5f2ff;
  border-radius: 999px;
  text-align: center;
  padding: 4.8vw;
  margin-bottom: 4vw;
}
.footer .line_btn p {
  display: inline-block;
  font-size: 4vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #0a3191;
  position: relative;
  z-index: 1;
  padding-left: 2.9333333333em;
}
.footer .line_btn p::before {
  background: url(/img/common/line.png) no-repeat center center/contain;
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 2em;
  height: 2em;
  transform: translate(0%, -50%);
}
.footer_sns {
  width: 8vw;
  height: 8vw;
  margin: 0 auto;
}
.footer_sns img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.footer_mid_box {
  width: 100%;
  background: #f2fbff;
  border-radius: 5.3333333333vw;
  padding: 5.3333333333vw 4vw;
}
.footer_mid_txt {
  font-size: 4.2666666667vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #0a3191;
  text-align: center;
  position: relative;
  z-index: 1;
  margin-bottom: 5.3333333333vw;
}
.footer_mid_txt::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 3.75em;
  height: 0.125em;
  background: #1981ec;
  transform: translate(0%, -50%);
}
.footer_mid_txt::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 0%;
  width: 3.75em;
  height: 0.125em;
  background: #1981ec;
  transform: translate(0%, -50%);
}
.footer_mid_btn {
  width: 100%;
  padding: 4vw;
  background: #fff;
  border-radius: 2.6666666667vw;
  border: 0.8vw solid #1981ec;
  margin: 0 auto;
}
.footer_mid_btn p {
  display: inline-block;
  font-size: 4vw;
  line-height: 1.6em;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #0a3191;
  position: relative;
  z-index: 1;
  padding-left: 3em;
}
.footer_mid_btn p::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 2em;
  height: 1.6666666667em;
  transform: translate(0%, -50%);
  background: url(/img/top/linkicon.png) no-repeat center center/contain;
}
.footer .footer_mid_btn01 {
  margin-bottom: 4vw;
}
.footer_dl {
  margin-bottom: 8vw;
}
.footer_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 2.6666666667vw;
}
.footer_dl_box:not(:last-child) {
  margin-bottom: 5.3333333333vw;
}
.footer_dl_box dt {
  width: 24vw;
  padding: 1.8666666667vw;
  text-align: center;
  background: #77c0f8;
  font-size: 4.2666666667vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #fff;
}
.footer_dl_box dd {
  font-size: 4.2666666667vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #0a3191;
}
.footer_nav {
  margin-top: 8vw;
}
.footer_nav_list {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: center;
  gap: 6.6666666667vw 6.6666666667vw;
}
.footer_nav_item {
  font-size: 4vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #0a3191;
  position: relative;
  z-index: 1;
  padding-left: 1.375em;
}
.footer_nav_item a {
  color: #0a3191;
}
.footer_nav_item::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 0.75em;
  height: 0.75em;
  transform: translate(0%, -50%);
  background: #1981ec;
}
.footer_nav_item:nth-child(7) {
  padding-left: 1em;
}
.footer_nav_item:nth-child(7)::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 0.375em;
  height: 0.375em;
  transform: translate(0%, -50%);
  background: #1981ec;
}
.footer_nav_item:nth-child(8) {
  padding-left: 1em;
}
.footer_nav_item:nth-child(8)::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 0.375em;
  height: 0.375em;
  transform: translate(0%, -50%);
  background: #1981ec;
}
.footer .copy_right {
  font-size: 3.4666666667vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 400;
  color: #0a3191;
  display: block;
  text-align: center;
}
.footer .copy_right a {
  color: #0a3191;
}

/*--------------------footer--------------------*/
/*--------------------mv--------------------*/
.mv {
  width: 100%;
  height: 133.3333333333vw;
  position: relative;
  z-index: 3;
  background: url(/img/top/mvdeco.png) no-repeat left center/60%;
}
.mv_img {
  width: 90%;
  height: 57vw;
  position: absolute;
  z-index: -1;
  bottom: -10%;
  right: 50%;
  transform: translate(50%, 0%);
}
.mv_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.mv_catch {
  width: 94%;
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  transform: translate(-50%, 6%);
}

/*--------------------mv--------------------*/
/*--------------------sv--------------------*/
.sv_not_found .sv_catch span {
  font-size: 7.2vw;
}

.sv {
  width: 100%;
  position: relative;
  z-index: 1;
  height: 120vw;
  background: url(/img/sv/svdeco.png) no-repeat left top/contain;
}
.sv_img {
  width: 90%;
  position: absolute;
  z-index: -2;
  bottom: 0vw;
  right: 50%;
  transform: translate(50%, 0%);
}
.sv_catch {
  width: 90%;
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  transform: translate(-50%, 30%);
  border-top: 1.0666666667vw solid #0a3191;
  border-bottom: 1.0666666667vw solid #0a3191;
}
.sv_catch::after {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  left: 50%;
  width: 100%;
  height: 22.2906666667vw;
  transform: translate(-50%, 70%);
  background: url(/img/sv/svill02.png) no-repeat center center/cover;
}
.sv_catch::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  right: 5%;
  width: 28.5714285714%;
  height: 14.6666666667vw;
  transform: translate(0%, -120%);
  background: url(/img/sv/svill01.png) no-repeat center center/contain;
}
.sv_catch span {
  display: block;
  text-align: center;
  font-size: 7.4666666667vw;
  line-height: 1;
  letter-spacing: 0.1em;
  font-weight: 900;
  color: #0a3191;
  padding: 10.6666666667vw 0;
}
.sv_catch span::first-letter {
  color: #1981ec;
}

/*--------------------sv--------------------*/
.cmn_ttl {
  text-align: center;
  margin-bottom: 8vw;
}
.cmn_ttl span {
  font-size: 6.9333333333vw;
  line-height: 1;
  letter-spacing: 0.08em;
  font-weight: 900;
  color: #1981ec;
  background: #fff;
  padding: 1.8666666667vw 4vw;
  display: inline-block;
  border-radius: 2.6666666667vw;
}

.cmn_txt {
  font-size: 4vw;
  line-height: 1.5;
  letter-spacing: 0.05em;
  font-weight: 500;
  color: #0a3191;
}

/*--------------------company--------------------*/
.gre {
  width: 100%;
  position: relative;
  z-index: 1;
  margin-top: 21.3333333333vw;
  background: url(/img/company/decogre.png) no-repeat left bottom/15%, url(/img/company/decogre02.png) no-repeat right bottom/15%, #e5f8ff;
}
.gre::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 100%;
  height: 8vw;
  transform: translate(-50%, -100%);
  background: url(/img/company/wavet.png) no-repeat center center/100% 100%;
}
.gre_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  flex-direction: column-reverse;
  gap: 10.6666666667vw;
}
.gre_ibox {
  width: 100%;
}
.gre_ibox_box {
  width: 100%;
  background: #f2ffcc;
  padding: 4vw;
  margin-top: -13.3333333333vw;
  z-index: 10;
  position: relative;
  z-index: 1;
  text-align: center;
}
.gre_ibox_box p {
  font-size: 4.8vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #1981ec;
  margin-bottom: 4vw;
}
.gre_ibox_box strong {
  font-size: 6.4vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #1981ec;
}
.gre_box {
  width: 100%;
}
.gre_box p:not(:last-child) {
  margin-bottom: 6.6666666667vw;
}
.gre_img {
  width: 100%;
  height: 117.3333333333vw;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.gre_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.company {
  width: 100%;
  position: relative;
  z-index: 1;
}
.company::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 100%;
  height: 8vw;
  transform: translate(-50%, -100%);
  background: url(/img/company/waveb.png) no-repeat center center/100% 100%;
}
.company_ttl span {
  background: #e5f8ff;
  color: #1981ec;
}
.company_dl {
  width: 100%;
  margin-bottom: 8vw;
}
.company_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  font-size: 4vw;
  line-height: 2em;
  letter-spacing: 0.08em;
  font-weight: 500;
  color: #0a3191;
  border-bottom: 0.5333333333vw solid #1981ec;
  text-align: center;
}
.company_dl_box:first-child {
  border-top: 0.5333333333vw solid #1981ec;
}
.company_dl_box dt {
  width: 100%;
  background: #f2ffcc;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  padding: 4vw;
  font-weight: 700;
}
.company_dl_box dd {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  padding: 4vw;
}
.company_dl_box dd img {
  width: 70%;
}
.company_dl_box dd img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.googlemap {
  width: 100%;
  height: 80vw;
  border-radius: 8vw;
  overflow: hidden;
}
.googlemap iframe {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border: none;
}

/*--------------------company--------------------*/
/*--------------------qa--------------------*/
.qa {
  width: 100%;
  background: #e5f8ff;
  position: relative;
  z-index: 1;
  margin-top: 21.3333333333vw;
}
.qa::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 100%;
  height: 8vw;
  transform: translate(-50%, -100%);
  background: url(/img/company/wavet.png) no-repeat center center/100% 100%;
}
.qa_dl_box {
  width: 100%;
  padding: 4vw 4vw;
  border: 2.1333333333vw solid #f3ffb7;
  background: #fff;
}
.qa_dl_box:not(:last-child) {
  margin-bottom: 5.3333333333vw;
}
.qa_dl_box dt {
  font-size: 4.8vw;
  line-height: 1.5;
  letter-spacing: 0.05em;
  font-weight: 700;
  color: #0a3191;
  padding-bottom: 1.0416666667em;
  border-bottom: 0.5333333333vw solid #1981ec;
  margin-bottom: 4vw;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4vw;
}
.qa_dl_box dd {
  font-size: 4vw;
  line-height: 1.5;
  letter-spacing: 0.05em;
  font-weight: 700;
  color: #0a3191;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4vw;
}
.qa_dl_box_b {
  width: 5.3333333333vw;
  flex-shrink: 0;
  display: block;
  font-size: 8vw;
  line-height: 1;
  letter-spacing: 0.5em;
  font-weight: 900;
  color: #1981ec;
}
.qa_dl_box_r {
  width: calc(100% - 9.3333333333vw);
}

/*--------------------qa--------------------*/
/*--------------------flow--------------------*/
.flow {
  width: 100%;
  background: #e5f8ff;
  position: relative;
  z-index: 1;
  margin-top: 21.3333333333vw;
}
.flow::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 100%;
  height: 8vw;
  transform: translate(-50%, -100%);
  background: url(/img/company/wavet.png) no-repeat center center/100% 100%;
}
.flow_box {
  width: 100%;
  background: #fff;
  padding: 5.3333333333vw 4vw;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 5.3333333333vw;
  position: relative;
  z-index: 1;
}
.flow_box:not(:last-child) {
  margin-bottom: 16vw;
}
.flow_box:not(:last-child)::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  left: 50%;
  width: 21.3333333333vw;
  height: 13.3333333333vw;
  background: url(/img/flow/arrowbb.png) no-repeat center center/contain;
  transform: translate(-50%, 80%);
}
.flow_img {
  width: 70%;
  height: 57.3333333333vw;
  margin: 0 auto;
}
.flow_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.flow_item {
  width: 100%;
}
.flow_item_ttl {
  text-align: center;
  font-size: 4.8vw;
  line-height: 1.4;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #1981ec;
  background: #f2ffcc;
  padding: 0 4vw 2.6666666667vw 4vw;
  border-radius: 1.3333333333vw;
  overflow: hidden;
  margin-bottom: 4vw;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: center;
}
.flow_item_ttl span {
  width: 60%;
  margin: 0 auto 2.6666666667vw;
  border-bottom-left-radius: 2.6666666667vw;
  border-bottom-right-radius: 2.6666666667vw;
  text-align: center;
  padding: 1.3333333333vw 1.3333333333vw;
  background: #1981ec;
  font-size: 8vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #fff;
}
/*--------------------flow--------------------*/
/*--------------------rone--------------------*/
.refound {
  width: 100%;
  background: #e5f8ff;
  position: relative;
  z-index: 1;
  overflow: hidden;
  margin-top: 10.6666666667vw;
}
.refound::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 100%;
  height: 8vw;
  transform: translate(-50%, 0%);
  background: url(/img/company/wavet.png) no-repeat center center/100% 100%, #fff;
}
.refound_ttl {
  font-size: 6.1333333333vw;
  line-height: 1.7;
  letter-spacing: 0.06em;
  font-weight: 900;
  color: #0a3191;
}
.refound_ttl span {
  margin-right: 1.3333333333vw;
}
.refound_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8vw;
  position: relative;
  z-index: 1;
}
.refound_img {
  width: 100%;
  height: 64vw;
}
.refound_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.refound_box {
  width: 100%;
}
.refound_box p span {
  font-weight: 700;
}
.refound_box p:not(:last-child) {
  margin-bottom: 5.3333333333vw;
}

.merit {
  width: 100%;
  background: url(/img/rone/decolt.png) no-repeat left top/20%, url(/img/rone/decorb.png) no-repeat right bottom/20%;
}
.merit_ttl {
  font-size: 6.1333333333vw;
  line-height: 1.7;
  letter-spacing: 0.06em;
  font-weight: 900;
  color: #0a3191;
}
.merit_ttl span {
  background: #e5f8ff;
  margin-left: 1.3333333333vw;
}
.merit_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 10.6666666667vw;
}
.merit_box {
  width: 100%;
}
.merit_box_ttl {
  width: 100%;
  background: #f2ffcc;
  font-size: 5.3333333333vw;
  line-height: 1.5;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #1981ec;
  padding: 2.6666666667vw 2.1333333333vw;
  text-align: center;
  margin-bottom: 4vw;
}
.merit_img {
  width: 60%;
  margin: 0 auto 8vw;
  text-align: center;
}
.merit_txt {
  padding: 0 10px;
}

.support {
  width: 100%;
  background: #e5f8ff;
  position: relative;
  z-index: 1;
}
.support::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: -7%;
  right: 27%;
  width: 26.6666666667vw;
  height: 37.3333333333vw;
  background: url(/img/rone/ill03.png) no-repeat center center/contain;
  transform: translate(50%, 0%);
}
.support::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 100%;
  height: 8vw;
  transform: translate(-50%, 0%);
  background: url(/img/company/wavet.png) no-repeat center center/100% 100%, #fff;
}
.support_ttl {
  font-size: 6.1333333333vw;
  line-height: 1.7;
  letter-spacing: 0.06em;
  font-weight: 900;
  color: #0a3191;
}
.support_ttl span {
  margin-left: 1.3333333333vw;
}
.support_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 5.3333333333vw;
}
.support_flex:nth-child(even) {
  flex-direction: row-reverse;
}
.support_flex:not(:last-child) {
  margin-bottom: 13.3333333333vw;
}
.support_img {
  width: 100%;
  height: 57.3333333333vw;
}
.support_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.support_box {
  width: 100%;
}
.support_box_ttl {
  font-size: 5.3333333333vw;
  text-align: center;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #1981ec;
  background: #f2ffcc;
  padding: 2.6666666667vw 4vw;
  margin-bottom: 4vw;
}

.area {
  width: 100%;
}
.area_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8vw;
}
.area_img {
  width: 100%;
  height: 84.8vw;
}
.area_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.area_box {
  width: 100%;
  text-align: center;
}
.area_ttl {
  margin-bottom: 12vw;
}
.area_ttl span {
  background: #e5f8ff;
}
.area_txt {
  margin-bottom: 5.3333333333vw;
  font-size: 4.8vw;
  line-height: 1.5;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #1981ec;
  padding-bottom: 5.8666666667vw;
  border-bottom: 0.5333333333vw solid #0a3191;
  text-align: center;
  display: inline-block;
}
.area_txt_c {
  color: #0a3191;
}
.area_txt_b {
  font-size: 5.8666666667vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #0a3191;
  background: #f2ffcc;
  padding: 0 1.3333333333vw;
}

/*--------------------rone--------------------*/
/*--------------------index--------------------*/
.happy {
  width: 100%;
  position: relative;
  z-index: 2;
  padding-top: 26.6666666667vw;
  background: #e5f8ff;
}
.happy::after {
  content: "";
  position: absolute;
  z-index: -2;
  bottom: 0%;
  left: 50%;
  width: 40vw;
  height: 26.6666666667vw;
  transform: translate(-50%, 20%);
  background: url(/img/top/ill02.png) no-repeat center center/contain;
}
.happy::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 100%;
  height: 8vw;
  transform: translate(-50%, 0%);
  background: url(/img/company/wavet.png) no-repeat center center/100% 100%, #fff;
}
.happy_ttl {
  font-size: 6.1333333333vw;
  padding: 0 4vw;
  line-height: 1.7;
  letter-spacing: 0.06em;
  font-weight: 900;
  color: #0a3191;
}
.happy_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  flex-direction: row-reverse;
  gap: 8vw;
  position: relative;
  z-index: 1;
  padding: 0 4vw;
}
.happy_img {
  width: 100%;
  height: 63.4666666667vw;
}
.happy_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.happy_box {
  width: 100%;
}
.happy_box p span {
  font-weight: 700;
}
.happy_box p:not(:last-child) {
  margin-bottom: 5.3333333333vw;
}

.top_movie {
  width: 100%;
  padding: 26.6666666667vw 0 53.3333333333vw;
  background: url(/img/top/bgmovie.png) no-repeat center center/cover;
}
.top_movie_box {
  width: 90%;
  height: 51.4666666667vw;
  background: #000;
  border: 1.0666666667vw solid #1981ec;
  border-radius: 8vw;
  overflow: hidden;
  margin: 0 auto;
}
.top_movie_box iframe {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.check {
  width: 100%;
  padding-top: 0;
  border-top: 1.6vw solid #77c0f8;
  border-bottom: 1.6vw solid #77c0f8;
}
.check_ttl {
  width: 90%;
  margin: -16vw auto 8vw;
  background: url(/img/top/boxbg.png) no-repeat center center/cover;
  position: relative;
  z-index: 1;
  padding: 13.3333333333vw 0 13.3333333333vw;
  font-size: 6.4vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 900;
  color: #0a3191;
}
.check_ttl::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 3%;
  width: 13.3333333333vw;
  height: 14.9333333333vw;
  background: url(/img/top/ill04.png) no-repeat center center/contain;
  transform: translate(0%, -30%);
}
.check_ttl::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: -2%;
  right: 3%;
  width: 10.6666666667vw;
  height: 21.3333333333vw;
  background: url(/img/top/ill05.png) no-repeat center center/contain;
  transform: translate(0%, -30%);
}
.check_ttl span {
  font-size: 5.3333333333vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #fff;
  background: #1981ec;
  border-radius: 999px;
  display: block;
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.check_txt {
  width: 94%;
  margin: 0 auto;
  text-align: center;
}
.check_contact {
  width: 100%;
  margin: 0 auto;
  background: #f2ffcc;
  padding: 8vw 4vw;
}
.check_contact_ttl {
  width: 100%;
  background: #fff;
  font-size: 5.3333333333vw;
  line-height: 1.4;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #1981ec;
  padding: 4vw;
  text-align: center;
  margin-bottom: 5.3333333333vw;
}
.check_contact_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 5.3333333333vw;
  margin-bottom: 2.6666666667vw;
}
.check_contact_txt {
  text-align: center;
}
.check .footer_tel {
  margin: 0;
}

.info {
  width: 90%;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.info::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  left: 2%;
  width: 26.6666666667vw;
  height: 10.6666666667vw;
  transform: translate(0%, 50%);
  background: url(/img/top/fill01.png) no-repeat center center/contain;
}
.info::after {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  right: 2%;
  width: 26.6666666667vw;
  height: 21.3333333333vw;
  transform: translate(0%, 50%);
  background: url(/img/top/fill01.png) no-repeat center center/contain;
}
.info_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8vw;
}
.info_box {
  width: 100%;
  height: 53.3333333333vw;
  position: relative;
  z-index: 1;
  border: 0.8vw solid #1981ec;
}
.info_box:nth-child(1) {
  background: url(/img/top/iimg01.png) no-repeat center center/cover;
}
.info_box:nth-child(1) .info_ttl::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 15.4666666667vw;
  height: 24vw;
  transform: translate(-50%, -90%);
  background: url(/img/top/iill01.png) no-repeat center center/contain;
}
.info_box:nth-child(2) {
  background: url(/img/top/iimg02.png) no-repeat center center/cover;
}
.info_box:nth-child(2) .info_ttl::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 45.8666666667vw;
  height: 17.8666666667vw;
  transform: translate(-50%, -80%);
  background: url(/img/top/iill02.png) no-repeat center center/contain;
}
.info_box:nth-child(3) {
  background: url(/img/top/iimg03.png) no-repeat center center/cover;
}
.info_box:nth-child(3) .info_ttl::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 29.8666666667vw;
  height: 23.4666666667vw;
  transform: translate(-50%, -90%);
  background: url(/img/top/iill03.png) no-repeat center center/contain;
}
.info_ttl {
  position: absolute;
  z-index: -1;
  bottom: 0%;
  left: 50%;
  transform: translate(-50%, -30%);
  background: #0a3191;
  padding: 4vw;
  border-radius: 999px;
  width: 90%;
  text-align: center;
}
.info_ttl::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 4vw;
  width: 4.5333333333vw;
  height: 5.0666666667vw;
  transform: translate(0%, -50%);
  background: url(/img/top/arrowi.png) no-repeat center center/contain;
}
.info_ttl span {
  font-size: 5.3333333333vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #fff;
}

.top_news {
  width: 100%;
  background: #e5f8ff;
}
.top_news_inner {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 10.6666666667vw;
}
.top_news_ttl {
  font-size: 7.4666666667vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 900;
  color: #0a3191;
  text-align: center;
}
.top_news_box {
  width: 100%;
}
.top_news_btn {
  width: 100%;
  background: #0a3191;
  padding: 5.3333333333vw;
  border-radius: 999px;
}
.top_news_btn p {
  font-size: 4vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #fff;
  text-align: center;
}
.top_news_post {
  width: 100%;
}

/*--------------------index--------------------*/
/*--------------------ent--------------------*/
.ent {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: center;
  margin-top: 8vw;
  gap: 5.3333333333vw;
  margin-bottom: 8vw;
}
.ent_left {
  width: 94%;
  height: 93.3333333333vw;
  background: url(/img/ent/enimg01.png) no-repeat center center/cover;
  position: relative;
  z-index: 1;
  margin: 0 auto;
}
.ent_left_txt {
  width: 80%;
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.ent_right {
  width: 94%;
}
.ent_right_txt {
  width: 80%;
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.ent_right_box01 {
  width: 100%;
  height: 53.3333333333vw;
  background: url(/img/ent/enimg02.png) no-repeat center center/cover;
  margin-bottom: 5.3333333333vw;
  position: relative;
  z-index: 1;
}
.ent_right_box02 {
  width: 100%;
  height: 53.3333333333vw;
  background: url(/img/ent/enimg03.png) no-repeat center center/cover;
  position: relative;
  z-index: 1;
}

/*--------------------ent--------------------*/
.sub_ttl {
  font-size: 7.4666666667vw;
  line-height: 1;
  letter-spacing: 0.05em;
  font-weight: 700;
  color: #0a3191;
}/*# sourceMappingURL=style_sp.css.map */