/* reset */
.col3{
  width:auto;
  margin:auto;
}
.inner{
  padding:0;
}

.ctaButton:after{
  display:none;
}

/* style */

#nav{
  height:6.6rem;
}

#nav > .nav{
  justify-content: center;
}

.heroFormContainer form{
  margin-top:1.6rem;
}

header#header{
  padding:0 10rem;
}

#firstView{
  margin-top:10rem;
  background:linear-gradient(60deg,#0080FF,#284ADD);
}

#firstView > .inner{
  display:flex;
  justify-content: space-around;
  align-items: center;
  flex-wrap:wrap;
  margin:0 auto;
  /* width:83.46%; */
  width:96%;
  max-width:114rem;
  padding: 2.2rem 0;
}

.fv1{
  width:35%;
}

.fv1 p span{
  /* font-size:3.55vw; */
  font-size:4.2rem;
  display:block;
  color:#fff;
  letter-spacing: .2rem;
}

.fv1 p > span >span{
  font-size:120%;
  display:inline;
  color:#FFD600;
  vertical-align: -.2rem;
}

.fv1 p + img{
  display:block;
  margin-top:2rem;
  width:22rem;
}

.fv2{
  width:30%;
  text-align:left;
}

.fv2 > img{
  width:96%;
}

.fv3{
  width:35%;
}

.heroFormContainer h2{
  font-size: 2rem;
  position: relative;
  text-align: center;
  color:#000;
}
.heroFormContainer h2:after {
  position: absolute;
  content: "";
  width: 60px;
  height: 4px;
  background: #FFD600;
  margin: auto;
  bottom: -10px;
  left: 0;
  right: 0;
}

.formHead p{
  font-size:1.4rem;
  margin-bottom:.6rem;
}

.formHead p > span{
  font-size:1.3rem;
  padding:0 .5rem;
  border-radius:.2rem;
}

.formFooter.name span{
  font-size:1.4rem;
}

.heroFormContainer > form > p{
  font-size:1.4rem;
  margin-bottom:1.4rem;
}

.heroFormContainer > form > p a{
  font-size:1.4rem;
}

.formSubmit{
  font-size:1.6rem;
}

.formFooter input{
  font-size:1.4rem;
}

.formFooter.name{
  justify-content: space-between;
}
.formFooter.name span input{
  width:100%;
}

.common{
  padding:5rem 1.4rem 8rem;
}

.common h2{
  margin-bottom:3.2rem;
}

.col3{
  width:96%;
  max-width:114rem;
  margin:0 auto;
}

.col3 .inner{
  display:flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap:wrap;
}

.col3 .inner .col3Child{
  width:29%;
  margin:0 2.1% 1.6rem;
}

.col3 .inner .col3Child img{
  margin-bottom:1.8rem;
}

.col3 .inner .col3Child p{
  margin-top:3rem;
  text-align:left;
}

#problem{
  position:relative;
  width:100%;
  padding:2rem 1.4rem;
  background:#284ADD;
}

#problem:after{
  position:absolute;
  content:"";
  background:center /contain no-repeat url(../img/arrrow.png);
  bottom:-2.3rem;
  left:0;
  right:0;
  margin:0 auto;
  width:6rem;
  height:2.4rem;
}

#problem .inner{
  width:96%;
  max-width:74rem;
  margin:0 auto;
  position:relative;
}

#problem .inner:after{
  position:absolute;
  content:"";
  background:center / contain no-repeat url(../img/problem.svg);
  width:17.8rem;
  height:15.6rem;
  right:0;
  bottom:-2rem;
}

#problem .inner > p{
  margin:0;
  text-align: left;
  color:#fff;
  font-size:3rem;
}

#problem .inner > p:nth-of-type(1){
  margin-bottom:.5rem;
}

#problem .inner > p:nth-of-type(2){
  font-size:1.6rem;
}

#select{
  background:#0080FF;
}

#select > span{
  display:block;
  text-align:center;
  background:#FFD600;
  width:47rem;
  margin:0 auto .8rem;
  padding:.4rem 2.4rem;
  border-radius:10rem;
}

#select > h2{
  text-align:center;
  color:#fff;
}

.col2{
}

.col2 .inner{
  display:flex;
  justify-content: flex-start;
  flex-wrap:wrap;
  width:96%;
  max-width:114rem;
  margin:0 auto;
}

.col2Child{
  width:48%;
  margin:0 1% 1.6rem;
  padding:3.2rem 1.8rem;
}

#select .col2Child{
  display:flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap:wrap;
  background:#fff;
  border-radius: 1rem;
  box-shadow: .3rem .6rem 1rem rgba(186, 237, 255, .34);
}

#select .col2Child img{
  width:20.76%;
  height:auto;
}

.col2ChildInner{
  width:75.31%;
}

.col2ChildInner *{
  text-align: left;
}

