@charset "utf-8";

:root {
  --black: #000000;
  --white: #fff;
  --red: #c11407;
  --brown: #462004;
}

html,
body {
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-optical-sizing: auto;
  line-height: 2;
  overflow-x: clip;
  font-style: normal;
  letter-spacing: 0.1em;
  color: #000000;
  word-break: auto-phrase;
  position: relative;
  z-index: 1;
}

iframe{border:none; display:block;}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "irohamaru", sans-serif;
  font-weight: 500;
  font-style: normal;
}

a {
  color: #000000;
  text-decoration: none !important;
}

a:hover {
  color: #c11407;
  cursor: pointer;
}

/* フォント */

.iroha {
  font-family: "irohamaru", sans-serif !important;
  font-weight: 500;
}

.zen-m {
  font-family: "zen-maru-gothic", sans-serif !important;
  font-weight: 500;
}

.zen-mb {
  font-family: "zen-maru-gothic", sans-serif !important;
  font-weight: 700 !important;
}

.zen-bb {
  font-family: "zen-maru-gothic", sans-serif !important;
  font-weight: 900 !important;
}

.taku {
  font-family: "tk-takumi-yururi-font-mini", sans-serif !important;
  font-weight: 800;
}

.fc-white {
  color: #fff !important;
}

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

.fc-yellow {
  color: #ffd37a !important;
}

.fc-brown {
  color: #462004 !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-brown {
  border: 1px solid #5e3505;
}

.bl-brown {
  border-left: 1px solid #5e3505;
}

.br-brown {
  border-right: 1px solid #5e3505;
}

.bb-brown {
  border-bottom: 1px solid #5e3505;
}

.bt-brown {
  border-bottom: 1px solid #5e3505;
}

/* ボタン */

.button-wrap,
.button-wrap2 {
  position: relative;
  width: 250px;
  height: 64px;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* 黄色い影 */
.button-shadow,
.button-shadow2 {
  position: absolute;
  width: 100%;
  height: 55px;
  background: #ffbb33;
  border-radius: 999px;
  bottom: -7px;
  left: 0;
  z-index: 0;
}

/* 背景SVG */
.button-bg,
.button-bg2 {
  position: absolute;
  width: 100%;
  z-index: 2;
  transition: all 0.3s;
}

.button-wrap p,
.button-wrap2 p {
  position: relative;
  z-index: 3;
  font-size: 14px;
  transition: all 0.3s;
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 500;
}

/* hover：背景SVGだけ15px下げて影に重ねる */
.button-wrap:hover .button-bg,
.button-wrap2:hover .button-bg2 {
  transform: translateY(8px);
}

.button-wrap:hover p,
.button-wrap2:hover p {
  transform: translateY(8px);
}

@media (min-width: 768px) {

  /* 黄色い影 */
  .button-shadow {
    width: 100%;
    height: 50px;
    bottom: -8px;
  }

  .button-wrap p,
  .button-wrap2 p {
    font-size: 18px;
  }

  /* hover：背景SVGだけ15px下げて影に重ねる */
  .button-wrap:hover .button-bg,
  .button-wrap2:hover .button-bg2 {
    transform: translateY(15px);
  }

  .button-wrap:hover p,
  .button-wrap2:hover p {
    transform: translateY(15px);
  }
}

.inst-button {
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 5.758px;
  border: 2.159px solid #462004;
  width: 164px;
  padding: 8px 23px;
  transition: all 0.3s;
}

.inst-button2 {
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 5.758px;
  border: 2.159px solid #462004;
  width: 240px;
  padding: 8px 23px;
  transition: all 0.3s;
}

@media (min-width: 768px) {
  .inst-button,
  .inst-button2 {
    padding: 14px 23px;
  }
}

.inst-button div {
  display: flex;
  align-items: center;
  justify-content: center;
}

.inst-button p,
.inst-button2 p {
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 900;
  font-size: 16px;
  color: #462004 !important;
}

.inst-button-logo {
  width: 18px;
  height: 18px;
}

.inst-button:hover,
.inst-button2:hover {
  background-color: #ffd279;
  color: #462004 !important;
}

.button.is-free {
  width: auto;
  padding: 0 36px;
}

/* ナビ */

.a-nav-menu {
  display: none;
  opacity: 0;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 900;
  justify-content: end;
  align-items: center;
  transition: all 0.3s;
  background: rgba(102, 42, 0, 0.5);
}

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

.a-nav-box {
  background: #662a00;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100vh;
  overflow-y: auto; /* はみ出したら縦スクロール */
}

.a-nav-list {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: start;
}

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

.a-nav-list .title {
  font-size: clamp(1rem, 0.757rem + 1.05vw, 1.75rem);
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 900;
  color: #ffd279 !important;
  transition: all 1s;
}

.a-nav-list .list {
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 900;
  color: #fff !important;
  transition: all 1s;
}

.a-nav-menu a:hover p {
  color: var(--red);
}

.top-logo {
  max-width: 180px;
}

.nav-logo {
  max-width: 160px;
}

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

.menu-box > a:not(:last-child) {
  margin-bottom: 12px;
}

@media (min-width: 768px) {
  .a-nav-box {
    width: 60%;
  }
}

@media (min-width: 992px) {
  .nav-logo {
    max-width: 160px;
  }

  .a-nav-box {
    width: 40%;
  }

  .menu-box {
    display: block;
  }

  .menu-box > a:not(:last-child) {
    margin-bottom: 0;
    margin-right: 12px;
  }
}

.reserve-button {
  position: fixed;
  bottom: 30px;
  right: 0;
  width: 142px;
  transition: all 0.3s;
  transform-origin: right;
  z-index: 700;
}

.reserve-button:hover {
  transform: scale(1.05);
}

.a-burger {
  position: fixed;
  top: 25px;
  right: 25px;
  z-index: 1100;
  width: 45px;
  height: 53px;
  cursor: pointer;
  margin: 0;
  padding: 0;
  background-image: url(../images/burger.svg);
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
}

.a-burger.is-active {
  background-image: url(../images/burger-clo.svg);
}

@media (min-width: 768px) {
  .a-burger {
    top: 10px;
    right: 25px;
    z-index: 1100;
    width: 55px;
    height: 106px;
  }
}

.nav-tel-link {
  max-width: 200px;
}

/* フッター */

.foot-posi {
  display: flex;
  flex-direction: column;
}

.acces-box {
  position: relative;
  background-color: #fff;
  border-radius: 20px;
  padding: 2.8rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: start;
  flex: 1 1 0; /* ★横幅が縮む・同じ比率で並ぶ */
  min-width: 0; /* ★はみ出し防止 */
}

.acces-box2 {
  position: relative;
  background-color: #fff;
  border-radius: 20px;
  padding: 2.8rem;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  min-width: 0; /* ★はみ出し防止 */
}

@media (min-width: 768px) {
  .foot-posi {
    display: flex;
    flex-direction: row;
  }

  .acces-box2 {
    width: 70%;
  }
}

.acces-box .deco,
.acces-box2 .deco {
  position: absolute;
  top: -8%;
  right: 4%;
  width: 100%;
  max-width: 80px;
  z-index: 5;
}

@media (min-width: 768px) {
  .acces-box .deco,
  .acces-box2 .deco {
    max-width: 65px;
  }
}

.acces-box .text,
.acces-box2 .text {
  position: relative;
  font-size: clamp(0.75rem, 0.629rem + 0.53vw, 1.125rem);
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 500;
  z-index: 6;
  line-height: 2.6;
}

.foot-posi2 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-image: url(../images/foot-bg.jpg);
  background-size: cover !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  overflow: hidden;
  border-radius: 50px 50px 0 0;
}

