@charset "UTF-8";

.haed_h2 {
  font-size: 4.8rem;
  text-align: left;
  font-weight: 600;
  line-height: 1.46;
  letter-spacing: 0.06em;
  margin-bottom: .9em;
  padding-bottom: .55em;
  position: relative;
}
.haed_h2::before {
  background: #0A51B8;
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  height: .4rem;
  width: 6rem;
}
#sec01 {
  padding-top: 5rem;
}
#sec01 .wrap .lead {
  font-size: 1.6rem;
  text-align: center;
  font-weight: 400;
  line-height: 2.06;
  letter-spacing: 0.06em;
  margin-bottom: 6rem;
}
#sec01 .wrap .content h2 {
  background: #0A51B8;
  border-radius: .7rem;
  color: #fff;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.06em;
  margin-bottom: 3.5rem;
  padding: 1.8rem 3rem;
}
#sec01 .wrap .content p {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 2.06;
  letter-spacing: 0.06em;
  padding: 0 1.5rem;
}
@media screen and (max-width: 1200px) {
  .haed_h2 {
    font-size: 4vw;
  }
  .haed_h2::before {
    height: .3rem;
    width: 5.6rem;
  }
  #sec01 {
    padding-top: 4.1666vw;
  }
  #sec01 .wrap .lead {
    font-size: 1.333vw;
    margin-bottom: 5vw;
  }
  #sec01 .wrap .content h2 {
    border-radius: .6rem;
    font-size: 1.8333vw;
    margin-bottom: 2.9166vw;
    padding: 1.5rem 2.5vw;
  }
  #sec01 .wrap .content p {
    font-size: 1.333vw;
    padding: 0 1.25vw;
  }
}
@media screen and (max-width: 840px) {
  .haed_h2 {
    font-size: 6.4vw;
    margin-bottom: 1.25em;
    padding-bottom: 1em;
  }
  .haed_h2::before {
    width: 3.8rem;
  }
  #sec01 {
    padding-top: 17.33vw;
  }
  #sec01 .wrap {
    width: 92vw;
  }
  #sec01 .wrap .lead {
    font-size: 3.7333vw;
    margin-bottom: 13.333vw;
    padding: 0 2.6666vw;
  }
  #sec01 .wrap .content h2 {
    border-radius: 1.3333vw;
    font-size: 4.2666vw;
    margin-bottom: 5.8666vw;
    padding: 3.7333vw 5.8666vw;
  }
  #sec01 .wrap .content p {
    font-size: 3.7333vw;
    padding: 0 2.666vw;
  }
}

