@charset "UTF-8";
/* --------------------------------------------------------------
   共通
-------------------------------------------------------------- */
body {
  min-width: 1040px;
  font-size: 18px;
  color: #2A3C67;
}

.wrapper {
  overflow: hidden;
}

.container {
  width: 1000px;
  margin: 0 auto;
}

.container_min {
  width: 837px;
  margin: 0 auto;
}

.cmn_header {
  padding: 30px 0 17px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.cmn_header .tel {
  display: flex;
}
.cmn_header .tel .img01 {
  margin-right: 10px;
}

.cmn_footer {
  padding: 40px 0 45px;
  background: #202020;
}
.cmn_footer .outer {
  display: flex;
  justify-content: center;
  font-size: 14px;
  font-weight: 400;
  color: #fff;
}
.cmn_footer .outer ul {
  margin-bottom: 80px;
}
.cmn_footer .outer ul li {
  line-height: 1.71;
}
.cmn_footer .outer ul li:not(:last-of-type) {
  margin-bottom: 25px;
}
.cmn_footer .outer ul:first-of-type {
  margin-right: 140px;
}
.cmn_footer small {
  text-align: center;
  display: block;
  font-size: 14px;
  color: #fff;
}

.mv h1 img {
  width: 100%;
}
.mv .txt {
  text-align: center;
  background-color: #1089ef;
}

.subsc .tit {
  padding: 22px 0 21px;
  text-align: center;
  position: relative;
  background: #1f1f1f;
}
.subsc .tit span {
  position: absolute;
  bottom: -37px;
  left: 50%;
  transform: translateY(-50%);
}
.subsc .txt01 {
  text-align: center;
  background: #e6e3e9;
}
.subsc .txt02 {
  padding: 40px 0 48px;
  text-align: center;
  background: #262e6a;
}
.subsc .txt02 .tit02 {
  margin-bottom: 25px;
}
.subsc .txt03 {
  padding: 42px 0 50px;
  background-image: url("../images/subsc/bg.png");
  background-repeat: no-repeat;
  background-size: cover;
}
.subsc .txt03 .outer {
  display: flex;
}
.subsc .txt03 .outer .desc {
  margin-top: -71px;
}
.subsc .txt03 .inner {
  width: 540px;
  padding: 19px 0;
  margin-left: -1px;
  text-align: center;
  background: #fff;
}
.subsc .txt03 .inner .btn {
  display: block;
  margin-bottom: 4px;
}
.subsc .txt03 .inner .btn img {
  transition: 0.2s ease;
}
.subsc .txt03 .inner .btn:hover img {
  transform: scale(0.98, 0.98);
  transition: 0.2s ease;
}
.subsc .txt03 .inner .desc02 {
  margin-bottom: 10px;
}
.subsc .txt03 .inner .btn02 {
  cursor: pointer;
  transition: 0.2s ease;
}
.subsc .txt03 .inner .btn02:hover {
  transform: scale(0.98, 0.98);
  transition: 0.2s ease;
}

.subsc02 .tit {
  padding: 18px 0 20px;
}
.subsc02 .tit .outer {
  display: inline-grid;
}
.subsc02 .tit .outer img:first-of-type {
  margin-bottom: 19px;
}

.sec01 {
  padding: 50px 0;
}
.sec01 .box {
  width: 830px;
  padding: 40px 50px 30px;
  margin: 0 auto;
  text-align: left;
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.3);
  border-radius: 20px;
  color: #000;
  letter-spacing: 0.027em;
}
.sec01 .box h2 {
  margin-bottom: 20px;
  position: relative;
}
.sec01 .box h2:after {
  content: "";
  position: absolute;
  height: 1px;
  width: 570px;
  right: 5px;
  top: 10px;
  background: #000;
}
.sec01 .box p {
  line-height: 1.88;
}

.sec02 {
  padding: 40px 0 28px;
  background: #e4e6ed;
}
.sec02 p {
  text-align: center;
  padding-right: 47px;
}

