body{
  font-size:16px;
  margin:0;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: 500;
  color:#333;
}
a{
  text-decoration: none;
}
h2,h3,h4,h5,p{
  margin:0;
}

.about,.profile,.for,.cr,.step,.merit,.reco,.qa{
  width: 80%;
  margin: 0 auto;
  max-width: 1020px;
  margin-bottom: 80px;
}
.about h2,.profile h2,.for h2,.cr h2,.step h2,.merit h2,.reco h2,.qa h2{
  color:#bddaeb;
  font-size: 2rem;
}
.about h3,.profile h3,.for h3,.cr h3,.step h3,.merit h3,.reco h3,.qa h3{
  color:#3795d3;
  margin-left: 24px;
  font-size: 1rem;
  margin-bottom: 20px;
}
@media screen and (max-width: 640px){
  .about,.profile,.for,.cr,.step,.merit,.reco,.qa{
    width:90%;
  }
}

/*hover*/
a{
  display: inline-block;
  transition: .3s;
}
a:hover{
  transform: scale(1.1);
}
footer a:hover{
  transform: scale(1.0);
}

/*animation*/
/*div.animation_box {
  opacity: 1;
  transform: translateX(-20px);
  transition: 1s ease;
}*/

/*mv*/
.mv{
  background: url(../img/top.jpg) bottom center no-repeat;
  background-size: cover;
  width: 100%;
  height: 555px;
}
.top_container{
  width: 80%;
  margin: 0 auto;
  max-width: 1020px;
  color:white;
  position: relative;
}
.top_container p{
  margin-top:50px;
}
.top_container>p{
  background-color: #16479B;
  display: inline-block;
  padding: 20px;
  border-radius: 30px;
}
.top_container h2{
  font-weight: normal;
  font-size: 2rem;
  margin-top: 40px;
  line-height: 60px;
}
.top_container img{
  position: absolute;
  height: 500px;
  right: 0;
  top: 0;
  margin-top: 80px
}
.header{
  text-align: right;
  padding-top: 30px;
}
.header_button{
  padding: 15px 30px;
  font-size: 0.875rem;
  border-radius: 30px;
  color:white;
}
.contact{
  border:1px solid white;
  margin-right: 10px;
}
.login{
  background-color:#0059d3;
}
@media screen and (max-width: 640px){
  .mv{
    background: url(../img/top_sp.jpg) bottom center no-repeat;
    background-size: cover;
  }
  .top_container{
    width: 90%;
  }
  .header_button{
    padding: 14px 21px;
  }
  .contact{
    margin-right:5px;
  }
  .top_container h2{
    margin-top:10px;
  }
  .top_container img{
    height:300px;
    margin-top:300px;
  }
}

/*content1*/
.content1{
  background-color:#eef3f5;
}
.content1_container{
  width: 80%;
  margin: 0 auto;
  max-width: 1020px;
  text-align:center;
  padding: 50px 0;
}
.content1_container img{
  width: 30%;
  margin-right: 1%;
  margin-bottom: 20px;
}
.content1_container p:first-child{
  margin-bottom:20px;
}
.content1_container span{
  font-weight: bold;
  font-size:1.25rem;
}
@media screen and (max-width: 640px){
  .content1_container{
    width: 90%;
  }
  .content1_container img{
    width: 80%;
    margin-bottom: 10px;
  }
  .content1_container p:first-child{
    margin-bottom: 26px;
  }
}

/*CTA*/
.cta{
  background-image: url(../img/cta.jpg);
  background-size: cover;
  margin-bottom: 80px;
}
.cta_container{
  width: 80%;
  margin: 0 auto;
  max-width: 1020px;
  padding: 70px 0 64px 0;
  text-align:center;
  color:white;
}
.cta_container img{
  width:70%;
  margin-bottom: 30px;
}
.fukidashi{
  margin-bottom:10px;
  font-size: 0.875rem;
}
.cta_container p:nth-child(2){
  margin-bottom:20px;
}
.cta_button p{
  margin-bottom:6px;
}
.cta_button a{
  background: #16479B;
  padding: 24px;
  border-radius: 20px;
  display: inline-block;
  font-weight: bold;
  color: white;
}
.cta_button span{
  color: #2575bc;
  background: white;
  border-radius: 30px;
  padding: 12px;
  margin-right: 10px;
  font-family: auto;
  font-weight: normal;
}
@media screen and (max-width: 640px){
  .cta_container{
    width: 90%;
  }
  .cta_container img{
    width: 90%;
    margin-bottom: 60px;
  }
  .cta_button a{
    padding:20px;
    font-size: 0.875rem;
  }
  .cta_button span{
    margin-right: 6px;
  }
}

