.swiper-container-horizontal>.swiper-pagination-bullets, .swiper-pagination-custom, .swiper-pagination-fraction{
  bottom: -5px;
}

.sp{
  display: none;
}

/* line */
.line{
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

button{
  display: none;
}

.line p{
  font-size: 20px;
  color: #003399;
  font-weight: bold;
  background:rgba(0, 0, 0, 0)
  linear-gradient(transparent 60%, #ffff23 0%) repeat scroll 0 0;
  margin-bottom: 10px;
}

.line a{
  width: 310px;
  height: 80px;
  line-height: 75px;
  display: block ;
  border: 5px solid #fff;
  background: #00bc4e;
  border-radius: 15px;
  color: #fff;
  font-family: 'Kosugi Maru', sans-serif;
  font-size: 32px;
  font-weight: bold;
  box-sizing: border-box;
  letter-spacing: 2px;
}

.line a span{
  font-size: 24px;
  font-family: initial;
}

h2{
  display: inline-block;
  font-size: 30px;
  font-family: Impact, Haettenschweiler, 'Arial Narrow Bold', sans-serif;
  color: #003399;
  font-weight: bold;
  border-bottom: 5px solid #f0ff00;
  padding-bottom: 5px;
  margin: 60px 0;
}

header{
  height: 110px;
  padding: 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

header .logo{
  width: 275px;
}

header .logo img{
  width: 100%;
}

header nav{
  padding: 0 10px;
}

header nav ul{
  justify-content: center;
  display: flex;
  flex-wrap: wrap;
}

header nav ul li{
  margin-right: 5px;
  padding-right: 5px;
  border-right: 1px solid #899ed3;
}

header nav ul li:last-child{
  margin: 0;
  padding: 0;
  border: none;
}

header nav ul li a{
  color: #003399;
  font-size: 13px;
  font-weight: bold;
}

header .contact{
  display: flex;
  flex-direction: column;
}

header .contact p{
  background: #003399;
  color: #fff;
  font-size: 13px;
  text-align: center;
  border-radius: 5px;
  padding: 7px;
  line-height: 16px;
  margin-bottom: 10px;
}

header .contact div{
  display: flex;
  align-items: center;
}

header .contact div img{
  width: 25px;
  margin-top: -6px;
}

header .contact div a{
  font-size: 30px;
  font-weight: bold;
  color: #003399;
}

#mainV{
  background: #003db6;
  text-align: center;
  padding: 30px 0;
}

#mainV .catch{
  padding: 30px 0;
}

#mainV .catch p{
  color: #fff;
  font-family: 'Times New Roman', Times, serif;
  font-size: 25px;
  margin-bottom: 15px;
}

#mainV .catch h1{
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #fff;
  font-size: 40px;
  font-family: 'Trebuchet MS', 'Lucida Sans Unicode', 'Lucida Grande', 'Lucida Sans', Arial, sans-serif;
  font-weight: bold;
  letter-spacing: 5px;
}

#mainV .catch h1 img{
  width: 250px;
  margin-top: 15px;
}

#mainV ul{
  display: flex;
  justify-content: center;
}

#mainV ul li{
  width: 170px;
  margin-right: 20px;
  position: relative;
}

#mainV ul li img{
  width: 100%;
}

#mainV ul li p{
  text-align: center;
  background: #fff;
  position: absolute;
  bottom: 0px;
  width: 100%;
  height: 30px;
  line-height: 28px;
  border: 2px solid #001a4e;
  font-size: 14px;
  box-sizing: border-box;
  font-family: 'Trebuchet MS', 'Lucida Sans Unicode', 'Lucida Grande', 'Lucida Sans', Arial, sans-serif;
  font-weight: bold;
  color: #003399;
}

#mainV ul li p span{
  font-size: 130%;
}

#mainV .line{
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 30px;
  flex-direction: initial;
}

#first{
  background: #ededed;
  padding: 30px 0;
}

#first .firstInner{
  width: 850px;
  border: 7px solid #003399;
  border-radius: 10px;
  box-sizing: border-box;
  background: #fff;
  margin: 0 auto;
  text-align: center;
}

