/*
 * ======================================
 * site.css — 出汁ダシ サイト固有CSS
 * 追加クラス一覧（共通SCSS取り込み検討用）
 * ======================================
 *
 * .dashi-header / .dashi-topbar / .dashi-logo / .dashi-nav   - 暖色ベージュのstickyヘッダー（上部ユーティリティバー付き）
 * .dashi-eyebrow / .dashi-title / .dashi-lead / .dashi-textlink - 英小ラベル＋明朝大見出しの共通見出しパターン
 * .dashi-sec / .dashi-wrap                                    - clamp余白セクション＋幅可変ラッパー（参考デザインの余白に追従）
 * .dashi-mv                                                   - メインビュー（静止画＋グラデ＋コピー、CMSスライダー差し替え対応）
 * .dashi-news / .dashi-linkcard                               - TOPお知らせ・各ページ案内カード
 * .dashi-hero / .dashi-breadcrumb                             - 下層ページの暖色ヒーロー＋パンくず
 * .dashi-cols / .dashi-figure / .dashi-ar-*                   - 2カラム＋画像フレーム＋アスペクト比
 * .dashi-reason / .dashi-product / .dashi-ec                  - About理由カード／商品ラインナップ／EC帯
 * .dashi-menulist / .dashi-chip / .dashi-infodl / .dashi-notebox - 店舗メニュー・トッピング・店舗情報
 * .dashi-facts / .dashi-flow / .dashi-notes / .dashi-cal / .dashi-form - 体験講座の詳細・流れ・注意・カレンダー・予約フォーム
 * .dashi-langbar / .dashi-twcard / .dashi-twmenu              - 繁体字LP用
 * .dashi-blog / .dashi-filter / .dashi-entrylist / .dashi-pager / .dashi-sidebox / .dashi-article - ブログ一覧・詳細・サイドバー
 * .dashi-cta / .dashi-footer                                  - 予約CTA帯／暗色フッター
 * .dashi-fade                                                 - スクロールフェードイン
 *
 * ======================================
 * 共通SCSSに不足していたもの（5分類）
 * ======================================
 * 装飾パターン不足 : メインビューの静止画＋コピー重ね、開催カレンダー（丸印の空き状況）
 * 構造不足         : 上部ユーティリティバー付きstickyヘッダー、英小ラベル＋明朝大見出しの2段見出し、暗色3カラムフッター
 * 値の粒度不足     : 参考デザインがclamp()ベースの可変余白・可変文字サイズのため site 側で clamp 指定
 */

:root {
  --copper: #A56A38;
  --gold: #C99A63;
  --ink: #26241F;
  --beige: #FAF8F4;
  --line: #E6E2DA;
}