@media (min-width: 768px) {
  .foot-posi2 {
    border-radius: 80px 80px 0 0;
  }
}

.foot-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  position: relative;
  padding: 2rem;
  background-color: #fff;
  border-radius: 60px 0 60px 0;
}

.foot-box .deco {
  position: absolute;
  top: -7%;
  right: -2%;
  width: 100%;
  max-width: 120px;
}

.foot-box .logo {
  width: 100%;
  max-width: 212px;
  margin-bottom: 1rem;
}

.foot-list {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 10px;
}

.foot-list .title {
  font-size: clamp(1.25rem, 1.088rem + 0.7vw, 1.75rem);
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 900;
}

.foot-list .list {
  font-size: clamp(0.875rem, 0.754rem + 0.53vw, 1.25rem);
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 900;
}

.foot-list2 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
}

@media (min-width: 768px) {
  .foot-list2 {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 30px;
  }
}

.foot-list2 .title {
  font-size: clamp(1.25rem, 1.088rem + 0.7vw, 1.75rem);
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 900;
}

.foot-deco {
  display: none;
  align-items: center;
  justify-content: center;
  object-fit: contain;
}

@media (min-width: 768px) {
  .foot-deco {
    display: flex;
  }
}

.foot-deco img {
  width: 80%;
  height: auto;
}

.foot-box2 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

@media (min-width: 768px) {
  .foot-box2 {
    flex-direction: row;
  }
}

.foot-box2 .title {
  border: #462004 solid 3px;
  padding: 2.5rem 1.8rem;
  border-radius: 100px;
  font-size: 16px;
  margin-right: 0;
  margin-bottom: 1.5rem;
}

@media (min-width: 768px) {
  .foot-box2 .title {
    margin-right: 1.5rem;
    margin-bottom: 0;
  }
}

.foot-company {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.foot-company h2 {
  font-size: clamp(1rem, 0.919rem + 0.35vw, 1.25rem);
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 900;
}

.foot-company p {
  font-size: clamp(0.75rem, 0.629rem + 0.53vw, 1.125rem);
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 700;
}

.foot-logo {
  max-width: 220px;
}

.foot-insta {
  width: 26px;
}

@media (min-width: 768px) {
  .foot-logo {
    max-width: 250px;
  }
}

/* News表示 */

/* 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: center;
  gap: 20px;
  margin-top: 5rem;
}

.webgene-pagination ul li,
.pagelink p {
  padding: 0 1rem;
}
.webgene-pagination ul li a,
.pagelink p a {
  display: inline-flex !important;
  font-family: "hiragino-mincho-pron", serif;
  width: 230px;
  height: 50px;
  padding: 15px 22px !important;
  align-items: center;
  justify-content: space-between;
  transition: all 0.3s;
  border: 1px solid #fff;
}
.webgene-pagination ul li a:hover,
.pagelink p a:hover {
  cursor: pointer;
  background-color: rgba(255, 255, 255, 0.2);
}

/* Nextボタン */
.webgene-pagination li.next a::after,
.pagelink p.next a::after {
  content: "";
  display: block;
  width: 33px;
  height: 7px;
  background-image: url("../images/arrow.png");
  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: 33px;
  height: 7px;
  background-image: url("../images/arrow-prev.png");
  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;
  }
}

/* ページ共通設定 */

.top-fv {
  position: relative;
  width: 100%;
  height: calc(100vh + 64px);
}

@media (min-width: 992px) {
  .top-fv {
    height: calc(100vh + 120px);
  }
}

.common-fv {
  position: relative;
  width: 100%;
  height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 80px;
  margin-bottom: 50px;
}

.common-fv .deco {
  position: absolute;
  width: 42%;
  max-width: 370px;
  top: -5%;
  right: -2%;
}

@media (min-width: 768px) {

  .common-fv {
    position: relative;
    width: 100%;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 0;
    margin-bottom: 0;
  }

  .common-fv .deco {
    position: absolute;
    width: 30%;
    max-width: 370px;
    top: 11%;
    right: 3%;
  }
}

.top-fv-bg-l {
  position: absolute;
  width: 80%;
  max-width: 950px;
  top: 0;
  left: -20%;
}

.top-fv-bg-r {
  position: absolute;
  width: 80%;
  max-width: 960px;
  bottom: 0%;
  right: -20%;
}

@media (min-width: 768px) {
  .top-fv-bg-l {
    width: 85%;
    left: -22%;
  }

  .top-fv-bg-r {
    width: 85%;
    bottom: 0%;
    right: -27%;
  }
}