/*about*/
.about>p{
  margin-bottom:20px;
}
.about>img{
  width:70%;
  margin-left: 30%;
}
.about2{
  display: flex;
}
.about2_wrapper_right{
  margin: 20px 1%;
}
.about2_wrapper_right img{
  width:85%;
  margin-left:15%;
}
.about2_wrapper_right p{
  display: inline-block;
  padding: 14px;
  background-color: white;
  font-weight: bold;
  position: absolute;
  margin-top: -16px;
  font-size: 0.9rem;
  border: 1px solid #16479b;
}
@media screen and (max-width: 640px){
  .about2{
    display: block;
  }
  .about>img{
    width:100%;
    margin-left:0;
  }
}


/*content2*/
.content2{
  background-color:#eef3f5;
  clip-path: polygon(0 0, 100% 130px, 100% 100%, 0 100%);
  margin-bottom:80px;
}
.content2_container{
  width: 80%;
  margin: 0 auto;
  max-width: 1020px;
  padding-top: 130px;
  padding-bottom: 40px;
}
.content2_container h2:nth-child(2){
  margin-left: 140px;
}
.content2_container img{
  width: 30%;
}
.content2_container p{
  width: 68%;
  display: inline-block;
  vertical-align: top;
  margin-top: 84px;
}
@media screen and (max-width: 640px){
  .content2_container{
    width: 90%;
  }
  .content2_container h2{
    font-size:1.25rem;
  }
  .content2_container h2:nth-child(2){
    margin-left: 0px;
  }
  .content2_container img {
    width: 70%;
    display: block;
    margin: 0 auto;
  }
  .content2_container p {
    width: 100%;
    margin-top: 40px;
  }
}

/*profile*/
.profile img{
  width: 24%;
}
.profile_text{
  width: 72%;
  display: inline-block;
  vertical-align: top;
  margin-left: 2%;
}
.profile_text h4{
  font-size: 1.25rem;
  margin-bottom: 20px;
}
@media screen and (max-width: 640px){
  .profile img{
    width: 100%;
  }
  .profile_text{
    width: 100%;
    margin-left: 0;
  }
}

