/* =========================
  BASE（SP）
========================= */
:root {
  --bg: #fdfaf5;
  --text: #302210;
  --muted: #6a6a6a;
  /* ★var(--muted)の受け皿（これ重要） */
  --line: #e0ddd8;

  --sans: "Noto Sans JP", sans-serif;
  --serif: "Zen Old Mincho", serif;

  --page: 390px;
  --header-h: 72px;

  --title-mint: #82CBBE;
  --title-line: #C8B8A5;

  --fab-w: 39px;
  --fab-h: 57px;

  --panel-w: 300px;
  --panel-h: 526px;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: var(--sans);
  color: var(--text);
  background: var(--bg);
  line-height: 2;
  letter-spacing: 0.05em;
  /* あなたの最終版に合わせて維持 */
  /* 画面下固定ボタンの高さ分の余白 */
  padding-bottom: 70px;
}


/* 390pxの“実画面” */
.page {
  width: 100%;
  max-width: 390px;
  margin: 0 auto;
  background: var(--bg);
  min-height: 100vh;
}

.footer-sns img,
.menu-sns img,
.header-sns img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

/* =========================
  SNSアイコン：ふわっと浮くホバー（LP準拠）
  リンク要素（<a>）側に transition をかけて、
  アイコン画像ごと浮き上がらせる
========================= */
.footer-sns a,
.menu-sns a,
.header-sns__link {
  display: inline-flex;
  /* ブロック化でtransformが効くように */
  align-items: center;
  justify-content: center;
  -webkit-tap-highlight-color: transparent;
  transition:
    transform 0.25s ease,
    opacity 0.25s ease;
}

/* ホバー：浮く＋少し明るく */
.footer-sns a:hover,
.menu-sns a:hover,
.header-sns__link:hover {
  transform: translateY(-3px);
  /* 3px 上に浮かせる */
  opacity: 1;
}

/* タップ・クリック時：押した感 */
.footer-sns a:active,
.menu-sns a:active,
.header-sns__link:active {
  transform: translateY(0px) scale(0.92);
  opacity: 0.75;
  transition-duration: 0.08s;
}

/* キーボードフォーカス */
.footer-sns a:focus-visible,
.menu-sns a:focus-visible,
.header-sns__link:focus-visible {
  outline: 2px solid #82CBBE;
  outline-offset: 4px;
  border-radius: 4px;
}

/* =========================
  HEADER（SP）
========================= */
.site-header {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: var(--page);
  height: var(--header-h);
  z-index: 200;

  /* 元画像は「背景なし」に見えるので透明 */
  background: transparent;
  border: none;
}

.header-inner {
  position: relative;
  /* ハンバーガー絶対配置用 */
  justify-content: flex-end;
  padding: 14px 14px 0;
}

/* SPはPC用要素を隠す（あなたの仕様維持） */
.brand,
.pc-nav,
.header-sns {
  display: none;
}

/* ハンバーガー（SP：右上固定） */

.hamburger {
  position: absolute;
  top: 14px;
  right: 14px;
  margin: 0;
  width: 32px;
  height: 24px;
  border: none;
  background: transparent;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 0;
  cursor: pointer;
}

.hamburger__line {
  width: 32px;
  height: 2px;
  background: rgba(60, 60, 60, .8);
  border-radius: 1px;
}

/* =========================
  HERO（SP：あなたの最終版に合わせて維持）
========================= */


.hero {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 92vh;
  /* LPと同じ：画面高さの92%（端末ごとに自動調整） */
  min-height: 620px;
  /* 最低620px確保（小さい端末でも潰れない） */
}

.hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* ここが超重要 */
  object-position: center;
}


/* 文字が中でいい感じに配置されるように */
.hero__content {
  position: relative;
  z-index: 1;
  height: 100%;
  display: grid;
  align-content: center;
  padding: 80px 16px;
}

/* タイトル（SP） */
.hero-title {
  position: absolute;
  top: 80px;
  left: 50%;
  transform: translateX(-50%);
  width: 255px;
  height: 70px;
  margin: 0;
  text-align: center;
  font-family: var(--serif);
  font-size: 24px;
  line-height: 35px;
  letter-spacing: 0.10em;
  font-weight: 700;
  color: #FAFAFA;
}

/* 2行固定（崩れ防止） */
.hero-title__line {
  display: block;
  white-space: nowrap;
  /* 1行を折り返さない */
}

/* =========================
  HEROとCONCEPTの間のロゴ
========================= */
.between-logo {
  width: 390px;
  margin: 0 auto;
  margin-top: 100px;
  padding: 80px 80px;
  display: flex;
  justify-content: center;
  background: var(--bg);
}

.between-logo__img {
  width: 180px;
  height: auto;
  display: block;
}

/* =========================
  SECTION（SP）
========================= */
.section {
  padding: 80px 24px;
  /* 最終版の余白に統一 */
  background: var(--bg);
}

.section-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 24px;
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--title-mint);
  margin: 0 auto 64px;
  text-align: center;
}

.section-title::before,
.section-title::after {
  content: "";
  display: block;
  width: 48px;
  height: 1px;
  background: var(--title-line);
}

p {
  margin: 0 0 12px;
}

p:last-child {
  margin-bottom: 0;
}

/* =========================
  CONCEPT（最終版）
========================= */
.concept {
  padding: 96px 24px 120px;
  background: var(--bg);
}

.concept-body {
  text-align: center;
}

.concept-lead {
  font-family: var(--serif);
  font-size: 20px;
  font-weight: 400;
  letter-spacing: 0.08em;
  line-height: 2.2;
  color: #876950;
  margin: 0 0 28px;
}

