@charset "UTF-8";



.pageH h2{
  padding-left: 0.1em;
  letter-spacing: 0.1em;
  line-height: 1.8;
}
/*for PC*/
@media screen and (min-width: 768px) {
  .pageH {
    padding-bottom: 45px;
  }
  .pageH h2{
    padding-left: 0.3em;
    letter-spacing: 0.3em;
  }
}




/*
lp
---------------------------*/
.lp {}
/*.lp .ttlEn {
  font-size: clamp(calc(29px * 0.7), calc(29vw / 9.76), 29px);
  letter-spacing: 0.1em;
  line-height: 1.0;
}*/

.lp figure{
  position: relative;
  width: calc((610 / 976) * 100%);
  max-width: 610px;
  margin: 0 auto;
}
.lp figure .cap {
  position: absolute;
  left: 0;
  bottom: 70px;
}
.lp .leg{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  width: calc((610 / 976) * 100%);
  margin: 10px auto 0 auto;
}
.lp .leg li{
  display: flex;
  align-items: center;
  margin: 0 10px 0 0;
  font-size: 10px;
  letter-spacing: 0.1em;
  line-height: 1.0;
  text-align: left;
}
.lp .leg li::before{
  content: "";
  display: block;
  width: 50px;
  height: 15px;
  margin: 0 10px 0 0;
  border-width: 2px;
  border-style: solid;
}
.lp .leg li:nth-of-type(1)::before{
  border-color: #55785a;
}
.lp .leg li:nth-of-type(2)::before{
  border-color: #c35f0a;
}
.lp .leg li:nth-of-type(3)::before{
  background: #dfcdb6;
  border-color: #dfcdb6;
}
@media screen and (max-width: 767px) {
  .lp {}
  /*.lp .ttlEn {
    font-size: clamp(calc(24px * 0.7), calc(24vw / 3.75), 24px);
  }*/
  .lp figure{
    width: 100%;
    margin: 0;
  }
  .lp figure .cap{
    bottom: 10px;
    left: 30px;
  }
  .lp .leg{
    width: 100%;
  }
  .lp .leg li{
    margin: 10px 10px 0 0;
    letter-spacing: normal;
  }
  .lp .leg li::before{
    width: 20px;
    margin-right: 5px;
  }
}

  

/*
takuchi
---------------------------*/
.takuchi{}

.takuchi h2{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 6em;
  height: 40px;
  padding-left: 0.1em;
  background: #333;
  color: #fff;
  font-size: clamp(calc(16px * 0.7), calc(16vw / 9.76), 16px);/*16 / 15*/
  line-height: 1.0;
  letter-spacing: 0.1em;
}

.takuchi table{
  width: 100%;
  max-width: 700px;
  margin: 50px auto 0 auto;
  border-collapse: collapse;
}
.takuchi table tr:nth-of-type(2n) td{
  background: #fff;
}
.takuchi table tr:nth-of-type(2n+1) td{
  background: #ebebeb;
}


.takuchi table th{
  position: relative;
  padding: 15px 0;
  background: #3d688e;
  color: #fff;
  font-size: clamp(calc(18px * 0.7), calc(18vw / 9.76), 18px);/*18 / 15*/
  font-weight: 400;
  line-height: 1.0;
  text-align: center;
}
.takuchi table th:nth-of-type(1){
  /*width: calc((140 / 700) * 100%);*/
  width: 140px;
}
.takuchi table th:nth-of-type(2){
  /*width: calc((350 / 700) * 100%);*/
  width: 350px;
}
.takuchi table th:nth-of-type(3){
  /*width: calc((210 / 700) * 100%);*/
  width: 210px;
}
.takuchi table th p{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 60px;
}
.takuchi table th + th p{
  border-left: 1px solid #fff;
}


.takuchi table .np{
  position: absolute;
  left: 50%;
  top: -12px;
  display: block;
  width: 160px;
  height: 50px;
  background: #c35f0a;
  color: #fff;
  font-size: clamp(calc(26px * 0.7), calc(26vw / 9.76), 26px);/*26 / 20*/
  line-height: 50px;
  transform: translate(-50%,0);
}
.takuchi table .np + p{
  padding-top: 33px;
}
.takuchi table td{
  padding: 20px 0;
  border-bottom: 1px solid #64645a;
  font-size: clamp(calc(18px * 0.7), calc(18vw / 9.76), 18px);/*18 / 15*/
  line-height: 1.0;
  text-align: center;
}
.takuchi table td:nth-of-type(3){
  font-size: clamp(calc(23px * 0.7), calc(23vw / 9.76), 23px);/*23 / 18*/
}

