@charset "UTF-8";
.mainVisual {
  padding: 44px 20px 0;
  margin: 0 0 90px;
}
.mainVisual .inner {
  max-width: 1400px;
  margin: 0 auto;
}

.productList {
  padding: 0 20px;
  /* margin: 0 0 120px; */
}
.productList .inner {
  max-width: 1400px;
  margin: 0 auto;
}
.productList .inner h2 {
  margin: 0 0 50px;
  padding: 0 0 40px;
  border-bottom: solid 1px #DFDDE0;
  color: #A80D1F;
  font-weight: bold;
  font-size: 1.6rem;
}
.productList .inner h2 span {
  font-size: 5rem;
  font-weight: 800;
  display: block;
  color: #333;
}
.productList .inner .productWrap {
  padding: 0 30px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 40px;
}
.productList .inner .productWrap .item {
  display: block;
  background-color: #FFF;
  width: 48%;
  border: solid 1px #E0DFDD;
  box-shadow: 0px 5px 6px rgba(195, 195, 195, 0.5);
  position: relative;
  margin: 0 0 50px;
}
.productList .inner .productWrap .item .topTxt {
  padding: 55px 50px 60px;
  min-height: 340px;
}
.productList .inner .productWrap .item .topTxt .name {
  display: flex;
  margin: 0 0 18px;
}
.productList .inner .productWrap .item .topTxt .name .img {
  min-width: 58px;
}
.productList .inner .productWrap .item .topTxt .name h3 {
  font-size: 3.2rem;
  margin-left: 20px;
  font-weight: 800;
  position: relative;
  line-height: 1.2;
  padding: 0 0 20px;
}
.productList .inner .productWrap .item .topTxt .name h3::after {
  position: absolute;
  background-color: #A80D1F;
  bottom: 0;
  left: 0;
  content: "";
  width: 30px;
  height: 2px;
}
.productList .inner .productWrap .item .topTxt > p {
  margin: 0 0 20px;
  color: #747474;
  font-size: 1.6rem;
}
.productList .inner .productWrap .item .topTxt .planList {
  max-width: 200px;
}
.productList .inner .productWrap .item .topTxt .planList li {
  padding: 5px 10px;
  border: 1.5px solid #DFDDE0;
  font-weight: 600;
  margin: 0 0 12px 0;
  color: #454545;
  font-size: 1.3rem;
  text-align: right;
}
.productList .inner .productWrap .item .topTxt .planList.pt2 {
  max-width: 140px;
}
.productList .inner .productWrap .item .topTxt .planList.pt2 li {
  text-align: center;
  padding: 10px 10px;
}
.productList .inner .productWrap .item .btnWrap {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  text-align: right;
  border-top: solid 1px #E0DFDD;
  min-height: 50px;
}
.productList .inner .productWrap .item .btnWrap .btn {
  display: inline-block;
  background-color: #A80D1F;
  color: #FFF;
  position: absolute;
  width: 300px;
  box-sizing: border-box;
  right: 0;
  bottom: 0;
  height: calc(100% + 1px);
  display: -webkit-flex;
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
}
.productList .inner .productWrap .item .btnWrap .btn span {
  display: inline-block;
  padding: 0 25px 0 70px;
  font-size: 1.5rem;
  position: relative;
}
.productList .inner .productWrap .item .btnWrap .btn span::before {
  content: "";
  position: absolute;
  width: 50px;
  height: 1px;
  background-color: #FFF;
  left: 0;
  top: 50%;
}
.productList .inner .productWrap .item .btnWrap .btn span::after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  border: 5px solid transparent;
  border-top: 9px solid #ffffff;
  transform: rotate(-90deg);
  right: 0;
  margin-top: -7px;
  top: 50%;
}
.productList .inner .buyBtnWrap {
  text-align: center;
  padding: 0 0 120px;
}
.productList .inner .buyBtnWrap a {
  background-color: #a80d1f;
  color: #FFF;
  border-radius: 6px;
  padding: 22px 70px;
  margin: 40px 0 0;
  display: inline-block;
  font-size: 2.4rem;
  font-weight: bold;
  min-width: 460px;
  box-sizing: border-box;
  position: relative;
}
.productList .inner .buyBtnWrap a::before {
  content: "";
  position: absolute;
  width: 12px;
  height: 12px;
  border-top: solid 2px;
  border-right: solid 2px;
  top: 50%;
  margin-top: -5px;
  right: 30px;
  color: #ffffff;
  display: block;
  transform: rotate(45deg);
}

