@charset "UTF-8";
@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
.about-outline {
  margin: 4.1666666667vw auto 0;
  width: 75vw;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 820px) {
  .about-outline {
    width: 83.3333333333vw;
  }
}
@media (max-width: 767px) {
  .about-outline {
    margin-top: 10.6666666667vw;
    width: 89.3333333333vw;
    display: block;
  }
}
.about-outline > .philosophy {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 3.75vw;
}
@media (max-width: 767px) {
  .about-outline > .philosophy {
    flex-direction: column-reverse;
    gap: 5.3333333333vw;
  }
}
.about-outline > .philosophy:before {
  content: "";
  display: block;
  width: 25.0694444444vw;
  aspect-ratio: 722/680;
  background-image: url(../../img/about/img_philosophy.webp);
  background-size: contain;
  background-position: 50% 50%;
  background-repeat: no-repeat;
}
@media (max-width: 767px) {
  .about-outline > .philosophy:before {
    width: 80%;
  }
}
.about-outline > .philosophy > .wrap {
  width: 36.5972222222vw;
}
@media (max-width: 767px) {
  .about-outline > .philosophy > .wrap {
    width: 100%;
  }
}
.about-outline > .philosophy > .wrap .ttl {
  font-weight: 700;
  font-size: clamp(32px * 0.8, 2.2222222222vw, 32px * 1.05);
  line-height: 1.4375;
  color: #009333;
  width: 34.8611111111vw;
  display: block;
}
@media (max-width: 767px) {
  .about-outline > .philosophy > .wrap .ttl {
    font-size: 5.8666666667vw;
    width: 100%;
  }
}
.about-outline > .philosophy > .wrap .desc {
  font-size: clamp(16px * 0.8, 1.1111111111vw, 16px * 1.05);
  line-height: 1.5;
  margin-top: 1.3888888889vw;
}
@media (max-width: 767px) {
  .about-outline > .philosophy > .wrap .desc {
    font-size: 3.7333333333vw;
    margin-top: 5.3333333333vw;
  }
}
.about-outline > .m-sub_ttl {
  margin-top: 4.1666666667vw;
}
@media (max-width: 767px) {
  .about-outline > .m-sub_ttl {
    margin-top: 16vw;
  }
}
.about-outline > .m-white_box > .desc_list > .group {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1.3888888889vw;
}
@media (max-width: 767px) {
  .about-outline > .m-white_box > .desc_list > .group {
    margin-top: 5.3333333333vw;
    flex-direction: column;
    gap: 1.6vw;
    justify-content: flex-start;
    align-items: flex-start;
    border-left: 0.2666666667vw solid #99CC33;
    padding-left: 3.2vw;
  }
}
.about-outline > .m-white_box > .desc_list > .group:first-of-type {
  margin-top: 0;
}
.about-outline > .m-white_box > .desc_list > .group > dt {
  width: clamp(150px * 0.8, 10.4166666667vw, 150px * 1.05);
  padding-right: clamp(30px * 0.8, 2.0833333333vw, 30px * 1.05);
  border-right: clamp(1px * 0.8, 0.0694444444vw, 1px * 1.05) solid #99CC33;
  font-weight: 700;
  font-size: clamp(18px * 0.8, 1.25vw, 18px * 1.05);
  line-height: 2;
  text-align: center;
  color: #006633;
}
@media (max-width: 767px) {
  .about-outline > .m-white_box > .desc_list > .group > dt {
    width: 100%;
    padding-right: 0;
    border-right: none;
    font-size: 3.7333333333vw;
    line-height: 1.5;
    text-align: left;
  }
}
.about-outline > .m-white_box > .desc_list > .group > dd {
  width: clamp(562px * 0.8, 39.0277777778vw, 562px * 1.05);
  padding-left: clamp(30px * 0.8, 2.0833333333vw, 30px * 1.05);
  font-size: clamp(18px * 0.8, 1.25vw, 18px * 1.05);
  line-height: 1.2222222222;
}
@media (max-width: 767px) {
  .about-outline > .m-white_box > .desc_list > .group > dd {
    width: 100%;
    padding-left: 0;
    font-size: 3.7333333333vw;
    box-sizing: border-box;
    line-height: 1.5;
  }
}
.about-outline > .m-white_box > .desc_list > .group > dd > a:not(.tel):not(.m-event_none) {
  text-decoration: underline;
}
.about-outline > .m-white_box > .desc_list > .group > dd > a:not(.tel):not(.m-event_none):hover {
  color: #006633;
}
@media (max-width: 767px) {
  .about-outline > .m-white_box > .desc_list > .group > dd > a:not(.tel):not(.m-event_none):hover {
    color: #2D2D2D;
  }
}
.about-outline > .m-white_box > .point_list {
  margin: 2.7777777778vw auto 0;
  width: fit-content;
}
@media (max-width: 767px) {
  .about-outline > .m-white_box > .point_list {
    margin-top: 8vw;
  }
}
.about-outline > .m-white_box > .point_list > li {
  font-size: clamp(18px * 0.8, 1.25vw, 18px * 1.05);
  line-height: 1.5;
  text-indent: -1em;
  padding-left: 1em;
}
@media (max-width: 767px) {
  .about-outline > .m-white_box > .point_list > li {
    font-size: 3.7333333333vw;
  }
}
.about-outline > .m-white_box > .point_list > li:before {
  content: "・";
}
.about-outline > .m-white_box > .point_list > li > a {
  text-decoration: underline;
}
.about-outline > .m-white_box > .point_list > li > a:hover {
  color: #006633;
}
@media (max-width: 767px) {
  .about-outline > .m-white_box > .point_list > li > a:hover {
    color: #2D2D2D;
  }
}
.about-outline > .m-white_box > .btn_wrap {
  display: flex;
  justify-content: center;
  gap: 2.0833333333vw;
  margin-top: 2.7777777778vw;
}
@media (max-width: 767px) {
  .about-outline > .m-white_box > .btn_wrap {
    flex-direction: column;
    align-items: center;
    margin-top: 8vw;
    gap: 3.2vw;
  }
}

