*, *:before, *:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box
}
html{
  scroll-behavior: smooth;
}
body {
  letter-spacing: 1.5px;
  max-width: 1000px;
  width: 100%;
  margin: auto;
}
footer{
    width: 100%;
    height: 100px;
    background-color: #333B3F;
    color: white;
    text-align: center;
}

ul.footer-menu li {
display: inline;
}
ul.footer-menu li a {
color: white;
}

.top img {
  max-width: 1000px;
  width: 100%;
}
.step {
  max-width: 950px;
  width: 100%;
  border: 1px solid #eadcc2;
  margin: 30px auto;
}
.step > p {
  width: 100%;
  background: #fef7ef;
  font-size: 2.5rem;
  text-align: center;
}
.step > p > span {
  font-size: 3.7rem;
}
.step .container {
  width: 100%;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  padding: 20px 0;
}
.container1 {
  display: flex;
}
.step .container img {
  width: 117px;
}
.step-text {
  margin: 7px
}
.step-deco {
  width: 80px;
  color: #171d59;
  border: 2px solid #171d59;
  text-align: center;
}
.arrow {
  font-size: 4.2rem;
  color: #b4b4b4;
  line-height: 10rem;
}
.arrow1 {
  display: none;
}
.btn {
  background: #ff971c;
  color: #fff;
  text-decoration: none;
  font-size: 3rem;
  font-weight: bold;
  letter-spacing: 0.5rem;
  line-height: 80px;
  width: 430px;
  box-shadow: 0 4px #935000;
  transition-property: transform;
  transition-duration: 0.3s;
}
.btn:hover {
  box-shadow: none;
  transform: translateY(4px);
}
.call-to-action {
  text-align: center;
  margin-bottom: 70px;
}
.feature h2 {
  text-align: center;
  color: #131957;
  font-size: 3.3rem;
}
.border {
  color: #131957;
  border-top: 2px solid;
  width: 140px;
  margin: 30px auto;
}
.feature {
  max-width: 1000px;
  width: 100%;
  margin: 30px auto;
}
.feature .container {
  width: 100%;
  display: flex;
  justify-content: space-between;
  margin-top: 60px;
}
.feature-box {
  border: 1px solid #171d59;
  text-align: center;
  margin: 10px;
}
.feature-box img {
  width: 130px;
}
.feature-box .text1 {
  background: #171d59;
  color: #fff;
  font-weight: bold;
  font-size: 2.5rem;
  padding: 15px;
  margin-bottom: 20px;
}
.feature-box .text2 {
  font-size: 1.7rem;
  text-align: left;
  padding: 20px 25px;
}
.mail {
  max-width: 1000px;
  width: 100%;
  background: #d7ecff;
  margin-top: 70px;
  margin-bottom: 72px;
  text-align: center;
}
.mail p {
  background: #171d59;
  color: #fff;
  font-size: 3.2rem;
  text-align: center;
  padding: 18px;
}
.mail img {
  max-width: 950px;
  width: 100%;
  margin: 40px auto;
}
.call-to-action h1 {
  color: #191e5e;
  margin: 40px;
}
.call-to-action span {
  font-size: 5rem;
}
.points {
  margin-bottom: 50px;
}
.point1 , .point2 , .point3 {
  display: flex;
  justify-content: space-between;
  border: 1px solid #171d59;
  border-radius: 5px;
  max-width: 950px;
  width: 100%;
  margin: 20px auto;
  padding: 20px;
}
.point1-img,.point2-img,.point3-img {
  display: flex;
  align-items: center;
}
.points img {
  height: 110px;
}
.point1-text-1,.point2-text-1,.point3-text-1,.point1-text-1-sp,.point2-text-1-sp,.point3-text-1-sp {
  background: #171d59;
  color: #fff;
  font-size: 2rem;
  padding: 3px 10px;
  letter-spacing: 1.5px;
}
.point1-text-2,.point2-text-2,.point3-text-2,.point1-text-2-sp,.point2-text-2-sp,.point3-text-2-sp {
  font-size: 2.5rem;
  font-weight: bold;
  color: #9d1c17;
}
.point1-text-1-sp,.point1-text-2-sp,.point2-text-1-sp,.point2-text-2-sp,.point3-text-1-sp,.point3-text-2-sp {
  display: none;
}
.point1-text , .point2-text , .point3-text {
  width: 78%;
}
.points p {
  margin-top: 20px;
  font-size: 1.7rem;
}
.voices {
  background: #d7ecff;
  max-width: 1000px;
  width: 100%;
  padding: 30px 0px;
}
.voice {
  display: flex;
  border: 1px solid #171d59;
  background: #fff;
  border-radius: 5px;
  max-width: 950px;
  width: 100%;
  margin: 30px auto;
  padding: 20px;
}
.voices h2 {
  color: #171c5c;
  font-size: 3.8rem;
  text-align: center;
}
.voice-img {
  display: flex;
  align-items: center;
}
.voices img {
  height: 150px;
}
.voice-text {
  width: 80%;
  margin-left: 20px;
}
.voice-text1 {
  font-size: 2.2rem;
  text-align: left;
  letter-spacing: 1.5px;
}
.voice-name {
  font-size: 2rem;
  text-align: right;
}
.price {
  background: #171d59;
  width: 100%;
  padding: 35px;
  margin-bottom:  100px;
}
.price-h {
  width: 80%;
  color: #fff;
  font-size: 4rem;
  text-align: center;
  border: 1px solid #fff;
  margin: 0 auto;
}
.price-container {
  display: flex;
  justify-content: center;
  align-items: flex-end;

  padding: 25px 0px;
}
.price-text1 {
  font-family: Yu Gothic UI;
  color: #fcff00;
  width: 8%;
  font-size: 5.5rem;
  line-height: 50px;
  text-align: center;
  margin-bottom: 15px;
}
.price-text2 {
  /* width: 60%; */
  text-align: center;
  padding: 0px;
  line-height: 75px;
}
.price-text2-1 {
  color: #fff;
  font-size: 3.5rem;
  padding: 0px;
}
.price-text2-2 {
  font-family: Yu Gothic UI;
  color: #fcff00;
  font-size: 14rem;
  font-weight: bold;
  padding: 0px;
  letter-spacing: -3px;
}
.price-text2-2 span {
  font-size: 7rem;
  font-weight: bold;
}
.price-text3 {
  background: #991c1a;
  /* width: 25%; */
  line-height: 45px;
  text-align: center;
  padding: 25px;
  margin: 0 10px;
  border-radius: 5px;
}
.price-text3-1 {
  color: #fff;
  font-size: 2.6rem;
}
.price-text3-2 {
  color: #fff;
  font-size: 3rem;
  margin: 0;
}
.price-text3-2 span{
  font-size: 6rem;
  font-weight: bold;
}
.price-f {
  color: #fff;
  text-align: center;
  font-size: 1.7rem;
}
.flow h2 {
  color: #171c5c;
  font-size: 3.8rem;
  text-align: center;
}
.border2 {
  color: #131957;
  border-top: 1px solid;
  margin: 70px auto;
}
.flow-number {
  display: flex;
  justify-content: center;
  align-items: center;
}
.number-deco {
  font-family: Yu Gothic UI;
  background: #171d59;
  color: #fff;
  font-size: 5rem;
  width: 80px;
  height: 80px;
  line-height: 80px;
  text-align: center;
  border-radius: 50%;
  margin: 0 50px 10px;
}
.arrow-deco {
  color: #171d59;
  font-size: 5rem;
  margin: 0 25px 10px;
}
.flow-text {
  display: flex;
  justify-content: center;
  padding: 20px 35px;
}
.flow-text p {
  width: 27%;
  font-size: 1.6rem;
  margin: 0px 40px;
}
.flow-img {
  display: flex;
  justify-content: center;
  padding: 5px 35px;
}
.flow-img img {
  width: 180px;
  margin: 0px 50px;
}
.flow-text2 {
  display: flex;
  justify-content: center;
  padding: 10px 35px;
}
.flow-text2 p {
  width: 27%;
  font-size: 1.1rem;
  margin: 0px 40px;
}
.flow-sp {
  display: none;
}
.hearing > p {
  color: #16195e;
  font-size: 1.8rem;
  text-align: center;
}
.hearing-top {
  background: #171d59;
  color: #fff;
  text-align: center;
  font-size: 4rem;
  letter-spacing: 5px;
  padding: 15px;
  margin: 45px 0px;
}
.hearing-top p {
  margin: 0;
}
h3{
  color: #171c5c;
  font-size: 3rem;
  text-align: center;
}
.btn1{
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border-radius: .6em;
  font-weight: bold;
  margin: 10px;
}
.btn1 p{
  display: inline-block;
  font-size: 2rem;
  margin: 1em 0;
}
.btn1 {
  border: 4px solid ;
  opacity: 1;
}
.btn1 b{
  font-size: 2.8rem;
  padding: 0 10px 0 20px;
}
.btnc2{
  color: #000000;
  border-color: #000000;
}
.active{
  color: #1D51C3;
  border-color: #1D51C3;
}
.deactive{
  color: #1D51C3;
  border-color: #1D51C3;
}

