@charset "UTF-8";
/* 横並び
-----------------------------------*/
.com-wrap {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-bottom: 80px;
}
.com-wrap .img {
  width: 48%;
}
@media screen and (max-width: 767px) {
  .com-wrap .img {
    width: 100%;
  }
}
.com-wrap .txt {
  width: 48%;
}
@media screen and (max-width: 767px) {
  .com-wrap .txt {
    width: 100%;
  }
}
.com-wrap.txt-left {
  flex-direction: row-reverse;
}

/* 横並びリスト
-----------------------------------*/
.list-col2,
.list-col3,
.list-col4 {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}

.list-col2 li {
  width: 48%;
  margin-bottom: 24px;
}
.list-col2 li:nth-child(even) {
  margin-left: 4%;
}

.list-col3 li {
  width: 32%;
  margin-bottom: 16px;
  margin-right: 2%;
}
.list-col3 li:nth-child(3n) {
  margin-right: 0;
}

.list-col4 li {
  width: 24%;
  margin-bottom: 16px;
  margin-right: 1.333%;
}
.list-col4 li:nth-child(4n) {
  margin-right: 0;
}

/* リスト、アイコン
-----------------------------------*/
/* リスト（デフォルト） */
.list-df {
  margin-left: 23px;
  list-style: disc;
}

/* リスト（ドット） */
.list-dot li {
  padding-left: 1em;
}

.list-dot li:before {
  content: "・";
  margin-left: -1em;
}

/* リスト（数字） */
.list-num li {
  margin-left: 30px;
}

/*===================================
	アコーディオン体裁
===================================*/
.ac-menu {
  margin-top: 32px;
}
@media screen and (max-width: 858px) {
  .ac-menu {
    margin-top: 24px;
  }
}
.ac-menu button {
  position: relative;
  width: 100%;
  padding: 8px 16px;
  border: 1px solid #CCC;
  background-color: transparent;
  line-height: 1.3;
  text-align: left;
  cursor: pointer;
}
.ac-menu button::after {
  content: "";
  position: absolute;
  width: 24px;
  height: 24px;
  border-top: #fff 4px solid;
  border-right: #fff 4px solid;
  transform: rotate(135deg);
  transition-duration: 0.5s;
  position: absolute;
  right: 0;
  left: 0;
  bottom: 16px;
  margin: 0 auto;
}
.ac-menu button.open::after {
  transform: rotate(-45deg);
}

.ac-cts {
  display: none;
  padding: 16px 24px;
  background-color: #CCC;
}
@media screen and (max-width: 858px) {
  .ac-cts {
    padding: 16px;
  }
}