#sec02 {
  padding: 13rem 0;
}
#sec02 .recruit_tab {
  margin-bottom: 3.5rem;
}
#sec02 .recruit_tab ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
#sec02 .recruit_tab ul li a {
  background: #D5D5D5;
  border-radius: .5rem;
  color: #fff;
  display: block;
  font-size: 1.7rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-align: center;
  padding: 2.5rem 1.5rem;
}
#sec02 .recruit_tab ul li a:hover {
  background: #0A51B8;
  opacity: 1.0;
}
#sec02 .recruit_tab ul li a.act {
  background: #0A51B8;
}
#sec02 .recruit_content dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#sec02 .recruit_content dl dt, 
#sec02 .recruit_content dl dd {
  border-bottom: 1px solid #B2B2B2;
  font-size: 1.7rem;
  font-weight: 400;
  line-height: 1.88;
  letter-spacing: 0.06em;
}
#sec02 .recruit_content dl:first-child dt, 
#sec02 .recruit_content dl:first-child dd {
  border-top: 1px solid #B2B2B2;
}
#sec02 .recruit_content dl dt {
  background: #F0F0F0;
  font-weight: 600;
  text-align: center;
  padding: 2.354rem 1rem;
  max-width: 22rem;
  min-width: 22rem;
}
#sec02 .recruit_content dl dd {
  background: #fff;
  font-weight: 400;
  padding: 2.354rem 3.8rem;
  flex-grow: 1;
}
#sec02 .recruit_content h2 {
  background: #0A51B8;
  border-radius: .7rem;
  color: #fff;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.06em;
  margin-top: 6rem;
  margin-bottom: 3.5rem;
  padding: 1.8rem 3rem;
}
#sec02 .recruit_content p {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 2.06;
  letter-spacing: 0.06em;
  padding: 0 1.5rem;
}
#sec02 .btn {
  margin-top: 6rem;
}
#sec02 .btn a {
  width: 31rem;
  height: 7rem;
  margin: 0 auto;
}
@media screen and (max-width: 1200px) {
  #sec02 {
    padding: 10.333vw 0;
  }
  #sec02 .recruit_tab {
    margin-bottom: 2.9166vw;
  }
  #sec02 .recruit_tab ul li a {
    border-radius: .4rem;
    font-size: 1.4166vw;
    padding: 2.0833vw 1.25vw;
  }
  #sec02 .recruit_content dl dt, 
  #sec02 .recruit_content dl dd {
    font-size: 1.4166vw;
  }
  #sec02 .recruit_content dl dt {
    padding: 1.9616vw 0.8333vw;
    max-width: 18.333vw;
    min-width: 18.333vw;
  }
  #sec02 .recruit_content dl dd {
    padding: 1.9616vw 3.166vw;
  }
  #sec02 .recruit_content h2 {
    border-radius: .6rem;
    font-size: 1.8333vw;
    margin-top: 5vw;
    margin-bottom: 2.9166vw;
    padding: 1.5rem 2.5vw;
  }
  #sec02 .recruit_content p {
    font-size: 1.333vw;
    padding: 0 1.25vw;
  }
  #sec02 .btn {
    margin-top: 5vw;
  }
  #sec02 .btn a {
    width: 25.833vw;
    height: 5.8333vw;
  }
}
@media screen and (min-width: 841px) {
  #sec02 .recruit_tab ul li {
    margin-top: 1.2%;
    margin-right: 0.8%;
    width: calc(100% / 5 - 3.2% / 5);
  }
  #sec02 .recruit_tab ul li:nth-child(5n) {
    margin-right: 0;
  }
  #sec02 .recruit_tab ul li:nth-child(-n+5) {
    margin-top: 0;
  }
}
@media screen and (max-width: 840px) {
  #sec02 {
    padding: 16vw 0;
  }
  #sec02 .wrap {
    width: 92vw;
  }
  #sec02 .haed_h2 {
    padding-left: 2.6666vw;
    padding-right: 2.6666vw;
  }
  #sec02 .haed_h2::before {
    left: 2.6666vw;
  }
  #sec02 .recruit_tab {
    margin-bottom: 10.666vw;
  }
  #sec02 .recruit_tab ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 0;
  }
  #sec02 .recruit_tab ul li {
    margin-right: 1.4492%;
    margin-top: 1.4493%;
    width: 49.2754%;
  }
  #sec02 .recruit_tab ul li:nth-child(2n) {
    margin-right: 0;
  }
  #sec02 .recruit_tab ul li:nth-child(-n+2) {
    margin-top: 0;
  }
  #sec02 .recruit_tab ul li a {
    border-radius: .5rem;
    font-size: 4vw;
    padding: 5.3333vw 2.666vw;
  }
  #sec02 .recruit_content dl {
    display: block;
  }
  #sec02 .recruit_content dl dt {
    border-bottom: none;
    font-size: 4.2666vw;
    padding: 0;
    min-width: auto;
    max-width: none;
    width: 100%;
  }
  #sec02 .recruit_content dl dd {
    font-size: 4vw;
    padding: 0;
    width: 100%;
  }
  #sec02 .recruit_content dl:first-child dd {
    border-top: none;
  }
  #sec02 .recruit_content dl dt, 
  #sec02 .recruit_content dl dd {
    padding: 4vw 5.333vw;
    text-align: left;
  }
  #sec02 .recruit_content h2 {
    border-radius: 1.3333vw;
    font-size: 4.2666vw;
    margin-bottom: 5.8666vw;
    margin-top: 9.333vw;
    padding: 3.7333vw 5.8666vw;
  }
  #sec02 .recruit_content p {
    font-size: 3.7333vw;
    padding: 0 2.666vw;
  }
  #sec02 .btn {
    margin-top: 9.333vw;
  }
  #sec02 .btn a {
    width: 64.1025641026vw;
    height: 14.1025641026vw;
  }
}