@charset "UTF-8";
/*!
 * sakura-ec-2024 original css
 * Copyright 2024 ft-team
 */
@media screen and (max-width: 768px) {
  .only-pc {
    display: none !important;
  }
}

@media screen and (min-width: 769px) {
  .only-sp {
    display: none !important;
  }
}

/*!
 * sakura-ec-2024 original css
 * Copyright 2024 ft-team
 */
.header {
  width: 100%;
  position: fixed;
  top: 0;
  z-index: 10;
}
@media screen and (min-width: 769px) {
  .header {
    background-color: #fff;
    height: 13.79310345rem;
  }
}
@media screen and (max-width: 768px) {
  .header {
    background-color: #fff;
    height: 12.41666667rem;
  }
}
.header-wrapper {
  margin: auto;
  padding: 2em 2.5em;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .header-wrapper {
    padding: 0 2.25rem;
    height: 100%;
    align-items: center;
  }
}
@media screen and (min-width: 769px) {
  .header-wrapper {
    height: 100%;
    align-items: center;
    padding-top: 0;
    padding-bottom: 0;
  }
}
.header-wrapper .header-content:first-child {
  width: 18.1%;
}
@media screen and (max-width: 768px) {
  .header-wrapper .header-content:first-child {
    width: 61.7%;
  }
  .header-wrapper .header-content:first-child img {
    width: 100%;
  }
}
.header-wrapper .header-content:last-child {
  width: 61.5%;
}
@media screen and (max-width: 768px) {
  .header-wrapper .header-content:last-child {
    width: auto;
  }
}
.header-wrapper .header-content .header-content__body {
  display: flex;
  justify-content: space-around;
}
@media screen and (max-width: 768px) {
  .header-wrapper .header-content .header-content__body {
    justify-content: space-between;
  }
}
.header-wrapper .header-content .header-content__body .text-link-group {
  font-size: 3.24rem;
  letter-spacing: 0.16rem;
  flex: 0.66;
  display: flex;
  justify-content: space-around;
  align-items: center;
}
.header-wrapper .header-content .header-content__body .text-link-group .header-list-item {
  white-space: nowrap;
}
.header-wrapper .header-content .header-content__body .btn-group {
  flex: 0.34;
  display: flex;
  justify-content: space-around;
}

#js-menu {
  position: relative;
  width: 6.70833333rem;
  height: 6.70833333rem;
  cursor: pointer;
}
#js-menu span {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #666;
  border-radius: 4px;
}
#js-menu span:nth-of-type(1) {
  transform: translateY(calc(-50% - 1.8rem));
}
#js-menu span:nth-of-type(2) {
  transform: translateY(-50%);
}
#js-menu span:nth-of-type(3) {
  transform: translateY(calc(-50% + 1.8rem));
}
#js-menu.active span:nth-of-type(1) {
  transform: translateY(-50%) rotate(45deg);
}
#js-menu.active span:nth-of-type(2) {
  opacity: 0;
}
#js-menu.active span:nth-of-type(3) {
  transform: translateY(-50%) rotate(-45deg);
}

#js-menu, #js-menu span {
  display: inline-block;
  transition: all 0.5s;
  box-sizing: border-box;
}

