@charset "utf-8";

html,
body {
  font-family: "ten-mincho-text", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-optical-sizing: auto;
  line-height: 2;
  font-style: normal;
  letter-spacing: 0.1em;
  overflow-x: clip;
  background-color: #fff;
  color: #2d2d2d;
  word-break: auto-phrase;
}

.bg-fix {
  background-image: url("../images/washi-bg.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "ten-mincho-text", sans-serif;
  font-weight: 400;
  font-style: normal;
}

a {
  color: #2d2d2d;
  text-decoration: none !important;
  transition: all 0.3s;
}

a.white {
  color: #fff !important;
}

a:hover {
  color: #d0a969 !important;
  cursor: pointer;
}

.is-scroll-lock {
  overflow: hidden;
}

/* フォント */

.ten {
  font-family: "ten-mincho-text", sans-serif;
  font-weight: 400;
}

.zen-r {
  font-family: "zen-old-mincho", sans-serif;
  font-weight: 400;
}

.zen-b {
  font-family: "zen-old-mincho", sans-serif;
  font-weight: 700;
}

.zen-k {
  font-family: "zen-old-mincho", sans-serif;
  font-weight: 900;
}

.fc-white,
.fc-white a {
  color: #fff;
}

.fc-beige {
  color: #fff9ec !important;
}

.fc-brown {
  color: #6b3f0d !important;
}

.fc-red {
  color: #ff2d30 !important;
}

.v-text {
  writing-mode: vertical-rl;
  text-orientation: upright;
  white-space: nowrap;
}

.text-shadow {
  text-shadow: 2px 2px 5px black;
}

.text-shadow-white {
  text-shadow: 2px 2px 5px white;
}

.has-shadow {
  box-shadow: 4px 4px 12px rgba(0, 0, 0, 0.15);
}

/* 背景 */
.bg-white {
  background-color: #fff;
}

.bg-brown {
  background-color: #726030;
}

.bg-yellow {
  background-color: #e3b017;
}

.bg-beige-1 {
  background-color: rgba(242, 203, 76, 0.21);
}

.bg-beige-2 {
  background-color: rgba(190, 135, 16, 0.15);
}

/*罫線*/
.b-black {
  border: 1px solid #2d2d2d;
}

.bl-black {
  border-left: 1px solid #2d2d2d;
}

.br-black {
  border-right: 1px solid #2d2d2d;
}

.bb-black {
  border-bottom: 1px solid #2d2d2d;
}

.bt-black {
  border-top: 1px solid #2d2d2d;
}

.bx-black {
  border-left: 1px solid #2d2d2d;
  border-right: 1px solid #2d2d2d;
}

.bb-white {
  border-bottom: 1px solid #fff;
}

/* ボタン */
.button {
  position: relative;
  display: inline-flex !important;
  background-color: #fff;
  border: #c7b192 1px solid;
  width: 220px;
  height: 50px;
  justify-content: start;
  align-items: center;
  transition: all 0.3s;
  padding: 1.2rem;
}

.button.w {
  width: 280px;
  padding: 2rem;
}
.reserve-button {
  width: 340px;
  padding: 2rem;
  background-color: #d0a969;
}

.reserve-button:hover {
  background-color: #403427;
}

@media (min-width: 768px) {
  .button {
    width: 248px;
    height: 60px;
  }
  .button.w {
    width: 500px;
  }
  .reserve-button {
    width: 500px;
  }
}

.button::after {
  content: "";
  width: 9px;
  height: 12px;
  background-image: url(../images/arrow.svg);
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  transition: all 0.3s;
}

.button p {
  font-family: "zen-old-mincho", sans-serif;
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-weight: 700;
  color: #6b3f0d;
  margin: 0 !important;
  padding: 0 !important;
}
.reserve-button p {
  color: #fff;
}
.button:hover {
  background-color: #3f2f1d;
}

.button:hover::after {
  right: 16px;
}

.button:hover p {
  color: #fff;
}

.button-y {
  position: relative;
  display: inline-flex !important;
  background-color: #d0a969;
  border: #fff 1px solid;
  width: 220px;
  height: 50px;
  justify-content: start;
  align-items: center;
  transition: all 0.3s;
  padding: 1.2rem;
}

@media (min-width: 768px) {
  .button-y {
    width: 256px;
    height: 60px;
  }
}

.button-y::after {
  content: "";
  width: 9px;
  height: 12px;
  background-image: url(../images/arrow-w.svg);
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  transition: all 0.3s;
}

.button-y p {
  font-family: "zen-old-mincho", sans-serif;
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-weight: 700;
  color: #fff;
  margin: 0 !important;
  padding: 0 !important;
}

.button-y:hover {
  background-color: #3f2f1d;
}

.button-y:hover::after {
  right: 16px;
}

.line-button {
}
.reserve-button::after {
  background-image: url(../images/arrow-w.svg);
}
/* ナビ */

.header-wrap {
  position: fixed;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.5rem 1.5rem 0 1.5rem;
  width: 100%;
  z-index: 900;
  transition: all 0.4s ease;
}

@media (min-width: 768px) {
  .header-wrap {
    padding: 2rem 2rem 0 2rem;
  }
}

.header-logo {
  max-width: 250px;
  transition: all 0.4s ease;
}

.a-nav-menu {
  display: none;
  opacity: 0;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 900;
  justify-content: center;
  align-items: center;
  transition: all 0.3s ease;
  background-image: url("../images/header-bg.jpg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.a-nav-menu.edit {
  display: flex;
  opacity: 1;
}

.nav-menu-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
}

.nav-menu-wrap .box1 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  gap: 1rem;
}

.nav-menu-wrap .box1.foot {
  gap: 3rem;
}

@media (min-width: 768px) {
  .nav-menu-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4rem;
  }

  .nav-menu-wrap .box1 {
    gap: 0rem;
  }

  .nav-menu-wrap .box1 {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
    gap: 0rem;
  }

  .nav-menu-wrap .box1.foot {
    gap: 2rem;
  }
}

.nav-menu-wrap .box1 .store {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
}

.nav-menu-btn {
  max-width: 424px;
  width: 75%;
}

.foot-menu-btn {
  width: 100%;
}