.concept-title {
  font-family: var(--serif);
  font-size: 19px;
  font-weight: 400;
  letter-spacing: 0.08em;
  line-height: 2.2;
  color: #605B5B;
  margin: 40px 0 20px;
}

.concept-text {
  font-family: var(--serif);
  font-size: 15px;
  letter-spacing: 0.04em;
  line-height: 2.4;
  color: #6a6a6a;
  margin: 0 0 32px;
}

.concept-quote {
  font-family: var(--serif);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 2.4;
  color: #8a6b4e;
  margin: 56px 0 40px;
}

.concept-text:last-of-type {
  margin-bottom: 0;
}

/* =========================
  FLOW（最終版）
========================= */
.flow {
  padding: 96px 24px;
  background: var(--bg);
}

.flow-what {
  margin: 50px 0 22px;
}

.flow-what-jp {
  margin: 0 0 6px;
  font-family: var(--serif);
  font-size: 20px;
  font-weight: 600;
  letter-spacing: .06em;
  color: #876950;
}

.flow-what-en {
  margin: 0;
  font-family: var(--serif);
  font-size: 20px;
  font-weight: 400;
  letter-spacing: .08em;
  color: #876950;
}

.flow-intro {
  margin: 0 0 22px;
}

.flow-text {
  font-family: var(--serif);
  margin: 0 0 20px;
  font-size: 16px;
  letter-spacing: .04em;
  line-height: 2.25;
  color: #6a6a6a;
}

.flow-list {
  display: grid;
  gap: 48px;
}

.flow-item p {
  margin: 0;
}

.flow-item img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
  margin-top: 25px;
  margin-bottom: 14px;
  border-radius: 8px;
  box-shadow: 0 6px 16px rgba(0, 0, 0, .08);
  background: #fff;
}

.flow-step {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin: 0 0 8px;
  font-family: var(--serif);
  color: #876950;
}

.flow-step__num {
  font-family: var(--serif);
  font-size: 33px;
  letter-spacing: .06em;
  margin-top: 10px;
  margin-bottom: 4px;
  line-height: 1;
  font-weight: 300;
  opacity: 0.22;
  letter-spacing: 0.06em;
}

.flow-step__jp {
  font-family: var(--serif);
  font-size: 22px;
  letter-spacing: .06em;
}

.flow-step__en {
  margin: 0 0 12px;
  font-family: var(--serif);
  font-size: 18px;
  letter-spacing: .08em;
  color: #876950;
}

.flow-tag {
  margin: 0 0 12px;
  font-family: var(--serif);
  font-size: 18px;
  letter-spacing: .04em;
  color: #876950;
}

.flow-desc {
  font-family: var(--serif);
  margin: 0 0 15px;
  font-size: 15px;
  line-height: 2.1;
  letter-spacing: .04em;
  color: #6a6a6a;
}

.flow-end {
  margin-top: 56px;
}

.flow-end-lead {
  margin: 0 0 15px;
  font-family: var(--serif);
  font-size: 16px;
  letter-spacing: .12em;
  color: #876950;
  margin-bottom: 150px;
}

.flow-end-title {
  margin: 0 0 15px;
  font-family: var(--serif);
  font-size: 19px;
  letter-spacing: .12em;
  color: #876950;
}


/* =========================
  MENU（SP：あなたの最終版に合わせた状態）
========================= */
.menu-list {
  display: grid;
  gap: 48px;
}

.menu-item {
  position: relative;
  padding: 24px 0 18px;
  border-bottom: none;
}

.menu-photo {
  width: 100%;
  height: 220px;
  overflow: hidden;
  margin-bottom: 14px;
}

.menu-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 8px;
  box-shadow: 0 6px 16px rgba(0, 0, 0, .08);
}

.menu-header {
  margin: 0 0 12px;
  padding-bottom: 12px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  border-bottom: 1px solid var(--line);
}

.menu-name {
  margin: 0;
  font-family: var(--serif);
  font-size: 18px;
  line-height: 1.55;
  letter-spacing: .06em;
  color: #876950;
}

.menu-name .menu-sub {
  display: block;
  margin-top: 6px;
  font-family: var(--serif);
  font-size: 16px;
  letter-spacing: .12em;
  font-weight: 400;
  color: #876950;
}

.menu-price {
  margin: 0;
  font-family: var(--serif);
  font-size: 16px;
  letter-spacing: .06em;
  color: #876950;
  white-space: nowrap;
}

.menu-price .tax {
  font-size: 12px;
  letter-spacing: .15em;
}

.menu-desc {
  margin: 0;
  font-family: var(--serif);
  font-size: 14px;
  line-height: 2.1;
  letter-spacing: .04em;
  color: #6a6a6a;
}

.menu-name-hand {
  display: block;
  margin-top: 6px;
  font-family: var(--serif);
  font-size: 15px;
  /* FLOWの英字（.flow-step__en）に寄せる */
  letter-spacing: .12em;
  font-weight: 400;
  color: #876950;
}

.menu-sub-hand {
  display: block;
  margin-top: 6px;
  font-family: var(--serif);
  font-size: 13px;
  /* MENU ITEM 4 と同じ */
  letter-spacing: .12em;
  font-weight: 400;
  color: #876950;
}

/* =========================
  STAFF（最終版）
========================= */
.staff {
  padding: 96px 24px 120px;
  background: var(--bg);
}