@media (min-width: 992px) {
  .top-fv-bg-l {
    width: 80%;
    top: 0;
    left: -18%;
  }

  .top-fv-bg-r {
    width: 80%;
    bottom: 0%;
    right: -18%;
  }
}

@media (min-width: 1200px) {
  .top-fv-bg-l {
    width: 60%;
    top: 0;
    left: -10%;
  }

  .top-fv-bg-r {
    width: 60%;
    bottom: 0%;
    right: -10%;
  }
}

.top-fv-wrap {
  position: relative;
  display: flex;
  justify-content: center;
  height: 100%;
  width: 100%;
}

.top-fv-title {
  position: relative;
  top: 47%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  background-image: url("../images/top-fv-bg.svg");
  background-size: 310px;
  background-repeat: no-repeat;
  background-position: center;
  width: 100%;
  height: 100%;
  z-index: 2;
}

.top-fv-title h1 {
  font-family: "irohamaru", sans-serif;
  font-weight: 500;
  font-size: clamp(1.563rem, 0.935rem + 2.71vw, 3.5rem);
  color: var(--red) !important;
  writing-mode: vertical-rl;
  text-orientation: upright;
  white-space: nowrap;
  margin-top: 110px;
  letter-spacing: 0.2em;
}

.top-fv-title p {
  font-family: "irohamaru", sans-serif;
  font-weight: 500;
  font-size: clamp(1.125rem, 0.68rem + 1.93vw, 2.5rem);
  color: var(--brown) !important;
  line-height: 1.2;
  writing-mode: vertical-rl;
  text-orientation: upright;
  white-space: nowrap;
  margin-bottom: 100px;
  letter-spacing: 0.2em;
}

.top-k-logo {
  position: absolute;
  width: 40%;
  max-width: 346px;
  bottom: 10%;
  left: 5%;
}

.top-m-logo {
  position: absolute;
  width: 40%;
  max-width: 346px;
  top: 8%;
  right: 5%;
}

.top-k-logo:hover,
.top-m-logo:hover {
  animation: poyon 0.6s ease;
}

@keyframes poyon {
  0% {
    transform: scale(1);
  }
  30% {
    transform: scale(1.05, 0.95);
  }
  60% {
    transform: scale(0.98, 1.03);
  }
  100% {
    transform: scale(1);
  }
}

.top-fv-deco1 {
  position: absolute;
  max-width: 430px;
  width: 40%;
  top: -3%;
  right: 40%;
  z-index: 5;
}

.top-fv-deco2 {
  position: absolute;
  max-width: 274px;
  width: 30%;
  bottom: 0%;
  left: 40%;
  z-index: 5;
}

@media (min-width: 768px) {
  .top-fv-title {
    background-size: 520px;
  }
  .top-m-logo {
    top: 4%;
  }

  .top-fv-deco2 {
    width: 22%;
    left: 36%;
  }
}

@media (min-width: 992px) {
  .top-fv-title {
    background-size: 600px;
  }
}

@media (min-width: 1200px) {
  .top-fv-title {
    background-size: 500px;
  }

  .top-k-logo {
    bottom: 14%;
    left: 10%;
  }

  .top-m-logo {
    top: 4%;
    right: 10%;
  }

  .top-fv-deco1 {
    width: 20%;
    top: -6%;
    right: 45%;
  }

  .top-fv-deco2 {
    width: 14%;
    bottom: 2%;
    left: 34%;
  }
}

.lh-33 {
  line-height: 3.3 !important;
}

.fs-text {
  font-size: clamp(0.625rem, 0.504rem + 0.53vw, 1rem);
}

.fs-title {
  font-size: clamp(1rem, 0.757rem + 1.05vw, 1.75rem);
}

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

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

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

/* TOP */

.top-sec2-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-image: url("../images/top-sec2-bg.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.top-sec2-deco {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.top-sec2-deco::before {
  content: "";
  position: absolute;
  display: block;
  width: 40%;
  aspect-ratio: 4 / 3;
  background-image: url("../images/top-sec2-kushi.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  top: -18%;
  right: -6%;
  z-index: 0;
}

@media (min-width: 768px) {
  .top-sec2-deco::before {
    width: 30%;
    max-width: 400px;
    top: -18%;
    right: 0%;
  }
}

.title-sec {
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 2;
}

@media (min-width: 768px) {
  .title-sec {
    margin-left: 10%;
  }
}

.title-sec h2 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif;
  font-weight: 800;
  letter-spacing: 0em;
  line-height: 1;
  color: #dbb68d;
  font-size: clamp(5rem, 2.57rem + 10.51vw, 12.5rem);
}

.title-sec p {
  font-family: "irohamaru", sans-serif;
  font-weight: 500;
  color: var(--red);
  line-height: 1.5;
  font-size: clamp(0.75rem, 0.426rem + 1.4vw, 1.75rem);
  margin-left: 5px;
}

.title-sec2 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 2;
}

.title-sec2 h2 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif;
  font-weight: 800;
  letter-spacing: 0em;
  line-height: 1;
  color: #dbb68d;
  font-size: clamp(2.5rem, 1.366rem + 4.9vw, 6rem);
}

.title-sec2 p {
  font-family: "irohamaru", sans-serif;
  font-weight: 500;
  color: var(--red);
  line-height: 1.5;
  font-size: clamp(0.625rem, 0.423rem + 0.88vw, 1.25rem);
  margin-left: 5px;
}