.nav-menu-btn:hover,
.foot-menu-btn:hover {
  transform: scale(1.03);
}

.nav-menu-wrap .box1 .store .text {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  gap: 1rem;
}

.line-btn {
  width: 90%;
  max-width: 510px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  background-color: #3f2f1d;
  border-radius: 6px;
  border: #fff 1px solid;
  transition: all 0.3s ease-in;
  padding: 0.5rem;
}

.line-btn.green {
  background-color: #4cc764;
}

.line-btn:hover {
  background-color: #d0a969;
  transform: scale(1.03);
}

.line-btn .logo {
  width: 36px;
}

.line-btn p {
  color: #fff;
  font-family: "ten-mincho-text", sans-serif;
  font-weight: 400;
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  line-height: 1.2;
}

@media (min-width: 768px) {
  .nav-menu-btn {
    width: 90%;
  }

  .line-btn {
    width: 90%;
    padding: 0.8rem;
  }
}

.nav-list {
  display: flex;
  flex-direction: row-reverse;
  align-items: start;
  justify-content: center;
  width: 100%;
}

.nav-list .box {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.2rem;
}

.nav-list.foot .box {
  gap: 1.2rem;
}

@media (min-width: 768px) {
  .nav-list .box {
    gap: 2rem;
  }

  .nav-list.foot .box {
    gap: 2rem;
  }
}

.nav-list a {
  min-width: auto;
}

.nav-list .box a p {
  font-size: clamp(0.875rem, 0.794rem + 0.35vw, 1.125rem);
  line-height: 1.2;
  letter-spacing: 0.25em;
}

.nav-list.foot .box a p {
  text-align: center;
}

@media (min-width: 768px) {
  .nav-list.foot .box a p {
    text-align: start;
  }
}

.burger-wrap {
  position: relative;
  z-index: 1100;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  cursor: pointer;
}

.burger-wrap p {
  display: none;
  font-family: "zen-old-mincho", sans-serif;
  font-weight: 900;
  font-size: clamp(1rem, 0.838rem + 0.7vw, 1.5rem);
  line-height: 1;
  color: #2d2d2d;
}

@media (min-width: 768px) {
  .burger-wrap p {
    display: block;
  }
}

.a-burger {
  position: relative;
  width: 36px;
  height: 10px;
  margin: 0;
  padding: 0;
}

.a-burger div {
  width: 36px;
  height: 1px;
  background-color: #2d2d2d;
  position: absolute;
  left: 0px;
  transform-origin: center;
  transition: all 0.3s;
  padding: 0;
  margin: 0;
}

.a-burger div:nth-child(1) {
  top: 0px;
}

.a-burger div:nth-child(2) {
  bottom: 0px;
}

.burger-wrap.is-active .a-burger div:nth-child(1) {
  transform: rotate(-45deg);
  top: 6px;
}

.burger-wrap.is-active .a-burger div:nth-child(2) {
  transform: rotate(45deg);
  bottom: 4px;
}

@media (min-width: 768px) {
  .a-burger {
    width: 42px;
    height: 14px;
  }

  .a-burger div {
    width: 42px;
  }

  .burger-wrap.is-active .a-burger div:nth-child(1) {
    top: 6px;
  }

  .burger-wrap.is-active .a-burger div:nth-child(2) {
    bottom: 6px;
  }
}

.header-button {
  position: relative;
  width: 220px;
  padding: 0.6rem;
  background-color: #d0a969;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease-in;
  z-index: 1100;
}

.header-button p {
  color: #fff;
  font-family: "ten-mincho-text", sans-serif;
  font-weight: 400;
  font-size: clamp(0.875rem, 0.754rem + 0.53vw, 1.25rem);
  line-height: 1.2;
}

.header-button:hover {
  background-color: #403427;
}

@media (min-width: 768px) {
  .header-button {
    width: 270px;
    padding: 1.2rem;
  }
}

.header-wrap.is-scrolled {
  background: rgba(255, 255, 255, 0.7);
  padding: 0.8rem;
}

@media (min-width: 768px) {
  .header-wrap.is-scrolled {
    padding: 1.5rem;
  }
}

.header-wrap.is-scrolled .header-logo {
  opacity: 0;
  pointer-events: none;
}

/* フッター */