.about-joint {
  margin: 6.9444444444vw auto 0;
  width: 75vw;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 820px) {
  .about-joint {
    width: 83.3333333333vw;
  }
}
@media (max-width: 767px) {
  .about-joint {
    margin-top: 21.3333333333vw;
    width: 89.3333333333vw;
    display: block;
  }
}
@media (max-width: 767px) {
  .about-joint > .m-white_box {
    padding-left: 3.2vw;
    padding-right: 3.2vw;
  }
}
.about-joint > .m-white_box > .txt {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 1.3888888889vw 2.7777777778vw;
}
@media (max-width: 767px) {
  .about-joint > .m-white_box > .txt {
    flex-direction: column;
    gap: 5.3333333333vw;
  }
}
.about-joint > .m-white_box > .txt > a {
  font-weight: 500;
  font-size: clamp(18px * 0.8, 1.25vw, 18px * 1.05);
  line-height: 1.5;
}
@media (max-width: 767px) {
  .about-joint > .m-white_box > .txt > a {
    font-size: 3.7333333333vw;
    letter-spacing: -0.05em;
  }
}
.about-joint > .m-white_box > .txt > a:after {
  content: "";
  display: inline-block;
  width: clamp(16px * 0.8, 1.1111111111vw, 16px * 1.05);
  aspect-ratio: 16/16;
  background-image: url(../../img/common/icn_open-black.svg);
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: contain;
  transition: 0.3s;
  margin-left: 0.6944444444vw;
}
@media (max-width: 767px) {
  .about-joint > .m-white_box > .txt > a:after {
    width: 3.2vw;
    margin-left: 1.0666666667vw;
  }
}
.about-joint > .m-white_box > .txt > a:hover {
  color: #009333;
}
@media (max-width: 767px) {
  .about-joint > .m-white_box > .txt > a:hover {
    color: #2D2D2D;
  }
}
.about-joint > .m-white_box > .txt > a:hover:after {
  background-image: url(../../img/common/icn_open-green.svg);
}
@media (max-width: 767px) {
  .about-joint > .m-white_box > .txt > a:hover:after {
    background-image: url(../../img/common/icn_open-black.svg);
  }
}

