@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400;500;600;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Marcellus&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700&display=swap");
/* ==================================
    HEADER
================================== */
.header {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
}

.header-inner {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: 25vw;
  height: 100%;
}

.header-logo {
  width: 298px;
  margin-left: auto;
  margin-right: auto;
}

.header-Instagram {
  margin-top: 60px;
  width: 180px;
  height: 44px;
  margin-left: auto;
  margin-right: auto;
}

.header-Instagram__button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  border-top: 1px solid #a8b7a7;
  border-bottom: 1px solid #a8b7a7;
}

.header-Instagram__button--text {
  display: inline-block;
  padding-left: 34px;
  background-image: url(../images/icon/insta_icon.svg);
  background-position: 0 center;
  background-repeat: no-repeat;
  background-size: 21px auto;
  font-family: "Marcellus", "游ゴシック", "Noto Sans JP", "メイリオ", "ヒラギノ角ゴ Pro W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", Arial, sans-serif;
  font-size: 1.7rem;
  line-height: 24px;
  letter-spacing: 0em;
  color: #557a53;
}

.top .header-contents {
  display: none;
}

.lower .header {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  padding-top: 25px;
}

.lower .header-inner {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: row;
  width: 100%;
  height: auto;
  padding-left: 50px;
  padding-right: 42px;
}

.lower .header-contents {
  display: flex;
  justify-content: flex-end;
  margin-left: auto;
}

.lower .header-contact {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.lower .header-contact__button {
  position: relative;
  padding-top: 26px;
  background-image: url(../images/icon/mail_icon02.svg);
  background-repeat: no-repeat;
  background-size: 32px auto;
  background-position: center top;
  z-index: 1000;
}

.lower .header-contact__button--text {
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.1;
  color: #242524;
}

.lower .header-logo {
  width: 199px;
  margin-right: auto;
  margin-left: 0;
}

.open .header-contents {
  position: fixed;
  top: 28px;
  right: 42px;
  z-index: 2000;
}

@media screen and (max-width: 1480px) {
  .header-inner {
    width: 25vw;
  }
  .header-logo {
    width: 20.13514vw;
  }
  .header-Instagram {
    margin-top: 4.05405vw;
    width: 180px;
    height: 44px;
  }
  .header-Instagram__button--text {
    padding-left: 34px;
    background-size: 21px auto;
    font-size: 1.7rem;
    line-height: 24px;
  }
  .lower .header {
    padding-top: 1.68919vw;
  }
  .lower .header-inner {
    padding-left: 3.37838vw;
    padding-right: 2.83784vw;
  }
  .lower .header-contact__button {
    padding-top: 26px;
    background-size: 32px auto;
  }
  .lower .header-contact__button--text {
    font-size: 1.2rem;
  }
  .lower .header-logo {
    width: 13.44595vw;
  }
  .open .header-contents {
    position: fixed;
    top: 1.89189vw;
    right: 2.83784vw;
    z-index: 2000;
  }
}

@media screen and (max-width: 1200px) {
  .header-inner {
    width: 25vw;
  }
  .header-logo {
    width: 20.13514vw;
  }
  .header-Instagram {
    margin-top: 4.05405vw;
    width: 15vw;
    height: 44px;
  }
  .header-Instagram__button--text {
    padding-left: 2.83333vw;
    background-size: 1.75vw auto;
    font-size: 1.5rem;
    line-height: 2vw;
  }
  .lower .header {
    padding-top: 2.08333vw;
  }
  .lower .header-inner {
    padding-left: 4.16667vw;
    padding-right: 3.5vw;
  }
  .lower .header-contact__button {
    padding-top: 26px;
    background-size: 32px auto;
  }
  .lower .header-contact__button--text {
    font-size: 1.2rem;
  }
  .lower .header-logo {
    width: 16.58333vw;
  }
  .open .header-contents {
    top: 2.33333vw;
    right: 3.5vw;
  }
}

@media screen and (max-width: 992px) {
  .lower .header {
    padding-top: 2.52016vw;
  }
  .lower .header-inner {
    padding-left: 5.04032vw;
    padding-right: 4.23387vw;
  }
  .lower .header-logo {
    width: 20.06048vw;
  }
  .open .header-contents {
    top: 2.82258vw;
    right: 4.23387vw;
  }
}

@media screen and (max-width: 768px) {
  .header {
    flex-direction: column;
    height: auto !important;
  }
  .header-inner {
    position: relative;
    width: 100%;
    height: 27.34375vw;
  }
  .header-logo {
    width: 52.21354vw;
  }
  .header-contents {
    display: block;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 5.20833vw;
  }
  .top .header-contents {
    display: block;
  }
  .lower .header {
    padding-top: 0;
  }
  .lower .header-inner {
    width: 100%;
    height: 27.34375vw;
    padding-left: 0;
    padding-right: 0;
    background-color: none !important;
  }
  .lower .header-contact {
    display: none;
  }
  .lower .header-logo {
    width: 52.21354vw;
    margin-left: auto;
    margin-right: auto;
  }
  .open .header-contents {
    position: fixed;
    top: 13.67188vw;
    right: 5.20833vw;
    z-index: 2000;
  }
}

/* ==================================
    FOOTER CONTACT
================================== */
.footer-contact {
  width: 100%;
  height: 250px;
  background-color: #d5d9d0;
}

.footer-contact__contents {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  background-image: url(../images/common/footer-contact/bg.png);
  background-position: 18.375vw 0;
  background-repeat: no-repeat;
  background-size: 167px auto;
}

.footer-contact__titleHeader {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding-right: 52px;
}

.footer-contact__titleHeader--english {
  font-family: "Marcellus", "游ゴシック", "Noto Sans JP", "メイリオ", "ヒラギノ角ゴ Pro W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", Arial, sans-serif;
  font-size: 3.5rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0px;
  color: #5c7a4e;
}

.footer-contact__titleHeader--text {
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 1.13px;
  color: #373837;
}

.footer-contact__wrapper {
  padding-top: 8px;
  padding-bottom: 8px;
  padding-left: 47px;
  border-left: 1px solid #abb1a5;
}

.footer-contact__wrapper .textArea__text {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.05em;
  color: #242524;
}

.footer-contact__box {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin-top: 15px;
}

.footer-contact__tel {
  padding-right: 28px;
}

.footer-contact__telText {
  font-family: "Lato", "游ゴシック", "Noto Sans JP", "メイリオ", "ヒラギノ角ゴ Pro W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", Arial, sans-serif;
  color: #577748;
}

.footer-contact__telText--text {
  padding-right: 14px;
  font-size: 1.9rem;
  letter-spacing: 0.57px;
}

.footer-contact__telText--number {
  font-size: 2.7rem;
  font-weight: normal;
  letter-spacing: 0.81px;
}

.footer-contact__businesstime {
  margin-top: 10px;
  font-size: 1.4rem;
  line-height: 1.2;
  letter-spacing: 0.05em;
  color: #373837;
}

.footer-contact__button--style {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  position: relative;
  width: 320px;
  height: 60px;
  padding-left: 30px;
  background-color: #6a845e;
}

.footer-contact__button--style::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 20px;
  width: 45px;
  height: 6px;
  margin: auto;
  background-image: url(../images/icon/arrow_icon.svg);
  background-position: 0 center;
  background-repeat: no-repeat;
  background-size: 46px auto;
  transition: 0.4s;
}

