/* ----------------------------------------------------------------------------
ABOUT
---------------------------------------------------------------------------- */
@media screen and (min-width: 1281px) {
  #sec_about {
    padding: 40px 0 150px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  #sec_about {
    padding: 40px 0 120px;
  }
}
@media screen and (max-width: 767px) {
  #sec_about {
    padding: 40px 0 40px;
  }
}

.l_page_content {
  overflow: hidden;
}

.section-intro {
  padding-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .section-intro {
    padding-bottom: 40px;
  }
}

.section-message {
  background-image: url(../img/about/message-bg.webp);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: bottom left;
  position: relative;
  padding-top: 120px;
  padding-bottom: 18.0555555556vw;
}
@media screen and (max-width: 767px) {
  .section-message {
    margin-top: 40px;
    padding-top: 30px;
    padding-bottom: 140px;
  }
}
.section-message::after {
  content: "";
  display: block;
  background-color: #ffffff;
  position: absolute;
  background-position: bottom left;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 8.3333333333vw;
  border-radius: 140px 0 0 0;
}
@media screen and (max-width: 767px) {
  .section-message::after {
    height: 56px;
    border-radius: 40px 0 0 0;
  }
}
.section-message .message-flex {
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .section-message .message-flex {
    flex-direction: column;
  }
}
.section-message .message-flex .img {
  width: 37.5%;
}
@media screen and (max-width: 767px) {
  .section-message .message-flex .img {
    width: 100%;
    padding-top: 80px;
    margin-bottom: 40px;
  }
}
.section-message .message-flex .txt_wrap {
  width: 44.1666666667%;
  max-width: 530px;
}
@media screen and (max-width: 1280px) {
  .section-message .message-flex .txt_wrap {
    width: 55%;
    max-width: 100%;
  }
}
.section-message .message-flex .txt_wrap .sec_title_wrap {
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  .section-message .message-flex .txt_wrap {
    width: 100%;
  }
  .section-message .message-flex .txt_wrap .sec_title_wrap {
    position: absolute;
    top: 0;
    left: 20px;
  }
}
.section-message .message-flex .txt_wrap h2 {
  margin-bottom: 20px;
}
.section-message .message-flex .txt_wrap h3 {
  font-size: 24px;
  font-family: "NotoSerifJP-Bold";
  margin-bottom: 16px;
}
@media screen and (max-width: 767px) {
  .section-message .message-flex .txt_wrap h3 {
    font-size: 18px;
  }
}
.section-message .message-flex .txt_wrap .txt {
  font-size: 16px;
  margin-bottom: 16px;
}
@media screen and (max-width: 767px) {
  .section-message .message-flex .txt_wrap .txt {
    font-size: 14px;
    text-align: justify;
  }
}
.section-message .message-flex .txt_wrap .note {
  font-size: 16px;
  font-family: "NotoSerifJP-Medium";
}
@media screen and (max-width: 767px) {
  .section-message .message-flex .txt_wrap .note {
    font-size: 14px;
    width: -moz-fit-content;
    width: fit-content;
    margin-right: 0;
    margin-left: auto;
  }
}