@media screen and (max-width: 999px) {
#review .reviewInner{
  width: 95% !important;}
	
}


#first .firstInner h2 img{
  display: initial;
  width: 30px;
}

#first .firstInner img{
  width: 600px;
  display: block;
  margin: 0 auto;
}

#first .firstInner p{
  width: 600px;
  margin: 30px auto;
  line-height: 30px;
}

#first .announce{
  background: #114fcc;
  color: #fff;
  border-radius: 5px;
  width: 750px;
  margin: 30px auto;
  padding: 20px 0;
  text-align: center;
  font-size: 20px;
  line-height: 40px;
}


#review{
  background: #ededed;
  padding: 30px 0;
}

#review .reviewInner{
  width: 850px;
  border: 7px solid #003399;
  border-radius: 10px;
  box-sizing: border-box;
  background: #fff;
  margin: 0 auto;
  text-align: center;
  padding:30px;
}

#review .reviewInner h2 img{
  display: initial;
  width: 30px;
}

#review .reviewInner img{
  width: 600px;
  display: block;
  margin: 0 auto;
}

#review .reviewInner p{
}

#review .reviewInner ul{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #CCC;
	padding-top:10px;
	padding-bottom:10px;
}
#review .reviewInner ul li{text-align:left;}
#review .reviewInner ul li.nickname{width:20%;}
#review .reviewInner ul li p.date{ text-align:right; font-size:0.8rem; margin-top:10px;}


#aboutPresent{
  text-align: center;
  border-top: 5px solid #003399;
  border-bottom: 5px solid #003399;
  padding-bottom: 50px;
}

#aboutPresent ul:nth-child(3){
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 30px 0 50px;
  
}

#aboutPresent ul:nth-child(3) li{
  width: 250px;
  margin-right: 10px;
}

#aboutPresent ul:nth-child(3) li:last-child{
  margin: 0;
}

#aboutPresent ul:nth-child(3) li p{
  background: #003db6;
  color: #fff;
  border-radius: 5px 5px 0 0;
  padding: 15px 0;
}

#aboutPresent ul:nth-child(3) li div{
  background: #fff;
  border: 5px solid #003db6;
  border-radius: 0 0 5px 5px;
}

#aboutPresent ul:nth-child(3) li div img{
  width: 100%;
}

#aboutPresent p:nth-child(4){
  line-height: 30px;
}

#aboutPresent p:nth-child(4) img{
  margin: 30px 0 0;
}

.planWrap{
  margin: 50px 0;
}

.planWrap .plan{
  width: 700px;
  margin: 0 auto;
  box-shadow: 0px 0 8px 0px #ddd;
  display: flex;
}

.planWrap .plan li{
  width: 50%;
  border-right:1px solid #ddd;
}

.planWrap .plan li:last-child{
  border: none;
}

.planWrap .plan li .planTitle{
  font-size: 30px;
  font-family: 'Trebuchet MS', 'Lucida Sans Unicode', 'Lucida Grande', 'Lucida Sans', Arial, sans-serif;
  font-weight: bold;
  color: #003399;
  padding: 30px 0;
}

.planWrap .plan li .planTitle span{ 
  font-size: 17px;
  letter-spacing: 5px;
}

.planWrap .plan li .planPrice{
  background: #0048ff;
  color: #fff;
  font-size: 50px;
  font-family: 'Trebuchet MS', 'Lucida Sans Unicode', 'Lucida Grande', 'Lucida Sans', Arial, sans-serif;
  font-weight: bold;
  line-height: 20px;
  height: 100px;
  padding: 23px 0 0 0;
}

.planWrap .plan li .planPrice span{
  font-size: 30px;
}

.planWrap .plan li .planPrice span:last-child{
  font-size: 20px;
}

.planWrap .plan li .planExplain{
  text-align: left;
  width: 200px;
  margin: 30px auto;
  line-height: 25px;
  color: #003399;
}

