@charset "UTF-8";
.main {
  padding: 60px 0 0 0;
  overflow-x: hidden;
}
.main * {
  font-size: 62.5%;
  font-family: "Helvetica Neue", Helvetica, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
.main ._sp {
  display: block;
}
@media screen and (min-width: 760px) {
  .main ._sp {
    display: none;
  }
}
.main ._pc {
  display: none;
}
@media screen and (min-width: 760px) {
  .main ._pc {
    display: block;
  }
}

.bg {
  position: relative;
  z-index: 1;
}
.bg__img {
  position: absolute;
  width: 40%;
  bottom: 50px;
  left: 15px;
  z-index: 1;
}
@media screen and (min-width: 960px) {
  .bg__img {
    width: 100%;
    bottom: -50px;
  }
}
.bg__img img {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}
@media screen and (min-width: 520px) {
  .bg__img img {
    width: 70%;
  }
}
@media screen and (min-width: 760px) {
  .bg__img img {
    width: 60%;
  }
}
@media screen and (min-width: 960px) {
  .bg__img img {
    width: 25%;
  }
}
@media screen and (min-width: 1280px) {
  .bg__img img {
    width: 16%;
  }
}
@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.bg__img--active img:nth-child(1) {
  animation-name: fadein;
  animation-duration: 1s;
  animation-delay: 0.2s;
  animation-timing-function: linear;
  animation-fill-mode: both;
}
.bg__img--active img:nth-child(2) {
  animation-name: fadein;
  animation-duration: 1s;
  animation-delay: 0.4s;
  animation-timing-function: linear;
  animation-fill-mode: both;
}
.bg__img--active img:nth-child(3) {
  animation-name: fadein;
  animation-duration: 1s;
  animation-delay: 0.6s;
  animation-timing-function: linear;
  animation-fill-mode: both;
}
.bg__img--active img:nth-child(4) {
  animation-name: fadein;
  animation-duration: 1s;
  animation-delay: 0.8s;
  animation-timing-function: linear;
  animation-fill-mode: both;
}
.bg__img--active img:nth-child(5) {
  animation-name: fadein;
  animation-duration: 1s;
  animation-delay: 1s;
  animation-timing-function: linear;
  animation-fill-mode: both;
}
.bg__img--active img:nth-child(6) {
  animation-name: fadein;
  animation-duration: 1s;
  animation-delay: 1.2s;
  animation-timing-function: linear;
  animation-fill-mode: both;
}
.bg__img--active img:nth-child(7) {
  animation-name: fadein;
  animation-duration: 1s;
  animation-delay: 1.4s;
  animation-timing-function: linear;
  animation-fill-mode: both;
}

.heading {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 123px;
  z-index: 1;
}
@media screen and (min-width: 760px) {
  .heading {
    background-size: 40% auto;
    background-position: top -120px right -150px;
  }
}
@media screen and (min-width: 1280px) {
  .heading {
    background-size: 28% auto;
  }
}
.heading__title {
  text-align: center;
  z-index: 2;
  font-size: 1.6rem;
}
@media screen and (min-width: 960px) {
  .heading__title {
    font-size: 2rem;
  }
}
.heading__title--about {
  font-size: 1.4rem;
}
@media screen and (min-width: 960px) {
  .heading__title--about {
    font-size: 1.6rem;
  }
}
.heading--space {
  margin: 60px 0 0 0;
}
.heading__bg {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  z-index: 1;
}
.heading__bg img {
  position: absolute;
  top: -50px;
  right: -30%;
  width: 65%;
  opacity: 0;
}
@media screen and (min-width: 520px) {
  .heading__bg img {
    top: -75px;
    right: -100px;
    width: 50%;
  }
}
@media screen and (min-width: 760px) {
  .heading__bg img {
    top: -120px;
    right: -150px;
    width: 50%;
  }
}
@media screen and (min-width: 960px) {
  .heading__bg img {
    width: 40%;
  }
}
@media screen and (min-width: 1280px) {
  .heading__bg img {
    top: -120px;
    width: 28%;
  }
}
@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.heading__bg--active img:nth-child(1) {
  animation-name: fadein;
  animation-duration: 1s;
  animation-delay: 0.2s;
  animation-timing-function: linear;
  animation-fill-mode: both;
}
.heading__bg--active img:nth-child(2) {
  animation-name: fadein;
  animation-duration: 1s;
  animation-delay: 0.4s;
  animation-timing-function: linear;
  animation-fill-mode: both;
}
.heading__bg--active img:nth-child(3) {
  animation-name: fadein;
  animation-duration: 1s;
  animation-delay: 0.6s;
  animation-timing-function: linear;
  animation-fill-mode: both;
}
.heading__bg--active img:nth-child(4) {
  animation-name: fadein;
  animation-duration: 1s;
  animation-delay: 0.8s;
  animation-timing-function: linear;
  animation-fill-mode: both;
}
.heading__bg--active img:nth-child(5) {
  animation-name: fadein;
  animation-duration: 1s;
  animation-delay: 1s;
  animation-timing-function: linear;
  animation-fill-mode: both;
}
.heading__bg--active img:nth-child(6) {
  animation-name: fadein;
  animation-duration: 1s;
  animation-delay: 1.2s;
  animation-timing-function: linear;
  animation-fill-mode: both;
}
.heading__bg--active img:nth-child(7) {
  animation-name: fadein;
  animation-duration: 1s;
  animation-delay: 1.4s;
  animation-timing-function: linear;
  animation-fill-mode: both;
}
@media screen and (max-width: 520px) {
  .heading__bg--about img, .heading__bg--right img {
    right: -45%;
  }
}

.index__inner {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin: 0 auto;
}
.index__item {
  position: relative;
  width: 100%;
}
@media screen and (min-width: 960px) {
  .index__item {
    width: 50%;
  }
}
.index__link {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: flex-start;
  width: 100%;
  height: 100%;
  padding: 40px 0 0 0;
  color: #212121;
  transition: 0.3s;
}
@media screen and (min-width: 1280px) {
  .index__link {
    padding: 60px 0 0 0;
  }
}
.index__link:hover {
  opacity: 0.7;
}
.index__title {
  margin: 0 0 10px 0;
  text-align: center;
  font-weight: bold;
  font-size: 1.6rem;
}
@media screen and (min-width: 960px) {
  .index__title {
    font-size: 2rem;
  }
}
@media screen and (min-width: 760px) {
  .index__title {
    margin: 0 0 20px 0;
  }
}
.index__title span {
  display: block;
  text-align: center;
  font-weight: normal;
  color: #035EAE;
  font-size: 1.2rem;
}
@media screen and (min-width: 960px) {
  .index__title span {
    font-size: 1.4rem;
  }
}
.index__title br {
  display: block;
}
@media screen and (min-width: 1280px) {
  .index__title br {
    display: none;
  }
}
.index__text {
  display: none;
  text-align: center;
  font-size: 1.2rem;
}
@media screen and (min-width: 960px) {
  .index__text {
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 960px) {
  .index__text {
    display: block;
  }
}
.index__text br {
  display: block;
}
@media screen and (min-width: 1280px) {
  .index__text br {
    display: none;
  }
}
.index__image img {
  width: 100%;
  height: auto;
}

.main {
  padding: 60px 0 0 0;
  overflow-x: hidden;
}

.main * {
  font-size: 62.5%;
  font-family: "Noto Sans JP", sans-serif;
}

.main ._sp {
  display: block;
}

@media screen and (min-width: 760px) {
  .main ._sp {
    display: none;
  }
}
.main ._pc {
  display: none;
}

@media screen and (min-width: 760px) {
  .main ._pc {
    display: block;
  }
}
.bg {
  position: relative;
  z-index: 1;
}

.bg__img {
  position: absolute;
  width: 40%;
  bottom: 50px;
  left: 15px;
  z-index: 1;
}

@media screen and (min-width: 960px) {
  .bg__img {
    width: 100%;
    bottom: -50px;
  }
}
.bg__img img {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}

@media screen and (min-width: 520px) {
  .bg__img img {
    width: 70%;
  }
}
@media screen and (min-width: 760px) {
  .bg__img img {
    width: 60%;
  }
}
@media screen and (min-width: 960px) {
  .bg__img img {
    width: 25%;
  }
}
@media screen and (min-width: 1280px) {
  .bg__img img {
    width: 16%;
  }
}
@-webkit-keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.bg__img--active img:nth-child(1) {
  -webkit-animation-name: fadein;
  animation-name: fadein;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 0.2s;
  animation-delay: 0.2s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.bg__img--active img:nth-child(2) {
  -webkit-animation-name: fadein;
  animation-name: fadein;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 0.4s;
  animation-delay: 0.4s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.bg__img--active img:nth-child(3) {
  -webkit-animation-name: fadein;
  animation-name: fadein;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 0.6s;
  animation-delay: 0.6s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.bg__img--active img:nth-child(4) {
  -webkit-animation-name: fadein;
  animation-name: fadein;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 0.8s;
  animation-delay: 0.8s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.bg__img--active img:nth-child(5) {
  -webkit-animation-name: fadein;
  animation-name: fadein;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 1s;
  animation-delay: 1s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.bg__img--active img:nth-child(6) {
  -webkit-animation-name: fadein;
  animation-name: fadein;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 1.2s;
  animation-delay: 1.2s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.bg__img--active img:nth-child(7) {
  -webkit-animation-name: fadein;
  animation-name: fadein;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 1.4s;
  animation-delay: 1.4s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.heading {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 123px;
  z-index: 1;
}

@media screen and (min-width: 760px) {
  .heading {
    background-size: 40% auto;
    background-position: top -120px right -150px;
  }
}
@media screen and (min-width: 1280px) {
  .heading {
    background-size: 28% auto;
  }
}
.heading__title {
  text-align: center;
  z-index: 2;
  font-size: 1.6rem;
}

@media screen and (min-width: 960px) {
  .heading__title {
    font-size: 2rem;
  }
}
.heading__title--about {
  font-size: 1.4rem;
}

@media screen and (min-width: 960px) {
  .heading__title--about {
    font-size: 1.6rem;
  }
}
.heading--space {
  margin: 60px 0 0 0;
}

.heading__bg {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  z-index: 1;
}

.heading__bg img {
  position: absolute;
  top: -50px;
  right: -30%;
  width: 65%;
  opacity: 0;
}

@media screen and (min-width: 520px) {
  .heading__bg img {
    top: -75px;
    right: -100px;
    width: 50%;
  }
}
@media screen and (min-width: 760px) {
  .heading__bg img {
    top: -120px;
    right: -150px;
    width: 50%;
  }
}
@media screen and (min-width: 960px) {
  .heading__bg img {
    width: 40%;
  }
}
@media screen and (min-width: 1280px) {
  .heading__bg img {
    top: -120px;
    width: 28%;
  }
}
@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.heading__bg--active img:nth-child(1) {
  -webkit-animation-name: fadein;
  animation-name: fadein;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 0.2s;
  animation-delay: 0.2s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.heading__bg--active img:nth-child(2) {
  -webkit-animation-name: fadein;
  animation-name: fadein;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 0.4s;
  animation-delay: 0.4s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.heading__bg--active img:nth-child(3) {
  -webkit-animation-name: fadein;
  animation-name: fadein;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 0.6s;
  animation-delay: 0.6s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.heading__bg--active img:nth-child(4) {
  -webkit-animation-name: fadein;
  animation-name: fadein;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 0.8s;
  animation-delay: 0.8s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.heading__bg--active img:nth-child(5) {
  -webkit-animation-name: fadein;
  animation-name: fadein;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 1s;
  animation-delay: 1s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.heading__bg--active img:nth-child(6) {
  -webkit-animation-name: fadein;
  animation-name: fadein;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 1.2s;
  animation-delay: 1.2s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.heading__bg--active img:nth-child(7) {
  -webkit-animation-name: fadein;
  animation-name: fadein;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 1.4s;
  animation-delay: 1.4s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

@media screen and (max-width: 520px) {
  .heading__bg--about img,
  .heading__bg--right img {
    right: -45%;
  }
}
.index__inner {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin: 0 auto;
}

.index__item {
  position: relative;
  width: 100%;
}

@media screen and (min-width: 960px) {
  .index__item {
    width: 50%;
  }
}
.index__link {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: flex-start;
  width: 100%;
  height: 100%;
  padding: 40px 0 0 0;
  color: #212121;
  transition: 0.3s;
}

@media screen and (min-width: 1280px) {
  .index__link {
    padding: 60px 0 0 0;
  }
}
.index__link:hover {
  opacity: 0.7;
}

.index__title {
  margin: 0 0 10px 0;
  text-align: center;
  font-weight: bold;
  font-size: 1.6rem;
}

@media screen and (min-width: 960px) {
  .index__title {
    font-size: 2rem;
  }
}
@media screen and (min-width: 760px) {
  .index__title {
    margin: 0 0 20px 0;
  }
}
.index__title span {
  display: block;
  text-align: center;
  font-weight: normal;
  color: #035EAE;
  font-size: 1.2rem;
}

@media screen and (min-width: 960px) {
  .index__title span {
    font-size: 1.4rem;
  }
}
.index__title br {
  display: block;
}

@media screen and (min-width: 1280px) {
  .index__title br {
    display: none;
  }
}
.index__text {
  display: none;
  text-align: center;
  font-size: 1.2rem;
}

@media screen and (min-width: 960px) {
  .index__text {
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 960px) {
  .index__text {
    display: block;
  }
}
.index__text br {
  display: block;
}

@media screen and (min-width: 1280px) {
  .index__text br {
    display: none;
  }
}
.index__image img {
  width: 100%;
  height: auto;
}

/* 20250529追加:プロモーションビデオのスタイル */
.st-main__text {
  font-size: 16px;
  margin: 20px 0 10px 0;
}

.st-main__video {
  width: 100%;
}

html {
  font-size: 10px;
}

a {
  text-decoration: none;
}

@media screen and (min-width: 760px) {
  #page-title span {
    width: 260px;
  }
}

.about__bg {
  position: absolute;
  z-index: 2;
}
.about__bg--top {
  right: -170px;
}
@media screen and (min-width: 520px) {
  .about__bg--top {
    right: -100px;
  }
}
@media screen and (min-width: 760px) {
  .about__bg--top {
    right: 0;
  }
}
.about__bg--purpose {
  left: -40px;
  bottom: -50px;
}
@media screen and (min-width: 520px) {
  .about__bg--purpose {
    left: -80px;
  }
}
@media screen and (min-width: 760px) {
  .about__bg--purpose {
    left: 0px;
    bottom: -120px;
  }
}
@media screen and (min-width: 960px) {
  .about__bg--purpose {
    left: -130px;
    bottom: -300px;
  }
}
@media screen and (min-width: 1280px) {
  .about__bg--purpose {
    left: 0;
  }
}
.about__bg--purpose img {
  width: 80%;
}
@media screen and (min-width: 760px) {
  .about__bg--purpose img {
    width: auto;
  }
}
.about__bg--our-business {
  display: none;
  top: -110px;
  right: -110px;
  width: 40%;
}
@media screen and (min-width: 520px) {
  .about__bg--our-business {
    top: -75px;
    right: -80px;
    width: auto;
  }
}
@media screen and (min-width: 760px) {
  .about__bg--our-business {
    top: -120px;
    right: -30px;
  }
}
@media screen and (min-width: 960px) {
  .about__bg--our-business {
    display: block;
    right: 0;
  }
}
@media screen and (min-width: 1280px) {
  .about__bg--our-business {
    top: -70px;
  }
}
.about__bg--education {
  display: none;
  top: 30px;
  left: 0;
  width: 40%;
}
@media screen and (min-width: 520px) {
  .about__bg--education {
    top: 0;
  }
}
@media screen and (min-width: 760px) {
  .about__bg--education {
    top: -20px;
  }
}
@media screen and (min-width: 960px) {
  .about__bg--education {
    display: block;
    top: -80px;
  }
}

.section__inner {
  width: 100%;
  max-width: 900px;
  height: auto;
  margin: 0 auto;
  padding: 0 15px;
}
.section__title {
  margin: 0 0 20px 0;
  text-align: center;
  font-weight: normal;
  color: #035EAE;
  font-size: 2rem;
}
@media screen and (min-width: 960px) {
  .section__title {
    font-size: 2.4rem;
  }
}
.section__title span {
  display: block;
  font-size: 1.4rem;
}
@media screen and (min-width: 960px) {
  .section__title span {
    font-size: 1.6rem;
  }
}
.section__title span {
  letter-spacing: 1px;
  line-height: 2;
}
.section__text {
  margin: 0 0 20px 0;
  text-align: center;
  line-height: 2;
  font-size: 1.4rem;
}
@media screen and (min-width: 960px) {
  .section__text {
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 960px) {
  .section__text {
    margin: 0 0 60px 0;
  }
}
.section--keyvisual {
  background-image: url(../images/about/keyvisual_bg_pic1.png);
  background-repeat: no-repeat;
  background-size: 50%;
  position: relative;
}
@media screen and (min-width: 960px) {
  .section--keyvisual {
    background-size: contain;
  }
}
.section--purpose {
  position: relative;
}
.section--strengths {
  position: relative;
}
.section--infographics {
  padding: 65px 0;
  background: linear-gradient(135deg, #E6F6FF, #ECF7FD);
}
.section--history {
  padding: 65px 0;
  background-color: #FCFAF2;
}
.section--our-business {
  padding-top: 66px;
  position: relative;
}
.section--education {
  position: relative;
  background-color: #EFF4FD;
  padding: 150px 0 56px 0;
}
.section--estate {
  background-color: #FFF7F0;
  padding: 56px 0;
}
.section--tel {
  background-color: #ECF8F6;
  padding: 56px 0;
}
.section--park {
  background-color: #FDFCE5;
  padding: 56px 0;
}
.section--bottom {
  background-image: url(../images/about/bottom_bg.png);
  background-repeat: no-repeat;
  background-size: 60%;
  background-position: bottom left;
}
@media screen and (min-width: 960px) {
  .section--bottom {
    background-size: 30%;
  }
}

.keyvisual {
  padding-top: 45px;
}
.keyvisual__unit {
  display: block;
  justify-content: center;
  align-items: center;
  margin-bottom: 45px;
}
@media screen and (min-width: 960px) {
  .keyvisual__unit {
    display: flex;
  }
}
.keyvisual__unit--bg {
  background-image: url(../images/about/keyvisual_bg_pic2.png);
  background-repeat: no-repeat;
  background-position: bottom right;
  background-size: 50%;
  position: relative;
}
@media screen and (min-width: 960px) {
  .keyvisual__unit--bg {
    background-image: none;
  }
}
.keyvisual__title {
  font-size: 2rem;
}
@media screen and (min-width: 960px) {
  .keyvisual__title {
    font-size: 2.4rem;
  }
}
.keyvisual__title {
  font-weight: normal;
  text-align: center;
}
.keyvisual__title span {
  font-size: 1.4rem;
}
@media screen and (min-width: 960px) {
  .keyvisual__title span {
    font-size: 1.6rem;
  }
}
.keyvisual__title span {
  display: block;
  margin-top: 8px;
  letter-spacing: 1px;
}
.keyvisual__title--blue {
  font-size: 2rem;
}
@media screen and (min-width: 960px) {
  .keyvisual__title--blue {
    font-size: 2.4rem;
  }
}
.keyvisual__title--blue {
  color: #035EAE;
}
.keyvisual__title--yellow {
  font-size: 2rem;
}
@media screen and (min-width: 960px) {
  .keyvisual__title--yellow {
    font-size: 2.4rem;
  }
}
.keyvisual__title--yellow {
  color: #F3A100;
}
.keyvisual__img {
  width: 40%;
  margin: 20px auto;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .keyvisual__img {
    width: auto;
    margin: 0 60px;
  }
}
.keyvisual__text {
  font-size: 1.2rem;
}
@media screen and (min-width: 960px) {
  .keyvisual__text {
    font-size: 1.4rem;
  }
}
.keyvisual__text {
  line-height: 2;
  text-align: center;
  margin-top: 20px;
  padding: 0 20px;
}
@media screen and (min-width: 960px) {
  .keyvisual__text {
    text-align: left;
    margin-top: 0;
    margin-left: 35px;
    padding: 0;
    padding-left: 35px;
    border-left: solid 1px #707070;
  }
}
.keyvisual__text span {
  font-size: 1.2rem;
}
@media screen and (min-width: 960px) {
  .keyvisual__text span {
    font-size: 1.4rem;
  }
}
.keyvisual__text span {
  font-weight: bold;
}
.keyvisual--bg {
  background-image: none;
}
@media screen and (min-width: 960px) {
  .keyvisual--bg {
    background-image: url(../images/about/keyvisual_bg_pic2.png);
    background-repeat: no-repeat;
    background-position: bottom right;
    background-size: 40%;
    position: relative;
  }
}

.purpose {
  display: block;
  justify-content: space-between;
  margin: 0 0 65px 0;
}
@media screen and (min-width: 960px) {
  .purpose {
    display: flex;
    margin: 65px 0;
  }
}
.purpose__group {
  width: 100%;
}
@media screen and (min-width: 760px) {
  .purpose__group {
    width: max-content;
    margin: auto;
  }
}
.purpose__title {
  position: relative;
  width: max-content;
  font-size: 2rem;
}
@media screen and (min-width: 960px) {
  .purpose__title {
    font-size: 2.4rem;
  }
}
.purpose__title {
  font-weight: normal;
  color: #035EAE;
  padding: 0 70px;
  margin: 0 auto 20px auto;
  border-bottom: solid 2px #F5D54B;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .purpose__title {
    margin: 0 0 40px 0;
    padding: 0 70px 0 0;
    text-align: left;
  }
}
.purpose__title::after {
  content: "";
  position: absolute;
  width: 50%;
  left: 0;
  bottom: -2px;
  display: block;
  border-bottom: solid 2px #035EAE;
}
.purpose__title span {
  display: block;
  font-size: 1.4rem;
}
@media screen and (min-width: 960px) {
  .purpose__title span {
    font-size: 1.6rem;
  }
}
.purpose__title span {
  margin-top: 8px;
  letter-spacing: 1px;
}
.purpose__subtitle {
  font-size: 1.6rem;
}
@media screen and (min-width: 960px) {
  .purpose__subtitle {
    font-size: 2rem;
  }
}
.purpose__subtitle {
  font-weight: bold;
  line-height: 2;
  margin-bottom: 20px;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .purpose__subtitle {
    text-align: left;
    margin-bottom: 40px;
  }
}
.purpose__text {
  font-size: 1.2rem;
}
@media screen and (min-width: 960px) {
  .purpose__text {
    font-size: 1.4rem;
  }
}
.purpose__text {
  margin-bottom: 10px;
  line-height: 2;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .purpose__text {
    text-align: left;
  }
}
.purpose__img {
  text-align: center;
  width: 50%;
  margin: auto;
}
.purpose__img img {
  width: 100%;
  height: auto;
}
.purpose__bg {
  position: absolute;
  width: 60%;
  bottom: -200px;
  left: 15px;
  z-index: 2;
}
@media screen and (min-width: 960px) {
  .purpose__bg {
    width: 100%;
  }
}

.business {
  position: relative;
  justify-content: space-between;
  padding: 0 0 40px 0;
}
@media screen and (min-width: 960px) {
  .business {
    display: flex;
  }
}
.business__unit {
  width: 100%;
}
@media screen and (min-width: 960px) {
  .business__unit {
    width: 48%;
  }
}
@media screen and (min-width: 1280px) {
  .business__unit {
    width: 40%;
  }
}
.business__text {
  display: none;
  text-align: center;
  letter-spacing: 1.4rem;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  padding: 0 34px;
  margin: 0 34px;
  background-image: url(../images/about/business_text_bg.png);
  background-repeat: no-repeat;
  background-size: cover;
  font-size: 1.6rem;
}
@media screen and (min-width: 960px) {
  .business__text {
    font-size: 2rem;
  }
}
@media screen and (min-width: 1280px) {
  .business__text {
    display: block;
  }
}

.business-item {
  width: 100%;
  height: 42%;
  margin: 0 0 20px 0;
  background-position: right top 30px;
  background-repeat: no-repeat;
  background-size: 100px auto;
}
@media screen and (min-width: 760px) {
  .business-item {
    margin: 0 0 40px 0;
  }
}
@media screen and (min-width: 960px) {
  .business-item {
    margin: 0 0 60px 0;
  }
}
@media screen and (min-width: 1280px) {
  .business-item {
    background-position: right top;
    background-size: auto;
  }
}
.business-item__heading {
  display: flex;
  align-items: center;
  margin: 0 0 10px 0;
}
@media screen and (min-width: 960px) {
  .business-item__heading {
    margin: 0 0 28px 0;
  }
}
.business-item__title {
  font-weight: bold;
  font-size: 1.6rem;
}
@media screen and (min-width: 960px) {
  .business-item__title {
    font-size: 2rem;
  }
}
.business-item__title--education span {
  color: #035EAE;
}
.business-item__title--estate span {
  color: #FF7D23;
}
.business-item__title--tel span {
  color: #27BC9F;
}
.business-item__title--park span {
  color: #F5D54B;
}
.business-item__title--en {
  font-size: 1.4rem;
}
@media screen and (min-width: 960px) {
  .business-item__title--en {
    font-size: 1.6rem;
  }
}
.business-item__subtitle {
  margin: 0 0 10px 0;
  font-weight: normal;
  font-size: 1.6rem;
}
@media screen and (min-width: 960px) {
  .business-item__subtitle {
    font-size: 2rem;
  }
}
.business-item__subtitle {
  text-align: center;
  border-top: solid 1px;
  border-bottom: solid 1px;
  padding: 10px 0;
}
@media screen and (min-width: 960px) {
  .business-item__subtitle {
    margin: 0 0 20px 0;
    padding: 20px 0;
  }
}
.business-item__subtitle--education {
  color: #035EAE;
}
.business-item__subtitle--estate {
  color: #FF7D23;
}
.business-item__subtitle--tel {
  color: #27BC9F;
}
.business-item__subtitle--park {
  color: #F5D54B;
}
.business-item__subtitle--en {
  font-size: 1.4rem;
}
@media screen and (min-width: 960px) {
  .business-item__subtitle--en {
    font-size: 1.6rem;
  }
}
.business-item__icon {
  margin: 0 15px 0 0;
}
.business-item__text {
  line-height: 2;
  font-size: 1.2rem;
}
@media screen and (min-width: 960px) {
  .business-item__text {
    font-size: 1.4rem;
  }
}

.strengths {
  background-color: #FFFFFF;
  padding: 40px 15px;
  margin-bottom: 84px;
  box-shadow: 10px 11px 30px rgba(0, 0, 0, 0.1);
}
@media screen and (min-width: 960px) {
  .strengths {
    padding: 60px;
  }
}
.strengths__title {
  margin: 0 0 20px 0;
  text-align: center;
  font-weight: normal;
  color: #035EAE;
  font-size: 2rem;
}
@media screen and (min-width: 960px) {
  .strengths__title {
    font-size: 2.4rem;
  }
}
.strengths__title span {
  display: block;
  letter-spacing: 1px;
}
.strengths__subtitle {
  font-size: 1.4rem;
}
@media screen and (min-width: 960px) {
  .strengths__subtitle {
    font-size: 1.6rem;
  }
}
.strengths__subtitle {
  font-weight: bold;
  text-align: center;
  color: #035EAE;
  border-top: solid 1px #035EAE;
  border-bottom: solid 1px #035EAE;
  padding: 20px 0;
  margin-bottom: 40px;
}
@media screen and (min-width: 960px) {
  .strengths__subtitle {
    padding: 46px 0;
  }
}
.strengths__text {
  font-size: 1.2rem;
}
@media screen and (min-width: 960px) {
  .strengths__text {
    font-size: 1.4rem;
  }
}
.strengths__text {
  line-height: 2;
  margin-bottom: 40px;
}
@media screen and (min-width: 960px) {
  .strengths__text {
    margin-bottom: 0;
  }
}
.strengths__img {
  width: 80%;
  margin: auto;
}
.strengths__group {
  display: block;
  justify-content: space-between;
}
@media screen and (min-width: 960px) {
  .strengths__group {
    display: flex;
  }
}
.strengths__unit {
  width: 100%;
  margin-right: 34px;
}
@media screen and (min-width: 960px) {
  .strengths__unit {
    width: 50%;
  }
}
.strengths__img img {
  width: 100%;
}
.strengths__bg {
  width: 100%;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: -1;
}
.strengths__bg img {
  width: 100%;
  height: 300px;
}

.infographics__subtitle {
  color: #035EAE;
  font-size: 1.4rem;
}
@media screen and (min-width: 960px) {
  .infographics__subtitle {
    font-size: 1.6rem;
  }
}
.infographics__subtitle {
  text-align: center;
  margin-bottom: 50px;
}
.infographics__group {
  display: block;
  padding-bottom: 30px;
}
@media screen and (min-width: 760px) {
  .infographics__group {
    display: flex;
  }
}
.infographics__item {
  display: flex;
  flex-direction: column;
  width: 100%;
  position: relative;
  background-color: #FFFFFF;
  box-shadow: 10px 11px 30px rgba(0, 0, 0, 0.1);
  margin-right: 20px;
  margin-bottom: 20px;
  padding: 10px;
}
.infographics__item:last-child {
  margin-right: 0;
}
@media screen and (min-width: 760px) {
  .infographics__item {
    width: 33.3333333333%;
    margin-bottom: 0;
  }
}
.infographics__tag {
  font-size: 1.6rem;
}
@media screen and (min-width: 960px) {
  .infographics__tag {
    font-size: 2rem;
  }
}
.infographics__tag {
  font-weight: bold;
  text-align: center;
  margin-bottom: 20px;
}
.infographics__flex {
  display: flex;
  justify-content: center;
}
.infographics__img {
  width: 50px;
  height: 50px;
}
.infographics__img img {
  width: 100%;
}
.infographics__number {
  font-size: 4rem;
  font-family: kozuka-gothic-pr6n, sans-serif;
  font-weight: 900;
  font-style: normal;
  text-align: center;
  color: #035EAE;
  margin-left: 10px;
}
.infographics__number--en {
  font-size: 3.6rem;
}
.infographics__number--en .infographics__unit {
  display: inline-block;
  line-height: 1;
  text-align: left;
  font-size: 1rem;
}
.infographics__value {
  font-size: inherit;
}
.infographics__unit {
  color: #000000;
  font-size: 2rem;
}
@media screen and (min-width: 960px) {
  .infographics__unit {
    font-size: 2.4rem;
  }
}
.infographics__content {
  background-color: #FFFFFF;
  padding: 50px 15px;
  box-shadow: 10px 11px 30px rgba(0, 0, 0, 0.1);
}
@media screen and (min-width: 960px) {
  .infographics__content {
    padding: 50px;
  }
}
.infographics__title {
  position: relative;
  width: max-content;
  font-size: 2rem;
}
@media screen and (min-width: 960px) {
  .infographics__title {
    font-size: 2.4rem;
  }
}
.infographics__title {
  font-weight: bold;
  text-align: center;
  border-bottom: solid 2px #F5D54B;
  margin: auto;
  margin-bottom: 30px;
  padding-bottom: 25px;
}
.infographics__title::after {
  content: "";
  position: absolute;
  width: 50%;
  bottom: -2px;
  display: block;
  border-bottom: solid 2px #035EAE;
}
.infographics__text {
  font-size: 1.2rem;
}
@media screen and (min-width: 960px) {
  .infographics__text {
    font-size: 1.4rem;
  }
}
.infographics__text {
  text-align: center;
  line-height: 2;
  margin-bottom: 20px;
}
.infographics__graph {
  position: relative;
  width: 100%;
  max-width: 584px;
  height: auto;
  min-height: 225px;
  margin: 0 auto;
  overflow: hidden;
}
@media screen and (min-width: 520px) {
  .infographics__graph {
    min-height: 360px;
  }
}
@media screen and (min-width: 760px) {
  .infographics__graph {
    min-height: 384px;
  }
}
.infographics__graph--active img:nth-child(1) {
  transform: rotate(-90deg);
  animation: circle1 1.5s linear both;
  z-index: 4;
}
.infographics__graph--active img:nth-child(2) {
  transform: rotate(-180deg);
  animation: circle1 1.5s linear both;
  z-index: 3;
}
.infographics__graph--active img:nth-child(3) {
  transform: rotate(-240deg);
  animation: circle2 1.5s linear both;
  z-index: 2;
}
.infographics__graph--active img:nth-child(4) {
  transform: rotate(-360deg);
  animation: circle3 1.5s linear both;
  z-index: 1;
}
.infographics__graph--active img:nth-child(5) {
  animation-delay: 1.5s;
  z-index: 6;
}
.infographics__graph--active img:nth-child(6) {
  z-index: 5;
}
.infographics__graph img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  opacity: 0;
}
.infographics .fade-in-delay {
  visibility: visible !important;
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn;
  animation-duration: 1s;
  animation-delay: 0.2s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}
.infographics .fade-in {
  visibility: hidden;
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes circle1 {
  0% {
    opacity: 0;
  }
  100% {
    transform: rotate(0deg);
    opacity: 1;
  }
}
@keyframes circle2 {
  0% {
    opacity: 0;
  }
  100% {
    transform: rotate(0deg);
    opacity: 1;
  }
}
@keyframes circle3 {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 0;
  }
  100% {
    transform: rotate(0deg);
    opacity: 1;
    z-index: 4;
  }
}
@keyframes circle4 {
  0% {
    opacity: 0;
  }
  30% {
    opacity: 0;
  }
  100% {
    transform: rotate(0deg);
    opacity: 1;
  }
}
.history {
  background-color: #FFFFFF;
  box-shadow: 10px 11px 30px rgba(0, 0, 0, 0.1);
}
.history__inner {
  padding: 40px 15px;
}
@media screen and (min-width: 960px) {
  .history__inner {
    padding: 40px;
  }
}
.history__topics {
  font-size: 1.6rem;
}
@media screen and (min-width: 960px) {
  .history__topics {
    font-size: 2rem;
  }
}
.history__topics {
  font-weight: bold;
  text-align: center;
  color: #FFFFFF;
  background-color: #035EAE;
  padding: 24px 0;
}
.history__head {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  border: solid 5px #EBEBEB;
  padding: 26px 10px;
  margin-bottom: 20px;
}
.history__title {
  width: 50%;
  display: inline-flex;
  align-items: center;
  font-size: 1.4rem;
  font-weight: bold;
  margin-bottom: 10px;
}
@media screen and (min-width: 960px) {
  .history__title {
    width: 22%;
    margin-bottom: 0;
  }
}
.history__title:before {
  content: "";
  display: inline-block;
  margin-right: 5px;
  width: 25px;
  height: 25px;
}
.history__title--blue:before {
  background: #035EAE;
}
.history__title--green:before {
  background: #27BC9F;
}
.history__title--orange:before {
  background: #FF7D23;
}
.history__title--yellow:before {
  background: #F5D54B;
}
@media screen and (min-width: 960px) {
  .history__title--en {
    font-size: 1rem;
  }
}
.history__title span {
  width: calc(100% - 30px);
  padding: 0 10px 0 0;
}
.history__unit {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 0;
  margin: 5px;
  margin-bottom: 26px;
}
@media screen and (min-width: 960px) {
  .history__unit {
    padding: 0 10px;
    margin: 0 0 26px 0;
  }
}
.history__item {
  width: 50%;
  font-weight: bold;
  margin-bottom: 10px;
}
@media screen and (min-width: 960px) {
  .history__item {
    width: 22%;
    margin-bottom: 0;
  }
}
.history__item--blue {
  color: #035EAE;
}
.history__item--green {
  color: #27BC9F;
}
.history__item--orange {
  color: #FF7D23;
}
.history__item--yellow {
  color: #F5D54B;
}
.history__year {
  display: flex;
  align-items: center;
  margin-bottom: 4px;
  font-size: 1.2rem;
  font-family: Hiragino Kaku Gothic ProN;
}
.history__year span {
  font-size: 1.4rem;
}
@media screen and (min-width: 960px) {
  .history__year span {
    font-size: 1.6rem;
  }
}
.history__year span {
  margin-right: 4px;
}
.history__text {
  font-size: 1.2rem;
  line-height: 2;
}
.history__text--en {
  line-height: 1.2;
  padding: 0 5px;
}
@media screen and (min-width: 960px) {
  .history__text--en {
    padding: 0;
  }
}
.history__graph {
  display: block;
  justify-content: space-between;
}
@media screen and (min-width: 960px) {
  .history__graph {
    display: flex;
  }
}
.history__chronology {
  position: relative;
  margin-bottom: 8px;
  padding-left: 0;
}
.history__chronology.sal-animate:nth-child(1) {
  transition-delay: 0.1s;
}
@media screen and (min-width: 960px) {
  .history__chronology.sal-animate:nth-child(1) {
    transition-delay: 0.2s;
  }
}
.history__chronology.sal-animate:nth-child(2) {
  transition-delay: 0.2s;
}
@media screen and (min-width: 960px) {
  .history__chronology.sal-animate:nth-child(2) {
    transition-delay: 0.4s;
  }
}
.history__chronology.sal-animate:nth-child(3) {
  transition-delay: 0.3s;
}
@media screen and (min-width: 960px) {
  .history__chronology.sal-animate:nth-child(3) {
    transition-delay: 0.6s;
  }
}
.history__chronology.sal-animate:nth-child(4) {
  transition-delay: 0.4s;
}
@media screen and (min-width: 960px) {
  .history__chronology.sal-animate:nth-child(4) {
    transition-delay: 0.8s;
  }
}
.history__chronology.sal-animate:nth-child(5) {
  transition-delay: 0.5s;
}
@media screen and (min-width: 960px) {
  .history__chronology.sal-animate:nth-child(5) {
    transition-delay: 1s;
  }
}
.history__chronology.sal-animate:nth-child(6) {
  transition-delay: 0.6s;
}
@media screen and (min-width: 960px) {
  .history__chronology.sal-animate:nth-child(6) {
    transition-delay: 1.2s;
  }
}
.history__chronology.sal-animate:nth-child(7) {
  transition-delay: 0.7s;
}
@media screen and (min-width: 960px) {
  .history__chronology.sal-animate:nth-child(7) {
    transition-delay: 1.4s;
  }
}
.history__chronology.sal-animate:nth-child(8) {
  transition-delay: 0.8s;
}
@media screen and (min-width: 960px) {
  .history__chronology.sal-animate:nth-child(8) {
    transition-delay: 1.6s;
  }
}
.history__chronology.sal-animate:nth-child(9) {
  transition-delay: 0.9s;
}
@media screen and (min-width: 960px) {
  .history__chronology.sal-animate:nth-child(9) {
    transition-delay: 1.8s;
  }
}
.history__chronology.sal-animate:nth-child(10) {
  transition-delay: 1s;
}
@media screen and (min-width: 960px) {
  .history__chronology.sal-animate:nth-child(10) {
    transition-delay: 2s;
  }
}
.history__chronology.sal-animate:nth-child(11) {
  transition-delay: 1.1s;
}
@media screen and (min-width: 960px) {
  .history__chronology.sal-animate:nth-child(11) {
    transition-delay: 2.2s;
  }
}
@media screen and (min-width: 960px) {
  .history__chronology {
    padding-left: 50px;
  }
}
.history__chronology::before {
  display: none;
}
@media screen and (min-width: 960px) {
  .history__chronology::before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 10px;
    height: 10px;
    background: #DEDEDE;
    border-radius: 50%;
    left: 0;
  }
}
.history__chronology::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 50px;
  border-bottom: 3px solid #DEDEDE;
  left: 5px;
}
.history__empty {
  display: none;
}
@media screen and (min-width: 960px) {
  .history__empty {
    display: block;
  }
}
.history__timeline {
  position: relative;
  background-color: #FFFFFF;
  border: solid 3px #DEDEDE;
  padding: 6px 12px;
  z-index: 2;
}
@media screen and (min-width: 960px) {
  .history__timeline {
    width: 315px;
  }
}
.history__box {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
.history__box p {
  font-size: 1.2rem;
  font-weight: bold;
  font-family: Hiragino Kaku Gothic ProN;
  line-height: 1.8;
}
.history__box figure {
  width: 65px;
  height: 65px;
  margin-left: 20px;
}
.history__box--second {
  margin-top: 10px;
  padding-top: 10px;
  border-top: dashed 2px #DEDEDE;
}
@media screen and (min-width: 960px) {
  .history__box--en p {
    font-size: 1rem;
  }
}
.history__empty {
  content: "";
  height: 24px;
}
.history__btn {
  background-color: #F5F5F5;
  padding: 27px 0;
}
.history__btn a {
  position: relative;
  height: 50px;
  line-height: 50px;
  margin: 0 auto;
  font-weight: bold;
  display: block;
  width: 100%;
  max-width: 300px;
  text-align: center;
  overflow: hidden;
  color: #FFFFFF;
  background-color: #035EAE;
}
.history__btn a a {
  display: block;
  color: inherit;
  font-size: inherit;
}
.history__btn a a span {
  position: relative;
  z-index: 2;
  color: inherit;
  font-size: inherit;
}
.history__btn a button {
  display: block;
  color: inherit;
  font-size: inherit;
}
.history__btn a {
  border-radius: 5px;
  font-size: 1.4rem;
}
@media screen and (min-width: 960px) {
  .history__btn a {
    font-size: 1.6rem;
  }
}
.history__btn a {
  position: relative;
  transition: 0.3s;
}
.history__btn a:hover {
  opacity: 0.7;
}
.history__btn a:hover {
  background-position: center right 18px;
}
.history__btn a span {
  font-size: 1.2rem;
}
@media screen and (min-width: 960px) {
  .history__btn a span {
    font-size: 1.4rem;
  }
}
.history__btn a span {
  padding: 4px 10px;
  margin-left: 10px;
  border: solid 1px #FFFFFF;
}

.history-bar {
  position: relative;
  width: 100%;
  height: auto;
  margin: 0 0 20px 0;
}
@media screen and (min-width: 960px) {
  .history-bar {
    margin: 0;
  }
}
.history-bar__img {
  width: 100%;
  height: auto;
}
.history-bar__img img {
  width: 100%;
  height: auto;
}
@media screen and (min-width: 760px) {
  .history-bar__img img {
    height: 100%;
    width: auto;
  }
}
.history-bar__list {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  display: flex;
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 960px) {
  .history-bar__list {
    display: block;
  }
}
.history-bar__list--active li {
  animation-name: bar1;
  animation-duration: 1s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
  background-color: #FFFFFF;
}
@media screen and (min-width: 960px) {
  .history-bar__list--active li {
    animation-name: bar2;
  }
}
.history-bar__item {
  width: 5.2631578947%;
  height: 100%;
}
@media screen and (min-width: 960px) {
  .history-bar__item {
    width: 100%;
    height: calc((100% - 0px) / 20);
  }
}
.history-bar__item:nth-child(1) {
  animation-delay: 0.2s;
}
.history-bar__item:nth-child(2) {
  animation-delay: 0.4s;
}
.history-bar__item:nth-child(3) {
  animation-delay: 0.6s;
}
.history-bar__item:nth-child(4) {
  animation-delay: 0.8s;
}
.history-bar__item:nth-child(5) {
  animation-delay: 1s;
}
.history-bar__item:nth-child(6) {
  animation-delay: 1.2s;
}
.history-bar__item:nth-child(7) {
  animation-delay: 1.4s;
}
.history-bar__item:nth-child(8) {
  animation-delay: 1.6s;
}
.history-bar__item:nth-child(9) {
  animation-delay: 1.8s;
}
.history-bar__item:nth-child(10) {
  animation-delay: 2s;
}
.history-bar__item:nth-child(11) {
  animation-delay: 2.2s;
}
.history-bar__item:nth-child(12) {
  animation-delay: 2.4s;
}
.history-bar__item:nth-child(13) {
  animation-delay: 2.6s;
}
.history-bar__item:nth-child(14) {
  animation-delay: 2.8s;
}
.history-bar__item:nth-child(15) {
  animation-delay: 3s;
}
.history-bar__item:nth-child(16) {
  animation-delay: 3.2s;
}
.history-bar__item:nth-child(17) {
  animation-delay: 3.4s;
}
.history-bar__item:nth-child(18) {
  animation-delay: 3.6s;
}
.history-bar__item:nth-child(19) {
  animation-delay: 3.8s;
}
.history-bar__item:nth-child(20) {
  animation-delay: 4s;
}
@keyframes bar1 {
  0% {
    clip-path: inset(0);
  }
  100% {
    clip-path: inset(0 0 100% 0);
  }
}
@keyframes bar2 {
  0% {
    clip-path: inset(0);
  }
  100% {
    clip-path: inset(0 0 0 100%);
  }
}

.our-business {
  margin-top: -14vw;
}
@media screen and (min-width: 760px) {
  .our-business {
    margin-top: -104px;
  }
}
.our-business__img {
  text-align: center;
  position: relative;
  z-index: 2;
  bottom: -14vw;
}
@media screen and (min-width: 760px) {
  .our-business__img {
    bottom: -104px;
  }
}

.block {
  padding-top: 46px;
  background-color: #FFFFFF;
  box-shadow: 10px 11px 30px rgba(0, 0, 0, 0.1);
}
.block__heading {
  display: flex;
  align-items: center;
  padding: 0 15px;
  margin: 0 0 28px 0;
}
@media screen and (min-width: 960px) {
  .block__heading {
    padding: 0 60px;
  }
}
.block__title {
  font-size: 1.6rem;
}
@media screen and (min-width: 960px) {
  .block__title {
    font-size: 2rem;
  }
}
.block__title {
  font-weight: bold;
  margin-left: 20px;
}
@media screen and (min-width: 960px) {
  .block__title {
    display: flex;
    justify-content: space-between;
    width: 100%;
  }
}
.block__title span {
  font-size: 1.2rem;
}
@media screen and (min-width: 960px) {
  .block__title span {
    font-size: 1.4rem;
  }
}
.block__title span {
  font-weight: normal;
  display: block;
}
@media screen and (min-width: 960px) {
  .block__title span {
    display: unset;
    margin-left: 14px;
  }
}
.block__subtitle {
  font-size: 2rem;
}
@media screen and (min-width: 960px) {
  .block__subtitle {
    font-size: 2.4rem;
  }
}
.block__subtitle {
  font-weight: normal;
  margin: 0 0 20px 0;
  font-feature-settings: "palt";
}
.block__subtitle--education {
  color: #035EAE;
}
.block__subtitle--estate {
  color: #FF7D23;
}
.block__subtitle--tel {
  color: #27BC9F;
}
.block__subtitle--park {
  color: #F5D54B;
}
.block__content {
  width: 100%;
  display: block;
  padding: 0 15px;
}
@media screen and (min-width: 960px) {
  .block__content {
    display: flex;
    margin-bottom: 40px;
    padding: 0 60px;
  }
}
.block__unit {
  width: 100%;
}
@media screen and (min-width: 960px) {
  .block__unit {
    width: 50%;
  }
}
.block__text {
  font-size: 1.2rem;
}
@media screen and (min-width: 960px) {
  .block__text {
    font-size: 1.4rem;
  }
}
.block__text {
  line-height: 2;
  margin-bottom: 20px;
}
@media screen and (min-width: 960px) {
  .block__text {
    margin-bottom: 0;
  }
}
@media screen and (min-width: 960px) {
  .block__text--en {
    line-height: 1.2;
  }
}
.block__img {
  width: 100%;
  margin: auto;
  margin-bottom: 20px;
}
@media screen and (min-width: 520px) {
  .block__img {
    width: 50%;
  }
}
@media screen and (min-width: 960px) {
  .block__img {
    margin-left: 54px;
    margin-bottom: 0;
  }
}
.block__img img {
  width: 100%;
}
.block__btn {
  padding: 40px 0;
}
.block__btn a {
  position: relative;
  height: 50px;
  line-height: 50px;
  margin: 0 auto;
  font-weight: bold;
  background-image: url(../images/about/business_item_btn_icon.svg);
  background-position: center right 20px;
  background-repeat: no-repeat;
  font-size: 1.4rem;
}
@media screen and (min-width: 960px) {
  .block__btn a {
    font-size: 1.6rem;
  }
}
.block__btn a {
  position: relative;
  transition: 0.3s;
}
.block__btn a:hover {
  opacity: 0.7;
}
.block__btn a:hover {
  background-position: center right 18px;
}
.block__btn--education a {
  display: block;
  width: 100%;
  max-width: 300px;
  text-align: center;
  overflow: hidden;
  color: #FFFFFF;
  background-color: #035EAE;
}
.block__btn--education a a {
  display: block;
  color: inherit;
  font-size: inherit;
}
.block__btn--education a a span {
  position: relative;
  z-index: 2;
  color: inherit;
  font-size: inherit;
}
.block__btn--education a button {
  display: block;
  color: inherit;
  font-size: inherit;
}
.block__btn--education a {
  border-radius: 5px;
}
.block__btn--estate a {
  display: block;
  width: 100%;
  max-width: 300px;
  text-align: center;
  overflow: hidden;
  color: #FFFFFF;
  background-color: #FF7D23;
}
.block__btn--estate a a {
  display: block;
  color: inherit;
  font-size: inherit;
}
.block__btn--estate a a span {
  position: relative;
  z-index: 2;
  color: inherit;
  font-size: inherit;
}
.block__btn--estate a button {
  display: block;
  color: inherit;
  font-size: inherit;
}
.block__btn--estate a {
  border-radius: 5px;
}
.block__btn--tel a {
  display: block;
  width: 100%;
  max-width: 300px;
  text-align: center;
  overflow: hidden;
  color: #FFFFFF;
  background-color: #27BC9F;
}
.block__btn--tel a a {
  display: block;
  color: inherit;
  font-size: inherit;
}
.block__btn--tel a a span {
  position: relative;
  z-index: 2;
  color: inherit;
  font-size: inherit;
}
.block__btn--tel a button {
  display: block;
  color: inherit;
  font-size: inherit;
}
.block__btn--tel a {
  border-radius: 5px;
}
.block__btn--park a {
  display: block;
  width: 100%;
  max-width: 300px;
  text-align: center;
  overflow: hidden;
  color: #FFFFFF;
  background-color: #F5D54B;
}
.block__btn--park a a {
  display: block;
  color: inherit;
  font-size: inherit;
}
.block__btn--park a a span {
  position: relative;
  z-index: 2;
  color: inherit;
  font-size: inherit;
}
.block__btn--park a button {
  display: block;
  color: inherit;
  font-size: inherit;
}
.block__btn--park a {
  border-radius: 5px;
}

.education {
  display: block;
}
@media screen and (min-width: 960px) {
  .education {
    display: flex;
  }
}
.education__group {
  width: 100%;
  display: block;
}
@media screen and (min-width: 960px) {
  .education__group {
    display: flex;
  }
}
.education__tag {
  display: flex;
  justify-content: center;
  font-weight: bold;
  margin: auto;
  width: 100%;
}
@media screen and (min-width: 960px) {
  .education__tag {
    display: block;
  }
}
.education__tag p {
  text-align: center;
  margin: auto;
  width: 100%;
  padding: 10px 0;
  font-size: 1.4rem;
}
@media screen and (min-width: 960px) {
  .education__tag p {
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 960px) {
  .education__tag p {
    width: 184px;
  }
}
.education__tag--blue1 p {
  border: solid 1px #2A62CE;
  color: #2A62CE;
}
.education__tag--blue2 {
  background-color: #F4F7FD;
}
.education__tag--blue2 p {
  border: solid 1px #2A62CE;
  background-color: #2A62CE;
  color: #FFFFFF;
}
.education__tag--yellow1 p {
  border: solid 1px #F4BC41;
  color: #F4BC41;
}
.education__tag--yellow2 {
  background-color: #FFFBF1;
}
.education__tag--yellow2 p {
  border: solid 1px #F4BC41;
  background-color: #F4BC41;
  color: #FFFFFF;
}
.education__tag--en p {
  height: 40px;
  font-size: 1rem;
}
@media screen and (min-width: 960px) {
  .education__tag--en p {
    height: auto;
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 960px) and (min-width: 960px) {
  .education__tag--en p {
    font-size: 1.6rem;
  }
}
.education__img {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.education__img--blue {
  background-color: #F4F7FD;
}
.education__img--yellow {
  background-color: #FFFBF1;
}
.education__img figure {
  width: 40%;
  margin: 10px;
}
@media screen and (min-width: 960px) {
  .education__img figure {
    margin: 18px;
  }
}
.education__img figure img {
  width: 100%;
}
.education__img .figcaption {
  font-size: 1.2rem;
}
@media screen and (min-width: 960px) {
  .education__img .figcaption {
    font-size: 1.4rem;
  }
}
.education__img .figcaption {
  font-weight: bold;
  text-align: center;
  margin-top: 10px;
}
@media screen and (min-width: 960px) {
  .education__img .figcaption--en {
    height: 40px;
  }
}
.education__img .figcaption--blue {
  color: #035EAE;
}
.education__img .figcaption--yellow {
  color: #F3A100;
}

.estate {
  display: block;
}
@media screen and (min-width: 960px) {
  .estate {
    display: flex;
  }
}
.estate__img {
  width: 80%;
  margin: auto;
}
@media screen and (min-width: 960px) {
  .estate__img {
    width: 100%;
  }
}
.estate__img img {
  width: 100%;
}
.estate__img figcaption {
  font-size: 1.2rem;
}
@media screen and (min-width: 960px) {
  .estate__img figcaption {
    font-size: 1.4rem;
  }
}
.estate__img figcaption {
  font-weight: bold;
  text-align: center;
  margin: 20px 0;
}

.tel {
  display: block;
}
@media screen and (min-width: 960px) {
  .tel {
    display: flex;
  }
}
.tel__img {
  width: 80%;
  margin: auto;
}
@media screen and (min-width: 960px) {
  .tel__img {
    width: 100%;
  }
}
.tel__img img {
  width: 100%;
}

.park {
  display: block;
}
@media screen and (min-width: 960px) {
  .park {
    display: flex;
  }
}
.park__img {
  width: 80%;
  margin: auto;
}
@media screen and (min-width: 960px) {
  .park__img {
    width: 100%;
  }
}
.park__img img {
  width: 100%;
}

.bottom {
  display: block;
  justify-content: space-evenly;
  align-items: center;
  padding: 40px 0;
}
@media screen and (min-width: 960px) {
  .bottom {
    padding: 114px 0;
    display: flex;
  }
}
.bottom__text {
  width: 100%;
  margin: 0 auto 30px auto;
  font-size: 1.6rem;
}
@media screen and (min-width: 960px) {
  .bottom__text {
    font-size: 2rem;
  }
}
.bottom__text {
  line-height: 2;
}
.bottom__text span {
  font-size: 1.6rem;
}
@media screen and (min-width: 960px) {
  .bottom__text span {
    font-size: 2rem;
  }
}
.bottom__text span {
  font-weight: bold;
}
@media screen and (min-width: 760px) {
  .bottom__text {
    width: max-content;
  }
}
@media screen and (min-width: 960px) {
  .bottom__text {
    margin-bottom: 0;
  }
}
.bottom__img {
  width: 30%;
  margin: auto;
}
.bottom__img img {
  width: 100%;
}