@charset "UTF-8";

#sec01 {
  padding-top: 10rem;
}
.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 .wrap .text {
  font-size: 1.6rem;
  text-align: left;
  font-weight: 400;
  line-height: 2.06;
  letter-spacing: 0.06em;
  margin-bottom: 6rem;
}
#sec01 .wrap .fig {
  max-width: 1000px;
  margin: 0 auto;
}
#sec01 .wrap .fig img {
  vertical-align: bottom;
}
#sec01 .wrap .box {
  background: #F2F6FC;
  margin-top: 8rem;
  padding: 4.5rem 6rem 5rem;
  text-align: center;
}
#sec01 .wrap .box h3 {
  color: #0A51B8;
  font-size: 3rem;
  font-weight: 600;
  line-height: 1.23;
  letter-spacing: 0.06em;
  margin-bottom: 2.5rem;
}
#sec01 .wrap .box p {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 2.06;
  letter-spacing: 0.06em;
}
#sec01 .wrap .box ol {
  margin-top: 3rem;
  counter-reset: listnum;
}
#sec01 .wrap .box ol li {
  background: #FFFFFF;
  border-radius: .7rem;
  text-align: left;
  font-size: 2.5rem;
  font-weight: 500;
  line-height: 1.48;
  letter-spacing: 0.06em;
  padding: 2.1rem 2.6rem;
}
#sec01 .wrap .box ol li::before{
  counter-increment: listnum;
  content: counter(listnum, decimal-leading-zero)". ";
  font-family: "Barlow Condensed", sans-serif;
  color: #0A51B8;
  font-weight: 600;
  font-size: 2.8rem;
  line-height: 1.21;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 1200px) {
  #sec01 {
    padding-top: 8.333vw;
  }
  .haed_h2 {
    font-size: 4vw;
  }
  .haed_h2::before {
    height: .3rem;
    width: 5.6rem;
  }
  #sec01 .wrap .text {
    font-size: 1.333vw;
    margin-bottom: 5vw;
  }
  #sec01 .wrap .box {
    margin-top: 6.6666vw;
    padding: 3.75vw 5vw 4.1666vw;
  }
  #sec01 .wrap .box h3 {
    font-size: 2.5vw;
    margin-bottom: 2.0833vw;
  }
  #sec01 .wrap .box p {
    font-size: 1.333vw;
  }
  #sec01 .wrap .box ol {
    margin-top: 2.5vw;
  }
  #sec01 .wrap .box ol li {
    border-radius: 0.5833vw;
    font-size: 2.08333vw;
    padding: 1.75vw 2.1666vw;
  }
  #sec01 .wrap .box ol li::before{
    font-size: 2.333vw;
  }
}
@media screen and (min-width: 841px) {
  #sec01 .wrap .box ol {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  #sec01 .wrap .box ol li {
    width: 49.352%;
  }
  #sec01 .wrap .box ol li:nth-child(1) { 
    order: 1;
    margin-right: 1.296%;
  }
  #sec01 .wrap .box ol li:nth-child(4) { 
    order: 2;
  }
  #sec01 .wrap .box ol li:nth-child(2) { 
    order: 3;
    margin-right: 1.296%;
    margin-top: 1.2037%;
  }
  #sec01 .wrap .box ol li:nth-child(5) { 
    order: 4;
    margin-top: 1.2037%;
  }
  #sec01 .wrap .box ol li:nth-child(3) { 
    order: 5;
    margin-right: 1.296%;
    margin-top: 1.2037%;
  }
}
@media screen and (max-width: 840px) {
  #sec01 {
    padding-top: 18.666vw;
  }
  #sec01 .wrap {
    width: 92vw;
  }
  .haed_h2 {
    font-size: 6.4vw;
    margin-bottom: 1.25em;
    padding-bottom: 1em;
  }
  .haed_h2::before {
    width: 3.8rem;
  }
  #sec01 .haed_h2 {
    padding-left: 2.6666vw;
    padding-right: 2.6666vw;
  }
  #sec01 .haed_h2::before {
    left: 2.6666vw;
  }
  #sec01 .wrap .text {
    font-size: 3.7333vw;
    margin-bottom: 9.6vw;
    padding: 0 2.6666vw;
  }
  #sec01 .wrap .fig {
    padding: 0 2.6666vw;
  }
  #sec01 .wrap .box {
    margin-top: 13.333vw;
    padding: 9.0666vw 5.333vw 8vw;
  }
  #sec01 .wrap .box h3 {
    font-size: 6.4vw;
    margin-bottom: 4.8vw;
  }
  #sec01 .wrap .box p {
    font-size: 3.7333vw;
  }
  #sec01 .wrap .box ol {
    margin-top: 5.8666vw;
  }
  #sec01 .wrap .box ol li {
    border-radius: 1.8666vw;
    font-size: 4.5333vw;
    padding: 4.2666vw 5.333vw;
    padding-left: 13.8666vw;
    position: relative;
  }
  #sec01 .wrap .box ol li + li {
    margin-top: .6rem;
  }
  #sec01 .wrap .box ol li::before{
    font-size: 6.1333vw;
    position: absolute;
    left: 5.333vw;
  }
}

