@charset "UTF-8";

/* <aside class="pointNav"> ------------------ */
/* SP */
.pointNav{
  background: #E8F8DA;
  margin-top: 75px;
  display: flex;
  justify-content: center;
  padding: 50px 18px;
}

.pointNav nav{
  width: 100%;
  max-width: 325px;
  box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
}

.pointNav nav a{
  display: block;  
}

.pointNav nav .pointNavHead a{
  padding: 20px 25px;
  color: #FFF;
  background: #5BB647;
  border-radius: 10px 10px 0 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.pointNav nav .pointNavHead a::after{
  content: "";
  width: 24px;
  height: 24px;
  background: url(../images/point/pointNavHead_arrow.svg) no-repeat;
  background-size: 100% auto;
}

.pointNav nav .pointNavHead,
.pointNav nav ul{
  /*width: 100%;
  max-width: 325px;*/
}

.pointNav nav ul{
  border-right: 2px solid  #F3F3F3;
  border-left: 2px solid  #F3F3F3;
  border-bottom: 2px solid  #F3F3F3;
  border-radius: 0 0 10px 10px;
  background: #FFF;
  padding: 0 12px;
}

.pointNav nav ul li{
  border-bottom: 1px solid  #F3F3F3;
}

.pointNav nav ul li:last-child{
  border-bottom: none;
}

.pointNav nav ul li a{
  display: block;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.pointNav nav ul li a::after{
  content: "";
  width: 16px;
  height: 16px;
  background: url(../images/point/pointNav_arrow.svg) no-repeat;
  background-size: auto 100%;
}

.pointNav nav ul li a{
  padding: 17px 11px;
}

.pointNav nav ul li a.pointCurrent{
  color: #C2C2C2;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.pointNav nav ul li a.pointCurrent::after{
  content: "";
  width: 16px;
  height: 16px;
  background: url(../images/point/pointNavCurrent_arrow.svg) no-repeat;
  background-size: auto 100%;
}

.gFooter{
  margin-top: 0 !important;
}
.page-pointTop .gFooter {
  margin-top: 75px !important;
}
@media screen and (min-width: 768px) {
  .page-pointTop .gFooter {
    margin-top: 145px !important;
  }
}



/* PC */
@media screen and (min-width: 768px) {
  .pointNav nav {
  max-width: 1000px;
  }

  .pointNav nav ul {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
  }

  .pointNav nav .pointNavHead a{
    padding: 20px 35px;
    font-size: 1.15em;
  }

  .pointNav nav ul li{
    border-right: 1px solid #F3F3F3;
  }

  .pointNav nav ul li:nth-child(3n){
    border-right: none;
  }

  .pointNav nav ul li a,
  .pointNav nav ul li.pointCurrent{
    padding: 20px 15px;
    font-size: 1.15em;
  }

  .pointNav nav .pointNavHead a::after{
    width: 28px;
    height: 28px;
    }

  .pointNav nav ul li.pointCurrent::after{
    width: 20px;
    height: 20px;
  }
  .pointNav nav ul li a::after{
    width: 20px;
    height: 20px;
  }

  .pointNav nav ul li:nth-child(4),
  .pointNav nav ul li:nth-child(5){
    border-bottom: none;
  }

  

}


/* <aside class="pointNav"> end ------------------ */





/* br h1 ------------------ */
/* SP */
.brSp{
  display: block;
}
/* PC */
@media screen and (min-width: 768px) {
  .brSp{
    display: none;
  }
}
/* br end ------------------ */





/* point h1 ------------------ */
/* SP */
.pageH{
  border-bottom: 1px solid #5BB647;
  padding-bottom: 30px;
}

/* PC */
/* point h1 end ------------------ */





/* point h2 ------------------ */
/* SP */
.secrionH{
  border-bottom: 1px solid #5BB647;
  border-top: 1px solid #5BB647;
  margin-bottom: 30px;
  font-weight: 700;
  text-align: center;
  padding: 15px 0;
  color: #5BB647;
  font-size: 1.230769em;
  line-height: 1.6;
}

/* PC */
.secrionH{
  /*max-width: 800px;*/
  width: 100%;
  margin: 0 auto 1.875em;
}
/* point h2 end ------------------ */






/* SP */
.sectionWrapper{
  margin: 0 auto 75px;
}
/* PC */
@media screen and (min-width: 768px) {
  .sectionWrapper{
   max-width: 1000px;
   width: 100%;
    margin: 0 auto 120px;
  }
}





/* SP */
.leadTxt{
  margin-bottom: 30px;
  text-align: center;
  letter-spacing: .05em;
  font-size: 1.307em;
  font-weight: 700;
  line-height: 1.6;
  font-size: 1.15em;
}

/* PC */
@media screen and (min-width: 768px) {
  .leadTxt{
    font-size: 1.25em;
    margin-bottom: 1.875em;
  }
}






/* pageImg ------------------ */
/* SP */
.pageImg{
  margin: 0 -18px 30px;
}

/* PC */
@media screen and (min-width: 768px) {
  .pageImg{
    width: 100%;
    max-width: 1000px;
    margin: 0 auto 1.875em;
  }
}

/* pageImg end ------------------ */





/* sectionImg ------------------ */
/* SP */
.sectionImg{
  margin: 0 -18px 30px;
}

.sectionCard .imgGroup{
  margin: 0 0 15px;
}

.sectionCard .imgGroup img{
  border-radius: 15px;
}


/* PC */
@media screen and (min-width: 768px) {
  .sectionImg{
    width: 100%;
    max-width: 1000px;
    margin: 0 auto 1.875em;
  }

  .sectionCard .imgGroup{
    margin: 0 0 25px;
  }
}

/* sectionImg end ------------------ */





/* pointSection ------------------ */
.pointSection{
  background: #E8F8DA;
  border-radius: 15px;
  padding: 20px 20px 35px;
  margin: 0 15px 75px;
}
.pointSection.magicbook {
  position: relative;
}
.pointSection.magicbook:before {
  content: '';
  display: block;
  width: 35px;
  height: 45px;
  background: url(../images/point/p_mark.svg) center / 100% auto no-repeat;
  position: absolute;
  top: 18px;
  right: 20px;
}
@media screen and (min-width: 768px) {
  .pointSection.magicbook:before {
    top: 30px;
    right: 30px;
    width: 40px;
    height: 50px;
  }
}

.pointSection header{
  margin: 0 0 33px;

}
.pointSection header p{
  background: #5BB647;
  display: inline-block;
  padding: 0 30px 0 20px;
  margin-left: -20px;
  margin-bottom: 15px;
  color: #FFF;
  position: relative;
  font-weight: 700;
}

.pointSection header p::before{
  content: "";
  position: absolute;
  background: url(../images/point/pointSectionStar.svg) no-repeat;
  background-size: 100% auto;
  width: 25px;
  height: 22.99px;
  left: -12px;
top: -9px;
}
.pointSection header p::after{
  content: "";
  position: absolute;
  right: -1px;
  width: 10px;
  height: 26px;
  clip-path: polygon(0 50%, 100% 0, 100% 100%);
  background: #E8F8DA;
}

.pointSection header h2{
  font-family: Roboto;
  font-weight: 700;
  font-size: 18px; 
}


.pointSection .pointSectionImgGropu{/* イメージが2つ並んでいる時 */
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}

.pointSection .pointSectionImg{/* イメージが1つの時 */
}

.pointSection .pointSectionImg img,
.pointSection .pointSectionImgGropu img{
  border-radius: 10px;
}

.pointSection .pointSectionTxtGropu{
  margin: 25px 0 0;
}

.pointSection .pointSectionTxtGropu p{
  margin: 0 0 35px;
  font-weight: 400;
}

.pointSection .pointSectionTxtGropu p:last-of-type{
  margin: 0;
}



/* PC */
@media screen and (min-width: 768px) {
  .pointSection{
    width: 100%;
    max-width: 600px;
    margin: 0 auto 150px;
    padding: 30px 40px 45px;
  }
  .pointSection header h2 {
    font-size: 1.25rem;
  }
   .pointSection header p{
    font-size: 1.125rem;
    margin-left: -40px;
    padding: 0 45px 0 40px;
   }
  .pointSection header p::before{
    width: 40px;
    height: 38px;
    left: -17px;
    top: -12px;
  }
  .pointSection header p::after{
    height: 35px;
  }
  
  .pointSection .pointSectionImgGropu{
    /*max-width: 400px;*/
    margin: 0 auto;
    gap: 18px
  }
  .pointSection .pointSectionTxtGropu {
    margin: 35px 0 0;
  }
  .pointSection .pointSectionTxtGropu p{
    margin: 0 0 45px;
  }
}
/* pointSection end ------------------ */







/* sp */
.texGroup{
  margin: 0 15px 30px;
}


.texGroup p{
  margin: 0 0 30px;
  font-weight: 400;
}

.texGroup p:last-of-type{
  margin: 0;
}
