@charset "UTF-8";
/* ==================================================
 * Color set
 * ================================================== */
/* ==================================================
 * Font
 * ================================================== */
/* ==================================================
 * width
 * ================================================== */
/* ==================================================
 * layout
 * ================================================== */
/* ==================================================
 * bg
 * ================================================== */
/* ==================================================
 * font text
 * ================================================== */
/* ==================================================
 * other
 * ================================================== */
.btn-01__link {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-weight: 400;
  border-radius: 50rem;
  background: url("/img/common/btn-bg.png") left bottom no-repeat;
  background-color: #226750;
  color: #fff;
  overflow: hidden;
}
.btn-01__link:hover {
  color: rgba(255, 255, 255, 0.8);
}

.com-dot-top, .com-dot-btm {
  width: 100%;
  display: flex;
  justify-content: space-between;
  position: absolute;
  left: 0;
  z-index: -1;
}
.com-dot-top::before, .com-dot-top::after, .com-dot-btm::before, .com-dot-btm::after {
  content: "";
  display: block;
  width: 8px;
  aspect-ratio: 1/1;
  border-radius: 50rem;
  background: #226750;
}
.com-dot-top {
  top: 0;
  transform: translateY(-50%);
}
.com-dot-btm {
  bottom: 0;
  transform: translateY(50%);
}

.arw-solid-wht {
  position: relative;
  z-index: 1;
}
.arw-solid-wht::after {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  transition: 0.3s;
  width: 8px;
  aspect-ratio: 8/17;
  background-image: url("/img/common/arrow-solid-wht.png");
  background-size: 100%;
  top: 50%;
  right: 30px;
  transform: translate(0, -50%);
  transition: 0.3s;
}
.arw-solid-wht:hover::after {
  transform: translate(-1px, -50%);
}

.deco-line-top {
  display: flex;
  flex-direction: column;
  row-gap: 20px;
}
.deco-line-top::before {
  content: "";
  display: block;
  width: 1px;
  height: 30px;
  background: #3d3019;
  margin: 0 auto;
}

.deco-bf, .deco-af,
.obj-bf,
.obj-af,
.bg-bf,
.bg-af {
  position: relative;
  z-index: 1;
}
.deco-bf::before, .deco-af::after,
.obj-bf::before,
.obj-af::after,
.bg-bf::before,
.bg-af::after {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  transition: 0.3s;
}

