@charset "UTF-8";
/*-----------------------------
//local common
-----------------------------*/
.of img {
  -o-object-fit: cover;
  object-fit: cover;
  font-family: "object-fit: cover;";
  background-size: cover;
  background-position: center center;
  width: 100%;
  height: 100%;
}

/*-----------------------------
//local parts
-----------------------------*/
.headerArea {
  position: fixed;
  top: 0;
  left: 0;
}

.cont_tit .title {
  position: relative;
  padding-top: 6rem;
  padding-bottom: 3rem;
}
@media screen and (max-width: 640px) {
  .cont_tit .title {
    padding-top: 9.72vw;
    padding-bottom: 5.55vw;
  }
}
.cont_tit .title span {
  font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", 游明朝, "Yu Mincho",
    YuMincho, serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.7rem;
  letter-spacing: 0.18em;
  line-height: 1;
  color: #505050;
}
.os-android .cont_tit .title span {
  font-family: a-otf-ryumin-pr6n, serif;
  font-weight: 300 !important;
}
@media screen and (max-width: 640px) {
  .cont_tit .title span {
    font-size: 3.33vw;
  }
}
.cont_tit .title[data-txt]:before {
  content: attr(data-txt);
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  font-family: sofia-pro, sans-serif;
  font-weight: 300;
  font-style: normal;
  font-size: 4.2rem;
  letter-spacing: 0.04em;
  line-height: 1;
  color: #4a4645;
  text-wrap: nowrap;
  white-space: nowrap;
}
@media screen and (max-width: 640px) {
  .cont_tit .title[data-txt]:before {
    font-size: 6.66vw;
  }
}
.cont_tit .title:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: calc(50% - 2rem);
  display: block;
  width: 4rem;
  height: 1px;
  background-color: #505050;
}
.sec_tit .title {
  position: relative;
  padding-top: 5rem;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .sec_tit .title {
    padding-top: 8.33vw;
  }
}
.sec_tit .title span {
  position: relative;
  padding: 0 0.5rem;
  font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", 游明朝, "Yu Mincho",
    YuMincho, serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.6rem;
  letter-spacing: 0.13em;
  line-height: 1;
  color: #2d2d2d;
}
.os-android .sec_tit .title span {
  font-family: a-otf-ryumin-pr6n, serif;
  font-weight: 300 !important;
}
@media screen and (max-width: 640px) {
  .sec_tit .title span {
    font-size: 3.33vw;
    letter-spacing: 0.05em;
  }
}
.sec_tit .title span:before,
.sec_tit .title span:after {
  content: "";
  position: absolute;
  top: 50%;
  display: block;
  width: 3rem;
  height: 1px;
  background-color: #666;
}
@media screen and (max-width: 640px) {
  .sec_tit .title span:before,
  .sec_tit .title span:after {
    width: 2rem;
  }
}
.sec_tit .title span:before {
  left: -3rem;
}
@media screen and (max-width: 640px) {
  .sec_tit .title span:before {
    left: -2rem;
  }
}
.sec_tit .title span:after {
  right: -3rem;
}
@media screen and (max-width: 640px) {
  .sec_tit .title span:after {
    right: -2rem;
  }
}
.sec_tit .title[data-txt]:before {
  content: attr(data-txt);
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  font-family: sofia-pro, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 3.5rem;
  letter-spacing: 0.06em;
  line-height: 1;
  color: #4a4645;
}
@media screen and (max-width: 640px) {
  .sec_tit .title[data-txt]:before {
    font-size: 6.94vw;
    letter-spacing: 0.05em;
  }
}

/*-----------------------------
//local contents
-----------------------------*/
.-vanish {
  display: block;
  line-height: 0;
  height: 0;
  overflow: hidden;
}