.feature01 {
  font-size: 16px;
}
.feature01 .catch {
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;
  font-size: 38px;
  text-align: center;
  line-height: 1.2;
  margin: 120px auto 40px;
}
@media screen and (max-width: 767px) {
  .feature01 .catch {
    font-size: 22px;
    line-height: 1.4;
    margin: 0 auto 32px;
  }
}
.feature01 .read {
  margin-top: 48px;
  text-align: center;
}
.feature01 .read .ttl {
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;
  line-height: 1.2;
  display: inline-block;
  margin: 0 auto 64px;
  padding: 0.7em 1.5em 0.6em;
  color: #fff;
  font-size: 28px;
  text-align: center;
  background: #4555aa;
}
@media screen and (max-width: 767px) {
  .feature01 .read .ttl {
    font-size: 20px;
    padding: 0.7em 1em 0.6em;
  }
}
.feature01 .read .bgColor {
  background: #eff3f5 !important;
}
.feature01 .read .box {
  max-width: 930px;
  margin: auto;
  padding: 20px 35px 24px;
  border-radius: 30px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .feature01 .read .box {
    padding: 20px 16px 24px;
  }
}
.feature01 .read .box::before {
  width: 36px;
  height: 45px;
  display: block;
  margin: auto;
  padding: 20px 16px 24px;
  content: "";
  background: url(/assets/images/index/index_ic01.png) no-repeat;
  background-size: 36px;
  background-position: center;
  position: absolute;
  top: -76px;
  right: 0;
  left: 0;
}
.feature01 .read .box .inner dt {
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;
  font-weight: bold;
}
.feature01 .read .box .inner > dt {
  margin-bottom: 20px;
  font-size: 32px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .feature01 .read .box .inner > dt {
    font-size: 20px;
  }
}
.feature01 .read .box .inner > dd {
  justify-content: space-between;
}
.feature01 .read .box .inner .list-box {
  width: 30%;
  background: #fff;
  padding: 32px 16px 16px;
}
@media screen and (max-width: 767px) {
  .feature01 .read .box .inner .list-box {
    width: 100%;
    padding: 32px 24px 16px;
  }
}
@media screen and (max-width: 767px) {
  .feature01 .read .box .inner .list-box:not(:last-child) {
    margin-bottom: 40px;
  }
}
.feature01 .read .box .inner .list-box dt {
  margin: -40px auto 0;
  color: #fff;
  font-size: 24px;
  text-align: center;
  background: #3a9ac2;
  margin-bottom: 16px;
}
@media screen and (max-width: 767px) {
  .feature01 .read .box .inner .list-box dt {
    font-size: 20px;
  }
}
.feature01 .read .box .inner .list-box dd li {
  width: 100%;
  text-align: left;
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .feature01 .read .box .inner .list-box dd li {
    font-size: 14px;
  }
}
.feature01 .read .box h4 {
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;
  margin-top: 1em;
  font-size: 24px;
  text-align: center;
  line-height: 1.7;
}
@media screen and (max-width: 767px) {
  .feature01 .read .box h4 {
    font-size: 20px;
  }
}