.tbl {
  width: 100%;
}
.tbl td {
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}
.tbl-01 dl {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
.tbl-01 dt, .tbl-01 dd {
  padding: 15px;
}
.tbl-01 dt {
  width: 200px;
  max-width: 100%;
  border-top: solid 1px #226750;
}
.tbl-01 dd {
  width: 860px;
  max-width: 100%;
  border-top: solid 1px rgba(61, 48, 25, 0.3);
  font-weight: 400;
}

.com-layout {
  display: flex;
}
.com-tel .tel {
  font-family: "Courgette", cursive;
  letter-spacing: 0;
  line-height: 1;
}
.com-contents {
  display: flex;
  flex-direction: column;
}
.com-box-shadow {
  box-shadow: 10.285px 12.257px 49.47px 1.53px rgba(61, 48, 25, 0.24);
}

.layout-clm-2 {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}
.layout-clm-2 .list-item,
.layout-clm-2 .layout-item {
  width: calc((100% - 40px) / 2);
}
.layout-clm-2-c {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 40px;
}
.layout-clm-2-c .list-item,
.layout-clm-2-c .layout-item {
  width: calc((100% - 40px) / 2);
}
.layout-clm-3 {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}
.layout-clm-3 .list-item,
.layout-clm-3 .layout-item {
  width: calc((100% - 80px) / 3);
}
.layout-clm-3-c {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 40px;
}
.layout-clm-3-c .list-item,
.layout-clm-3-c .layout-item {
  width: calc((100% - 80px) / 3);
}
.layout-clm-4 {
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
}
.layout-clm-4 .list-item,
.layout-clm-4 .layout-item {
  width: calc((100% - 96px) / 4);
}
.layout-clm-4-c {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 32px;
}
.layout-clm-4-c .list-item,
.layout-clm-4-c .layout-item {
  width: calc((100% - 96px) / 4);
}

.list-blog .list-item, .list-news .list-item, .list-privacy .list-item, .list-info .list-item, .list-commitment .list-item, .list-menu .list-item, .list-price .list-item, .list-faq .list-item, .list-voice .list-item {
  width: 100%;
}
.list-news__bx {
  display: flex;
  align-items: center;
  -moz-column-gap: 20px;
       column-gap: 20px;
}
.list-news time {
  font-family: "Courgette", cursive;
  letter-spacing: 0;
  display: block;
  color: #226750;
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .list-news time {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-news time {
    font-size: 20px;
  }
}
.list-news__item {
  padding: 15px 20px;
  border-bottom: solid 1px rgba(61, 48, 25, 0.3);
}
.list-news__item:first-child {
  padding-top: 0 !important;
}
.list-news__link {
  display: flex;
  flex-direction: column;
  row-gap: 5px;
}
.list-news__ttl {
  width: 100%;
  overflow-wrap: break-word;
  word-break: break-all;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  text-align: left;
}
.list-banner__item {
  width: 350px;
  max-width: 100%;
  aspect-ratio: 350/180;
}
.list-banner__link {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 0 30px;
  position: relative;
  z-index: 1;
}
.list-banner__link:before {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  transition: 0.3s;
  width: 354px;
  aspect-ratio: 354/184;
  background: url("/img/top/banner-frame.png") center center no-repeat;
  background-size: cover;
  right: 12px;
  bottom: 12px;
}
.list-banner__link:after {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  transition: 0.3s;
  width: 40px;
  aspect-ratio: 1/1;
  background-image: url("/img/common/arrow-circle-grn.png");
  background-size: 100%;
  top: 50%;
  right: 40px;
  transform: translate(0, -50%);
}
.list-banner__link:hover::before {
  transform: translate(12px, 12px);
}
.list-banner__link:hover::after {
  transform: translate(-2px, -50%);
}
.list-banner .menu {
  background: url("/img/top/banner-img-menu.jpg") center center no-repeat;
  background-size: cover;
}
.list-banner .faq {
  background: url("/img/top/banner-img-faq.jpg") center center no-repeat;
  background-size: cover;
}
.list-banner .voice {
  background: url("/img/top/banner-img-voice.jpg") center center no-repeat;
  background-size: cover;
}
.list-banner .ttl-main {
  row-gap: 5px;
  margin-bottom: 0 !important;
}
.list-banner .ttl-main .en {
  font-size: 40px;
  font-size: 4rem;
}
@media screen and (max-width: 768px) {
  .list-banner .ttl-main .en {
    font-size: 50px;
    font-size: 6.5104166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-banner .ttl-main .en {
    font-size: 33.3333333333px;
  }
}
.list-banner .ttl-main .jp {
  color: #226750;
  font-size: 18px;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .list-banner .ttl-main .jp {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-banner .ttl-main .jp {
    font-size: 18.6666666667px;
  }
}
.list-info__item {
  padding: 15px 0;
  border-bottom: solid 1px rgba(61, 48, 25, 0.3);
}
.list-info__item:first-child {
  padding-top: 0 !important;
}
.list-commitment__item {
  border: solid 1px #3d3019;
  padding: 60px 100px;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}
.list-commitment__item::before, .list-commitment__item::after {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  transition: 0.3s;
  width: calc(100% - 100px);
  height: 1px;
  background: url("/img/common/pattern-bg.jpg");
  left: 50%;
  z-index: 1;
}
.list-commitment__item::before {
  top: 0;
  transform: translate(-50%, -1px);
}
.list-commitment__item::after {
  bottom: 0;
  transform: translate(-50%, 1px);
}
.list-commitment .ttl-02 {
  display: flex;
  align-items: center;
  -moz-column-gap: 15px;
       column-gap: 15px;
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .list-commitment .ttl-02 {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-commitment .ttl-02 {
    font-size: 22.6666666667px;
  }
}
.list-commitment .ttl-02 .num {
  font-family: "Courgette", cursive;
  letter-spacing: 0;
  color: #226750;
  font-weight: 400;
  font-size: 36px;
  font-size: 3.6rem;
}
@media screen and (max-width: 768px) {
  .list-commitment .ttl-02 .num {
    font-size: 46px;
    font-size: 5.9895833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-commitment .ttl-02 .num {
    font-size: 30.6666666667px;
  }
}
.list-commitment .txtbx {
  width: 670px;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  row-gap: 30px;
}
.list-menu__item {
  display: flex;
  flex-direction: column;
  row-gap: 40px;
}
.list-menu__ttl {
  font-family: "Shippori Mincho", serif;
  font-weight: 700;
  font-weight: 700;
  text-align: center;
  border-top: solid 1px #226750;
  border-bottom: solid 1px #226750;
  padding: 15px 0;
  display: flex;
  flex-direction: column;
  row-gap: 10px;
  position: relative;
  z-index: 1;
}
.list-menu__ttl h4 {
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .list-menu__ttl h4 {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-menu__ttl h4 {
    font-size: 22.6666666667px;
  }
}
.list-menu .com-layout {
  justify-content: center;
  align-items: flex-start;
  -moz-column-gap: 40px;
       column-gap: 40px;
}
.list-menu .img {
  width: 260px;
  min-width: 260px;
  aspect-ratio: 260/190;
  overflow: hidden;
}
.list-menu .txtbx {
  width: 100%;
  display: flex;
  flex-direction: column;
  row-gap: 15px;
}
.list-menu .ttl-03 {
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .list-menu .ttl-03 {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-menu .ttl-03 {
    font-size: 20px;
  }
}
.list-menu .txt {
  white-space: pre-wrap;
}
.list-menu-loop {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  row-gap: 5px;
}
.list-menu-loop__item {
  color: #226750;
  display: flex;
}
.list-menu-loop__item:not(:first-child)::before {
  content: "／";
  display: block;
  margin: 0 5px;
}
.list-price__item {
  border-bottom: solid 1px #226750;
  padding: 15px 20px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.list-price dt {
  max-width: 76%;
  font-family: "Shippori Mincho", serif;
  font-weight: 700;
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .list-price dt {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-price dt {
    font-size: 20px;
  }
}
.list-price dd {
  max-width: 20%;
  color: #226750;
  text-align: right;
}
.list-faq__item {
  border-bottom: solid 1px rgba(61, 48, 25, 0.3);
  padding: 30px 40px 30px 0;
}
.list-faq__item:first-child {
  padding-top: 0 !important;
}
.list-faq dt {
  cursor: pointer;
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-start;
  -moz-column-gap: 15px;
       column-gap: 15px;
  font-family: "Shippori Mincho", serif;
  font-weight: 700;
  font-weight: 700;
  transition: 0.3s;
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .list-faq dt {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-faq dt {
    font-size: 22.6666666667px;
  }
}
.list-faq dt::before {
  content: "Q";
  display: block;
  width: 44px;
  min-width: 44px;
  aspect-ratio: 1/1;
  border-radius: 50rem;
  padding: 0 4px 3px 0;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #226750;
  color: #fff;
  font-family: "Courgette", cursive;
  letter-spacing: 0;
  line-height: 1;
  font-weight: 400;
  font-size: 26px;
  font-size: 2.6rem;
}
@media screen and (max-width: 768px) {
  .list-faq dt::before {
    font-size: 36px;
    font-size: 4.6875vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-faq dt::before {
    font-size: 24px;
  }
}
.list-faq dt::after {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  transition: 0.3s;
  width: 10px;
  aspect-ratio: 1/1;
  border-top: solid 2px #226750;
  border-right: solid 2px #226750;
  top: 50%;
  right: 0;
  transform: translate(40px, -50%) rotate(135deg);
}
.list-faq dt:hover {
  opacity: 0.8;
}
.list-faq dt:hover::after {
  transform: translate(40px, calc(-50% + 2px)) rotate(135deg);
}
.list-faq dd {
  padding: 20px 0 0 60px;
  white-space: pre-wrap;
}
.list-voice .com-layout {
  justify-content: center;
  align-items: flex-start;
  -moz-column-gap: 40px;
       column-gap: 40px;
}
.list-voice .img {
  width: 330px;
  aspect-ratio: 330/380;
  overflow: hidden;
}
.list-voice .ttl-03 {
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .list-voice .ttl-03 {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-voice .ttl-03 {
    font-size: 22.6666666667px;
  }
}
.list-voice .txtbx {
  width: 100%;
  display: flex;
  flex-direction: column;
  row-gap: 15px;
}
.list-voice .txt {
  white-space: pre-wrap;
}
.list-voice__item {
  border-top: solid 1px #226750;
  border-bottom: solid 1px #226750;
  padding: 40px;
  position: relative;
  z-index: 1;
}
.list-gallery__item {
  display: flex;
  flex-direction: column;
  row-gap: 15px;
}
.list-gallery__img {
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
}
.list-gallery__ttl {
  font-family: "Shippori Mincho", serif;
  font-weight: 700;
  text-align: center;
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .list-gallery__ttl {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-gallery__ttl {
    font-size: 22.6666666667px;
  }
}

.tag-main__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 5px;
  font-weight: 500;
  font-size: 18px;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .tag-main__list {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tag-main__list {
    font-size: 18.6666666667px;
  }
}
.tag-main__link {
  display: block;
  background: #765c30;
  color: #fff;
  padding: 10px 20px;
  border-radius: 50rem;
}
.tag-main__link:hover {
  color: rgba(255, 255, 255, 0.8);
}
.tag-sub__list {
  display: flex;
  flex-wrap: wrap;
  font-size: 14px;
  font-size: 1.4rem;
}
@media screen and (max-width: 768px) {
  .tag-sub__list {
    font-size: 24px;
    font-size: 3.125vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tag-sub__list {
    font-size: 16px;
  }
}
.tag-sub__item {
  line-height: 1;
  color: #765c30;
  padding: 0 10px;
}
.tag-sub__item:not(:first-child) {
  border-left: solid 1px #765c30;
}
.tag-sub__item:first-child {
  padding-left: 0 !important;
}
.tag-sub__item:last-child {
  padding-right: 0 !important;
}

.ttl-main {
  display: flex;
  flex-direction: column;
  row-gap: 10px;
}
.ttl-main .en {
  font-family: "Courgette", cursive;
  letter-spacing: 0;
  color: #226750;
  line-height: 1;
  font-size: 80px;
  font-size: 8rem;
}
@media screen and (max-width: 768px) {
  .ttl-main .en {
    font-size: 90px;
    font-size: 11.71875vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-main .en {
    font-size: 60px;
  }
}
.ttl-main .jp {
  font-family: "Shippori Mincho", serif;
  font-weight: 700;
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .ttl-main .jp {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-main .jp {
    font-size: 22.6666666667px;
  }
}
.ttl-sub {
  font-family: "Shippori Mincho", serif;
  font-weight: 700;
  border-left: solid #226750 6px;
  border-bottom: solid 1px rgba(61, 48, 25, 0.3);
  padding: 10px 20px 15px 20px;
  margin-bottom: 30px;
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .ttl-sub {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-sub {
    font-size: 22.6666666667px;
  }
}
.ttl-01 {
  font-family: "Shippori Mincho", serif;
  font-weight: 700;
  font-weight: 700;
  text-align: center;
  border-bottom: solid 1px #226750;
  padding-bottom: 15px;
  position: relative;
  z-index: 1;
}
.ttl-01::before, .ttl-01::after {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  transition: 0.3s;
  width: 8px;
  aspect-ratio: 1/1;
  border-radius: 50rem;
  background: #226750;
  bottom: 0;
  transform: translate(0, 50%);
}
.ttl-01::before {
  left: 0;
}
.ttl-01::after {
  right: 0;
}
.ttl-02 {
  font-family: "Shippori Mincho", serif;
  font-weight: 700;
  font-weight: 700;
  border-bottom: solid 1px rgba(61, 48, 25, 0.3);
  padding-bottom: 15px;
}
.ttl-03 {
  display: flex;
  align-items: center;
  -moz-column-gap: 10px;
       column-gap: 10px;
  font-family: "Shippori Mincho", serif;
  font-weight: 700;
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .ttl-03 {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-03 {
    font-size: 20px;
  }
}
.ttl-03::before {
  content: "";
  display: block;
  width: 20px;
  height: 1px;
  background: rgba(61, 48, 25, 0.3);
}

.txt-plain {
  line-height: 2;
  font-weight: 400;
}

.header-nav__item,
.drawer-nav__item,
.footer-nav__item,
.footer-sub__item {
  line-height: 1;
}
.header-nav__link:hover,
.drawer-nav__link:hover,
.footer-nav__link:hover,
.footer-sub__link:hover {
  opacity: 0.8;
}

.header-nav__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  -moz-column-gap: 55px;
       column-gap: 55px;
}
.header-nav__item:nth-child(3) {
  margin-right: 270px;
}
.header-nav__link {
  display: flex;
  flex-direction: column;
  text-align: center;
  row-gap: 10px;
}
.header-nav__link .en {
  font-family: "Courgette", cursive;
  letter-spacing: 0;
  color: #226750;
  text-transform: lowercase;
  font-size: 26px;
  font-size: 1.3541666667vw;
}
@media screen and (max-width: 1120px) {
  .header-nav__link .en {
    font-size: 17.3333333333px;
  }
}
@media screen and (min-width: 1920px) {
  .header-nav__link .en {
    font-size: 26px;
  }
}
.header-nav__link .jp {
  color: #765c30;
  font-size: 16px;
  font-size: 0.8333333333vw;
}
@media screen and (max-width: 1120px) {
  .header-nav__link .jp {
    font-size: 10.6666666667px;
  }
}
@media screen and (min-width: 1920px) {
  .header-nav__link .jp {
    font-size: 16px;
  }
}

.footer-nav__list {
  display: flex;
  gap: 30px;
  font-weight: 400;
  font-size: 16px;
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  .footer-nav__list {
    font-size: 26px;
    font-size: 3.3854166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .footer-nav__list {
    font-size: 17.3333333333px;
  }
}
.footer-nav__link {
  color: #eee;
}

.footer-sub__list {
  display: flex;
  justify-content: flex-end;
  font-weight: 400;
  font-size: 12px;
  font-size: 1.2rem;
}
@media screen and (max-width: 768px) {
  .footer-sub__list {
    font-size: 22px;
    font-size: 2.8645833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .footer-sub__list {
    font-size: 14.6666666667px;
  }
}
.footer-sub__item {
  padding: 0 15px;
}
.footer-sub__item:not(:first-child) {
  border-left: solid 1px #fff;
}
.footer-sub__item:first-child {
  padding-left: 0 !important;
}
.footer-sub__item:last-child {
  padding-right: 0 !important;
}
.footer-sub__link {
  color: #eee;
}

#ctn-top #header {
  padding-bottom: 135px;
}
#ctn-top #header::before, #ctn-top #header::after {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  transition: 0.3s;
  height: 100%;
  top: 0;
}
#ctn-top #header::before {
  aspect-ratio: 1221/770;
  background-image: url("/img/top/mv-bg-01.png");
  background-size: 100%;
  left: 0;
}
#ctn-top #header::after {
  aspect-ratio: 535/770;
  background-image: url("/img/top/mv-bg-02.png");
  background-size: 100%;
  right: 0;
}
#ctn-top #header .cts-1080::before, #ctn-top #header .cts-1080::after {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  transition: 0.3s;
}
#ctn-top #header .cts-1080::before {
  width: 472px;
  max-width: 24.5833333333%;
  aspect-ratio: 472/513;
  background-image: url("/img/top/mv-obj-01.png");
  background-size: 100%;
  top: 50%;
  left: 0;
  transform: translate(0, -55%);
  z-index: 2;
}
#ctn-top #header .cts-1080::after {
  width: 357px;
  max-width: 18.59375%;
  aspect-ratio: 357/355;
  background-image: url("/img/top/mv-obj-02.png");
  background-size: 100%;
  right: 0;
  bottom: 100px;
}
#ctn-top #header .header-side {
  top: 0;
  transform: translateY(-20%);
}
#ctn-low #header {
  background: url("/img/common/sv-bg.jpg") center bottom no-repeat;
  background-size: cover;
}
#ctn-low #header .header-side {
  bottom: 0;
}
#ctn-low #header .header-mv::before {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  transition: 0.3s;
  width: 310px;
  max-width: 16.1458333333%;
  aspect-ratio: 310/197;
  background-image: url("/img/common/sv-obj-01.png");
  background-size: 100%;
  left: 5.31%;
  bottom: 0;
}

#header {
  padding-top: 80px;
  overflow: hidden;
  position: relative;
  z-index: 1;
}
#header .com-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
}

.header-side {
  position: absolute;
  right: 0;
  z-index: 1;
}
.header-side__sns {
  margin: -3.4vw 1vw 0 0;
}
.header-lace {
  width: 100%;
  height: 42px;
  background: url("/img/common/pattern-lace.png");
  background-repeat: repeat-x;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

.mv, .sv {
  width: 1080px;
  max-width: 56.25%;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.mv img, .sv img {
  display: block;
  width: 100%;
}

.mv {
  margin-top: 50px;
}

.sv {
  margin-top: 80px;
}
.sv-img {
  width: 35.19%;
  margin-left: auto;
  position: relative;
}
.sv-img::before {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  transition: 0.3s;
  width: 40%;
  aspect-ratio: 152/146;
  background-image: url("/img/common/sv-obj-02.png");
  background-size: 100%;
  left: 0;
  bottom: 0;
  transform: translate(-50%, 0);
  z-index: 1;
}
.sv-ttl {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
  z-index: 1;
  font-family: "Shippori Mincho", serif;
  font-weight: 700;
  letter-spacing: 0.04em;
  font-size: 36px;
  font-size: 1.875vw;
}
@media screen and (max-width: 1120px) {
  .sv-ttl {
    font-size: 24px;
  }
}
@media screen and (min-width: 1920px) {
  .sv-ttl {
    font-size: 36px;
  }
}

.top-about {
  padding: 0 0 140px 0;
  background: url("/img/common/com-obj-grass.png") right 8.7% bottom no-repeat;
  background-size: 19.95%;
}
.top-about .ttl-main {
  margin-bottom: 200px;
}
.top-about .img-01 {
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(165px, 0);
  z-index: -1;
}
.top-about .img-02 {
  margin-left: -70px;
}
.top-about .obj-af::after {
  width: 546px;
  aspect-ratio: 1/1;
  background-image: url("/img/common/com-obj-lace.png");
  background-size: 100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.top-voice {
  padding: 140px 0;
  background: url("/img/top/voice-bg.jpg") center center no-repeat;
  background-size: cover;
}
.top-voice.obj-bf::before {
  width: 621px;
  max-width: 32.34375%;
  aspect-ratio: 621/417;
  background-image: url("/img/common/com-obj-leaf.png");
  background-size: 100%;
  top: 0;
  left: 2.6%;
  transform: translate(0, -70%);
}

.top-banner {
  padding: 150px 0;
  background: url("/img/top/banner-obj.png") left 6.04% top no-repeat;
  background-size: 30.16%;
}

.top-info {
  padding: 140px 0 80px 0;
}
.top-info .ttl-main {
  margin-bottom: 50px;
}
.top-info .obj-bf::before {
  width: 346px;
  aspect-ratio: 346/661;
  background-image: url("/img/top/info-obj.png");
  background-size: 100%;
  top: 0;
  right: 0;
  transform: translate(340px, -325px);
}
.top-info.bg-af::after {
  width: 1680px;
  max-width: 87.5%;
  height: 100%;
  background-image: url("/img/top/info-bg.jpg");
  background-size: cover;
  background-position: right center;
  top: 0;
  left: 0;
}

.top-gmap .com-gmap {
  width: 1680px;
  max-width: 87.5%;
}

.top-news {
  padding: 140px 0;
}
.top-news .cts-1080 {
  min-height: 240px;
}
.top-news .btn {
  position: absolute;
  left: 0;
  top: 130px;
}
.top-news.bg-bf::before {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  transition: 0.3s;
  width: 392px;
  max-width: 20.4166666667%;
  aspect-ratio: 1/1;
  background-image: url("/img/common/com-obj-lace.png");
  background-size: 100%;
  top: 0;
  left: 7.03%;
  transform: translate(0, -36%);
}

#ctn-low section {
  padding: 130px 0;
}
#ctn-low .ttl-main {
  margin-bottom: 60px;
}
#ctn-low .salon-about .ttl-main {
  margin-bottom: 150px;
}

.salon-concept .img {
  margin-left: -50px;
}
.salon-concept .cts-1080.obj-bf::before {
  width: 534px;
  aspect-ratio: 534/335;
  background-image: url("/img/salon/concept-obj-01.png");
  background-size: 100%;
  top: 0;
  right: 0;
  transform: translate(324px, 20%);
}
.salon-concept .cts-1080.obj-af::after {
  width: 419px;
  aspect-ratio: 1/1;
  background-image: url("/img/common/com-obj-lace.png");
  background-size: 100%;
  right: 0;
  bottom: 0;
  transform: translate(50px, -50px);
}
.salon-concept .txt.obj-bf::before {
  width: 240px;
  aspect-ratio: 240/158;
  background-image: url("/img/salon/concept-obj-02.png");
  background-size: 100%;
  top: 0;
  left: 0;
  transform: translate(-130px, 40%);
}

.salon-about .wrp {
  padding: 130px 100px;
  background: url("/img/salon/about-bg.jpg") center center no-repeat;
  background-size: cover;
}
.salon-about .img {
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(100px, -90px);
}
.salon-about .obj-bf::before {
  width: 318px;
  aspect-ratio: 383/208;
  background-image: url("/img/common/com-obj-grass.png");
  background-size: 100%;
  right: 0;
  bottom: 100%;
  transform: translateX(50px);
}
.salon-about .obj-af::after {
  width: 621px;
  aspect-ratio: 621/417;
  background-image: url("/img/common/com-obj-leaf.png");
  background-size: 100%;
  left: 0;
  bottom: 0;
  transform: translate(-220px, -65px);
  z-index: 1;
}

.info-greeting .obj-af::after {
  width: 395px;
  aspect-ratio: 1/1;
  background-image: url("/img/common/com-obj-lace.png");
  background-size: 100%;
  left: 0;
  bottom: 0;
  transform: translate(-100px, 100px);
}

#footer {
  background: url("/img/common/footer-bg.jpg") center center no-repeat;
  background-size: cover;
}
#footer .wrp-main {
  padding: 100px 0;
}
#footer .wrp-sub .cts-1280 {
  border-top: solid 1px rgba(255, 255, 255, 0.3);
  padding: 20px 0;
}/*# sourceMappingURL=style.css.map */