@charset "UTF-8";
/*page contents*/
#home .mv {
  width: 100%;
  position: relative;
  overflow: hidden;
  background-color: #E6F2FF;
  height: 527px;
}
@media (max-width: 767px) {
  #home .mv {
    height: 100%;
    padding-top: 1.5em;
  }
}
#home .mv::before {
  content: "";
  position: absolute;
  left: 47%;
  top: -26px;
  display: block;
  width: 725px;
  height: 492px;
  background: url(../img/mv_bg.png) no-repeat 0/contain;
}
@media (max-width: 1024px) {
  #home .mv::before {
    width: 80%;
    left: auto;
    right: -20vw;
  }
}
@media (max-width: 1024px) and (max-width: 767px) {
  #home .mv::before {
    width: 100%;
    left: auto;
    right: -30vw;
    top: -29px;
  }
}
#home .mv .wrap {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  max-width: 1160px;
  padding-left: 40px;
  padding-right: 40px;
}
@media (max-width: 1024px) {
  #home .mv .wrap {
    padding-left: 20px;
    padding-right: 20px;
    width: 100%;
  }
}
#home .mv .wrap {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 15px;
  height: 100%;
  padding-bottom: 135px;
  padding-top: 10px;
}
@media (max-width: 767px) {
  #home .mv .wrap {
    padding-top: 0;
    padding-bottom: 0;
    gap: 1em;
  }
}
#home .mv .wrap .ttl2 {
  font-weight: bold;
  font-size: 3.8rem;
  font-weight: 500;
  -webkit-text-stroke: 18px #E6F2FF; /* 縁の太さと色 */
  paint-order: stroke fill; /* 縁を先に描画して、その上に文字を乗せる */
  stroke-linejoin: round; /* 角を丸くする設定 */
}
@media (max-width: 767px) {
  #home .mv .wrap .ttl2 {
    font-size: 2.8rem;
  }
}
#home .mv .wrap .ttl3 {
  font-weight: bold;
  font-size: 2.4rem;
  font-weight: 700;
}
@media (max-width: 1024px) {
  #home .mv .wrap .ttl3 {
    -webkit-text-stroke: 18px #E6F2FF; /* 縁の太さと色 */
    paint-order: stroke fill; /* 縁を先に描画して、その上に文字を乗せる */
    stroke-linejoin: round; /* 角を丸くする設定 */
  }
}
@media (max-width: 1024px) and (max-width: 767px) {
  #home .mv .wrap .ttl3 {
    font-size: 2rem;
    line-height: 1.5;
    -webkit-text-stroke: 10px #E6F2FF;
  }
}
#home .mv .wrap p {
  font-size: 1.8rem;
  font-weight: 600;
}
@media (max-width: 1024px) {
  #home .mv .wrap p {
    -webkit-text-stroke: 14px #E6F2FF; /* 縁の太さと色 */
    paint-order: stroke fill; /* 縁を先に描画して、その上に文字を乗せる */
    stroke-linejoin: round; /* 角を丸くする設定 */
  }
}
@media (max-width: 1024px) and (max-width: 767px) {
  #home .mv .wrap p {
    font-size: 1.6rem;
    width: 60%;
    -webkit-text-stroke: 12px #E6F2FF;
  }
  #home .mv .wrap p br {
    display: none;
  }
}
#home .mv .wrap a.regist_btn {
  margin-top: 1em;
  display: block;
  width: 334px;
  padding: 1.25em 2em;
  color: #fff;
  font-size: 1.8rem;
  font-weight: 600;
  background-color: #0055A7;
  border: 2px solid #0055A7;
  border-radius: 3em;
  text-align: center;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