.footer-contact__button--style:hover::after {
  right: 16px;
}

.footer-contact__button--text {
  padding-left: 36px;
  background-image: url(../images/icon/mail_icon.svg);
  background-position: 0 center;
  background-repeat: no-repeat;
  background-size: 21px auto;
  font-family: "Lato", "游ゴシック", "Noto Sans JP", "メイリオ", "ヒラギノ角ゴ Pro W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", Arial, sans-serif;
  font-size: 1.5rem;
  line-height: 24px;
  letter-spacing: 0.9px;
  text-align: left;
  color: #ffffff;
}

@media screen and (max-width: 992px) {
  .footer-contact {
    width: 100%;
    height: auto;
  }
  .footer-contact__contents {
    flex-direction: column;
    height: 100%;
    padding-top: 10.08065vw;
    padding-bottom: 10.08065vw;
    background-image: url(../images/common/footer-contact/bg.png);
    background-position: 5.04032vw 0;
    background-repeat: no-repeat;
    background-size: 16.83468vw auto;
  }
  .footer-contact__titleHeader {
    padding-right: 0px;
    padding-bottom: 3.02419vw;
  }
  .footer-contact__titleHeader--english {
    font-family: "Marcellus", "游ゴシック", "Noto Sans JP", "メイリオ", "ヒラギノ角ゴ Pro W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", Arial, sans-serif;
    font-size: 3.5rem;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0px;
    color: #5c7a4e;
  }
  .footer-contact__titleHeader--text {
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 1.13px;
    color: #373837;
  }
  .footer-contact__wrapper {
    padding-top: 5.24194vw;
    padding-bottom: 0px;
    padding-left: 0px;
    border-left: none;
    border-top: 1px solid #abb1a5;
  }
  .footer-contact__wrapper .textArea__text {
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.4;
    letter-spacing: 0.05em;
    color: #242524;
  }
}

