#about .mainvisual {
  height: 220px;
  margin-top: 100px;
  background: url(../img/mainvisual.jpg) no-repeat center/cover;
}

@media screen and (max-width: 1199px) {
  #about .mainvisual {
    margin-top: 60px;
  }
}

@media screen and (max-width: 767px) {
  #about .mainvisual {
    height: 180px;
    margin-top: 60px;
  }
}

#about .mainvisual .inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

#about .mainvisual .inner__box__ttl {
  color: #fff;
  letter-spacing: 0.04rem;
  font-weight: 500;
  font-size: 3.6rem;
  font-family: industry, sans-serif;
  margin-top: calc(80px - (((3.6rem * 1.6) - 3.6rem) / 2));
}

@media screen and (max-width: 767px) {
  #about .mainvisual .inner__box__ttl {
    font-size: 2.6rem;
    margin-top: 60px;
  }
}

#about .mainvisual .inner__box__sub {
  font-size: 1.8rem;
  color: #fff;
  text-align: center;
}

@media screen and (max-width: 767px) {
  #about .mainvisual .inner__box__sub {
    font-size: 1.3rem;
  }
}

#about .breadcrumb {
  background: #f2f2f2;
  padding: 15px 0;
}

#about .breadcrumb__txt__link {
  color: #333;
  text-decoration: none;
}

#about .greeting {
  margin-top: 80px;
  background: url(../img/pic_about05.jpg) no-repeat right center/52.7%;
}

@media screen and (max-width: 1199px) {
  #about .greeting {
    background: url(../img/bg_about02.jpg) no-repeat center/cover;
  }
}

@media screen and (max-width: 767px) {
  #about .greeting {
    margin-top: 60px;
    width: 100%;
  }
}

#about .greeting__message {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

#about .greeting__message__txt {
  width: 70%;
}

#about .greeting__message__img {
  width: 25%;
}

#about .greeting .greeting__flex {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 0 0 auto;
}

@media screen and (max-width: 1199px) {
  #about .greeting .greeting__flex {
    -webkit-box-align: inherit;
        -ms-flex-align: inherit;
            align-items: inherit;
    display: block;
  }
}

#about .greeting .greeting__flex__info {
  width: 100%;
  max-width: 800px;
  padding: 60px;
  -webkit-box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.2);
  -ms-box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.2);
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.2);
  background: #fff;
}

@media screen and (max-width: 1199px) {
  #about .greeting .greeting__flex__info {
    width: 100%;
    max-width: inherit;
    padding: 80px 0;
    -webkit-box-shadow: none;
            box-shadow: none;
    background: none;
  }
}

@media screen and (max-width: 767px) {
  #about .greeting .greeting__flex__info {
    padding: 60px 0;
  }
}

#about .greeting .greeting__flex__info__ttl {
  padding-bottom: 10px;
  font-size: 1.8rem;
  font-weight: bold;
  border-bottom: 1px solid #333;
}

@media screen and (max-width: 1199px) {
  #about .greeting .greeting__flex__info__ttl {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 767px) {
  #about .greeting .greeting__flex__info__ttl {
    font-size: 1.4rem;
  }
}

#about .greeting .greeting__flex__info__head {
  margin-top: 30px;
  font-size: 2.8rem;
  font-weight: bold;
}

@media screen and (max-width: 1199px) {
  #about .greeting .greeting__flex__info__head {
    font-size: 2.2rem;
  }
}

@media screen and (max-width: 767px) {
  #about .greeting .greeting__flex__info__head {
    font-size: 1.8rem;
  }
}

#about .greeting .greeting__flex__info__txt {
  margin-top: 30px;
}

#about .greeting .greeting__flex__info__name {
  margin-top: 30px;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: right;
}

@media screen and (max-width: 767px) {
  #about .greeting .greeting__flex__info__name {
    font-size: 1.4rem;
  }
}

#about .approach {
  margin-top: 80px;
}

@media screen and (max-width: 767px) {
  #about .approach {
    margin-top: 60px;
  }
}

#about .approach .approach__flex__fig {
  width: 75%;
  margin: auto;
}

@media screen and (max-width: 1199px) {
  #about .approach .approach__flex__fig {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  #about .approach .approach__flex__fig {
    width: 100%;
    margin: 60px auto 60px;
  }
}

#about .approach .approach__flex__fig__head {
  margin-top: 30px;
  font-size: 1.8rem;
  margin-top: 40px;
  font-weight: bold;
}

@media screen and (max-width: 1199px) {
  #about .approach .approach__flex__fig__head {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 767px) {
  #about .approach .approach__flex__fig__head {
    font-size: 1.4rem;
    margin-top: 30px;
  }
}