@media (max-width: 767px) {
  #home .mv .wrap a.regist_btn {
    font-size: 1.6rem;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 1em auto 0;
    padding: 1em 2em;
  }
}
#home .mv .wrap a.regist_btn:hover {
  opacity: 0.65;
}
#home .mv .wrap a.regist_btn span {
  padding-left: 2.5em;
  position: relative;
}
#home .mv .wrap a.regist_btn span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: auto;
  margin: auto;
  width: 2em;
  height: 1.25em;
  -webkit-mask: url(../img/ic_regist.svg) no-repeat center/contain;
          mask: url(../img/ic_regist.svg) no-repeat center/contain;
  background-color: #fff;
}
#home .topics {
  padding-top: 0;
  margin-top: -135px;
  position: relative;
  padding-bottom: 1em;
}
@media (max-width: 767px) {
  #home .topics {
    margin-top: 0;
  }
}
#home .topics .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  background-color: rgba(255, 255, 255, 0.92);
  border-radius: 1em;
  padding-top: 2.5em;
}
#home .topics .wrap .txt {
  width: 140px;
}
@media (max-width: 767px) {
  #home .topics .wrap .txt {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
#home .topics .wrap .txt .msr {
  font-size: 4.2rem;
  color: #032D42;
}
@media (max-width: 767px) {
  #home .topics .wrap .txt .msr {
    font-size: 2.8rem;
  }
}
#home .topics .wrap .txt .btn1_cmn {
  margin-top: 1em;
  display: inline-block;
}
@media (max-width: 767px) {
  #home .topics .wrap .txt .btn1_cmn {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-top: 0;
  }
}
#home .topics .wrap .news_list_cmn {
  width: calc(100% - 140px);
}
@media (max-width: 767px) {
  #home .topics .wrap .news_list_cmn {
    width: 100%;
  }
}
#home .topics .wrap .news_list_cmn li {
  margin-left: 4em;
  border-bottom: 1px solid #e0e0e0;
}
@media (max-width: 767px) {
  #home .topics .wrap .news_list_cmn li {
    margin-left: 0;
  }
}
#home .about {
  background: url(../img/about_bg.png) no-repeat center top/cover;
  padding-bottom: 9em;
}
@media (max-width: 767px) {
  #home .about {
    padding-top: 2.5em;
    padding-bottom: 8em;
  }
}
#home .about .wrap .ttl2_cmn {
  text-align: center;
}
#home .about .wrap .ttl2_cmn + p {
  text-align: center;
}
#home .about .wrap .cont_wrap {
  margin-top: 3em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
@media (max-width: 1024px) {
  #home .about .wrap .cont_wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media (max-width: 1024px) and (max-width: 767px) {
  #home .about .wrap .cont_wrap {
    margin-top: 1.5em;
  }
}
#home .about .wrap .cont_wrap .txt {
  width: calc(100% - 451px);
  padding-right: 3em;
}
@media (max-width: 1024px) {
  #home .about .wrap .cont_wrap .txt {
    width: 100%;
    padding-right: 0;
    padding-bottom: 3em;
  }
}
@media (max-width: 1024px) and (max-width: 767px) {
  #home .about .wrap .cont_wrap .txt {
    padding-bottom: 2em;
  }
}
#home .about .wrap .cont_wrap .txt .ttl3 {
  font-size: 1.8rem;
  font-weight: 500;
}
#home .about .wrap .cont_wrap .txt p {
  margin-top: 1em;
  font-size: 1.6rem;
}
#home .about .wrap .cont_wrap .img {
  width: 451px;
}
@media (max-width: 767px) {
  #home .about .wrap .cont_wrap .img {
    width: 100%;
    max-width: 335px;
  }
}
#home .search .wrap .link_btn_cmn {
  margin-top: 3em;
}
@media (max-width: 767px) {
  #home .search .wrap .link_btn_cmn {
    margin-top: 1.5em;
  }
}
#home .search .wrap .link_btn_cmn a {
  background-color: #E6F2FF;
}
#home .search .wrap .link_btn_cmn a:hover {
  background-color: #fff;
}
#home .search .wrap .link_btn_cmn a p {
  padding-bottom: 1em;
}
@media (max-width: 767px) {
  #home .search .wrap .link_btn_cmn a p {
    padding-bottom: 0.5em;
  }
}
#home .open-innovation {
  background-color: #F8F9FA;
}
#home .open-innovation .wrap .link_btn_cmn {
  margin-top: 4em;
}
@media (max-width: 767px) {
  #home .open-innovation .wrap .link_btn_cmn {
    margin-top: 2em;
  }
}
#home .open-innovation .wrap .desc {
  font-weight: 500;
  font-size: 2.8rem;
  margin-top: 3em;
}
@media (max-width: 767px) {
  #home .open-innovation .wrap .desc {
    font-size: 2.2rem;
    margin-top: 1.5em;
  }
}
#home .open-innovation .wrap .note {
  font-size: 1.6rem;
  margin-top: 1em;
}
@media (max-width: 767px) {
  #home .open-innovation .wrap .note {
    font-size: 1.4rem;
  }
}
#home .access {
  overflow: hidden;
}
#home .access .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media (min-width: 768px) and (max-width: 1024px) {
  #home .access .wrap {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
