﻿/* Font faces — paths relative to this stylesheet */
@font-face {
  font-family: 'YDWaosagi';
  src: url('assets/fonts/YDWaosagi.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'LINE Seed JP';
  src: url('assets/fonts/LINESeedJP_OTF_Th.woff2') format('woff2');
  font-weight: 100;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'LINE Seed JP';
  src: url('assets/fonts/LINESeedJP_OTF_Rg.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'LINE Seed JP';
  src: url('assets/fonts/LINESeedJP_OTF_Bd.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'LINE Seed JP';
  src: url('assets/fonts/LINESeedJP_OTF_Eb.woff2') format('woff2');
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Alfa Slab One';
  src: url('assets/fonts/AlfaSlabOne-Regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/*
 * =============================================================================
 * 【デザイン調整のしかた】
 *
 * · 調整したいプロパティのブロック（例: .mv__mv-picture--main）に数値を直接書いてください。
 * · MV ロゴ … .mv 内の --mv-corner-inset-*／右上 … :root の --mv-pc-topbar-inset-end／トップに戻る … --mv-pc-page-top-inset-end
 * · 下部バー … タブレット 761〜1024px：--mv-bottom-bar-height（枠の高さ）／--mv-bottom-bar-ig-icon-size（IGだけ）
 * · 下部バー文字 … 同上 @media の .mv__reserve-sub / -main の font-size
 *
 * 【必須】ブレークポイントごとに分けて書く（タブレット修正が SP/PC に波及しないこと）
 * · PC … @media (min-width: 1025px) またはベース（メディアクエリなし）のみ
 * · タブレット … @media (min-width: 761px) and (max-width: 1024px) のみ
 * · スマホ … @media (max-width: 760px) のみ
 * · max-width: 1024px … 下部バー固定など「両方共通のレイアウト」のみ。数値は書かない
 * · タブレットの数値 … @media (min-width: 761px) and (max-width: 1024px) のみ
 * · スマホの数値 … @media (max-width: 760px) のみ
 * · 1024px ブロックで font-size / padding を変えるとスマホにも波及するため禁止
 * · 画面幅に応じて動かすときは clamp(最小px, vw, 最大px) の形だけを使ってください。
 * · position:fixed の UI（.mv__top-bar）は main 直下に置く。他セクションに z-index を
 *   付けて前面に出さない（固定バーがスクロール中だけ消える原因になる）。
 * · セクション見出しなどのオレンジ文言 … --site-orange-text（#f07828）
 * · セクションタイトル（出店ブルワリー等）… 各 @media 内に px 直書き（:root 変数は使わない）
 * =============================================================================
 */
:root {
  --site-orange-text: #f07828;
}

/* メニュー開閉時（body overflow:hidden）でもスクロールバー幅を確保し、横ズレを防ぐ */
html {
  scrollbar-gutter: stable;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 700;
}

.mv__visually-hidden {
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  inline-size: 1px;
  block-size: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

.mv {
  position: relative;
  isolation: isolate;
  z-index: 1; /* 下部 .site-bg より前面 */
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
  min-height: 100svh;
  padding-inline: clamp(12px, 4vw, 44px);
  /* 上／下 は別々に変更したければ、この2つの clamp をそれぞれ編集 */
  padding-block:
    clamp(12px, 3vw, 30px)
    clamp(20px, 5vw, 52px);
  /* フォールバック色（本番の背景レイヤーは .mv__mv-bg） */
  background-color: #6ec7f5;
  overflow: hidden;
  /* ロゴ・右上ボタン（上／左／右を個別に調整可。1024px以下は各 @media で上書き） */
  --mv-corner-inset-top: 32px;
  --mv-corner-inset-inline-start: 32px;
  --mv-corner-inset-inline-end: 32px;
}
.mv__logo-mark {
  position: absolute;
  z-index: 5;
  /* 右上 .mv__top-bar と同じ上位置（ボタン上辺＝セーフエリア込み） */
  inset-block-start: calc(var(--mv-corner-inset-top) + env(safe-area-inset-top, 0px));
  inset-inline-start: calc(var(--mv-corner-inset-inline-start) + env(safe-area-inset-left, 0px));
  width: clamp(32px, 6.4vw, 56px);
  height: auto;
  pointer-events: none;
}

.mv__shell {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  gap: clamp(10px, 3vw, 30px);
  /* ヒーロー列（リボン＋MVクラスタ）の最大幅 */
  inline-size: min(1560px, 100%);
  margin-inline: auto;
}

/*
 * 予約・Instagram（main 直下配置）
 * position:fixed ＋ z-index で全ページ最前面。親 .mv 内に置くと
 * .lead / .brewery の z-index に隠れてスクロール中だけ消える。
 * PC右上レイアウト切替 … mv__top-bar--side-vertical（index.html 参照）
 */
.mv__top-bar {
  /* main 直下（.mv の外）のため、位置用変数は .mv__top-bar 自身または :root で定義 */
  --mv-corner-inset-top: 32px;
  --mv-corner-inset-inline-end: 32px;
  position: fixed;
  inset-inline-end: calc(var(--mv-corner-inset-inline-end, 32px) + env(safe-area-inset-right, 0px));
  inset-block-start: calc(var(--mv-corner-inset-top, 32px) + env(safe-area-inset-top, 0px));
  z-index: 10000;
  display: flex;
  justify-content: flex-end;
  pointer-events: none;
}

.mv__top-bar > * {
  pointer-events: auto;
}

/* スマホ：子要素は従来どおり独立配置（ハンバーガーは下部バー外） */
.mv__top-bar-cluster {
  display: contents;
}

.mv__actions-area {
  position: relative;
}

.mv__actions-group {
  display: flex;
  align-items: center; /* 予約ボタンと Instagram を天地中央で揃える */
  gap: 12px;
}

/*
 * PC（1025px以上）右上 CTA — 縦並び（添付2）
 * 横並び（添付1）に戻す … index.html から mv__top-bar--side-vertical を外す
 * 縦並び時 … 画面右・天地中央に fixed（--mv-side-vertical-inset-end で左右位置）
 */
@media (min-width: 1025px) {
  :root {
    --mv-side-vertical-inset-end: 32px;
    /* 縦 CTA 列の基準幅（予約ボタン＋Instagram のセンター軸） */
    --mv-side-column-width: 112px;
  }

  .mv__top-bar--side-vertical {
    inset-block-start: 50%;
    inset-block-end: auto;
    inset-inline-end: calc(var(--mv-side-vertical-inset-end) + env(safe-area-inset-right, 0px));
    translate: 0 -50%;
  }

  .mv__top-bar--side-vertical .mv__actions-group {
    flex-direction: column;
    align-items: center;
    inline-size: var(--mv-side-column-width);
    gap: 10px;
  }

  .mv__top-bar--side-vertical .mv__reserve-btn {
    padding: 14px 10px 10px;
    border-radius: 40px;
    box-shadow:
      0 3px 0 #a30f37,
      0 10px 20px rgba(240, 21, 76, 0.24);
  }

  .mv__top-bar--side-vertical .mv__reserve-btn-inner {
    flex-direction: column;
    align-items: center;
    gap: 8px;
  }

  .mv__top-bar--side-vertical .mv__reserve-lines {
    writing-mode: vertical-rl;
    text-orientation: mixed;
    gap: 0.35em;
  }

  .mv__top-bar--side-vertical .mv__reserve-sub {
    font-size: 18px; /* PC縦CTA — サブ */
    letter-spacing: 0.08em;
  }

  .mv__top-bar--side-vertical .mv__reserve-main {
    font-size: 22px; /* PC縦CTA — メイン */
    letter-spacing: 0.1em;
  }

  .mv__top-bar--side-vertical .mv__reserve-icon {
    width: 26px;
    height: 26px;
  }

  .mv__top-bar--side-vertical .mv__instagram-icon {
    width: clamp(48px, 5vw, 56px);
    height: clamp(48px, 5vw, 56px);
  }
}

/* リボン：メインビジュアル直上・同一カラム内でセンター（デザイン上「タイトル直上」相当） */
.mv__ribbon {
  margin: 0;
}

.mv__ribbon-inner {
  display: inline-block;
  transform: skewX(-12deg);
  background-color: #227fab;
  /* padding: 上・右・下・左（いずれも clamp: 最小 / vw / 最大） */
  padding:
    clamp(8px, 2vw, 10px)
    clamp(20px, 4vw, 44px)
    clamp(8px, 2vw, 10px)
    clamp(24px, 5vw, 48px);
}

.mv__ribbon-text {
  display: block;
  transform: skewX(12deg);
  color: #fff;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(14px, 3.8vw, 28px);
  font-style: italic;
  letter-spacing: 0.02em;
  line-height: 1.35;
}

.mv__announce-area {
  text-align: center;
  inline-size: 100%;
  /* コンポとは別レイヤーのため、リボン下端と KV 画像上端に余白を確保 */
  translate: 0;
}

.mv__stage {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding-block: clamp(16px, 3vw, 40px);
  padding-inline: clamp(10px, 2vw, 18px);
}

.mv__hero-stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  inline-size: 100%;
  width: 100%;
  margin-inline: auto;
  /* リボン下端〜メイン画像上端の縦あき（約760px以下は @media 内の .mv__hero-stack で上書き） */
  gap: 10px;
}

/*
 * MV前景（上段タイトルPNG ＋ 日程PNG）
 * 画像の表示幅は .mv__mv-picture--main / --date の max-width だけ変更（PC）
 */
.mv__mv-cluster {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  margin-inline: auto;
  gap: 0;
  filter: drop-shadow(0 10px 22px rgba(12, 40, 80, 0.12));
}

/* MV全面の背景（PC: mv-bg-pc.jpg／SP: mv-bg-sp.jpg）。.mv のフルブリードレイヤー */
.mv__mv-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
  margin: 0;
  padding: 0;
  pointer-events: none;
  overflow: hidden;
}

.mv__mv-bg-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}

.mv__mv-picture {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0;
  line-height: 0;
}

/* PC：メイン画像（タイトル＋人物）の表示幅 */
.mv__mv-picture--main {
  max-width: 969px;
}

/*
 * PC：日程帯の表示幅・横位置
 * 【調整用 CSS 変数 — .mv__mv-picture--date】
 * · --mv-date-offset-x … 横位置（負の値で左へ。例: -24px）
 * · --mv-date-offset-y … 縦位置（+で下へ。通常は 0）
 */
.mv__mv-picture--date {
  max-width: 565px;
  translate: var(--mv-date-offset-x, 0px) var(--mv-date-offset-y, 0px);
}

.mv__mv-img {
  display: block;
  width: 100%;
  height: auto;
}

/* メインキャッチ側は上センター基準（mv-main と同様の見え方寄せ） */
.mv__mv-img--main {
  object-fit: contain;
  object-position: center top;
}

/* CTAボタン：メインのみ YDWaosagi／サブ文言は LINE Seed JP Rg */
.mv__reserve-btn {
  flex: 0 0 auto;
  text-decoration: none;
  color: #fff;
  border-radius: 999px;
  background-color: #f0154c;
  /* padding: 上・右・下・左 */
  padding:
    clamp(8px, 1.8vw, 13px)
    clamp(17px, 3vw, 30px)
    clamp(8px, 1.8vw, 13px)
    clamp(18px, 3.5vw, 30px);
  box-shadow:
    0 3px 0 #a30f37,
    0 14px 24px rgba(240, 21, 76, 0.28);
  transition:
    transform 0.14s ease,
    box-shadow 0.14s ease;
}

.mv__reserve-btn:hover {
  transform: translateY(-1px);
}

.mv__reserve-btn:active {
  transform: translateY(2px);
  box-shadow:
    0 1px 0 #a30f37,
    0 8px 16px rgba(240, 21, 76, 0.2);
}

.mv__reserve-btn:focus-visible {
  outline: 3px solid #fff;
  outline-offset: 4px;
}

.mv__reserve-btn-inner {
  display: inline-flex;
  align-items: center;
  gap: clamp(6px, 2vw, 15px);
}

.mv__reserve-lines {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.12em;
  line-height: 1.05;
}

/*
 * 予約ボタン — 共通（フォントのみ。文字サイズは配置ごとに分ける）
 * · MV右上（添付1）… :root の --mv-pc-topbar-reserve-*（1025px以上）
 * · セクション内（添付2・3）… .notes__reserve-btn / .table-seat__reserve-btn（連動）
 * · 下部固定バー … .mv__top-bar .mv__reserve-*（1024px以下）
 */
.mv__reserve-sub {
  font-family: 'YDWaosagi', 'Hiragino Sans', sans-serif;
  font-weight: normal;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.mv__reserve-main {
  font-family: 'YDWaosagi', 'Hiragino Sans', sans-serif;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

/* セクション内CTA（テーブル有料席・注意事項）— サブ/メインは連動 */
.notes__reserve-btn .mv__reserve-sub,
.table-seat__reserve-btn .mv__reserve-sub {
  font-size: 16px; /* PC — セクション内サブ */
}

.notes__reserve-btn .mv__reserve-main,
.table-seat__reserve-btn .mv__reserve-main {
  font-size: 20px; /* PC — セクション内メイン */
}

.mv__reserve-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: clamp(20px, 9vw, 28px);
  height: clamp(20px, 9vw, 28px);
  border-radius: 50%;
  background-color: #fff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.mv__reserve-arrow {
  display: block;
  width: 62%;
  max-width: 20px;
  height: auto;
}

.mv__reserve-arrow path {
  vector-effect: non-scaling-stroke;
}

/* Instagram（コード／SVGのみ・外周は角丸スクエア） */
.mv__instagram {
  display: flex;
  line-height: 0;
  border-radius: 16%;
}

.mv__instagram-icon {
  display: block;
  /* PC（1025px〜）— サイズ調整は width / height の clamp だけ変更 */
  width: clamp(54px, 10vw, 82px);
  height: clamp(54px, 10vw, 82px);
  filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.2));
  transition: transform 0.14s ease;
}

.mv__instagram:hover .mv__instagram-icon {
  transform: scale(1.04);
}

.mv__instagram:focus-visible {
  outline: 3px solid #fff;
  outline-offset: 4px;
  border-radius: 16%;
}

/* =============================================================================
   MV直下「lead」（白縁 … PCは text-stroke／1024px以下は --lead-text-outline-shadow）
============================================================================= */

.lead {
  position: relative;
  isolation: isolate;
  z-index: 1; /* 下部 .site-bg より前面 */
  padding: 96px 24px 120px;
  background: linear-gradient(180deg, #FFDC9A 0%, #FFC559 100%);
  /*
   * overflow-x: clip だけだと、仕様上 overflow-y が visible にならず auto 扱いになり、
   * 絶対配置の .lead__bubbles が親の外へはみ出した部分が縦にも切れることがある。
   */
  overflow: visible;
}

/*
 * 下端の泡レイヤー（img 1枚・リピートなし／タイル継ぎ目なし）
 */
.lead__bubbles {
  position: absolute;
  inset-inline: 0;
  bottom: 0;
  width: 100%;
  pointer-events: none;
  z-index: 0;
  line-height: 0;
}

.lead__bubbles-img {
  display: block;
  width: 100%;
  height: auto;
}

.lead__inner {
  position: relative;
  z-index: 1;
  width: min(1120px, 100%);
  margin-inline: auto;
}

.lead__badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 12px;
}

.lead__badge {
  display: inline-block;
  padding: 10px 18px;
  background: #fff;
  color: #227fab;
  border: none;
  /* 見出しと同フォント丸ゴシック */
  font-family: 'YDWaosagi', 'Hiragino Sans', sans-serif;
  font-weight: normal;
  font-size: clamp(18px, 4.3vw, 28px);
  line-height: 1.3;
  letter-spacing: 0.02em;
  border-radius: 8px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
}

.lead__hero {
  /* grid の「中央 1fr」だとマグと分割されコピー幅が細くなり、日本語が語の途中で折れやすい */
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: flex-end;
  gap: clamp(12px, 2.5vw, 28px);
  margin-top: 12px;
  width: 100%;
}

.lead__mug {
  flex-shrink: 0;
}

.lead__mug-img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 168px;
}

.lead__mug--left .lead__mug-img {
  transform: rotate(-10deg);
}

/* 青枠側：同一画像を左右反転 */
.lead__mug--right .lead__mug-img {
  transform: scaleX(-1) rotate(-10deg);
}

.lead__copy {
  flex: 1 1 auto;
  /* マグより優先して横幅を確保（adjust: 最小px / 最大の上限） */
  min-width: min(100%, 300px);
  max-width: min(920px, 100%);
  text-align: center;
  /* 下端の縦間はすべて --lead-copy-to-panels-gap（lead__panels margin-top）に集約して手調整しやすくする */
  padding-block-end: 0;
  line-break: strict;
  word-break: normal;
}

/* 語の途中改行を避けたいフレーズだけマークアップでまとめる */
.lead__phrase {
  white-space: nowrap;
}

.lead__title,
.lead__tagline {
  font-family: 'YDWaosagi', 'Hiragino Sans', sans-serif;
  font-weight: normal;
  font-size: clamp(26px, 6vw, 36px);
  line-height: 1.28;
  letter-spacing: 0.02em;
  color: #227fab;
  /* PC（1025px〜）— 縁取り。タブレット・スマホは @media (max-width: 1024px) で shadow に切替 */
  -webkit-text-stroke: 5px #fff;
  paint-order: stroke fill;
}

.lead__title {
  margin: 0;
}

/* 「が」の直後の改行：<br class="lead__title-br">。宽幅では非表示／1024px 以下で改行 */
.lead__title-br {
  display: none;
}

.lead__tagline {
  margin: 18px 0 0;
}

/*
 * lead 3パネル（PC）
 * レイアウトB … 左：開催日程／右：.lead__panels-side（会場＋入場料）
 * 会場↔入場料の縦あき → .lead__panels-side-gap の height（px）
 * 入場料ラベル下〜コンテンツ上の縦あき → .lead-panel--admission の --lead-panel-admission-label-gap（px）
 * 右列の高さ＝開催日程と同じ → .lead__panels-side の flex ＋ 子パネル flex:1
 * 3列横並びに戻すとき → 会場・入場料を .lead__panels 直下に戻し grid を3列化
 */
.lead__panels {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: 24px;
  margin-top: clamp(36px, 4.5vw, 78px);
  align-items: stretch;
}

.lead-panel--schedule {
  grid-column: 1;
  grid-row: 1;
}

/* 右列：会場＋入場料（縦並び・高さは左の開催日程に合わせる） */
.lead__panels-side {
  grid-column: 2;
  grid-row: 1;
  display: flex;
  flex-direction: column;
  align-self: stretch;
  min-width: 0;
  min-height: 100%;
  height: 100%;
}

.lead__panels-side > .lead-panel {
  flex: 1 1 0;
  min-height: 0;
  width: 100%;
}

/* 会場と入場料のあいだ（PC）— height だけ変更 */
.lead__panels-side-gap {
  flex: 0 0 auto;
  width: 100%;
  height: 40px;
}

.lead__panels > .lead-panel--schedule {
  align-self: stretch;
  height: 100%;
}

.lead-panel {
  --lead-panel-orange-text: var(--site-orange-text);

  position: relative;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  min-height: 0;
  /* 上・左右・下（この3つの px だけ変更） */
  padding: 32px 18px 22px;
  background: rgba(255, 253, 248, 0.94);
  border: 2px solid #ff9f43;
  border-radius: 14px;
  text-align: center;
}

/* 会場／入場料：ラベル下の余白を縦センターで使って3枚の視覚高さを揃える */
.lead-panel__body-fill {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: 0;
  width: 100%;
}

.lead-panel__body-fill--schedule {
  justify-content: flex-start;
  align-items: stretch;
}

.lead-panel__center-block {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* 会場（PC）：アイコン左・テキスト右（添付2） */
.lead-panel--venue .lead-panel__center-block {
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 14px;
}

.lead-panel--venue .lead-panel__venue-name {
  text-align: left;
}

.lead-panel--admission {
  /*
   * 入場料ラベル（pill）の下端〜「入場料無料」上の縦余白
   * --lead-panel-admission-label-gap … この数値だけ変更（px）
   * --lead-panel-admission-label-half … ラベル下半分の高さ（label の padding/font 変更時のみ）
   */
  --lead-panel-admission-label-gap: 16px;
  --lead-panel-admission-label-half: 24px;
  padding-top: calc(var(--lead-panel-admission-label-half) + var(--lead-panel-admission-label-gap));
}

.lead-panel--admission .lead-panel__body-fill {
  justify-content: flex-start;
  padding-block-start: 0;
}

.lead-panel--admission .lead-panel__center-block {
  gap: 14px;
}

.lead-panel__label {
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% -50%;
  margin: 0;
  padding: 8px 74px;
  background: #fff;
  border: 2px solid #ff9f43;
  color: var(--lead-panel-orange-text);
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  /* PC（1025px〜） */
  font-size: 20px;
  border-radius: 999px;
  white-space: nowrap;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.8),
    0 2px 6px rgba(180, 100, 30, 0.12);
}

.lead-panel__highlight {
  margin: 12px 0 0;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  font-size: 16px;
  color: #525252;
}

.lead-panel__highlight-gap {
  margin-inline: 6px;
  font-weight: 800;
}

.lead-panel__divider {
  width: 100%;
  margin: 16px 0 14px;
  border: 0;
  border-block-end: 2px dotted rgba(255, 150, 80, 0.55);
}

/*
 * 開催日程の文字サイズ（px 直書き）
 * PC … このブロック／タブレット … @media (max-width: 1024px)／SP … @media (max-width: 760px)
 */
.lead-panel--schedule .lead-panel__highlight {
  margin: 8px 0 0;
  font-size: 22px;
}

.lead-panel--schedule .lead-panel__divider {
  display: none;
}

.lead-panel--schedule .lead-panel__schedule-days {
  margin-top: 8px; /* 日付見出しと DAY 一覧の間（破線非表示分） */
}

.lead-panel__schedule-days {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
  margin: 0;
  padding: 0;
  list-style: none;
}

.lead-panel__schedule-day {
  display: grid;
  grid-template-columns: auto 2px 1fr;
  grid-template-rows: auto;
  column-gap: 0;
  padding-block: 10px 12px;
  padding-inline-start: 0;
  padding-inline-end: 16px; /* 赤枠（カード右） */
  background: #fff;
  border: 1px solid rgba(255, 159, 67, 0.4);
  border-radius: 10px;
  text-align: left;
}

/* 青枠左右（バッジ両端）— padding-inline の1行だけ変更（PC） */
.lead-panel__schedule-badge-slot {
  grid-column: 1;
  grid-row: 1;
  align-self: center;
  padding-inline: 32px;
}

.lead-panel__schedule-badge {
  display: inline-block;
  padding: 6px 9px;
  background-color: var(--site-orange-text);
  border-radius: 8px;
  color: #fff;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  font-size: 24px;
  line-height: 1.2;
  letter-spacing: 0.04em;
}

.lead-panel__schedule-vrule {
  grid-column: 2;
  grid-row: 1;
  align-self: stretch;
  /* PC：縦点線右〜日付・時間 */
  margin-inline-end: 10px;
  width: 0;
  min-height: 36px;
  border-inline-start: 2px dotted rgba(255, 150, 80, 0.55);
}

/* 日付と時間を横並び（添付1） */
.lead-panel__schedule-meta {
  grid-column: 3;
  grid-row: 1;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 10px 14px;
  min-width: 0;
}

.lead-panel--schedule .lead-panel__day {
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  font-size: 22px;
  line-height: 1.25;
  color: #525252;
}

.lead-panel--schedule .lead-panel__hours {
  display: inline-block;
  width: auto;
  padding: 8px 10px;
  border-radius: 999px;
  color: #525252;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  font-size: 22px;
  line-height: 1.3;
  text-align: center;
  white-space: nowrap;
}

.lead-panel__map-icon {
  display: block;
  width: 44px;
  height: auto;
}

.lead-panel__venue-name {
  margin: 0;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  font-size: 22px;
  line-height: 1.45;
  text-align: center;
  color: #525252;
}

.lead-panel__map {
  margin: 0;
}

.lead-panel__map-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #525252;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(15px, 3.4vw, 20px);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 6px;
}