.col2ChildInner h3{
  margin-bottom:1.4rem;
}

.col2ChildInner h3:after{
  left:0;
  right:auto;
  bottom:-.8rem;
}

#select .col2Child.otherFeature2{
  width:100%;
  display: block;
}

#select .col2Child.otherFeature2 ul{
  margin:2.7rem 0 0;
  padding:0;
  list-style: none;
}

#select .col2Child.otherFeature2 ul > li{
  margin-bottom:1rem;
  margin-left:3.6rem;
  position:relative;
}

#select .col2Child.otherFeature2 ul > li:before{
  position: absolute;
  content: "";
  width: .9rem;
  height: .9rem;
  background: #0080FF;
  margin:0;
  top:.8rem;
  left: -1.8rem;
  border-radius:100%;
}

#case{
  background:#E9F4FF;
}

#case > .inner:nth-of-type(1){
  display:flex;
  justify-content: flex-start;
  flex-wrap:wrap;
  width:96%;
  max-width:114rem;
  margin:0 auto;
}


#case > .inner:nth-of-type(1) .col3Child{
  width:31%;
  margin:0 1.15% 1.6rem;
  padding: 3.2rem 1.2rem;
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0.3rem 0.6rem 1rem rgba(186, 237, 255, .34);
  position:relative;
}
/* 後ほど削除 */
/* #case > .inner:nth-of-type(1) .col3Child{
  width:48%;
  margin:0 1% 1.6rem;
} */

#case > .inner:nth-of-type(1) .col3Child .caseTag{
  position:absolute;
  background:#284ADD;
  border-radius:10rem;
  padding:.3rem 1rem;
  color:#fff;
  font-size:1.2rem;
  top:1.6rem;
  right:1.2rem;
}

#case > .inner:nth-of-type(1) .col3Child img{
  width:18rem;
  height:auto;
  display: block;
  margin:2.6rem auto 1.1rem;
}

#case > .inner:nth-of-type(1) .col3Child p{
  margin-top:3.2rem;
}

#case > .inner:nth-of-type(1) .col3Child a{
  display:block;
  position:absolute;
  width:100%;
  height:100%;
  top:0;
  left:0;
}

#case > .inner:nth-of-type(2){
  display:flex;
  justify-content: flex-start;
  flex-wrap:wrap;
  width:96%;
  max-width:114rem;
  margin:0 auto;
}

#case > .inner:nth-of-type(2) .col4Child{
  width:23%;
  margin:0 1% 1.6rem;
  padding: 0 1.2rem 2.6rem;
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0.3rem 0.6rem 1rem rgba(186, 237, 255, .34);
  text-align:center;
  position:relative;
}

#case > .inner:nth-of-type(2) .col4Child img{
  width:18rem;
  height:auto;
  display: block;
  margin:0 auto;
}

#case > .inner:nth-of-type(2) .col4Child h3{
  font-size:1.8rem;
}

#case > .inner:nth-of-type(2) .col4Child .caseTag{
  background:#284ADD;
  border-radius:10rem;
  padding:.3rem 1rem;
  color:#fff;
  font-size:1.2rem;
  display: inline-block;
  margin-top: 2.2rem;
}

#case > .inner:nth-of-type(2) .col4Child a{
  display:block;
  position:absolute;
  width:100%;
  height:100%;
  top:0;
  left:0;
}

.cta > .inner{
  padding:3.2rem 1.4rem;
}

.cta > .inner h2{
  font-size:2.6rem;
}

.cta p{
  font-size:1.6rem;
}

.cta a{
  margin: 0 auto;
  background: #FFD600;
  border-radius: 10rem;
  padding: 1.2rem 4.4rem;
  font-size:1.6rem;
  color:#000;
  margin-top:0;
}

.ctaWay{
  margin:0;
}

.cwLeft{
  margin:0;
}

#faq{
  padding:5rem 1.4rem 8rem;
}

.faq > .inner{
  max-width:114rem;
}

.question > h3{
  font-size:1.8rem;
}

.answer > p{
  font-size:1.6rem;
}

.countermeasure{
  padding:5rem 1.4rem 8rem;
}

.countermeasure > .inner{
  max-width:76.6rem;
}

.countermeasure > .inner > p{
  text-align:left;
}

.dmarc25{
  padding:5rem 1.4rem 8rem;
}

.dmarc25 > .inner{
  max-width:76.6rem;
  padding:0;
}

.dmarc25 > .inner > p{
  text-align:left;
}

@media(min-width:1024px) and (max-width:1189px){
  .fv1 p span{
    font-size:3.45vw;
  }
}

@media(min-width:1190px) and (max-width:1300px){
  .fv1 p span{
    font-size:3.25vw;
  }
}