.planWrap .plan li:last-child .planPrice{
  background: #ff6c00;
}

.QAWrap{
  margin: 50px 0;
}

.QAWrap h3{
  font-family: 'Trebuchet MS', 'Lucida Sans Unicode', 'Lucida Grande', 'Lucida Sans', Arial, sans-serif;
  font-weight: bold;
  font-size: 35px;
  color: #003db6;
  margin-bottom: 50px;
}

.QAWrap h3 span{
  color:rgb(182, 12, 12);
}

.QAWrap dl{
  text-align: left;
  width: 600px;
  margin: 0 auto 15px;
  border-bottom: 1px solid #ddd;
}

.QAWrap dl:last-child{
  margin: 0 auto 0;
  border: none;
}

.QAWrap dl dt{
  color: #003db6;
}

.QAWrap dl dt:before,
.QAWrap dl dd:before{
  font-weight: bold;
  text-align: center;
  width: 25px;
  height: 25px;
  line-height: 25px;
  color: #fff;
  display: inline-block;
  margin-right: 5px;
}

.QAWrap dl dt:before{
  content: "Q";
  background: #003db6;
}

.QAWrap dl dd:before{
  content: "A";
  background: rgb(182, 12, 12);
}

.QAWrap dl dd{
  margin-top: 15px;
  padding-bottom: 15px;
  color: rgb(182, 12, 12);
}

#aboutDigital{
  background: #003399;
  color: #fff;
  text-align: center;
  padding-bottom: 50px;
}

#aboutDigital h2{
  color: #fff;
}

#aboutDigital ul:nth-child(3){
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 30px 0 50px;
  
}

#aboutDigital ul:nth-child(3) li{
  width: 250px;
  margin-right: 10px;
}

#aboutDigital ul:nth-child(3) li:last-child{
  margin: 0;
}

#aboutDigital ul:nth-child(3) li p{
  background: #003db6;
  color: #fff;
  border-radius: 5px 5px 0 0;
  padding: 15px 0;
  border: 3px solid #fff;
}

#aboutDigital ul:nth-child(3) li div{
  background: #fff;
  border: 5px solid #fff;
  border-radius: 0 0 5px 5px;
}

#aboutDigital ul:nth-child(3) li div img{
  width: 100%;
}

#aboutDigital .plan{
  background: #fff;
  box-shadow: none;
}

#aboutDigital .plan .planPrice{
  line-height: 37px;
  padding: 0;
}

#aboutDigital #demerit .std ul:first-child li{
  color: #fff;
}

#aboutDigital #demerit .caution{
  background: #fff;
  border-radius: 10px;
}

#aboutDigital .plan .planPrice span:first-child{
  font-size: 20px;
}

#aboutDigital .plan .planPrice span:last-child{
  font-size: 30px;
}

#aboutDigital .plan li:first-child .planPrice{
  background: #45c554;
}

#aboutDigital .plan li .planPrice{
  background: #fc4f4f ;
}

#aboutDigital .plan .planExplain p{
  text-align: center;
  color: #45c554;
  font-size: 40px;
  font-weight: bold;
  margin-bottom: 30px;
  line-height: 40px;
}

#aboutDigital .plan .planExplain p span{
  font-size: 20px;
}

#aboutDigital .plan li:last-child .planExplain p{
  color: #fc4f4f;
}

#aboutDigital #flow h5{
  background: #fff;
  color: #003399;
}

#aboutDigital #flow ul{
  background: #fff;
}

#aboutDigital .QAWrap{
  background: #fff;
  width: 700px;
  margin: 0 auto;
}

#aboutDigital .QAWrap h3{
  padding-top: 30px;
}

#aboutDigital p:nth-child(4) img{
  width: 250px;
  margin-top: 30px;
}

#merit{
  background: #e6f8ff;
  text-align: center;
  padding-bottom: 40px;
}

#merit ul{
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  width: 1000px;
  margin: 0 auto;
}

#merit ul li{
  padding: 10px;
  width: 200px;
  height: 250px;
  background: #fff;
  box-shadow: 0px 0 2px 0px rgb(189, 189, 189);
  position: relative;
  margin-right: 20px;
  margin-bottom: 40px;
}

