@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap");
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Arsenal:ital,wght@0,400;0,700;1,400;1,700&family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Noto+Sans+JP&family=Nunito:ital,wght@0,200..1000;1,200..1000&display=swap');

.l-main {
  margin-top: 6.5vw;
}
@media only screen and (max-width: 768px) {
  .l-main {
    margin-top: 13.8vw;
  }
}

.pcOnly { display: block !important;}
.spOnly { display: none !important;}

@media only screen and (max-width: 768px) {
  .pcOnly { display: none !important;}
  .spOnly { display: block !important;}
}

.main_kv {
  position: relative;
}
.main_kv .main_ttl {
  position: absolute;
  left: 20.3vw;
  top: 8.07vw;
  width: 26.4vw;
  left: 42vw;
  top: 10vw;
  width: 15vw;
}
.main_kv .main_txt {
  position: absolute;
  right: 17.7vw;
  bottom: -4.6875vw;
  width: max-content;
  height: 14.0vw;
  background: url(../img/index/line.png) no-repeat bottom center;
  background-size: auto 11.6vw;
  font-size: 1.04vw;
  font-weight: 500;
  text-align: center;
  color: #fff;
}
@media only screen and (max-width: 768px) {
  .main_kv {
    overflow: hidden;
  }
  .main_kv .main_ttl {
    left: 25vw;
    top: 41.6vw;
    width: 33.8vw;
    left: 34vw;
    top: 49vw;
    width: 34vw;
  }
  .main_kv .main_txt {
    left: 0;
    right: 0;
    bottom: 30.5vw;
    margin: auto;
    height: 11.1vw;
    background: url(../img/index/arrow.png) no-repeat bottom center;
    background-size: auto 2.2vw;
    font-size: 3.3vw;
  }
}

.l-main .index_h3_cell {
  padding: 0rem 0 3.125vw;
  margin: 0 auto;
}
.l-main .index_cell01 .index_h3_cell {
  padding: 0rem 0 1.05vw;
}
.l-main .index_h3_cell h3 {
  text-align: center;
  font-size: 2.9vw;
  font-weight: 400;
  line-height: 1.5;
  margin: 0 auto 1.1vw;
  font-family: "Yu Mincho", "游明朝", "YuMincho", "Hiragino Mincho ProN", "ヒラギノ明朝 ProN W3", serif;
  letter-spacing: 0.06em;
}
.l-main .index_h3_cell p {
  text-align: center;
  color: #0050A5;
  font-size: 1.6vw;
  margin: 0 auto;
  line-height: 1;
  font-family: "Arsenal", sans-serif;
  font-weight: 400;
}
@media only screen and (max-width: 768px) {
  .l-main .index_h3_cell {
    padding: 0rem 0 10.5vw;
    margin: 0 auto;
  }
  .l-main .index_h3_cell h3 {
    font-size: 5.0vw;
    margin: 0 auto 3.3vw;
  }
  .l-main .index_h3_cell p {
    font-size: 3.3vw;
  }
}