.staff-photo {
  width: 240px;
  height: 240px;
  margin: 0 auto 28px;
  border-radius: 50%;
  overflow: hidden;
}

.staff-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 0;
  box-shadow: none;
}

.staff-body {
  max-width: 330px;
  margin: 0 auto;
  padding-top: 0;
}

.staff-name {
  margin: 0 0 48px;
  padding-bottom: 12px;
  position: relative;
  text-align: center;
  font-family: var(--serif);
  font-size: 22px;
  letter-spacing: .08em;
  color: #605B5B;
}

.staff-name::after {
  content: "";
  display: block;
  width: 40px;
  height: 1px;
  background: rgba(135, 105, 80, .35);
  margin: 16px auto 18px;
}

.staff-text {
  margin: 0 0 22px;
  font-family: var(--serif);
  font-size: 16px;
  letter-spacing: .04em;
  line-height: 2.35;
  color: #6a6a6a;
}

.staff-text:last-child {
  margin-bottom: 0;
}

/* =========================
  OFFER（最終版）
========================= */
.offer {
  padding: 96px 24px 120px;
  background: var(--bg);
}

.offer-body {
  text-align: center;
}

.offer-card {
  margin: 0 auto 36px;
}

.offer-card img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 12px;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08);
}

.offer .offer-btn--mint {
  width: 312px;
  max-width: 100%;
  height: 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #bfe0d9;
  color: rgba(60, 60, 60, .85);
  text-decoration: none;
  font-family: var(--serif);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: .08em;
  box-shadow: none;
  margin: 0 auto;
}

/* =========================
  Q&A（最終版）
========================= */
.qa {
  padding: 96px 24px;
  background: var(--bg);
}

.qa-list {
  display: grid;
  gap: 16px;
}

.qa-item {
  border: none;
  background: #EDE6DD;
  border-radius: 14px;
  padding: 18px 16px;
}

.qa-q {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-family: var(--serif);
  font-size: 16px;
  letter-spacing: .06em;
  line-height: 1.9;
  color: #876950;
  margin: 0;
}

.qa-q::-webkit-details-marker {
  display: none;
}

.qa-q::before {
  content: "Q.";
  flex: 0 0 auto;
  font-family: var(--serif);
  font-size: 18px;
  letter-spacing: .06em;
  color: #876950;
  margin-right: 2px;
}

.qa-q::after {
  content: "＋";
  flex: 0 0 auto;
  font-size: 22px;
  line-height: 1;
  color: #876950;
  transform: translateY(-1px);
}

.qa-item[open] .qa-q::after {
  content: "－";
}

.qa-a {
  margin-top: 14px;
  background: #F7F3ED;
  border-radius: 12px;
  padding: 14px 14px 16px;
}

.qa-a p {
  margin: 0;
  font-family: var(--serif);
  font-size: 15px;
  letter-spacing: .06em;
  line-height: 2.2;
  color: #6a6a6a;
}

.qa-a p::before {
  content: "---A. ";
  color: #876950;
  font-family: var(--serif);
  letter-spacing: .06em;
}

/* =========================
  ACCESS（最終版）
========================= */
.access {
  padding: 96px 24px;
  background: var(--bg);
}

.access-photo {
  margin: 0 0 18px;
}

.access-photo img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
  border-radius: 8px;
  box-shadow: 0 6px 16px rgba(0, 0, 0, .08);
}

.access-head {
  display: grid;
  gap: 10px;
  margin: 0 0 10px;
}

.access-name,
.access-telrow {
  margin: 0;
  font-family: var(--serif);
  font-size: 18px;
  letter-spacing: .06em;
  color: #605B5B;
}

.access-tel {
  color: inherit;
  text-decoration: none;
}

.access-sep {
  height: 1px;
  background: #d9d2c8;
  margin: 16px 0;
}

.access-text {
  margin: 0 0 18px;
  font-family: var(--serif);
  font-size: 15px;
  letter-spacing: .04em;
  line-height: 2.25;
  color: #6a6a6a;
}

.access-map {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--serif);
  font-size: 14px;
  letter-spacing: .06em;
  color: #605B5B;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 6px;
  margin: 0 0 10px;
}

.access-map__icon {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: #3c3c3c;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  line-height: 1;
}

.access-block {
  display: grid;
  gap: 10px;
  margin: 0;
}

.access-key,
.access-val {
  margin: 0;
  font-family: var(--serif);
  font-size: 15px;
  letter-spacing: .04em;
  color: #6a6a6a;
}

.access-card {
  background: #EDE6DD;
  border-radius: 10px;
  padding: 22px 16px;
}

.access-card__title {
  margin: 0 0 14px;
  text-align: center;
  font-family: var(--serif);
  font-size: 22px;
  letter-spacing: .08em;
  color: #605B5B;
}

.access-card__text {
  margin: 0 0 18px;
  font-family: var(--serif);
  font-size: 15px;
  letter-spacing: .04em;
  line-height: 2.1;
  color: #6a6a6a;
}

.access-card__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  border-radius: 999px;
  background: #bfe0d9;
  color: rgba(60, 60, 60, .85);
  text-decoration: none;
  font-family: var(--serif);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: .06em;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
}



/* =========================
  固定予約ボタン（画面下部・全幅バー）
  ※ LPと同じレイアウト。さらにHPでは画面幅いっぱいに広げる
========================= */