#sec02 {
  background: #F8F5F0;
  margin-top: 10rem;
  padding: 11.5rem 0;
}
#sec02 h2.haed_h2 {
  margin-top: 14rem;
}
#sec02 h2.haed_h2:first-child {
  margin-top: 0;
}
#sec02 .sec02_wrap .text {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.88;
  letter-spacing: 0.06em;
}
#sec02 .sec02_wrap .fig {
  text-align: center;
}
#sec02 .sec02_wrap .fig span {
  display: block;
  font-size: 1.8rem;
  font-weight: 600;
  line-height: 1.68;
  letter-spacing: 0.06em;
  margin-top: 2.2rem;
}
#sec02 .sec02_wrap .fig span em {
  font-size: 2.8rem;
  font-style: normal;
  display: block;
}
#sec02 .sec02_wrap .fig img {
  vertical-align: bottom;
}
@media screen and (max-width: 1200px) {
  #sec02 {
    margin-top: 8.333vw;
    padding: 9.5833vw 0;
  }
  #sec02 h2.haed_h2 {
    margin-top: 11.666vw;
  }
  #sec02 .sec02_wrap .text {
    font-size: 1.3333vw;
  }
  #sec02 .sec02_wrap .fig span {
    font-size: 1.5vw;
    margin-top: 1.8333vw;
  }
  #sec02 .sec02_wrap .fig span em {
    font-size: 2.3333vw;
  }
}
@media screen and (min-width: 841px) {
  #sec02 .sec02_wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    flex-flow: row-reverse nowrap;
  }
  #sec02 .sec02_wrap .fig {
    width: 43.1666%
  }
  #sec02 .sec02_wrap .text {
    width: 50%
  }
}
@media screen and (max-width: 840px) {
  #sec02 {
    margin-top: 16vw;
    padding: 16vw 0;
  }
  #sec02 h2.haed_h2 {
    margin-top: 14.666vw;
  }
  #sec02 .sec02_wrap .text {
    font-size: 3.7333vw;
    margin-top: 6.4vw;
  }
  #sec02 .sec02_wrap .fig span {
    font-size: 4vw;
    margin-top: 4.8vw;
  }
  #sec02 .sec02_wrap .fig span em {
    font-size: 5.333vw;
  }
}