.takuchi table td:nth-of-type(2) span{
  margin: 0 0.3em;
}

/*for SP*/
@media screen and (max-width: 767px) {
  .takuchi{}
  .takuchi h2{
    height: 36px;
    font-size: clamp(calc(15px * 0.7), calc(15vw / 3.75), 15px);/*16 / 15*/
  }
  .takuchi table{
    max-width: initial;
    margin: 20px auto 0 auto;
  }
  .takuchi table tr:nth-of-type(2n+1) td{}
  .takuchi table th{
    padding: 10px 0;
    font-size: clamp(calc(15px * 0.7), calc(15vw / 3.75), 15px);/*18 / 15*/
  }
  .takuchi table th:nth-of-type(1){
    /*width: calc((140 / 700) * 100%);*/
    width: 3.5em;
  }
  .takuchi table th:nth-of-type(2){
    /*width: calc((350 / 700) * 100%);*/
    width: auto;
  }
  .takuchi table th:nth-of-type(3){
    /*width: calc((210 / 700) * 100%);*/
    width: auto;
  }
  .takuchi table th p{
    height: 40px;
  }
  .takuchi table th + th p{}


  .takuchi table .np{
    top: -10px;
    width: 80%;
    height: 30px;
    font-size: clamp(calc(12px * 0.7), calc(12vw / 3.75), 12px);
    line-height: 30px;
    white-space: nowrap;
  }
  .takuchi table .np + p{
    padding-top: 18px;
  }
  .takuchi table td{
    font-size: clamp(calc(15px * 0.7), calc(15vw / 3.75), 15px);/*18 / 15*/
  }
  .takuchi table td:nth-of-type(3){
    font-size: clamp(calc(18px * 0.7), calc(18vw / 3.75), 18px);/*23 / 18*/
  }

  .takuchi table td:nth-of-type(2) span{}
}



.cvWrap{
  padding: 60px 0 0 0;
  background: #fff;
  filter: drop-shadow(2px 2px 1px rgba(0,0,0,0.3));
  text-align: center;
}
.cvWrap .t01{
  padding-left: 0.4em;
  font-size: clamp(calc(25px * 0.7), calc(25vw / 9.76), 25px);/*25 / 20*/
  line-height: 1.2;
  letter-spacing: 0.4em;
}
.cvWrap .t01 + p{
  margin: 25px 0 0 0;
  padding-left: 0.2em;
  letter-spacing: 0.2em;
}
.cvWrap ul{
  display: flex;
  margin: 50px 0 0 0;
}
.cvWrap ul li{
  width: calc(100% / 2);
  height: 120px;
}
.cvWrap ul li a{
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding-left: 0.2em;
  color: #fff;
  font-size: clamp(calc(20px * 0.7), calc(20vw / 9.76), 20px);/*20 / 18*/
  letter-spacing: 0.2em;
}

.cvWrap ul li a .icoArrow{
  right: 20px;
  top: 50%;
  transform: translate(0,-50%);
}

@media screen and (min-width: 768px) {
  /*hover*/
  .cvWrap ul li a:hover .icoArrow{
    right: 15px;
  }
}

.cvWrap ul li.res a{
  background: #3d688e;
}
.cvWrap ul li.req a{
  background: #333;
}
/*for SP*/
@media screen and (max-width: 767px) {
  .cvWrap{
    padding-top: 30px;
  }
  .cvWrap .t01{
    padding-left: 0.2em;
    font-size: clamp(calc(20px * 0.7), calc(20vw / 3.75), 20px);/*25 / 20*/
    letter-spacing: 0.2em;
  }
  .cvWrap .t01 + p{
    margin-top: 20px;
    padding-left: 0.1em;
    letter-spacing: 0.1em;
  }
  .cvWrap ul{
    display: block;
    margin-top: 30px;
  }
  .cvWrap ul li{
    width: 100%;
    height: 80px;
  }
  .cvWrap ul li a{
    padding-left: 0.1em;
    font-size: clamp(calc(16px * 0.7), calc(16vw / 3.75), 16px);/*20 / 16*/
    letter-spacing: 0.1em;
  }
  /*hover*/
  .cvWrap ul li a:active .icoArrow{
    right: 15px;
  }
}