@media screen and (max-width: 768px) {
  .footer-contact__contents {
    height: 100%;
    padding-top: 13.02083vw;
    padding-bottom: 13.02083vw;
    padding-left: 6.51042vw;
    padding-right: 6.51042vw;
    background-position: 6.51042vw 0;
    background-size: 21.74479vw auto;
  }
  .footer-contact__titleHeader {
    padding-bottom: 3.90625vw;
  }
  .footer-contact__titleHeader--english {
    font-size: 7.8125vw;
  }
  .footer-contact__titleHeader--text {
    font-size: 3.90625vw;
  }
  .footer-contact__wrapper {
    padding-top: 6.77083vw;
  }
  .footer-contact__wrapper .textArea__text {
    text-align: center;
    font-size: 1.4rem;
    line-height: 1.8;
  }
  .footer-contact__wrapper .textArea__text span {
    display: inline-block;
  }
  .footer-contact__box {
    flex-direction: column;
    margin-top: 3.90625vw;
  }
  .footer-contact__tel {
    padding-right: 0px;
  }
  .footer-contact__telText {
    text-align: center;
  }
  .footer-contact__telText--text {
    padding-right: 14px;
    font-size: 3.64583vw;
  }
  .footer-contact__telText--number {
    font-size: 7.03125vw;
  }
  .footer-contact__telText--number a {
    color: #5c7a4e;
  }
  .footer-contact__businesstime {
    margin-top: 1.30208vw;
    font-size: 3.64583vw;
  }
  .footer-contact__button {
    margin-top: 6.51042vw;
  }
  .footer-contact__button--style {
    width: 67.70833vw;
    height: 13.02083vw;
    padding-left: 3.90625vw;
  }
  .footer-contact__button--style::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 5.20833vw;
    width: 11.71875vw;
    height: 1.82292vw;
    background-size: 100% auto;
    transition: 0.4s;
  }
  .footer-contact__button--style:hover::after {
    right: 16px;
  }
  .footer-contact__button--text {
    padding-left: 9.375vw;
    background-size: 5.46875vw auto;
    font-size: 3.90625vw;
    line-height: 1.6;
  }
}

/* ==================================
    FOOTER
================================== */
.footer {
  width: 100%;
  background-color: #ededea;
  padding-left: 90px;
  padding-right: 90px;
  padding-top: 20px;
  padding-bottom: 32px;
}

