@media screen and (max-width: 767px) {
  .gnavWrap + #contents:not(.maxWidth) {
    padding-top: 50px !important; } }
.saSectionBorder {
  border: 6px solid #A6C683; }
  .saSectionBorder + .saSectionBorder {
    border-top: none; }
  .saSectionBorder .inner {
    padding: 5.15% 4.57%; }
  .saSectionBorder p + p {
    margin-top: 1.8em; }
  @media screen and (max-width: 767px) {
    .saSectionBorder {
      border: 4px solid #A6C683; }
      .saSectionBorder p + p {
        margin-top: 1.6em; } }

.saContainer {
  margin: 40px 0 0;
  position: relative; }

.saContainer::before {
  content: "";
  position: absolute;
  left: -5%;
  bottom: 20%;
  width: 110%;
  height: 54%;
  max-height: 421px;
  background-color: #DCEDC9; }

.saContainer .saInner {
  position: relative;
  margin: 30px auto 0;
  max-width: 800px; }

.saInner h2 {
  margin-bottom: 25px;
  text-align: center;
  line-height: 1.2;
  font-size: 2.4rem; }

.saModalList {
  margin-top: 20px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px 20px; }
  .saModalList button {
    padding: 0;
    border: none;
    background: none;
    transition: opacity 0.3s; }
    .saModalList button:hover {
      opacity: 0.75; }
  @media screen and (max-width: 767px) {
    .saModalList {
      margin-top: 7px;
      gap: 2px 6px; } }

#saModal button[data-izimodal-close] {
  position: fixed;
  z-index: 999;
  top: 0;
  right: 0;
  display: block;
  width: 58px !important;
  height: 58px;
  padding: 10px;
  border: none;
  background-color: transparent;
  outline: none;
  transition: all .5s;
  opacity: 1;
  background: #000 url(/shared/components/iziModal/icon_close.svg) 50% 50% no-repeat !important; }
  #saModal button[data-izimodal-close]:hover {
    opacity: .7; }
@media screen and (max-width: 767px) {
  #saModal {
    max-width: 100% !important; }
    #saModal button[data-izimodal-close] {
      position: absolute;
      top: 0;
      right: 3px;
      transform: scale(0.6);
      opacity: 1; } }

.saBtnWrap {
  display: flex;
  justify-content: center;
  margin: 60px 0 0; }

.saBtn {
  display: inline-block;
  padding: 8px 30px;
  border: #5d5d5d 1px solid;
  color: #333333;
  text-align: center;
  transition: all 0.5s; }

a .saBtn {
  text-decoration: none; }

.saBtn:hover {
  background-color: #333333;
  color: #FFFFFF;
  text-decoration: none; }

.saBtn.-wide {
  min-width: 400px; }
  @media screen and (max-width: 767px) {
    .saBtn.-wide {
      min-width: auto;
      width: auto; } }

.saAbout h2 {
  font-size: 2.4rem;
  text-align: center;
  color: #628D34; }

.saAbout h3 {
  font-size: 2.0rem;
  font-weight: bold;
  margin-top: 40px; }
  @media screen and (max-width: 767px) {
    .saAbout h3 {
      font-size: 1.6rem; } }

.saGallery .slide-media,
.saGallery .thumb-media {
  position: relative;
  overflow: hidden; }
.saGallery .slide-media img,
.saGallery .thumb-media img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover; }
.saGallery .swiper-button-next, .saGallery .swiper-button-prev {
  position: absolute;
  top: 50%;
  width: 120px;
  height: 80px;
  margin-top: -40px;
  z-index: 10;
  text-align: center;
  cursor: pointer;
  background: none;
  transform: translateY(-50%); }
  .saGallery .swiper-button-next::before, .saGallery .swiper-button-prev::before {
    content: '';
    position: absolute;
    right: 0;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 70px;
    height: 14px;
    border-bottom: 2px solid #fff;
    transition: all 0.3s; }
.saGallery .swiper-button-prev {
  left: 0;
  border-left: #fff 1px solid;
  border-bottom: #fff 1px solid; }
  .saGallery .swiper-button-prev::before {
    transform: skewX(-35deg);
    border-left: 2px solid #fff;
    transform-origin: center left; }
.saGallery .swiper-button-next {
  right: 0;
  border-right: #fff 1px solid;
  border-bottom: #fff 1px solid; }
  .saGallery .swiper-button-next::before {
    transform: skewX(35deg);
    border-right: 2px solid #fff;
    transform-origin: center right; }
@media screen and (max-width: 767px) {
  .saGallery .swiper-button-next, .saGallery .swiper-button-prev {
    position: fixed;
    top: auto;
    bottom: 0;
    width: 34px;
    height: 20px;
    margin-top: 0; }
    .saGallery .swiper-button-next::before, .saGallery .swiper-button-prev::before {
      width: 20px;
      height: 6px; }
  .saGallery .swiper-button-prev {
    left: 10px; }
  .saGallery .swiper-button-next {
    right: 10px; } }

.saGallery {
  overflow: hidden; }

.saGallery .swiper {
  max-width: 872px;
  margin: auto;
  padding: 0 180px; }
  @media screen and (max-width: 767px) {
    .saGallery .swiper {
      padding: 60px 10px 0; } }

.saGallery .thumb-wrapper {
  max-width: 590px;
  margin: auto; }
  @media screen and (max-width: 767px) {
    .saGallery .thumb-wrapper {
      padding: 0 10px 40px; } }

.saGallery .swiper {
  overflow: visible; }

.saGallery .swiper-fade .swiper-slide {
  -webkit-transition-property: opacity, -webkit-transform !important;
  transition-property: opacity, -webkit-transform !important;
  transition-property: opacity, transform !important;
  transition-property: opacity, transform, -webkit-transform !important;
  pointer-events: none; }

.saGallery .swiper-fade .swiper-slide-active {
  pointer-events: auto; }

.saGallery .swiper-controller {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding-top: 62.5%; }

.saGallery .slide {
  display: block;
  overflow: hidden; }

.saGallery .slide-media {
  display: block;
  padding-top: 100%; }

.saGallery .slide-media img {
  object-fit: contain; }

.saGallery .slide-title {
  margin: 15px 0 30px;
  line-height: 1.6;
  font-size: 1.8rem;
  color: #fff; }
  @media screen and (max-width: 767px) {
    .saGallery .slide-title {
      margin: 8px 0 15px;
      font-size: 1.4rem; } }

.saGallery .thumb-wrapper {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px; }
  @media screen and (max-width: 767px) {
    .saGallery .thumb-wrapper {
      gap: 5px; } }

.saGallery .thumb-media {
  padding-top: 100%;
  cursor: pointer; }
  .saGallery .thumb-media:hover {
    opacity: 0.8; }

.saGallery .thumb-media-active {
  opacity: 0.5; }
  .saGallery .thumb-media-active:hover {
    opacity: 0.5; }