.lead-panel__map-link-icon {
  flex-shrink: 0;
  width: clamp(16px, 4.5vw, 20px);
  height: auto;
}

.lead-panel__map-link:hover {
  color: #383838;
}

.lead-panel__map-link:focus-visible {
  outline: 3px solid #227fab;
  outline-offset: 3px;
  border-radius: 4px;
}

.lead-panel__fee {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: clamp(6px, 1.8vw, 10px);
  margin: 0;
  width: 100%;
  color: var(--lead-panel-orange-text);
}

.lead-panel__fee-main {
  margin: 0;
  padding-inline: 0;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  font-size: 28px;
  line-height: 1.22;
  letter-spacing: 0.03em;
  color: var(--lead-panel-orange-text);
}

.lead-panel__fee-note {
  margin: 0 auto;
  padding: 6px 24px;
  width: fit-content;
  max-width: 100%;
  background-color: var(--site-orange-text);
  border-radius: 999px;
  color: #fff;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  font-size: 18px;
  line-height: 1.38;
  text-align: center;
}



/* =============================================================================
   Coming Soon（飲食ブース・限定グッズ）
   SPの店先イラスト間 → @media (max-width: 760px) 内
   .coming-soon__storefront の --coming-soon-storefront-gap
   Coming Soon 前後の余白 → .coming-soon の --coming-soon-gap-top / --coming-soon-gap-bottom
   文字の縁取り → .coming-soon の --coming-soon-label-stroke / --coming-soon-title-stroke
     （「幅 色」の2値。例: 2px #1a5278）
============================================================================= */
/* 出店ブルワリー内：カード一覧（最終行）の直下 */
.coming-soon {
  position: relative;
  width: 100%;
  /* PC — 上／下の余白（それぞれ独立。--coming-soon-gap-top / bottom だけ変更） */
  --coming-soon-gap-top: 96px;
  --coming-soon-gap-bottom: 96px;
  /* PC — 文字の縁取り（太さ 色） */
  --coming-soon-label-stroke: 2px #1a5278;
  --coming-soon-title-stroke: 5px #1a5278;
  margin-top: var(--coming-soon-gap-top);
  margin-bottom: var(--coming-soon-gap-bottom);
}

.coming-soon__panel {
  position: relative;
  overflow: hidden;
  border-radius: clamp(14px, 2.2vw, 20px);
  background-color: #17bbde;
  /* ガーランド上端と青枠上辺のあいだ（デザイン準拠） */
  padding-top: 8px;
}

.coming-soon__garland {
  display: block;
  width: 100%;
  height: auto;
}

.coming-soon__body {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  column-gap: clamp(4px, 1.5vw, 20px);
  padding:
    clamp(8px, 2vw, 16px)
    clamp(10px, 2.5vw, 28px)
    clamp(16px, 3.5vw, 32px);
}

/* イラスト2点をまとめる（PCは横並び・SPは店先グリッド用に display:contents） */
.coming-soon__storefront {
  display: contents;
}

.coming-soon__kitchen {
  grid-column: 1;
  grid-row: 1;
  justify-self: start;
  width: clamp(110px, 24vw, 240px);
  height: auto;
}