.top-sec2-deco2 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.top-sec2-deco2::before {
  content: "";
  position: absolute;
  display: block;
  width: 50%;
  aspect-ratio: 4 / 3;
  background-image: url("../images/top-sec2-oden.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  bottom: 18%;
  left: -18%;
  z-index: 0;
}

@media (min-width: 768px) {
  .top-sec2-deco2::before {
    width: 36%;
    max-width: 360px;
    bottom: -34%;
    left: -4%;
  }
}

@media (min-width: 992px) {
  .top-sec2-deco2::before {
    width: 40%;
    max-width: 360px;
    bottom: -44%;
    left: -3%;
  }
}

.top-sec2-deco3 {
  margin: 0 calc(50% - 50vw);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.top-sec2-deco3 .l {
  width: clamp(400px, 86vw, 895px);
  transform: translateX(-8%);
}

.top-sec2-deco3 .r {
  width: clamp(300px, 60vw, 678px);
  transform: translateX(10%);
  margin-top: 20px;
}

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

  .top-sec2-deco3 .l {
    transform: translateX(-8%);
  }

  .top-sec2-deco3 .r {
    transform: translateX(6%);
    margin-top: 0px;
  }
}

.top-sec3-wrap,
.top-sec4-wrap,
.top-sec5-wrap {
  position: relative;
  width: 100%;
  z-index: 2;
}

.top-sec3-wrap .deco {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 0;
  width: clamp(300px, 66vw, 800px);
}

.top-sec4-wrap .deco {
  position: absolute;
  right: 0px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 0;
  width: clamp(300px, 66vw, 800px);
}

.top-sec3-wrap .bgimg {
  position: absolute;
  display: block;
  top: 60%;
  left: 0%;
  width: 100%;
  max-width: 838px;
  z-index: 0;
}

.top-sec4-wrap .bgimg {
  position: absolute;
  display: block;
  top: 60%;
  right: 0;
  width: 100%;
  max-width: 838px;
  z-index: 0;
}

@media (min-width: 768px) {
  .top-sec4-wrap .deco {
    right: 0px;
  }

  .top-sec3-wrap .bgimg {
    position: absolute;
    width: 66%;
    top: 50%;
    max-width: 900px;
  }

  .top-sec4-wrap .bgimg {
    position: absolute;
    width: 66%;
    top: 50%;
    right: 0%;
    max-width: 838px;
  }
}

.top-sec3-wrap2 {
  position: relative;
  width: 100%;
  background-color: #8a6516;
  background-repeat: no-repeat;
  background-position: center;
  background-size: auto;
}

.top-sec4-wrap2 {
  position: relative;
  width: 100%;
  background-color: #ffd279;
  background-repeat: no-repeat;
  background-position: center;
  background-size: auto;
}

.top-sec3-wrap2 .bg,
.top-sec4-wrap2 .bg {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  width: 100%;
  z-index: 0;
}

.top-sec3-box,
.top-sec4-box {
  width: 100%;
  display: flex;
  flex-direction: column;
}

@media (min-width: 768px) {
  .top-sec3-box {
    width: 100%;
    display: flex;
    flex-direction: row;
  }

  .top-sec4-box {
    width: 100%;
    display: flex;
    flex-direction: row-reverse;
  }
}

.top-sec3-box-l {
  position: relative;
  flex: 1;
  display: flex;
  align-items: end;
  z-index: 3;
  margin-bottom: 25px;
}

.top-sec4-box-l {
  position: relative;
  flex: 1;
  display: flex;
  align-items: end;
  justify-content: start;
  z-index: 3;
  margin-bottom: 25px;
}

.top-sec3-box-r,
.top-sec4-box-r {
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  background-color: #fff;
  border-radius: 80px 0 80px 0;
  z-index: 4;
  overflow: hidden;
  gap: 34px;
  padding: 3.2rem;
}

@media (min-width: 768px) {
  .top-sec3-box-l {
    flex: 4;
    margin-bottom: 0;
  }

  .top-sec4-box-l {
    flex: 4;
    justify-content: end;
    margin-bottom: 0;
  }

  .top-sec3-box-r {
    flex: 5;
    margin-left: 20px;
  }

  .top-sec4-box-r {
    flex: 5;
    margin-right: 20px;
  }
}

.top-sec3-box-r .deco,
.top-sec4-box-r .deco {
  position: absolute;
  bottom: -5%;
  right: -5%;
  width: 95%;
  max-width: 528px;
  z-index: 5;
}

.top-sec3-box-r h2,
.top-sec4-box-r h2 {
  position: relative;
  font-size: clamp(1.5rem, 0.974rem + 2.28vw, 3.125rem);
  font-family: "irohamaru", sans-serif;
  font-weight: 500;
  z-index: 6;
  color: var(--red);
}

.top-sec3-box-r .title,
.top-sec4-box-r .title {
  position: relative;
  font-size: clamp(1rem, 0.676rem + 1.4vw, 2rem);
  font-family: "irohamaru", sans-serif;
  font-weight: 500;
  z-index: 6;
}

.top-sec3-box-r .text,
.top-sec4-box-r .text {
  position: relative;
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 500;
  z-index: 6;
  line-height: 2.6;
}

.top-sec3-box-l .logo,
.top-sec4-box-l .logo {
  width: 70%;
  max-width: 380px;
  z-index: 1;
}

@media (min-width: 768px) {
  .top-sec3-box-l .logo,
  .top-sec4-box-l .logo {
    width: 85%;
  }
}

.top-sec5-wrap .bgimg {
  position: absolute;
  top: 65%;
  left: 0%;
  width: 100%;
  max-width: 930px;
  z-index: 0;
}

@media (min-width: 768px) {
  .top-sec5-wrap .bgimg {
    position: absolute;
    width: 66%;
    top: 70%;
    max-width: 930px;
  }
}

/* 串でん */

.common-fv-img {
  position: relative;
  width: 92%;
  height: 92%;
  transform: translateY(0%);
  overflow: hidden;
  border-radius: 30px;
}

.common-fv-img .bg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}

@media (min-width: 768px) {
  .common-fv-img {
    width: 85%;
    height: 85%;
    transform: translateY(-2%);
  }
}

@media (min-width: 992px) {
  .common-fv-img {
    width: 85%;
    height: 85%;
    transform: translateY(-2%);
  }
}

.common-fv-box {
  position: absolute;
  bottom: -12%;
  left: -5%;
  width: 340px;
  height: 190px;
  background-image: url("../images/fv-title-bg.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (min-width: 768px) {
  .common-fv-box {
    bottom: 10%;
    left: -1%;
    width: 540px;
    height: 290px;
  }
}

@media (min-width: 992px) {
  .common-fv-box {
    bottom: 5%;
    left: 5%;
    width: 640px;
    height: 390px;
  }
}

.common-fv-box .text,
.common-fv-box .text2 {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  transform: translateY(10%);
}

.common-fv-box .text h1,
.common-fv-box .text2 h1 {
  font-family: "irohamaru", sans-serif;
  font-weight: 500;
  font-size: clamp(0.875rem, 0.632rem + 1.05vw, 1.625rem);
  color: var(--red);
  margin-left: 5px;
  margin-bottom: 0px;
}

.common-fv-box .text h2 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif;
  font-weight: 800;
  font-size: clamp(3rem, 1.947rem + 4.55vw, 6.25rem);
  color: #dbb68d;
  margin: 0;
}

