.home-heading {
  margin-bottom: 20px;
  font-size: 4.5rem;
  text-align: center;
  font-weight: 700;
  color: #19228d;
}
@media screen and (max-width: 750px) {
  .home-heading {
    font-size: 3rem;
  }
}

.home-lead {
  margin-bottom: 60px;
  font-size: 2rem;
  text-align: center;
}
@media screen and (max-width: 750px) {
  .home-lead {
    font-size: 1.8rem;
  }
}

.home-top {
  display: flex;
  align-items: center;
  -moz-column-gap: 30px;
       column-gap: 30px;
  margin-bottom: 50px;
}
@media screen and (max-width: 750px) {
  .home-top {
    display: block;
    margin-bottom: 0;
  }
}
.home-top .home-heading {
  margin-bottom: 0;
  font-size: 5.8rem;
  text-align: left;
  font-weight: 700;
  color: #1f1f1f !important;
}
@media screen and (max-width: 750px) {
  .home-top .home-heading {
    margin-bottom: 20px;
    font-size: 3rem;
    text-align: center;
  }
}
.home-top .home-heading::first-letter {
  color: #19228d;
}
.home-top .home-lead {
  flex: 1;
  margin-bottom: 0;
  text-align: left;
}
@media screen and (max-width: 750px) {
  .home-top .home-lead {
    margin-bottom: 60px;
    text-align: center;
  }
}

.home-mainimg {
  position: relative;
}
.home-mainimg .mainimg-main {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  padding-block: 45px;
  background: rgba(25, 34, 141, 0.7);
}
@media screen and (max-width: 750px) {
  .home-mainimg .mainimg-main {
    position: static;
    padding-block: 9.2307692308%;
    background-color: #19228d;
  }
}
.home-mainimg .mainimg-con {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 750px) {
  .home-mainimg .mainimg-con {
    display: block;
  }
}
.home-mainimg .mainimg-copy {
  position: absolute;
  top: 0;
  left: 0;
  margin-top: -4em;
  padding: 10px 2em;
  background-color: #afe4f6;
  font-size: 1.7rem;
  text-align: center;
  border-radius: 2em;
  line-height: 1;
}
@media screen and (max-width: 750px) {
  .home-mainimg .mainimg-copy {
    font-size: 1.2rem;
  }
}
.home-mainimg .mainimg-heading span {
  padding: 5px 1em;
  background-color: #fff;
  font-size: 2.7rem;
  font-weight: 700;
}
@media screen and (max-width: 750px) {
  .home-mainimg .mainimg-heading span {
    padding-inline: 0.5em;
    font-size: 1.8rem;
  }
}
.home-mainimg .mainimg-logo {
  width: 100%;
  max-width: 436px;
}
@media screen and (max-width: 750px) {
  .home-mainimg .mainimg-logo {
    width: 93.8461538462%;
    max-width: 100%;
    margin: 7.6923076923% auto 0;
  }
}