#sec03 {
  padding: 10rem 0;
}
#sec03 .company_tab {
  margin-bottom: 3.5rem;
}
#sec03 .company_tab ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
#sec03 .company_tab ul li {
  width: 32.8333%;
}
#sec03 .company_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;
}
#sec03 .company_tab ul li a.act {
  background: #0A51B8;
}
#sec03 .company_content dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#sec03 .company_content dl dt, 
#sec03 .company_content dl dd {
  border-bottom: 1px solid #B2B2B2;
  font-size: 1.7rem;
  font-weight: 400;
  line-height: 1.88;
  letter-spacing: 0.06em;
}
#sec03 .company_content dl:first-child dt, 
#sec03 .company_content dl:first-child dd {
  border-top: 1px solid #B2B2B2;
}
#sec03 .company_content dl dt {
  background: #F0F0F0;
  font-weight: 600;
  text-align: center;
  padding: 2.354rem 1rem;
  width: 22rem;
}
#sec03 .company_content dl dd {
  background: #fff;
  font-weight: 400;
  padding: 2.354rem 3.8rem;
  flex-grow: 1;
}
#sec03 .company_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;
}
#sec03 .company_content p {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 2.06;
  letter-spacing: 0.06em;
  padding: 0 1.5rem;
}
#sec03 .company_content .btn.company {
  margin-top: 5rem;
}
#sec03 .company_content .btn.company a {
  border: .2rem solid #CE312A;
  color: #CE312A;
  width: 60rem;
  height: 8rem;
  font-size: 1.8rem;
  border-radius: .5rem;
  margin: 0 auto;
}
#sec03 .company_content .btn.company a:hover {
  background: #CE312A;
  color: #fff;
}
@media screen and (max-width: 1200px) {
  #sec03 {
    padding: 8.333vw 0;
  }
  #sec03 .company_tab {
    margin-bottom: 2.9166vw;
  }
  #sec03 .company_tab ul li a {
    border-radius: .4rem;
    font-size: 1.4166vw;
    padding: 2.0833vw 1.25vw;
  }
  #sec03 .company_content dl dt, 
  #sec03 .company_content dl dd {
    font-size: 1.4166vw;
  }
  #sec03 .company_content dl dt {
    padding: 1.9616vw 0.8333vw;
    width: 18.333vw;
  }
  #sec03 .company_content dl dd {
    padding: 1.9616vw 3.166vw;
  }
  #sec03 .company_content h2 {
    border-radius: .6rem;
    font-size: 1.8333vw;
    margin-top: 5vw;
    margin-bottom: 2.9166vw;
    padding: 1.5rem 2.5vw;
  }
  #sec03 .company_content p {
    font-size: 1.333vw;
    padding: 0 1.25vw;
  }
  #sec03 .company_content .btn.company {
    margin-top: 4.1666vw;
  }
  #sec03 .company_content .btn.company a {
    width: 5vw;
    height: 6.666vw;
    font-size: 1.5vw;
    border-radius: 0.4166vw;
  }
}
@media screen and (max-width: 840px) {
  #sec03 {
    padding: 16vw 0;
  }
  #sec03 .wrap {
    width: 92vw;
  }
  #sec03 .haed_h2 {
    padding-left: 2.6666vw;
    padding-right: 2.6666vw;
  }
  #sec03 .haed_h2::before {
    left: 2.6666vw;
  }
  #sec03 .company_tab {
    margin-bottom: 10.666vw;
  }
  #sec03 .company_tab ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  #sec03 .company_tab ul li {
    margin-right: 1.4492%;
    margin-top: 1.4493%;
    width: 49.2754%;
  }
  #sec03 .company_tab ul li:nth-child(2n) {
    margin-right: 0;
  }
  #sec03 .company_tab ul li:nth-child(-n+2) {
    margin-top: 0;
  }
  #sec03 .company_tab ul li a {
    border-radius: .5rem;
    font-size: 3.7333vw;
    padding: 4vw 2.666vw;
  }
  #sec03 .company_content dl {
    display: block;
  }
  #sec03 .company_content dl dt {
    font-size: 4.2666vw;
    padding: 0;
    width: 100%;
  }
  #sec03 .company_content dl dd {
    font-size: 4vw;
    padding: 0;
    width: 100%;
  }
  #sec03 .company_content dl:first-child dd {
    border-top: none;
  }
  #sec03 .company_content dl dt, 
  #sec03 .company_content dl dd {
    padding: 4vw 5.333vw;
    text-align: left;
  }
  #sec03 .company_content h2 {
    border-radius: 1.3333vw;
    font-size: 4.2666vw;
    margin-bottom: 5.8666vw;
    margin-top: 9.333vw;
    padding: 3.7333vw 5.8666vw;
  }
  #sec03 .company_content p {
    font-size: 3.7333vw;
    padding: 0 2.666vw;
  }
  #sec03 .company_content .btn.company {
    margin-top: 8vw;
  }
  #sec03 .company_content .btn.company a {
    width: 88.333vw;
    height: 13.333vw;
    font-size: 4vw;
    border-radius: 1.333vw;
  }
}