.common-fv-box .text2 h2 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif;
  font-weight: 800;
  font-size: clamp(2.25rem, 1.359rem + 3.85vw, 5rem);
  color: var(--red);
  margin: 0;
}

.common-fv .deco2 {
  position: absolute;
  bottom: -20%;
  left: -8%;
  width: 25%;
  max-width: 180px;
}

@media (min-width: 768px) {
  .common-fv .deco2 {
    bottom: 3%;
    left: 4%;
    width: 20%;
  }
}

@media (min-width: 992px) {
  .common-fv .deco2 {
    bottom: 3%;
    left: 4%;
    width: 100%;
  }
}

@media (min-width: 1200px) {
  .common-fv .deco2 {
    left: 4%;
  }
}

.kushi-sec2-box {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
}

.kushi-sec2-text {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 2rem;
  position: relative;
  width: 100%;
  z-index: 3;
}

.kushi-sec2-text .text {
  writing-mode: vertical-rl;
  text-orientation: upright;
  white-space: nowrap;
  font-size: clamp(1.125rem, 0.882rem + 1.05vw, 1.875rem);
  letter-spacing: 0.2em;
  line-height: 3.4;
  color: #462004;
}

.kushi-sec2-text .deco-l {
  position: absolute;
  bottom: -50%;
  left: -7%;
  width: 40%;
  max-width: 406px;
}

.kushi-sec2-text .deco-r {
  position: absolute;
  top: -45%;
  right: -26%;
  width: 50%;
  max-width: 446px;
}

@media (min-width: 768px) {

  .kushi-sec2-text .deco-l {
    bottom: -38%;
    left: -5%;
    width: 35%;
  }

  .kushi-sec2-text .deco-r {
    top: -25%;
    right: -5%;
    width: 35%;
  }
}

@media (min-width: 992px) {

  .kushi-sec2-text .deco-l {
    bottom: -38%;
    left: -5%;
    width: 40%;
  }

  .kushi-sec2-text .deco-r {
    top: -25%;
    right: -10%;
    width: 40%;
  }
}

.kushi-sec2-bg {
  position: relative;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2rem;
}

.kushi-sec2-bg .bg {
  width: 100%;
  border-radius: 20px;
  z-index: 1;
  overflow: hidden;
}

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

.kushi-sec2-bg .logo {
  position: absolute;
  left: 50%;
  bottom: -25%;
  transform: translateX(-50%);
  max-width: 396px;
  width: 40%;
  z-index: 3;
}

@media (min-width: 768px) {
  .kushi-sec2-bg {
    margin-top: 3rem;
  }

  .kushi-sec2-bg .bg {
    width: 85%;
    border-radius: 80px;
  }

  .kushi-sec2-bg .logo {
    position: absolute;
    left: 50%;
    bottom: -15%;
    transform: translateX(-50%);
    max-width: 396px;
    width: 25%;
    z-index: 3;
  }
}

.kushi-sec3-bg1 {
  width: 100%;
  height: 50px;
  position: relative;
  transform: translateY(1px);
}

@media (min-width: 768px) {
  .kushi-sec3-bg1 {
    height: 172px;
  }
}

.kushi-sec3-bg1 img{
  position: absolute;
  bottom: 0;
}

.kushi-sec3-wrap {
  background-color: #8A6516;
  width: 100%;
  position: relative;
  z-index: 1;
}

.man-sec3-wrap {
  background-color: #FFD279;
  width: 100%;
  position: relative;
  z-index: 1;
}

.kushi-sec3-wrap .bg,
.man-sec3-wrap .bg {
  width: 100%;
  position: absolute;
  bottom: 0;
  z-index: 0;
}

.kushi-sec3-box,
.man-sec3-box {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.kushi-sec3-box h2 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif ;
  font-weight: 800;
  font-size: clamp(4rem, 2.866rem + 4.9vw, 7.5rem);
  color: #FFD37A;
  margin-bottom: 2rem;
}

.man-sec3-box h2 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif ;
  font-weight: 800;
  font-size: clamp(4rem, 2.866rem + 4.9vw, 7.5rem);
  color: #662A00;
  margin-bottom: 2rem;
}

.kushi-sec3-box .title1 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif ;
  font-weight: 800;
  font-size: clamp(1.875rem, 1.227rem + 2.8vw, 3.875rem);
  color: #FFD37A;
  margin-bottom: 1.2rem;
}

.man-sec3-box .title1 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif ;
  font-weight: 800;
  font-size: clamp(1.875rem, 1.227rem + 2.8vw, 3.875rem);
  color: #662A00;
  margin-bottom: 1.2rem;
}

.kushi-sec3-box .title2 {
  font-family: "irohamaru", sans-serif ;
  font-weight: 500;
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  color: #FFD37A;
  margin-bottom: 2rem;
}

.man-sec3-box .title2 {
  font-family: "irohamaru", sans-serif ;
  font-weight: 500;
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  color: #662A00;
  margin-bottom: 2rem;
}

.kushi-sec3-box .text {
  font-size: clamp(0.75rem, 0.629rem + 0.53vw, 1.125rem);
  color: #fff;
  line-height: 3.0;
}

.man-sec3-box .text {
  font-size: clamp(0.75rem, 0.629rem + 0.53vw, 1.125rem);
  color: #000;
  line-height: 3.0;
}

.kushi-sec3-box .deco,
.man-sec3-box .deco {
  position: static;
  width: 100%;
  max-width: 776px;
  margin-bottom: 1.2rem;
}