.sec03 {
  padding: 24px 0 10px;
  text-align: center;
  background-image: url("../images/sec03/bg.jpg");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
.sec03 p {
  margin-bottom: -50px;
}

.sec04 {
  padding: 14px 0 0;
  text-align: center;
  background-image: url("../images/sec04/bg.png");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
.sec04 p {
  margin-bottom: -50px;
}

.sec05 {
  padding: 55px 0 80px;
  text-align: center;
  background-image: url("../images/sec05/bg.png");
  background-size: cover;
  background-position: bottom;
}
.sec05 .pic {
  margin: 25px 0;
}

.sec06 {
  padding: 30px 0 48px;
  text-align: center;
  background-image: url("../images/sec06/bg.png");
  background-size: cover;
  background-position: initial;
  background-repeat: no-repeat;
}
.sec06 .tit {
  margin-bottom: 29px;
}
.sec06 .txt {
  margin-bottom: 34px;
}

.sec07 {
  padding: 45px 0 35px;
  text-align: center;
  background-image: url("../images/sec07/bg.png");
  background-size: cover;
}
.sec07 .tit {
  margin-bottom: 30px;
}

.sec08 {
  padding: 40px 0 0;
  text-align: center;
  background-image: url("../images/sec08/bg.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: top;
}
.sec08 .tit {
  margin-bottom: 7px;
}
.sec08 .tit02 {
  margin-bottom: -10px;
}
.sec08 .txt {
  margin-bottom: 20px;
}

.sec09 {
  padding: 5px 0 42px;
  text-align: center;
  background: #262e6a;
}

.slide_sec {
  padding: 0 0 62px;
  text-align: center;
  background-image: url("../images/slide/bg.png");
  background-repeat: no-repeat;
  background-size: cover;
}
.slide_sec .tit img {
  margin-top: -30px;
}
.slide_sec .slick-slide {
  margin: 0 77.5px;
}
.slide_sec .slick-dots {
  bottom: -55px;
}
.slide_sec .slick_outer {
  position: relative;
}
.slide_sec .slick_outer .arrow {
  width: 725px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  position: absolute;
  top: 307px;
  left: 50%;
  transform: translateX(-50%);
}
.slide_sec .slick_outer .arrow .prev {
  cursor: pointer;
}
.slide_sec .slick_outer .arrow .next {
  cursor: pointer;
}

.sec10 {
  padding: 0 0 50px;
  text-align: center;
}
.sec10 .txt01 {
  margin: -13px 0 30px;
}

.qa_sec {
  padding: 70px 0 30px;
}
.qa_sec .qa {
  padding: 65px 0 55px;
  margin-bottom: 33px;
  border: 4px solid #262e6a;
}
.qa_sec .qa .tit {
  margin: -87px auto 40px;
  width: 220px;
  height: 42px;
  font-size: 25px;
  text-align: center;
  border-radius: 10px;
  line-height: 1.45;
  font-weight: bold;
  color: #fff;
  background: #262e6a;
}
.qa_sec .qa .lists dd,
.qa_sec .qa .lists dt {
  padding-left: 57px;
  position: relative;
}
.qa_sec .qa .lists dt {
  margin-bottom: 26px;
  font-size: 25px;
  font-weight: bold;
  line-height: 1.47;
  color: #262e6a;
}
.qa_sec .qa .lists dt:before {
  content: "";
  width: 45px;
  height: 45px;
  left: 0;
  position: absolute;
  background-image: url("../images/qa/q.png");
}
.qa_sec .qa .lists dd {
  font-size: 19px;
  line-height: 1.65;
  color: #000;
}
.qa_sec .qa .lists dd:not(:last-of-type) {
  margin-bottom: 100px;
}
.qa_sec .qa .lists dd:not(:last-of-type):after {
  content: "";
  height: 2px;
  width: 73px;
  position: absolute;
  left: 0;
  bottom: -50px;
  background: #262e6a;
}
.qa_sec .qa .lists dd:before {
  content: "";
  width: 45px;
  height: 45px;
  left: 0;
  position: absolute;
  background-image: url("../images/qa/a.png");
}
.qa_sec .btn {
  margin: 0 auto;
  text-align: center;
}
.qa_sec .btn img {
  transition: 0.2s ease;
}
.qa_sec .btn:hover img {
  transform: scale(0.98, 0.98);
  transition: 0.2s ease;
}