@media (max-width: 767px) {
  #home .access .wrap {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
#home .access .wrap > .txt {
  width: calc(100% - 435px);
  padding-right: 4em;
}
@media (min-width: 768px) and (max-width: 1024px) {
  #home .access .wrap > .txt {
    width: 55%;
    padding-right: 0;
  }
}
@media (max-width: 767px) {
  #home .access .wrap > .txt {
    width: 100%;
    padding-right: 0;
  }
}
#home .access .wrap .img {
  width: 435px;
  position: relative;
  padding-bottom: 60px;
}
@media (min-width: 768px) and (max-width: 1024px) {
  #home .access .wrap .img {
    width: 40%;
  }
}
@media (max-width: 767px) {
  #home .access .wrap .img {
    width: 60%;
    margin: 2em auto 0;
    max-width: 200px;
    padding-bottom: 0;
  }
}
#home .access .wrap .img img {
  position: relative;
}
#home .access .wrap .img::before {
  content: "";
  position: absolute;
  right: -60px;
  bottom: 0;
  display: block;
  width: 399px;
  height: 316px;
  border-radius: 1em;
  background-image: -webkit-gradient(linear, left top, right top, color-stop(0, #00BAFF), to(#0055A7));
  background-image: linear-gradient(to right, #00BAFF 0, #0055A7 100%);
}
@media (min-width: 768px) and (max-width: 1024px) {
  #home .access .wrap .img::before {
    width: 100%;
  }
}
@media (max-width: 767px) {
  #home .access .wrap .img::before {
    width: 100%;
    height: 50%;
    right: -20px;
    bottom: -20px;
    border-radius: 0.25em;
  }
}
#home .access .name {
  font-size: 2rem;
  font-weight: 500;
  margin-top: 2.5em;
}
@media (max-width: 767px) {
  #home .access .name {
    margin-top: 1em;
  }
}
#home .access .note {
  font-size: 1.4rem;
  margin-top: 1.25em;
}
#home .access .note a {
  text-decoration: underline;
}
#home .access .note a:hover {
  color: #0055A7;
}
#home .access address {
  margin-top: 3em;
  font-size: 1.4rem;
  line-height: 2.25;
}
@media (max-width: 767px) {
  #home .access address {
    margin-top: 1em;
  }
}
#home .access .map_btn a {
  font-size: 1.8rem;
  font-weight: 600;
  color: #032D42;
  margin-top: 2em;
  border: 1px solid #707070;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 4em;
  padding: 1em 4em;
}
@media (max-width: 767px) {
  #home .access .map_btn a {
    font-size: 1.6rem;
    margin-top: 1.5em;
  }
}
#home .access .map_btn a:hover {
  background-color: #707070;
  color: #fff;
}/*# sourceMappingURL=top.css.map */