@media (min-width: 768px) {
  .kushi-sec3-box .deco,
  .man-sec3-box .deco {
    position: absolute;
    top: -30%;
    right: -20%;
    width: 70%;
    max-width: 776px;
    margin-bottom: 0;
  }
}

@media (min-width: 992px) {
  .kushi-sec3-box .deco,
  .man-sec3-box .deco {
    right: -14%;
  }
}

.kushi-sec3-img {
  width: 100%;
  max-width: 1000px;
  transform: translateX(-8%);
}

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

.kushi-sec4-wrap {
  width: 100%;
  position: relative;
  z-index: 1;
}

.kushi-sec4-box {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
}

.kushi-sec4-box h2 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif ;
  font-weight: 800;
  font-size: clamp(4rem, 2.866rem + 4.9vw, 7.5rem);
  color: var(--red);
  margin-bottom: 0.8rem;
}

.kushi-sec4-box .title1 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif ;
  font-weight: 800;
  font-size: clamp(1.875rem, 1.227rem + 2.8vw, 3.875rem);
  color: var(--red);
  margin-bottom: 0.8rem;
}

.kushi-sec4-box .title2 {
  font-family: "irohamaru", sans-serif ;
  font-weight: 500;
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  color: var(--red);
  margin-bottom: 2rem;
}

.kushi-sec4-img {
  overflow: hidden;
  width: 100%;
  height: 100%;
}

.kushi-sec4-img img {
  width: 100%;
  height: 100%;
  border-radius: 20px 0 0 20px;
  object-fit: cover;
}

.kushi-sec4-col,
.man-sec4-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.kushi-sec4-col .box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1.2rem 2rem;
  border-radius: 20px 20px 0 0;
  background-color: #FFF;
  width: 100%;
}

.man-sec4-col .box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1.2rem 2rem;
  border-radius: 20px 20px 0 0;
  background-color: #FFE1A4;
  width: 100%;
}


.kushi-sec4-col .box h3,
.man-sec4-col .box h3 {
  font-family: "zen-maru-gothic", sans-serif ;
  font-weight: 700 ;
  font-size: 23px;
  color: var(--red);
  text-align: center;
  margin-bottom: 0;
}

.kushi-sec4-col .box p,
.man-sec4-col .box p {
  font-family: "zen-maru-gothic", sans-serif ;
  font-weight: 700 ;
  font-size: 12px;
  color: #462004;
  text-align: center;
}

@media (min-width: 768px) {

  .kushi-sec4-col .box h3,
  .man-sec4-col .box h3 {
    font-size: 18px;
    white-space: nowrap;
  }

  .kushi-sec4-col .box p,
  .man-sec4-col .box p {
    font-size: 10px;
    white-space: nowrap;
  }
}

@media (min-width: 992px) {
  .kushi-sec4-col .box h3,
  .man-sec4-col .box h3 {
    font-size: 24px;
  }

  .kushi-sec4-col .box p,
  .man-sec4-col .box p {
    font-size: 16px;
    white-space: nowrap;
  }
}

.kushi-sec4-col .bg,
.man-sec4-col .bg {
  overflow: hidden;
  width: 100%;
  height: 100%;
}

.kushi-sec4-col .bg img,
.man-sec4-col .bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0 0 20px 20px;
}

.kushi-sec4-col2 {
  position: relative;
  width: 100%;
}

.kushi-sec4-col2 img {
  position: static;
  width: 97%;
  max-width: 430px;
  margin-top: 1rem;
}

.kushi-sec4-col2 .box {
  width: 100%;
  background-color: #FFF;
  border-radius: 20px;
  overflow: hidden;
  padding: 2rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

@media (min-width: 768px) {

  .kushi-sec4-col2 img {
    position: absolute;
    top: 50%;
    right: 5%;
    transform: translateY(-50%);
    width: 36%;
    margin-top: 0;
  }

  .kushi-sec4-col2 .box {
    padding: 4rem;
  }
}

.kushi-sec4-col2 .box h3 {
  font-size: clamp(1.5rem, 1.217rem + 1.23vw, 2.375rem);
  font-family: "zen-maru-gothic", sans-serif ;
  font-weight: 700 ;
  color: var(--red);
}

.kushi-sec4-col2 .box p {
  font-size: clamp(0.875rem, 0.389rem + 2.1vw, 2.375rem);
  font-family: "zen-maru-gothic", sans-serif ;
  font-weight: 700 ;
  color: var(--brown);
}

.kushi-sec5-wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  position: relative;
  padding: 0 1.5rem;
  z-index: 4;
}

@media (min-width: 768px) {
  .kushi-sec5-wrap {
    flex-direction: row;
  }
}

.kushi-sec5-box-l {
  width: 100%;
  flex: 1;
}

.kushi-sec5-box-l img {
  object-fit: contain;
  object-position: center;
  width: 90%;
  max-width: 698px;
  transform: translateX(20%);
  margin-bottom: 2rem;
}

@media (min-width: 768px) {
  .kushi-sec5-box-l img {
    width: 120%;
    transform: translateX(-25%);
    margin-bottom: 0;
  }
}

.kushi-sec5-box-r,
.man-sec5-box-r {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex: 1;
  margin-right: 8%;
}

.kushi-sec5-box-r h2 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif ;
  font-weight: 800;
  font-size: clamp(4rem, 2.866rem + 4.9vw, 7.5rem);
  color: #FFD37A;
  margin-bottom: 1.2rem;
}

.man-sec5-box-r h2 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif ;
  font-weight: 800;
  font-size: clamp(4rem, 2.866rem + 4.9vw, 7.5rem);
  color: #662A00;
  margin-bottom: 1.2rem;
}

.kushi-sec5-box-r .title1 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif ;
  font-weight: 800;
  font-size: clamp(1.875rem, 1.227rem + 2.8vw, 3.875rem);
  color: #FFD37A;
  margin-bottom: 1.2rem;
}

.man-sec5-box-r .title1 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif ;
  font-weight: 800;
  font-size: clamp(1.875rem, 1.227rem + 2.8vw, 3.875rem);
  color: #662A00;
  margin-bottom: 1.2rem;
}