.feature02 {
  margin-bottom: 64px;
}
.feature02 .nr {
  margin-bottom: 64px;
}
.feature02 .ac-wrap {
  max-width: 1000px;
  margin: 0 auto;
}
.feature02 .ac-wrap .ac-menu {
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .feature02 .ac-wrap .ac-menu {
    margin-top: 24px;
  }
}
.feature02 .ac-wrap .ac-menu.menu01 {
  background: url(/assets/images/index/feature_bg01.jpg) no-repeat;
  background-position: top center;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .feature02 .ac-wrap .ac-menu.menu01 {
    background: url(/assets/images/index/feature_bg01_sp.jpg) no-repeat;
    background-position: top center;
    background-size: cover;
  }
}
.feature02 .ac-wrap .ac-menu.menu02 {
  background: url(/assets/images/index/feature_bg02.jpg) no-repeat;
  background-position: top center;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .feature02 .ac-wrap .ac-menu.menu02 {
    background: url(/assets/images/index/feature_bg02_sp.jpg) no-repeat;
    background-position: top center;
    background-size: cover;
  }
}
.feature02 .ac-wrap .ac-menu.menu03 {
  background: url(/assets/images/index/feature_bg03.jpg) no-repeat;
  background-position: top center;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .feature02 .ac-wrap .ac-menu.menu03 {
    background: url(/assets/images/index/feature_bg03_sp.jpg) no-repeat;
    background-position: top center;
    background-size: cover;
  }
}
.feature02 .ac-wrap .ac-menu.menu04 {
  background: url(/assets/images/index/feature_bg04.jpg) no-repeat;
  background-position: top center;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .feature02 .ac-wrap .ac-menu.menu04 {
    background: url(/assets/images/index/feature_bg04_sp.jpg) no-repeat;
    background-position: top center;
    background-size: cover;
  }
}
.feature02 .ac-wrap .ac-menu.menu05 {
  background: url(/assets/images/index/feature_bg05.jpg) no-repeat;
  background-position: top center;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .feature02 .ac-wrap .ac-menu.menu05 {
    background: url(/assets/images/index/feature_bg05_sp.jpg) no-repeat;
    background-position: top center;
    background-size: cover;
  }
}
.feature02 .ac-wrap .ac-menu button {
  position: relative;
  width: 100%;
  max-width: 600px;
  height: 160px;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 20px;
  color: #FFF;
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;
  font-size: 24px;
  padding: 24px 32px;
  margin: 0 auto;
  border: none;
}
@media screen and (max-width: 767px) {
  .feature02 .ac-wrap .ac-menu button {
    gap: 8px;
    max-width: 400px;
    height: 115px;
    font-size: 16px;
    padding: 16px 16px 24px;
  }
}
.feature02 .ac-wrap .ac-menu button::after {
  width: 16px;
  height: 16px;
  border-top: #fff 2px solid;
  border-right: #fff 2px solid;
  bottom: 24px;
}
@media screen and (max-width: 767px) {
  .feature02 .ac-wrap .ac-menu button::after {
    bottom: 12px;
  }
}
.feature02 .ac-wrap .ac-menu button .num {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 64px;
  height: 64px;
  font-size: 18px;
  border-radius: 50%;
  background: linear-gradient(135deg, #1b386e, #0a3a8a);
  font-weight: bold;
  flex-shrink: 0;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
  border: 3px solid #fff;
}
@media screen and (max-width: 767px) {
  .feature02 .ac-wrap .ac-menu button .num {
    min-width: 56px;
    height: 56px;
    font-size: 20px;
    border: 2px solid #fff;
  }
}
.feature02 .ac-wrap .ac-menu button .num::after {
  content: "";
  position: absolute;
  top: 8px;
  left: 12px;
  width: 40%;
  height: 30%;
  background: rgba(255, 255, 255, 0.4);
  border-radius: 50%;
  filter: blur(4px);
}
.feature02 .ac-wrap .ac-cts {
  background-color: #EFF3F5;
  padding: 0 40px 16px;
}
@media screen and (max-width: 767px) {
  .feature02 .ac-wrap .ac-cts {
    padding: 0 8px 16px;
  }
}
.feature02 .ac-wrap .ac-cts + .ac-cts .com-wrap {
  border-top: dashed 2px #333;
}
@media screen and (max-width: 767px) {
  .feature02 .ac-wrap .ac-cts + .ac-cts .com-wrap {
    border-top: dashed 1px #333;
  }
}
.feature02 .ac-wrap .ac-cts a:hover {
  opacity: 0.7;
}
.feature02 .ac-wrap .ac-cts .com-wrap {
  align-items: center;
  gap: 20px 3%;
  margin-bottom: 0;
  padding-top: 16px;
}
.feature02 .ac-wrap .ac-cts .com-wrap .img {
  width: 34.653%;
  max-width: 240px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .feature02 .ac-wrap .ac-cts .com-wrap .img {
    width: 100%;
    max-width: initial;
  }
}
.feature02 .ac-wrap .ac-cts .com-wrap .img img {
  max-width: 100%;
}
.feature02 .ac-wrap .ac-cts .com-wrap .txt {
  width: 54.257%;
}
@media screen and (max-width: 767px) {
  .feature02 .ac-wrap .ac-cts .com-wrap .txt {
    width: 100%;
  }
}
.feature02 .ac-wrap .ac-cts .com-wrap .txt dt {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 1em;
}
@media screen and (max-width: 767px) {
  .feature02 .ac-wrap .ac-cts .com-wrap .txt dt {
    font-size: 16px;
  }
}
.feature02 .ac-wrap .ac-cts .list-link {
  display: flex;
  gap: 16px;
}
.feature02 .ac-wrap .ac-cts .list-link li {
  text-decoration: underline;
}
.feature02 .ac-wrap .ac-cts .list-link li:hover {
  text-decoration: none;
}
/*# sourceMappingURL=index.css.map */