.mod_link_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  max-width: 70.4rem;
  width: 100%;
  height: 10.2rem;
  margin: auto;
  margin-top: 5.5rem;
  background-color: rgba(255, 255, 255, 0.53);
}
@media screen and (max-width: 640px) {
  .mod_link_box {
    display: block;
    max-width: 100%;
    width: 68.75vw;
    height: auto;
    padding: 1.5rem 0;
  }
}
.mod_link_box > dt {
  width: 26.1rem;
  height: 4.8rem;
  line-height: 0;
  margin-right: 5rem;
}
@media screen and (max-width: 640px) {
  .mod_link_box > dt {
    width: 59.72vw;
    height: auto;
    margin: auto;
  }
}
.mod_link_box > dt img {
  width: 100%;
  height: auto;
}
.mod_link_box > dd {
  margin: 0;
}
.mod_link_box .more_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 25.3rem;
  height: 5.5rem;
  background-color: #a2cb65;
}
@media screen and (max-width: 640px) {
  .mod_link_box .more_btn {
    width: 59.72vw;
    height: 12.5vw;
    margin: auto;
    margin-top: 1rem;
  }
}
.mod_link_box .more_btn span {
  font-size: 1.6rem;
  letter-spacing: 0.04em;
  line-height: 1;
  color: #fff;
}
@media screen and (max-width: 640px) {
  .mod_link_box .more_btn span {
    font-size: 3.88vw;
  }
}

.support_wrap {
  position: relative;
  margin-top: 12rem;
  background-color: #fff;
}
@media screen and (max-width: 640px) {
  .support_wrap {
    margin-top: 5rem;
  }
}
.support_wrap .cont_tit {
  text-align: center;
  padding-top: 6.5rem;
}
@media screen and (max-width: 640px) {
  .support_wrap .cont_tit {
    padding-top: 3rem;
  }
}

.sec_intro {
  position: relative;
  display: block;
}
.sec_intro::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: 15vw;
  left: 0;
  background-color: #f0ede7;
  z-index: 0;
}
@media screen and (max-width: 640px) {
  .sec_intro {
    background-color: #f0ede7;
  }
  .sec_intro::after {
    position: static;
  }
}

.sec_intro > .in {
  max-width: 144rem;
  width: 100%;
  padding: 0 13rem;
  padding-bottom: 10rem;
  margin: auto;
  margin-top: 4.5rem;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 640px) {
  .sec_intro > .in {
    max-width: 100%;
    padding: 0;
    margin-top: 3rem;
  }
}
.sec_intro .mv {
  display: block;
  line-height: 0;
  margin: 0;

}
.sec_intro .mv img {
  width: 100%;
  /* height: auto; */
  display: block;
  margin: 0;
}


.sec_intro .catch {
  font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", 游明朝, "Yu Mincho",
    YuMincho, serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2.8rem;
  letter-spacing: 0.13em;
  line-height: 1.72;
  color: #666;
  text-align: center;
  margin-top: 8rem;
}
.os-android .sec_intro .catch {
  font-family: a-otf-ryumin-pr6n, serif;
  font-weight: 300 !important;
}
@media screen and (max-width: 640px) {
  .sec_intro .catch {
    font-size: 5.5vw;
    letter-spacing: 0.08em;
    line-height: 1.62;
    margin-top: 3.4rem;
  }
}
.sec_intro .read {
  font-size: 1.8rem;
  letter-spacing: 0.13em;
  line-height: 2.16;
  color: #666;
  text-align: center;
  margin-top: 4rem;
  font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", 游明朝, "Yu Mincho",
  YuMincho, serif;
}
@media print, screen and (min-width: 641px) {
  .sec_intro .read {
    font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", 游明朝, "Yu Mincho",
      YuMincho, serif;
    font-weight: 400;
    font-style: normal;
  }
  .os-android .sec_intro .read {
    font-family: a-otf-ryumin-pr6n, serif;
    font-weight: 300 !important;
  }
}
@media screen and (max-width: 640px) {
  .sec_intro .read {
    display: inline-block;
    margin: auto;
    margin-top: 1.5rem;
    font-size: 4.16vw;
    letter-spacing: 0.01em;
    line-height: 1.73;
    text-align: left;
    padding: 0 9.72vw;
  }
}