#sec04 {
  background: #F8F5F0;
  padding: 10rem 0 9.5rem;
}
#sec04 .wrap .content + .content {
  margin-top: 8rem;
}
#sec04 .wrap .content dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#sec04 .wrap .content dl dt, 
#sec04 .wrap .content dl dd {
  border-bottom: 1px solid #B2B2B2;
  font-size: 1.7rem;
  font-weight: 400;
  line-height: 1.88;
  letter-spacing: 0.06em;
}
#sec04 .wrap .content dl:first-child dt, 
#sec04 .wrap .content dl:first-child dd {
  border-top: 1px solid #B2B2B2;
}
#sec04 .wrap .content dl dt {
  background: #F0F0F0;
  font-weight: 600;
  text-align: center;
  padding: 2.354rem 1rem;
  width: 15.7rem;
}
#sec04 .wrap .content dl dd {
  font-weight: 400;
  padding: 2.354rem 3.8rem;
  flex-grow: 1;
}
#sec04 .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;
}
#sec04 .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) {
  #sec04 {
    background: #F8F5F0;
    padding: 8.333vw 0 7.9166vw;
  }
  #sec04 .wrap .content + .content {
    margin-top: 6.666vw;
  }
  #sec04 .wrap .content dl dt, 
  #sec04 .wrap .content dl dd {
    font-size: 1.41666vw;
  }
  #sec04 .wrap .content dl dt {
    padding: 1.9616vw 0.8333vw;
    width: 13.0833vw;
  }
  #sec04 .wrap .content dl dd {
    padding: 1.9616vw 3.1666vw;
  }
  #sec04 .wrap .content h2 {
    border-radius: .6rem;
    font-size: 1.8333vw;
    margin-bottom: 2.9166vw;
    padding: 1.5rem 2.5vw;
  }
  #sec04 .wrap .content p {
    font-size: 1.333vw;
    padding: 0 1.25vw;
  }
}
@media screen and (max-width: 840px) {
  #sec04 {
    padding: 16vw 0;
  }
  #sec04 .wrap {
    width: 92vw;
  }
  #sec04 .haed_h2 {
    padding-left: 2.6666vw;
    padding-right: 2.6666vw;
  }
  #sec04 .haed_h2::before {
    left: 2.6666vw;
  }
  #sec04 .wrap .content + .content {
    margin-top: 13.333vw;
  }
  #sec04 .wrap .content dl {
    display: block;
  }
  #sec04 .wrap .content dl dt {
    font-size: 4.2666vw;
    padding: 0;
    width: 100%;
  }
  #sec04 .wrap .content dl dd {
    font-size: 4vw;
    padding: 0;
    width: 100%;
  }
  #sec04 .wrap .content dl:first-child dd {
    border-top: none;
  }
  #sec04 .wrap .content dl dt, 
  #sec04 .wrap .content dl dd {
    padding: 4vw 5.333vw;
    text-align: left;
  }
  #sec04 .wrap .content h2 {
    border-radius: 1.3333vw;
    font-size: 4.2666vw;
    margin-bottom: 5.8666vw;
    padding: 3.7333vw 5.8666vw;
  }
  #sec04 .wrap .content p {
    font-size: 3.7333vw;
    padding: 0 2.666vw;
  }
}

#sec05 {
  padding-top: 10rem;
}
#sec05 ul li span {
  display: block;
  font-size: 1.7rem;
  font-weight: 400;
  line-height: 1.88;
  letter-spacing: 0.06em;
  margin-top: .45em;
  text-align: center;
}
@media screen and (max-width: 1200px) {
  #sec05 {
    padding-top: 8.333vw;
  }
  #sec05 ul li span {
    font-size: 1.4166vw;
  }
}
@media screen and (min-width: 841px) {
  #sec05 ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  #sec05 ul li {
    width: 32.5833%;
  }
}
@media screen and (max-width: 840px) {
  #sec05 {
    padding-top: 16vw;
  }
  #sec05 .wrap {
    width: 92vw;
  }
  #sec05 .haed_h2 {
    padding-left: 2.6666vw;
    padding-right: 2.6666vw;
  }
  #sec05 .haed_h2::before {
    left: 2.6666vw;
  }
  #sec05 ul li + li {
    margin-top: 8vw;
  }
  #sec05 ul li span {
    font-size: 3.7333vw;
    margin-top: .25em;
  }
}