.home-nav {
  padding: 65px 0 90px;
}
@media screen and (max-width: 750px) {
  .home-nav {
    padding-block: 60px;
  }
}
.home-nav ul {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 30px;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
}
@media screen and (max-width: 750px) {
  .home-nav ul {
    grid-template-columns: 1fr 1fr;
    gap: 20px 6.1538461538%;
  }
}
.home-nav ul li a {
  display: block;
  text-decoration: none;
  height: 100%;
  padding: 1px;
  background: linear-gradient(to right, #92cdd7, #2a5ded);
  border-radius: 1em;
  box-shadow: 0 0 20px 0px rgba(0, 0, 0, 0.2);
  overflow: hidden;
}
@media screen and (max-width: 750px) {
  .home-nav ul li a {
    box-shadow: 0 0 10px 0px rgba(0, 0, 0, 0.2);
  }
}
.home-nav ul li a div {
  height: 100%;
  padding: 20px 20px 40px;
  background-color: #fff;
  border-radius: 1em;
}
@media screen and (max-width: 750px) {
  .home-nav ul li a div {
    padding: 16.2866449511% 6.5146579805% 9.7719869707%;
  }
}
.home-nav ul li a figure {
  margin-bottom: 20px;
  text-align: center;
}
@media screen and (max-width: 750px) {
  .home-nav ul li a figure {
    width: 40%;
    margin: 0 auto 20px;
  }
}
.home-nav ul li a dl dt {
  margin-bottom: 10px;
  font-size: 2.2rem;
  font-weight: 700;
  color: #19228d;
  text-align: center;
}
@media screen and (max-width: 750px) {
  .home-nav ul li a dl dt {
    font-size: 1.6rem;
  }
}
.home-nav ul li a dl dd {
  font-size: 1.5rem;
  text-align: center;
}
@media screen and (max-width: 750px) {
  .home-nav ul li a dl dd {
    font-size: 1.2rem;
  }
}

.home-news {
  padding: 70px 0 80px;
  background-color: #e0ebf5;
}
@media screen and (max-width: 750px) {
  .home-news {
    padding-block: 60px;
  }
}
.home-news .home-top {
  justify-content: space-between;
}
.home-news .news-btn {
  width: 100%;
  max-width: 235px;
}
@media screen and (max-width: 750px) {
  .home-news .news-btn {
    margin: 40px auto 0;
  }
}
.home-news .news-btn a {
  position: relative;
  display: block;
  text-decoration: none;
  padding: 10px;
  background: linear-gradient(to right, #92cdd7, #2a5ded);
  font-size: 1.4rem;
  font-weight: 700;
  text-align: center;
  color: #fff;
  border-radius: 2em;
}
.home-news .news-btn a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 4px;
  height: 9px;
  margin-top: -4.5px;
  margin-right: 10px;
  background: url("../img/common/ico_arrow_w.svg");
}
.home-news .news-main {
  position: relative;
  padding: 25px 50px;
  background-color: #fff;
  border-radius: 1em;
  overflow: hidden;
}
.home-news .news-main .slide-btn {
  z-index: 99;
  position: absolute;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 100%;
  background-color: #fff;
}
.home-news .news-main .slide-btn img {
  width: 8px;
}
.home-news .news-main .slide-btn._prev {
  left: 0;
}
.home-news .news-main .slide-btn._next {
  right: 0;
}
.home-news .news-main .c-newslist li a {
  padding: 0 10px 30px;
  border-right: 1px solid #c9c9c9;
}

.home-data {
  padding: 90px 0 100px;
  background-color: #f6f9fc;
}
@media screen and (max-width: 750px) {
  .home-data {
    padding-block: 60px;
  }
}
.home-data .data-main {
  position: relative;
  margin-bottom: 40px;
  padding: 40px 100px 100px;
  background-color: #e5ecfa;
  border-radius: 10px;
}
@media screen and (max-width: 980px) {
  .home-data .data-main {
    padding-inline: 50px;
  }
}
@media screen and (max-width: 750px) {
  .home-data .data-main {
    padding: 40px;
  }
}
.home-data .data-main .data-fig {
  position: absolute;
  right: 0;
  margin-right: 7.5%;
}
@media screen and (max-width: 750px) {
  .home-data .data-main .data-fig {
    position: static;
    margin: 0 auto;
  }
}
.home-data .data-main .data-fig._fig01 {
  top: 0;
  width: 34.4166666667%;
  margin-top: -5.8333333333%;
}
@media screen and (max-width: 750px) {
  .home-data .data-main .data-fig._fig01 {
    width: 100%;
  }
}
.home-data .data-main .data-fig._fig02 {
  bottom: 0;
  width: 37.4166666667%;
}
@media screen and (max-width: 750px) {
  .home-data .data-main .data-fig._fig02 {
    width: 100%;
  }
}
.home-data .data-main .data-box .data-txt {
  display: inline-block;
  margin-bottom: 20px;
  padding: 5px 1em;
  background-color: #19228d;
  font-size: 1.5rem;
  font-weight: 700;
  text-align: center;
  color: #fff;
  border-radius: 2em;
  line-height: 1;
}
.home-data .data-main .data-box .data-heading {
  margin-bottom: 20px;
  font-size: 5.7rem;
  font-weight: 700;
  color: #19228d;
  line-height: 1.4;
}
@media screen and (max-width: 750px) {
  .home-data .data-main .data-box .data-heading {
    font-size: 2.7rem;
  }
}
.home-data .data-main .data-box .data-lead {
  margin-bottom: 20px;
  font-size: 2.1rem;
  color: #19228d;
  line-height: 1.8;
}
@media screen and (max-width: 750px) {
  .home-data .data-main .data-box .data-lead {
    font-size: 1.8rem;
  }
}
.home-data .data-main .data-box .data-btn {
  width: 100%;
  max-width: 344px;
}
@media screen and (max-width: 750px) {
  .home-data .data-main .data-box .data-btn {
    max-width: 100%;
    margin-bottom: 40px;
  }
}
.home-data .data-main .data-box .data-btn a {
  display: block;
  text-decoration: none;
  padding: 15px 30px;
  background: #19228d url("../img/common/ico_link_w.svg") no-repeat right 15px center;
  background-size: 15px auto;
  font-size: 2rem;
  font-weight: 700;
  text-align: center;
  color: #fff;
  border-radius: 2em;
}
@media screen and (max-width: 750px) {
  .home-data .data-main .data-box .data-btn a {
    font-size: 1.8rem;
  }
}
.home-data .data-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
}
@media screen and (max-width: 750px) {
  .home-data .data-list {
    grid-template-columns: 1fr;
  }
}
.home-data .data-list li a {
  display: block;
  text-decoration: none;
  height: 100%;
  padding: 25px;
  border: 1px solid #e5ecfa;
  background-color: #fff;
  box-shadow: 4px 4px 5px 0px rgba(0, 0, 0, 0.3);
  border-radius: 10px;
}
.home-data .data-list li dl dt {
  margin-bottom: 30px;
}
.home-data .data-list li dl dt .ico-data {
  width: 2.3rem;
  margin-right: 20px;
}
.home-data .data-list li dl dt .ico-data::before {
  content: url("../img/home/data_i001.svg");
}
.home-data .data-list li dl dt span {
  font-size: 2.7rem;
  font-weight: 700;
}
@media screen and (max-width: 750px) {
  .home-data .data-list li dl dt span {
    font-size: 2rem;
  }
}
.home-data .data-list li dl dt .ico-link {
  width: 1.5rem;
  margin-left: 1em;
}
.home-data .data-list li dl dd {
  font-size: 1.8rem;
}