#merit ul li h4{
  position: absolute;
  background: #0048ff;
  color: #fff;
  border-radius: 25px;
  width: 70%;
  margin: 0 auto;
  height: 25px;
  line-height: 25px;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}

#merit ul li p{
  padding-top: 30px;
  font-size: 18px;
  font-weight: bold;
  color: #0048ff;
  text-decoration: underline;
  line-height: 35px;
}

#merit ul li img{
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}

#demerit{
  text-align: center;
  padding-bottom: 50px;
}

#demerit h5{
  font-size: 25px;
  color: #003db6;
  border-bottom: 3px solid rgb(209, 12, 12);
  padding-bottom: 20px;
  width: 700px;
  margin: 0 auto;
  font-weight: bold;
}

#demerit div {
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  width: 700px;
  margin: 0 auto;
}

#demerit div.diz{
  margin-top: 80px;
}

#demerit div.std ul:nth-child(1){
  margin-top: 30px;
}

#demerit div ul:nth-child(1)  {
  text-align: left;
  font-size: 20px;
  color: #003db6;
  font-weight: bold;
}

#demerit div ul:nth-child(1) li{
  margin-top: 20px;
}

#demerit div ul:nth-child(2){
  display: flex;
}

#demerit div ul:nth-child(2) li{
  width: 200px;
}

#demerit div ul:nth-child(2) img{
  width: 100%;
}

#demerit div ul:nth-child(2) p{
  font-size: 13px;
  padding: 0 20px;
}

#demerit div p:nth-child(3){
  margin: 30px auto;
  background: #b60000;
  border-radius: 10px;
  color: #fff;
  width: 700px;
  padding: 20px;
  text-align: left;
}

.caution{
  width: 700px!important;
  margin: 0 auto!important;
  display: flex!important;
  flex-direction: initial!important;
}

.caution img{
  width: 150px;
}

.caution p{
  width: 500px;
  text-align: left;
  color: crimson;
}

#demerit a{
  display: block;
  width: 250px;
  height: 50px;
  background: #cd1414;
  color: #fff;
  line-height: 50px;
  margin: 50px auto 0;
}

#flow{
  text-align: center;
  padding-bottom: 50px;
}

#flow div h5{
  background: #003db6;
  color: #fff;
  font-size: 28px;
  font-weight: bold;
  border-radius: 10px;
  width: 500px;
  margin: 0 auto;
  padding: 10px 0;
}

#flow div ul{
  width: 600px;
  margin: 30px auto;
}

#flow div ul li{
  display: flex;
  align-items: center;
}

#flow div ul li img{
  width: 150px;
}

#flow div ul li p{
  text-align: left;
  color: #003399;
  font-size: 16px;
  font-weight: bold;
}

#flow div ul li p span{
  font-size: 12px;
}

#usersVoice{
  background: #eefcff;
  text-align: center;
  padding-bottom: 50px;
}

#usersVoice ul{
  display: flex;
}

#usersVoice ul li{
  width: 300px;
  background: #fff;
  border-radius: 10px;
  box-shadow: 4px 4px 0px 0px #3f51b5;
  padding: 20px;
  color: #10398a;
  text-align: left;
  margin: 0 20px 20px 0;
}

#usersVoice ul li dl{
  display: flex;
  margin-bottom: 10px;
  border-bottom: 1px solid #ededed;
  padding-bottom: 5px;
}

#usersVoice ul li dl dt{
  text-align: left;
  width: 170px;
}

#usersVoice ul li dl:first-child dd{
  color: #10398a;
}

#usersVoice ul li dl dd{
  color: rgb(224, 221, 24);
}

#problem{
  text-align: center;
  background: #003db6;
  padding-bottom: 100px;
}

#problem img{
  width: 700px;
}

#problem ul{
  width: 600px;
  margin: 0 auto;
}