/*
  .fixed-reserve：画面最下部に固定されるバー全体
  - width: 100vw / left: 0 で画面幅いっぱいに広げる
  - transform: none（.page の中央寄せを打ち消す）
*/
.fixed-reserve {
  position: fixed;
  bottom: 0;
  left: 0;
  /* 左端から開始 */
  width: 100%;
  /* 画面幅いっぱい */
  padding: 12px 20px;
  background: #BFE0D9;
  z-index: 9999;
  box-shadow: 0 -6px 20px rgba(0, 0, 0, 0.08);
  box-sizing: border-box;
}

/*
  .fixed-reserve-btn：バー内のボタン
  - max-width を外すことで親の幅いっぱいに広がる
*/
.fixed-reserve-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 46px;
  background: #BFE0D9;
  color: #6a6a6a;
  font-family: var(--serif);
  font-size: 18px;
  letter-spacing: 0.08em;
  text-decoration: none;
  border-radius: 0;
  /* LPと同じ：フラットなバー（角丸なし） */
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: background-color 0.2s ease, transform 0.2s ease;
}

.fixed-reserve-btn:hover {
  background-color: #a8d4cb;
}

.fixed-reserve-btn:active {
  background-color: #8ec9be;
  transform: scale(0.98);
  transition-duration: 0.08s;
}

.fixed-reserve-btn:focus-visible {
  outline: 3px solid #82CBBE;
  outline-offset: 2px;
}

/* =========================
  HAMBURGER OVERLAY（SP）
========================= */
.menu-overlay {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: none;
  background: rgba(0, 0, 0, .10);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}

.menu-overlay.is-open {
  display: block;
}

.menu-panel {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(calc(var(--page)/2 - var(--panel-w)));
  width: var(--panel-w);
  height: var(--panel-h);
  background: #AFCFCA;
  border-radius: 8px;
  display: grid;
  align-content: center;
  justify-items: center;
  padding: 0;
}

.menu-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 55px;
  height: 55px;
  border: none;
  background: transparent;
  font-size: 34px;
  line-height: 0.2;
  color: rgba(60, 60, 60, .65);
  cursor: pointer;
}

.menu-nav {
  margin-bottom: 40px;
  display: grid;
  gap: 22px;
  justify-items: center;
  text-align: center;
}

.menu-link {
  font-family: var(--serif);
  font-size: 16px;
  line-height: 20px;
  letter-spacing: .18em;
  text-decoration: none;
  color: rgba(60, 60, 60, .70);
}

.menu-sns {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 56px;
  display: flex;
  justify-content: center;
  gap: 18px;
}

.menu-sns img {
  width: 24px;
  height: 24px;
  display: block;
  opacity: .9;
}

html.is-menu-open {
  overflow: hidden;
}


/* =========================
  FOOTER（SP：最終版）
========================= */
.site-footer {
  background: var(--bg);
  padding: 96px 24px 40px;
}

.footer-inner {
  max-width: var(--page);
  margin: 0 auto;
  text-align: center;
}

.footer-logo img {
  width: 180px;
  height: auto;
  margin: 0 auto 64px;
  display: block;
}

.footer-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px 80px;
  justify-content: center;
  margin-bottom: 48px;
}

.footer-nav-col {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-nav-col li {
  margin-bottom: 22px;
}

.footer-nav-col a {
  font-family: var(--serif);
  font-size: 14px;
  letter-spacing: 0.18em;
  text-decoration: none;
  color: #6a6a6a;
  /* ヘッダーと同じ：色変化をなめらかにする */
  transition: color 0.2s ease;
}

/* ホバー：ヘッダーと同じミントグリーンに変化 */
.footer-nav-col a:hover {
  color: var(--title-mint); /* #82CBBE */
}

.footer-sns {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-bottom: 32px;
}

.footer-sns img {
  width: 28px;
  height: 28px;
  opacity: 0.85;
}

.footer-copy {
  font-family: var(--serif);
  font-size: 12px;
  letter-spacing: 0.12em;
  color: #6a6a6a;
  margin: 0;
}




/* =========================
   ボタン共通：ふわっと演出
========================= */
/*
  ボタン共通インタラクション
  -webkit-tap-highlight-color：iOSのタップ青ハイライトを無効化して自前のactiveで代替
  -webkit-touch-callout：iOSで border-radius 角のタップ漏れを防ぐ
*/
.btn-float {
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
  cursor: pointer;
  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease,
    background-color 0.2s ease,
    color 0.2s ease;
}

/* PC：マウスオーバー（浮く＋ミントが濃くなる） */
.btn-float:hover {
  background-color: #a8d4cb;
  transform: translateY(-3px);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12);
}

/* キーボードフォーカス（Tabキー操作・アクセシビリティ） */
.btn-float:focus-visible {
  outline: 3px solid #82CBBE;
  outline-offset: 3px;
  transform: translateY(-3px);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12);
}

/* タップ・クリック時（押した瞬間：沈む＋さらに濃く） */
.btn-float:active {
  background-color: #8ec9be;
  transform: translateY(1px) scale(0.98);
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.12);
  transition-duration: 0.08s;
}



/* レスポンシブ */
/* =========================================================
   PC OVERRIDE（SPは変えない：768px〜だけ上書き）
   ========================================================= */