.modals {
  display: none;
  position: fixed;
  z-index: 9;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  background-image: url("../img/menu_bg.png");
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 768px) {
  .modals {
    background-image: none;
    background-color: rgba(255, 255, 255, 0.9);
  }
}
.modals.active {
  display: block;
}
.modals__close {
  position: absolute;
  top: 2.6rem;
  right: 2.25rem;
  width: 6.70833333rem;
  height: 6.70833333rem;
  cursor: pointer;
  z-index: 1;
}
.modals__close span {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #666;
  border-radius: 4px;
}
.modals__close span:nth-of-type(1) {
  transform: translateY(-50%) rotate(45deg);
}
.modals__close span:nth-of-type(2) {
  transform: translateY(-50%) rotate(-45deg);
}
.modals .modals-wrapper {
  height: 100%;
  width: 100%;
}
.modals .modals-wrapper .modals-contents .modals-content {
  padding-top: 21.33333333rem;
  overflow-y: scroll;
}
.modals .modals-wrapper .modals-contents .modals-content .modals__body {
  font-size: 3.75rem;
  letter-spacing: 0.45rem;
  color: #383838;
  text-align: center;
}
.modals .modals-wrapper .modals-contents .modals-content .modals__body .modals-menu-item {
  margin-bottom: 9.41666667rem;
}
.modals .modals-wrapper .modals-contents .modals-content .modals__body .modals-menu-item a {
  color: #383838;
}
.modals .modals-wrapper .modals-contents .modals-content .modals__body .modals-menu-item:last-child {
  margin-bottom: 0;
}
.modals .modals-wrapper .modals-contents .modals-content .modals__footer {
  margin-top: 9.41666667rem;
}
.modals .modals-wrapper .modals-contents .modals-content .modals__footer .modals-menu-footer-item-list {
  width: 80%;
  margin: auto;
  display: flex;
  justify-content: space-around;
  align-items: center;
}
.modals .modals-wrapper .modals-contents .modals-content .modals__footer .modals-menu-footer-item {
  width: 44%;
}
.modals .modals-wrapper .modals-contents .modals-content .modals__bottom {
  margin-top: 9.41666667rem;
  padding: 0;
}
.modals .modals-wrapper .modals-contents .modals-content .modals__bottom .modals__bottom-insta {
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.33333333rem;
}
.modals .modals-wrapper .modals-contents .modals-content .modals__bottom .modals__bottom-insta img {
  width: 3.75rem;
}
.modals .modals-wrapper .modals-contents .modals-content .modals__bottom .modals__bottom-insta span {
  margin-left: 2.5rem;
  font-size: 3.33333rem;
}