.section-philosophy {
  position: relative;
  padding-bottom: 280px;
}
@media screen and (max-width: 767px) {
  .section-philosophy {
    padding-bottom: 180px;
  }
}
.section-philosophy .sec_title_wrap.center {
  text-align: center;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 30px;
}
.section-philosophy .sec_title_wrap.center .title_sec::before {
  margin: auto;
  left: 0;
  right: 0;
  transform: translateX(-51px);
}
@media screen and (max-width: 767px) {
  .section-philosophy .sec_title_wrap.center .title_sec::before {
    transform: translateX(-29px);
  }
}
.section-philosophy .sec_title_wrap.center .title_sec::after {
  margin: auto;
  left: 0;
  right: 0;
  transform: translateX(10px);
}
.section-philosophy .philosophy-txt {
  font-size: 24px;
  line-height: 1.8;
  text-align: center;
}
@media screen and (max-width: 1280px) {
  .section-philosophy .philosophy-txt {
    font-size: 18px;
  }
}
.section-philosophy .philosophy-flex {
  justify-content: space-between;
}
.section-philosophy .philosophy-flex.reverse {
  flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.reverse {
    flex-direction: column-reverse;
  }
}
.section-philosophy .philosophy-flex.first {
  margin-top: 6.9444444444vw;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.first {
    margin-top: 60px;
  }
}
.section-philosophy .philosophy-flex.first .img {
  width: 45.625vw;
  margin: 0 calc(50% - 50vw);
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.first .img {
    width: calc(100vw - 20px);
    border-radius: 0 40px 0 0;
    overflow: hidden;
  }
}
.section-philosophy .philosophy-flex.first .txt_wrap {
  width: 43.75vw;
  max-width: 630px;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.first .txt_wrap {
    width: 100%;
  }
}
.section-philosophy .philosophy-flex.first .txt_wrap .txt {
  font-size: 36px;
  font-family: "NotoSerifJP-Regular";
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.first .txt_wrap .txt {
    font-size: 20px;
    margin: 40px 0;
  }
}
.section-philosophy .philosophy-flex.second {
  margin-top: 6.9444444444vw;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.second {
    margin-top: 80px;
    flex-direction: column-reverse;
  }
}
.section-philosophy .philosophy-flex.second .img {
  width: 45.4861111111vw;
  margin: 0 calc(50% - 50vw);
  margin-top: 140px;
  position: relative;
  z-index: 2;
  height: 24.6527777778vw;
  min-height: 355px;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.second .img {
    width: 100vw;
    transform: translateX(20px);
    margin-top: 0;
    height: auto;
    min-height: auto;
    border-radius: 40px 0 0 0;
  }
}
.section-philosophy .philosophy-flex.second .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.section-philosophy .philosophy-flex.second .img::before {
  display: block;
  content: "";
  position: absolute;
  background-color: #cde9f4;
  top: 0;
  left: 0;
  width: 100vw;
  height: 1px;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.second .img::before {
    display: none;
  }
}
.section-philosophy .philosophy-flex.second .img::after {
  display: block;
  content: "";
  position: absolute;
  background-color: #cde9f4;
  bottom: 0;
  left: 0;
  width: 100vw;
  height: 1px;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.second .img::after {
    display: none;
  }
}
.section-philosophy .philosophy-flex.second .txt_wrap {
  width: 41.6666666667vw;
  max-width: 600px;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.second .txt_wrap {
    width: 100%;
    max-width: 100%;
  }
}
.section-philosophy .philosophy-flex.second .txt_wrap .sec_title_wrap {
  margin-bottom: 40px;
}
.section-philosophy .philosophy-flex.second .txt_wrap ul {
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  height: 24.6527777778vw;
  min-height: 355px;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.second .txt_wrap ul {
    height: auto;
    min-height: auto;
    margin-bottom: 40px;
  }
}
.section-philosophy .philosophy-flex.second .txt_wrap ul li {
  font-size: clamp(1.8rem, 1.6vw, 2.4rem);
  font-family: "NotoSerifJP-Regular";
  display: flex;
  align-items: center;
  position: relative;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.second .txt_wrap ul li {
    font-size: 14px;
  }
}
.section-philosophy .philosophy-flex.second .txt_wrap ul li::after {
  display: block;
  content: "";
  position: absolute;
  background-color: #cde9f4;
  bottom: -2.0833333333vw;
  left: 0;
  width: 100vw;
  height: 1px;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.second .txt_wrap ul li::after {
    display: none;
  }
}
.section-philosophy .philosophy-flex.second .txt_wrap ul li:last-child::after {
  display: none;
}
.section-philosophy .philosophy-flex.second .txt_wrap ul li span {
  font-family: "Forum";
  font-size: clamp(2.4rem, 2.8vw, 4rem);
  margin-right: 28px;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.second .txt_wrap ul li span {
    font-size: 24px;
    margin-right: 16px;
  }
}
.section-philosophy .philosophy-flex.last {
  margin-top: 6.9444444444vw;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.last {
    margin-top: 80px;
    flex-direction: column-reverse;
  }
}
.section-philosophy .philosophy-flex.last .img {
  width: 45.625vw;
  margin: 0 calc(50% - 50vw);
  margin-top: 140px;
  position: relative;
  z-index: 2;
  height: 50.3472222222vw;
  min-height: 725px;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.last .img {
    width: 100vw;
    transform: translateX(-20px);
    border-radius: 0 40px 0 0;
    margin-top: 40px;
    overflow: hidden;
    height: auto;
    min-height: auto;
  }
}
.section-philosophy .philosophy-flex.last .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.last .img img {
    height: auto;
  }
}
.section-philosophy .philosophy-flex.last .img::before {
  display: block;
  content: "";
  position: absolute;
  background-color: #cde9f4;
  top: 0;
  left: -100vw;
  width: 200vw;
  height: 1px;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.last .img::before {
    display: none;
  }
}
.section-philosophy .philosophy-flex.last .img::after {
  display: block;
  content: "";
  position: absolute;
  background-color: #cde9f4;
  bottom: 0;
  left: -100vw;
  width: 200vw;
  height: 1px;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.last .img::after {
    display: none;
  }
}
.section-philosophy .philosophy-flex.last .txt_wrap {
  width: 41.6666666667vw;
  max-width: 600px;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.last .txt_wrap {
    width: 100%;
    max-width: 100%;
  }
}
.section-philosophy .philosophy-flex.last .txt_wrap .sec_title_wrap {
  margin-bottom: 40px;
}
.section-philosophy .philosophy-flex.last .txt_wrap ul {
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  height: 50.3472222222vw;
  min-height: 725px;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.last .txt_wrap ul {
    height: auto;
    min-height: auto;
  }
}
.section-philosophy .philosophy-flex.last .txt_wrap ul li {
  font-size: clamp(1.8rem, 1.6vw, 2.4rem);
  font-family: "NotoSerifJP-Regular";
  position: relative;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.last .txt_wrap ul li {
    font-size: 14px;
    padding-bottom: 12px;
  }
}
.section-philosophy .philosophy-flex.last .txt_wrap ul li::after {
  display: block;
  content: "";
  position: absolute;
  background-color: #cde9f4;
  bottom: -1.8055555556vw;
  left: 0;
  width: 100vw;
  height: 1px;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.last .txt_wrap ul li::after {
    bottom: 0;
    width: 100%;
    transform: none;
  }
}
.section-philosophy .philosophy-flex.last .txt_wrap ul li:last-child::after {
  display: none;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.last .txt_wrap ul li:last-child::after {
    display: block;
  }
}
.section-philosophy .philosophy-flex.last .txt_wrap ul li span {
  display: block;
  font-size: clamp(2rem, 2.3vw, 3rem);
  margin-bottom: 0.9722222222vw;
}
@media screen and (max-width: 767px) {
  .section-philosophy .philosophy-flex.last .txt_wrap ul li span {
    font-size: 18px;
  }
}
.section-philosophy .txt_flow {
  overflow: hidden;
  position: absolute;
  bottom: 0;
  left: 0;
}
.section-philosophy .txt_flow .txt_flow-content {
  display: flex;
  gap: 50px;
  white-space: nowrap;
  animation: txt_flow_anim 20s linear infinite;
  align-items: center;
}
.section-philosophy .txt_flow .txt_flow-content img {
  height: 115px;
}
@media screen and (max-width: 767px) {
  .section-philosophy .txt_flow .txt_flow-content img {
    height: 90px;
  }
}
@media screen and (min-width: 1281px) {
  .section-philosophy .txt_flow {
    width: 100%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  .section-philosophy .txt_flow {
    width: 120%;
  }
}
@media screen and (max-width: 767px) {
  .section-philosophy .txt_flow {
    width: 170%;
  }
}
@keyframes txt_flow_anim {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

.section-profile {
  padding-top: 130px;
  background-image: url(../img/about/profile-bg.webp);
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .section-profile {
    padding-top: 80px;
    background-image: url(../img/about/profile-bg-sp.webp);
  }
}
.section-profile .profile-flex {
  justify-content: space-between;
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .section-profile .profile-flex {
    margin-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .section-profile .profile-flex {
    flex-direction: column;
  }
}
.section-profile .profile-flex .img {
  width: 29.1666666667vw;
}
@media screen and (max-width: 767px) {
  .section-profile .profile-flex .img {
    width: 100%;
  }
}
.section-profile .profile-flex .txt_wrap {
  width: 41.6666666667vw;
  max-width: 600px;
}
@media screen and (max-width: 1280px) {
  .section-profile .profile-flex .txt_wrap {
    width: 60%;
  }
}
@media screen and (max-width: 767px) {
  .section-profile .profile-flex .txt_wrap {
    width: 100%;
    max-width: 100%;
  }
}
.section-profile .profile-flex .txt_wrap dl {
  display: flex;
  padding-top: 20px;
  padding-bottom: 20px;
  border-bottom: solid 1px #092d4c;
}
@media screen and (max-width: 767px) {
  .section-profile .profile-flex .txt_wrap dl {
    width: 100%;
    font-size: 14px;
  }
}
.section-profile .profile-flex .txt_wrap dl dt {
  width: 33.3333333333%;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .section-profile .profile-flex .txt_wrap dl dt {
    width: 130px;
  }
}
.section-profile .profile-flex .txt_wrap dl dd {
  width: 66.6666666667%;
}
@media screen and (max-width: 767px) {
  .section-profile .profile-flex .txt_wrap dl dd {
    width: 100%;
  }
}
.section-profile .profile-flex .txt_wrap dl dd span {
  display: block;
}
.section-profile .profile-flex .txt_wrap dl dd span:last-child {
  margin-top: 10px;
}
.section-profile .profile-flex .txt_wrap dl dd .indent {
  padding-left: 1em;
  text-indent: -1em;
}
.section-profile .profile-flex .txt_wrap dl dd .note {
  padding-left: 1em;
  margin-top: 10px;
}
.section-profile {
  /* --------------------------------------
  SEC_MAP
  -------------------------------------- */
}
.section-profile #sec_map {
  position: relative;
}
@media screen and (min-width: 1281px) {
  .section-profile #sec_map {
    padding: 140px 0;
  }
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  .section-profile #sec_map {
    padding: 100px 0;
  }
}
@media screen and (max-width: 767px) {
  .section-profile #sec_map {
    padding: 80px 0;
  }
}
.section-profile #map_wrap {
  width: 100%;
  height: 0;
  position: relative;
}
.section-profile #map_wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 768px) {
  .section-profile #map_wrap {
    padding-top: 400px;
  }
}
@media screen and (max-width: 767px) {
  .section-profile #map_wrap {
    padding-top: 200px;
  }
}