#form_first{
  display: none;
}

.form_active{

}

.form_deactive{
  display: none;
}

#hearing{
  padding-top: 70px;
  margin-top: -70px;
}

form {
  padding: 15px;
}
.form-question1 {
  background: #171d59;
  color: #fff;
  font-size: 1.7rem;
  font-weight: bold;
  padding: 10px 15px;
  border-radius: 5px;
}
.form-question2 {
  color: #18215a;
  font-size: 1.6rem;
  font-weight: bold;
  margin: 10px;
}
.question-container {
  margin-bottom: 40px;
}
.question-text {
  display: flex;
}
label {
  font-size: 1.5rem;
  padding-left: 7px;
}
.form-container {
  display: flex;
}
.form-container-1 {
  width: 45%;
}
textarea {
  width: 95%;
  height: 100px;
  padding: 15px;
}
.uproad {
  color: #18215a;
  font-weight: bold;
}
.nameform {
  display: flex;
}
.nameform1 {
  width: 48%;
}
.input-deco {
  width: 95%;
  padding: 10px;
}
.npc{
  display: none;
}

@media (max-width: 640px)  {
    .npc{
      display: block;
    }
  main {
    margin: 0 7px;
  }
  .step .container {
    flex-direction: column;
  }
  .container1 {
    justify-content: center;
  }
  .step > p {
    font-size: 2rem;
  }
  .step > p > span {
    font-size: 3rem;
  }

  .arrow {
    display: none;
  }
  .arrow1 {
    display: flex;
    font-size: 4.2rem;
    line-height: 35px;
    color: #b4b4b4;
    padding: 0px 15px;
    justify-content: center;
  }
  .btn {
    font-size: 1.7rem;
    font-weight: bold;
    letter-spacing: 0.5rem;
    line-height: 65px;
    width: 250px;
    box-shadow: 0 4px #935000;
  }
  .border {
    border-top: 2px solid;
    width: 140px;
    margin: 5px auto;
  }
  .feature .container {
    display: inline;
  }
  .feature h2 {
    font-size: 2rem;
  }
  .feature-box img {
    width: 80px;
  }
  .feature-box {
    margin: 10px;
  }
  .feature-box .text1 {
    font-size: 2rem;
    padding: 5px;
    margin-bottom: 5px;
  }
  .feature-box .text2 {
    font-size: 1.4rem;
    text-align: left;
    padding: 5px 8px;
  }
  .mail {
    margin-top: 15px;
    margin-bottom: 30px;
  }
  .mail p {
    font-size: 2.5rem;
    padding: 10px;
  }
  .call-to-action h1 {
    margin: 10px;
    font-size: 1rem;
  }
  .call-to-action span {
    font-size: 2.8rem;
  }
  .points {
    margin: 0 5px;
  }
  .point1-text-1 , .point2-text-1 , .point3-text-1 {
    display: none;
  }
  .point1-text-2 , .point2-text-2 , .point3-text-2 {
    display: none;
  }
  .point1-text-1-sp,.point1-text-2-sp,.point2-text-1-sp,.point2-text-2-sp,.point3-text-1-sp,.point3-text-2-sp {
    display: inline;
  }
  .point1-text-1-sp,.point2-text-1-sp,.point3-text-1-sp {
    font-size: 1.4rem;
  }
  .point1-text-2-sp,.point2-text-2-sp,.point3-text-2-sp {
    font-size: 1.5rem;
    line-height: 25px;
  }
  .points p {
    margin-top: 20px;
    font-size: 1rem;
  }
  .points img {
    height: 70px;
  }
  .point1 , .point2 , .point3 {
    padding: 10px;
  }
  .voices {
    padding: 20px 5px;
  }
  .voices h2 {
    font-size: 2.2rem;
    margin-top: 7px;
  }
  .voices img {
    height: 80px;
  }
  .voice-text1 {
    font-size: 1.2rem;
  }
  .voice-name {
    font-size: 1.1rem;
  }
  .price {
    padding: 15px;
    margin-bottom: 30px;
  }
  .price-h {
    width: 80%;
    font-size: 1.8rem;
    margin: 0 auto;
  }
  .price-container {
    padding: 10px 0px;
  }
  .price-text1 {
    font-size: 1.5rem;
    line-height: 18px;
    margin-bottom: 2px;
  }
  .price-text2 {
    text-align: center;
    padding: 0px;
    line-height: 20px;
  }
  .price-text2-1 {
    color: #fff;
    font-size: 1.3rem;
    padding: 0px;
  }
  .price-text2-2 {
    font-size: 4.2rem;
    padding: 0px;
    letter-spacing: -3px;
  }
  .price-text2-2 span {
    font-size: 2.2rem;
    font-weight: bold;
  }
  .price-text3 {
    line-height: 10px;
    padding: 5px;
    margin: 0 5px;
    border-radius: 5px;
  }
  .price-text3-1 {
    color: #fff;
    font-size: 1.1rem;
  }
  .price-text3-2 {
    color: #fff;
    font-size: 1.1rem;
    margin: 0;
  }
  .price-text3-2 span{
    font-size: 1.6rem;
    font-weight: bold;
  }
  .price-f {
    font-size: 1.1rem;
  }
  .flow {
    display: none;
  }
  .border2 {
    margin: 25px auto;
  }

  .flow-sp {
    display: block;
    text-align: center;
  }
  .flow-sp-1 {
    display: flex;
    justify-content: center;
  }
  .number-deco {
    font-size: 2rem;
    width: 40px;
    height: 40px;
    line-height: 40px;
    text-align: center;
    border-radius: 50%;
    margin: 5px;
  }
  .flow-sp h2 {
    font-size: 1.9rem;
  }
  .flow-sp-text {
    width: 70%;
    font-size: 1.3rem;
  }
  .flow-sp-text2 {
    font-size: 1.2rem;
    text-align: center;
    padding: 10px;
  }
  .flow-sp img {
    width: 150px;
  }
  .hearing > p {
    font-size: 1.2rem;
  }
  .hearing-top {
    font-size: 2.2rem;
    letter-spacing: 5px;
    padding: 10px;
    margin: 30px 0px;
  }
  h3{
  font-size: 1.8rem;
}
  .btn1 p{
    font-size: 1.4rem;
  }
  .btn1 b{
    font-size: 1.8rem;
    padding: 8px;
  }
  form {
    padding: 10px;
  }
  .form-question1 {
    font-size: 1.2rem;
    font-weight: bold;
    padding: 5px 5px;
    border-radius: 3px;
  }
  .form-question2 {
    font-size: 1.2rem;
    font-weight: bold;
    margin: 5px;
    line-height: 27px;
  }
  .form-container {
    display: inline;
  }
  .form-container-1 {
    width: 100%;
  }
  label {
    font-size: 1.2rem;
  }
  .input-up {
    width: 95%;
  }