.header-sub-nav {
  font-size: 1.6vw;
}
@media screen and (min-width: 769px) {
  .header-sub-nav {
    font-size: 0.45vw;
  }
}
@media screen and (min-width: 1920px) {
  .header-sub-nav {
    font-size: 8.7px;
  }
}
.header-sub-nav h1 {
  color: #383838;
}
.header-sub-nav img {
  width: 100%;
}
.header-sub-nav a {
  text-decoration: none;
  color: #383838;
}
.header-sub-nav a:hover {
  opacity: 0.6;
}
.header-sub-nav.only-sp {
  background-image: url("../img/sp/top_tori1.png"), url("../img/sp/top_leaf1.png"), url("../img/sp/top_leaf3.png"), url("../img/sp/top_leaf2.png");
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
  background-position: center 10%, right 2%, left 70%, 90% 63%;
  background-size: 10%, 23%, 23%, 23%;
}
.header-sub-nav.only-pc {
  background-image: url("../img/top_flower1.png"), url("../img/top_tori1.png"), url("../img/top_flower2.png");
  background-repeat: no-repeat, no-repeat, no-repeat;
  background-position: left 0 top 10%, right 24% top 8%, top 10% right 0%;
  background-size: 16%, 4%, 18%;
}
.header-sub-nav .header-sub-nav-wrapper {
  padding: 4em 0;
  width: 62%;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .header-sub-nav .header-sub-nav-wrapper {
    width: 72%;
    padding: 7em 0 0;
  }
}
.header-sub-nav .header-sub-nav__header {
  display: none;
}
@media screen and (min-width: 769px) {
  .header-sub-nav .header-sub-nav__header {
    display: block;
  }
}
.header-sub-nav .header-sub-nav__header .header-sub-nav__text {
  font-size: 4em;
  text-align: center;
  padding-bottom: 0.6em;
}
.header-sub-nav .header-sub-nav__body .sub-nav__list {
  padding-inline-start: 0px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.8em;
}
@media screen and (min-width: 769px) {
  .header-sub-nav .header-sub-nav__body .sub-nav__list {
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 0;
  }
}
.header-sub-nav .header-sub-nav__body .sub-nav__list .sub-nav__list__item {
  list-style: none;
  /* メニューアイテムのホバースタイル */
}
.header-sub-nav .header-sub-nav__body .sub-nav__list .sub-nav__list__item:hover .drop-menu-list {
  transform: scaleY(1) !important; /* ドロップダウンメニューの表示 */
}
.header-sub-nav .header-sub-nav__body .sub-nav__list {
  /* ドロップダウンメニュー */
}
.header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu {
  position: relative;
}
.header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list {
  font-size: 13px;
  padding: 10% 10% 25%;
  border-radius: 15px;
  background-color: #FBEADD;
  left: -44%;
  position: absolute;
  top: 115%;
  transform: scaleY(0); /* ドロップダウンメニューの非表示 */
  transform-origin: center top; /* 変形を適応する基準を設定 */
  transition: transform 0.3s; /* 表示の変化をアニメーション化 */
  width: 180%;
  z-index: 2;
}
.header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list:before {
  content: "";
  position: absolute;
  left: 45%;
  top: -20px;
  display: block;
  background: #EDCFBC;
  height: 20px;
  width: 35px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
}
@media screen and (min-width: 960px) {
  .header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list {
    font-size: 16px;
  }
}
@media screen and (min-width: 1280px) {
  .header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list {
    font-size: 20px;
  }
}
@media screen and (min-width: 1536px) {
  .header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list {
    font-size: 22px;
  }
}
@media screen and (min-width: 1920px) {
  .header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list {
    font-size: 24px;
  }
}
.header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list.__green {
  font-size: 13px;
  padding: 10% 10% 25%;
  border-radius: 15px;
  background-color: #F1F4CC;
  left: -44%;
  position: absolute;
  top: 115%;
  transform: scaleY(0); /* ドロップダウンメニューの非表示 */
  transform-origin: center top; /* 変形を適応する基準を設定 */
  transition: transform 0.3s; /* 表示の変化をアニメーション化 */
  width: 180%;
  z-index: 2;
}
.header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list.__green:before {
  content: "";
  position: absolute;
  left: 45%;
  top: -20px;
  display: block;
  background: #C0DC97;
  height: 20px;
  width: 35px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
}
@media screen and (min-width: 960px) {
  .header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list.__green {
    font-size: 16px;
  }
}
@media screen and (min-width: 1280px) {
  .header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list.__green {
    font-size: 20px;
  }
}
@media screen and (min-width: 1536px) {
  .header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list.__green {
    font-size: 22px;
  }
}
@media screen and (min-width: 1920px) {
  .header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list.__green {
    font-size: 24px;
  }
}
.header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list .drop-menu-item {
  border-bottom: dashed 1px #63654F;
  list-style: none;
  transition: opacity 0.3s; /* 不透明度の変化をアニメーション化 */
}
.header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list .drop-menu-item a {
  padding: 6% 0 4%;
  display: inline-block;
  display: flex;
  justify-content: space-between;
  position: relative;
}
.header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list .drop-menu-item a span {
  display: inline-block;
}
.header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list .drop-menu-item a span:first-child {
  margin-left: 8%;
}
.header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list .drop-menu-item a span:last-child {
  margin-right: 8%;
}
.header-sub-nav .header-sub-nav__body .sub-nav__list .drop-menu .drop-menu-list .drop-menu-item a img {
  position: absolute;
  right: 8%;
  top: 50%;
  width: 4%;
  transform: translateY(-50%);
}

@media screen and (max-width: 768px) {
  .--sp-sticky {
    position: sticky;
    top: 0;
    z-index: 1000;
  }
}

/*!
 * sakura-ec-2024 original css
 * Copyright 2024 ft-team
 */
