@keyframes moveBg {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: 1487px 0;
  }
}
#contents section {
  border-top: 1px solid #e3e3e6;
}
#contents section#greeting .wrap {
  width: 580px;
}
#contents section#greeting .wrap p {
  line-height: 32px;
  padding: 14px 0;
  background-image: url("../image/about/sakamoto.jpg");
  background-size: 156px 156px;
  background-position: center;
  background-repeat: no-repeat;
  background-position: right 0 center;
}
@media all and (-webkit-min-device-pixel-ratio: 1.5), all and (-o-min-device-pixel-ratio: 3 / 2), all and (min--moz-device-pixel-ratio: 1.5), all and (min-device-pixel-ratio: 1.5) {
  #contents section#greeting .wrap p {
    background-image: url("../image/about/sakamoto@2x.jpg");
  }
}
#contents section#features .wrap .feature {
  position: relative;
  display: -webkit-flex;
  display: flex;
  align-items: flex-end;
  padding: 100px 0;
}
#contents section#features .wrap .feature:last-child {
  padding-bottom: 0;
}
#contents section#features .wrap .feature img {
  position: absolute;
}
#contents section#features .wrap .feature .text {
  width: 460px;
}
#contents section#features .wrap .feature .text h3 {
  font-size: 20px;
  font-weight: 300;
  margin-bottom: 30px;
  letter-spacing: 0.14em;
}
#contents section#features .wrap .feature .text p {
  line-height: 29px;
}
#contents section#features .wrap .feature:nth-child(2n-1) {
  flex-direction: row-reverse;
}
#contents section#features .wrap .feature:nth-child(2n-1) img {
  left: -130px;
}
#contents section#features .wrap .feature:nth-child(2n) img {
  right: -130px;
}
#contents section#features .wrap .feature#feature2 {
  padding-top: 0;
}
#contents section#features .wrap .feature#feature2 .mfcloud {
  margin-top: 23px;
  padding: 10px 0;
  font-size: 11px;
  line-height: 24px;
  background-image: url("../image/about/mfcloud.png");
  background-size: 110px 96px;
  background-position: center;
  background-repeat: no-repeat;
  background-position: center right 0;
}
@media all and (-webkit-min-device-pixel-ratio: 1.5), all and (-o-min-device-pixel-ratio: 3 / 2), all and (min--moz-device-pixel-ratio: 1.5), all and (min-device-pixel-ratio: 1.5) {
  #contents section#features .wrap .feature#feature2 .mfcloud {
    background-image: url("../image/about/mfcloud@2x.png");
  }
}
#contents section#features .wrap .feature#feature3 img {
  left: -180px;
}
#contents section#profile table {
  width: 500px;
  margin: 0 auto;
  background-image: linear-gradient(to right, #74787f, #74787f 1px, transparent 1px, transparent 4px);
  background-size: 3px 1px;
  background-position: bottom;
  background-repeat: repeat-x;
}
#contents section#profile table tr {
  background-image: linear-gradient(to right, #74787f, #74787f 1px, transparent 1px, transparent 4px);
  background-size: 3px 1px;
  background-position: top;
  background-repeat: repeat-x;
}
#contents section#profile table tr th, #contents section#profile table tr td {
  padding: 15px 0;
}
#contents section#profile table tr th {
  width: 105px;
}
#contents section#profile a {
  text-decoration: underline;
}
#contents section#profile > img {
  display: block;
  width: 600px;
  margin: 60px auto 0;
}
#contents section#history table {
  width: 500px;
  margin: 0 auto;
  font-size: 13px;
  line-height: 32px;
}
#contents section#history table tr th {
  width: 105px;
}
#contents section#history .photoes {
  margin-top: 60px;
  width: 100%;
  height: 100px;
  background: url(../image/about/history.jpg) repeat-x center;
  animation: moveBg 120s infinite linear;
}
#contents section#access {
  padding-bottom: 0;
}
#contents section#access .wrap {
  max-width: 500px;
}
#contents section#access #map {
  margin-top: 60px;
  height: 600px;
  background: #fcfcfc;
}

@media (max-width: 970px) {
  #contents section#greeting .wrap {
    margin: 0 20px;
    width: calc(100% - 40px);
  }
  #contents section#greeting .wrap p {
    padding: 0;
    padding-top: 111px;
    background-position: center top 0;
    background-size: 90px 90px;
    line-height: 2em;
    text-align: justify;
  }
  #contents section#features .wrap .feature {
    align-items: center;
    -webkit-flex-direction: column-reverse;
    flex-direction: column-reverse;
    padding: 0 0 50px;
  }
  #contents section#features .wrap .feature img {
    position: relative;
    left: auto;
    right: auto;
    width: 100%;
    max-width: 539px;
    height: auto;
  }
  #contents section#features .wrap .feature .text {
    width: 100%;
  }
  #contents section#features .wrap .feature .text h3 {
    margin-top: 18.5px;
    margin-bottom: 14px;
    font-size: 15px;
    line-height: 26.5px;
    text-align: center;
  }
  #contents section#features .wrap .feature .text p {
    line-height: 2em;
    text-align: justify;
  }
  #contents section#features .wrap .feature:nth-child(2n), #contents section#features .wrap .feature:nth-child(2n-1) {
    -webkit-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
  #contents section#features .wrap .feature:nth-child(2n) img, #contents section#features .wrap .feature:nth-child(2n-1) img {
    position: relative;
    left: auto;
    right: auto;
  }
  #contents section#features .wrap .feature#feature2 .mfcloud {
    padding: 0 85px 0 0;
    font-size: 7.5px;
    line-height: 15px;
    background-size: 75px auto;
    line-height: 2em;
    text-align: justify;
    height: 65px;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: column;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  #contents section#features .wrap .feature#feature3 img {
    left: 0;
  }
  #contents section#profile {
    padding-bottom: 0;
  }
  #contents section#profile table {
    width: calc(100% - 60px);
    font-size: 10px;
  }
  #contents section#profile table tr {
    background-image: linear-gradient(to right, #74787f, #74787f 1px, transparent 1px, transparent 4px);
    background-size: 3px 1px;
    background-position: top;
    background-repeat: repeat-x;
  }
  #contents section#profile table tr th, #contents section#profile table tr td {
    padding: 10px 0;
  }
  #contents section#profile table tr th {
    width: 72.5px;
  }
  #contents section#profile > img {
    width: 100%;
  }
  #contents section#history table {
    width: calc(100% - 60px);
    font-size: 10px;
    line-height: 22px;
    max-width: 370px;
    margin: 0 30px;
  }
  #contents section#history table tr th, #contents section#history table tr td {
    padding: 3px 0;
  }
  #contents section#history table tr th {
    width: 80px;
  }
  #contents section#history .photoes {
    margin-top: 30px;
  }
  #contents section#access #map {
    height: 460px;
  }
}

/*# sourceMappingURL=about.css.map */