.sec_detail {
  background-color: #f0ede7;
}
@media screen and (max-width: 640px) {
  .sec_detail {
    padding-top: 19.4vw;
  }
}
.sec_detail > .in {
  position: relative;
  width: 100%;
  margin: auto;
  padding: 0 4rem;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media screen and (max-width: 640px) {
  .sec_detail > .in {
    padding: 0;
    margin-top: 0;
  }
}
.sec_detail
  [data-slidearea01][data-slidearea01-slidelimit]
  .slidearea01_link.dammy {
  opacity: 0;
}
@media print, screen and (min-width: 641px) {
  .sec_detail [data-slidearea01] {
    padding: 0;
    overflow: hidden;
  }
}
@media screen and (max-width: 640px) {
  .sec_detail [data-slidearea01] {
    margin: 0;
    padding: 0 4.17%;
  }
}
.sec_detail [data-slidearea01] .slidearea01_wrap {
  max-width: 1116px;
  width: 100%;
  margin: auto;
  position: relative;
}
.sec_detail [data-slidearea01] .slidearea01_btns {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  height: 58rem;
  width: 100%;
}
@media screen and (max-width: 640px) {
  .sec_detail [data-slidearea01] .slidearea01_btns {
    height: 61.11vw;
  }
}
.sec_detail [data-slidearea01] .slidearea01_btns button {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  z-index: 1;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
@media print, screen and (min-width: 641px) {
  .sec_detail [data-slidearea01] .slidearea01_btns button {
    width: 9rem;
    height: 9rem;
  }
}
@media screen and (max-width: 640px) {
  .sec_detail [data-slidearea01] .slidearea01_btns button {
    width: 3.5rem;
    height: 3.5rem;
  }
}
.sec_detail [data-slidearea01] .slidearea01_btns button:before,
.sec_detail [data-slidearea01] .slidearea01_btns button:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
@media print, screen and (min-width: 641px) {
  .sec_detail [data-slidearea01] .slidearea01_btns button:before {
    width: 4rem;
    height: 4rem;
    background-color: #fff;
  }
}
.sec_detail [data-slidearea01] .slidearea01_btns button:after {
  width: 1rem;
  height: 1rem;
  border: 2px solid #666;
}
@media screen and (max-width: 640px) {
  .sec_detail [data-slidearea01] .slidearea01_btns button:after {
    border-width: 1px;
  }
}
@media print, screen and (min-width: 641px) {
  .sec_detail [data-slidearea01] .slidearea01_btns button.next {
    right: 3rem;
  }
}
@media screen and (max-width: 640px) {
  .sec_detail [data-slidearea01] .slidearea01_btns button.next {
    right: -1.5rem;
  }
}
.sec_detail [data-slidearea01] .slidearea01_btns button.next:after {
  border-bottom: rgba(0, 0, 0, 0) !important;
  border-left: rgba(0, 0, 0, 0) !important;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  right: 3px;
}
@media print, screen and (min-width: 641px) {
  .sec_detail [data-slidearea01] .slidearea01_btns button.prev {
    left: 3rem;
  }
}
@media screen and (max-width: 640px) {
  .sec_detail [data-slidearea01] .slidearea01_btns button.prev {
    left: -1.5rem;
  }
}
.sec_detail [data-slidearea01] .slidearea01_btns button.prev:after {
  border-bottom: rgba(0, 0, 0, 0) !important;
  border-right: rgba(0, 0, 0, 0) !important;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  right: -3px;
}
.sec_detail [data-slidearea01] .slidearea01_btns button.disabled {
  pointer-events: none;
  opacity: 0.3;
}
.no-touchevents
  .sec_detail
  [data-slidearea01]
  .slidearea01_btns
  button:hover:before {
  background-color: #000;
}
.no-touchevents
  .sec_detail
  [data-slidearea01]
  .slidearea01_btns
  button:hover:after {
  border-color: #fff;
}
.sec_detail [data-slidearea01] .slidearea01_wrapin {
  padding: 0;
}
.sec_detail [data-slidearea01] .slidearea01_content {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.sec_detail [data-slidearea01] .slidearea01_content.disableTrs {
  -webkit-transition: none !important;
  transition: none !important;
}
.sec_detail [data-slidearea01] .slidearea01_link {
  display: block;
  position: relative;
  top: 0;
  left: 0;
  height: 100%;
}
.sec_detail [data-slidearea01] .slidearea01_link > .in {
  position: relative;
  margin: 0 2.8%;
}
@media screen and (max-width: 640px) {
  .sec_detail [data-slidearea01] .slidearea01_link > .in {
    margin: 0 1.5%;
  }
}
.sec_detail [data-slidearea01] .slidearea01_link > .in .ph {
  display: block;
  line-height: 0;
  width: 100%;
  height: 58rem;
}
@media screen and (max-width: 640px) {
  .sec_detail [data-slidearea01] .slidearea01_link > .in .ph {
    height: 61.11vw;
  }
}
.sec_detail [data-slidearea01] .slidearea01_link > .in .ph img {
  width: 100%;
  height: auto;
}
.sec_detail [data-slidearea01] .slidearea01_pager {
  text-align: center;
  margin-top: 3rem;
}
@media screen and (max-width: 640px) {
  .sec_detail [data-slidearea01] .slidearea01_pager {
    margin-top: 1rem;
  }
}
.sec_detail [data-slidearea01] .slidearea01_pager button {
  width: 3rem;
  height: 3rem;
  position: relative;
  display: inline-block;
  vertical-align: top;
}
.sec_detail [data-slidearea01] .slidearea01_pager button:after,
.sec_detail [data-slidearea01] .slidearea01_pager button:before {
  content: "";
  display: block;
  background-color: #fff;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  border-radius: 50%;
  width: 1rem;
  height: 1rem;
}
@media screen and (max-width: 640px) {
  .sec_detail [data-slidearea01] .slidearea01_pager button:after,
  .sec_detail [data-slidearea01] .slidearea01_pager button:before {
    background-color: #ccb89d;
  }
}
.sec_detail [data-slidearea01] .slidearea01_pager button:after {
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.no-touchevents
  .sec_detail
  [data-slidearea01]
  .slidearea01_pager
  button:hover:after,
.sec_detail [data-slidearea01] .slidearea01_pager button.active:after {
  background-color: #8e8066;
}
@media screen and (max-width: 640px) {
  .no-touchevents
    .sec_detail
    [data-slidearea01]
    .slidearea01_pager
    button:hover:after,
  .sec_detail [data-slidearea01] .slidearea01_pager button.active:after {
    background-color: #a6bc4a;
  }
}
.sec_detail [data-slidearea01] .slidearea01_pager button.active {
  cursor: default;
  pointer-events: none;
}
.sec_detail [data-slidearea01] .slidearea01_imgpager {
  margin-top: 3rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media screen and (max-width: 640px) {
  .sec_detail [data-slidearea01] .slidearea01_imgpager {
    display: none;
  }
}
.sec_detail [data-slidearea01] .slidearea01_imgpager_btn {
  position: relative;
  display: block;
  margin: 0 0.5rem;
  cursor: pointer;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
@media print, screen and (min-width: 641px) {
  .sec_detail [data-slidearea01] .slidearea01_imgpager_btn {
    width: 14.4rem;
    height: 9.6rem;
  }
}
@media screen and (max-width: 640px) {
  .sec_detail [data-slidearea01] .slidearea01_imgpager_btn {
    width: 30px;
    height: 30px;
  }
}
.sec_detail [data-slidearea01] .slidearea01_imgpager_btn:after {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border: 2px solid #aa8021;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  opacity: 0;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
@media print, screen and (min-width: 641px) {
  .sec_detail
    [data-slidearea01]
    .slidearea01_imgpager_btn
    + .photogallery01_btn {
    margin-left: 10px;
  }
}
@media screen and (max-width: 640px) {
  .sec_detail
    [data-slidearea01]
    .slidearea01_imgpager_btn
    + .photogallery01_btn {
    margin-left: 0;
  }
}
.sec_detail [data-slidearea01] .slidearea01_imgpager_btn img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.no-touchevents .sec_detail [data-slidearea01] .slidearea01_imgpager_btn:hover {
  opacity: 0.6;
}
.sec_detail [data-slidearea01] .slidearea01_imgpager_btn.active {
  cursor: default;
  pointer-events: none;
}
.sec_detail [data-slidearea01] .slidearea01_imgpager_btn.active:after {
  opacity: 1;
}

.section > .in {
  position: relative;
  width: 100%;
  max-width: 118rem;
  margin: auto;
  padding: 7rem 6rem;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border-top: 2px solid #af9967;
  background-color: #fff;
}
@media screen and (max-width: 640px) {
  .section > .in {
    padding: 3.8rem 4.86vw 6.94vw;
  }
}
@media screen and (max-width: 640px) {
  .section .txt_box {
    width: 100%;
    margin: 0;
    margin-top: 3.2rem;
    padding: 0 0.8rem;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
}
.section .txt_box .title {
  font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", 游明朝, "Yu Mincho",
    YuMincho, serif;
  font-weight: 500;
  font-style: normal;
  font-size: 2rem;
  letter-spacing: 0.06em;
  line-height: 1.7;
  color: #af9967;
}
.os-android .section .txt_box .title {
  font-family: a-otf-ryumin-pr6n, serif;
  font-weight: 300 !important;
}
@media screen and (max-width: 640px) {
  .section .txt_box .title {
    font-size: 4.72vw;
    letter-spacing: 0.08em;
    line-height: 1.64;
    grid-column: 1;
    grid-row: 1;
  }
}
.section .txt_box .-sub {
  display: block;
  font-family: sofia-pro, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  line-height: 1;
  color: #4a4645;
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 640px) {
  .section .txt_box .-sub {
    font-size: 4.44vw;
  }
}
.section .txt_box .txt {
  font-size: 1.5rem;
  letter-spacing: 0.08em;
  line-height: 1.73;
  color: #666;
  margin-top: 2.5rem;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ",
    Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}
@media screen and (min-width: 641px) and (max-width: 1240px) {
  .section .txt_box .title {
    font-size: 1.6rem;
  }
  .section .txt_box .txt {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 640px) {
  .section .txt_box .txt {
    font-size: 3.65vw;
    line-height: 1.64;
    letter-spacing: 0.1em;
    margin-top: 0.8rem;
    grid-column: 1;
    grid-row: 3;
  }
}
@media screen and (min-width: 641px) and (max-width: 1120px) {
  .section .txt_box .title {
    font-size: 1.6rem;
    white-space: nowrap;
  }
}
.section.-support .support_box {
  display: grid;
  grid-template-rows: 1fr auto;
  grid-template-columns: auto auto;
  width: 100%;
  margin: 6rem auto 0;
  row-gap: 18px;
  column-gap: 18px;
  max-width: 98rem;
  /* padding: 0 2.77vw; */
  /* padding: 0 4rem; */
}
@media screen and (min-width: 641px) and (max-width: 1120px) {
  .section.-support .support_box {
    column-gap: 3rem;
  }
}
@media screen and (max-width: 640px) {
  .section.-support .support_box {
    grid-template-rows: repeat(4, auto);
    grid-template-columns: 1fr;
    margin-top: 3.3rem;
    row-gap: 7vw;
    padding: 0;
  }
}
.section.-support .support_box .thumb {
  display: block;
  /* max-width: 35.97vw; */
  max-width: 51.8rem;
  width: 100%;
  line-height: 0;
  grid-column: 1;
  grid-row: 1;
  margin: auto;
  margin-left: 0;
}
@media screen and (min-width: 641px) and (max-width: 1240px) {
  .section.-support .support_box .thumb {
    max-width: 40vw;
  }
}
@media screen and (max-width: 640px) {
  .section.-support .support_box .thumb {
    width: calc(100% + 9.72vw);
    margin: 0 -4.86vw;
    height: auto;
    grid-row: 2;
  }
}
.section.-support .support_box .thumb img {
  width: 100%;
  height: auto;
}
.section.-support .support_box .txt_box {
  margin: auto;
  max-width: 39rem;
}
@media screen and (min-width: 641px) and (max-width: 1240px) {
  .section.-support .support_box .txt_box {
    max-width: 35vw;
  }
}
@media screen and (max-width: 640px) {
  .section.-support .support_box .txt_box {
    max-width: 100%;
    display: contents;
  }
}

.section.-support .support_box .txt_box .title {
  /* font-size: 1.38vw; */
  font-size: 2rem;
  letter-spacing: 0.01em;
}
@media screen and (min-width: 641px) and (max-width: 1240px) {
  .section.-support .support_box .txt_box .title {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 640px) {
  .section.-support .support_box .txt_box .title {
    font-size: 4.7vw;
    margin-left: 0;
    letter-spacing: 0.04em;
    text-align: center;
  }
}

@media screen and (max-width: 640px) {
  .section.-support .support_box .txt_box .txt {
    padding: 0 4.86vw;
  }
}

.section.-support .support_box .txt_box .txt .innerText {
  font-size: 1.4rem;
}
@media screen and (min-width: 641px) and (max-width: 1240px) {
  .section.-support .support_box .txt_box .txt .innerText {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 640px) {
  .section.-support .support_box .txt_box .txt .innerText {
    font-size: 1.2rem;
    letter-spacing: 0.05em;
  }
}
.section.-support .support_box .txt_box .txt .innerText:not(:last-of-type) {
  margin-bottom: 1.5rem;
}
@media screen and (min-width: 641px) and (max-width: 1240px) {
  .section.-support .support_box .txt_box .txt .innerText:not(:last-of-type) {
    margin-bottom: 0.5rem;
  }
}

.section.-support .support_box .txt_subBox {
  grid-row: 2;
  grid-column: 1 / 3;
}
@media screen and (max-width: 640px) {
  .section.-support .support_box .txt_subBox {
    grid-row: 4;
    grid-column: 1;
    background-color: rgba(240, 237, 231, 0.34);
    padding: 3.33vw 4.86vw;
  }
}
.section.-support .support_box .txt_subBox .title {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ",
    Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  font-size: 1.2rem;
  font-weight: 500;
  position: relative;
  padding-left: 2rem;
  color: #666;
  letter-spacing: 0.08em;
  line-height: 1.66;
}
.section.-support .support_box .txt_subBox .title:before {
  content: "";
  position: absolute;
  width: 1.8rem;
  height: 1px;
  background-color: #af9967;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 100;
}
@media screen and (max-width: 640px) {
  .section.-support .support_box .txt_subBox .title {
    padding-left: 2rem;
  }

  .section.-support .support_box .txt_subBox .title:before {
    width: 1.3rem;
  }
}

.section.-support .support_box .txt_subBox .txt {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ",
    Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  font-size: 1.2rem;
  letter-spacing: 0.08em;
  font-weight: 400;
  color: #666;
  line-height: 1.66;
}

.section.-support .support_innerBox {
  position: relative;
  max-width: 118rem;
  margin: auto;
  margin-top: 12.4rem;
  padding: 5rem 2.77vw 3.39vw;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox {
    max-width: 100%;
    width: 100%;
    height: auto;
    margin-top: 7rem;
    padding: 14.3vw 0 0;
  }
}
.section.-support .support_innerBox::before {
  /* content: none; */
  content: "";
  position: absolute;
  z-index: 0;
  border: 1px solid #beb08f;
}
.section.-support .support_innerBox:before {
  top: 0.5rem;
  bottom: 0.5rem;
  left: 0;
  right: 0;
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox:before {
    top: 0.5rem;
    bottom: -0.1rem;
    left: -0.1rem;
    right: -0.1rem;
  }
}
.section.-support .support_innerBox .title {
  position: absolute;
  z-index: 1;
  top: -1.6rem;
  left: 0;
  right: 0;
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .title {
    top: -1rem;
    width: 47.22vw;
    margin: 0 auto;
  }
  .section.-support .support_innerBox .title img {
    width: 100%;
    height: 100%;
  }
}
.section.-support .support_innerBox .col3 {
  max-width: 980px;
  margin: 0 auto 100px;
  padding: 40px 0;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .col3 {
    flex-direction: column;
    row-gap: 60px;
    padding: 0 4.86vw 14.7vw;
    margin: 0 auto;
  }
}
.section.-support .support_innerBox .col3 .col {
  width: calc(100% / 3 - 1.5rem);
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .col3 .col {
    width: 100%;
  }
}
.section.-support .support_innerBox .col3 .col .col_tit {
  position: relative;
  font-size: 1.5rem;
  letter-spacing: 0.07em;
  font-family: sofia-pro, sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1;
  color: #4a4645;
  text-wrap: nowrap;
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .col3 .col .col_tit {
    padding-bottom: 15px;
    margin-bottom: 25px;
  }

  .section.-support .support_innerBox .col3 .col .col_tit:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 5.55vw;
    height: 2px;
    background-color: #af9967;
  }
}

@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .col3 .col .sec_tit .title {
    position: static;
    padding: 0;
  }

  .section.-support
    .support_innerBox
    .col3
    .col
    .sec_tit
    .title[data-txt]:before {
    font-size: 4.44vw;
    letter-spacing: 0.07em;
    position: static;
  }
}
.section.-support .support_innerBox .col3 .col .ph {
  width: 100%;
  margin: 1.25vw 0 0;
  display: block;
}
.section.-support .support_innerBox .col3 .col .ph .img {
  width: 100%;
  height: auto;
  display: block;
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .col3 .col .ph {
    margin: 0 0 5.27vw;
  }
}
.section.-support .support_innerBox .catch {
  font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", 游明朝, "Yu Mincho",
    YuMincho, serif;
  font-weight: 700;
  font-style: normal;
  font-size: 1.7rem;
  letter-spacing: 0.06em;
  line-height: 1.7;
  color: #af9967;
  text-align: left;
  margin-top: 1.86vw;
  padding: 0 0.59vw;
}
.os-android .section.-support .support_innerBox .catch {
  font-family: a-otf-ryumin-pr6n, serif;
  font-weight: 300 !important;
}
@media screen and (min-width: 641px) and (max-width: 1120px) {
  .section.-support .support_innerBox .catch {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .catch {
    font-size: 4.44vw;
    letter-spacing: 0.1em;
    line-height: 1.8;
    text-align: center;
    padding: 0;
  }
}
.section.-support .support_innerBox .read {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ",
    Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.3rem;
  letter-spacing: 0.08em;
  line-height: 1.57;
  text-align: left;
  color: #666;
  margin-top: 2rem;
  padding: 0 0.59vw;
}
.os-android .section.-support .support_innerBox .read {
  font-family: a-otf-ryumin-pr6n, serif;
  font-weight: 300 !important;
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .read {
    font-size: 3.88vw;
    letter-spacing: 0.04em;
    line-height: 1.72;
    margin-top: 1.5rem;
    padding: 0;
  }
}

/* ------ 取り組み事例 ------- */
.section.-support .support_innerBox .case_box {
  max-width: 980px;
  width: 100%;
  margin: 0 auto;
  background-color: #f0ede7;
  box-sizing: border-box;
  padding: 4.2rem 4.5rem 3.8rem 6.6rem;
  display: grid;
  grid-template-columns: auto 24.4% 22.4%;
  grid-template-rows: auto;
  column-gap: 10px;
  position: relative;
}
.section.-support .support_innerBox .case_box::before {
  content: "";
  position: absolute;
  top: -8rem;
  left: 50%;
  transform: translateX(-50%);
  width: 1px;
  height: 48px;
  background-color: #8e8066;
}
@media screen and (min-width: 641px) and (max-width: 1120px) {
  .section.-support .support_innerBox .case_box {
    padding: 4.2rem 2rem 3.8rem 3rem;
  }
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .case_box {
    padding: 11.25vw 4.86vw 10.28vw;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: repeat(5, auto);
    column-gap: 10px;
  }
  .section.-support .support_innerBox .case_box::before {
    content: none;
  }
}
.section.-support .support_innerBox .case_box .ph_box {
  grid-column: 2;
  grid-row: 1;
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .case_box .ph_box {
    grid-column: 1;
    grid-row: 3;
  }
}
.section.-support .support_innerBox .case_box .ph_box .ph {
  width: 100%;
  height: auto;
  display: block;
  margin: 0;
}
.section.-support .support_innerBox .case_box .ph_box .ph .img {
  width: 100%;
  height: auto;
}
.section.-support .support_innerBox .case_box .col3 {
  width: 100%;
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
  justify-content: flex-end;
  margin: 0;
  padding: 0;
  grid-column: 3;
  grid-row: 1;
  row-gap: 7px;
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .case_box .col3 {
    grid-column: 1;
    grid-row: 5;
    flex-direction: row;
    column-gap: 10px;
  }
}
.section.-support .support_innerBox .case_box .col3 .ph .img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}
.section.-support .support_innerBox .case_box .txt_box {
  padding: 18px 0 0;
  text-align: left;
  grid-column: 1;
  grid-row: 1;
  margin-right: 10%;
  max-width: 35rem;
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .case_box .txt_box {
    display: contents;
  }
}
.section.-support .support_innerBox .case_box .txt_box .title {
  font-size: 1.2rem;
  font-weight: 500;
  position: relative;
  padding-left: 3rem;
  color: #666;
  top: 0;
  left: 0;
  line-height: 1;
}
.section.-support .support_innerBox .case_box .txt_box .title:before {
  content: "";
  position: absolute;
  width: 1.8rem;
  height: 1px;
  background-color: #af9967;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .case_box .txt_box .title {
    grid-column: 1;
    grid-row: 1;
    text-align: center;
    width: auto;
    padding: 0 2rem;
  }
  .section.-support .support_innerBox .case_box .txt_box .title:before {
    width: 15px;
  }
  .section.-support .support_innerBox .case_box .txt_box .title:after {
    content: "";
    position: absolute;
    width: 15px;
    height: 1px;
    background-color: #af9967;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }
}

.section.-support .support_innerBox .case_box .txt_box .catch {
  font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", 游明朝, "Yu Mincho",
    YuMincho, serif;
  font-weight: 700;
  font-style: normal;
  font-size: 1.8rem;
  letter-spacing: 0.012em;
  line-height: 1.8;
  color: #af9967;
  text-align: left;
  margin-top: 23px;
  margin-bottom: 18px;
  padding: 0;
}
@media screen and (min-width: 641px) and (max-width: 1120px) {
  .section.-support .support_innerBox .case_box .txt_box .catch {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .case_box .txt_box .catch {
    font-size: 4.72vw;
    letter-spacing: 0.05em;
    line-height: 1.74;
    grid-column: 1;
    grid-row: 2;
    text-align: center;
  }
}
.section.-support .support_innerBox .case_box .txt_box .txt {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ",
    Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  font-weight: 400;
  color: #666;
  margin-top: 0;
}
@media screen and (min-width: 641px) and (max-width: 1120px) {
  .section.-support .support_innerBox .case_box .txt_box .txt {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .case_box .txt_box .txt {
    grid-column: 1;
    grid-row: 4;
    font-size: 1.2rem;
    line-height: 1.73;
    padding: 7.36vw 2.08vw 8.47vw;
  }
}
.section.-support .support_innerBox .case_box .deco {
  position: absolute;
  bottom: -2rem;
  right: 1rem;
  width: 215px;
  height: 41px;
}
.section.-support .support_innerBox .deco img {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 640px) {
  .section.-support .support_innerBox .case_box .deco {
    right: 0;
    left: 4.86vw;
    bottom: -1.5rem;
  }
}

/* ------------ バナー -------------- */
.ud {
  padding-bottom: 6rem;
  max-width: 118rem;
  width: 100%;
  margin: 80px auto 0;
}
@media screen and (max-width: 640px) {
  .ud {
    margin: 0 auto;
    padding-top: 10vw;
    background-color: #fff;
  }
}

.ud .in {
  position: relative;
  display: block;
}

.ud .in .mv {
  display: block;
}
.ud .in .mv img {
  display: block;
}


/* ------------ ブライダルフェア毎⽇開催中 -------------- */
.mod_fair_box {
  background-color: #f0ede7;
  padding: 8rem 0;
  min-width: 1024px;
  font-size: 1.4rem;
  color: #666;
  letter-spacing: 0.1em;
  text-align: center;
  line-height: 1;
}
@media screen and (max-width: 640px) {
  .mod_fair_box {
    min-width: 0;
    padding: 5.55vw;
    margin-top: 0;
    font-size: 3.88vw;
    line-height: 1.9;
    text-align: left;
    background-color: #f7eee5;
  }
}
.mod_fair_box > .in {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  background-color: #fff;
  max-width: 1140px;
  margin: 0 auto;
  padding: 10px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media screen and (max-width: 640px) {
  .mod_fair_box > .in {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 0;
  }
}
.mod_fair_box .left_box {
  padding: 8px;
}
@media screen and (max-width: 640px) {
  .mod_fair_box .left_box {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    padding: 6.11vw 5.55vw 7.63vw;
  }
}
.mod_fair_box .left_box dt {
  width: 100%;
  height: 7.6rem;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .mod_fair_box .left_box dt {
    height: auto;
  }
}
.mod_fair_box .left_box dt img {
  width: auto;
  height: 100%;
}
@media screen and (max-width: 640px) {
  .mod_fair_box .left_box dt img {
    width: 100%;
    height: auto;
  }
}
.mod_fair_box .left_box dd p {
  margin-bottom: 26px;
  line-height: 1.8;
}
@media screen and (max-width: 640px) {
  .mod_fair_box .left_box dd p {
    margin-bottom: 1.5rem;
  }
}
.mod_fair_box .left_box dd a {
  display: block;
  background-color: #a6bc4a;
  max-width: 304px;
  margin: 0 auto;
  padding: 12px 0;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
@media screen and (max-width: 640px) {
  .mod_fair_box .left_box dd a {
    max-width: calc(100% - 1.5rem);
    text-align: center;
    padding: 2.22vw 0;
  }
  .mod_fair_box .left_box dd a img {
    width: auto;
    height: 2.77vw;
  }
}
.mod_fair_box .left_box dd a:hover {
  opacity: 0.6;
}
.mod_fair_box .ph {
  display: block;
  line-height: 0;
}
@media screen and (max-width: 640px) {
  .mod_fair_box .ph {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
  }
}
.mod_fair_box .ph img {
  width: 100%;
  height: auto;
}