#problem ul li{
  display: flex;
  align-items: center;
  color: #fff;
  font-weight: bold;
  text-align: left;
  font-size: 25px;
  margin: 20px 0;
}

#problem ul li img{
  height: 25px;
  width: auto;
  margin-right: 10px;
}

.solutionCatch{
  text-align: center;
  position: relative;
  top: -75px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 700px;
  height: 150px;
  margin: 0 auto;
  font-size: 35px;
  font-weight: bold;
  background: #003db6;
  color: #f0ff00;
  border-radius: 20px;
  border: 5px solid #fff;
}

#solution .phone{
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 50px;
}

#solution .phone img{
  height: 100px;
  width: auto;
}

#solution .phone a{
  font-size: 90px;
  font-weight: bold;
  color: #003db6;
}

.lastCatch{
  background: #003db6;
  text-align: center;
  padding: 30px 0;
}

.lastCatch img{
  width: 700px;
}

.lastCatch p{
  color: #f0ff00;
  text-align: center;
  font-size: 35px;
  margin-top: 30px;
}

#other{
  width: 600px;
  margin: 50px auto;
}

#other p{
  text-align: center;
  font-size: 20px;
}

#other dl{
  margin: 30px 0;
}

#other dd{
  margin-left: 15px;
}

#company{
  text-align: center;
  background: #003db6;
  padding-bottom: 50px;
}

#company h2{
  color: #fff;
}

#company dl{
  color: #fff;
  display: flex;
  margin: 15px auto;
  width: 500px;
}

#company dl dt{
  width: 150px;
}

footer{
  background: #003db6;
  text-align: center;
  padding-bottom: 20px;
}

footer img{
  width: 200px;
}

footer nav{
  margin-bottom: 20px;
}

footer nav ul{
  display: flex;
  justify-content: center;
  margin-top: 10px;
}

footer nav ul li{
  margin-right: 10px;
}

footer nav ul li:last-child{
  margin: 0;
}

footer nav ul li a{
  font-size: 12px;
  color: #fff;
}

small{
  padding: 20px 0;
  color: #fff;
}

