@charset "utf-8";
.footer {
  background-color: #407875;
}
.footer__bg {
  padding-top: 130px;
  padding-bottom: 155px;
  background: url("../imgs/common/footer_bg_img.png") center center / cover no-repeat;
}
.footer__wrap {
  width: calc(100% - 40px);
  max-width: 1235px;
  margin: 0 auto;
}
.footer__box {
  max-width: 1140px;
  margin: 0 auto 0 0;
  display: flex;
  justify-content: space-between;
}

/*--------------------------------
	footer__lft
--------------------------------*/
.footer__lft {
  width: 290px;
}
.footer__logo {
  width: 100%;
  max-width: 205px;
  display: block;
  margin-bottom: 40px;
}
.footer__title {
  font-size: 14px;
  margin-bottom: 8px;
  line-height: 1.75;
}
.footer__address {
  margin-bottom: 41px;
}
.footer__address p {
  font-size: 12px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 300;
  line-height: 1.375;
}
.footer__address p:not(:last-child) {
  margin-bottom: 18px;
}
img.footer__bnr {
  width: 122px;
  margin-bottom: 60px;
}
.footer__sns {
  width: 9px;
  padding-left: 10px;
}
.footer__snsText {
  font-size: 10px;
  font-family: "Libre Caslon Display", serif;
  font-weight: 400;
  margin-bottom: 20px;
  line-height: 1;
  letter-spacing: 0.063em;
}
.footer__snsList {
  width: 9px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 14px 20px;
}
.footer__snsItem.x {
  width: 9px;
}
.footer__snsItem.fb {
  width: 5px;
}
.footer__snsItem.insta {
  width: 9px;
}
.footer__snsItem.youtube {
  width: 9px;
}
/*--------------------------------
	footerNav
--------------------------------*/
.footerNav {
  width: calc(100% - 320px);
  max-width: 750px;
  padding-top: 52px;
}
.footerNav__column3 {
  display: grid;
  grid-template-columns: auto auto auto;
  gap: 0 12%;
}
.footerNav__column3.mgb {
  margin-bottom: 27px;
}
.footerNav__row {
  width: fit-content;
  flex: 1;
}
.footerNav__row.sp {
  display: none;
}
.footerNav__row:nth-child(3) {
  flex: initial;
}
.footerNav__rowItem1 {
  margin-bottom: 24px;
}
.footerNav__title {
  font-size: 16px;
  font-family: "Libre Caslon Display", serif;
  font-weight: 400;
  margin-bottom: 9px;
  pointer-events: none;
  line-height: 1.75;
  letter-spacing: 0.063em;
}
.footerNav__title.pointer--all {
  pointer-events: all;
}
.footerNav__item {
  font-size: 12px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 300;
  display: block;
  line-height: 1.75;
}
.footerNav__item--type02 {
  font-size: 16px;
  font-family: "Libre Caslon Display", serif;
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: 0.063em;
}
.footerNav__item--type03 {
  font-size: 14px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 300;
  line-height: 1.75;
}
.footerNav__item:not(:last-child) {
  margin-bottom: 9px;
}
.hover__line {
  position: relative;
  display: inline-block;
  text-decoration: none;
}

.footerNav__list.sml {
  display: flex;
  gap: 5px 12%;
  flex-wrap: wrap;
  padding-top: 70px;
}
.footerNav__list.sml .footerNav__item:not(:last-child) {
  margin-bottom: 0;
}

/*--------------------------------
	footerCopy
--------------------------------*/
footer .inner-1040 {
  max-width: 1040px;
  margin-left: auto;
  margin-right: auto;
}
#cp {
  color: #fff;
  font-size: 11px;
  font-family: "GaramondPremrPro-MedCapt";
  text-align: center;
  line-height: 1.75;
  letter-spacing: 0.1em;
}

.bg--green {
  background-color: #006934;
}
footer #gftr {
  width: 100%;
  max-width: 1200px;
  padding-top: 75px;
  padding-bottom: 55px;
}
footer #flogo {
  width: 13%;
  max-width: 145px;
  height: auto;
  margin: 0 auto 4.2%;
}
footer #flogo a {
  display: block;
}
footer #flogo img {
  width: 100%;
  height: auto;
}
footer #gftr ul {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 1015px;
  margin: 0 auto 20px;
}
footer #gftr ul li {
  width: 20%;
  max-width: 203px;
}
footer #gftr ul li a {
  display: block;
}
footer #gftr ul li img {
  width: 100%;
  height: auto;
}

@media screen and (max-width: 1000px) {
  .footer__box {
    display: block;
  }
  .footer__lft {
    width: 100%;
  }
  .footer__logo {
    margin: 0 auto 40px;
  }
  .footer__title,
  .footer__address p {
    text-align: center;
  }
  img.footer__bnr {
    margin: 0 auto 60px;
  }
  .footer__sns {
    width: 100%;
    max-width: 200px;
    padding-left: 0;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .footer__snsText {
    width: 90px;
    margin-bottom: 0;
  }
  .footer__snsText .vertical {
    writing-mode: horizontal-tb;
  }
  .footer__snsList {
    width: calc(100% - 90px);
    max-width: 100px;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 14px 0;
  }

  .footerNav {
    width: 100%;
    margin: 0 auto;
  }
}

@media screen and (max-width: 750px) {
  .footer__bg {
    padding-top: 63px;
    padding-bottom: 95px;
  }
  img.footer__bnr {
    margin: 0 auto 50px;
  }
  .footerNav__column3 {
    width: 100%;
    max-width: 460px;
    margin: 0 0 0 auto;
    grid-template-columns: auto auto;
    gap: 0 25px;
  }
  .footerNav {
    max-width: 530px;
  }
  .footerNav__column3--type02 {
    gap: 0 40px;
  }
  .footerNav__column3--type03 {
    gap: 0 77px;
    padding-top: 80px;
  }
  .footerNav__row.pc {
    display: none;
  }
  .footerNav__row.sp {
    display: block;
  }
  .footerNav__rowItem1,
  .footerNav__rowItem2 {
    width: fit-content;
  }
  .footerNav__list--other {
    width: 100%;
    max-width: 460px;
    margin: 0 0 0 auto;
  }
  .footerNav__list.sml {
    gap: 5px 30px;
    max-width: 392px;
    margin: 0 auto 0 0;
  }

  footer #gftr ul {
    justify-content: center;
    flex-wrap: wrap;
    margin: 0 auto;
  }
  footer #gftr ul li {
    width: calc(96% / 2);
    max-width: 235px;
    margin-bottom: 20px;
  }
  footer #gftr ul li:nth-child(3) {
    margin-right: 0;
  }
}
@media screen and (max-width: 480px) {
  footer #gftr #flogo {
    width: 100%;
    max-width: 57px;
    margin: 0 auto 20px;
  }
  footer #gftr ul {
    display: block;
    width: 100%;
    max-width: 203px;
    margin: 0 auto;
  }
  footer #gftr ul li {
    width: 100%;
    margin-right: 0;
  }
}