.coming-soon__character {
  grid-column: 3;
  grid-row: 1;
  justify-self: end;
  width: clamp(96px, 21vw, 173px);
  height: auto;
}

.coming-soon__copy {
  grid-column: 2;
  grid-row: 1;
  min-width: 0;
  text-align: center;
}

.coming-soon__label {
  margin: 0 0 clamp(2px, 0.8vw, 6px);
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(14px, 3.1vw, 22px);
  line-height: 1.35;
  letter-spacing: 0.06em;
  color: #ffe566;
  -webkit-text-stroke: var(--coming-soon-label-stroke);
  paint-order: stroke fill;
}

.coming-soon__title {
  margin: 0;
  font-family: 'Alfa Slab One', 'Times New Roman', serif;
  font-weight: 400;
  font-size: clamp(32px, 9.5vw, 68px);
  line-height: 1.05;
  letter-spacing: 0.02em;
  color: #ffe566;
  -webkit-text-stroke: var(--coming-soon-title-stroke);
  paint-order: stroke fill;
}

/* =============================================================================
   テーブル有料席（Coming Soon の直下）
============================================================================= */
.table-seat {
  /* 上余白は .coming-soon の --coming-soon-gap-bottom に任せる */
  padding: 0 24px 56px;
  background: #fff;
}

.table-seat__inner {
  width: min(1120px, 100%);
  margin-inline: auto;
  overflow-x: clip; /* 配置図などの横はみ出し防止 */
}

.table-seat__header {
  text-align: center;
}

.table-seat__title {
  margin: 0;
  color: var(--site-orange-text);
  font-family: 'YDWaosagi', 'Hiragino Sans', sans-serif;
  font-size: 40px; /* PC（1025px〜）— セクションタイトル */
  font-weight: normal;
  line-height: 1.25;
  letter-spacing: 0.12em;
}

.table-seat__title-wave {
  display: block;
  width: 332px; /* PC — 波線の幅 */
  height: auto;
  margin: 4px auto 20px;
  transform: translateX(-5px);
}

.table-seat__lead {
  margin: 0 0 32px;
  color: var(--site-orange-text);
  font-family: 'YDWaosagi', 'Hiragino Sans', sans-serif;
  font-size: 32px; /* PC — リード文 */
  font-weight: normal;
  line-height: 1.55;
  letter-spacing: 0.06em;
}

.table-seat__cta {
  display: flex;
  justify-content: center;
  margin: 0 0 72px;
}

.table-seat__reserve-btn {
  max-width: 100%;
}

.table-seat__board {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  text-align: center;
}


.table-seat__board-wave {
  display: block;
  width: 180px; /* PC — 料金表タイトル下の波線 */
  height: auto;
  margin: 4px auto 28px;
  transform: translateX(-6px);
}

.table-seat__columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
  min-width: 0;
  margin-bottom: 24px;
  text-align: left;
}

.table-seat__column {
  overflow: hidden;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.08);
}

.table-seat__column--b {
  border: 2px solid #A8C3D4;
}

.table-seat__column--a {
  border: 2px solid #FAC8AA;
}

.table-seat__column-title {
  margin: 0;
  padding: 12px 16px;
  border: none;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 20px; /* PC — エリア見出し */
  font-weight: 800;
  line-height: 1.4;
  text-align: center;
  background: #fff;
}

.table-seat__column--b .table-seat__column-title {
  border-bottom: 2px solid #2a6eb8;
  color: #2a6eb8;
}

.table-seat__column--a .table-seat__column-title {
  border-bottom: 2px solid var(--site-orange-text);
  color: var(--site-orange-text);
}

.table-seat__column-body {
  padding: 16px 16px 20px;
  border-radius: 0 0 12px 12px;
}

.table-seat__column--b .table-seat__column-body {
  background: #eef5fc;
}

.table-seat__column--a .table-seat__column-body {
  background: #fff5e4;
}

.table-seat__day + .table-seat__day {
  margin-top: 20px;
}

.table-seat__day-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 10px;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 16px; /* PC — 日付 */
  font-weight: 800;
  line-height: 1.4;
}

.table-seat__column--b .table-seat__day-title {
  color: #2a6eb8;
}

.table-seat__column--a .table-seat__day-title {
  color: var(--site-orange-text);
}

/* 日付横のカレンダーアイコン（PC — width / height でサイズ調整） */
.table-seat__day-icon {
  display: inline-block;
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.table-seat__column--b .table-seat__day-icon {
  background-image: url('assets/images/calender-blue.svg');
}

.table-seat__column--a .table-seat__day-icon {
  background-image: url('assets/images/calender-orange.svg');
}

/* 時間帯横の時計アイコン（PC — width / height でサイズ調整） */
.table-seat__slot-icon {
  display: inline-block;
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.table-seat__column--b .table-seat__slot-icon {
  background-image: url('assets/images/clock-blue.svg');
}

.table-seat__column--a .table-seat__slot-icon {
  background-image: url('assets/images/clock-orange.svg');
}

.table-seat__slots {
  margin: 0;
  padding: 12px 14px;
  list-style: none;
  background: #fff; /* PC — 時間・料金の範囲 */
  border-radius: 10px;
}

.table-seat__slot {
  display: flex;
  align-items: center; /* 時計アイコンと時間を横一列で中央揃え */
  gap: 8px;
  margin-bottom: 8px;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 16px; /* PC — 時間・料金 */
  font-weight: 700;
  line-height: 1.5;
}

.table-seat__slot:last-child {
  margin-bottom: 0;
}

.table-seat__column--b .table-seat__time,
.table-seat__column--b .table-seat__price {
  color: #333;
}

.table-seat__column--a .table-seat__time,
.table-seat__column--a .table-seat__price {
  color: #333;
}

.table-seat__time {
  flex-shrink: 0;
  white-space: nowrap;
}

.table-seat__slot--limited {
  flex-direction: column;
  align-items: stretch;
  gap: 4px;
  margin-bottom: 10px;
}

.table-seat__slot-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border: 1px solid;
  border-radius: 8px;
}

.table-seat__column--b .table-seat__slot--limited .table-seat__slot-row {
  border-color: #2a6eb8;
}

.table-seat__column--a .table-seat__slot--limited .table-seat__slot-row {
  border-color: var(--site-orange-text);
}

.table-seat__slot-note {
  margin: 0;
  padding-left: 26px; /* 時計アイコン分 — 時間テキストに揃える */
  font-size: 14px; /* PC — 限定発売注釈 */
  font-weight: 700;
  line-height: 1.4;
}

.table-seat__column--b .table-seat__slot-note {
  color: #2a6eb8;
}

.table-seat__column--a .table-seat__slot-note {
  color: var(--site-orange-text);
}

.table-seat__leader {
  flex: 1 1 auto;
  align-self: center;
  min-width: 16px;
  height: 0;
  margin: 0 2px;
  border-bottom: 2px dotted #c8c8c8;
}

.table-seat__price {
  flex-shrink: 0;
  font-weight: 800;
  white-space: nowrap;
}

.table-seat__tax {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin: 0;
  padding: 12px 28px;
  border: 1px solid #ffd4b8;
  border-radius: 999px;
  background: #fff8f2;
  color: #333;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 14px; /* PC — 税込注釈 */
  font-weight: 700;
  line-height: 1.5;
}

.table-seat__tax-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--site-orange-text);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
}

/* 配置図 — .table-seat__inner（最大1120px）と同じコンテンツ幅に収める */
.table-seat__seats-map {
  --table-seat-seats-map-gap-top: 28px;
  --table-seat-seats-map-gap-bottom: 28px;
  --table-seat-seats-map-max-width: 100%;
  display: block;
  box-sizing: border-box;
  width: min(100%, var(--table-seat-seats-map-max-width));
  min-width: 0;
  max-width: 100%;
  margin: var(--table-seat-seats-map-gap-top) auto var(--table-seat-seats-map-gap-bottom);
  padding: 0;
}

.table-seat__seats-map-img {
  display: block;
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  height: auto;
}

.table-seat__purchase {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 20px 12px;
  margin-top: 0; /* 上余白は .table-seat__seats-map の gap-bottom に任せる */
  text-align: left;
}

.table-seat__purchase-head {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  gap: 12px;
}

.table-seat__purchase-icon {
  display: inline-flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--site-orange-text);
}

.table-seat__purchase-icon-img {
  display: block;
  width: 28px;
  height: auto;
}

.table-seat__purchase-title {
  margin: 0;
  color: var(--site-orange-text);
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 18px; /* PC — 購入方法 */
  font-weight: 800;
  line-height: 1.4;
  white-space: nowrap;
}

.table-seat__purchase-list {
  flex: 0 0 auto;
  margin: 0;
  padding: 0;
  list-style: none;
}

.table-seat__purchase-list > li {
  position: relative;
  margin-bottom: 4px;
  padding-left: 1.1em;
  color: #333;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 16px; /* PC — 購入方法リスト */
  font-weight: 700;
  line-height: 1.75;
}

@media (min-width: 1025px) {
  .table-seat__purchase-list > li {
    white-space: nowrap;
  }
}

.table-seat__purchase-list > li::before {
  position: absolute;
  left: 0;
  content: '・';
}

.table-seat__purchase-list > li:last-child {
  margin-bottom: 0;
}

.table-seat__seat-info {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px; /* PC — 座席カード間隔 */
  min-width: 0;
  margin-top: 28px; /* PC — 料金表と座席カードの間隔 */
  text-align: left;
}

.table-seat__seat-card {
  padding: 18px 16px 20px;
  border: 2px solid #ff9f43;
  border-radius: 12px;
  background: #fff;
}

.table-seat__seat-card-title {
  margin: 0 0 12px;
  color: var(--site-orange-text);
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 20px; /* PC — 座席カード見出し */
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: 0.06em;
  text-align: center;
}

.table-seat__seat-card-divider {
  height: 0;
  margin: 0 0 12px;
  border-bottom: 2px dotted var(--site-orange-text);
}

.table-seat__seat-card-text {
  margin: 0;
  color: #333;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 14px; /* PC — 座席カード本文 */
  font-weight: 700;
  line-height: 1.75;
}

/* 4名席 — エリアB（#2a6eb8）と同色 */
.table-seat__seat-card--b {
  border-color: #2a6eb8;
}

.table-seat__seat-card--b .table-seat__seat-card-title {
  color: #2a6eb8;
}

.table-seat__seat-card--b .table-seat__seat-card-divider {
  border-bottom-color: #2a6eb8;
}

/* =============================================================================
   注意事項
============================================================================= */
.notes {
  padding: 56px 24px 72px;
  background: #fff;
}

.notes__inner {
  width: min(1120px, 100%);
  margin-inline: auto;
}

.notes__panel {
  padding: 36px 40px 32px;
  background: #fff;
  border: 2px solid #ff9f43;
  border-radius: 20px;
}

.notes__panel--request {
  margin-top: 32px; /* PC — 注意事項パネルとの間隔 */
}

.notes__section-heading {
  margin: 0 0 8px;
  color: #333;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  font-size: 16px; /* PC — 小見出し */
  line-height: 1.75;
}

.notes__section-heading + .notes__list {
  margin-top: 4px;
}

.notes__title {
  margin: 0 0 28px;
  color: var(--site-orange-text);
  font-family: 'YDWaosagi', 'Hiragino Sans', sans-serif;
  font-size: 32px;
  font-weight: normal;
  line-height: 1.3;
  letter-spacing: 0.08em;
  text-align: center;
}

.notes__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.notes__list > li {
  position: relative;
  margin-bottom: 14px;
  padding-left: 1.1em;
  color: #333;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.75;
}

.notes__list > li::before {
  position: absolute;
  left: 0;
  content: '・';
}

.notes__list > li:last-child {
  margin-bottom: 0;
}

.notes__list > li.notes__item--emphasis {
  color: #FD3411;
}

.notes__em {
  color: var(--site-orange-text);
}

.notes__pay-intro {
  margin: 24px 0 12px;
  padding: 0;
  color: #333;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  font-size: 16px;
  line-height: 1.75;
}

.notes__pay-rows {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 16px;
}

.notes__pay-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 16px;
}

.notes__pay-tag {
  display: inline-block;
  padding: 5px 14px;
  border: 1px solid #333;
  color: #333;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.4;
  white-space: nowrap;
}

.notes__pay-tag--online {
  border-color: var(--site-orange-text);
  color: var(--site-orange-text);
}

.notes__pay-desc {
  color: #333;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.5;
}

.notes__pay-desc--accent {
  color: var(--site-orange-text);
  font-weight: 800;
}

.notes__pay-visual {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  gap: 32px; /* PC — カード／電子マネー／コード決済の間隔 */
  width: min(100%, 880px); /* PC — 決済ロゴ全体の最大幅 */
  margin: 0 0 12px; /* 左寄せ（margin-inline: auto は使わない） */
}

.notes__pay-visual-item {
  display: flex;
  flex-direction: column;
  gap: 12px; /* 見出し（青枠）と画像（赤枠）の間隔 */
  min-width: 0;
}

.notes__pay-visual-label {
  margin: 0;
  padding: 8px 10px;
  border: 1px solid #bdbdbd;
  background: #e9e9e9;
  color: #333;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 16px; /* PC — 見出し（カード決済／電子マネー／コード決済） */
  font-weight: 800;
  line-height: 1.4;
  text-align: center;
}

.notes__pay-visual-img {
  display: block;
  box-sizing: border-box;
  width: 100%;
  height: auto;
  padding-inline: 8px; /* 左右 — ロゴ画像の余白 */
}

.notes__pay-note {
  margin: 0 0 16px; /* 下 — ■当日のご案内 とのあいだ */
  color: #333;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 700;
  font-size: 14px;
  line-height: 1.6;
}