@media screen and (max-width: 1199px) {

  header{
    justify-content: center;
    position: relative;
  }

  button{
    display: block;
    position: absolute;
    top: 35px;
    right: 10px;
  }

  button span{
    display: block;
    height: 5px;
    width: 40px;
    background: #003db6;
    margin-bottom: 10px;
  }

  button span:last-child{
    margin: 0;
  }

  header .logo{
    margin-right: 50px;
  }

  .sp{
    display: block;
  }

  .show{
    position: fixed;
    top: 0;
    right: 0%;
    width: 100%;
    height: 100vh;
    background: #fffffff2;
    z-index: 1;
  }

  .hide{
    position: fixed;
    top: 0;
    right: 100%;
    width: 100%;
    height: 100vh;
    background: #fffffff2;
    z-index: 1;
  }

  header nav ul{
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }

  header nav ul li{
    border: none;
    width:100%;
    text-align: center;
    height: 70px;
    line-height: 70px;
    border-bottom: 1px solid #ddd;
  }

  header nav ul li button{
    display: block;
    width: 100%;
    position: initial;
    top: 35px;
    right: 10px;
  }

  header nav ul li:last-child{
    border-bottom: 1px solid #ddd;
  }

  header nav ul li a{
    display: block;
  }

}
@media screen and (max-width: 999px) {
  header{
    flex-direction: column;
    height: 50px;
    align-items: end;
  }

  .sp{
    display: block;
  }

  .pc{
    display: none;
  }

  button{
    top: 7px;
    right: 5px;
  }

  header .logo {
    margin: 0;
    width: 55%;
    max-width: 200px;
  }

  header .contact{
    position: absolute;
    top: 0;
    right: 50px;
    background: #003db6;
  }

  header .contact div{
  }

  header .contact div a:first-child{
    height: 50px;
    width: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
  }
  header .contact div a:nth-child(2){
    height: 50px;
    width: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
  }


  header .contact div img{
    width: 80%;
    margin: 0;
  }

  header .contact p{
    display: none;
  }

  #mainV .catch p {
    font-size: 14px;
    margin-bottom: 15px;
  }

  #mainV .catch h1 {
    font-size: 22px;
    letter-spacing: 0.1em;
    padding: 0 10px;
  }

  #mainV ul li:last-child{
    margin: 0;
  }

  #mainV ul li p{
    height: auto;
    font-size: 10px;
    line-height: 15px;
    bottom: -10px;
  }

  #mainV ul{
    align-items: center;
  }

  .line img{
    width: 45%;
  }

  header .line a{
    width: 45%;
    font-size: 25px;
  }

  .line a span{
    font-size: 20px;
  }

  #first .firstInner {
    width: 95%;
  }

  #first .firstInner img{
    width: 100%;
  }

  #first .firstInner{
    padding: 10px;
  }

  #first .firstInner p{
    width: 100%;
    font-size: 14px;
  }

  #first .announce{
    width: 95%;
    font-size: 14px;
    padding: 10px;
    line-height: 20px;
  }

  .line p{
    font-size: 16px;
  }

  .line a{
    width: 90%;
  }

  #aboutPresent p{
    padding: 0 10px;
  }

  #aboutPresent ul:nth-child(3){
  }

  #aboutPresent ul:nth-child(3) li{
    margin: 15px 0 0 0;
  }

  #aboutPresent ul:nth-child(3) li:last-child{
    margin: 15px 0 0 0;
  }

  #aboutPresent ul:nth-child(3) li p{
    font-size: 12px;
    height: 50px;
  }

  .planWrap .plan{
    width: 95%;
    flex-direction: column;
  }

  .planWrap .plan li .planExplain{
    width: 80%;
  }

  .planWrap .plan li{
    border: none;
    width: 100%;
    border-bottom: 1px solid #ddd;
  }

  #flow div ul{
    width: 100%;
  }

  .QAWrap dl{
    width: 95%;
  }

  #aboutDigital ul:nth-child(3){
  }

  #aboutDigital ul:nth-child(3) li{
    margin: 10px 0 0 0;
  }

  #aboutDigital ul:nth-child(3) li:last-child{
    margin: 10px 0 0 0;
  }

  #aboutDigital ul:nth-child(3) li p{
    height: 60px;
    font-size: 11px;
  }

  #aboutDigital .QAWrap{
    width: 100%;
  }

  #merit ul{
    width: 100%;
    justify-content: center;
    align-items: center;
  }

  #merit ul li{
    width: 50%;
    margin-right: 0;
  }

  #merit ul li p{
    font-size: 14px;
  }

  #demerit div ul:nth-child(2){
    width: 95%;
  }

  #demerit h5{
    width: 100%;
  }

  #demerit div p:nth-child(3){
    width: 100%;
  }

  .caution{
    width: 100%!important;
  }

  #problem ul{
    width: 95%;
  }

  #problem img{
    width:100%;
  }

  .solutionCatch{
    width: 95%;
    font-size: 20px;
    height: 100px;
  }

  #solution .phone img{
    height: 40px;
  }

  #solution .phone a{
    font-size: 35px;
  }
  
  #demerit div{
    width: 100%;
  }

  #demerit div ul:nth-child(3){
    
  }

  #demerit div ul:nth-child(3) li{
    width: 50%;
  }

  .lastCatch p{
    font-size: 20px;
  }

  #usersVoice ul{
    width: 100%;
  }

  #usersVoice ul li{
    flex-direction: column;
    width: 90%;
    margin: 0 0 20px 0;
  }

  #problem ul li{
    font-size: 15px;
  }

  #problem ul li img{
    height: 15px;
  }

  .lastCatch img{
    width: 100%;
  }

  #other{
    width: 90%;
  }

  #company dl dt{
    width: 90px;
  }

  #company dl{
    width: 100%;
  }
  
  .planWrap .plan li .planTitle span{
    letter-spacing: 0px;
  }

  footer nav ul{
    flex-wrap: wrap;
  }

  footer nav ul li{
    margin: 0 15px 15px 0;
  }
}