.index_lead {
  padding: 6.5vw 0 1.08vw;
}
.index_lead p {
  font-size: 1.56vw;
  line-height: 1.8;
  color: #0050A5;
  margin: 0 auto 3.6vw;
  width: 36.4vw;
  width: auto;
  font-weight: 500;
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.index_lead p:last-of-type {
  margin: 0 auto 0vw;
}
@media only screen and (max-width: 768px) {
  .index_lead {
    padding: 9.7vw 0 25vw;
  }
  .index_lead p {
    font-size: 3.3vw;
    line-height: 2.0;
    margin: 0 auto 8.3vw;
    width: 75vw;
    width: auto;
  }
  .index_lead p:last-of-type {
    margin: 0 auto 0vw;
  }
}

.index_cell01 {
  padding: 9.6875vw 0 8.07vw;
  background: url(../img/common/line.png) no-repeat bottom center;
  background-size: 100% auto;
}
.index_cell01_box {
  background: #00FF0033;
  background: none;
  margin: 8vw auto;
  width: 80vw;
  display: flex;
  flex-direction: row-reverse;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
  align-content: stretch;
}
.index_cell01 .img02 {
  background: #0000FF33;
  background: none;
  width: 20vw;
  margin: 0 auto 1.25vw;
  margin: 0;
}
.index_cell01 .img02 img {
  line-height: 1.0;
}
.index_cell01 .index_txt01 {
  background: #FF000033;
  background: none;
  font-size: 1.25vw;
  line-height: 2.0;
  margin: 0 auto 6.25vw;
  margin: 0 2vw 0 0;
  width: 41.66vw;
  width: 40vw;
  color: #474C52;
  text-align: left;
}
@media only screen and (max-width: 768px) {
  .index_cell01 {
    padding: 16.6vw 0 31.9vw;
    background: url(../img/common/line_sp.png) no-repeat bottom center;
    background-size: 100% auto;
  }
  .index_cell01 .img02 {
    width: 83.3vw;
    margin: 0 auto 8.88vw;
  }
  .index_cell01 .index_txt01 {
    font-size: 3.3vw;
    line-height: 2.0;
    margin: 0 auto 9.72vw;
    width: 83.3vw;
  }
}

.index_cell02 {
  padding: 7.03vw 0 0;
}
.index_cell02 .index_txt02 {
  font-size: 1.875vw;
  line-height: 2.0;
  color: #0050A5;
  margin: 0 auto 2.86vw;
  font-weight: 500;
  font-family: "Yu Mincho", "游明朝", "YuMincho", "Hiragino Mincho ProN", "ヒラギノ明朝 ProN W3", serif;
}
.index_cell02 .img03 {
  margin-top: -7.55vw;
}
@media only screen and (max-width: 768px) {
  .index_cell02 {
    padding: 10.0vw 0 0;
  }
  .index_cell02 .index_txt02 {
    font-size: 3.3vw;
    line-height: 1.66;
    margin: 0 auto 8.33vw;
  }
  .index_cell02 .img03 {
    margin-top: 0vw;
  }
}

.index_cell03 {
  padding: 7.8125vw 0 0;
  position: relative;
  z-index: 3;
}
.index_cell02 .img03 {
  margin-top: -7.55vw;
}
@media only screen and (max-width: 768px) {
  .index_cell03 {
    padding: 8.8vw 0 0;
  }
  .index_cell02 .img03 {
    margin-top: 0vw;
  }
}

.index_cell04 {
  padding: 21.04vw 0 8.3vw;
  margin-top: -11.9vw;
  position: relative;
  z-index: 1;
  background: #EBF4FF;
}
.index_cell04 .flcell {
  margin: 0 auto 2.86vw;
  width: 83.3vw;
  display: flex;
  justify-content: space-between;
}
.index_cell04 .fleft {
  width: 40%;
}
.index_cell04 .fleft h3 {
  font-size: 1.66vw;
  font-weight: 400;
  line-height: 1;
  margin: 0 0 1.3vw;
  color: #0050A5;
  text-align: left;
  font-family: "Arsenal", sans-serif;
}
.index_cell04 .fleft h4 {
  font-size: 2.08vw;
  line-height: 1;
  margin: 0 0 1.4vw;
  color: #000;
  text-align: left;
  font-family: "Yu Mincho", "游明朝", "YuMincho", "Hiragino Mincho ProN", "ヒラギノ明朝 ProN W3", serif;
}
.index_cell04 .fleft .index_txt03 {
  font-size: 1.04vw;
  line-height: 2.0;
  margin: 0 0 2.3vw;
  color: #000;
  text-align: left;
}
.index_cell04 .fleft .index_txt03:last-of-type {
  margin: 0 0 0vw;
}
.index_cell04 .fright {
  width: 60%;
}
@media only screen and (max-width: 768px) {
  .index_cell04 {
    padding: 28.8vw 0 8.3vw;
    margin-top: -12.7vw;
  }
  .index_cell04 .flcell {
    margin: 0 auto 2.86vw;
    width: 83.3vw;
    flex-direction: column;
  }
  .index_cell04 .fleft {
    width: 100%;
    margin-bottom: 8.8vw;
  }
  .index_cell04 .fleft h3
  {
    font-size: 3.3vw;
    margin: 0 0 4.3vw;
  }
  .index_cell04 .fleft h4 {
    font-size: 5.5vw;
    margin: 0 0 4.4vw;
    font-family: inherit;
  }
  .index_cell04 .fleft .index_txt03 {
    font-size: 3.3vw;
    margin: 0 0 8.8vw;
    color: #474C52;
  }
  .index_cell04 .fleft .index_txt03:last-of-type {
    margin: 0 0 0vw;
  }
  .index_cell04 .fright {
    width: 100%;
  }
}

/* btn */
.btn_viewmore {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: max-content;
  height: 4.6vw;
  padding: 0vw 7.29vw 0vw 3.125vw;
  margin: 0 auto;
  font-size: 1.6vw;
  line-height: 1;
  color: #0050A5;
  text-decoration: none;
  border: 2px solid #0050A5;
  border-radius: 1.66vw;
  font-family: "Arsenal", sans-serif;
}
.btn_viewmore:after {
  display: block;
  position: absolute;
  content: "";
  width: 1.25vw;
  height: 1.25vw;
  right: 4.79vw;
  top: 0;
  bottom: 0;
  margin: auto;
  background: url(../img/common/icon_btn_viewmore.png) no-repeat;
  background-size: 100% 100%;
}
.btn_blue {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: max-content;
  height: 4.6vw;
  padding: 0vw 5.2vw 0vw 2.86vw;
  margin: 0 auto;
  font-size: 1.25vw;
  font-weight: 500;
  line-height: 1;
  color: #fff;
  text-decoration: none;
  border: 2px solid #0050A5;
  background: #0050A5;
  border-radius: 1.66vw;
}
.btn_blue:after {
  display: block;
  position: absolute;
  content: "";
  width: 1.25vw;
  height: 1.25vw;
  right: 2.86vw;
  top: 0;
  bottom: 0;
  margin: auto;
  background: url(../img/common/icon_btn_blue.png) no-repeat;
  background-size: 100% 100%;
}
@media only screen and (max-width: 768px) {
  .btn_viewmore {
    height: 10.5vw;
    padding: 0vw 8.88vw 0vw 4.44vw;
    font-size: 3.3vw;
    border-radius: 5.5vw;
  }
  .btn_viewmore:after {
    width: 2.2vw;
    height: 2.2vw;
    right: 4.16vw;
  }
  .btn_blue {
    height: 10.5vw;
    padding: 0vw 10.6vw 0vw 9.72vw;
    font-size: 3.3vw;
    border-radius: 5.5vw;
  }
  .btn_blue:after {
    width: 2.2vw;
    height: 2.2vw;
    right: 6.11vw;
  }
}

#lottie-index {
  position: absolute;
  top: -11.04vw;
  left: 11.7vw;
  width: 45.5vw;
  height: 48.6vw;
  z-index: 1;
  top: -4vw;
  left: 24.5vw;
  width: 50vw;
  height: 52vw;
}
@media only screen and (max-width: 768px) {
  #lottie-index {
    top: 12.5vw;
    left: 0vw;
    width: 76.3vw;
    height: 76.3vw;
	top: 7vw;
    left: -20vw;
    width: 140vw;
    height: 140vw;
  }
}
