/* 共通（全サイト共通の設定） */
/* サイト全体の上下のpadding */
.l-contents__inner {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* フッターとbodyの間の隙間を消す */
.l-footer {
  margin-top: -1px !important;
}

/* 共通（各サイトごとに設定） */
/* 全体の背景カラー */
body {
  background-color: #F5EFE6 !important;
}

/* パーツ */
/* ボタン */
.btn__color-reverse a {
  border: 1px solid transparent;
}

.btn__color-reverse a,
.btn__color-reverse span {
  transition: all 0.3s ease;
}

.btn__color-reverse a:hover {
  filter: none;
  background-color: #fff;
  border: 1px solid #C3A995;
}

.btn__color-reverse a:hover span {
  color: #C3A995;
}

/* テキストデコレーション・リンクの下線 */
.text-decoration--none a {
  text-decoration-color: #0693e3;
}

/* ヘッダーの背景カラー */
.l-header.l-header--center.l-header--sticky-sm {
  background-color: #FDF8F2;
}

/* ファーストビュー */
/* ファーストビューのタイトルに影をつける */
.fv .smb-section__title {
  text-shadow: 2px 1px 5px #1F1F1F;

}

/* ファーストビュー・リード文に影をつける */
.fv .smb-section__body p span {
  text-shadow: 1px 2px 5px #1F1F1F;
}

/* コンセプトセクション */
.concept {
  position: relative !important;
}

.concept__bg-image {
  position: absolute;
  top: -5rem;
  left: calc(50% - 50vw);
  z-index: 0;
}

/* メニューセクション */
.menu {
  position: relative !important;
  z-index: 2;
}

/* バナーにホバーしたら画像拡大 */
.menu__banner img {
  transition: all 0.3s ease;
}

.menu__banner:hover img {
  transform: scale(1.2);
}

/* バナー上の文字の囲み */
.menu__banner .smb-items__banner__body-inner {
  border: 1px solid #6A8CA0;
  /* border: 1px solid #fff; */
  background-color: rgba(0, 0, 0, 0.2);
  padding: 1rem;
}

/* フロー */
/* フロー背景画像 */
.flow {
  position: absolute !important;
}

.flow__bg-image {
  position: absolute;
  top: -200px;
  right: calc(50% - 50vw);
  z-index: -1;
  opacity: 0.5;
}

/* 店舗情報・アクセス */
/* Googleマップを白黒に */
.access {
  position: relative;
}

.access__map {
  filter: grayscale(100%);
}

.access__bg-image {
  position: absolute;
  top: 8rem;
  right: calc(50% - 50vw);
  z-index: 0;
  opacity: 1;
  filter: brightness(0.7);
}

/* 最終CTA */
.reservation .smb-section__subtitle span {
  position: relative;
  z-index: 2;
  padding-left: 1rem;
  padding-right: 1rem;
}

.reservation__box {
  position: relative;
  z-index: 0;
}

/* =========================================================
# フッター
========================================================= */
/*
# 中央寄せ・ボーダー
---------------------------------- */
.l-footer-widget-area__item.c-row__col {
  text-align: center;
  border-left: 1px solid #e3e3e3;
}

@media screen and (max-width: 1023px) {

  .l-footer-widget-area__item.c-row__col {
    text-align: center;
    border-left: none;
  }
}

/*
# 1023以下でロゴ消す・幅70％
---------------------------------- */
@media screen and (max-width: 1023px) {

  .l-footer__body .c-container {
    width: 70%;
  }

  .l-footer__body .c-container .c-site-branding__title {
    display: none;
  }
}

.l-footer__body {
  /* background-color: #333; */
}

/* コピーライト */
/* コピーライト背景 */
.l-footer--footer-4 .l-footer__footer,
.l-footer--footer-5 .l-footer__footer {
  background-color: var(--accent-color);

}

/* コピーライトテキスト */
.l-footer--footer-4 .l-footer__footer,
.l-footer--footer-5 .l-footer__footer .c-copyright {
  color: #fff;
  background-color: var(--accent-color);
}

/* コピーライトテキスト中央寄せ */
.l-footer__footer .c-row {
  justify-content: center;
}


/* ----------------------------透かし文字マーキーを乗せるセクション */
/* =========================
  透かし文字マーキー
========================= */

/* 親 */
.wm-marquee {
  position: relative;
  /* overflow: hidden; */
  height: 160px;
  width: 100vw;

  /* container制限を突破して画面端まで */
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

/* レーン */
.wm-marquee__track {
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  z-index: 1;
}

/* 流れる部分 */
.wm-marquee__run {
  display: flex;
  width: max-content;
  will-change: transform;
  animation: wm-run 60s linear infinite;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}

/* 文字 */
.wm-marquee__run>span {
  display: inline-block;
  white-space: nowrap;
  padding-right: 1rem;
  /* ←端まで詰めるなら小さめ */
  font-size: clamp(48px, 6vw, 120px);
  font-weight: 800;
  letter-spacing: .12em;

  color: transparent;
  -webkit-text-stroke: 1px rgba(255, 255, 255, .55);

  backface-visibility: hidden;
  transform: translateZ(0);
}

@keyframes wm-run {
  from {
    transform: translate3d(0, 0, 0);
  }

  to {
    transform: translate3d(-50%, 0, 0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .wm-marquee__run {
    animation: none;
  }
}

@media (max-width: 600px) {
  .wm-marquee {
    height: 120px;
  }

  .wm-marquee__run>span {
    font-size: clamp(28px, 8vw, 56px);
    letter-spacing: .10em;
    padding-right: .75rem;
  }
}

.marquee-reverse .wm-marquee__run {
  animation-direction: reverse;
}



/* ============================
  FV PIN + Scroll-lock Reveal
   ============================ */

/* ここで全体サイズを調整（高さがデカい問題はここ触る） */
:root{
  --fv-sticky-top: 5vh;      /* sticky開始位置 */
  --fv-sticky-h: 60vh;       /* 見せたい枠の高さ（90vhにしたければ90vh） */
  --fv-radius: 16px;         /* 角丸 */
  --fv-bg-zoom-from: 1.18;   /* 開始ズーム倍率（小さくしたければ1.10〜1.15） */
  --fv-bg-zoom-dur: 2400ms;  /* ズーム戻りの時間 */
}

/* FV全体：ここが“ピン留め領域” */
.fv-pin{
  position: relative;
  /* 余白がデカい原因になりやすいので min-height は必要最小限に */
  min-height: calc(var(--fv-sticky-top) + var(--fv-sticky-h));
}

/* セクション自体の余計な上下paddingがある場合を抑える（必要なら） */
.fv-pin.wp-block-snow-monkey-blocks-section{
  padding-top: 0;
  padding-bottom: 0;
}

/* 画像＋文字の「見える枠」：stickyで固定 */
.fv-pin .smb-section__inner{
  position: sticky;
  top: var(--fv-sticky-top);
  height: var(--fv-sticky-h);
  display: flex;
  align-items: center;
  overflow: hidden;
  border-radius: var(--fv-radius);
}

/* Snow Monkeyのcontainerが幅制限してると“端まで”にならないので100%化 */
.fv-pin .smb-section__inner > .c-container{
  max-width: none;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

/* 文字レイヤーを前に */
.fv-pin .smb-section__contents-wrapper{
  position: relative;
  z-index: 2;
}

/* 背景画像ズーム */
.fv-pin .smb-section__bgimage,
.fv-pin .smb-section__bgimage img,
.fv-pin .smb-section__bgimage video{
  will-change: transform;
}

/* 初期ズーム（ロード直後は大きめ） */
.fv-pin .smb-section__bgimage{
  transform: scale(var(--fv-bg-zoom-from));
  transition: transform var(--fv-bg-zoom-dur) cubic-bezier(.2,.7,.2,1);
}

/* 文字が動き出したらズームを戻す */
.fv-pin.zoom-start .smb-section__bgimage{
  transform: scale(1);
}

/* 文字が一瞬出る問題対策：JS準備が終わるまで隠す */
.fv-pin .smb-section__title,
.fv-pin .smb-section__body{
  visibility: hidden;
}
.fv-pin.is-ready .smb-section__title,
.fv-pin.is-ready .smb-section__body{
  visibility: visible;
}

/* 1文字ずつの表示（charに分割して is-on で点灯） */
.fv-pin .js-char-split .char{
  display: inline-block;
  opacity: 0;
  transform: translate3d(0, 18px, 0);
  filter: blur(10px);
  will-change: transform, opacity, filter;
  color: #fff; /* 黒くなる問題はここで完全に潰す */
  transition:
    opacity .45s ease,
    transform .7s cubic-bezier(.2,.7,.2,1),
    filter .7s ease;
}
.fv-pin .js-char-split .char.is-on{
  opacity: 1;
  transform: translate3d(0,0,0);
  filter: blur(0);
}

/* FVタイトルサイズ */
.fv-pin .smb-section__title{
  font-size: clamp(44px, 6vw, 110px);
  line-height: 1.08;
  font-weight: 700;
  margin: 0;
}

/* FVリード文 */
.fv-pin .smb-section__body{
  font-size: clamp(18px, 1.8vw, 28px);
  line-height: 1.7;
  font-weight: 500;
  color: #fff;
  margin-top: 16px;
}

/* タイトルをもう少し上へ（ここで調整） */
.fv-pin .smb-section__header{
  margin-top: -18px; /* 上げたいなら -30px とかに */
}

/* 省エネ設定 */
@media (prefers-reduced-motion: reduce){
  .fv-pin .smb-section__inner{ position: static; height: auto; }
  .fv-pin .smb-section__bgimage{ transform: none !important; transition: none !important; }
  .fv-pin .js-char-split .char{ opacity: 1; transform: none; filter: none; transition: none; }
  .fv-pin .smb-section__title,
  .fv-pin .smb-section__body{ visibility: visible; }
}

/* SPは高さを少し縮める（必要なら） */
@media (max-width: 600px){
  :root{
    --fv-sticky-top: 3vh;
    --fv-sticky-h: 74vh;
    --fv-radius: 12px;
    --fv-bg-zoom-from: 1.12;
  }
  .fv-pin .smb-section__header{ margin-top: -8px; }
}

.fv-pin .smb-section__contents-wrapper{
  padding-left: clamp(18px, 4vw, 72px);
  padding-right: clamp(18px, 3vw, 48px); /* 右も少しあると綺麗 */
}

.fv-pin .smb-section__header{
  margin-top: -200px;
}



/* --------------------------
  tak ファーストビュー
-------------------------- */

.fv-slider-wrap {
  --fv-h: 58vh;
  --fv-min-h: 340px;
  --fv-max-h: 560px;
  position: relative;
  overflow: hidden;
}

/* タブレット以上 */
@media (min-width: 768px) {
  .fv-slider-wrap {
    --fv-h: 72vh;
    --fv-min-h: 520px;
    --fv-max-h: 90vh;
  }
}

/* PC */
@media (min-width: 1025px) {
  .fv-slider-wrap {
    --fv-h: 90vh;
    --fv-min-h: 520px;
    --fv-max-h: 920px;
  }
}

/* 小さめスマホ */
@media (max-width: 480px) {
  .fv-slider-wrap {
    --fv-h: 54vh;
    --fv-min-h: 300px;
    --fv-max-h: 460px;
  }
}

/* FVはスライド全体の高さを先に決める */
.fv-slider-wrap .smb-spider-slider,
.fv-slider-wrap .spider,
.fv-slider-wrap .spider__canvas,
.fv-slider-wrap .spider__slide,
.fv-slider-wrap .smb-spider-slider__figure-wrapper {
  height: clamp(var(--fv-min-h), var(--fv-h), var(--fv-max-h)) !important;
  min-height: 0 !important;
  max-height: none !important;
}

/* Spiderが inline style で高さを持つ場合にも上書き */
.fv-slider-wrap .spider__canvas[style] {
  height: clamp(var(--fv-min-h), var(--fv-h), var(--fv-max-h)) !important;
}

/* 画像ラッパー */
.fv-slider-wrap .smb-spider-slider__figure-wrapper {
  overflow: hidden;
  line-height: 0;
}

/* スライド本体 */
.fv-slider-wrap .smb-spider-slider .spider__slide {
  position: relative;
  overflow: hidden;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
}

/* オーバーレイ */
.fv-slider-wrap .smb-spider-slider .spider__slide::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    rgba(0, 0, 0, 0.38),
    rgba(0, 0, 0, 0.22)
  );
  pointer-events: none;
  z-index: 1;
}

@media (max-width: 767px) {
  .fv-slider-wrap .smb-spider-slider .spider__slide::after {
    background: linear-gradient(
      rgba(0, 0, 0, 0.42),
      rgba(0, 0, 0, 0.26)
    );
  }
}

/* 画像は親の高さを埋める */
.fv-slider-wrap .smb-spider-slider img.spider__figure {
  display: block;
  width: 100%;
  height: 100% !important;
  min-height: 100% !important;
  max-height: none !important;
  object-fit: cover;
  object-position: center center;
  transform: scale(1.03);
  transform-origin: center center;
  transition: transform 7s linear;
  will-change: transform;
}

/* アクティブスライドのみズーム */
.fv-slider-wrap .smb-spider-slider .spider__slide[data-active="true"] img.spider__figure {
  transform: scale(1.12);
}


/* ======================================
  ファーストビュー縦コピー
====================================== */

.fv-vertical-copy {
  position: absolute;
  top: 52%;
  left: 50%;
  transform: translate(-50%, -50%);
  writing-mode: vertical-rl;
  text-orientation: mixed;
  z-index: 10;
  pointer-events: none;
  color: rgba(255, 255, 255, 0.95);
  font-family: "Noto Serif JP", serif;
  font-size: clamp(24px, 3.2vw, 40px);
  line-height: 2;
  letter-spacing: 0.18em;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
  opacity: 0;
  animation: fvCopyFadeIn 1.8s ease 0.6s forwards;
}

@media (min-width: 768px) {
  .fv-vertical-copy {
    min-height: 660px;
    font-size: clamp(24px, 3.2vw, 40px);
  }
}

@media (max-width: 767px) {
  .fv-vertical-copy {
    top: 50%;
    left: 50%;
    min-height: 400px;
    font-size: clamp(22px, 2.8vw, 32px);
    line-height: 1.9;
    letter-spacing: 0.14em;
  }
}

@media (max-width: 480px) {
  .fv-vertical-copy {
    font-size: 18px;
    line-height: 1.8;
    letter-spacing: 0.1em;
    top: 63%;
  }
}

@keyframes fvCopyFadeIn {
  0% {
    opacity: 0;
    transform: translate(-50%, -46%);
  }
  100% {
    opacity: 1;
    transform: translate(-50%, -50%);
  }
}

/* ========================================
  料理ギャラリー用：高さリセット
======================================== */
.tak-gallery-slider,
.tak-gallery-slider .smb-spider-slider,
.tak-gallery-slider .spider,
.tak-gallery-slider .spider__canvas,
.tak-gallery-slider .spider__slide,
.tak-gallery-slider .smb-spider-slider__figure-wrapper {
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
}

.tak-gallery-slider .spider__canvas {
  display: flex !important;
  align-items: flex-start !important;
}

.tak-gallery-slider .spider__slide {
  display: block !important;
  flex: 0 0 100% !important;
  align-self: flex-start !important;
  overflow: hidden !important;
}

.tak-gallery-slider .smb-spider-slider__figure-wrapper {
  line-height: 0 !important;
  overflow: hidden !important;
}

.tak-gallery-slider img.spider__figure {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  object-fit: cover !important;
}

/* 中に余計な余白ブロックがある場合の保険 */
.tak-gallery-slider p,
.tak-gallery-slider .wp-block-spacer {
  margin: 0 !important;
}

/* FVスライダーの角丸を消す */
.fv-slider-wrap .spider__slide,
.fv-slider-wrap .smb-spider-slider__figure-wrapper,
.fv-slider-wrap img.spider__figure {
  border-radius: 0 !important;
}


/* ======================================
  ヘッダー
====================================== */

.l-header {
  transition: background-color 0.4s ease, backdrop-filter 0.4s ease;
}

.l-header[data-scrolled="false"] {
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.l-header[data-scrolled="true"] {
  background: rgba(0, 0, 0, 0.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.l-header,
.l-header a,
.c-site-branding__title a,
.c-global-nav a,
.c-drawer__toggle {
  color: #fff;
}

.c-hamburger-btn__bar {
  background-color: #fff;
}


/* 店舗情報・アクセス */
/* Googleマップを白黒に */
.access {
  position: relative;
}
.access__map {
  filter: grayscale(100%);
}

.access__bg-image {
  position: absolute;
  top: 6rem;
  right: calc(50% - 50vw);
  z-index: 0;
  opacity: 1;
}

/* 最終CTA */
.reservation .smb-section__subtitle span {
  position: relative;
  z-index: 2;
  padding-left: 1rem;
  padding-right: 1rem;
}
.reservation__box {
  position: relative;
  z-index: 0;
}