.about-gallery {
  margin: 8.3333333333vw auto 0;
  width: 75vw;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 820px) {
  .about-gallery {
    width: 83.3333333333vw;
  }
}
@media (max-width: 767px) {
  .about-gallery {
    margin-top: 21.3333333333vw;
    width: 89.3333333333vw;
    display: block;
  }
}
.about-gallery .slider {
  margin: 3.0555555556vw auto 0;
}
@media (max-width: 767px) {
  .about-gallery .slider {
    margin-top: 8vw;
  }
}
.about-gallery .slider .swiper-wrapper img {
  width: 52.7777777778vw;
  aspect-ratio: 760/477;
  object-fit: contain;
  margin-left: auto;
  margin-right: auto;
  display: block;
}
@media (max-width: 767px) {
  .about-gallery .slider .swiper-wrapper img {
    width: 100%;
  }
}
.about-gallery .slider-thumbnail {
  margin: 1.7361111111vw auto 0;
}
@media (max-width: 767px) {
  .about-gallery .slider-thumbnail {
    margin-top: 2.1333333333vw;
  }
}
.about-gallery .slider-thumbnail .swiper-wrapper {
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 1.3888888889vw;
}
@media (max-width: 767px) {
  .about-gallery .slider-thumbnail .swiper-wrapper {
    gap: 2.1333333333vw;
  }
}
.about-gallery .slider-thumbnail .swiper-slide {
  width: 13.6111111111vw !important;
  aspect-ratio: 760/477;
  cursor: pointer;
  transition: 0.3s;
}
@media (max-width: 767px) {
  .about-gallery .slider-thumbnail .swiper-slide {
    width: calc((100% - 4.2666666667vw) / 3) !important;
  }
}
.about-gallery .slider-thumbnail .swiper-slide:hover {
  opacity: 0.7;
}
@media (max-width: 767px) {
  .about-gallery .slider-thumbnail .swiper-slide:hover {
    opacity: 1;
  }
}
.about-gallery .slider-thumbnail .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.about-facility {
  margin: 8.3333333333vw auto 0;
  width: 75vw;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 820px) {
  .about-facility {
    width: 83.3333333333vw;
  }
}
@media (max-width: 767px) {
  .about-facility {
    margin-top: 21.3333333333vw;
    width: 89.3333333333vw;
    display: block;
  }
}
.about-facility > .list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 2.7777777778vw;
  margin-top: 2.7777777778vw;
}
@media (max-width: 767px) {
  .about-facility > .list {
    flex-direction: column;
    gap: 4.2666666667vw;
    margin-top: 8vw;
  }
}
.about-facility > .list > .group {
  background-color: #fff;
  border-radius: 0.6944444444vw;
  padding: 2.7777777778vw;
  width: calc((100% - 2.7777777778vw) / 2);
  box-sizing: border-box;
}
@media (max-width: 767px) {
  .about-facility > .list > .group {
    border-radius: 2.6666666667vw;
    padding: 5.3333333333vw;
    width: 100%;
  }
}
.about-facility > .list > .group > dt {
  color: #006633;
  font-weight: 700;
  font-size: clamp(20px * 0.8, 1.3888888889vw, 20px * 1.05);
  line-height: 1.45;
}
@media (max-width: 767px) {
  .about-facility > .list > .group > dt {
    font-size: 4.2666666667vw;
  }
}
.about-facility > .list > .group > dd {
  margin-top: 1.3888888889vw;
}
@media (max-width: 767px) {
  .about-facility > .list > .group > dd {
    margin-top: 3.2vw;
  }
}
.about-facility > .list > .group > dd > img {
  display: block;
  width: 100%;
}
.about-facility > .list > .group > dd > .txt {
  font-size: clamp(16px * 0.8, 1.1111111111vw, 16px * 1.05);
  line-height: 1.5;
  margin-top: 1.3888888889vw;
}
@media (max-width: 767px) {
  .about-facility > .list > .group > dd > .txt {
    font-size: 3.7333333333vw;
    margin-top: 3.2vw;
  }
}

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