@media(min-width:800px) and (max-width:1023px){
  .fv1 p span{
    font-size:3.25vw;
  }
}
@media(min-width:769px) and (max-width:1023px){
  header#header{
    padding:0 1rem;
  }
  #nav.active {
    height: calc(100vh - 70px);
  }
  #firstView{
    margin-top:7rem;
  }
  .fv1{
    width:49%;
  }
  .fv2{
    display:none;
  }
  .fv3{
    width:49%;
  }
  .fv1 p span{
    font-size:3.6rem;
  }
}

@media(max-width:1080px){
  #nav{
    padding:1.6rem;
  }
}

@media(max-width:768px){
  header#header{
    padding:0 1.6rem;
  }
  header#header > a > img{
    height:4rem;
  }
  #firstView{
    margin-top:7rem;
  }
  .fv1{
    width:49%;
  }
  .fv2{
    width:49%
  }
  .fv3{
    width:100%;
  }
  .fv1 p span{
    font-size:4.6vw;
  }
  #problem .inner:after{
    width: 12.8rem;
    height: 11.6rem;
    right: -3.8rem;
  }
  #nav.active {
    height: calc(100vh - 70px);
  }
}

@media(max-width:480px){
  p, li, a, blockquote, div, span, th, td{
    font-size:1.6rem;
  }
  .common,#faq{
    padding:4rem 1.4rem 3.2rem;
  }
  #firstView > .inner{
    justify-content: flex-start;
  }
  .fv2{
    order:1;
    width:100%;
    text-align:right;
  }
  .fv2 img{
    width:80%;
  }
  .fv1{
    order:2;
    width:100%;
    margin-top: -20%;
    margin-bottom:3.6rem;
  }
  .fv1 p span{
    font-size:3.4rem
  }
  .fv3{
    order:3;
  }
  .fv1 p + img{
    margin-top:1rem;
  }
  .col3 .inner .col3Child{
    width:100%;
    margin: 0 auto 2.2rem;
  }
  #problem .inner > p{
    font-size:2.2rem;
  }
  #problem .inner:after{
    width:15.3rem;
    height:13.4rem;
    right:-2.2rem;
    top:-6rem;
    bottom:auto;
  }
  #select > span{
    width:auto;
    margin:0 auto 1.8rem;
  }
  #select > h2{
    margin-bottom:2.2rem;
  }
  #select .col2Child{
    width:100%;
    padding:3.2rem 1.4rem;
  }
  #select .col2Child img{
    width:11rem;
  }
  .col2ChildInner{
    width:calc(100% - 12rem);
  }
  .col2 .inner{
    width:100%;
  }
  #case > .inner:nth-of-type(1){
    width:100%;
  }
  #case > .inner:nth-of-type(1) .col3Child{
    width:100%;
  }
  #case > .inner:nth-of-type(1) .col3Child:nth-of-type(3){
    padding-bottom:2.2rem;
  }
  /* #case > .inner:nth-of-type(1) .col3Child:nth-of-type(3) img{
    display:none;
  } */
  #case > .inner:nth-of-type(2){
    width:100%;
  }
  #case > .inner:nth-of-type(2) .col4Child{
    width: 48%;
    margin: 0 1% 1.6rem;
  }
  .cta > .inner h2{
    font-size:2.2rem;
  }
  .countermeasure{
    padding:3rem 1.4rem 4rem;
  }
  .dmarc25 {
    padding:3rem 1.4rem 4rem;
  }
  #nav{
    height: calc(100vh - 70px);
  }
  #case > .inner:nth-of-type(2) .col4Child h3{
    font-size:1.4rem;
  }
  #case > .inner:nth-of-type(2) .col4Child img{
    width:100%;
  }
  .heroFormContainer h2{
    font-size:2.2rem;
  }
  .formFooter.name span{
    width:49%;
  }
}

.cta a{
  transition:all .3s ease;
}

.cta a:hover {
  box-shadow: 0 3px 10px rgba(0,0,0,.16);
}

.ctaButton.header{
  
}

.ctaButton.header:before{
  position: absolute;
  content: "";
  width: 1.6rem;
  height: 1.8rem;
  background-image: url(../../img/new_window.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  top: 0;
  bottom: 0;
  right: 2.2rem;
  margin: auto;
}

.cta a{
  position: relative;
}

.cta a:before{
  position: absolute;
  content: "";
  width: 1.3rem;
  height: 1.4rem;
  background-image: url(../../img/contactRightArrow.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  top: 0;
  bottom: 0;
  right: 2.2rem;
  margin: auto;
}

ul.navContact > li > a:before{
  position: absolute;
  content: "";
  width: 1.3rem;
  height: 1.4rem;
  background-image: url(../../img/contactRightArrow.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  top: 0;
  bottom: 0;
  right: 2.2rem;
  margin: auto;
}

.formHead p > span:nth-of-type(2){
  display:inline;
}
@media(max-width:480px){
  .formHead p > span:nth-of-type(2){
    font-size:1.2rem;
    display:block;
  }
}