@media (min-width: 768px) {

  /* ========== 0) 全体の背景（ここが唯一の正） ========== */
  body {
    background: #FDFAF5;
  }

  /* ページ全体の“箱” */
  .page {
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 50px;
    /* ← 両サイド余白（好みで60〜120） */
    background: transparent;
    /* ← body背景を見せる（ズレ防止） */
  }

  /* セクション共通：上下余白だけ（左右は.pageが担当） */
  .section {
    padding: 80px 0;
    background: transparent;
    /* ← セクションは基本“塗らない” */
  }

  /* ✅ HEROだけは画面いっぱい（フルブリード） */
  .hero {
    width: 100vw;
    max-width: none;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    /* LPと同じ：ブラウザの表示領域いっぱいに広げる */
    height: 100vh;
    /* ブラウザのアドレスバーなどを除いた実際の表示高さ（iOS Safari対策） */
    height: 100dvh;
    min-height: 700px;
    /* 極端に短いウィンドウでも最低限の高さを確保 */
  }

  /* HERO内の角丸は無し */
  .hero__video {
    border-radius: 0;
  }

  /* ✅ 重要：MENUだけ色が違う問題の根本対策 */
  .section.menu {
    background: transparent !important;
    /* ← .menu に背景指定が残ってても勝つ */
  }

  /* ヘッダー */
  /* ヘッダー全体をPC幅に */
  .site-header {
    width: 100%;
    max-width: 1440px;
  }

  .header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 18px 80px 0;
  }

  /* PC（768px〜）：ロゴ左 / ナビ中央 / SNS右、ハンバーガー非表示 */

  /* PCで表示 */
  .brand,
  .pc-nav,
  .header-sns {
    display: flex;
    align-items: center;
  }


  /* ナビ（中央寄せ） */
  .pc-nav {
    flex: 1 1 auto;
    justify-content: right;
    gap: 28px;
  }

  .pc-nav__link {
    font-family: var(--serif);
    font-size: 14px;
    letter-spacing: 0.12em;
    color: rgba(60, 60, 60, 0.75);
    text-decoration: none;
    white-space: nowrap;
  }

  /* ナビリンク：ホバーでミントグリーンに色変化（LPと同じ） */
  .pc-nav__link {
    transition: color 0.2s ease;
  }

  .pc-nav__link:hover {
    color: var(--title-mint);
    /* #82CBBE */
    opacity: 1;
  }

  /* SNS（右） */
  .header-sns {
    flex: 0 0 auto;
    gap: 10px;
  }

  .header-sns__link img {
    width: 30px;
    height: 22px;
    display: block;
    opacity: 0.85;
  }

  /* PCではハンバーガーを消す */
  .hamburger {
    display: none;
  }

  /* ---- タイポ（仕様メモ：PCサイズ） ---- */
  p.concept-text,
  .flow-text {
    font-size: 18px;
    line-height: 2.2;
    letter-spacing: 0.02em;
    color: #605B5B;
    font-family: var(--serif);
  }

  h1.hero-title {
    font-size: 38px;
    font-weight: 700;
    color: #FAFAFA;
    letter-spacing: 0.08em;
    line-height: 60px;
    font-family: var(--serif);
    /* 見出し寄せ */
    text-align: left;
    width: auto;
    height: auto;
    top: 23%;
    left: 30%;
    transform: translate(-50%, -50%);
  }

  h2.section-title {
    font-size: 30px;
    font-weight: 700;
    color: #82CBBE;
    letter-spacing: 0.08em;
    margin-bottom: 60px;
    font-family: var(--serif);
  }

  /* 消さない */
  #concept .section-title {
    font-size: 30px;
    font-weight: 700;
    color: #82CBBE;
    letter-spacing: 0.08em;
    margin-bottom: 60px;
    font-family: var(--serif);
  }



  /* HEROとCONCEPT間ロゴ：PCは余白80、中央 */
  .between-logo {
    width: 100%;
    max-width: 1440px;
    padding: 80px 0 0;
  }

  .between-logo__img {
    width: 240px;
  }

  /* =========================
   　CONCEPT：リード文
  　　SP：改行あり / PC：改行なし
    ========================= */
  .concept-lead br {
    display: none;
  }

  h3.concept-lead {
    font-size: 28px;
    line-height: 1.9;
    letter-spacing: 0.02em;
    color: #876950;
    font-family: var(--serif);
    padding: 20px;
  }

  /* フロー */
  /* =========================================================
     FLOW（PC）：横スライド（ABOUT風）最終セット
    ========================================================= */

  /* セクション内の「直下960制限」をFLOWだけ無効化 */
  #flow.section>* {
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .flow-what {
    line-height: 1.9;
    letter-spacing: 0.02em;
    color: #876950;
    font-family: var(--serif);
    padding: 20px;
    text-align: center;
  }

  .flow-what-jp,
  .flow-what-en {
    font-size: 28px;
    line-height: 1.9;
    letter-spacing: 0.02em;
    color: #876950;
    font-family: var(--serif);
  }

  .flow-list {
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    gap: 28px 28px;
  }

  /* カード本体（幅固定でスライド） */
  #flow .flow-item {
    flex: 0 0 960px;
    height: 340px;
    scroll-snap-align: start;
    display: grid;
    grid-template-columns: 1fr 1fr;
    /* 50/50 */
    border-radius: 18px;
    overflow: hidden;
    margin-bottom: 80px;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.04);
  }

  /* 左：画像 */
  #flow .flow-photo {
    width: 100%;
    height: 340px;
    object-fit: cover;
    display: block;
    margin: 0;
  }


  /* 右：本文 */
  #flow .flow-body {
    height: 340px;
    padding: 24px 28px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    justify-content: flex-start;
    overflow: hidden;
    /* はみ出し事故防止 */
  }

  /* 説明が長い時だけスクロール（崩れない保険） */
  #flow .flow-desc {
    overflow: auto;
    padding-right: 8px;
  }



  #flow .flow-step__num {
    font-family: var(--serif);
    font-size: 72px;
    font-weight: 300;
    opacity: 0.22;
    letter-spacing: 0.06em;
  }


  /* 1.は消す（01.を使う） */

  .flow-step__jp {
    font-size: 28px;
    letter-spacing: .06em;
  }

  /* CLEANSING（余白が空きすぎるのを防ぐ） */
  .flow-step__en {
    margin: 0;
    font-family: var(--serif);
    font-size: 18px;
    letter-spacing: .10em;
    color: #876950;
  }

  .flow-tag {
    margin: 0;
    font-family: var(--serif);
    font-size: 18px;
    letter-spacing: .06em;
    color: #876950;
  }

  /* 説明文：高さ内に収める（長文でも崩れない） */
  .flow-desc {
    margin: 0;
    font-family: var(--serif);
    font-size: 16px;
    line-height: 1.9;
    letter-spacing: .02em;
    color: #605B5B;

    /* ✅ はみ出す場合だけ下でスクロール（見た目を崩さない保険） */
    overflow: auto;
    padding-right: 8px;
  }

  .flow-text {
    text-align: center;
    max-width: 1000px;
    /* ← 折り返し幅 */
    margin-left: auto;
    margin-right: auto;
    line-height: 40px;
  }

  .flow-intro {
    margin-top: 50px;
    margin-bottom: 110px;
    /* 余白 */
  }


  .flow-end {
    text-align: center;
  }

  .flow-end-lead {
    font-size: 22px;
    line-height: 2.5;
    letter-spacing: 0.02em;
    color: #876950;
    font-family: var(--serif);
    padding: 20px;
    margin-bottom: 150px;
    margin-top: 40px;
  }

  .flow-end-title {
    font-size: 28px;
    line-height: 1.9;
    letter-spacing: 0.02em;
    color: #876950;
    font-family: var(--serif);
    padding: 20px;
    margin-bottom: 20px;
    margin-top: 40px;
  }

  #flow .flow-photo img {
    transform: scale(1.03);
  }

  /* =========================================================
     FLOW：ジグザグ配置
  ========================================================= */
  /* ずれ量：しっかり動きが出る */
  :root {
    --flow-shift: clamp(80px, 10vw, 200px);
    --flow-y: 22px;
  }

  /* 基本：まず全部0にする */
  #flow .flow-item {
    --x: 0px;
    --y: 0px;
    transform: translate(var(--x), var(--y));
    flex: 0 0 960px !important;
  }

  /* 偶数だけ右＋少し下 */
  #flow .flow-item:nth-child(even) {
    --x: var(--flow-shift);
  }

  /* 2番：少しだけ控えめ（下げないなら --y は触らない） */
  #flow .flow-item:nth-child(2) {
    --x: calc(var(--flow-shift) * 0.9);
    /* 下げたいなら入れる / 不要なら消す */
  }

  /* 4番：少し強め */
  #flow .flow-item:nth-child(4) {
    --x: calc(var(--flow-shift) * 1.2);
  }

  #flow .section {
    padding-left: 0;
    padding-right: 0;
  }



  /* =========================
       MENU（PC）
    ========================= */

  .menu .menu-list {
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 28px 28px;
  }

  .menu-name,
  .menu-price {
    font-size: 20px;
    line-height: 1.9;
    letter-spacing: 0.02em;
    color: #876950;
    font-family: var(--serif);
  }

  .menu-desc {
    margin: 0;
    font-family: var(--serif);
    font-size: 16px;
    line-height: 1.9;
    letter-spacing: .02em;
    color: #605B5B;

    /* ✅ はみ出す場合だけ下でスクロール（見た目を崩さない保険） */
    overflow: auto;
    padding-right: 8px;
  }

  /* 共通：画像 */
  .menu .menu-photo img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    border-radius: 12px;
  }

  /* =========================
       MENU 1枚目 FEATURED（PC幅調整版）
       下3枚の幅感に合わせる
    ========================= */
  .menu .menu-item--featured {
    grid-column: 1 / -1;
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;

    display: grid;
    grid-template-columns: 6.5fr 5.5fr;
    column-gap: 36px;
    row-gap: 0;
    align-items: start;

    padding: 0;
    border: 0;
  }

  /* 左：画像 */
  .menu .menu-item--featured .menu-photo {
    grid-column: 1;
    grid-row: 1 / 3;

    width: 100%;
    height: 360px;
    margin: 0;
    overflow: hidden;
    border-radius: 14px;
  }

  .menu .menu-item--featured .menu-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 14px;
    box-shadow: none;
  }

  /* 右上：情報 */
  .menu .menu-item--featured .menu-info-grid {
    grid-column: 2;
    grid-row: 1;

    display: grid;
    grid-template-columns: minmax(0, 1fr) 170px;
    grid-template-rows: auto auto;
    column-gap: 18px;
    row-gap: 14px;

    align-items: end;
    width: 100%;
    padding: 8px 0 18px;
    border-bottom: 1px solid #ddd6cc;
  }

  /* 左上：タイトル */
  .menu .menu-item--featured .menu-info-grid .menu-name {
    grid-column: 1;
    grid-row: 1;

    margin: 0;
    min-width: 0;

    font-family: var(--serif);
    font-size: 28px;
    font-weight: 400;
    line-height: 1.45;
    letter-spacing: 0.03em;
    color: #876950;

    white-space: nowrap;
  }

  /* 右上：人気NO.1 */
  .menu .menu-item--featured .menu-info-grid .menu-badge {
    grid-column: 2;
    grid-row: 1;

    justify-self: end;
    align-self: center;

    margin: 0;
    padding: 6px 12px;

    font-family: var(--serif);
    font-size: 13px;
    font-weight: 400;
    line-height: 1;
    letter-spacing: 0.04em;

    color: #8f6d54;
    background: #efe5dc;
    border-radius: 6px;

    white-space: nowrap;
  }

  /* 左下：英字 */
  .menu .menu-item--featured .menu-info-grid .menu-sub {
    grid-column: 1;
    grid-row: 2;

    margin: 0;

    font-family: var(--serif);
    font-size: 17px;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: 0.08em;
    color: #8f6d54;

    white-space: nowrap;
  }

  /* 右下：価格 */
  .menu .menu-item--featured .menu-info-grid .menu-price {
    grid-column: 2;
    grid-row: 2;

    justify-self: end;
    align-self: end;

    margin: 0;

    font-family: var(--serif);
    font-size: 18px;
    font-weight: 400;
    line-height: 1.4;
    letter-spacing: 0.02em;
    color: #8f6d54;

    white-space: nowrap;
  }

  .menu .menu-item--featured .menu-info-grid .menu-price .tax {
    font-size: 13px;
    letter-spacing: 0.03em;
  }

  /* 右下：本文 */
  .menu .menu-item--featured .menu-desc {
    grid-column: 2;
    grid-row: 2;

    max-width: 100%;
    margin: 24px 0 0;
    padding-right: 0;

    font-family: var(--serif);
    font-size: 17px;
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.02em;
    color: #605B5B;
  }

  /* 既存保険 */
  .menu .menu-item--featured .menu-header {
    display: block;
    margin: 0;
    padding: 0;
    border: 0;
  }

  /* -------- 下段：小さい3枚 -------- */

  .menu .menu-item--small .menu-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 10px;
    min-height: 120px;
    margin-top: 20px;
    /* ←余計なズレ防止 */
  }

  .menu .menu-item--small .menu-photo {
    height: 190px;
    /* ←ここも調整ポイント */
  }

  /* ▼ 2/3/4（小カード）を同じ設計にする */
  .menu .menu-item--small {
    grid-column: span 4;
    display: grid;
    grid-template-rows: 170px auto 1fr;
    /* 画像 / ヘッダー / 説明 */
    gap: 14px;
    align-items: start;
  }

  /* ヘッダー（タイトル+価格）を縦に並べて中央寄せ */
  .menu .menu-item--small .menu-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    /* 中央揃え */
    text-align: center;
    gap: 10px;
    min-height: 120px;
    /* ★ここで “タイトルブロックの高さ” を揃える */
  }

  /* タイトル（どのクラス名でも同じ扱いにする） */
  .menu .menu-item--small .menu-name,
  .menu .menu-item--small .menu-name-hand {
    margin: 0;
    line-height: 1.4;
    min-height: 3.2em;
    /* ★2行分くらい確保（長い/短い差を吸収） */
  }

  /* サブ（facial remedy など）も同じ扱い */
  .menu .menu-item--small .menu-sub,
  .menu .menu-item--small .menu-sub-hand {
    display: block;
    margin-top: 6px;
    font-size: 14px;
    /* 好みで */
    opacity: 0.9;
  }

  /* 価格は “タイトルの下に必ず来る” */
  .menu .menu-item--small .menu-price {
    margin: 0;
    /* 余白は header の gap で管理 */
    white-space: nowrap;
  }

  /* 説明文：高さと行数を揃える（長文でも崩れない） */
  .menu .menu-item--small .menu-desc {
    margin: 0;
    line-height: 1.9;

    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    /* ★4行で揃える（増減OK） */
    overflow: hidden;

    min-height: calc(1.9em * 4);
    /* ★4行ぶんの高さを確保 */
  }

  /* スタッフ */
  /* staffセクションは直下要素で2カラムにする（.staff-photo と .staff-body） */
  .staff>.staff-photo,
  .staff>.staff-body {
    padding-left: 0;
    padding-right: 0;
  }

  .staff-photo img {
    width: 300px;
    /* ← 今より大きく（例） */
    max-width: 100%;
    border-radius: 50%;
    display: block;
  }


  .staff {
    display: grid;
    grid-template-columns: 400px 1fr;
    column-gap: 64px;
    align-items: center;
    max-width: 1100px;
    margin: 0 auto;
  }


  .staff .section-title {
    grid-column: 1 / -1;
    margin-bottom: 56px;
  }

  .staff-body {
    max-width: none;
    margin: 0;
    padding: 0;
  }

  /* 名前 */
  .staff-name {
    font-family: var(--serif);
    font-size: 25px;
    letter-spacing: 0.08em;
    margin: 0;
    padding-bottom: 16px;
    position: relative;
  }

  .staff-name::after {
    content: "";
    display: block;
    width: 44px;
    height: 1px;
    background: rgba(135, 105, 80, 0.45);
    margin: 14px auto 0;
  }

  .staff-text {
    font-size: 18px;
    line-height: 1.9;
    letter-spacing: 0.02em;
    color: #605B5B;
  }

  .staff-profile {
    text-align: center;
  }

  .staff-profile img {
    width: 300px;
    /* ← 少し大きめ。260〜300で微調整OK */
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    object-fit: cover;
    display: block;
    margin: 0 auto 32px;
    /* ほんのり影 */
    filter: drop-shadow(0 10px 20px rgba(0, 0, 0, 0.12));
  }

  .staff-photo {
    margin-top: 32px;
  }


  /* オファー */
  /* OFFER チケット画像 */
  .offer-body .offer-card img {
    width: 550px;
    /* ← まずはここを調整（340〜380がおすすめ） */
    max-width: 100%;
    height: auto;
    display: block;
    margin: 0 auto;

    border-radius: 12px;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08);
  }

  .offer-body {
    text-align: center;
  }

  /* 親（カード）を広げる：ここが効きます */
  .offer-card {
    width: min(520px, 100%);
    /* 420 / 480 / 520…で調整OK */
    margin: 0 auto 62px;
  }

  /* 画像は親幅にフィットさせる */
  .offer-card img {
    width: 100%;
    max-width: none;
    /* 上限解除 */
    height: auto;
    display: block;
    border-radius: 12px;
    box-shadow: 0 12px 24px rgba(0, 0, 0, .08);
  }

  .offer .offer-btn--mint {
    width: auto;
    padding: 20px 64px;
    /* ← 横方向が特に効く */
    min-width: 360px;

    height: auto;
    font-size: 20px;
  }

  /* Q & A */
  /* ---- Q&A / ACCESS：横幅を整えて“中央に上品” ---- */
  .qa,
  .access {
    padding: 80px 0;
  }

  .qa>*,
  .access>* {
    max-width: 860px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 80px;
    padding-right: 80px;
  }

  .qa-item {
    margin-bottom: 18px;
  }

  .qa-q {
    font-size: 20px;
    line-height: 1.9;
    letter-spacing: 0.02em;
    color: #876950;
    font-family: var(--serif);
  }

  .qa-a p {
    margin: 0;
    font-family: var(--serif);
    font-size: 18px;
    line-height: 1.9;
    letter-spacing: .02em;
    color: #605B5B;
  }


  /* アクセス */

  /* ACCESS 画像 */
  .access-photo img {
    width: 100%;
    max-width: 960px;
    height: auto;
    margin: 0 auto;
    display: block;
    border-radius: 16px;
  }

  /* テキスト中央寄せ */
  .access-head,
  .access-text {
    text-align: center;
  }

  /* Google Maps / 営業時間 / 定休日 を中央寄せ */
  .access-map,
  .access-block p {
    text-align: center;
    font-size: 18px;
  }

  /* Google Maps リンクを中央に */
  .access-map a {
    justify-content: center;
  }

  .access-sep {
    text-align: center;
  }

  .map {
    text-align: center;
  }

  /* フォントサイズ調整 */
  .access-name {
    font-size: 28px;
    letter-spacing: 0.04em;
  }

  .access-telrow {
    font-size: 18px;
  }

  .access-text {
    font-size: 18px;
    line-height: 2;
  }


  /* ご予約カード（一番強調） */
  .access-card {
    max-width: 730px;
    margin-top: 120px;
    padding: 64px 56px;
    text-align: center;
  }

  /* タイトル */
  .access-card__title {
    font-size: 22px;
    /* ← 文字を大きく */
    margin-bottom: 24px;
  }

  /* 説明文 */
  .access-card__text {
    font-size: 18px;
    /* ← PCは少し大きめ */
    line-height: 2;
    margin-bottom: 32px;
  }

  /* ボタン */
  .access-card__btn {
    width: 360px;
    /* ← PCだけ横長 */
    height: 64px;
    margin: 0 auto;
    font-size: 17px;
  }

  /* セクション全体にゆとり */
  .section.access {
    padding: 140px 0;
  }

  /* 写真 */
  .access-photo {
    margin-bottom: 72px;
  }


  /* 区切り線 */
  .access-sep {
    margin: 20px auto;
  }




  /* =========================
   PCだけ：FOOTER 調整
========================= */

  /* フッター全体：中央寄せ＆少し余白 */
  .site-footer {
    padding: 56px 0 48px;
  }

  .footer-inner {
    max-width: 960px;
    /* ここで中央にまとまる */
    margin: 0 auto;
    text-align: center;
    /* 中央寄せ */
  }

  /* ロゴを大きく */
  .footer-logo img {
    width: 250px;
    /* 好みで 120〜180px で調整OK */
    height: auto;
  }

  /* nav を中央寄せ（2カラムを中央に並べる） */
  .footer-nav {
    display: flex;
    justify-content: center;
    /* 中央寄せ */
    gap: 140px;
    /* 左右の列の間隔（好みで調整） */
    margin-top: 28px;
  }

  /* ul のデフォルトを消す */
  .footer-nav-col {
    list-style: none;
    padding: 0;
    margin: 0;
    text-align: center;
  }

  /* 文字を大きく＆行間も整える */
  .footer-nav-col a {
    display: inline-block;
    font-size: 16px;
    /* 14→16 くらいが見やすい */
    letter-spacing: 0.08em;
    line-height: 2.2;
    text-decoration: none;
    /* 下線不要なら */
  }

  /* li間の余白（行間だけで足りなければ） */
  .footer-nav-col li+li {
    margin-top: 12px;
  }

  .footer-logo a {
    display: inline-block;
    transition: transform 0.25s ease, opacity 0.25s ease;
  }

  .footer-logo a:hover {
    transform: translateY(-3px);
    opacity: 0.85;
  }

  /* fixed-reserve：PC（幅の最大値を設定） */
  .fixed-reserve {
    padding: 16px 40px;
  }

  .fixed-reserve-btn {
    /* PCではバー全幅を使う（LPと同じフラットな見た目） */
    max-width: 100%;
    margin: 0;
    height: 52px;
    font-size: 18px;
    border-radius: 0;
    /* LPと同じフラット（丸角なし） */
  }


}