.about section:not(.tpl-contact) h2 {
  position: relative;
  margin-bottom: 60px;
  padding-bottom: 30px;
  font-size: 3.8rem;
  font-weight: normal;
  text-align: center;
}

.about section:not(.tpl-contact) h2:after {
  display: block;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  width: 90px;
  height: 2px;
  margin: auto;
  background-color: #68a082;
  content: "";
}

.about-mv .mv {
  background-image: url(/assets/img/about/mv_bg.jpg);
}

.about-company {
  padding: 130px 0;
}

.about-company-table > table tr:last-of-type td {
  border-bottom: 1px solid #dfdfdf;
}

.about-company-table > table tr th {
  width: 200px;
  padding: 20px 15px;
  border-top: 1px solid #dfdfdf;
  line-height: 1.7;
  text-align: left;
}

.about-company-table > table tr td {
  padding: 20px 15px;
  padding-left: 0;
  border-top: 1px solid #dfdfdf;
  line-height: 1.5;
  vertical-align: middle;
}

.about-company-table > table tr td > div {
  font-size: 1.4rem;
}

.about-company-table > table tr td > div.en > dl > dt {
  width: 14em;
}

.about-company-table > table tr td > div.en > dl > dd {
  width: calc(100% - 14em);
}

.about-company-table > table tr td > div > dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}

.about-company-table > table tr td > div > dl:nth-of-type(n+2) {
  margin-top: 15px;
}

.about-company-table > table tr td > div > dl > dt {
  width: 11em;
}

.about-company-table > table tr td > div > dl > dd {
  width: calc(100% - 11em);
}

.about-officer {
  position: relative;
  padding: 130px 0;
  background-image: url(/assets/img/common/bg.jpg);
  background-position: center top;
  background-repeat: repeat-y;
  background-size: 100%;
}

.about-officer:before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url(/assets/img/about/officer_logo.png);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 100%;
  content: "";
}

.about-officer-list {
  position: relative;
}

.about-officer-list > dl {
  padding: 0 5px;
  border-top: 1px solid #bababa;
}

.about-officer-list > dl.on > dt {
  background-image: url(/assets/img/about/accordion_close.png);
}

.about-officer-list > dl:last-of-type {
  border-bottom: 1px solid #bababa;
}

.about-officer-list > dl > dt {
  padding: 30px 0;
  background-image: url(/assets/img/about/accordion_open.png);
  background-position: right 20px center;
  background-repeat: no-repeat;
  font-size: 2.0rem;
  font-weight: bold;
}

.about-officer-list > dl > dd {
  padding-right: 90px;
  padding-bottom: 30px;
  line-height: 1.7;
}

.about-map {
  padding-top: 130px;
}

.about-map-list > ul > li {
  padding-bottom: 60px;
}

.about-map-list > ul > li > div {
  position: relative;
  height: 360px;
}

.about-map-list > ul > li > div > iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.about-map-list > ul > li > p {
  margin-top: 30px;
  text-align: center;
}

.about-map-list > ul > li > p > span {
  display: inline-block;
  margin-right: 25px;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  .about section:not(.tpl-contact) h2 {
    margin-bottom: 30px;
    padding-bottom: 15px;
    font-size: 2.0rem;
  }
  .about section:not(.tpl-contact) h2:after {
    width: 40px;
    height: 1px;
  }
  .about-company {
    padding: 65px 0;
  }
  .about-company-table > table tr th {
    display: block;
    width: 100%;
    padding: 15px 5px 5px;
  }
  .about-company-table > table tr td {
    display: block;
    padding: 0 5px 15px;
    border-top: none;
  }
  .about-company-table > table tr td > div.en > dl > dt {
    width: 10em;
  }
  .about-company-table > table tr td > div.en > dl > dd {
    width: calc(100% - 10em);
  }
  .about-company-table > table tr td > div {
    margin-top: 5px;
    font-size: 1.2rem;
  }
  .about-officer {
    padding: 65px 0;
  }
  .about-officer-list > dl {
    padding-right: 0;
  }
  .about-officer-list > dl > dt {
    padding: 15px 0;
    background-position: right 10px center;
    background-size: 20px;
    font-size: 1.6rem;
    line-height: 1.3;
  }
  .about-officer-list > dl > dd {
    padding: 0 0 15px;
  }
  .about-map {
    padding-top: 65px;
  }
  .about-map-list > ul > li {
    padding-bottom: 40px;
  }
  .about-map-list > ul > li > div {
    height: 300px;
  }
  .about-map-list > ul > li > p {
    margin-top: 20px;
    padding: 0 23px;
    line-height: 1.7;
    text-align: left;
  }
  .about-map-list > ul > li > p > span {
    display: block;
  }
}

@media screen and (min-width: 768px), print {
  .about-company-table > table tr:last-of-type th {
    border-bottom: 1px solid #dfdfdf;
  }
}