/* ============ 共通見出し・セクション ============ */
.dashi-sec { padding: clamp(56px, 9vw, 112px) 0; }
.dashi-sec--sm { padding: clamp(48px, 7vw, 88px) 0; }
.dashi-sec--beige { background: var(--beige); border-top: 1px solid #EEEEEE; border-bottom: 1px solid #EEEEEE; }
.dashi-sec--beige-top { background: var(--beige); border-top: 1px solid #EEEEEE; }
.dashi-sec--dark { background: var(--ink); color: #E8E4DB; }

.dashi-wrap { max-width: 1180px; margin: 0 auto; padding: 0 clamp(20px, 4vw, 40px); }
.dashi-wrap--mid { max-width: 1080px; }
.dashi-wrap--text { max-width: 900px; }
.dashi-wrap--form { max-width: 760px; }

.dashi-eyebrow { margin: 0 0 14px; font-size: 11px; letter-spacing: 0.34em; color: var(--copper); font-weight: 500; }
.dashi-eyebrow--gold { color: var(--gold); }
.dashi-eyebrow--lg { font-size: 12px; letter-spacing: 0.4em; }

.dashi-title { margin: 0; font-family: "Noto Serif JP", serif; font-weight: 500; font-size: clamp(22px, 3vw, 32px); line-height: 1.6; letter-spacing: 0.04em; color: var(--ink); }
.dashi-title--lg { font-size: clamp(30px, 5vw, 52px); line-height: 1.4; letter-spacing: 0.08em; }
.dashi-title--multiline { font-size: clamp(26px, 4.4vw, 48px); line-height: 1.4; letter-spacing: 0.06em; }
.dashi-title--sm { font-size: clamp(20px, 2.6vw, 28px); }
.dashi-title--white { color: #fff; }

.dashi-lead { margin: 0; font-size: clamp(14px, 1.6vw, 15.5px); line-height: 2.3; color: #4A463D; font-weight: 300; }
.dashi-lead--center { max-width: 50em; margin: 0 auto; }
.dashi-lead--dark { color: #B5B0A6; }
.dashi-strong { font-weight: 500; color: var(--ink); }
.dashi-note { margin: 0; font-size: 12px; line-height: 1.9; color: #ADA89D; }
.dashi-role { margin: 0; font-size: 13px; letter-spacing: 0.06em; color: #9A958C; }

.dashi-textlink { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; letter-spacing: 0.1em; color: var(--ink); border-bottom: 1px solid var(--ink); padding-bottom: 6px; }
.dashi-textlink span { color: var(--copper); }

.dashi-sechead { margin-bottom: clamp(36px, 5vw, 56px); }
.dashi-sechead--sm { margin-bottom: clamp(28px, 4vw, 40px); }
.dashi-sechead--center { text-align: center; }

/* ============ 画像フレーム・比率 ============ */
.dashi-figure { border-radius: 4px; overflow: hidden; }
.dashi-figure img { width: 100%; height: 100%; object-fit: cover; display: block; }
.dashi-ar-4-5 { aspect-ratio: 4 / 5; }
.dashi-ar-3-4 { aspect-ratio: 3 / 4; }
.dashi-ar-4-3 { aspect-ratio: 4 / 3; }
.dashi-ar-16-10 { aspect-ratio: 16 / 10; }
.dashi-ar-16-9 { aspect-ratio: 16 / 9; }
.dashi-ar-16-7 { aspect-ratio: 16 / 7; }

/* ============ 2カラム ============ */
.dashi-cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: clamp(32px, 5vw, 72px); align-items: center; }
.dashi-cols--start { align-items: start; }
.dashi-cols--280 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }

/* ============ ヘッダー ============ */
.dashi-header { position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,0.94); backdrop-filter: blur(8px); border-bottom: 1px solid #DDDDDD; }

/* ナビ右横のアクション（旧 topbar 内容） */
.dashi-header__actions { display: flex; align-items: center; gap: clamp(12px, 1.6vw, 20px); }
.dashi-header__tel { display: inline-flex; align-items: center; gap: 6px; color: var(--ink); font-size: 14px; letter-spacing: 0.04em; white-space: nowrap; }
.dashi-header__tel:hover { opacity: 0.7; }
.dashi-header__tel-icon { width: 15px; height: 15px; display: inline-flex; color: var(--copper); }
.dashi-header__tel-icon svg { width: 100%; height: 100%; }
.dashi-header__sns { display: flex; align-items: center; gap: 8px; }
.dashi-iconbtn { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 50%; border: 1px solid #D8D5CE; color: #8A857B; font-size: 16px; transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease; }
.dashi-iconbtn:hover { background: var(--ink); border-color: var(--ink); color: #fff; }

.header__inner--spread.dashi-header__main { max-width: 100%; width: 100%; height: auto; padding: 14px 20px; gap: clamp(16px, 2vw, 28px); justify-content: flex-end; }
.dashi-header__main .dashi-nav { margin-left: auto; margin-right: 0; } /* ナビ・電話・SNSを右寄せでまとめる */
.dashi-logo { position: fixed; top: 0; left: 0; z-index: 200; display: flex; align-items: center; justify-content: center; width: clamp(120px, 11vw, 165px); height: clamp(120px, 11vw, 165px); padding: 16px; background: #fff; box-shadow: 2px 2px 14px rgba(0,0,0,0.08); }
.dashi-logo img { width: 100%; height: auto; max-width: 100%; object-fit: contain; }
.dashi-logo__sub { display: none; }

.dashi-nav { margin-right: 0; gap: clamp(14px, 1.8vw, 30px); }
.dashi-nav__item a { flex-direction: column; align-items: center; gap: 3px; padding: 4px 0 6px; }
.dashi-nav__ja { font-size: 14px; letter-spacing: 0.06em; font-weight: 500; color: #3A382F; white-space: nowrap; }
.dashi-nav__en { font-size: 9px; letter-spacing: 0.22em; color: #B7B1A6; }
.dashi-nav__item--current a::after { width: 100%; left: 0; background: var(--copper); }
.dashi-nav__item--current .dashi-nav__ja { color: var(--ink); }

/* SPナビ調整（共通sp-navを暖色gradientのまま流用、不要なFAアイコンは消す） */
.sp-nav .sp-nav__link::after { content: none; }
.dashi-spnav__tel { display: block; color: #fff; font-size: 1.6rem; font-weight: 600; }
.dashi-spnav__links { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-top: 16px; }
/* ヘッダー/フッターと同じ丸アイコンボタン（.dashi-iconbtn）を流用。暖色背景用に配色だけ上書き */
.dashi-spnav__links .dashi-iconbtn { border-color: rgba(255,255,255,0.6); color: #fff; }
.dashi-spnav__links .dashi-iconbtn:hover { background: #fff; border-color: #fff; color: var(--copper); }

/* ============ メインビュー ============ */
.dashi-mv { position: relative; height: clamp(440px, 76vh, 660px); overflow: hidden; background: #E2E0DA; }
.dashi-mv__stage { position: absolute; inset: 0; height: 100%; }
.dashi-mv__slide { position: absolute; inset: 0; }
.dashi-mv__inner { position: absolute; inset: 0; }
.dashi-mv__inner img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.dashi-mv__shade { position: absolute; inset: 0; background: linear-gradient(to top, rgba(18,15,11,0.64) 0%, rgba(18,15,11,0.28) 42%, rgba(18,15,11,0.06) 68%); }
/* CMSスライダー差し替え時もオーバーレイがかかるよう、MVコンテナ自体に重ねる（静止画の .dashi-mv__shade と同じグラデ） */
.dashi-mv::after { content: ""; position: absolute; inset: 0; z-index: 2; pointer-events: none; background: linear-gradient(to top, rgba(18,15,11,0.64) 0%, rgba(18,15,11,0.28) 42%, rgba(18,15,11,0.06) 68%); }
.dashi-mv__copy { position: absolute; left: 0; bottom: 0; z-index: 3; padding: clamp(28px, 6vw, 72px) clamp(20px, 6vw, 80px); }
.dashi-mv__eyebrow { margin: 0 0 14px; font-size: clamp(10px, 1.4vw, 12px); letter-spacing: 0.4em; color: rgba(255,255,255,0.85); }
.dashi-mv__title { margin: 0; font-family: "Noto Serif JP", serif; font-weight: 500; color: #fff; font-size: clamp(28px, 5.2vw, 58px); line-height: 1.45; letter-spacing: 0.04em; text-shadow: 0 2px 24px rgba(0,0,0,0.3); }
.dashi-mv__lead { margin: 18px 0 0; font-size: clamp(12px, 1.6vw, 15px); line-height: 1.9; color: rgba(255,255,255,0.92); max-width: 30em; }
.dashi-mv__controls { position: absolute; right: clamp(20px, 6vw, 80px); bottom: clamp(28px, 6vw, 72px); z-index: 3; display: flex; align-items: center; gap: 16px; }
.dashi-mv__arrow { width: 42px; height: 42px; border: 1px solid rgba(255,255,255,0.6); background: rgba(255,255,255,0.08); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; backdrop-filter: blur(4px); cursor: pointer; }
.dashi-mv__arrow svg { width: 18px; }
.dashi-mv__dots { display: flex; gap: 8px; align-items: center; }
.dashi-mv__dot { height: 10px; width: 10px; border-radius: 999px; border: none; background: rgba(255,255,255,0.45); padding: 0; cursor: pointer; transition: width 0.4s ease, background 0.4s ease; }
.dashi-mv__dot.is-active { width: 28px; background: #fff; }

/* ============ TOP お知らせ ============ */
.dashi-news__head { display: flex; flex-wrap: wrap; align-items: baseline; justify-content: space-between; gap: 16px; margin-bottom: 32px; }
.dashi-news__more { font-size: 13px; letter-spacing: 0.08em; color: #6E6A62; border-bottom: 1px solid #C9C5BC; padding-bottom: 5px; }
.dashi-news__list { list-style: none; margin: 0; padding: 0; }
.dashi-news__item { border-top: 1px solid var(--line); }
.dashi-news__item:last-child { border-bottom: 1px solid var(--line); }
.dashi-news__link { display: grid; grid-template-columns: 88px 1fr; gap: clamp(16px, 3vw, 28px); align-items: center; padding: 18px 4px; color: var(--ink); }
.dashi-news__thumb { width: 88px; height: 64px; border-radius: 3px; object-fit: cover; }
.dashi-news__body { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.dashi-news__meta { display: flex; align-items: center; gap: 14px; }
.dashi-news__date { font-size: 12px; letter-spacing: 0.08em; color: #9A958C; }
.dashi-news__cat { font-size: 10.5px; letter-spacing: 0.12em; color: var(--copper); border: 1px solid #E0CDB6; border-radius: 2px; padding: 3px 9px; white-space: nowrap; }
.dashi-news__title { font-size: clamp(14px, 1.6vw, 15.5px); line-height: 1.6; font-weight: 500; }
.dashi-news__link:hover { opacity: 1; }
.dashi-news__link:hover .dashi-news__title { color: var(--copper); }

/* ============ TOP 各ページ案内カード ============ */
.dashi-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: clamp(16px, 2vw, 28px); }
.dashi-linkcard { display: block; color: var(--ink); }
.dashi-linkcard__media { position: relative; aspect-ratio: 4 / 3; border-radius: 4px; overflow: hidden; }
.dashi-linkcard__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
.dashi-linkcard:hover { opacity: 1; }
.dashi-linkcard:hover .dashi-linkcard__media img { transform: scale(1.05); }
.dashi-linkcard__shade { position: absolute; inset: 0; background: linear-gradient(to top, rgba(20,18,14,0.44), rgba(20,18,14,0) 55%); }
.dashi-linkcard__en { position: absolute; left: 16px; bottom: 14px; font-size: 10px; letter-spacing: 0.24em; color: rgba(255,255,255,0.92); }
.dashi-linkcard__head { display: flex; align-items: center; justify-content: space-between; padding: 16px 4px 0; }
.dashi-linkcard__title { font-size: 16px; font-weight: 500; letter-spacing: 0.04em; }
.dashi-linkcard__arrow { color: var(--copper); font-size: 15px; }
.dashi-linkcard__desc { margin: 6px 4px 0; font-size: 12.5px; line-height: 1.8; color: #8A857B; font-weight: 300; }

/* ============ 下層ヒーロー・パンくず ============ */
.dashi-hero { background: var(--beige); border-bottom: 1px solid #EEEEEE; }
.dashi-hero__inner { max-width: 1080px; margin: 0 auto; padding: clamp(40px, 6vw, 72px) clamp(20px, 5vw, 40px); }
.dashi-hero__title { margin: 0; font-family: "Noto Serif JP", serif; font-weight: 500; font-size: clamp(30px, 5vw, 52px); letter-spacing: 0.08em; color: var(--ink); }
.dashi-breadcrumb { margin-bottom: clamp(28px, 5vw, 48px); font-size: 11.5px; letter-spacing: 0.06em; color: #9A958C; }
.dashi-breadcrumb a { color: #9A958C; }
.dashi-breadcrumb__sep { margin: 0 8px; color: #C9C5BC; }

/* ============ About 理由（ダーク）・ストーリー ============ */
.dashi-reason-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: clamp(24px, 3vw, 48px); }
.dashi-reason { border-top: 2px solid var(--gold); padding-top: 28px; }
.dashi-reason__head { display: flex; align-items: baseline; gap: 16px; margin-bottom: 20px; }
.dashi-reason__num { font-family: "Noto Serif JP", serif; font-size: 40px; color: var(--gold); line-height: 1; }
.dashi-reason__title { margin: 0; font-size: clamp(17px, 2vw, 20px); font-weight: 500; color: #fff; line-height: 1.5; }
.dashi-reason__text { margin: 0; font-size: 14px; line-height: 2.2; color: #B5B0A6; font-weight: 300; }

/* ============ 商品ラインナップ・EC帯 ============ */
.dashi-product { border: 1px solid var(--line); border-radius: 4px; overflow: hidden; background: #fff; }
.dashi-product__media { position: relative; aspect-ratio: 16 / 10; overflow: hidden; }
.dashi-product__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.dashi-product__tag { position: absolute; top: 16px; left: 16px; font-size: 10.5px; letter-spacing: 0.16em; color: #6B4B2A; background: rgba(255,255,255,0.9); border-radius: 2px; padding: 5px 11px; font-weight: 500; }
.dashi-product__body { padding: clamp(24px, 3vw, 36px); }
.dashi-product__type { margin: 0 0 6px; font-size: 11px; letter-spacing: 0.24em; color: var(--copper); }
.dashi-product__title { margin: 0 0 18px; font-family: "Noto Serif JP", serif; font-weight: 500; font-size: clamp(21px, 2.6vw, 26px); letter-spacing: 0.04em; }
.dashi-product__text { margin: 0 0 24px; font-size: 14px; line-height: 2.1; color: #4A463D; font-weight: 300; }
.dashi-product__rec { margin: 0 0 12px; font-size: 12px; letter-spacing: 0.12em; color: #9A958C; }
.dashi-taglist { display: flex; flex-wrap: wrap; gap: 8px; }
.dashi-tag { font-size: 12.5px; color: #4A463D; background: #F2EFE9; border-radius: 2px; padding: 7px 13px; }

.dashi-ec { background: var(--ink); }
.dashi-ec__inner { max-width: 1080px; margin: 0 auto; padding: clamp(48px, 7vw, 80px) clamp(20px, 5vw, 40px); display: flex; flex-wrap: wrap; align-items: center; gap: clamp(28px, 5vw, 56px); }
.dashi-ec__img { flex: 1 1 300px; min-width: 0; max-width: 440px; width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 4px; display: block; }
.dashi-ec__body { flex: 1 1 320px; }
.dashi-btn-gold { display: inline-flex; align-items: center; gap: 10px; color: var(--ink); background: var(--gold); text-decoration: none; padding: 16px 30px; border-radius: 2px; font-weight: 500; font-size: 14px; letter-spacing: 0.08em; }
.dashi-btn-gold:hover { opacity: 0.9; }

/* ============ 店舗メニュー ============ */
.dashi-badge { display: inline-block; font-size: 10.5px; letter-spacing: 0.18em; color: var(--copper); border: 1px solid #E0CDB6; border-radius: 2px; padding: 4px 11px; }
.dashi-price { font-family: "Noto Serif JP", serif; font-size: 24px; color: var(--ink); }
.dashi-price--sm { font-size: 18px; white-space: nowrap; }
.dashi-menu-en { font-size: 11px; letter-spacing: 0.14em; color: #ADA89D; }

.dashi-menuhead { display: flex; align-items: baseline; gap: 14px; margin: 0 0 4px; font-size: clamp(17px, 2vw, 20px); font-weight: 500; letter-spacing: 0.04em; }
.dashi-menuhead__en { font-size: 10.5px; letter-spacing: 0.18em; color: var(--copper); }
.dashi-menulist { list-style: none; margin: 18px 0 0; padding: 0; border-top: 1px solid var(--line); }
.dashi-menulist__item { display: flex; align-items: center; gap: clamp(16px, 3vw, 22px); padding: 18px 4px; border-bottom: 1px solid var(--line); }
.dashi-menulist__img { width: clamp(150px, 34vw, 260px); aspect-ratio: 4 / 3; object-fit: cover; border-radius: 4px; flex-shrink: 0; }
.dashi-menulist__body { flex: 1; min-width: 0; }
.dashi-menulist__name { margin: 0 0 4px; font-size: clamp(15px, 1.8vw, 17px); font-weight: 500; letter-spacing: 0.02em; }
.dashi-menulist__en { margin: 0 0 7px; font-size: 10.5px; letter-spacing: 0.12em; color: #BBB6AC; }
.dashi-menulist__desc { margin: 0; font-size: 13px; line-height: 1.85; color: #8A857B; font-weight: 300; }
.dashi-menulist__note { margin: 8px 0 0; font-size: 12px; line-height: 1.7; color: var(--copper); }

.dashi-toppings { background: var(--beige); border: 1px solid var(--line); border-radius: 4px; padding: clamp(22px, 3vw, 32px); }
.dashi-chiplist { display: flex; flex-wrap: wrap; gap: 10px; }
.dashi-chip { display: inline-flex; align-items: baseline; gap: 8px; font-size: 13px; color: #4A463D; background: #fff; border: 1px solid var(--line); border-radius: 999px; padding: 8px 16px; }
.dashi-chip__price { color: var(--copper); font-weight: 500; }

/* ============ 店舗情報 dl・地図 ============ */
.dashi-infodl { margin: 0; font-size: 14.5px; }
.dashi-infodl__row { display: flex; gap: 18px; padding: 16px 0; border-bottom: 1px solid var(--line); }
.dashi-infodl__row:last-child { border-bottom: none; }
.dashi-infodl__row dt { width: 92px; flex-shrink: 0; color: #9A958C; font-size: 13px; letter-spacing: 0.04em; }
.dashi-infodl__row dd { margin: 0; }
.dashi-infodl__row dd a { color: var(--ink); font-weight: 500; }
.dashi-notebox { display: flex; gap: 12px; margin-top: 24px; padding: 16px 18px; background: #fff; border: 1px solid var(--line); border-radius: 4px; }
.dashi-notebox__icon { color: var(--copper); flex-shrink: 0; }
.dashi-notebox__icon svg { width: 20px; }
.dashi-notebox__text { margin: 0; font-size: 13px; line-height: 1.9; color: #6E6A62; }
.dashi-mapframe { border-radius: 4px; overflow: hidden; border: 1px solid #DDDDDD; line-height: 0; }
.dashi-mapframe iframe { display: block; border: 0; }
.dashi-maplink { display: inline-flex; align-items: center; gap: 6px; margin-top: 14px; font-size: 13px; color: var(--copper); letter-spacing: 0.04em; }

/* ============ 体験講座 ============ */
.dashi-facts { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 1px; background: #E0DCD3; border: 1px solid #E0DCD3; border-radius: 4px; overflow: hidden; }
.dashi-fact { background: #fff; padding: 24px 20px; }
.dashi-fact__label { margin: 0 0 10px; font-size: 11px; letter-spacing: 0.14em; color: #9A958C; }
.dashi-fact__value { margin: 0; font-size: clamp(16px, 2vw, 19px); font-weight: 500; line-height: 1.4; }
.dashi-fact__sub { margin: 6px 0 0; font-size: 12px; color: #8A857B; font-weight: 300; }

.dashi-flowbox { background: #fff; border: 1px solid var(--line); border-radius: 4px; padding: clamp(24px, 4vw, 40px); }
.dashi-flowbox__img { width: 100%; aspect-ratio: 16 / 7; object-fit: cover; border-radius: 3px; margin-bottom: 24px; display: block; }
.dashi-flowbox__title { margin: 0 0 8px; font-size: 16px; font-weight: 500; letter-spacing: 0.04em; }
.dashi-flowbox__sub { margin: 0 0 22px; font-size: 13px; color: #8A857B; font-weight: 300; }
.dashi-flow { list-style: none; margin: 0; padding: 0; }
.dashi-flow__item { display: flex; gap: 16px; padding: 14px 0; border-top: 1px solid #F0EEE8; }
.dashi-flow__num { flex-shrink: 0; width: 26px; height: 26px; border-radius: 50%; background: var(--ink); color: #fff; font-size: 12px; display: flex; align-items: center; justify-content: center; }
.dashi-flow__text { margin: 0; font-size: 14px; line-height: 1.8; color: #4A463D; }

.dashi-notes { background: #fff; border: 1px solid #E0CDB6; border-radius: 4px; padding: clamp(24px, 4vw, 40px); }
.dashi-notes__head { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.dashi-notes__head-icon { color: var(--copper); }
.dashi-notes__head-icon svg { width: 20px; }
.dashi-notes__title { margin: 0; font-size: 16px; font-weight: 500; letter-spacing: 0.04em; }
.dashi-notes__list { list-style: none; margin: 0; padding: 0; }
.dashi-notes__item { display: flex; gap: 12px; padding: 9px 0; font-size: 13.5px; line-height: 1.9; color: #4A463D; }
.dashi-notes__bullet { color: var(--copper); flex-shrink: 0; line-height: 1.9; }

/* 開催カレンダー */
.dashi-calbar { display: flex; flex-wrap: wrap; align-items: baseline; justify-content: space-between; gap: 16px; margin-bottom: clamp(28px, 4vw, 40px); }
.dashi-calmonth { font-family: "Noto Serif JP", serif; font-size: clamp(18px, 2.4vw, 24px); color: var(--ink); }
.dashi-callegend { display: flex; flex-wrap: wrap; gap: 18px; margin-bottom: 20px; font-size: 12.5px; color: #6E6A62; }
.dashi-callegend__item { display: inline-flex; align-items: center; gap: 6px; }
.dashi-mark { font-size: 15px; color: var(--copper); }
.dashi-mark--few { color: #B5763A; }
.dashi-mark--full { color: #C2BEB4; }
.dashi-cal { border: 1px solid #E0DCD3; border-radius: 4px; overflow: hidden; }
.dashi-cal__head { display: grid; grid-template-columns: repeat(7, 1fr); background: var(--beige); border-bottom: 1px solid #E0DCD3; }
.dashi-cal__dow { padding: 12px 0; text-align: center; font-size: 12px; letter-spacing: 0.1em; color: #8A857B; }
.dashi-cal__grid { display: grid; grid-template-columns: repeat(7, 1fr); }
.dashi-cal__cell { aspect-ratio: 1 / 1; min-height: 64px; border-right: 1px solid #EEEAE2; border-bottom: 1px solid #EEEAE2; background: #FCFBF9; display: flex; align-items: flex-start; padding: 8px 10px; }
.dashi-cal__cell--open { background: #fff; flex-direction: column; align-items: center; justify-content: center; gap: 3px; padding: 4px; border: none; border-right: 1px solid #EEEAE2; border-bottom: 1px solid #EEEAE2; cursor: pointer; }
.dashi-cal__cell--open.is-selected { background: #F6EEE3; box-shadow: inset 0 0 0 2px var(--copper); }
.dashi-cal__date { font-size: 13px; color: #C9C5BC; }
.dashi-cal__cell--open .dashi-cal__date { color: #4A463D; }
.dashi-cal__mark { font-size: 17px; line-height: 1; }

/* フォーム */
.dashi-form { background: #fff; border: 1px solid var(--line); border-radius: 4px; padding: clamp(24px, 4vw, 44px); display: flex; flex-direction: column; gap: 22px; }
.dashi-form--plain { background: none; border: none; padding: 0; }
.dashi-form__label { display: flex; flex-direction: column; gap: 8px; }
.dashi-form__labeltext { font-size: 13px; font-weight: 500; }
.dashi-form__req { color: var(--copper); font-size: 11px; }
.dashi-form__row { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 22px; }
.dashi-form input, .dashi-form select, .dashi-form textarea { font-family: inherit; font-size: 15px; padding: 13px 14px; border: 1px solid #D8D4CB; border-radius: 3px; background: #FCFBF9; color: var(--ink); }
.dashi-form input:focus, .dashi-form select:focus, .dashi-form textarea:focus { outline: none; border-color: var(--copper); }
.dashi-form textarea { resize: vertical; line-height: 1.7; }
.dashi-form__submit { align-self: flex-start; margin-top: 6px; font-family: inherit; font-size: 15px; letter-spacing: 0.08em; color: #fff; background: var(--ink); border: none; border-radius: 3px; padding: 16px 40px; cursor: pointer; font-weight: 500; }
.dashi-form__submit--center { align-self: center; padding: 16px 44px; }
.dashi-form__submit:hover { opacity: 0.88; }
.dashi-form__done { background: #fff; border: 1px solid #E0CDB6; border-radius: 4px; padding: 40px; text-align: center; }
.dashi-form__done-title { margin: 0 0 10px; font-size: 18px; font-weight: 500; color: var(--copper); }
.dashi-form__done-text { margin: 0; font-size: 14px; line-height: 1.9; color: #6E6A62; }
.dashi-form__demo-note { margin: 18px 0 0; text-align: center; font-size: 14px; color: var(--copper); }

/* CMSフォーム：必須バッジの色をサイトの銅色に上書き */
.form-pattern-1 dl dt:not(.pattern-exclusion) span.required::before {
    background: #A56A38!important;
}

/* CMSフォーム：任意バッジ */
.form-pattern-1 dl dt:not(.pattern-exclusion) span.optional::before {
    content: '任意'!important;
    color: #fff!important;
    background: #acacac!important;
}

/* ============ 繁体字LP ============ */
.dashi-langbar { background: var(--ink); color: #D8D4CC; font-size: 12.5px; letter-spacing: 0.04em; }
.dashi-langbar__inner { max-width: 1080px; margin: 0 auto; padding: 10px clamp(20px, 5vw, 40px); display: flex; flex-wrap: wrap; gap: 12px; align-items: center; justify-content: space-between; }
.dashi-langbar__label { color: var(--gold); white-space: nowrap; }
.dashi-langbar__link { color: #D8D4CC; border-bottom: 1px solid #4A463D; padding-bottom: 2px; }
.dashi-placeholder { margin: 0; font-size: 12px; line-height: 1.8; color: #ADA89D; border-left: 2px solid #E0CDB6; padding-left: 12px; }
.dashi-twcard { background: #fff; border: 1px solid var(--line); border-radius: 4px; padding: 28px; }
.dashi-twcard__title { margin: 0 0 12px; font-size: 18px; font-weight: 500; }
.dashi-twcard__text { margin: 0; font-size: 13.5px; line-height: 2; color: #6E6A62; font-weight: 300; }
.dashi-twmenu__name { margin: 14px 0 4px; font-size: 16px; font-weight: 500; }
.dashi-twmenu__desc { margin: 0; font-size: 13px; color: #8A857B; font-weight: 300; }
.dashi-tw-sub { font-size: 0.6em; color: #6E6A62; }
.dashi-tw-mail { font-size: 13px; color: #6E6A62; }
.dashi-mail-link { color: var(--copper); border-bottom: 1px solid #E0CDB6; }

/* tw カレンダー：全セル中央寄せ・白背景 */
.dashi-cal--center .dashi-cal__cell { background: #fff; flex-direction: column; align-items: center; justify-content: center; gap: 3px; padding: 4px; min-height: 56px; }
.dashi-cal__date--on { color: #4A463D; }
.dashi-cal--center .dashi-cal__mark { font-size: 16px; }

/* カレンダーCMS（#roscal / table構造）を .dashi-cal と同じデザインに合わせる */
#cms-calendar-1-area .calendar { border: 1px solid #E0DCD3; border-radius: 4px; overflow: hidden; }
#cms-calendar-1-area .calendar_head { padding: 14px 0; text-align: center; font-family: "Noto Serif JP", serif; font-size: clamp(18px, 2.4vw, 24px); letter-spacing: 0.04em; color: var(--ink); background: var(--beige); border-bottom: 1px solid #E0DCD3; }
#cms-calendar-1-area .calendar_body table { width: 100%; border-collapse: collapse; table-layout: fixed; }
#cms-calendar-1-area th.calendar { padding: 12px 0; text-align: center; font-size: 12px; font-weight: 400; letter-spacing: 0.1em; color: #8A857B; background: var(--beige); border-bottom: 1px solid #E0DCD3; }
#cms-calendar-1-area td.calendar { height: 64px; vertical-align: top; text-align: center; border-right: 1px solid #EEEAE2; border-bottom: 1px solid #EEEAE2; background: #FCFBF9; font-size: 13px; color: #4A463D; }
#cms-calendar-1-area tr td.calendar:last-child { border-right: none; }
#cms-calendar-1-area td.calendar.kara { background: #F4F1EB; }
#cms-calendar-1-area td.calendar.today { background: #F6EEE3; box-shadow: inset 0 0 0 2px var(--copper); }
#cms-calendar-1-area td.calendar .days { padding: 8px 6px; cursor: pointer; }
#cms-calendar-1-area th.calendar.sun, #cms-calendar-1-area td.calendar.sun .days { color: #B5763A; }
#cms-calendar-1-area th.calendar.sat, #cms-calendar-1-area td.calendar.sat .days { color: #7E97A6; }

/* ============ ブログ ============ */
.dashi-blog { display: flex; flex-wrap: wrap; gap: clamp(36px, 5vw, 64px); }
.dashi-blog__main { flex: 3 1 460px; min-width: 0; }
.dashi-blog__side { flex: 1 1 260px; min-width: 0; }
.dashi-filter { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 32px; }
.dashi-filter__btn { font-family: inherit; font-size: 12.5px; letter-spacing: 0.04em; padding: 8px 16px; border-radius: 999px; cursor: pointer; border: 1px solid #DDD8CF; background: #fff; color: #6E6A62; }
.dashi-filter__btn.is-active { background: var(--ink); color: #fff; border-color: var(--ink); }
.dashi-entrylist { list-style: none; margin: 0; padding: 0; }
.dashi-entrylist__item { border-top: 1px solid var(--line); }
.dashi-entrylist__link { display: grid; grid-template-columns: 120px 1fr; gap: clamp(16px, 3vw, 28px); align-items: center; padding: 22px 4px; color: var(--ink); }
.dashi-entrylist__thumb { width: 120px; height: 84px; border-radius: 3px; object-fit: cover; }
.dashi-entrylist__noimg { width: 120px; height: 84px; border-radius: 3px; background: linear-gradient(135deg, #E7E4DD, #D6D2C9); display: flex; align-items: center; justify-content: center; color: #ADA89D; }
.dashi-entrylist__noimg svg { width: 24px; }
.dashi-entrylist__title { font-size: clamp(14px, 1.6vw, 16px); line-height: 1.6; font-weight: 500; }
.dashi-entrylist__link:hover { opacity: 1; }
.dashi-entrylist__link:hover .dashi-entrylist__title { color: var(--copper); }

.dashi-pager { display: flex; justify-content: center; align-items: center; gap: 8px; margin-top: 48px; }
.dashi-pager__item { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; border: 1px solid var(--line); border-radius: 3px; color: #6E6A62; font-size: 14px; }
.dashi-pager__item svg { width: 16px; }
.dashi-pager__item--current { border-color: var(--ink); background: var(--ink); color: #fff; }
.dashi-pager__item--disabled { color: #C9C5BC; }

.dashi-sidebox { margin-bottom: 40px; }
.dashi-sidebox__title { margin: 0 0 18px; font-size: 12px; letter-spacing: 0.18em; color: var(--copper); padding-bottom: 12px; border-bottom: 1px solid var(--line); }
.dashi-sidelist { list-style: none; margin: 0; padding: 0; }
.dashi-sidelist__cat { display: flex; justify-content: space-between; align-items: center; padding: 11px 2px; font-size: 13.5px; color: #4A463D; border-bottom: 1px solid #F0EEE8; }
.dashi-sidelist__count { font-size: 12px; color: #ADA89D; }
.dashi-sidelist__recent { display: block; padding: 12px 2px; border-bottom: 1px solid #F0EEE8; }
.dashi-sidelist__recent-date { display: block; font-size: 11px; color: #9A958C; margin-bottom: 4px; }
.dashi-sidelist__recent-title { font-size: 13px; line-height: 1.6; color: #4A463D; }
.dashi-sidelist__arc { display: block; padding: 11px 2px; font-size: 13.5px; color: #4A463D; border-bottom: 1px solid #F0EEE8; }

.dashi-article__meta { display: flex; align-items: center; gap: 14px; margin-bottom: 18px; }
.dashi-article__title { margin: 0 0 32px; font-family: "Noto Serif JP", serif; font-weight: 500; font-size: clamp(24px, 3.6vw, 36px); line-height: 1.55; letter-spacing: 0.03em; }
.dashi-article__hero { aspect-ratio: 16 / 9; border-radius: 4px; overflow: hidden; margin-bottom: 40px; }
.dashi-article__hero img { width: 100%; height: 100%; object-fit: cover; display: block; }
.dashi-article__body { font-size: clamp(14px, 1.6vw, 15.5px); line-height: 2.3; color: #3A382F; font-weight: 300; }
.dashi-article__body p { margin: 0 0 24px; }
.dashi-article__body p:last-child { margin: 0; }
.dashi-article__body h2 { margin: 40px 0 16px; font-family: "Noto Serif JP", serif; font-weight: 500; font-size: 20px; letter-spacing: 0.04em; color: var(--ink); }
.dashi-article__btn { display: inline-flex; align-items: center; gap: 10px; margin-top: 40px; font-size: 14px; letter-spacing: 0.06em; color: #fff; background: var(--ink); padding: 15px 30px; border-radius: 3px; }
.dashi-article__btn span { color: var(--gold); }
.dashi-article__back { margin-top: 48px; padding-top: 28px; border-top: 1px solid var(--line); }
.dashi-backlink { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: #6E6A62; }
.dashi-backlink span { color: var(--copper); }

/* ============ 予約CTA帯 ============ */
.dashi-cta { background: var(--ink); color: #E8E4DB; }
.dashi-cta__inner { max-width: 1080px; margin: 0 auto; padding: clamp(48px, 7vw, 80px) clamp(20px, 5vw, 40px); display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: clamp(28px, 5vw, 48px); }
.dashi-cta__title { margin: 8px 0 14px; font-family: "Noto Serif JP", serif; font-weight: 500; color: #fff; font-size: clamp(22px, 3vw, 30px); letter-spacing: 0.04em; }
.dashi-cta__desc { margin: 0; font-size: 14px; line-height: 1.9; color: #B5B0A6; font-weight: 300; }
.dashi-cta__action { display: flex; flex-direction: column; align-items: flex-start; gap: 10px; }
.dashi-cta__tel { display: inline-flex; align-items: center; gap: 10px; font-size: clamp(24px, 3vw, 32px); font-weight: 500; color: #fff; }
.dashi-cta__tel-icon { color: var(--gold); display: inline-flex; }
.dashi-cta__tel-icon svg { width: 0.7em; }
.dashi-cta__hours { font-size: 12px; color: #9A958C; }
.dashi-cta__btn { display: inline-flex; align-items: center; gap: 10px; margin-top: 4px; background: var(--gold); color: var(--ink); padding: 14px 28px; border-radius: 2px; font-weight: 500; font-size: 14px; letter-spacing: 0.08em; }
.dashi-cta__btn:hover { opacity: 0.9; }

/* ============ フッター（暗色3カラム） ============ */
.dashi-footer { background: var(--ink); color: #D8D4CC; border-top: 3px solid var(--copper); }
.dashi-footer__inner { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: clamp(28px, 5vw, 64px); max-width: 1240px; margin: 0 auto; padding: clamp(40px, 6vw, 72px) clamp(16px, 4vw, 40px) 40px; }
.dashi-footer__logo { display: inline-flex; }
.dashi-footer__logo img { height: 84px; width: 84px; border-radius: 6px; display: block; }
.dashi-footer__lead { margin: 22px 0 0; font-size: 13px; line-height: 2; color: #ABA69B; }
.dashi-footer__sns { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
/* ヘッダーと同じ丸アイコンボタン（.dashi-iconbtn）を流用。暗色フッター用に配色だけ上書き */
.dashi-footer__sns .dashi-iconbtn { border-color: #4A463D; color: #D8D4CC; }
.dashi-footer__sns .dashi-iconbtn:hover { background: var(--gold); border-color: var(--gold); color: var(--ink); }
.dashi-footer__heading { margin: 0 0 18px; font-size: 11px; letter-spacing: 0.26em; color: var(--gold); font-weight: 500; }
.dashi-footer__dl { margin: 0; font-size: 13px; line-height: 1.9; color: #ABA69B; }
.dashi-footer__row { display: flex; gap: 14px; padding: 7px 0; border-bottom: 1px solid #3A372F; }
.dashi-footer__row:last-child { border-bottom: none; }
.dashi-footer__row dt { width: 64px; flex-shrink: 0; color: #7E7A70; }
.dashi-footer__row dd { margin: 0; color: #D8D4CC; }
.dashi-footer__row dd a { color: #D8D4CC; }
.dashi-footer__map-frame { border-radius: 4px; overflow: hidden; border: 1px solid #4A463D; line-height: 0; }
.dashi-footer__map-frame iframe { filter: grayscale(0.25); display: block; border: 0; }
.dashi-footer__map-link { display: inline-flex; align-items: center; gap: 6px; margin-top: 12px; font-size: 12px; color: var(--gold); letter-spacing: 0.04em; }
.dashi-footer__bottom { border-top: 1px solid #3A372F; }
.dashi-footer__bottom-inner { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 12px; max-width: 1240px; margin: 0 auto; padding: 18px clamp(16px, 4vw, 40px); font-size: 11px; color: #7E7A70; letter-spacing: 0.04em; }
.dashi-footer__bottom-nav { display: flex; flex-wrap: wrap; gap: 18px; }
.dashi-footer__bottom-nav a { color: #ABA69B; }

/* ============ フェードイン ============ */
.dashi-fade { opacity: 0; transform: translateY(24px); transition: opacity 0.7s ease, transform 0.7s ease; }
.dashi-fade.is-inview { opacity: 1; transform: none; }

/* ============ レスポンシブ微調整 ============ */
@media (max-width: 1100px) {
  .dashi-header__actions { display: none; } /* SPはハンバーガー内に集約 */
  /* ① ヘッダーのメインバー（白いstickyバー）を非表示。ロゴ(固定)とハンバーガーはheader外なので残る */
  .dashi-header { display: none; }
}

/* ===== スマホ向け調整 ===== */
@media (max-width: 768px) {
  /* ② ロゴマークを約半分のサイズに */
  .dashi-logo { width: clamp(64px, 20vw, 84px); height: clamp(64px, 20vw, 84px); padding: 9px; }

  /* ③ アクセス等のテーブル（dl）を縦積みにして見やすく */
  .dashi-infodl__row { flex-direction: column; gap: 4px; padding: 14px 0; }
  .dashi-infodl__row dt { width: auto; }
  .dashi-footer__row { gap: 4px; }

  /* ④ PCで中央配置の長文を左寄せに（見出し・英小ラベルは中央のまま） */
  .text-center .dashi-lead,
  .dashi-sechead--center .dashi-lead,
  .dashi-lead--center {
    text-align: left;
    max-width: none;
    margin-left: 0;
    margin-right: 0;
  }

  /* ⑤ フッターロゴに背景色をつけて中央揃え */
  .dashi-footer__logo { display: flex; width: fit-content; margin: 0 auto; background: #fff; padding: 12px; border-radius: 8px; }

  /* ⑥ フッターナビを非表示 */
  .dashi-footer__bottom-nav { display: none; }

  /* パンくずリストを非表示 */
  .dashi-breadcrumb { display: none; }

  /* 固定ロゴ（左上）とページヒーローの英語タイトルが被らないよう上部に余白を確保 */
  .dashi-hero__inner { padding-top: calc(clamp(64px, 20vw, 84px) + 32px); }

  /* tw.php の言語バーを非表示 */
  .dashi-langbar { display: none; }

  /* products.php のEC帯：online.jpg が画面からはみ出さないよう縦積み＆幅100% */
  .dashi-ec__inner { flex-direction: column; align-items: stretch; }
  .dashi-ec__img { flex: none; width: 100%; max-width: 100%; }
  .dashi-ec__body { flex: none; min-width: 0; }
}

@media (max-width: 600px) {
  .dashi-logo__sub { display: none; }
  .dashi-menulist__item { flex-wrap: wrap; }
  .dashi-menulist__img { width: 100%; }
  .dashi-news__link { grid-template-columns: 72px 1fr; }
  .dashi-news__thumb { width: 72px; height: 54px; }
  .dashi-entrylist__link { grid-template-columns: 96px 1fr; }
  .dashi-entrylist__thumb, .dashi-entrylist__noimg { width: 96px; height: 68px; }
}