.kushi-sec5-box-r .title2 {
  font-family: "irohamaru", sans-serif ;
  font-weight: 500;
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  color: #FFD37A;
  margin-bottom: 2rem;
}

.man-sec5-box-r .title2 {
  font-family: "irohamaru", sans-serif ;
  font-weight: 500;
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  color: #662A00;
  margin-bottom: 2rem;
}

.kushi-sec5-box-r .text {
  font-size: clamp(0.75rem, 0.629rem + 0.53vw, 1.125rem);
  color: #fff;
  line-height: 3.0;
}

.man-sec5-box-r .text {
  font-size: clamp(0.75rem, 0.629rem + 0.53vw, 1.125rem);
  color: #000;
  line-height: 3.0;
}

.kushi-sec5-img {
  width: 100%;
  max-width: 1000px;
  transform: translateX(5%);
}

@media (min-width: 768px) {
  .kushi-sec5-img {
    width: 90%;
    transform: translateX(16%);
  }
}

/* フードメニュー */

.food-sec2-box {
  position: relative;
  width: 100%;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.food-sec2-box .bg{
  position: absolute;
  top: 50%;
  transform: translateY(-80%);
  width: 100%;
  z-index: 2;
}


@media (min-width: 768px) {
  .food-sec2-box .bg{
    position: absolute;
    top: 50%;
    transform: translateY(-64%);
    width: 100%;
    z-index: 2;
  }
}

@media (min-width: 1200px) {
  .food-sec2-box .bg{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 100%;
    z-index: 2;
  }
}

.food-sec2-img {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 260px;
  max-height: 534px;
  z-index: 4;
}

.food-sec2-img img {
  width: 100%;
  height: 100%;
  border-radius: 20px;
  object-fit: cover;
}

@media (min-width: 768px) {

  .food-sec2-img {
    width: 90%;
    height: auto;
  }

  .food-sec2-img img {
    border-radius: 40px;
  }
}

.food-sec2-text {
  position: relative;
  background-color: #FFF;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  border-radius: 20px;
  padding: 3rem;
  width: 92%;
  max-width: 850px;
  z-index: 4;
  margin-top: 1rem;
}

.food-sec2-text h2 {
  font-family: "irohamaru", sans-serif ;
  font-weight: 500;
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  color: var(--red);
  line-height: 1.8;
  margin-bottom: 2rem;
}

.food-sec2-text p {
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 500;
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  line-height: 2.6;
  color: #000;
}

@media (min-width: 768px) {
  .food-sec2-text {
    position: relative;
    background-color: #FFF;
    display: flex;
    flex-direction: column;
    align-items: start;
    justify-content: center;
    border-radius: 20px;
    padding: 3rem;
    width: 90%;
    max-width: 850px;
    transform: translateY(-10%);
    z-index: 4;
    margin-left: 1.6rem;
    margin-top: 0;
  }
}

@media (min-width: 992px) {
  .food-sec2-text {
    padding: 3rem;
    width: 68%;
    max-width: 850px;
    transform: translateY(-35%);
    margin-left: 2.4rem;
  }
}

.food-sec3-wrap {
  width: 100%;
  position: relative;
  z-index: 0;
}

.food-sec3-wrap .bg {
  position: absolute;
  z-index: 1;
  width: 85%;
  top: -20px;
  right: -11%;
  max-width: 1000px;
}

@media (min-width: 768px) {
  .food-sec3-wrap .bg {
    position: absolute;
    z-index: 1;
    width: 85%;
    top: -156px;
    right: -11%;
    max-width: 1000px;
  }
}

.food-sec3-title {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.food-sec3-title h2 {
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 500;
  color: var(--red);
  font-size: clamp(1rem, 0.595rem + 1.75vw, 2.25rem);
}

.food-sec3-title p {
  font-family: "tk-takumi-yururi-font-mini", sans-serif ;
  font-weight: 800;
  font-size: clamp(3.75rem, 2.333rem + 6.13vw, 8.125rem);
  color: var(--red);
  line-height: 1;
}

.food-sec3-title2 {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin-bottom: 3rem;
}

@media (min-width: 768px) {
  .food-sec3-title2 {
    align-items: center;
    justify-content: start;
    width: 100%;
    margin-bottom: 3rem;
  }
}

.food-sec3-title2 h2 {
  position: relative;
  font-size: clamp(1.875rem, 1.47rem + 1.75vw, 3.125rem);
  color: var(--red);
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 500;
  z-index: 3;
  line-height: 1.5;
}

.food-sec3-title2 img {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 30%;
  z-index: 1;
  width: 45%;
  max-width: 284px;
}

.food-list {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  z-index: 5;
  margin-bottom: 1.2rem;
}

@media (min-width: 768px) {
  .food-list {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    z-index: 5;
    margin-bottom: 0;
  }
}

.food-list h3 {
  font-size: clamp(1.5rem, 1.257rem + 1.05vw, 2.25rem);
  color: var(--red);
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 500;
}

.food-list p {
  font-size: clamp(0.875rem, 0.673rem + 0.88vw, 1.5rem);
  color: #000;
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 500;
  line-height: 2.0;
}

.food-list .plice  {
  display: flex;
  justify-content: end;
  align-items: end;
}

.food-list .plice p {
  font-size: clamp(1.5rem, 1.257rem + 1.05vw, 2.25rem);
  color: #000;
  font-family: "zen-maru-gothic", sans-serif;
  font-weight: 500;
  line-height: 2.0;
}

.food-list-box {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  z-index: 5;
}

.food-list-box .name {
  font-size: 16px;
  color: #000;
  padding-left: 1rem;
  white-space: nowrap;  
}

.food-list-box .price {
  display: flex;
  align-items: end;
  justify-content: end;
  font-size: 16px;
  color: #000;
  padding-right: 1rem;
  white-space: nowrap;  
}

@media (min-width: 768px) {
  .food-list-box .name {
    padding-left: 2rem;
    font-size: 14px;
  }
  
  .food-list-box .price {
    padding-right: 2rem;
    font-size: 14px;
  }
}

@media (min-width: 992px) {
  .food-list-box .name {
    padding-left: 3rem;
    font-size: 24px;
  }
  
  .food-list-box .price {
    padding-right: 3rem;
    font-size: 24px;
  }
}

.food-sec6-wrap {
  position: relative;
  width: 100%;
  background-color: #8a6516;
  background-repeat: no-repeat;
  background-position: center;
  background-size: auto;
}

.food-sec6-wrap .bg {
  position: absolute;
  width: 100%;
  bottom: 0%;
}

.food-sec6-wrap2 {
  position: relative;
  width: 100%;
  background-color: #FFD279;
  background-repeat: no-repeat;
  background-position: center;
  background-size: auto;
}

.food-sec6-wrap2 .bg {
  position: absolute;
  width: 100%;
  bottom: 0%;
}

.food-sec6-box1 {
  position: relative;
  background-color: #FFF;
  border-radius: 20px;
  padding: 2rem 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 4;
  transform: translateY(-15%);
  width: 92%;
  margin-left: 1rem;
}

@media (min-width: 768px) {
  .food-sec6-box1 {
    padding: 5rem 4rem;
    transform: translateY(-40%);
    width: 100%;
    margin-left: 0;
    align-items: start;
  }
}

.food-sec6-box1 h2 {
  font-family: "zen-maru-gothic", sans-serif ;
  font-weight: 700 ;
  font-size: clamp(1.5rem, 1.136rem + 1.58vw, 2.625rem);
  color: var(--red);
}

.food-sec6-box1 h3 {
  font-family: "zen-maru-gothic", sans-serif ;
  font-weight: 700 ;
  font-size: clamp(1rem, 0.717rem + 1.23vw, 1.875rem);
  color: #462004;
}

.food-sec6-box2 {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: end;
  width: 80%;
  max-width: 850px;
  z-index: 2;
}

.food-sec6-box2 img {
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center;
}

/* アクセス */

.access-wrap {
  width: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

@media (min-width: 768px) {
  .access-wrap {
    width: 100%;
    position: relative;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: start;
  }
}

.store-box {
  position: static;
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 2rem;
}

@media (min-width: 768px) {
  .store-box {
    position: sticky;
    top: 0;
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 2rem;
  }
}

.store-box .text {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.store-box .text h2 {
  font-family: "irohamaru", sans-serif;
  font-weight: 500;
  font-size: clamp(0.875rem, 0.632rem + 1.05vw, 1.625rem);
  color: var(--red);
  margin-left: 5px;
  margin-bottom: 1.2rem;
}

.store-box .text h3 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif;
  font-weight: 800;
  font-size: clamp(3rem, 1.947rem + 4.55vw, 6.25rem);
  color: #dbb68d;
  margin: 0;
}

.store-box p {
  font-size: clamp(0.75rem, 0.629rem + 0.53vw, 1.125rem);
  color: #000;
  line-height: 2.0;
}

.store-img {
  position: relative;
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 2rem;
}

.store-img div{
  width: 100%;
  height: auto;
  max-width: 590px;

}

.store-img img{
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: 40px 0 40px 0;
}

.store-box2 {
  display: flex;
  flex: 3;
  flex-direction: column;
  gap: 2rem;
}

.store-box2 .text {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.store-box2 .text h2 {
  font-family: "irohamaru", sans-serif;
  font-weight: 500;
  font-size: clamp(0.875rem, 0.632rem + 1.05vw, 1.625rem);
  color: var(--red);
  margin-left: 5px;
  margin-bottom: 1.2rem;
}

.store-box2 .text h3 {
  font-family: "tk-takumi-yururi-font-mini", sans-serif;
  font-weight: 800;
  font-size: clamp(3rem, 1.947rem + 4.55vw, 6.25rem);
  color: #dbb68d;
  margin: 0;
}

.store-box2 p {
  font-size: clamp(0.75rem, 0.629rem + 0.53vw, 1.125rem);
  color: #000;
  line-height: 2.0;
}

.store-img2 {
  position: relative;
  display: flex;
  flex: 2;
  flex-direction: column;
  gap: 2rem;
}

.store-img2 div{
  width: 100%;
  height: auto;
}

.store-img2 img{
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.store-name {
  position: relative;
  display: block;
  align-items: center;
  justify-content: center;
}

.store-name h2 {
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
}

.store-name h2::before {
  content: "";
  display: block;
  width: 40px;
  height: 40px;
  background-image: url("../images/ac-deco.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: -70px;
}

.store-name h2::after {
  content: "";
  display: block;
  width: 40px;
  height: 40px;
  background-image: url("../images/ac-deco.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: -70px;
}

.store-name-text {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 80%;
  gap: 2rem;
}

@media (min-width: 768px) {
  .store-name-text {
    width: 65%;
  }
}


.store-name-text p {
  font-size: clamp(0.75rem, 0.629rem + 0.53vw, 1.125rem);
  color: #000;
  line-height: 2.0;
}

.form-privacy {
  border: solid 1px var(--black);
  background-color: white;
  height: 230px;
  overflow-y: auto;
  padding: 40px 30px;
}

.button-con {
  transition: all 0.3s;
  background-color: #fff;
  border: #462004 solid 1px;
  padding: 0.5rem 4rem ;
  color: #462004;
}

.button-con.reset {
  transition: all 0.3s;
  background-color: #a3987c;
  border: #462004 solid 1px;
  padding: 0.5rem 4rem ;
  color: #FFF;
}

.button-con:hover,
.button-con.reset:hover {
  transition: all 0.3s;
  background-color: #662A00;
  color: #FFF;
}


.r-20 {
  border-radius: 20px;
  overflow: hidden;
}

.r-40-lt {
  border-radius: 40px 0 40px 0;
  overflow: hidden;
}

.r-20-t {
  border-radius: 20px 20px 0 0 ; 
  overflow: hidden;
}

.r-20-b {
  border-radius: 0 0 20px 20px;
  overflow: hidden;
}

.r-m {
  margin-top: 1.5rem;
}

@media (min-width: 768px) {
  .r-m {
    margin-top: 0rem;
  }
}

.all-bgimg {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100vh;
  background-image: url("../images/washi-bg.jpg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  z-index: -1;
}

.swiper-slide {
  overflow: hidden;
  border-radius: 20px;
}