#about .approach .approach__flex__fig__txt {
  margin-top: 20px;
}

#about .function {
  margin-top: 80px;
  padding: 80px 0;
  background: url(../img/bg_about01.jpg) no-repeat center/cover;
}

@media screen and (max-width: 767px) {
  #about .function {
    margin-top: 60px;
    padding: 60px 0;
  }
}

#about .function__ttl {
  color: #fff;
  font-size: 2.8rem;
  font-weight: bold;
  text-align: center;
}

@media screen and (max-width: 1199px) {
  #about .function__ttl {
    font-size: 2.2rem;
  }
}

@media screen and (max-width: 767px) {
  #about .function__ttl {
    font-size: 1.8rem;
  }
}

#about .function__txt {
  color: #fff;
  margin-top: 30px;
  text-align: center;
}

#about .function__table {
  width: 100%;
  margin-top: 60px;
}

#about .function__table tr {
  width: 100%;
}

#about .function__table tr th {
  color: #fff;
  width: 19.167%;
  vertical-align: middle;
  background: #000;
}

@media screen and (max-width: 767px) {
  #about .function__table tr th {
    width: 100%;
    padding: 10px 20px;
  }
}

#about .function__table tr td {
  width: 80.833%;
  padding: 30px;
  background: #fff;
}

@media screen and (max-width: 767px) {
  #about .function__table tr td {
    width: 100%;
    padding: 20px;
  }
}

#about .function__table tr td ul li {
  padding-left: 15px;
  background: url(../img/ico_maru01@2x.png) no-repeat top 10px left/5px;
}

@media screen and (max-width: 767px) {
  #about .function__table tr td ul li {
    background-position: top 7px left;
  }
}

#about .function__table tr td ul li:not(:first-child) {
  margin-top: 5px;
}

#about .function table, #about .function th, #about .function td {
  border: 1px solid #ccc;
  border-collapse: collapse;
}

@media screen and (max-width: 767px) {
  #about .function table, #about .function th, #about .function td {
    display: block;
  }
}

#about .function__fig {
  width: 61.25%;
  margin: 80px auto 0;
}

@media screen and (max-width: 1199px) {
  #about .function__fig {
    width: 90%;
  }
}

@media screen and (max-width: 767px) {
  #about .function__fig {
    width: 100%;
    margin-top: 60px;
  }
}

#about .info {
  margin: 80px auto;
}

@media screen and (max-width: 767px) {
  #about .info {
    margin: 60px auto;
  }
}

#about .info__ttl {
  font-size: 2.8rem;
  font-weight: bold;
  text-align: center;
}

@media screen and (max-width: 1199px) {
  #about .info__ttl {
    font-size: 2.2rem;
  }
}

@media screen and (max-width: 767px) {
  #about .info__ttl {
    font-size: 1.8rem;
  }
}

#about .info__table {
  width: 100%;
  margin-top: 40px;
}

#about .info__table tr {
  width: 100%;
}

#about .info__table tr th {
  color: #fff;
  width: 19.167%;
  vertical-align: middle;
  background: #000;
}

@media screen and (max-width: 767px) {
  #about .info__table tr th {
    width: 100%;
    padding: 10px 20px;
  }
}

#about .info__table tr td {
  width: 80.833%;
  padding: 30px;
  background: #fff;
}

@media screen and (max-width: 767px) {
  #about .info__table tr td {
    width: 100%;
    padding: 20px;
  }
}

#about .info table, #about .info th, #about .info td {
  border: 1px solid #ccc;
  border-collapse: collapse;
}

@media screen and (max-width: 767px) {
  #about .info table, #about .info th, #about .info td {
    display: block;
  }
}

#about .settlement {
  margin: 80px 0;
}

@media screen and (max-width: 767px) {
  #about .settlement {
    margin: 60px;
  }
}

#about .settlement__ttl {
  font-size: 2.8rem;
  font-weight: bold;
  text-align: center;
}

@media screen and (max-width: 1199px) {
  #about .settlement__ttl {
    font-size: 2.2rem;
  }
}

@media screen and (max-width: 767px) {
  #about .settlement__ttl {
    font-size: 1.8rem;
  }
}

#about .settlement__link {
  color: #fff;
  width: 100%;
  max-width: 380px;
  display: block;
  margin: 30px auto 0;
  padding: 15.5px 0;
  text-align: center;
  text-decoration: none;
  background: url(../../common/img/ico_vec01@2x.png) no-repeat right 20px center/6px, url(../img/ico_pdf01@2x.png) no-repeat center left 20px/23px, #000;
}

#about .settlement__link:hover {
  opacity: 0.8;
}
/*# sourceMappingURL=style.css.map */