.section-history {
  background-image: url(../img/about/history-bg.webp);
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
  color: #ffffff;
  padding-top: 180px;
  padding-bottom: 240px;
}
@media screen and (max-width: 767px) {
  .section-history {
    background-image: url(../img/about/history-bg-sp.webp);
    padding-top: 80px;
    padding-bottom: 80px;
  }
}
.section-history::before {
  content: "";
  background-image: url(../img/about/history-cover.webp);
  background-size: 100%;
  background-repeat: no-repeat;
  display: block;
  position: absolute;
  top: -1px;
  left: 0;
  width: 100%;
  height: 9.0277777778vw;
}
@media screen and (max-width: 767px) {
  .section-history::before {
    background-image: url(../img/about/history-cover-sp.webp);
    width: 100%;
    height: 9.3333333333vw;
  }
}
.section-history .history-text {
  margin-top: 40px;
  margin-bottom: 60px;
  font-size: 16px;
  line-height: 1.8;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .section-history .history-text {
    font-size: 14px;
    text-align: left;
    margin-bottom: 40px;
  }
}
.section-history .history-wrap {
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-right: 0;
}
@media screen and (max-width: 1280px) {
  .section-history .history-wrap {
    margin: auto;
    transform: translateX(10%);
  }
}
.section-history dl {
  display: flex;
  line-height: 1.6;
  font-family: "NotoSerifJP-Medium";
}
.section-history dl dt {
  margin-right: 40px;
  position: relative;
  display: flex;
  align-items: center;
  font-weight: normal;
  width: 16.6666666667vw;
  padding-bottom: 30px;
  max-width: 240px;
}
@media screen and (max-width: 1280px) {
  .section-history dl dt {
    width: 180px;
    font-size: 12px;
    line-height: 1.6666666667;
    margin-right: 16px;
  }
}
@media screen and (max-width: 767px) {
  .section-history dl dt {
    width: 140px;
    min-width: 140px;
    align-items: flex-start;
  }
}
.section-history dl dt::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 10px;
  right: 10px;
  width: 1px;
  height: 100%;
  background-color: #00bff2;
}
.section-history dl dt span {
  display: inline-block;
  background-image: url(../img/about/history-list.webp);
  background-size: contain;
  background-repeat: no-repeat;
  width: 20px;
  aspect-ratio: 1;
  display: inline-block;
  margin-right: 0;
  margin-left: auto;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 1280px) {
  .section-history dl dt span {
    height: 20px;
  }
}
@media screen and (max-width: 1280px) {
  .section-history dl dd {
    width: 50%;
    font-size: 12px;
    line-height: 1.6666666667;
  }
}