.footer {
  background-color: #f3f3f3;
  color: #383838;
  padding: 4.6rem 5.75rem;
}
@media screen and (max-width: 768px) {
  .footer {
    padding: 4.2rem 5.75rem 5.3rem;
  }
}
.footer h1 {
  color: #383838;
}
.footer img {
  width: 100%;
}
.footer a {
  text-decoration: none;
  color: #383838;
}
.footer a:hover {
  opacity: 0.6;
}
.footer-contents {
  display: flex;
}
@media screen and (max-width: 768px) {
  .footer-contents {
    flex-direction: column;
  }
}
.footer-list {
  border-left: solid thin;
  padding: 0 0 15rem 5rem;
  font-size: 2.32rem;
  letter-spacing: 0.23rem;
}
@media screen and (max-width: 768px) {
  .footer-list {
    font-size: 2.09rem;
    border-left: none;
    padding: 3.6rem 0 0.6rem 1.9rem;
  }
}
.footer-list:first-child {
  border-left: none;
  flex: 0.18;
  padding-left: 0;
}
@media screen and (max-width: 768px) {
  .footer-list:first-child {
    padding: 0 0 3.25rem 0;
    flex: 0 1 auto;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
  }
}
.footer-list:first-child .footer-logo {
  width: 54%;
}
@media screen and (max-width: 768px) {
  .footer-list:first-child .footer-logo {
    width: 38%;
  }
}
.footer-list:first-child .footer-logo + .footer-logo {
  margin-top: 1.6rem;
}
@media screen and (max-width: 768px) {
  .footer-list:first-child .footer-logo + .footer-logo {
    margin-top: 0;
    margin-left: 6%;
  }
}
.footer-list:nth-child(2) {
  flex: 0.25;
  line-height: 4.59770115rem;
}
@media screen and (max-width: 768px) {
  .footer-list:nth-child(2) {
    flex: 0 1 auto;
    padding-left: 0;
    padding-top: 0;
    order: 1;
  }
}
.footer-list:nth-child(3) {
  flex: 0.57;
  font-size: 1.74rem;
  letter-spacing: 0.17rem;
  line-height: 3.44827586rem;
}
@media screen and (max-width: 768px) {
  .footer-list:nth-child(3) {
    order: 3;
    flex: 0 1 auto;
    border-top: 1px solid #ccc;
    padding: 3.6rem 0 0;
    font-size: 1.67rem;
    line-height: 3.25rem;
    color: #828282;
  }
}
.footer-list:nth-child(3) .item {
  color: #383838;
}
@media screen and (max-width: 768px) {
  .footer-list:nth-child(3) .item {
    color: #828282;
  }
}
@media screen and (max-width: 768px) {
  .footer-list:nth-child(4) {
    order: 2;
    padding: 2rem 0;
  }
}
.footer-list .insta {
  display: flex;
  margin-top: 4.26rem;
  align-items: center;
  line-height: normal;
}
@media screen and (max-width: 768px) {
  .footer-list .insta {
    font-size: 3.1rem;
    margin-top: 0;
    justify-content: flex-start;
  }
}
.footer-list .insta .logo {
  margin-right: 2.42rem;
}
@media screen and (max-width: 768px) {
  .footer-list .insta .logo {
    width: 5%;
    margin-right: 1rem;
  }
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-top {
  margin: 0 8%;
  background-color: #F3F4CE;
  padding: 2%;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-top .footer-top-wrapper .footer-top-contents .footer-top-content .footer-top-content__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-top .footer-top-wrapper .footer-top-contents .footer-top-content .footer-top-content__body li {
  list-style: none;
  padding: 5%;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-top .footer-top-wrapper .footer-top-contents .footer-top-content .footer-top-content__body li:first-child {
  padding: 5%;
  border-right: dashed 1px #63654F;
  border-bottom: dashed 1px #63654F;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-top .footer-top-wrapper .footer-top-contents .footer-top-content .footer-top-content__body li:nth-child(2) {
  padding: 5%;
  border-bottom: dashed 1px #63654F;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-top .footer-top-wrapper .footer-top-contents .footer-top-content .footer-top-content__body li:nth-child(3) {
  padding: 5%;
  border-right: dashed 1px #63654F;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-top .footer-top-wrapper .footer-top-contents .footer-top-content .footer-top-content__body li a {
  display: flex;
  align-items: center;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-top .footer-top-wrapper .footer-top-contents .footer-top-content .footer-top-content__body li a .footer-arrow-icon {
  width: 6%;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-top .footer-top-wrapper .footer-top-contents .footer-top-content .footer-top-content__body li a .footer-nav {
  font-weight: 600;
  display: flex;
  align-items: center;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-top .footer-top-wrapper .footer-top-contents .footer-top-content .footer-top-content__body li a .footer-nav div {
  margin-left: 2%;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-top .footer-top-wrapper .footer-top-contents .footer-top-content .footer-top-content__body li a .footer-nav .footer-nav-icon {
  width: 25%;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-top .footer-top-wrapper .footer-top-contents .footer-top-content .footer-top-content__body li a .footer-nav .footer-nav-text {
  font-size: 3.2vw;
  font-weight: 500;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid {
  margin: 8% 8%;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid .footer-mid-wrapper .footer-mid-contents .footer-mid-content .footer-mid-content__body {
  padding-inline-start: 0px;
  list-style: none;
  font-size: 2.6vw;
  border: dashed 1px #626262;
  border-radius: 5px;
  display: flex;
  flex-wrap: wrap;
  text-align: center;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid .footer-mid-wrapper .footer-mid-contents .footer-mid-content .footer-mid-content__body li {
  width: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid .footer-mid-wrapper .footer-mid-contents .footer-mid-content .footer-mid-content__body li:nth-child(odd) {
  border-bottom: dashed 1px #63654F;
  border-right: dashed 1px #63654F;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid .footer-mid-wrapper .footer-mid-contents .footer-mid-content .footer-mid-content__body li:nth-child(even) {
  border-bottom: dashed 1px #63654F;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid .footer-mid-wrapper .footer-mid-contents .footer-mid-content .footer-mid-content__body li:last-child {
  border-bottom: 0;
  border-right: dashed 1px #63654F;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid .footer-mid-wrapper .footer-mid-contents .footer-mid-content .footer-mid-content__body li a {
  display: block;
  padding: 10%;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid .footer-mid-wrapper .footer-mid-contents .footer-mid-content:last-child {
  padding: 2.5%;
  margin-top: 7%;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid .footer-mid-wrapper .footer-mid-contents .footer-mid-content .footer-mid-content__footer {
  font-size: 2.4vw;
  padding-inline-start: 0px;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid .footer-mid-wrapper .footer-mid-contents .footer-mid-content .footer-mid-content__footer .footer-mid-address {
  margin-bottom: 8%;
  font-size: 2.6vw;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid .footer-mid-wrapper .footer-mid-contents .footer-mid-content .footer-mid-content__footer .footer-mid-btn {
  /* 要素や大きさの設定 */
  display: block;
  width: 100%;
  margin: 0 auto;
  padding: 3.6% 0 4%;
  border-radius: 100vh;
  position: relative;
  /* テキストの設定 */
  color: #000;
  text-align: center;
  font-size: 4vw;
  /* 背景色の設定 */
  background-image: linear-gradient(to right, #F3F4CE 0%, #F3F4CE 100%);
  /* トランジションの設定 */
  transition-duration: 0.3s;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid .footer-mid-wrapper .footer-mid-contents .footer-mid-content .footer-mid-content__footer .footer-mid-btn img {
  position: absolute;
  right: 8%;
  top: 50%;
  width: 6%;
  transform: translateY(-50%);
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-bottom {
  margin-top: 7%;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-bottom .footer-bottom-back-img {
  position: relative;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-bottom .footer-bottom-back-img img:first-child {
  position: absolute;
  z-index: 2;
  width: 10%;
  right: 33%;
  top: 0%;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-bottom .footer-bottom-back-img img:last-child {
  position: absolute;
  z-index: 2;
  width: 30%;
  right: 0%;
  top: 0%;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-bottom .footer-bottom-wrapper .footer-bottom-contents .footer-bottom-content .footer-bottom-content__body {
  padding-top: 6%;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-bottom .footer-bottom-wrapper .footer-bottom-contents .footer-bottom-content .footer-bottom-content__body .swiper {
  width: 100%;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-bottom .footer-bottom-wrapper .footer-bottom-contents .footer-bottom-content .footer-bottom-content__body .footer-bottom-logo {
  width: 30%;
  margin: 3% auto;
}
@media screen and (min-width: 769px) {
  .footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-bottom .footer-bottom-wrapper .footer-bottom-contents .footer-bottom-content .footer-bottom-content__body .footer-bottom-logo {
    width: 20%;
    margin: 2% auto;
  }
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-items {
  margin: 0 7%;
}
@media screen and (min-width: 769px) {
  .footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-items {
    font-size: min(1.05vw, 20px);
  }
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-items .footer-items-wrapper .footer-items-contents {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1.2fr;
  gap: 1em;
}
@media screen and (min-width: 769px) {
  .footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-items .footer-items-wrapper .footer-items-contents {
    margin: 0 12%;
  }
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-items .footer-items-wrapper .footer-items-contents .footer-items-content ul {
  padding-inline-start: 0px;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-items .footer-items-wrapper .footer-items-contents .footer-items-content .footer-items-content__body li {
  list-style: none;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid-pc {
  margin: 4% 7% 0;
  background-color: #F7F0E6;
}
@media screen and (min-width: 769px) {
  .footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid-pc {
    font-size: min(1.05vw, 20px);
  }
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid-pc .footer-mid-pc-wrapper .footer-mid-pc-contents .footer-mid-pc-content .footer-mid-pc-content__body {
  padding: 2% 10%;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid-pc .footer-mid-pc-wrapper .footer-mid-pc-contents .footer-mid-pc-content .footer-mid-pc-content__body ul {
  padding-inline-start: 0px;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid-pc .footer-mid-pc-wrapper .footer-mid-pc-contents .footer-mid-pc-content .footer-mid-pc-content__body .footer-mid-list {
  display: flex;
}
.footer .footer-wrapper .footer-contents .footer-content .footer-content__body .footer-mid-pc .footer-mid-pc-wrapper .footer-mid-pc-contents .footer-mid-pc-content .footer-mid-pc-content__body .footer-mid-list li {
  list-style: none;
  margin: auto;
}
html {
  font-size: 0.45vw;
}
@media screen and (max-width: 768px) {
  html {
    font-size: 1.6vw;
  }
}
@media screen and (min-width: 1920px) {
  html {
    font-size: 8.7px;
  }
}

img {
  max-width: 100%;
}

h1 {
  color: #383838;
}

ul, ol {
  list-style: none;
  padding-inline-start: 0px;
}

a {
  text-decoration: none;
  color: #383838;
}
a:hover {
  opacity: 0.6;
}

/* Webフォントクラス/ */
/* Optima Nova */
.font-optima {
  font-family: optima-lt-pro, sans-serif;
  font-weight: 400;
  font-style: normal;
}

.font-tahoma {
  font-family: tahoma, sans-serif;
  font-weight: 400;
  font-style: normal;
}

/* noto sans cjk jp */
.font-noto-sans-L {
  font-family: noto-sans-cjk-jp, sans-serif;
  font-weight: 300;
  font-style: normal;
}

.font-noto-sans {
  font-family: noto-sans-cjk-jp, sans-serif;
  font-weight: 400;
  font-style: normal;
}

.font-noto-sans-M {
  font-family: noto-sans-cjk-jp, sans-serif;
  font-weight: 500;
  font-style: normal;
}

.font-noto-sans-B {
  font-family: noto-sans-cjk-jp, sans-serif;
  font-weight: 700;
  font-style: normal;
}

/* Shippori Mincho */
.font-shippori-mincho {
  font-family: shippori-mincho-b1, sans-serif;
  font-weight: 400;
  font-style: normal;
}

/* Futura PT */
.a-fade-in {
  opacity: 0;
  visibility: hidden;
}

.active .a-fade-in,
.active.a-fade-in {
  animation-name: fade-in-animation;
  animation-duration: var(--a-duration, 1s);
  animation-delay: var(--a-delay, 1s);
  animation-fill-mode: forwards;
  visibility: visible;
}

@keyframes fade-in-animation {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}