.faq {
  padding: 100px 20px 85px;
  background-color: #F2F2F2;
  overflow: hidden;
}
.faq .inner {
  max-width: 1400px;
  margin: 0 auto;
  position: relative;
  z-index: 0;
}
.faq .inner::after {
  position: absolute;
  content: "";
  width: 874px;
  height: 645px;
  background: url(../img/top/bg_faq.png) no-repeat 0 0;
  top: -100px;
  right: -280px;
  z-index: -1;
}
.faq .inner h2 {
  margin: 0 0 60px;
  padding: 0 0 40px;
  border-bottom: solid 1px #717171;
  color: #A80D1F;
  font-weight: bold;
  font-size: 1.6rem;
}
.faq .inner h2 span {
  font-size: 5rem;
  font-weight: 800;
  display: block;
  color: #333;
}

/*******************************************************************/
/* PC：幅768px以上
/*******************************************************************/
@media screen and (min-width: 768px), print {
  /*<start>==========================================================*/
  /*<end>============================================================*/
}
/*******************************************************************/
/* SP
/*******************************************************************/
@media screen and (max-width: 767px) {
  /*<start>==========================================================*/
  .mainVisual {
    padding: 0;
    margin: 0 0 40px;
  }
  .productList {
    padding: 0 4%;
    /* margin: 0 0 60px; */
  }
  .productList .inner h2 {
    margin: 0 0 30px;
    padding: 0 0 20px;
    font-size: 1.4rem;
  }
  .productList .inner h2 span {
    font-size: 4rem;
  }
  .productList .inner .productWrap {
    padding: 0 4%;
    display: block;
  }
  .productList .inner .productWrap .item {
    width: 100%;
    margin: 0 0 30px;
  }
  .productList .inner .productWrap .item .topTxt {
    padding: 9% 8% 50px;
    min-height: unset;
  }
  .productList .inner .productWrap .item .topTxt .name {
    display: flex;
    margin: 0 0 18px;
  }
  .productList .inner .productWrap .item .topTxt .name .img {
    flex: 0 0 40px;
    min-width: unset;
  }
  .productList .inner .productWrap .item .topTxt .name .img img {
    width: 100%;
  }
  .productList .inner .productWrap .item .topTxt .name h3 {
    font-size: 2.8rem;
    margin-left: 12px;
    padding: 0 0 15px;
  }
  .productList .inner .productWrap .item .topTxt > p {
    margin: 0 0 30px;
  }
  .productList .inner .productWrap .item .btnWrap .btn {
    width: 100%;
  }
  .productList .inner .buyBtnWrap {
    padding: 0 0 80px;
  }
  .productList .inner .buyBtnWrap a {
    padding: 14px 40px;
    margin: 15px 0 0;
    font-size: 1.6rem;
    min-width: 280px;
  }
  .faq {
    padding: 40px 4% 30px;
  }
  .faq .inner::after {
    width: 600px;
    height: 430px;
    background: url(../img/top/bg_faq.png) no-repeat 0 0;
    background-size: 600px auto;
    top: -52px;
    right: -358px;
  }
  .faq .inner h2 {
    margin: 0 0 30px;
    padding: 0 0 20px;
    font-size: 1.4rem;
  }
  .faq .inner h2 span {
    font-size: 4rem;
  }
  /*=================================================================*/
}/*# sourceMappingURL=toppage.css.map */