.footer-contents {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

.footer-about {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

.footer-about__logo {
  width: 108px;
  margin-right: 30px;
}

.footer-about__logo--link {
  display: block;
  width: 108px;
}

.footer-about__address {
  margin-right: 15px;
}

.footer-about__address--text {
  font-size: 14px;
  line-height: 1.2;
  letter-spacing: 0.05em;
  color: #242524;
}

.footer-about__mapButton {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: 100px;
  height: 24px;
  padding-left: 25px;
  background-image: url(../images/icon/map_icon.svg);
  background-position: 10px center;
  background-repeat: no-repeat;
  background-size: 9px auto;
  border: solid 1px #bbc0b9;
  font-family: "Lato", "游ゴシック", "Noto Sans JP", "メイリオ", "ヒラギノ角ゴ Pro W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", Arial, sans-serif;
  font-size: 1.2rem;
  font-weight: 300;
  line-height: 24px;
  letter-spacing: 0.6px;
  color: #335623;
}

.footer-copyright {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  margin-left: auto;
}

.footer-copyright__privacy {
  margin-right: 30px;
}

.footer-copyright__privacy--link {
  font-family: "Lato", "游ゴシック", "Noto Sans JP", "メイリオ", "ヒラギノ角ゴ Pro W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", Arial, sans-serif;
  font-size: 1.3rem;
  font-weight: 300;
  letter-spacing: 0.65px;
}

.footer-copyright__text {
  font-family: "Lato", "游ゴシック", "Noto Sans JP", "メイリオ", "ヒラギノ角ゴ Pro W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", Arial, sans-serif;
  font-size: 1.3rem;
  font-weight: 300;
  text-transform: uppercase;
}

.fixed-button {
  display: none;
}

@media screen and (max-width: 992px) {
  .footer {
    width: 100%;
    padding-left: 5.04032vw;
    padding-right: 5.04032vw;
    padding-top: 6.04839vw;
    padding-bottom: 5.04032vw;
  }
  .footer-contents {
    justify-content: center;
    align-items: center;
    flex-direction: column;
  }
  .footer-about {
    justify-content: center;
    align-items: center;
    flex-direction: column;
  }
  .footer-about__logo {
    width: 108px;
    margin-bottom: 20px;
    margin-right: 0px;
  }
  .footer-about__logo--link {
    width: 108px;
  }
  .footer-about__address {
    margin-right: 0px;
  }
  .footer-about__address--text {
    font-size: 1.4rem;
  }
  .footer-about__mapButton {
    width: 100px;
    height: 24px;
    margin-top: 25px;
    padding-left: 25px;
    font-size: 1.2rem;
  }
  .footer-copyright {
    flex-direction: column;
    margin-left: auto;
    margin-right: auto;
    margin-top: 5.04032vw;
  }
  .footer-copyright__privacy {
    margin-right: 0px;
  }
  .footer-copyright__privacy--link {
    font-size: 1.3rem;
  }
  .footer-copyright__text {
    margin-top: 1.30208vw;
    font-size: 1.3rem;
  }
}

@media screen and (max-width: 768px) {
  .footer {
    width: 100%;
    padding-left: 6.51042vw;
    padding-right: 6.51042vw;
    padding-top: 10.41667vw;
    padding-bottom: 23.4375vw;
  }
  .footer-about__logo {
    width: 41.40625vw;
    margin-bottom: 5.20833vw;
    margin-right: 0px;
  }
  .footer-about__logo--link {
    width: 100%;
  }
  .footer-about__address {
    margin-right: 0px;
  }
  .footer-about__address--text {
    font-size: 3.64583vw;
  }
  .footer-about__mapButton {
    margin-top: 3.25521vw;
  }
  .footer-copyright {
    margin-top: 6.51042vw;
  }
  .footer-copyright__privacy--link {
    font-size: 3.38542vw;
  }
  .footer-copyright__text {
    margin-top: 2.60417vw;
    font-size: 3.38542vw;
  }
  .fixed-button {
    display: flex;
    justify-content: flex-start;
    width: 100%;
    height: 20.18229vw;
    padding-top: 3.25521vw;
    padding-bottom: 3.125vw;
    padding-left: 3.90625vw;
    padding-right: 3.90625vw;
    background-color: rgba(36, 37, 36, 0.8);
    z-index: 50;
  }
  .fixed-button__style {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    width: 29.16667vw;
    height: 13.80208vw;
    margin-right: 2.60417vw;
    padding-bottom: 2.34375vw;
    background-color: #6a845e;
    font-size: 3.25521vw;
    font-weight: 500;
    line-height: 1.1;
    text-align: center;
    color: #ffffff;
  }
  .fixed-button__style:last-of-type {
    margin-right: 0px;
  }
  .fixed-button__style--box01 {
    background-image: url(../images/icon/tel_icon.svg);
    background-repeat: no-repeat;
    background-position: center 1.95312vw;
    background-size: 3.38542vw auto;
  }
  .fixed-button__style--box02 {
    background-image: url(../images/icon/mail_icon.svg);
    background-repeat: no-repeat;
    background-position: center 2.60417vw;
    background-size: 5.20833vw auto;
  }
  .fixed-button__style--box03 {
    background-image: url(../images/icon/map_icon_w.svg);
    background-repeat: no-repeat;
    background-position: center 1.69271vw;
    background-size: 3.64583vw auto;
  }
}

/* ==================================
    GLOBALNAV
================================== */
.globalnav {
  margin-top: -15px;
  padding-top: 70px;
}

.globalnav-list {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  text-align: center;
}

.globalnav-list__item {
  margin-top: 15px;
}

.globalnav-list__item--link {
  position: relative;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: 0.54px;
  color: #494949;
}

.globalnav-list__item--link::after {
  content: "";
  display: block;
  position: absolute;
  top: 105%;
  left: 0px;
  width: 100%;
  height: 1px;
  background-color: #a8b7a7;
  transform: scale(0, 1);
  transform-origin: right top;
  transition: transform .3s;
}

.globalnav-list__item--link:hover {
  opacity: 1;
}

.globalnav-list__item--link:hover::after {
  transform-origin: left top;
  transform: scale(1, 1);
}

@media screen and (max-width: 1480px) {
  .globalnav {
    margin-top: -1.01351vw;
    padding-top: 4.72973vw;
  }
  .globalnav-list__item {
    margin-top: 1.01351vw;
  }
  .globalnav-list__item--link {
    position: relative;
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 992px) {
  .globalnav-list__item--link {
    font-size: 1.6129vw;
  }
}

@media screen and (max-width: 768px) {
  .globalnav {
    display: none;
  }
}


/*======================================

	PCの時だけ改行

=======================================*/
@media screen and (max-width: 780px) {
    .br-pc { display: none; }
}

/*======================================

	スマホの時だけ改行

=======================================*/
.br-sp {
    display:none;
}

@media screen and (max-width: 780px) {
    .br-sp { display: block; }
}