/*for*/
.fors{
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.for_wrapper{
  background-color: #3795d3;
  color:white;
  position: relative;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 48%;
  margin: 0 1%;
  margin-bottom: 30px;
  padding: 40px 20px 30px 20px;
  border-radius: 20px;
}
.for_wrapper p{
  margin-bottom:30px;
  color:#333;
  background-color:white;
  padding: 16px;
  border-radius: 20px;
  margin-bottom:0;
}
.for_wrapper h4{
  text-align: center;
  font-size: 1.25rem;
  margin-bottom: 20px;
}
@media screen and (max-width: 640px){
  .for_wrapper{
    width: 100%;
    margin: 0;
    margin-bottom:30px;
  }
}

/*cr*/
.crs{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.cr_wrapper{
  width:43%;
  background-color: #3795d3;
  color: white;
  margin: 0 1%;
  margin-bottom: 30px;
  padding: 40px 20px 30px 20px;
  border-radius: 20px;
}
.cr_wrapper h4{
  text-align: center;
  font-size: 1.25rem;
}
.cr_wrapper p:first-of-type{
  font-size: 0.875rem;
  text-align: center;
  margin-bottom: 10px;
}
@media screen and (max-width: 640px){
  .cr_wrapper{
    width:100%;
  }
}

/*step*/
.steps{
  display: flex;
}
.step_wrapper img{
  width:100%;
}
.step_wrapper h4{
  display: inline-block;
  color: #3795d3;
  font-size: 30px;
}
.step_wrapper h5{
  display: inline-block;
  vertical-align: top;
  margin-left: 4px;
  margin-top: 2px;
}
.step h6{
  font-size: 1rem;
  background-color: #3795d3;
  display: inline-block;
  color: white;
  padding: 20px;
  width: 100%;
  text-align: center;
}
.about3 img{
  width:100%;
}
.about3 img{
  width:50%;
}
.about3_wrapper p{
  width: 47%;
  display: inline-block;
  vertical-align: top;
  margin-top: 22px;
}
.about3_wrapper{
  margin-bottom: 40px;
}
@media screen and (max-width: 640px){
  .about3_wrapper p{
    margin-left: 12px;
  }
  .steps{
    flex-wrap:wrap;
  }
  .step_wrapper h4{
    font-size:50px;
  }
  .step_wrapper h5{
    font-size: 1rem;
    margin-top: 14px;
  }
  .step h6{
    width:90%;
  }
  .about3 img{
    width:100%;
  }
  .about3_wrapper p{
    width: 97%;
    margin-top:0;
  }
}


/*content3*/
.content3{
  background-color:#eef3f5;
  clip-path: polygon(0 0, 100% 130px, 100% 100%, 0 100%);
  margin-bottom:80px;
}
.content3_container{
  width: 80%;
  margin: 0 auto;
  max-width: 1020px;
  padding-top: 130px;
  padding-bottom: 40px;
}
.content3_container p{
  margin-bottom: 20px;
}
.content3_container img:first-of-type{
  width:50%;
  margin-left: 10%;
}
.content3_container img:nth-of-type(2){
  width:50%;
  margin-left: 35%;
}
.content3_container img:last-of-type{
  width:50%;
  margin-left: 50%;
}
@media screen and (max-width: 640px){
  .content3_container img{
    width:100%!important;
    margin-left:0!important;
  }
  .content3_container{
    width: 90%;
  }
}

/*merit*/
.about4{
  width:80%;
  margin:0 auto;
}
.about4 h3{
  margin: 0;
  font-size: 20px;
  margin-bottom: 10px;
}
.about4_wrapper_left h3{
  margin-left: 130px;
}
.about4_wrapper_left p:last-child{
  margin-left: 130px;
}
.about4_wrapper_right p:last-child{
  margin-right: 130px;
}
.about4_wrapper_left, .about4_wrapper_right{
  padding-bottom:32px;
}
.about4_number{
  font-size: 120px;
  font-weight: bold;
  color: #a2deff;
  letter-spacing: -7px;
  position: absolute;
  z-index: -1;
  margin-top: -44px;
}
.about4_wrapper_left, .about4_wrapper_right{
  padding-bottom: 15px;
  margin-bottom: 24px;
  border-bottom: 2px solid #a2deff;
  position: relative;
}
.about4_wrapper_right .about4_number{
  right:0;
}
.merit>p{
  margin-top: 60px;
  margin-bottom: 20px;
}
table{
  width:100%;
}
table tbody th{
  font-weight: normal;
  text-align: left;
  width:30%;
  background-color:#77b6e4;
  color:white;
  padding: 10px;
}
table tbody td{
  text-align: center;
  background-color:#eef3f5;
}
table thead tr th{
  background-color:#3795d3;
  color:white;
  padding: 10px;
}
@media screen and (max-width: 640px){
  .about4{
    width:100%;
  }
  .about4_wrapper_left h3{
    margin-left: 12%;
  }
  .about4_wrapper_left p:last-child{
    margin-left: 12%;
  }
  .about4_wrapper_right p:last-child{
    width: 88%;
  }
}

/*Recommendation*/
.recos{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.reco_wrapper{
  width:43%;
  background-color: #3795d3;
  color: white;
  margin: 0 1%;
  margin-bottom: 30px;
  padding: 40px 20px 30px 20px;
  border-radius: 20px;
}
.reco_wrapper h4{
  text-align: center;
  font-size: 1.25rem;
}
.reco_wrapper p:first-of-type{
  font-size: 0.875rem;
  text-align: center;
  margin-bottom: 10px;
}
@media screen and (max-width: 640px){
  .reco_wrapper{
    width:100%;
  }
}

/*Q&A*/
.qa_heading{
  font-size:30px;
  color: #3795d3;
  font-weight: bold;
  display: inline-block;
  margin-right: 1%;
}
.qa_wrapper{
  margin-bottom: 24px;
}
.qa_wrapper h5{
  font-size: 1rem;
  width: 95%;
  display: inline-block;
  vertical-align: top;
  margin-top: 12px;
}
.qa_wrapper p{
  width: 95%;
  display: inline-block;
  vertical-align: top;
  margin-top: 10px;
}
@media screen and (max-width: 640px){
  .qa_wrapper h5{
    width: 90%;
  }
  .qa_wrapper p{
    width: 90%;
  }
}

/*footer*/
footer{
  text-align: center;
  font-size: 0.75rem;
  margin-bottom: 30px;
}
footer a{
  color:#333;
  padding: 10px;
  border-right: 1px solid #eee;
}
footer a:nth-child(3){
  border:none;
}
footer p{
  padding-top: 10px;
}