.notes__cta {
  display: flex;
  justify-content: center;
  margin: 32px 0 0;
}

.notes__reserve-btn {
  max-width: 100%;
}

/* =============================================================================
   会場アクセス
   駐車場案内ボックスの色 → .access__parking の --access-parking-accent / --access-parking-bg
============================================================================= */
.access {
  padding: 56px 24px 80px;
  background: transparent;
}

.access__inner {
  width: min(1120px, 100%);
  margin-inline: auto;
}

.access__header {
  text-align: center;
}

.access__title {
  margin: 0;
  color: var(--site-orange-text);
  font-family: 'YDWaosagi', 'Hiragino Sans', sans-serif;
  font-size: 40px; /* PC（1025px〜）— セクションタイトル */
  font-weight: normal;
  line-height: 1.25;
  letter-spacing: 0.12em;
}

.access__title-wave {
  display: block;
  width: 281px; /* PC — 波線の幅 */
  height: auto;
  margin: 4px auto 28px;
  transform: translateX(-6px);
}

.access__venue {
  margin: 0 0 28px;
  color: #333;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 16px; /* PC — 会場名・住所 */
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.04em;
  text-align: center;
}

.access__address-link {
  color: #227fab;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.access__address-link:hover {
  color: #1a6280;
}

.access__address-link:focus-visible {
  outline: 2px solid #227fab;
  outline-offset: 2px;
}

.access__routes {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px 48px;
  margin: 0 0 32px;
  padding: 0;
  list-style: none;
}

.access__route {
  display: flex;
  align-items: center;
  gap: 10px;
}

.access__route-icon {
  display: block;
  width: 21px; /* PC — 路線アイコン幅 */
  height: auto;
  flex-shrink: 0;
}

.access__route-label {
  color: #333;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 16px; /* PC — 駅名 */
  font-weight: 700;
  line-height: 1.4;
  white-space: nowrap;
}

.access__badge {
  display: inline-block;
  padding: 6px 16px;
  border-radius: 999px;
  background: var(--site-orange-text);
  color: #fff;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 14px; /* PC — 徒歩分数 */
  font-weight: 800;
  line-height: 1.3;
  white-space: nowrap;
}

/* 駐車場案内（路線情報と地図のあいだ・縦並び中央） */
.access__parking {
  --access-parking-accent: var(--site-orange-text);
  --access-parking-bg: #fff9f5;
  --access-parking-border: 2px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  margin: 0 0 32px;
  text-align: center;
  /* border: var(--access-parking-border) solid var(--access-parking-accent); */
  /* border-radius: 12px; */
  /* background-color: var(--access-parking-bg); */
}

.access__parking-head {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin: 0;
  padding: 0;
}

.access__parking-mark {
  display: grid;
  flex-shrink: 0;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background-color: var(--access-parking-accent);
  color: #fff;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 22px;
  font-weight: 800;
  line-height: 1;
}

.access__parking-heading {
  margin: 0;
  color: var(--access-parking-accent);
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 18px;
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: 0.04em;
}

.access__parking-body {
  margin: 0;
  padding: 0;
  color: #333;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.02em;
}

.access__map {
  /* 縦長画像のため .access__inner（1120px）より狭めて中央配置 */
  --access-map-max-width: 720px;
  width: min(100%, var(--access-map-max-width));
  margin-inline: auto;
  padding: 4px;
  border: 3px solid #fff;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
}

.access__map-img {
  display: block;
  width: 100%;
  height: auto;
  border: 0;
  border-radius: 4px;
}

/* =============================================================================
   フッター
============================================================================= */
.site-footer {
  padding: 56px 24px 64px;
  background: var(--site-orange-text);
  color: #fff;
}

.site-footer__inner {
  width: min(1120px, 100%);
  margin-inline: auto;
  text-align: center;
}

.site-footer__title {
  margin: 0 0 32px;
  /* font-family: 'YDWaosagi', 'Hiragino Sans', sans-serif; */
  font-size: 32px; /* PC — イベント名 */
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: 0.08em;
}

.site-footer__sponsors {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 16px;
  margin: 0 0 40px;
  padding: 0;
  list-style: none;
}

.site-footer__sponsor {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 80px; /* PC — ロゴ枠の高さ */
  padding: 12px 16px;
  border-radius: 8px;
  background: #fff;
}

.site-footer__sponsor-placeholder {
  color: #b3b3b3;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 14px; /* PC — プレースホルダー */
  font-weight: 700;
  line-height: 1.4;
}

.site-footer__divider {
  margin: 0 0 40px;
  border: 0;
  border-top: 1px solid #fff;
}

.site-footer__contact-heading {
  margin: 0 0 12px;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 18px; /* PC — 問合せ見出し */
  font-weight: 800;
  line-height: 1.5;
}

.site-footer__contact-lead,
.site-footer__contact-detail {
  margin: 0;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 16px; /* PC — 問合せ本文 */
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.02em;
}

.site-footer__contact-lead {
  margin-bottom: 8px;
}

.site-footer__contact-detail {
  margin-bottom: 40px;
}