.home-site {
  padding-block: 100px;
}
@media screen and (max-width: 750px) {
  .home-site {
    padding-block: 60px;
  }
}
.home-site .home-heading {
  margin-bottom: 50px;
}
.home-site .site-list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 70px 25px;
}
@media screen and (max-width: 750px) {
  .home-site .site-list {
    grid-template-columns: 1fr 1fr;
  }
}
.home-site .site-list li a {
  display: block;
  text-decoration: none;
}
.home-site .site-list li a figure {
  position: relative;
}
.home-site .site-list li a figure::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 31px;
  height: 31px;
  background: url("../img/common/ico_link02.svg");
}
.home-site .site-list li a p {
  margin-top: 10px;
  font-weight: 700;
  text-align: center;
}

.home-mice {
  padding-block: 80px;
  background: linear-gradient(to right, rgba(146, 205, 215, 0.3), rgba(42, 93, 255, 0.3));
}
@media screen and (max-width: 750px) {
  .home-mice {
    padding-block: 60px;
  }
}
.home-mice .mice-list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 30px;
  width: 100%;
  max-width: 890px;
  margin: 0 auto;
}
@media screen and (max-width: 750px) {
  .home-mice .mice-list {
    grid-template-columns: 1fr;
  }
}
.home-mice .mice-list li a {
  display: block;
  text-decoration: none;
  height: 100%;
  padding: 20px 15px;
  border: 1px solid #f6f9fc;
  background-color: #f6f9fc;
  border-radius: 10px;
}
.home-mice .mice-list li a p {
  margin-top: 10px;
}
.home-mice .mice-list li a p .ico {
  margin-left: 0.5em;
}

.home-useful {
  padding: 90px 0 100px;
}
@media screen and (max-width: 750px) {
  .home-useful {
    padding-block: 60px;
  }
}
.home-useful .useful-list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 30px;
  width: 100%;
  max-width: 890px;
  margin: 0 auto;
}
@media screen and (max-width: 750px) {
  .home-useful .useful-list {
    grid-template-columns: 1fr;
  }
}
.home-useful .useful-list li a {
  display: block;
  text-decoration: none;
  height: 100%;
  border: 1px solid #e0ebf5;
  background-color: #f6f9fc;
  border-radius: 10px;
}
.home-useful .useful-list li a dl {
  padding: 20px 20px 40px;
}
.home-useful .useful-list li a dl dt {
  margin-bottom: 15px;
  font-size: 1.8rem;
  font-weight: 700;
  color: #19228d;
}
.home-useful .useful-list li a dl dt._txt1 {
  margin-top: 0.5em;
}
.home-useful .useful-list li a dl dt .ico {
  margin-left: 0.5em;
}
.home-useful .useful-list li a dl dd {
  font-size: 1.4rem;
}
.home-useful .useful-foreigners {
  width: 100%;
  max-width: 1080px;
  margin: 80px auto 0;
  padding: 40px 80px;
  background-color: #e5ecfa;
  border-radius: 1em;
}
@media screen and (max-width: 750px) {
  .home-useful .useful-foreigners {
    padding: 40px;
  }
}
.home-useful .useful-foreigners .useful-heading {
  margin-bottom: 30px;
  text-align: center;
}
.home-useful .useful-foreigners .useful-heading span {
  text-decoration: underline;
  padding-bottom: 10px;
  text-underline-offset: 15px;
  font-size: 3.7rem;
  font-weight: 700;
  color: #19228d;
}
@media screen and (max-width: 750px) {
  .home-useful .useful-foreigners .useful-heading span {
    font-size: 2.7rem;
  }
}/*# sourceMappingURL=home.css.map */