#sec_csr {
  background: url(../../assets/img/index/co_bg_04.jpg) no-repeat top right;
  background-size: cover;
  position: relative;
  padding-bottom: 80px;
}
#sec_csr .txt_wrap {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 1281px) {
  #sec_csr .txt_wrap {
    padding-right: calc((100% - 1200px) / 2);
  }
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  #sec_csr .txt_wrap {
    padding-right: 20px;
  }
}
@media screen and (min-width: 768px) {
  #sec_csr .l_flex {
    justify-content: space-between;
    align-items: center;
  }
  #sec_csr .img {
    width: 45%;
  }
  #sec_csr .txt_wrap {
    padding-top: 30px;
    width: 45%;
  }
  #sec_csr .txt {
    margin-top: 30px;
  }
}
@media screen and (max-width: 767px) {
  #sec_csr .l_flex {
    display: block;
  }
  #sec_csr .txt_wrap {
    margin-top: 40px;
    width: 100%;
    padding: 0 20px 40px;
  }
  #sec_csr .txt {
    margin-top: 20px;
  }
  #sec_csr .img img {
    width: 100%;
    height: auto;
  }
}

.txt_flow {
  overflow: hidden;
  position: absolute;
  bottom: 0;
  left: 0;
}
.txt_flow .txt_flow-content {
  display: flex;
  gap: 50px;
  white-space: nowrap;
  animation: txt_flow_anim 20s linear infinite;
  align-items: center;
}
.txt_flow .txt_flow-content img {
  height: 177px;
}
@media screen and (max-width: 767px) {
  .txt_flow .txt_flow-content img {
    height: 133px;
  }
}
@media screen and (min-width: 1281px) {
  .txt_flow {
    width: 100%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  .txt_flow {
    width: 120%;
  }
}
@media screen and (max-width: 767px) {
  .txt_flow {
    width: 170%;
  }
}

@keyframes txt_flow_anim {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}/*# sourceMappingURL=about.css.map */