.foot-wrap {
  background-color: #3f2f1d;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

/* News表示 */

.webgene-blog {
  width: 100%;
}

/* News表示 画像あり版 */
.news-list .webgene-blog {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.news-list .webgene-item {
  width: 100%;
}

@media (min-width: 768px) {
  .news-list .webgene-item {
    width: 48%;
  }
}

/* ページネーション共通 */
.webgene-pagination {
  width: 100%;
}

.webgene-pagination ul,
.pagelink {
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  gap: 20px;
  max-width: 270px;
  margin-top: 4rem;
}

.webgene-pagination ul li,
.pagelink p {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  letter-spacing: 0.2rem;
  line-height: 1.5;
  width: auto;
  display: flex;
  justify-content: center;
  align-items: center;
}

.webgene-pagination ul li a,
.pagelink p a {
  display: inline-flex !important;
  width: 120px;
  height: 60px;
  border: 1px solid #c7b192;
  background-color: #fff;
  padding: 1rem 0.8rem !important;
  align-items: center;
  justify-content: space-between;
  transition: all 0.3s;
}

.webgene-pagination ul li a:hover,
.pagelink p a:hover {
  cursor: pointer;
  background-color: #d0a969;
}

.webgene-pagination .next {
  margin-left: auto;
}

@media (min-width: 768px) {
  .webgene-pagination ul,
  .pagelink {
    max-width: 400px;
  }
}

/* Nextボタン */
.webgene-pagination li.next a::after,
.pagelink p.next a::after {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  background-image: url("../images/arrow.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  transition: all 0.3s;
}
.webgene-pagination ul li.next a:hover::after,
.pagelink p.next a:hover::after {
  transform: translateX(2px);
}

/* Prevボタン */
.webgene-pagination ul li.prev a::before,
.pagelink p.prev a::before {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  background-image: url("../images/arrow-prev.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  transition: all 0.3s;
}
.webgene-pagination ul li.prev a:hover::before,
.pagelink p.prev a:hover::after {
  transform: translateX(-2px);
}

/* フォーム */
.formInput,
.formTextArea {
  width: 100%;
  padding: 0.5rem;
  border: none;
  border-radius: 0;
  border: 1px solid #cbc3b0;
  background-color: #fffcf5;
  margin-bottom: 2rem;
}

.formTextArea {
  height: 8rem;
}

.formInput:focus,
.formInput:focus-visible,
.formTextArea:focus,
.formTextArea:focus-visible,
.form-button:focus,
.form-button:focus-visible {
  border: 1px solid #cbc3b0;
  background-color: #fffcf5;
}
.zipInput {
  width: 6rem;
}
@media (min-width: 768px) {
  .formTh {
    padding-left: 2rem;
  }
}

.requiredText {
  background-color: #a3987c;
  color: #fff;
  padding: 4px 8px;
  font-size: 0.8rem;
  margin-left: 1rem;
}
.privacyformError {
  padding-top: 25px;
}
@media (min-width: 768px) {
  .privacyformError {
    padding-top: 0;
  }
}
/* ページ共通設定 */

.is-loading .top-fv-layer {
  visibility: hidden;
}

.top-fv-section {
  position: relative;
}

.fv-wrap {
  position: relative;
  height: 100vh;
  width: 100%;
  overflow: hidden;
  z-index: 1;
}

.top-fv-layer {
  position: absolute;
  inset: 0;
  opacity: 0;
  backface-visibility: hidden;
  will-change: opacity, transform, filter;
}

.top-fv-layer img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ===== 1枚目は最初から表示 ===== */
.top-fv-layer:first-child {
  opacity: 1;
  transform: scale(1.05); /* 少しだけ大きめで待機 */
  filter: blur(0px);
  z-index: 1;
}

/* ===== 2枚目以降は非表示スタート ===== */
.top-fv-layer:not(:first-child) {
  opacity: 0;
  transform: scale(1.08);
  filter: blur(12px);
}

.top-fv-layer:not(:first-child).edit {
  opacity: 1;
  transform: scale(1);
  filter: none;
}

/* 重なり順 */
.top-fv-layer:nth-child(1) {
  z-index: 1;
}
.top-fv-layer:nth-child(2) {
  z-index: 2;
}
.top-fv-layer:nth-child(3) {
  z-index: 3;
}

.top-fv-text {
  position: absolute;
  bottom: 6%;
  left: 10%;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1rem;
  text-shadow: 1px 1px 8px rgba(255, 255, 255, 0.9);
}

@media (min-width: 768px) {
  .top-fv-text {
    bottom: 10%;
    left: 12%;
  }
}

.top-fv-text .title {
  font-size: clamp(2rem, 1.028rem + 4.2vw, 5rem);
  line-height: 1.2;
  letter-spacing: 0.08em;
}

.top-fv-text .text {
  font-size: clamp(1rem, 0.676rem + 1.4vw, 2rem);
  line-height: 1.6;
  letter-spacing: 0.1em;
}

.top-fv-text .en {
  font-size: clamp(0.625rem, 0.504rem + 0.53vw, 1rem);
  line-height: 2;
  letter-spacing: 0.1em;
}

.top-fv-text3 {
  position: absolute;
  bottom: 5%;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  padding: 0 3rem;
  width: 100%;
  gap: 1.2rem;
}

@media (min-width: 768px) {
  .top-fv-text3 {
    flex-direction: row;
    padding: 0 4rem;
    bottom: 10%;
    gap: 0;
  }
}

@media (min-width: 992px) {
  .top-fv-text3 {
    padding: 0 6rem;
    gap: 1rem;
  }
}

@media (min-width: 1200px) {
  .top-fv-text3 {
    padding: 0 15rem;
  }
}

.top-fv-text3 .l {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: start;
  gap: 0.5rem;
  text-shadow: 1px 1px 7px rgba(255, 255, 255, 0.4);
}

.top-fv-text3 .r {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: start;
  text-shadow: 1px 1px 7px rgba(255, 255, 255, 0.4);
}

.top-fv-text3 .l .en {
  font-size: clamp(0.875rem, 0.673rem + 0.88vw, 1.5rem);
  letter-spacing: 0.2em;
}

.top-fv-text3 .l .jp {
  font-size: clamp(1.25rem, 0.805rem + 1.93vw, 2.625rem);
  line-height: 2;
}

.top-fv-text3 .r .jp {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  line-height: 2;
}

/* プラシバシーポリシー */
.policy-box {
  overflow-y: scroll;
  height: 400px;
  border-radius: 30px;
}

.btn a::after {
  content: "→";
}

/* TOP */

.top-sec2-wrap {
  background: linear-gradient(180deg, #fffefa 39.42%, #fff 100%);
  position: relative;
}

.top-sec2-deco {
  width: 100%;
  object-fit: contain;
}

.top-sec2-box1 {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 2.4rem;
}

@media (min-width: 768px) {
  .top-sec2-box1 {
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 0;
  }

  .top-sec2-box1.rev {
    flex-direction: row-reverse;
  }
}

.top-sec2-box1 .l {
  flex: 1.6;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 2rem;
}

.top-sec2-box1 .l .text {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.5rem;
}

.deco-title {
  position: relative;
  font-size: clamp(0.875rem, 0.673rem + 0.88vw, 1.5rem);
  color: #6b3f0d;
  padding-bottom: 1.6rem;
}

.deco-title::before {
  content: "";
  width: 80px;
  height: 1px;
  position: absolute;
  bottom: 0%;
  left: 0%;
  background-color: #000;
}

.top-sec2-box1 .l .text .title {
  color: #9f751a;
  font-size: clamp(1.25rem, 0.683rem + 2.45vw, 3rem);
  line-height: 1.8;
}

.top-sec2-box1 .l .text .p {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  line-height: 2;
}

.top-sec2-box1 .r {
  flex: none;
  width: 100%;
  overflow: hidden;
  padding: 0 2rem;
}

@media (min-width: 768px) {
  .top-sec2-box1 .r {
    flex: 1;
    padding: 0;
  }
}

.top-sec2-box1 .r img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.top-sec2-box2,
.top-sec2-box3 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  position: relative;
  z-index: 2;
}

@media (min-width: 768px) {
  .top-sec2-box2 {
    flex-direction: row;
    align-items: end;
    justify-content: start;
    padding-right: 5rem;
  }
  .top-sec2-box3 {
    flex-direction: row;
    align-items: end;
    justify-content: start;
    padding-left: 5rem;
  }
}

.top-sec2-box2 .l {
  flex: 1;
  overflow: hidden;
  margin-right: 2rem;
  width: 80%;
}

.top-sec2-box2 .r {
  flex: 0.6;
  max-height: 180px;
  overflow: hidden;
  width: 60%;
  margin-left: 5rem;
}

.top-sec2-box3 .l {
  flex: 0.8;
  overflow: hidden;
  margin-right: 2rem;
  width: 70%;
}

.top-sec2-box3 .r {
  flex: 1;
  overflow: hidden;
  width: 65%;
  margin-left: 5rem;
}

@media (min-width: 768px) {
  .top-sec2-box2 .l {
    margin-bottom: 2.4rem;
    margin-right: 0;
    width: 100%;
  }

  .top-sec2-box2 .r {
    width: 100%;
    margin-left: 0;
  }

  .top-sec2-box3 .l {
    margin-right: 0;
    width: 100%;
  }

  .top-sec2-box3 .r {
    width: 100%;
    margin-bottom: 3rem;
    margin-left: 0;
  }
}

.top-sec2-box2 .l img,
.top-sec2-box2 .r img,
.top-sec2-box3 .l img,
.top-sec2-box3 .r img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}

.top-sec2-box4 {
  display: flex;
  align-items: center;
  justify-content: end;
  position: relative;
  z-index: 2;
}

.top-sec2-box4 .l {
  width: 80%;
  height: 75px;
  margin-right: 3rem;
}

.top-sec2-box4 .l img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}

@media (min-width: 768px) {
  .top-sec2-box4 .l {
    width: 60%;
    height: 170px;
    margin-right: 4rem;
  }
}

.top-sec2-bg {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: auto;
  z-index: 0;
}

.top-sec2-bg img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.top-sec3-section {
  position: relative;
}

.top-sec3-wrap {
  height: 100vh;
  position: relative;
  overflow: hidden;
}

.top-sec3-layer {
  position: absolute;
  inset: 0;
  opacity: 0; /* 今回は全レイヤー最初非表示 */
  transform: scale(1.08);
  filter: blur(12px);
  will-change: opacity, transform, filter;
}

.top-sec3-layer.edit {
  opacity: 1;
  transform: scale(1);
  filter: blur(0);
}

.top-sec3-layer img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.top-sec3-layer.layer-3 {
  width: 100%;
  height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 1.6rem;
}

.top-sec3-layer.layer-3 .p {
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  line-height: 2.4;
  color: #fff;
}

.top-sec3-layer.layer-3 .title {
  font-size: clamp(1.75rem, 1.224rem + 2.28vw, 3.375rem);
  line-height: 1.8;
  color: #fff;
}

.top-sec4-wrap {
  background: linear-gradient(
    0deg,
    #fffefa 69.93%,
    rgba(255, 255, 255, 0) 100%
  );
}

.top-swiper-wrapper {
  transition-timing-function: linear;
}

.top-swiper {
  width: 100%;
  height: auto;
}

@media (min-width: 1200px) {
  .top-swiper {
    width: 90%;
    height: auto;
  }
}

.top-swiper-slide {
  display: flex;
  justify-content: center;
  align-items: center;
}

.top-swiper-slide img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.top-sec4-title {
  text-align: center;
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  color: #6b3f0d;
  line-height: 1.8;
}

.top-sec4-box {
  background-color: #fff;
  box-shadow: 4px 4px 8px 0 rgba(0, 0, 0, 0.1);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1.4rem;
  width: 100%;
  gap: 1rem;
}

@media (min-width: 768px) {
  .top-sec4-box {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 2rem;
    gap: 1.4rem;
  }
}

@media (min-width: 992px) {
  .top-sec4-box {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    width: 80%;
  }
}

.top-sec4-box .title {
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  color: #6b3f0d;
  line-height: 2;
}

.top-sec5-wrap {
  background: linear-gradient(
    0deg,
    rgba(255, 255, 255, 0) 76.47%,
    #fffefa 90.59%
  );
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.top-sec5-title {
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  line-height: 1.8;
  text-align: center;
  color: #6b3f0d;
}

.top-sec5-box1 {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 2.4rem;
}

@media (min-width: 768px) {
  .top-sec5-box1 {
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 0;
  }

  .top-sec5-box1.rev {
    flex-direction: row-reverse;
  }
}

.top-sec5-box1 .l {
  flex: 1.6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 2rem;
}

.top-sec5-box1 .l .text {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.5rem;
  max-width: 510px;
}

.top-sec5-deco {
  position: relative;
  font-size: clamp(0.875rem, 0.673rem + 0.88vw, 1.5rem);
  color: #6b3f0d;
}

.top-sec5-box1 .l .text .title {
  color: #9f751a;
  font-size: clamp(1.25rem, 0.683rem + 2.45vw, 3rem);
  line-height: 1.8;
}

.top-sec5-box1 .l .text .p {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  line-height: 2;
}

.top-sec5-box1 .r {
  flex: none;
  width: 100%;
  overflow: hidden;
  padding: 0 2rem;
}

@media (min-width: 768px) {
  .top-sec5-box1 .r {
    flex: 1;
    padding: 0;
  }
}

.top-sec5-box1 .r img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.top-sec6-wrap {
  width: 100%;
  background-image: url("../images/top-sec5-bg.jpg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.top-sec6-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  text-align: center;
}

.top-sec6-box .title {
  color: #edd0a7;
  font-size: clamp(2.25rem, 1.481rem + 3.33vw, 4.625rem);
  line-height: 1.5;
}

.top-sec6-box .p {
  color: #fff;
  font-size: clamp(1rem, 0.838rem + 0.7vw, 1.5rem);
  line-height: 1.5;
}

.top-sec7-wrap {
  background-color: #685f4a;
}

.top-sec7-box {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 2rem;
}

@media (min-width: 768px) {
  .top-sec7-box {
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 2rem;
  }
}

.top-sec7-box .l {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: start;
  gap: 1.5rem;
}

.top-sec7-box .l .title {
  color: #edd0a7;
  font-size: clamp(2.25rem, 1.481rem + 3.33vw, 4.625rem);
  line-height: 1.5;
}

.top-sec7-box .r {
  flex: none;
  display: block;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  width: 100%;
}

@media (min-width: 768px) {
  .top-sec7-box .r {
    flex: 2;
    display: block;
    flex-direction: column;
    align-items: start;
    justify-content: center;
  }
}

/* チュックリスト */

.fv-sub-wrap {
  height: 70vh;
  width: 100%;
  position: relative;
  display: flex;
  align-items: end;
  justify-content: center;
}

.fv-sub-wrap.staff {
  height: 50vh;
}

@media (min-width: 768px) {
  .fv-sub-wrap.staff {
    height: 60vh;
  }
}

@media (min-width: 1200px) {
  .fv-sub-wrap,
  .fv-sub-wrap.staff {
    height: 100vh;
  }
}

.fv-sub-text {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 0.5rem;
  color: #fff;
  margin-bottom: 3rem;
}

@media (min-width: 768px) {
  .fv-sub-text {
    gap: 1rem;
    margin-bottom: 5rem;
  }
}

.fv-sub-text .title {
  font-size: clamp(2rem, 1.028rem + 4.2vw, 5rem);
  line-height: 1.3;
  letter-spacing: 0.1em;
}

.fv-sub-text .text {
  font-size: clamp(1rem, 0.676rem + 1.4vw, 2rem);
  line-height: 1.6;
  letter-spacing: 0.1em;
}

.che-sec2-section {
  position: relative;
}

.che-sec2-wrap {
  height: 100vh;
  position: relative;
  overflow: hidden;
}

.che-sec2-layer {
  position: absolute;
  inset: 0;
  opacity: 0; /* 今回は全レイヤー最初非表示 */
  transform: scale(1.08);
  filter: blur(12px);
  will-change: opacity, transform, filter;
}

.che-sec2-layer.edit {
  opacity: 1;
  transform: scale(1);
  filter: blur(0);
}

.che-sec2-layer img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.che-sec2-layer.layer-1 {
  width: 100%;
  height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 1.6rem;
}

.che-sec2-layer.layer-1 .p {
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  line-height: 2.4;
  color: #2d2d2d;
}

.che-sec2-layer.layer-1 .title {
  font-size: clamp(1.75rem, 1.224rem + 2.28vw, 3.375rem);
  line-height: 1.8;
  color: #2d2d2d;
}

.che-sec2-layer.layer-3 {
  width: 100%;
  height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.6rem;
  background: rgba(64, 52, 39, 0.9);
  color: #fff;
}

.che-sec2-layer.layer-3 .deco {
  text-align: center;
  position: relative;
  padding-bottom: 1.5rem;
  font-size: clamp(1.125rem, 0.842rem + 1.23vw, 2rem);
  text-shadow: 1px 1px 7px rgba(255, 255, 255, 0.4);
}

.che-sec2-layer.layer-3 .deco::after {
  content: "";
  width: 134px;
  height: 1px;
  position: absolute;
  bottom: 0%;
  left: 50%;
  transform: translateX(-50%);
  background-color: #fff;
}

.che-sec2-layer.layer-3 .box {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.2rem;
}

.che-sec2-layer.layer-3 .box .p {
  position: relative;
  font-size: clamp(0.875rem, 0.873rem + 0.88vw, 2.5rem);
  line-height: 1.8;
  padding-left: 20px;
  line-height: 1.5;
}

.che-sec2-layer.layer-3 .box .p::before {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background-image: url("../images/text-deco.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  transition: all 0.3s;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: -14px;
}

.che-sec3-wrap {
  background: linear-gradient(180deg, #fff 0%, #fffbf4 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.che-sec3-title {
  text-align: center;
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  color: #6b3f0d;
  line-height: 1.8;
}

.che-sec3-img {
  display: flex;
  align-items: center;
  justify-content: start;
}

.che-sec3-img.rev {
  justify-content: end;
}

.che-sec3-img img {
  width: 90%;
}

@media (min-width: 768px) {
  .che-sec3-img img {
    width: 70%;
  }
}

.che-sec3-text {
  display: flex;
  align-items: center;
  justify-content: end;
}

.che-sec3-text p {
  padding-left: 20px;
  border-left: #6b3f0d solid 1px;
  font-size: clamp(0.75rem, 0.507rem + 1.05vw, 1.5rem);
  line-height: 2.4;
}

.che-sec4-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 1.6rem;
}

.che-sec4-title .p {
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  line-height: 2.4;
}

.che-sec4-title .title {
  font-size: clamp(1.75rem, 1.224rem + 2.28vw, 3.375rem);
  line-height: 1.8;
}

/* コンセプト */

.con-sec2-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

@media (min-width: 992px) {
  .con-sec2-wrap {
    flex-direction: row;
    align-items: center;
    justify-content: center;
  }
}

.con-sec2-img {
  flex: none;
  width: 60%;
  height: 25vh;
  overflow: hidden;
}

@media (min-width: 992px) {
  .con-sec2-img {
    flex: 1;
    width: 100%;
    height: auto;
    overflow: hidden;
  }
}

.con-sec2-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.con-sec2-text {
  flex: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  padding: 1.5rem;
  background: rgba(255, 255, 255, 0.75);
  text-align: center;
}

.con-sec2-text .title {
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  line-height: 1.8;
  color: #2d2d2d;
}

.con-sec2-text .p {
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  line-height: 2.4;
  color: #2d2d2d;
}

@media (min-width: 768px) {
  .con-sec2-text {
    flex: 1.6;
    gap: 2rem;
    padding: 1.5rem;
  }
}

.con-sec2-img2 {
  width: 100%;
  height: 40vh;
  overflow: hidden;
}

@media (min-width: 768px) {
  .con-sec2-img2 {
    height: auto;
    max-height: 536px;
  }
}

.con-sec2-img2 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.con-sec3-wrap {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.con-sec3-bg {
  position: absolute;
  inset: 0;
  background-image: url("../images/con-sec3-bg.jpg");
  background-size: cover; /* ← 箱いっぱいに */
  background-position: center; /* ← 中央基準 */
  background-repeat: no-repeat;
  z-index: 0;
}

.con-sec3-img {
  width: 100%;
  height: 25vh;
  overflow: hidden;
  position: relative;
  z-index: 1;
}

.con-sec3-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

@media (min-width: 768px) {
  .con-sec3-img {
    width: 100%;
    height: 100%;
    max-height: 480px;
  }
}

.con-sec3-box1 {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 2.4rem;
  position: relative;
  z-index: 1;
}

@media (min-width: 768px) {
  .con-sec3-box1 {
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
    gap: 0;
  }

  .con-sec3-box1.rev {
    flex-direction: row-reverse;
  }
}

.con-sec3-box1 .l {
  flex: 1.6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 2rem;
}

.con-sec3-box1 .l .text {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.5rem;
  max-width: 510px;
}

.con-sec3-box1 .l .text .title {
  color: #9f751a;
  font-size: clamp(1.125rem, 0.801rem + 1.4vw, 2.125rem);
  line-height: 1.8;
}

.con-sec3-box1 .l .text .p {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  line-height: 2;
}

.con-sec3-box1 .r {
  flex: none;
  width: 100%;
  overflow: hidden;
  padding: 0 2rem;
}

@media (min-width: 768px) {
  .con-sec3-box1 .l {
    flex: 1.8;
  }

  .con-sec3-box1 .r {
    flex: 1;
    padding: 0;
  }
}

@media (min-width: 992px) {
  .con-sec3-box1 .l {
    flex: 1.4;
  }
}

.con-sec3-box1 .r img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.con-sec4-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 1.6rem;
}

.con-sec4-title .p {
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  line-height: 2.4;
}

.con-sec4-title .title {
  font-size: clamp(1rem, 0.636rem + 1.58vw, 2.125rem);
  line-height: 1.8;
  color: #6b3f0d;
}

/* メニュー */

.menu-sec2-title {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 0.5rem;
}

.menu-sec2-title .title {
  font-size: clamp(1.75rem, 1.224rem + 2.28vw, 3.375rem);
  line-height: 1;
  color: #9f751a;
}

.menu-sec2-title .p {
  font-size: clamp(1rem, 0.838rem + 0.7vw, 1.5rem);
  line-height: 2;
  color: #6b3f0d;
}

.menu-sec2-con {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  border-bottom: 1px solid #2d2d2d;
}

.menu-sec2-box {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  width: 100%;
  gap: 2rem;
}

.menu-sec2-box .l {
  flex: 1.2;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.2rem;
  width: 100%;
  padding: 0 1rem;
}

@media (min-width: 768px) {
  .menu-sec2-box {
    flex-direction: row;
    align-items: stretch;
    gap: 0;
  }

  .menu-sec2-box .l {
    padding: 0;
  }
}

.menu-sec2-box .l .deco {
  background-color: #6b3f0d;
  padding: 0.6rem 1rem;
  border-radius: 10px;
}

.menu-sec2-box .l .deco.y {
  background-color: #c8881f;
}

.menu-sec2-box .l .deco p {
  font-size: 14px;
  color: #fff;
}

.menu-sec2-box .l .title {
  font-size: clamp(1.75rem, 1.507rem + 1.05vw, 2.5rem);
  line-height: 1.5;
  color: #6b3f0d;
}

.menu-sec2-box .l .price {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1rem;
}

.menu-sec2-box .l .price .b {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  color: #2d2d2d;
  line-height: 2;
}

.menu-sec2-box .l .price .red {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  color: #ff2d30;
}

.menu-sec2-box .l .price .red div {
  display: flex;
  align-items: end;
  justify-content: start;
}

.menu-sec2-box .l .price .red .p1 {
  font-size: clamp(0.875rem, 0.673rem + 0.88vw, 1.5rem);
  line-height: 1;
}

.menu-sec2-box .l .price .red .p2 {
  font-size: clamp(1.875rem, 1.511rem + 1.58vw, 3rem);
  line-height: 1;
}

.menu-sec2-box .r {
  flex: none;
  width: 100%;
  overflow: hidden;
  padding: 0 1rem;
}

@media (min-width: 768px) {
  .menu-sec2-box .r {
    flex: 1;
    padding: 0;
  }
}

.menu-sec2-box .r img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.menu-sec2-box2 {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.4rem;
  width: 100%;
  padding: 0 1rem;
}

@media (min-width: 768px) {
  .menu-sec2-box2 {
    padding: 0;
  }
}

.menu-sec2-box2 .text {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  line-height: 2.4;
}

.menu-sec2-box2 .icon {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.menu-sec2-box2 .icon .flex {
  display: flex;
  gap: 0.6rem;
}

.menu-sec2-box2 .icon .flex div {
  background-color: #f3f3f3;
  padding: 0.5rem 0.6rem;
  display: flex;
  align-items: center;
}

.menu-sec2-box2 .icon .flex div p {
  font-size: clamp(0.625rem, 0.504rem + 0.53vw, 1rem);
}

.menu-sec2-box3 {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 2.4rem;
  background-image: url("../images/menu-sec2-bg.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  box-shadow: 2px 2px 12px 0 rgba(0, 0, 0, 0.15);
  border: 1px solid #d0a969;
}

.menu-sec2-box3 p {
  font-size: clamp(1.125rem, 0.842rem + 1.23vw, 2rem);
  line-height: 1.8;
  color: #6b3f0d;
}

.menu-sec3-wrap {
  background: #fffcf7;
}

.menu-sec3-box {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.4rem;
  padding-bottom: 4rem;
  border-bottom: 1px solid #2d2d2d;
}

.menu-sec3-box.center {
  align-items: center;
}

.menu-sec3-box .title {
  font-size: clamp(1rem, 0.757rem + 1.05vw, 1.75rem);
  color: #6b3f0d;
  line-height: 1.5;
  border-left: 1px solid #6b3f0d;
  padding-left: 1rem;
}

.menu-sec3-box .text {
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  line-height: 2.4;
}

.menu-sec3-box .text2 {
  font-size: clamp(1rem, 0.838rem + 0.7vw, 1.5rem);
  line-height: 2;
}

.menu-sec3-box img {
  width: 100%;
  max-width: 700px;
}

.menu-sec3-box div {
  display: flex;
  align-items: end;
}

.menu-sec3-box .b {
  font-size: clamp(1rem, 0.838rem + 0.7vw, 1.5rem);
  line-height: 1;
}

.menu-sec3-box .red {
  font-size: clamp(1.5rem, 1.014rem + 2.1vw, 3rem);
  line-height: 1;
  color: #ff2d30;
}

.menu-sec4-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.menu-sec4-title {
  font-size: clamp(1.5rem, 1.014rem + 2.1vw, 3rem);
  line-height: 1.8;
  color: #9f751a;
  text-align: center;
}

/* メイクスモア */

.mak-sec2-wrap {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.mak-sec2-bg {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 100%;
  height: 100%;
  z-index: 0;
}

.mak-sec2-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  gap: 1.6rem;
}

@media (min-width: 768px) {
  .mak-sec2-bg {
    width: 70%;
  }

  .mak-sec2-box {
    flex-direction: row;
    gap: 0;
  }
}

.mak-sec2-box .l,
.mak-sec2-box .r {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mak-sec2-box .l img {
  max-width: 350px;
  width: 70%;
}

.mak-sec2-box .r p {
  font-size: clamp(1.5rem, 0.974rem + 2.28vw, 3.125rem);
  color: #6b3f0d;
  text-align: center;
}

@media (min-width: 768px) {
  .mak-sec2-box .r p {
    text-align: start;
  }
}

.mak-sec2-box2 .l {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.4rem;
}

.mak-sec2-box2 .l .title {
  font-size: clamp(1.125rem, 0.923rem + 0.88vw, 1.75rem);
  line-height: 1.8;
  color: #6b3f0d;
}

.mak-sec2-box2 .l .text {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  line-height: 2.4;
}

.mak-sec2-box2 .r {
  height: 40vh;
  overflow: hidden;
}

.mak-sec2-box2 .r img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

@media (min-width: 768px) {
  .mak-sec2-box2 .r {
    height: auto;
  }
}

.mak-sec3-box .l {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.4rem;
}

.mak-sec3-box .l .title {
  font-size: clamp(1.125rem, 0.923rem + 0.88vw, 1.75rem);
  line-height: 1.8;
  color: #6b3f0d;
}

.mak-sec3-box .l .box {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 0.8rem;
  width: 100%;
}

.mak-sec3-box .l .box .p1 {
  background: linear-gradient(90deg, #ffebe2 11.06%, #ffdac2 91.35%);
  width: 100%;
  padding: 0.5rem 0.8rem;
  font-size: clamp(0.625rem, 0.504rem + 0.53vw, 1rem);
}

.mak-sec3-box .l .box.g .p1 {
  background: linear-gradient(90deg, #f5fff6 11.06%, #daffdd 91.35%);
}

.mak-sec3-box .l .box .p2 {
  width: 100%;
  font-size: clamp(0.625rem, 0.504rem + 0.53vw, 1rem);
  line-height: 2;
}

.mak-sec3-box .r {
  height: 40vh;
  overflow: hidden;
}

.mak-sec3-box .r img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

@media (min-width: 768px) {
  .mak-sec3-box .r {
    height: auto;
  }
}

.mak-sec4-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.6rem;
}

.mak-sec4-title {
  color: #9f751a;
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  text-align: center;
}

.mak-sec4-box {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 0.8rem;
  width: 100%;
}

@media (min-width: 768px) {
  .mak-sec4-box {
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
    gap: 0rem;
  }
}

.mak-sec4-box .l {
  flex: none;
  overflow: hidden;
  height: 30vh;
  width: 100%;
}

.mak-sec4-box .l img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

@media (min-width: 768px) {
  .mak-sec4-box .l {
    flex: 1;
    height: 100%;
  }
}

.mak-sec4-box .r {
  flex: none;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: start;
  padding: 1rem;
}

.mak-sec4-box .r p {
  font-size: clamp(0.875rem, 0.754rem + 0.53vw, 1.25rem);
  line-height: 2.4;
}

@media (min-width: 768px) {
  .mak-sec4-box .r {
    flex: 1.8;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: start;
    padding: 3rem;
  }
}

.mak-map {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.8rem;
  width: 100%;
}

.mak-map-title {
  font-size: clamp(1.5rem, 1.014rem + 2.1vw, 3rem);
  line-height: 1;
  color: #9f751a;
}

.mak-sec5-wrap {
  background-image: url("../images/mak-sec4-bg.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
}

.gar-sec5-wrap {
  background-image: url("../images/gar-sec4-bg.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mak-sec5-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
}

.mak-sec5-box img {
  width: 60%;
  max-width: 360px;
}

.mak-sec5-box .title {
  font-size: clamp(1rem, 0.636rem + 1.58vw, 2.125rem);
  line-height: 1.8;
  color: #6b3f0d;
  text-align: center;
}

/* ギャラリーswiper */

.gal-swiper {
  width: 100%;
  height: auto;
  margin-left: auto;
  margin-right: auto;
}

.gal-swiper-slide {
  background-size: cover;
  background-position: center;
}

.gal-mySwiper2 {
  height: auto;
  width: 100%;
  max-width: 760px;
}

.gal-mySwiper {
  height: 80px;
  box-sizing: border-box;
  padding: 10px 0;
  max-width: 760px;
}

@media (min-width: 768px) {
  .gal-mySwiper {
    height: 140px;
  }
}

.gal-mySwiper .gal-swiper-slide {
  width: 25%;
  height: 100%;
  opacity: 0.4;
}

.gal-mySwiper .swiper-slide-thumb-active {
  opacity: 1;
}

.gal-swiper-slide img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.gal-swiper-wrapper.little img {
  object-fit: cover;
}

/* お客様の声 */

.voice-sec2-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 1.2rem;
}

.voice-sec2-box .title {
  font-size: clamp(1rem, 0.636rem + 1.58vw, 2.125rem);
  line-height: 1.8;
}

.voice-sec2-box .p {
  font-size: clamp(0.875rem, 0.754rem + 0.53vw, 1.25rem);
  line-height: 2.4;
}

.voice-sec2-box .box {
  width: 100%;
  border: 1px solid #c7b192;
  background: #fff;
  box-shadow: 2px 2px 8px 0 rgba(0, 0, 0, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s;
  padding: 2rem;
}

.voice-sec2-box .box:hover {
  transform: scale(1.03);
}

.voice-sec2-box .box img {
  width: 70%;
}

.voice-sec3-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}

.voice-sec3-box .title {
  font-size: clamp(1.125rem, 0.923rem + 0.88vw, 1.75rem);
  text-align: center;
  color: #bf2b2e;
}

.voice-sec3-box.gar .title {
  color: #127f10;
}

.voice-sec3-box .text {
  font-size: clamp(0.625rem, 0.544rem + 0.35vw, 0.875rem);
  text-align: center;
}

.voice-sec3-box .img {
  background-color: #ffe9e5;
  width: 100%;
  max-width: 794px;
  height: 40vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.voice-sec3-box.gar .img {
  background-color: #f6fff2;
}

@media (min-width: 768px) {
  .voice-sec3-box .img {
    height: 500px;
  }
}

.voice-sec3-box .img img {
  object-fit: contain;
  object-position: center;
  height: 100%;
  width: auto;
}

.voice-com {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  width: 100%;
  max-width: 794px;
}

.voice-com .box {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  width: 100%;
  border-bottom: 0.5px solid #2d2d2d;
  padding-bottom: 2rem;
  margin-bottom: 2rem;
  gap: 1.2rem;
}

.voice-com .box .com {
  width: 100%;
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  line-height: 1.8;
  position: relative;
  padding-left: 35px;
}

.voice-com .box .com.q::before {
  content: "";
  display: block;
  width: 25px;
  height: 25px;
  background-image: url("../images/Q-icon.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  left: 0%;
  top: -5%;
}

.voice-com .box .com.a::before {
  content: "";
  display: block;
  width: 25px;
  height: 25px;
  background-image: url("../images/A-icon.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  left: 0%;
  top: -5%;
}

@media (min-width: 768px) {
  .voice-com .box .com.q::before {
    left: 0%;
    top: 5%;
  }

  .voice-com .box .com.a::before {
    left: 0%;
    top: 5%;
  }
}

/* スタッフ紹介 */

.staff-wrap {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  width: 100%;
}

.staff-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  gap: 2rem;
}

@media (min-width: 768px) {
  .staff-box {
    flex-direction: row;
    align-items: start;
    justify-content: center;
    gap: 1.2rem;
  }
}

.staff-box .text {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  width: 100%;
  gap: 1rem;
}

.staff-box .text .name {
  border-left: 1px solid #2d2d2d;
  padding: 2px 20px;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 0.4rem;
}

.staff-box .text .name .s {
  font-size: clamp(0.875rem, 0.794rem + 0.35vw, 1.125rem);
  line-height: 1.8;
  color: #6b3f0d;
}

.staff-box .text .name .l {
  font-size: clamp(1.25rem, 1.007rem + 1.05vw, 2rem);
  line-height: 1.8;
  color: #6b3f0d;
}

.staff-box .text .box {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.staff-box .text .box p {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
}

.staff-box .img {
  flex: none;
  overflow: hidden;
  height: 50vh;
}

@media (min-width: 768px) {
  .staff-box .img {
    flex: 1;
    height: 100%;
  }
}

.staff-box .img img {
  width: auto;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

/* 予約方法 */

.guide-sec2-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 2rem;
}

.guide-sec2-box .title {
  color: #fff;
  font-size: clamp(1.125rem, 0.801rem + 1.4vw, 2.125rem);
  line-height: 2;
}

.guide-sec2-box .p {
  color: #fff;
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  line-height: 2.4;
}

.guide-sec3-title {
  font-size: clamp(1rem, 0.676rem + 1.4vw, 2rem);
  line-height: 1.8;
  text-align: center;
  position: relative;
}

.guide-sec3-title::before,
.guide-sec3-title::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 30px;
  height: 1px; /* 線の太さ */
  background: #2d2d2d;
  transform: translateY(-50%);
}

.guide-sec3-title::before {
  left: -25%;
}

.guide-sec3-title::after {
  right: -25%;
}

@media (min-width: 768px) {
  .guide-sec3-title::before,
  .guide-sec3-title::after {
    width: 80px;
  }

  .guide-sec3-title::before {
    left: -40%;
  }

  .guide-sec3-title::after {
    right: -40%;
  }
}

.guide-sec3-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: start;
  padding: 0 1.5rem 0rem 1.5rem;
  gap: 1rem;
  text-align: center;
  max-width: 860px;
  width: 100%;
  margin-bottom: 1.6rem;
}

@media (min-width: 768px) {
  .guide-sec3-step {
    flex-direction: row;
    padding: 0 2rem 2rem 2rem;
    gap: 1.8rem;
    text-align: start;
    margin-bottom: 0%;
  }
}

.guide-sec3-step .no {
  position: relative;
  width: 100px;
  padding: 0.5rem;
}

@media (min-width: 768px) {
  .guide-sec3-step .no {
    width: 145px;
  }
}

.guide-sec3-step .no img {
  width: 100%;
  object-fit: contain;
  object-position: center;
}

.guide-sec3-step .box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  flex: 2.5;
  border-bottom: #2d2d2d 0.5px solid;
  padding: 0 0 3rem 0;
}

@media (min-width: 768px) {
  .guide-sec3-step .box {
    align-items: start;
    gap: 1rem;
    flex: 6;
    padding: 3rem 0;
  }
}

.guide-sec3-step .box .title {
  font-size: clamp(1.125rem, 1.004rem + 0.53vw, 1.5rem);
  line-height: 1.8;
  color: #6b3f0d;
}

.guide-sec3-step .box .p {
  font-size: clamp(0.625rem, 0.504rem + 0.53vw, 1rem);
  line-height: 2;
}

.guide-line-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1.2rem;
  border: 1px solid #c7b192;
  background: #fff;
  box-shadow: 2px 2px 8px 0 rgba(0, 0, 0, 0.1);
}

@media (min-width: 992px) {
  .guide-line-box {
    padding: 2.4rem;
  }
}

.news-wrap {
  max-width: 840px;
}