.site-footer__contact-link {
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.site-footer__contact-link:hover {
  opacity: 0.85;
}

.site-footer__orgs {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 28px;
  /* 後援テキストと白線の間（margin だと潰れやすいので padding-bottom） */
  padding-bottom: 40px;
}

.site-footer__org-label {
  display: inline-block;
  margin: 0 0 8px;
  padding: 4px 16px;
  border: 1px solid #fff;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 14px; /* PC — 主催・後援ラベル */
  font-weight: 700;
  line-height: 1.4;
}

.site-footer__org-name {
  margin: 0;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 16px; /* PC — 主催・後援名 */
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.02em;
}

/* イベント参加規約ブロック（白線は border-top。上余白は .site-footer__orgs の padding-bottom） */
.site-footer__terms-block {
  margin: 0;
  padding: 0;
  border-top: 1px solid #fff;
}

.site-footer__terms {
  margin: 20px 0 0;
}

.site-footer__terms-link {
  color: #fff;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: 16px; /* PC — イベント参加規約 */
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.02em;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.site-footer__terms-link:hover {
  opacity: 0.85;
}

/* =============================================================================
   下部共通背景（lead より下）
   ─────────────────────────────────────────────────────────────────────────
   静止画 … PC: bg-beer-bubbles2-pc.jpg／SP: bg-beer-bubbles2-sp.jpg
   761〜1366px … .site-bg__fixed に pc.jpg（100% auto ＋ repeat-y で画面全体）
   760px以下 … .site-bg__fixed に sp.jpg（cover・iOS向け）
   1367px以上 … .site-bg--parallax に attachment:fixed＋cover（従来のPC）
   タブレット … --site-bg-tablet-bg-size（761〜1366px の @media 内）
============================================================================= */
.site-bg--parallax {
  position: relative;
  z-index: 0;
  isolation: isolate;
  background-color: #fff;
  background-image: url('assets/images/bg-beer-bubbles2-pc.jpg');
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  background-attachment: fixed;
}

/* SP 実機用固定レイヤー（静止画モード・760px 以下で表示） */
.site-bg__fixed {
  display: none;
}

/*
 * タブレット（761〜1366px）
 * · 親への attachment:fixed / cover は背景が拡大して見える
 * · viewport 固定レイヤーに 100% auto ＋ repeat-y（幅は画面幅・縦に繰返して全体を覆う）
 * · cover 単体は拡大しやすいため使わない（PC 1367px〜は従来どおり）
 */
@media (min-width: 761px) and (max-width: 1366px) {
  .site-bg--parallax {
    --site-bg-tablet-bg-size: 100% auto;
    background-image: none;
    background-attachment: scroll;
  }

  .site-bg--parallax .site-bg__fixed {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 0;
    background-color: #fff;
    background-image: url('assets/images/bg-beer-bubbles2-pc.jpg');
    background-repeat: repeat-y;
    background-position: center top;
    background-size: var(--site-bg-tablet-bg-size);
    pointer-events: none;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}

.site-bg--parallax > :not(.site-bg__fixed) {
  position: relative;
  z-index: 1;
}

/* 泡背景が見えるよう、各セクションの背面だけ透過（カード・パネルの白はそのまま） */
.site-bg--parallax .brewery,
.site-bg--parallax .table-seat,
.site-bg--parallax .notes,
.site-bg--parallax .access {
  background: transparent;
}

/* =============================================================================
   出店ブルワリー
============================================================================= */
.brewery {
  position: relative;
  /* 下余白は .coming-soon の margin-bottom に任せる */
  padding: clamp(56px, 7vw, 84px) clamp(18px, 4vw, 44px) 0;
  background: #fff;
}

.brewery__inner {
  width: min(1120px, 100%);
  margin-inline: auto;
}

.brewery__header {
  text-align: center;
}

.brewery__title {
  margin: 0;
  color: var(--site-orange-text);
  font-family: 'YDWaosagi', 'Hiragino Sans', sans-serif;
  font-size: 40px; /* PC（1025px〜）— セクションタイトル */
  font-weight: normal;
  line-height: 1.25;
  letter-spacing: 0.12em;
}

.brewery__title-wave {
  display: block;
  width: 337px; /* PC（波線の幅）— ここだけ変更 */
  height: auto;
  margin: 4px auto 22px;
  transform: translateX(-9px);
}

.brewery__lead {
  margin: 0;
  color: var(--site-orange-text);
  font-family: 'YDWaosagi', 'Hiragino Sans', sans-serif;
  font-size: 32px; /* PC（1025px〜）— リード文 */
  font-weight: normal;
  line-height: 1.4;
  letter-spacing: 0.08em;
}

.brewery__map-frame {
  margin-top: clamp(28px, 4vw, 42px);
  padding: clamp(16px, 2.2vw, 26px);
  background: #fff4df;
  border-radius: 8px;
}

.brewery__map-picture {
  display: block;
  width: 100%;
}

.brewery__map {
  display: block;
  width: 100%;
  height: auto;
}

.brewery__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(20px, 3vw, 32px);
  margin-top: 32px; /* 地図（青枠）とカード一覧（赤枠）のあいだ（PC）— ここだけ変更 */
  list-style: none;
  margin-inline: 0;
  padding: 0;
  /* 行内で最も高いカード（今回は右側）に合わせ、同じ行のカード高さを揃える */
  align-items: stretch;
}

.brewery__grid > li {
  display: flex;
  flex-direction: column;
  margin: 0;
  padding: 0;
  min-width: 0;
  min-height: 0;
}

/*
 * ブルワリーカード：スクロールで下からフェードイン
 * JS 起動後に .brewery__grid--reveal が付くまで非表示にしない
 */
/* 【調整②】せり上がり量（px）— from の 40px と :not(.is-visible) を同じ値に */
@keyframes brewery-card-reveal {
  from {
    opacity: 0;
    transform: translate3d(0, 40px, 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

/* カード1枚分の li ごとに、透過＋下からせり上がり */
.brewery__grid.brewery__grid--reveal > li:not(.is-visible) {
  opacity: 0;
  transform: translate3d(0, 40px, 0);
}

.brewery__grid.brewery__grid--reveal > li.is-visible {
  /* 【調整①】表示スピード（秒）— 透過・せり上がりともこの1行だけ変更 */
  animation: brewery-card-reveal 2s ease forwards;
}

.brewery-card {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  border-radius: 10px;
  background: #fff9f0;
}

.brewery-card__bar {
  margin: 0;
  padding: 12px 14px;
  background: #877428;
  text-align: center;
}

.brewery-card--header-forest .brewery-card__bar {
  background: #1A6E00;
}

.brewery-card--header-royal .brewery-card__bar {
  background: #2F61CE;
}

.brewery-card--header-oldboys .brewery-card__bar {
  background: #96833d;
}

.brewery-card--header-nobady .brewery-card__bar {
  background: #993AA2;
}

.brewery-card--header-hyuga .brewery-card__bar {
  background: #13A9DF;
}

.brewery-card--header-fujizakura .brewery-card__bar {
  background: #BE405F;
}

.brewery-card__name {
  margin: 0;
  color: #fff;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  font-size: 18px; /* PC — カード見出し */
  letter-spacing: 0.03em;
  line-height: 1.35;
}

.brewery-card__body {
  padding: clamp(16px, 2.4vw, 22px);
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.brewery-card__logo-box {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: clamp(14px, 2.2vw, 22px);
  background: #fff;
  border-radius: 8px;
}

.brewery-card__logo {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
}

.brewery-card__desc {
  margin: 16px 0 0; /* PC — 説明文の上余白 */
  padding: 0;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 700;
  font-size: 16px; /* PC — 本文（青枠）— 説明文 */
  line-height: 1.65;
  letter-spacing: 0.03em;
  color: #525252;
  text-align: left;
}

.brewery-card__detail {
  margin: 0;
  padding: 0;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 700;
  font-size: 16px; /* PC — 本文（青枠）— 住所・メニュー */
  line-height: 1.65;
  letter-spacing: 0.03em;
  color: #525252;
  text-align: left;
}

.brewery-card__block {
  margin-top: 24px; /* PC — 住所ブロックなどの間隔 */
}

.brewery-card__label {
  display: inline-block;
  margin: 0 0 4px;
  padding: 5px 12px;
  border: 1px solid #333;
  border-radius: 4px;
  background: #fff;
  color: #525252;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 800;
  font-size: 14px; /* PC — ラベル（赤枠）— 住所・HP・SNS・販売メニュー */
  line-height: 1.25;
  text-align: center;
}

.brewery-card__links {
  --brewery-card-link-gap: 12px;

  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--brewery-card-link-gap);
  margin: 0;
  padding: 0;
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-weight: 700;
  font-size: 16px; /* PC — 本文（青枠）— HP・SNSリンク */
  line-height: 1.35;
}

.brewery-card__links br {
  display: none;
}

.brewery-card__link {
  display: block;
  margin: 0;
  line-height: 1.35;
  color: #227fab;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.brewery-card__link:focus-visible {
  outline: 2px solid #227fab;
  outline-offset: 2px;
}

/*
 * PC（1025px以上）
 * 【調整用 — :root】※ .mv__top-bar は .mv の外（main 直下）のため変数は :root に置く
 * · --mv-pc-topbar-inset-end … 右上（予約＋IG）の右端（画面右からの px）
 * · --mv-pc-page-top-inset-end … トップに戻るの右端（別変数・既定は topbar と同値で右端揃え）
 * · --mv-pc-topbar-inset-top … 予約ボタン／IGの上余白
 * · --mv-pc-ig-icon-size … 右上IGアイコン一辺（角丸スクエア・トップに戻るの直径とは別）
 * · --mv-pc-hero-shift-max … 青枠を下げる量（1025px幅時の最大px・数値のみ。大きいほど下へ）
 * · --mv-pc-hero-shift-zero-from … この幅以上で下げ0＝案B（既定1700。変更時は下の675も合わせる）
 * · --mv-pc-sp-menu-size … ハンバーガー直径（px）
 * · --mv-pc-topbar-gap-reserve-instagram … 予約ボタン右↔Instagram左の余白（px）
 * · --mv-pc-topbar-gap-instagram-menu … Instagram右↔ハンバーガー左の余白（px）
 * · --mv-pc-sp-menu-align-offset … ハンバーガーの天地微調整（px・+で下へ）
 * · --mv-pc-header-clearance … リボンが右上UIと被らないよう確保する右側余白（px）
 * · 狭いPC（1025〜1279px）… 別ブロックで上余白・クリアランス・リボン改行を調整
 */
@media (min-width: 1025px) {
  :root {
    --mv-pc-sp-menu-size: 56px;
    --mv-pc-topbar-gap-reserve-instagram: 12px;
    --mv-pc-topbar-gap-instagram-menu: 12px;
    --mv-pc-sp-menu-align-offset: 0px;
    --mv-pc-topbar-inset-end: 12px;
    --mv-pc-page-top-inset-end: 21px;
    --mv-pc-topbar-inset-top: 12px;
    --mv-pc-ig-icon-size: clamp(54px, 10vw, 82px);
    --mv-pc-hero-shift-max: 140;
    --mv-pc-hero-shift-zero-from: 1700;
    --mv-pc-header-clearance: 500px;
    /* MV右上ボタンのみ（セクション内CTAとは別） */
    --mv-pc-topbar-reserve-sub: 16px;
    --mv-pc-topbar-reserve-main: 20px;
    /* 日程帯（入場無料＋日時）の横位置 — 負の値で左へ */
    --mv-date-offset-x: -28px;
    --mv-date-offset-y: 0px;
  }

  .mv__top-bar:not(.mv__top-bar--side-vertical) .mv__reserve-sub {
    font-size: var(--mv-pc-topbar-reserve-sub);
  }

  .mv__top-bar:not(.mv__top-bar--side-vertical) .mv__reserve-main {
    font-size: var(--mv-pc-topbar-reserve-main);
  }

  .mv {
    /* (zero-from - 1025) = 675 のとき … calc((1700px - 100vw) * shift-max / 675) */
    --mv-pc-hero-offset-top: clamp(
      0px,
      calc((1700px - 100vw) * var(--mv-pc-hero-shift-max) / 675),
      calc(var(--mv-pc-hero-shift-max) * 1px)
    );
  }

  .mv__top-bar:not(.mv__top-bar--side-vertical) {
    --mv-corner-inset-top: var(--mv-pc-topbar-inset-top);
    --mv-corner-inset-inline-end: var(--mv-pc-topbar-inset-end);
  }

  /* 予約・IG・ハンバーガーを同一行で天地中央揃え（余白は個別変数で調整） */
  .mv__top-bar:not(.mv__top-bar--side-vertical) .mv__actions-group {
    gap: 0;
  }

  /* .mv__top-bar:not(.mv__top-bar--side-vertical) .mv__reserve-btn {
    margin-inline-end: var(--mv-pc-topbar-gap-reserve-instagram, 12px);
  } */

  .mv__top-bar:not(.mv__top-bar--side-vertical) .mv__instagram {
    margin-inline-end: var(--mv-pc-topbar-gap-instagram-menu, 12px);
  }

  /*
   * PC：予約・IG・ハンバーガーを flex で天地中央揃え（ハンバーガーは下部バー外だが cluster で整列）
   */
  .mv__top-bar-cluster {
    display: flex;
    align-items: center;
    position: fixed;
    inset-block-start: calc(var(--mv-pc-topbar-inset-top, 12px) + env(safe-area-inset-top, 0px));
    inset-inline-end: calc(var(--mv-pc-topbar-inset-end, 12px) + env(safe-area-inset-right, 0px));
    inset-block-end: auto;
    inset-inline-start: auto;
    z-index: 10000;
    gap: 0;
    pointer-events: none;
  }

  .mv__top-bar-cluster > * {
    pointer-events: auto;
  }

  .mv__top-bar-cluster .mv__top-bar {
    position: static;
    inset: auto;
  }

  .mv__top-bar .mv__actions-area,
  .mv__top-bar .mv__actions-group {
    pointer-events: auto;
  }

  .mv__top-bar-cluster .sp-menu {
    position: static;
    inset: auto;
    flex: 0 0 auto;
    align-self: center;
    margin: 0;
    translate: 0 var(--mv-pc-sp-menu-align-offset, 0px);
    --sp-menu-size: var(--mv-pc-sp-menu-size, 56px);
    --sp-menu-bar-height: 2px;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .mv__top-bar:not(.mv__top-bar--side-vertical) .mv__instagram-icon {
    width: var(--mv-pc-ig-icon-size);
    height: var(--mv-pc-ig-icon-size);
  }

  .mv .mv__logo-mark {
    --mv-corner-inset-top: var(--mv-pc-topbar-inset-top);
  }

  /*
   * 青枠（リボン）：画面の天地中央は維持（.mv__stage の center）
   * 狭いPC … padding-top で下げ＋右側クリアランスで右上UIと被らない
   */
  .mv__shell {
    padding-top: var(--mv-pc-hero-offset-top);
  }

  .mv__announce-area {
    box-sizing: border-box;
    max-inline-size: min(100%, calc(100vw - var(--mv-pc-header-clearance)));
    margin-inline: auto;
    padding-inline: clamp(12px, 2vw, 24px);
  }
}

/*
 * 狭いPC（1025〜1279px）— 1024px付近の不自然な上余白・リボン改行を抑える
 * 1280px以上は従来どおり（1450px付近の見え方を維持）
 * 【調整用 — :root】
 * · --mv-pc-narrow-hero-offset-max … 1025px幅時の上余白（既定 78px）
 * · --mv-pc-narrow-hero-offset-min … 1279px幅時の上余白の下限（既定 60px）
 * · --mv-pc-narrow-hero-offset-slope … 幅が広がるほど上余白を減らす量（既定 0.055）
 * · --mv-pc-narrow-header-clearance-min … リボン右クリアランス最小（既定 300px）
 * · --mv-pc-narrow-ribbon-min-width … リボン1行確保の最小幅（既定 700px）
 * · --mv-pc-narrow-ribbon-top-gap … リボン上の追加余白（既定 6px）
 */
@media (min-width: 1025px) and (max-width: 1279px) {
  :root {
    --mv-pc-narrow-hero-offset-max: 78px;
    --mv-pc-narrow-hero-offset-min: 60px;
    --mv-pc-narrow-hero-offset-slope: 0.055;
    --mv-pc-narrow-header-clearance-min: 300px;
    --mv-pc-narrow-ribbon-min-width: 700px;
    --mv-pc-narrow-ribbon-top-gap: 6px;
    --mv-pc-header-clearance: clamp(
      var(--mv-pc-narrow-header-clearance-min),
      calc(100vw - var(--mv-pc-narrow-ribbon-min-width)),
      480px
    );
  }

  .mv {
    /* 1280pxに近づくほど減らすが、1200px付近でもCTA下を確保（下限あり） */
    --mv-pc-hero-offset-top: clamp(
      var(--mv-pc-narrow-hero-offset-min),
      calc(
        var(--mv-pc-narrow-hero-offset-max)
        - (100vw - 1025px) * var(--mv-pc-narrow-hero-offset-slope)
      ),
      var(--mv-pc-narrow-hero-offset-max)
    );
  }

  .mv__stage {
    justify-content: flex-start;
    padding-block-start: clamp(10px, 1.5vw, 16px);
  }

  .mv__announce-area {
    margin-block-start: var(--mv-pc-narrow-ribbon-top-gap, 6px);
  }

  .mv__ribbon-text {
    white-space: nowrap;
    text-wrap: nowrap;
    font-size: clamp(16px, 2.35vw, 24px);
  }
}

/* PC・広い画面（案B）：下げ量0・画面中央 */
@media (min-width: 1700px) {
  .mv__shell {
    padding-top: 0;
  }
}

/* ---------- タブレット＋スマホ共通（max-width: 1024px）— レイアウト切替のみ。数値は 761〜1024 / 760以下 ---------- */
@media (max-width: 1024px) {
  /*
   * MV：1024px以下 — 予約バーは下部固定（1025px以上で右上表示）
   * 数値（余白・文字サイズ等）は @media (761px〜1024px) と @media (max-width: 760px) のみ
   */
  body {
    /* 下部バー grid（予約ボタン : Instagram = 8 : 2）— 比率変更時は page-top の横位置も連動 */
    --mv-bottom-bar-grid-gap: 4px;
    --mv-bottom-bar-reserve-fr: 8;
    --mv-bottom-bar-ig-fr: 2;
    --mv-bottom-bar-ig-col-start: calc(
      (100% - var(--mv-bottom-bar-grid-gap))
      * var(--mv-bottom-bar-reserve-fr)
      / (var(--mv-bottom-bar-reserve-fr) + var(--mv-bottom-bar-ig-fr))
      + var(--mv-bottom-bar-grid-gap)
    );
    padding-bottom: calc(var(--mv-bottom-bar-height) + env(safe-area-inset-bottom, 0px));
  }

  .mv__top-bar {
    inset-inline: 0;
    inset-block-start: auto;
    inset-block-end: 0;
    inline-size: 100%;
    display: block;
    margin: 0;
    padding: 0;
    padding-bottom: env(safe-area-inset-bottom, 0px);
    background: transparent;
    box-shadow: none;
  }

  .mv__actions-area {
    width: 100%;
  }

  .mv__actions-group {
    display: grid;
    /* fr 単位は var() と直接連結できないため数値は minmax + 固定 fr で指定 */
    grid-template-columns: minmax(0, 8fr) minmax(0, 2fr);
    gap: var(--mv-bottom-bar-grid-gap);
    width: 100%;
    margin: 0;
    padding: 0;
    align-items: stretch;
  }

  .mv__top-bar .mv__reserve-btn {
    width: 100%;
    min-width: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
    min-height: var(--mv-bottom-bar-height);
    height: auto;
    /* 上部 .mv__reserve-btn の clamp padding を確実に上書き */
    padding: var(--mv-bottom-bar-padding-y) var(--mv-bottom-bar-padding-x);
    border-radius: 6px;
    background-color: #f0154c;
    box-shadow: 0 2px 8px rgba(163, 15, 55, 0.35);
  }

  .mv__top-bar .mv__reserve-btn:hover,
  .mv__top-bar .mv__reserve-btn:active {
    transform: none;
    box-shadow: none;
  }

  .mv__top-bar .mv__reserve-btn-inner {
    width: 100%;
    justify-content: center;
    gap: 0;
  }

  .mv__top-bar .mv__reserve-icon {
    display: none;
  }

  /* 下部バー文字サイズは 761〜1024px／760px以下で端末別指定（ここでは font-family のみ共通） */
  .mv__top-bar .mv__reserve-sub {
    font-family: 'YDWaosagi', 'Hiragino Sans', sans-serif;
    font-weight: normal;
    letter-spacing: 0.02em;
    max-width: none;
    white-space: nowrap;
  }

  .mv__top-bar .mv__reserve-main {
    letter-spacing: 0.02em;
    white-space: nowrap;
  }

  /* スマホ向け：IGは固定高さ＋アイコン中央（タブレットは 761px〜 で上書き） */
  .mv__top-bar .mv__instagram {
    position: relative;
    width: 100%;
    box-sizing: border-box;
    height: var(--mv-bottom-bar-height);
    min-height: var(--mv-bottom-bar-height);
    max-height: var(--mv-bottom-bar-height);
    display: block;
    min-width: 0;
    overflow: visible;
    border-radius: 6px;
    background: linear-gradient(135deg, #833AB4 0%, #FD1D1D 48%, #FCB045 100%);
    box-shadow: 0 2px 8px rgba(163, 15, 55, 0.25);
    padding: 0;
  }

  .mv__top-bar .mv__instagram-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    display: block;
    width: var(--mv-bottom-bar-ig-icon-size);
    height: var(--mv-bottom-bar-ig-icon-size);
    translate: -50% -50%;
    transform: none;
    filter: none;
  }

  .mv__top-bar .mv__instagram-icon .mv__instagram-icon-bg {
    fill: transparent;
  }

  .mv__top-bar .mv__instagram:hover .mv__instagram-icon {
    translate: -50% -50%;
    transform: scale(1.04);
  }

  .mv__top-bar .mv__instagram:focus-visible {
    border-radius: 6px;
  }

  .lead__title-br {
    display: revert;
  }

  /*
   * lead 見出し・サブコピー（青枠テキスト）の白縁
   * タブレット実機では -webkit-text-stroke がギザギザになるため 1024px 以下は shadow
   * 太さを変える … --lead-text-outline-shadow の px を増減（1〜4 付近）
   */
  .lead {
    --lead-text-outline-shadow:
      1px 0 0 #fff,
      -1px 0 0 #fff,
      0 1px 0 #fff,
      0 -1px 0 #fff,
      1px 1px 0 #fff,
      -1px 1px 0 #fff,
      1px -1px 0 #fff,
      -1px -1px 0 #fff,
      2px 0 0 #fff,
      -2px 0 0 #fff,
      0 2px 0 #fff,
      0 -2px 0 #fff,
      2px 2px 0 #fff,
      -2px 2px 0 #fff,
      2px -2px 0 #fff,
      -2px -2px 0 #fff,
      3px 0 0 #fff,
      -3px 0 0 #fff,
      0 3px 0 #fff,
      0 -3px 0 #fff,
      3px 3px 0 #fff,
      -3px 3px 0 #fff,
      3px -3px 0 #fff,
      -3px -3px 0 #fff,
      4px 0 0 #fff,
      -4px 0 0 #fff,
      0 4px 0 #fff,
      0 -4px 0 #fff;
  }

  .lead__title,
  .lead__tagline {
    -webkit-text-stroke: 0;
    paint-order: normal;
    text-shadow: var(--lead-text-outline-shadow);
    -webkit-font-smoothing: antialiased;
  }

}

/*
 * タブレット専用（761〜1024px）— スマホ（760px以下）・PC（1025px以上）に影響しない
 */
@media (min-width: 761px) and (max-width: 1024px) {
  /* セクション内CTA（テーブル有料席・注意事項） */
  .notes__reserve-btn .mv__reserve-sub,
  .table-seat__reserve-btn .mv__reserve-sub {
    font-size: 17px;
  }

  .notes__reserve-btn .mv__reserve-main,
  .table-seat__reserve-btn .mv__reserve-main {
    font-size: 19px;
  }

  .brewery {
    padding-block: 52px 0;
  }

  .coming-soon {
    --coming-soon-gap-top: 86px;
    --coming-soon-gap-bottom: 106px;
  }

  .brewery__title,
  .table-seat__title,
  .access__title {
    font-size: 40px; /* タブレット — セクションタイトル */
  }

  .brewery__title-wave {
    width: 323px;
  }

  .brewery__map-frame {
    padding: 18px;
  }

  .notes__panel {
    padding: 32px 28px 28px;
  }

  .notes__panel--request {
    margin-top: 28px;
  }

  .notes__title {
    font-size: 28px;
  }

  .notes__list > li,
  .notes__section-heading,
  .notes__pay-intro,
  .notes__pay-tag,
  .notes__pay-desc {
    font-size: 16px;
  }

  .table-seat__lead {
    font-size: 22px;
  }

  .brewery__lead {
    font-size: 22px;
  }

  .access__title-wave {
    width: 272px;
    margin-bottom: 24px;
  }

  /*
   * フッター — タブレット背景（.site-bg__fixed）より前面（SP は 760px 以下で同様）
   * 下部バー分は body の padding-bottom ではなくフッター内（オレンジ）に含める
   * （body 側だとフッター直後に白い余白ができ、最下部までスクロールすると下部バー下が白く見える）
   */
  body {
    padding-bottom: 0;
  }

  .site-footer {
    position: relative;
    z-index: 1;
    padding-block: 48px
      calc(56px + var(--mv-bottom-bar-height) + env(safe-area-inset-bottom, 0px));
    padding-inline: 24px;
  }

  /* safe-area は padding で確保（inset-block-end を変えると iOS でレイアウトが揺れやすい） */
  .mv__top-bar {
    inset-block-end: 0;
    padding-bottom: env(safe-area-inset-bottom, 0px);
  }

  .site-footer__title {
    margin-bottom: 28px;
    font-size: 28px;
  }

  .site-footer__sponsors {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 32px;
  }

  .site-footer__sponsor {
    min-height: 72px;
  }

  .site-footer__divider {
    margin-bottom: 32px;
  }

  .site-footer__contact-detail {
    margin-bottom: 32px;
  }

  .site-footer__orgs {
    gap: 24px;
    padding-bottom: 32px;
  }

  .site-footer__terms {
    margin-top: 18px;
  }

  .table-seat__columns {
    gap: 20px;
  }

  .table-seat__seats-map {
    --table-seat-seats-map-gap-top: 24px;
    --table-seat-seats-map-gap-bottom: 24px;
  }

  .table-seat__purchase {
    gap: 16px 24px;
  }

  .table-seat__seat-info {
    margin-top: 24px;
  }

  .table-seat__purchase-title,
  .table-seat__purchase-list > li {
    font-size: 16px;
  }

  .brewery__grid {
    margin-top: 28px;
  }

  .brewery-card__label {
    font-size: 14px;
  }

  .brewery-card__desc,
  .brewery-card__detail,
  .brewery-card__links {
    font-size: 16px;
  }

  .lead__badge {
    padding: 9px 15px;
  }

  .mv__logo-mark {
    width: clamp(32px, 5.5vw, 48px);
  }

  .mv {
    --mv-corner-inset-top: 10px;
    --mv-corner-inset-inline-start: 10px;
    --mv-corner-inset-inline-end: 10px;
  }

  .mv__mv-picture--main {
    max-width: min(100%, 480px);
  }

  .mv__mv-picture--date {
    max-width: min(100%, 420px);
  }

  .lead-panel__label {
    font-size: 19px;
  }

  .lead-panel--schedule .lead-panel__highlight {
    font-size: 17px;
  }

  .lead-panel__schedule-badge {
    font-size: 14px;
  }

  .lead-panel--schedule .lead-panel__day {
    font-size: 16px;
  }

  .lead-panel--schedule .lead-panel__hours {
    font-size: 14px;
  }

  .lead-panel__map-icon {
    width: 38px;
  }

  .lead-panel__venue-name {
    font-size: 17px;
  }

  .lead-panel__fee-main {
    font-size: 20px;
  }

  .lead-panel__fee-note {
    font-size: 14px;
    padding: 6px 20px;
  }

  .lead__panels-side-gap {
    height: 36px;
  }

  .lead-panel__schedule-day {
    padding-inline-end: 14px;
  }

  .lead-panel__schedule-badge-slot {
    padding-inline: 14px;
  }

  .lead-panel__schedule-vrule {
    margin-inline-end: 8px;
  }

  /*
   * 下部バー（タブレット）
   * · --mv-bottom-bar-height … 青枠全体の高さ（予約ボタン＋IGボタン）
   * · --mv-bottom-bar-ig-icon-size … 白IGアイコンだけ（大きくしてもバー高さは変わらない）
   * · --mv-bottom-bar-padding-y / -x … 予約ボタン内余白（高さとは別）
   */
  body,
  .mv__top-bar {
    --mv-bottom-bar-padding-y: 16px;
    --mv-bottom-bar-padding-x: 8px;
    --mv-bottom-bar-height: 80px;
    --mv-bottom-bar-ig-icon-size: 72px;
  }

  .mv__top-bar .mv__reserve-btn {
    height: var(--mv-bottom-bar-height);
    min-height: var(--mv-bottom-bar-height);
    max-height: var(--mv-bottom-bar-height);
  }

  .mv__top-bar .mv__instagram {
    height: var(--mv-bottom-bar-height);
    min-height: var(--mv-bottom-bar-height);
    max-height: var(--mv-bottom-bar-height);
    display: block;
    padding: 0;
    overflow: visible;
  }

  .mv__top-bar .mv__instagram-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
    transform: none;
  }

  .mv__top-bar .mv__instagram:hover .mv__instagram-icon {
    translate: -50% -50%;
    transform: scale(1.04);
  }

  /* 下部バー — 文字サイズ（タブレットのみ） */
  .mv__top-bar .mv__reserve-lines {
    gap: 2px;
  }

  .mv__top-bar .mv__reserve-sub {
    font-size: 14px;
    line-height: 1.25;
  }

  .mv__top-bar .mv__reserve-main {
    font-size: 24px;
    line-height: 1.2;
  }
}

/* ---------- スマホ専用（max-width: 760px）— タブレット・PCに影響しない ---------- */
@media (max-width: 760px) {
  /* セクション内CTA */
  .notes__reserve-btn .mv__reserve-sub,
  .table-seat__reserve-btn .mv__reserve-sub {
    font-size: 16px;
  }

  .notes__reserve-btn .mv__reserve-main,
  .table-seat__reserve-btn .mv__reserve-main {
    font-size: 18px;
  }

  .brewery__title,
  .table-seat__title,
  .access__title {
    font-size: 32px; /* スマホ — セクションタイトル */
  }

  /* 下部バー */
  body,
  .mv__top-bar {
    --mv-bottom-bar-padding-y: 6px;
    --mv-bottom-bar-padding-x: 8px;
    --mv-bottom-bar-height: 52px;
    --mv-bottom-bar-ig-icon-size: 62px;
  }

  .mv__top-bar .mv__reserve-btn {
    padding: var(--mv-bottom-bar-padding-y) var(--mv-bottom-bar-padding-x);
    min-height: var(--mv-bottom-bar-height);
  }

  .mv__top-bar .mv__instagram {
    height: var(--mv-bottom-bar-height);
    min-height: var(--mv-bottom-bar-height);
    max-height: var(--mv-bottom-bar-height);
    display: block;
    padding: 0;
  }

  .mv__top-bar .mv__instagram-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
    transform: none;
  }

  .mv__top-bar .mv__instagram:hover .mv__instagram-icon {
    translate: -50% -50%;
    transform: scale(1.04);
  }

  /* 下部バー — 文字サイズ（スマホのみ） */
  .mv__top-bar .mv__reserve-lines {
    gap: 2px;
  }

  .mv__top-bar .mv__reserve-sub {
    font-size: 18px;
    line-height: 1.25;
  }

  .mv__top-bar .mv__reserve-main {
    font-size: 18px;
    line-height: 1.2;
  }

  .brewery {
    padding: 42px 16px 0;
  }

  .brewery__title-wave {
    width: 251px;
    margin-bottom: 16px;
  }

  .brewery__lead {
    font-size: 20px; /* スマホ — リード文 */
  }

  .brewery__lead br {
    display: none;
  }

  .brewery__map-frame {
    margin-top: 24px;
    padding: 10px;
    overflow-x: hidden;
    border-radius: 6px;
  }

  .brewery__map {
    width: 100%;
    max-width: 100%;
  }

  /* ブルワリーカード：ラベル（赤枠）— スマホ */
  .brewery-card__label {
    font-size: 14px;
  }

  /* ブルワリーカード：本文（青枠）— スマホ */
  .brewery-card__desc,
  .brewery-card__detail,
  .brewery-card__links {
    font-size: 16px;
  }

  .brewery-card__name {
    font-size: 16px;
  }

  .brewery-card__desc {
    margin-top: 16px;
  }

  .brewery-card__block {
    margin-top: 24px;
  }

  .mv__logo-mark {
    width: clamp(22px, 6vw, 30px); /* スマホ — 1024px以下よりやや小さく */
  }

  /* lead：約760px以下 */
  .lead {
    padding: 40px 18px 100px;
  }

  .lead__badge {
    padding: 8px 12px;
  }

  .lead__hero {
    margin-top: 10px;
    gap: 16px 12px;
  }

  .lead__tagline {
    margin-top: 12px;
  }

  .lead-panel__label {
    font-size: 18px;
    padding: 7px 42px;
  }

  .lead__panels {
    gap: 36px;
    margin-top: 60px;
  }

  .lead-panel {
    padding: 42px 14px 20px;
  }

  .lead-panel--admission {
    padding-top: calc(var(--lead-panel-admission-label-half) + var(--lead-panel-admission-label-gap));
  }

  /* lead 3パネル：スマホ文字サイズ */
  .lead-panel--schedule .lead-panel__highlight {
    font-size: 16px;
  }

  .lead-panel__schedule-days {
    gap: 10px;
  }

  /* 開催日程：余白（スマホ） */
  .lead-panel__schedule-day {
    padding-block: 14px 12px;
    padding-inline-end: 12px;
    border-radius: 12px;
  }

  .lead-panel__schedule-badge-slot {
    padding-inline: 12px;
  }

  .lead-panel__schedule-badge {
    font-size: 14px;
    padding: 6px 8px;
  }

  .lead-panel__schedule-vrule {
    grid-row: 1;
    margin-inline-end: 8px;
    min-height: 44px;
  }

  .lead-panel--schedule .lead-panel__day {
    font-size: 17px;
  }

  .lead-panel__schedule-meta {
    justify-content: center;
    gap: 8px 12px;
  }

  .lead-panel--schedule .lead-panel__hours {
    padding: 8px 12px;
    font-size: 15px;
  }

  .lead-panel__map-icon {
    width: 36px;
  }

  .lead-panel__venue-name {
    font-size: 17px;
  }

  .lead-panel__fee-main {
    font-size: 19px;
  }

  .lead-panel__fee-note {
    font-size: 14px;
    padding: 5px 14px;
  }

  /* 地図とカード一覧のあいだ（スマホ）— ここだけ変更 */
  .brewery__grid {
    grid-template-columns: repeat(1, minmax(0, 1fr));
    margin-top: 24px;
  }

  /*
   * Coming Soon 前後の余白（スマホ）
   * --coming-soon-gap-top … 上の青枠（ブルワリーカード下〜Coming Soon上）
   * --coming-soon-gap-bottom … 下の青枠（Coming Soon下〜テーブル有料席上）
   */
  .coming-soon {
    --coming-soon-gap-top: 56px;
    --coming-soon-gap-bottom: 72px;
    /* SP — 文字の縁取り（太さ 色） */
    --coming-soon-label-stroke: 1.5px #1a5278;
    --coming-soon-title-stroke: 3px #1a5278;
  }

  /* SP：店舗看板（上）＋店先イラスト（下・中央寄せ） */
  .coming-soon__body {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    row-gap: 6px;
    padding: 10px 14px 16px;
    align-items: stretch;
  }

  .coming-soon__copy {
    grid-column: 1;
    grid-row: 1;
    padding-bottom: 2px;
  }

  /*
   * 店先イラスト（キッチンカー｜キャラクター）
   * --coming-soon-storefront-gap … 2枚のあいだの距離（0でぴったり、8pxで少し空く）
   * マイナス値も可（例: -12px でさらに寄せる）
   */
  .coming-soon__storefront {
    --coming-soon-storefront-gap:22px;
    display: flex;
    grid-column: 1;
    grid-row: 2;
    justify-content: center;
    align-items: flex-end;
    gap: var(--coming-soon-storefront-gap);
    width: 100%;
  }

  .coming-soon__kitchen {
    grid-column: auto;
    grid-row: auto;
    justify-self: auto;
    align-self: auto;
    flex-shrink: 0;
    width: min(46vw, 129px);
  }

  .coming-soon__character {
    grid-column: auto;
    grid-row: auto;
    justify-self: auto;
    align-self: auto;
    flex-shrink: 0;
    width: min(40vw, 92px);
  }

  .coming-soon__label {
    font-size: clamp(16px, 6.2vw, 20px);
  }

  .coming-soon__title {
    font-size: clamp(26px, 9.8vw, 48px);
  }

  .table-seat {
    padding: 0 16px 48px;
  }

  .table-seat__title-wave {
    width: 225px;
    margin-bottom: 16px;
  }

  .table-seat__lead {
    margin-bottom: 20px;
    font-size: 20px; /* スマホ — リード文 */
  }

  /* 下部共通背景：スマホ（760px以下）— pc.jpg をやめ sp.jpg の fixed レイヤーへ */
  .mv,
  .lead {
    position: relative;
    z-index: 1;
  }

  .site-footer {
    position: relative;
    z-index: 1;
  }

  .site-bg--parallax {
    background-image: none;
    background-attachment: scroll;
  }

  .site-bg--parallax .site-bg__fixed {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 0;
    background-color: #fff;
    background-image: url('assets/images/bg-beer-bubbles2-sp.jpg');
    background-repeat: no-repeat;
    background-position: center top;
    background-size: cover;
    pointer-events: none;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }

  .table-seat__cta {
    margin-bottom: 32px;
  }



  .table-seat__board-wave {
    width: 160px;
    margin-bottom: 24px;
  }

  .table-seat__columns {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .table-seat__column-title,
  .table-seat__day-title,
  .table-seat__slot {
    font-size: 16px;
  }

  .table-seat__slot-note {
    font-size: 14px; /* スマホ — 限定発売注釈 */
    padding-left: 26px;
  }

  .table-seat__column-body {
    padding: 16px 16px 20px;
  }

  .table-seat__tax {
    font-size: 14px;
    padding: 10px 20px;
  }

  .table-seat__seats-map {
    --table-seat-seats-map-gap-top: 20px;
    --table-seat-seats-map-gap-bottom: 20px;
  }

  .table-seat__purchase {
    flex-direction: column;
    align-items: center;
    gap: 12px;
  }

  .table-seat__purchase-list {
    flex: none; /* スマホ — 縦並び時に flex-basis 280px で空きが出ないようにする */
  }

  .table-seat__purchase-icon {
    width: 40px;
    height: 40px;
  }

  .table-seat__purchase-icon-img {
    width: 24px;
  }

  .table-seat__purchase-title,
  .table-seat__purchase-list > li {
    font-size: 16px;
  }

  .table-seat__seat-info {
    grid-template-columns: 1fr;
    gap: 12px;
    margin-top: 20px; /* スマホ — 料金表と座席カードの間隔 */
  }

  .table-seat__seat-card {
    padding: 16px 14px 18px;
  }

  .table-seat__seat-card-title {
    font-size: 16px;
    margin-bottom: 10px;
  }

  .table-seat__seat-card-divider {
    margin-bottom: 10px;
  }

  .table-seat__seat-card-text {
    font-size: 14px;
  }

  .access {
    padding: 40px 16px 56px;
  }

  .access__title-wave {
    width: 227px;
    margin-bottom: 20px;
  }

  .access__venue {
    margin-bottom: 24px;
    font-size: 16px;
  }

  .access__routes {
    flex-direction: column;
    align-items: center;
    gap: 16px;
    margin-bottom: 24px;
  }

  .access__route {
    width: 100%;
    max-width: 320px;
    justify-content: center;
  }

  .access__parking {
    gap: 8px;
    margin-bottom: 24px;
  }

  .access__parking-mark {
    width: 40px;
    height: 40px;
    font-size: 20px;
  }

  .access__parking-heading {
    font-size: 16px;
  }

  .access__parking-body {
    font-size: 14px;
    line-height: 1.7;
  }

  .access__map {
    --access-map-max-width: 100%;
    padding: 3px;
    border-width: 2px;
  }

  .site-footer {
    padding: 40px 16px 48px;
  }

  .site-footer__title {
    margin-bottom: 24px;
    font-size: 22px; /* スマホ — イベント名 */
    letter-spacing: 0.06em;
  }

  .site-footer__sponsors {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-bottom: 28px;
  }

  .site-footer__sponsor {
    min-height: 64px;
    padding: 10px 12px;
  }

  .site-footer__sponsor-placeholder {
    font-size: 12px; /* スマホ — プレースホルダー */
  }

  .site-footer__divider {
    margin-bottom: 28px;
  }

  .site-footer__contact-heading {
    font-size: 16px; /* スマホ — 問合せ見出し */
  }

  .site-footer__contact-lead,
  .site-footer__contact-detail,
  .site-footer__org-name {
    font-size: 14px; /* スマホ — 問合せ・主催後援 */
  }

  .site-footer__contact-detail {
    margin-bottom: 28px;
  }

  .site-footer__org-label {
    font-size: 12px; /* スマホ — 主催・後援ラベル */
    padding: 3px 12px;
  }

  .site-footer__orgs {
    gap: 20px;
    padding-bottom: 20px;
  }

  .site-footer__terms {
    margin-top: 16px;
  }

  .site-footer__terms-link {
    font-size: 14px; /* スマホ — イベント参加規約 */
  }

  .notes {
    padding: 40px 16px 56px;
  }

  .notes__panel {
    padding: 28px 18px 24px;
    border-radius: 14px;
  }

  .notes__panel--request {
    margin-top: 24px; /* スマホ — 注意事項パネルとの間隔 */
  }

  .notes__title {
    margin-bottom: 20px;
    font-size: 24px;
  }

  .notes__list > li,
  .notes__section-heading,
  .notes__pay-intro,
  .notes__pay-tag,
  .notes__pay-desc {
    font-size: 16px;
  }

  .notes__list > li {
    margin-bottom: 12px;
  }

  .notes__pay-intro {
    margin-top: 20px;
  }

  .notes__pay-visual {
    gap: 16px 12px; /* スマホ — 2列時の横／縦間隔 */
    width: 100%;
  }

  /* 3件・2列のとき、3つ目（コード決済）を中央寄せ */
  .notes__pay-visual-item:last-child:nth-child(3) {
    grid-column: 1 / -1;
    width: min(100%, 280px);
    margin-inline: auto;
  }

  .notes__pay-visual-label {
    font-size: 16px;
    padding: 8px 10px;
  }

  .notes__pay-note {
    font-size: 14px;
  }

  .notes__cta {
    margin-top: 24px;
  }

  /* セクション内 CTA（下部固定バーとは別レイアウト） */
  .notes__reserve-btn,
  .table-seat__reserve-btn {
    width: 100%;
    max-width: 480px;
    padding: 14px 24px;
    min-height: 0;
    border-radius: 999px;
    box-shadow:
      0 3px 0 #a30f37,
      0 10px 20px rgba(240, 21, 76, 0.24);
  }

  /* mv：約760px以下（画像は HTML の picture で *-sp に切替） */
  .mv {
    /*
     * スマホMV余白（ロゴ高さとは独立）
     * --mv-sp-hero-offset-top … 画面上端〜リボン上（青枠）。ここだけ変更
     * --mv-sp-hero-offset-bottom … 日程帯（入場無料）下。padding-block-end に反映
     */
    --mv-sp-hero-offset-top: 48px; /* スマホ — 画面上端〜リボン上（青矢印の余白） */
    --mv-sp-hero-offset-bottom: 40px;
    --mv-date-offset-x: -14px;
    --mv-date-offset-y: 0px;
    padding-inline: 10px;
    padding-block:
      0
      var(--mv-sp-hero-offset-bottom);
    --mv-corner-inset-top: 10px;
    --mv-corner-inset-inline-start: 10px;
    --mv-corner-inset-inline-end: 10px;
  }

  .mv__mv-bg-img {
    object-position: center bottom;
  }

  .mv__shell {
    inline-size: 100%;
    padding-top: var(--mv-sp-hero-offset-top); /* スマホ — 青枠余白（ロゴ高さと無関係） */
  }

  .mv__stage {
    justify-content: flex-start;
    /* スマホMV：上は .mv__shell padding-top、下は .mv padding-block-end */
    padding-block: 0;
    padding-inline: 0;
  }

  .mv__hero-stack {
    gap: 8px; /* スマホ — リボンとメイン画像の間隔 */
  }

  .mv__ribbon-text {
    font-size: clamp(14px, 4.2vw, 21px);
    text-wrap: balance;
  }

  .mv__announce-area {
    position: relative;
    z-index: 3;
    translate: 0 0;
    padding-inline: clamp(4px, 1.5vw, 10px);
    margin-bottom: 0;
  }

  .mv__ribbon-inner {
    max-inline-size: 100%;
    padding:
      clamp(6px, 1.8vw, 8px)
      clamp(14px, 4vw, 28px)
      clamp(6px, 1.8vw, 8px)
      clamp(16px, 4.5vw, 32px);
  }

  /* スマホ：メイン画像の表示幅 */
  .mv__mv-picture--main {
    max-width: min(100%, 410px);
  }

  /* スマホ：日程帯の表示幅 */
  .mv__mv-picture--date {
    max-width: min(100%, 370px);
  }

  .mv__mv-cluster {
    margin-top: 0;
    filter: drop-shadow(0 6px 14px rgba(12, 40, 80, 0.1));
  }

  .lead__hero {
    flex-wrap: wrap;
    align-items: center;
  }

  .lead__copy {
    flex: 1 0 100%;
    order: -1;
    min-width: 0;
    max-width: none;
    padding-block-end: 0;
  }

  .lead__mug-img {
    max-width: 108px;
  }

  /* レイアウトA相当：3パネル縦積み（スマホ） */
  .lead__panels {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .lead-panel--schedule,
  .lead__panels-side {
    grid-column: auto;
    grid-row: auto;
  }

  /* 右列：自然な高さ（縦積み） */
  .lead__panels-side {
    height: auto;
    min-height: 0;
  }

  .lead__panels-side > .lead-panel {
    flex: 0 0 auto;
  }

  /* 会場と入場料のあいだ（スマホ） */
  .lead__panels-side-gap {
    height: 36px;
  }

  .lead__panels > .lead-panel--schedule {
    height: auto;
  }

  .lead-panel--venue .lead-panel__center-block {
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }

  .lead-panel--venue .lead-panel__venue-name {
    text-align: center;
  }

  .lead-panel__label {
    white-space: normal;
    text-align: center;
    max-width: 92vw;
  }
}

/* =============================================================================
   MV：タブレット（761〜1024px）— スマホ（760px以下）には当てない
   【調整用 — .mv 内の変数】
   · --mv-tablet-hero-offset-top … 上余白（リボン上まで）
   · --mv-tablet-hero-offset-bottom … 下余白（日程下・青枠）
   · --mv-tablet-main-max-width … メイン画像の最大幅（px）
   · --mv-tablet-date-max-width … 日程画像の最大幅（px）
   · --mv-tablet-hero-stack-gap … リボンとメイン画像の間隔
============================================================================= */
@media (min-width: 761px) and (max-width: 1024px) {
  .mv {
    --mv-tablet-hero-offset-top: 24px;
    --mv-tablet-hero-offset-bottom: 12px;
    --mv-tablet-main-max-width: 590px;
    --mv-tablet-date-max-width: 500px;
    --mv-tablet-hero-stack-gap: 10px;
    --mv-date-offset-x: -20px;
    --mv-date-offset-y: 0px;
    padding-block-end: var(--mv-tablet-hero-offset-bottom);
  }

  .mv__shell {
    padding-top: var(--mv-tablet-hero-offset-top);
  }

  .mv__stage {
    padding-block-start: 0;
  }

  .mv__ribbon-text {
    white-space: nowrap;
    text-wrap: nowrap;
    font-size: clamp(16px, 2.4vw, 22px);
  }

  .mv__hero-stack {
    gap: var(--mv-tablet-hero-stack-gap);
  }

  .mv__mv-picture--main {
    max-width: min(100%, var(--mv-tablet-main-max-width));
  }

  .mv__mv-picture--date {
    max-width: min(100%, var(--mv-tablet-date-max-width));
  }

  .mv__stage {
    justify-content: flex-start;
  }

  .mv__mv-cluster {
    width: 100%;
    max-width: var(--mv-tablet-main-max-width);
  }
}

/* =============================================================================
   ハンバーガーメニュー（全幅・表示タイミングは main.js の SP_MENU_VISIBLE_ON_MV）

   【調整用 CSS 変数 — .sp-menu 内で変更】
   · --sp-menu-size … ボタン一辺（既定 44px）
   · --sp-menu-inset-top / --sp-menu-inset-end … 右上からの位置（既定 10px）
   · --sp-menu-bg … 背景色（既定 #fff）
   · --sp-menu-bar-color … 3本線の色（既定 #3a3a3a）
   · --sp-menu-bar-height … 3本線の太さ（既定 2px）例: 1.5px で細く
   · --sp-menu-bar-width … 3本線の横幅（既定 20px）
   · --sp-menu-bar-gap … 線と線の間隔（既定 5px）
   · --sp-menu-border-color … 枠線色（TOP ボタンと同じ #ffc559）
   · --sp-menu-border-width … 枠線太さ（TOP ボタンと同じ比率）
============================================================================= */
.sp-menu {
  --sp-menu-size: 56px;
  --sp-menu-inset-top: 10px;
  --sp-menu-inset-end: 10px;
  --sp-menu-bg: #fff;
  --sp-menu-border-color: #ffc559;
  --sp-menu-border-width: max(2px, calc(var(--sp-menu-size) * 3 / 88));
  --sp-menu-bar-color: #ffc559;
  --sp-menu-bar-height: 1px;
  --sp-menu-bar-width: 20px;
  --sp-menu-bar-gap: 5px;

  position: fixed;
  inset-block-start: calc(
    var(--sp-menu-inset-top) + env(safe-area-inset-top, 0px) + var(--sp-menu-vv-offset, 0px)
  );
  inset-inline-end: calc(var(--sp-menu-inset-end) + env(safe-area-inset-right, 0px));
  z-index: 10002;
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: var(--sp-menu-size);
  block-size: var(--sp-menu-size);
  padding: 0;
  border: var(--sp-menu-border-width) solid var(--sp-menu-border-color);
  border-radius: 50%;
  -webkit-appearance: none;
  appearance: none;
  background-color: #fff;
  background-color: var(--sp-menu-bg);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.16);
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity 0.35s ease,
    visibility 0.35s ease;
}

.sp-menu.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.sp-menu:hover,
.sp-menu:active,
.sp-menu:focus {
  background-color: var(--sp-menu-bg);
}

.sp-menu:focus-visible {
  outline: 3px solid #227fab;
  outline-offset: 3px;
}

.sp-menu__icon {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: var(--sp-menu-bar-gap);
  inline-size: var(--sp-menu-bar-width);
}

.sp-menu__bar {
  display: block;
  block-size: var(--sp-menu-bar-height);
  border-radius: calc(var(--sp-menu-bar-height) / 2);
  background-color: var(--sp-menu-bar-color);
}

@media (min-width: 761px) and (max-width: 1024px) {
  /* ハンバーガーアンカー用（main.js が scroll-margin-top を反映してスクロール） */
  #brewery-heading,
  #table-seat-heading,
  #access-heading {
    scroll-margin-top: 72px;
  }

}

@media (max-width: 760px) {
  #brewery-heading,
  #table-seat-heading,
  #access-heading {
    scroll-margin-top: 72px;
  }
}

@media (min-width: 1025px) {
  #brewery-heading,
  #table-seat-heading,
  #access-heading {
    scroll-margin-top: 80px;
  }

  .sp-menu-panel {
    --sp-menu-panel-inset-top: var(--mv-pc-topbar-inset-top, 12px);
    --sp-menu-panel-inset-end: var(--mv-pc-topbar-inset-end, 12px);
  }
}

/* =============================================================================
   ハンバーガー — 開いたメニューパネル（全幅・1024px以下は inset 10px／PCは --mv-pc-topbar-*）

   【調整用 CSS 変数 — .sp-menu-panel 内】
   · --sp-menu-panel-accent … リンク文字・矢印・区切り線（既定 #d78500）
   · --sp-menu-panel-width … パネル幅（既定 min(280px, calc(100vw - 20px))）
   · --sp-menu-panel-inset-top / --sp-menu-panel-inset-end … 右上位置（既定 10px）
============================================================================= */
.sp-menu-panel {
  --sp-menu-panel-accent: var(--site-orange-text);
  --sp-menu-panel-divider: rgba(215, 133, 0, 0.45);
  --sp-menu-panel-inset-top: 10px;
  --sp-menu-panel-inset-end: 10px;
  --sp-menu-panel-width: min(280px, calc(100vw - 20px));
  --sp-menu-panel-duration: 0.42s;
  --sp-menu-panel-ease: cubic-bezier(0.22, 1, 0.36, 1);

  position: fixed;
  inset: 0;
  z-index: 10003;
  display: block;
  pointer-events: none;
}

.sp-menu-panel__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0);
  transition: background var(--sp-menu-panel-duration) ease;
}

.sp-menu-panel__sheet {
  position: absolute;
  inset-block-start: calc(var(--sp-menu-panel-inset-top) + env(safe-area-inset-top, 0px));
  inset-inline-end: calc(var(--sp-menu-panel-inset-end) + env(safe-area-inset-right, 0px));
  inline-size: var(--sp-menu-panel-width);
  padding: 14px 12px 8px;
  border-radius: 4px;
  background: #fff;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.14);
  opacity: 0;
  transform: translateY(-10px) scale(0.97);
  transform-origin: top right;
  transition:
    opacity var(--sp-menu-panel-duration) var(--sp-menu-panel-ease),
    transform var(--sp-menu-panel-duration) var(--sp-menu-panel-ease);
}

.sp-menu-panel.is-open,
.sp-menu-panel.is-menu-shown {
  pointer-events: auto;
  visibility: visible;
}

.sp-menu-panel.is-open .sp-menu-panel__backdrop,
.sp-menu-panel.is-menu-shown .sp-menu-panel__backdrop {
  background: rgba(0, 0, 0, 0.1);
}

.sp-menu-panel.is-open .sp-menu-panel__sheet,
.sp-menu-panel.is-menu-shown .sp-menu-panel__sheet {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.sp-menu-panel__close {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-inline-start: auto;
  margin-block-end: 4px;
  padding: 4px;
  border: none;
  background: transparent;
  color: #8c8c8c;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}

.sp-menu-panel__close:focus-visible {
  outline: 2px solid #227fab;
  outline-offset: 2px;
  border-radius: 4px;
}

.sp-menu-panel__close-icon {
  display: block;
}

.sp-menu-panel__visually-hidden {
  position: absolute;
  inline-size: 1px;
  block-size: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.sp-menu-panel__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.sp-menu-panel__item {
  border-block-end: 1px solid var(--sp-menu-panel-divider);
}

.sp-menu-panel__item:last-child {
  border-block-end: none;
}

.sp-menu-panel__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 4px 16px 8px;
  color: var(--sp-menu-panel-accent);
  font-family: 'YDWaosagi', 'Hiragino Sans', sans-serif;
  font-size: 17px;
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: 0.02em;
  text-decoration: none;
}

.sp-menu-panel__link:focus-visible {
  outline: 2px solid #227fab;
  outline-offset: -2px;
  border-radius: 2px;
}

.sp-menu-panel__chevron {
  flex-shrink: 0;
  color: var(--sp-menu-panel-accent);
}

body.is-sp-menu-open {
  overflow: hidden;
}

@media (prefers-reduced-motion: reduce) {
  .sp-menu-panel {
    --sp-menu-panel-duration: 0.01ms;
  }

  .sp-menu-panel__sheet {
    transform: none;
  }

  .sp-menu-panel.is-open .sp-menu-panel__sheet,
  .sp-menu-panel.is-menu-shown .sp-menu-panel__sheet {
    transform: none;
  }
}

/* =============================================================================
   トップに戻る（画面右下・MV が見えなくなったらフェードイン）
   デザイン: 円形・上段ビールイラスト／下段黄色帯＋「TOP」

   【調整用 CSS 変数（.page-top 内）】
   · --page-top-size … 円の直径（SP 72px / タブレット 76px / PC は IG と同 clamp）
   · PC 1025px+ … :root の --mv-pc-page-top-inset-end（右上とは別変数）
   · --page-top-inset-end-tablet … 761〜1024px（画面右からの px）
   · --page-top-inset-end-sp … 〜760px（画面右からの px。下部バーとは別）
   · --page-top-inset-bottom … 下からの距離（PC 既定 32px）
   · --page-top-gap-above-bar … 〜1024px、下部固定バー上の余白（既定 12px）
   · --page-top-beer-offset-x … ビールアイコンの横位置（正=右 / 負=左）
============================================================================= */
.page-top {
  appearance: none;
  margin: 0;
  padding: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  --page-top-size: 72px;
  --page-top-beer-offset-x: 3px;
  --page-top-yellow: #ffc559;
  --page-top-cream: #fff8ef;
  --page-top-brown: #5c3d0f;
  --page-top-inset-end: 16px;
  --page-top-inset-end-tablet: 24px;
  --page-top-inset-end-sp: 16px;
  --page-top-inset-bottom: 20px;
  --page-top-gap-above-bar: 12px;
  --page-top-beer-height: calc(var(--page-top-size) * 42 / 88);
  --page-top-text-size: calc(var(--page-top-size) * 11 / 88);
  --page-top-border-width: max(2px, calc(var(--page-top-size) * 3 / 88));

  position: fixed;
  inset-inline-end: calc(var(--page-top-inset-end) + env(safe-area-inset-right, 0px));
  inset-block-end: calc(var(--page-top-inset-bottom) + env(safe-area-inset-bottom, 0px));
  z-index: 10001;
  display: grid;
  grid-template-rows: 7fr 5fr;
  inline-size: var(--page-top-size);
  block-size: var(--page-top-size);
  border: var(--page-top-border-width) solid var(--page-top-yellow);
  border-radius: 50%;
  overflow: hidden;
  background: var(--page-top-cream);
  box-shadow: 0 4px 16px rgba(120, 70, 10, 0.2);
  text-decoration: none;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity 0.35s ease,
    visibility 0.35s ease;
}

.page-top.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.page-top:focus-visible {
  outline: 3px solid #227fab;
  outline-offset: 4px;
}

.page-top__art {
  display: flex;
  align-items: center;
  justify-content: center;
  min-block-size: 0;
  background: var(--page-top-cream);
}

.page-top__beer {
  display: block;
  inline-size: auto;
  block-size: var(--page-top-beer-height);
  max-block-size: 100%;
  margin-inline-start: var(--page-top-beer-offset-x);
  transform-origin: 50% 92%;
}

/* ホバー時：グラスを少し持ち上げて傾け、乾杯したようなかすかな揺れ（overflow:hidden のまま円内で完結） */
@keyframes page-top-beer-cheers {
  0% {
    transform: translateY(0) rotate(0deg);
  }

  22% {
    transform: translateY(-2px) rotate(-9deg);
  }

  42% {
    transform: translateY(-3px) rotate(-11deg);
  }

  58% {
    transform: translateY(-2px) rotate(5deg);
  }

  74% {
    transform: translateY(-1px) rotate(-4deg);
  }

  100% {
    transform: translateY(0) rotate(0deg);
  }
}

.page-top:not(:hover):not(:focus-visible):not(:active) .page-top__beer {
  animation: none;
}

.page-top:hover .page-top__beer,
.page-top:focus-visible .page-top__beer,
.page-top:active .page-top__beer,
.page-top__beer.is-cheers {
  animation: page-top-beer-cheers 0.62s ease-in-out;
}

.page-top__body {
  display: flex;
  align-items: center;
  justify-content: center;
  min-block-size: 0;
  padding-block: 2px;
  background: var(--page-top-yellow);
}

.page-top__text {
  color: var(--page-top-brown);
  font-family: 'LINE Seed JP', system-ui, sans-serif;
  font-size: var(--page-top-text-size);
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.04em;
  text-align: center;
}

@media (min-width: 761px) and (max-width: 1024px) {
  .page-top {
    --page-top-size: 76px;
    --page-top-inset-end: var(--page-top-inset-end-tablet, 24px);
    inset-block-end: calc(
      var(--mv-bottom-bar-height, 52px) + var(--page-top-gap-above-bar) + env(safe-area-inset-bottom, 0px)
    );
  }
}

@media (min-width: 1025px) {
  /* 横並び時：右端位置は --mv-pc-page-top-inset-end のみ（右上は --mv-pc-topbar-inset-end） */
  html:not(:has(.mv__top-bar--side-vertical)) .page-top {
    --page-top-size: var(--mv-pc-ig-icon-size);
    --page-top-inset-end: var(--mv-pc-page-top-inset-end);
    --page-top-inset-bottom: 32px;
  }

  /* 縦 CTA（mv__top-bar--side-vertical）利用時のみ、列のセンター軸に中央揃え */
  :has(.mv__top-bar--side-vertical) .page-top {
    --page-top-size: clamp(48px, 5vw, 56px);
    --page-top-inset-end: calc(
      var(--mv-side-vertical-inset-end)
      + (var(--mv-side-column-width) - var(--page-top-size)) / 2
    );
  }
}

@media (max-width: 760px) {
  .page-top {
    --page-top-inset-end: var(--page-top-inset-end-sp, 16px);
    inset-block-end: calc(
      var(--mv-bottom-bar-height, 52px) + var(--page-top-gap-above-bar) + env(safe-area-inset-bottom, 0px)
    );
  }
}

@media (prefers-reduced-motion: reduce) {
  .mv__reserve-btn,
  .mv__instagram-icon {
    transition: none;
  }

  .brewery__grid.brewery__grid--reveal > li {
    opacity: 1;
    transform: none;
    animation: none;
  }

  .page-top {
    transition: none;
  }

  .page-top__beer,
  .page-top__beer.is-cheers {
    animation: none !important;
  }

  .sp-menu {
    transition: none;
  }
}


