/* ============================================================
   焼肉ふじ咲 — style_2505121610.css
   全ページ共通CSS（DW2020対応・Bootstrap不使用・独自レスポンシブ）
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --red:        #8B1A1A;
  --red-light:  #B22222;
  --gold:       #C4983A;
  --gold-light: #D4AF5A;
  --dark:       #0D0D0D;
  --dark-mid:   #161616;
  --dark-soft:  #1E1E1E;
  --text:       #E8E0D0;
  --text-muted: #8A8070;
  --bg:         #111111;
  --bg-warm:    #181818;
  --border:     #333333;
  --white:      #FFFDF9;
}

html { scroll-behavior: smooth; }
body { font-family: 'Noto Sans JP', sans-serif; background: var(--bg); color: var(--text); font-size: 16px; line-height: 1.7; }


/* ============================================================
   HEADER
   ============================================================ */
header { background: var(--dark); position: sticky; top: 0; z-index: 100; border-bottom: 2px solid var(--gold); }
.header-inner { max-width: 1100px; margin: 0 auto; padding: 0 1.5rem; display: flex; align-items: center; justify-content: space-between; height: 68px; gap: 1rem; }
.logo-wrap { display: flex; align-items: center; gap: 12px; text-decoration: none; flex-shrink: 0; }
.logo-wrap img { width: 48px; height: 48px; object-fit: contain; }
.logo-text { font-family: 'Noto Serif JP', serif; font-size: 1.1rem; color: var(--gold); letter-spacing: 0.1em; line-height: 1.3; }
.logo-text span { display: block; font-size: 0.6rem; color: var(--gold-light); letter-spacing: 0.2em; font-family: 'Noto Sans JP', sans-serif; font-weight: 400; }
nav ul { display: flex; gap: 0; list-style: none; }
nav ul li a { display: block; padding: 0.5rem 0.6rem; color: #9A8A70; text-decoration: none; font-size: 0.68rem; letter-spacing: 0.02em; border-left: 1px solid var(--border); transition: color 0.2s; white-space: nowrap; }
nav ul li:last-child a { border-right: 1px solid var(--border); }
nav ul li a:hover { color: var(--gold); }
/* 現在ページのナビリンクをゴールドに */
nav ul li a.nav-current { color: var(--gold); }


/* ============================================================
   HAMBURGER / MOBILE NAV
   ============================================================ */
.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 8px; background: none; border: none; }
.hamburger span { display: block; width: 24px; height: 2px; background: var(--gold); transition: all 0.3s; transform-origin: center; }
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.mobile-nav { display: none; background: var(--dark-mid); border-top: 1px solid var(--gold); }
.mobile-nav.open { display: block; }
.mobile-nav ul { list-style: none; padding: 0.5rem 0; }
.mobile-nav ul li a { display: block; padding: 0.9rem 1.5rem; color: #9A8A70; text-decoration: none; font-size: 0.9rem; letter-spacing: 0.04em; border-bottom: 1px solid var(--border); transition: background 0.2s; }
.mobile-nav ul li a:hover { background: rgba(196,152,58,0.1); color: var(--gold); }


/* ============================================================
   NOTICE BAR
   ============================================================ */
.notice-bar { background: var(--red); color: var(--white); text-align: center; padding: 0.85rem 1.5rem; font-size: 0.82rem; letter-spacing: 0.04em; line-height: 1.6; }
.notice-bar strong { color: #FFD97D; }


/* ============================================================
   HERO (index.html)
   ============================================================ */
.hero { position: relative; overflow: hidden; padding: 0; }
.hero-img { width: 100%; display: block; height: auto; }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(13,13,13,0.82) 0%, rgba(13,13,13,0.4) 55%, transparent 70%); display: flex; align-items: flex-start; pointer-events: none; }
.hero-content { padding: 2rem 2.5rem; max-width: 420px; pointer-events: auto; }
.hero-badge { display: inline-block; font-size: 0.68rem; letter-spacing: 0.22em; color: var(--gold); border: 1px solid var(--gold); padding: 0.28rem 0.9rem; margin-bottom: 1.2rem; }
.hero h1 { font-family: 'Noto Serif JP', serif; font-size: clamp(1.6rem, 5vw, 2.8rem); color: var(--gold); letter-spacing: 0.15em; line-height: 1.3; margin-bottom: 0.8rem; text-shadow: 0 2px 12px rgba(0,0,0,0.5); }
.hero p { font-size: 0.85rem; color: #D4C4A8; line-height: 1.8; margin-bottom: 1.5rem; }
.hero-actions { display: flex; gap: 0.8rem; flex-wrap: wrap; }


/* ============================================================
   BUTTONS
   ============================================================ */
.btn { display: inline-block; padding: 0.75rem 1.8rem; font-size: 0.82rem; letter-spacing: 0.08em; text-decoration: none; font-family: 'Noto Sans JP', sans-serif; transition: all 0.2s; border: none; cursor: pointer; }
.btn-primary { background: var(--red); color: var(--white); border: 2px solid var(--red); }
.btn-primary:hover { background: var(--red-light); border-color: var(--red-light); }
.btn-secondary { background: transparent; color: var(--gold); border: 2px solid var(--gold); }
.btn-secondary:hover { background: var(--gold); color: var(--dark); }
.btn-center { text-align: center; margin-top: 2rem; }
.btn-center .btn { display: inline-block; }


/* ============================================================
   SECTIONS (共通)
   ============================================================ */
section { padding: 4rem 1.5rem; }
.section-inner { max-width: 1100px; margin: 0 auto; }
.section-title { font-family: 'Noto Serif JP', serif; font-size: clamp(1.3rem, 4vw, 1.9rem); color: var(--red); letter-spacing: 0.12em; margin-bottom: 0.35rem; }
.section-sub { font-size: 0.72rem; letter-spacing: 0.25em; color: var(--text-muted); margin-bottom: 2.5rem; display: flex; align-items: center; gap: 0.8rem; }
.section-sub::after { content: ''; display: block; height: 1px; width: 40px; background: var(--gold); }
/* contact-sectionのsection-subは中央揃え */
.contact-section .section-sub { justify-content: center; }


/* ============================================================
   INFO BAR (お知らせ)
   ============================================================ */
.info-bar { background: var(--dark-mid); padding: 2rem 1.5rem; border-bottom: 1px solid var(--border); }
.info-bar-inner { max-width: 1100px; margin: 0 auto; display: flex; align-items: flex-start; gap: 1.2rem; }
.info-bar-label { font-family: 'Noto Serif JP', serif; font-size: 0.8rem; color: var(--gold); letter-spacing: 0.12em; white-space: nowrap; padding-top: 0.2rem; border-left: 3px solid var(--gold); padding-left: 0.7rem; }
.info-bar-frame { flex: 1; overflow: hidden; background: var(--dark-mid); }
.info-bar-frame iframe { display: block; width: 100%; border: none; }


/* ============================================================
   MENU TABS
   ============================================================ */
.menu-tabs { display: flex; flex-wrap: wrap; margin-bottom: 2rem; border-bottom: 2px solid var(--border); }
.menu-tab { padding: 0.6rem 1.1rem; font-size: 0.78rem; letter-spacing: 0.05em; color: var(--text-muted); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -2px; transition: color 0.2s, border-color 0.2s; background: none; border-top: none; border-left: none; border-right: none; font-family: 'Noto Sans JP', sans-serif; white-space: nowrap; }
.menu-tab.active { color: var(--gold); border-bottom-color: var(--gold); }
.menu-tab:hover { color: var(--text); }
.menu-panel { display: none; }
.menu-panel.active { display: block; }


/* ============================================================
   MENU GRID (カード形式)
   ============================================================ */
.menu-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.2rem; }
.menu-card { background: var(--dark-soft); border: 1px solid var(--border); overflow: hidden; transition: transform 0.2s, border-color 0.2s; }
.menu-card:hover { transform: translateY(-3px); border-color: var(--gold); }
.menu-card img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.menu-card-body { padding: 1rem 1.1rem; }
.menu-card-body h3 { font-family: 'Noto Serif JP', serif; font-size: 0.95rem; margin-bottom: 0.35rem; color: var(--text); }
.menu-card-body p { font-size: 0.78rem; color: var(--text-muted); line-height: 1.6; }
.menu-card-body small { font-size: 0.8rem; color: var(--gold); }
.menu-tag { display: inline-block; background: var(--red); color: var(--white); font-size: 0.62rem; padding: 0.12rem 0.45rem; letter-spacing: 0.06em; margin-bottom: 0.4rem; }


/* ============================================================
   MENU LIST (テキスト一覧)
   ============================================================ */
.menu-category { margin-bottom: 2rem; }
.menu-category-title { font-family: 'Noto Serif JP', serif; font-size: 0.9rem; color: var(--gold); border-left: 3px solid var(--gold); padding-left: 0.7rem; margin-bottom: 1rem; letter-spacing: 0.06em; }
.menu-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
.menu-list-item { padding: 0.55rem 0.3rem; border-bottom: 1px solid var(--border); font-size: 0.84rem; color: var(--text); display: flex; align-items: baseline; gap: 0.5rem; }
.menu-list-item::before { content: '・'; color: var(--gold); flex-shrink: 0; font-size: 0.7rem; }
.menu-note { font-size: 0.75rem; color: var(--text-muted); line-height: 1.7; margin: 0.8rem 0 1.2rem; padding: 0.8rem 1rem; border-left: 2px solid var(--border); }


/* ============================================================
   MORIAGE BOX
   ============================================================ */
.moriage-box { margin-top: 2rem; background: var(--dark); border: 1px solid var(--border); padding: 1.8rem 2rem; }
.moriage-box h3 { font-family: 'Noto Serif JP', serif; font-size: 1rem; color: var(--gold); margin-bottom: 1rem; letter-spacing: 0.1em; }
.moriage-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 0.6rem; }
.moriage-item { font-size: 0.82rem; color: var(--text-muted); padding: 0.5rem 0; border-bottom: 1px solid var(--border); }
.moriage-item strong { color: var(--gold-light); }


/* ============================================================
   COURSE SECTION (宴会コース) — index.html & category07.html共通
   ============================================================ */
.course-section { background: var(--dark); }
.course-section .section-title { color: var(--gold); }
.course-section .section-sub { color: var(--text-muted); }
/* menu内の宴会メニューは背景なし（page-bodyと統一） */
.page-body .course-section,
.page-body #course { background: transparent; }
.course-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.2rem; }
.course-card { border: 1px solid var(--border); padding: 1.8rem 1.5rem; background: var(--dark-soft); transition: border-color 0.2s; }
.course-card:hover { border-color: var(--gold); }
.course-card-label { font-size: 0.62rem; letter-spacing: 0.2em; color: var(--gold); margin-bottom: 0.7rem; }
.course-card h3 { font-family: 'Noto Serif JP', serif; font-size: 1.05rem; color: var(--text); margin-bottom: 0.5rem; }
.course-card p { font-size: 0.78rem; color: var(--text-muted); line-height: 1.7; margin-bottom: 0.8rem; }
.course-contents { font-size: 0.76rem; color: var(--text-muted); line-height: 1.8; background: var(--dark); padding: 0.8rem 1rem; margin-bottom: 0.8rem; border-left: 2px solid var(--border); }
.course-contents strong { color: var(--text); display: block; margin-bottom: 0.3rem; font-size: 0.78rem; }

/* コースブロック（大） */
.course-block { background: var(--dark-soft); border: 1px solid var(--border); padding: 2rem; margin-bottom: 1.5rem; }
.course-block h3 { font-family: 'Noto Serif JP', serif; font-size: 1.1rem; color: var(--gold); margin-bottom: 0.4rem; letter-spacing: 0.06em; display: flex; flex-wrap: wrap; align-items: baseline; gap: 0.4rem 0.6rem; }
.course-title-name { white-space: nowrap; }
.sp-only { display: none; }
.course-block .sub { font-size: 0.72rem; color: var(--text-muted); letter-spacing: 0.12em; margin-bottom: 1.2rem; }
.course-block-inner { display: grid; grid-template-columns: minmax(280px, 380px) 1fr; gap: 2rem; align-items: start; }
/* 画像エリア: all.jpg 1枚・縦長全体を黒帯なしで表示 */
.course-block-imgs { background: transparent; }
.course-block-imgs img { width: 100%; height: auto; max-height: none; object-fit: contain; display: block; }
.course-detail { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.course-col h4 { font-size: 0.8rem; color: var(--gold-light); letter-spacing: 0.08em; margin-bottom: 0.6rem; border-bottom: 1px solid var(--border); padding-bottom: 0.4rem; }
.course-col ul { list-style: none; padding: 0; }
.course-col ul li { font-size: 0.82rem; color: var(--text-muted); padding: 0.25rem 0; border-bottom: 1px solid rgba(255,255,255,0.04); }
.course-col ul li::before { content: '・'; color: var(--gold); }
.course-note { font-size: 0.75rem; color: var(--text-muted); margin-top: 1.2rem; line-height: 1.8; border-top: 1px solid var(--border); padding-top: 1rem; }

/* コースタイトル内 価格バッジ（h3内にインラインで配置） */
.course-price-badge { font-size: 0.78rem; color: var(--text-muted); font-family: 'Noto Sans JP', sans-serif; font-weight: 400; vertical-align: middle; }
.course-price-badge strong { font-size: 1rem; color: var(--gold); font-family: 'Noto Serif JP', serif; letter-spacing: 0.04em; margin: 0 0.1rem; }
.course-price-badge em { font-style: normal; font-size: 0.72rem; color: var(--text-muted); }

/* 飲み放題オプションボックス */
.nomihodai-box { margin-top: 1.5rem; padding: 1.2rem 1.5rem; border: 1px solid var(--gold); background: rgba(196,152,58,0.06); }
.nomihodai-box p.nomihodai-label { font-size: 0.8rem; color: var(--gold); letter-spacing: 0.1em; margin-bottom: 0.8rem; }
.nomihodai-items { display: flex; flex-wrap: wrap; gap: 0.4rem 1.2rem; }
.nomihodai-items span { font-size: 0.78rem; color: var(--text-muted); }


/* ============================================================
   KODAWARI SECTION
   ============================================================ */
.kodawari-section { background: var(--dark-mid); }
.kodawari-section .section-title { color: var(--gold); }
.kodawari-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.kodawari-card { background: var(--dark-soft); border: 1px solid var(--border); padding: 1.5rem; }
.kodawari-card h3 { font-family: 'Noto Serif JP', serif; font-size: 1rem; color: var(--gold); margin-bottom: 0.6rem; }
.kodawari-card p { font-size: 0.82rem; color: var(--text-muted); line-height: 1.8; }


/* ============================================================
   SHOP INFO SECTION (goldベース)
   ============================================================ */
.info-section { background: #C4983A; }
.info-section .section-title { color: #1A0800; }
.info-section .section-sub { color: #5A3800; }
.info-section .section-sub::after { background: #1A0800; }
.info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; }
.info-table { width: 100%; border-collapse: collapse; }
.info-table tr { border-bottom: 1px solid rgba(90,56,0,0.35); }
.info-table tr:last-child { border-bottom: none; }
.info-table th { text-align: left; padding: 0.85rem 0.5rem 0.85rem 0; font-size: 0.76rem; color: #5A3800; font-weight: 500; white-space: nowrap; width: 90px; vertical-align: top; letter-spacing: 0.06em; }
.info-table td { padding: 0.85rem 0; font-size: 0.88rem; color: #1A0800; line-height: 1.6; }
.info-table td small { color: #5A3800; }
.info-table td a { color: #660000; text-decoration: none; font-weight: 500; }
.info-table td a:hover { text-decoration: underline; }
.info-table td a.tel { color: var(--gold); }
.shop-photos { display: grid; grid-template-columns: 1fr 1fr; gap: 0.8rem; }
.shop-photos img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.shop-photo-cap { font-size: 0.72rem; color: #5A3800; text-align: center; margin-top: 0.3rem; }


/* ============================================================
   MAP
   ============================================================ */
.map-wrap { margin-top: 2.5rem; }
.map-wrap h3 { font-family: 'Noto Serif JP', serif; font-size: 1rem; color: #1A0800; margin-bottom: 1rem; letter-spacing: 0.08em; border-left: 3px solid #1A0800; padding-left: 0.7rem; }
.map-wrap iframe { width: 100%; height: 320px; border: 2px solid rgba(90,56,0,0.4); display: block; }


/* ============================================================
   CONTACT SECTION
   ============================================================ */
.contact-section { text-align: center; background: #1A1A1A; }
.contact-section .section-title { color: #DDD; }
.contact-section .section-sub { color: #777; }
.contact-section .section-sub::after { background: var(--gold); }
.contact-inner { max-width: 600px; margin: 0 auto; }
.tel-note { font-size: 0.78rem; color: #888; margin-bottom: 0.3rem; }
.tel-link { display: inline-block; font-family: 'Noto Serif JP', serif; font-size: clamp(1.6rem, 5vw, 2.3rem); color: #E06060; text-decoration: none; letter-spacing: 0.08em; margin: 0.8rem 0; transition: color 0.2s; }
.tel-link:hover { color: #FF8080; }
.hours-note { font-size: 0.8rem; color: #888; line-height: 1.9; }
.divider { width: 50px; height: 1px; background: #444; margin: 1.3rem auto; }
.contact-delivery-box { margin-top: 2rem; padding: 1.2rem 1.5rem; border: 1px solid var(--border); text-align: center; }
.contact-delivery-box p { font-size: 0.75rem; color: var(--text-muted); letter-spacing: 0.08em; margin-bottom: 0.8rem; }
.contact-btn-group { margin-top: 1.8rem; display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.btn-uber { background: #000; color: #fff; border-color: #000; }
.btn-uber:hover { background: #333; border-color: #333; }
.btn-line { background: #06C755; color: #fff; border-color: #06C755; }
.btn-line:hover { background: #04a344; border-color: #04a344; }


/* ============================================================
   PAGE HERO (サブページ共通)
   ============================================================ */
.page-hero { background: var(--dark); padding: 3rem 1.5rem 2.5rem; text-align: center; border-bottom: 2px solid var(--gold); }
.page-hero h1 { font-family: 'Noto Serif JP', serif; font-size: clamp(1.4rem, 4vw, 2rem); color: var(--gold); letter-spacing: 0.15em; margin-bottom: 0.3rem; }
.page-hero p { font-size: 0.72rem; letter-spacing: 0.25em; color: var(--text-muted); }
.page-body { max-width: 1000px; margin: 0 auto; padding: 3rem 1.5rem; }
.back-link { display: inline-flex; align-items: center; gap: 0.4rem; color: var(--text-muted); font-size: 0.8rem; text-decoration: none; margin-bottom: 2.5rem; letter-spacing: 0.05em; transition: color 0.2s; }
.back-link:hover { color: var(--gold); }
.back-link::before { content: '←'; }


/* ============================================================
   MENU PAGE (menu.html)
   ============================================================ */
.menu-section { margin-bottom: 3rem; }
.menu-section-head { font-family: 'Noto Serif JP', serif; font-size: 1.1rem; color: var(--gold); border-left: 4px solid var(--gold); padding-left: 0.8rem; margin-bottom: 1.2rem; letter-spacing: 0.08em; }
.menu-section-desc { font-size: 0.8rem; color: var(--text-muted); margin-bottom: 1rem; padding: 0.7rem 1rem; border-left: 2px solid var(--border); line-height: 1.7; }
.item-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); border-top: 1px solid var(--border); border-left: 1px solid var(--border); }
.item { padding: 0.6rem 0.8rem; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); font-size: 0.84rem; color: var(--text); }
.item.special { color: var(--gold-light); font-weight: 500; }
.photo-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; margin: 1.2rem 0; }
.photo-row figure { margin: 0; }
.photo-row img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; border: 1px solid var(--border); }
.photo-row figcaption { font-size: 0.75rem; color: var(--text-muted); text-align: center; margin-top: 0.3rem; }
.moriage-table { width: 100%; border-collapse: collapse; margin-top: 0.5rem; }
.moriage-table th { background: var(--dark-soft); color: var(--gold); font-size: 0.78rem; padding: 0.6rem 0.8rem; text-align: left; border: 1px solid var(--border); font-weight: 500; }
.moriage-table td { padding: 0.6rem 0.8rem; font-size: 0.82rem; color: var(--text-muted); border: 1px solid var(--border); }
.note { font-size: 0.75rem; color: var(--text-muted); margin-top: 2rem; padding: 0.8rem 1rem; border: 1px solid var(--border); line-height: 1.8; }
.section-label { font-family: 'Noto Serif JP', serif; font-size: 1.1rem; color: var(--gold); border-left: 4px solid var(--gold); padding-left: 0.8rem; margin: 2.5rem 0 1.2rem; letter-spacing: 0.08em; }


/* ============================================================
   TAKEOUT PAGE (category07.html)
   ============================================================ */
.takeout-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); border-top: 1px solid var(--border); border-left: 1px solid var(--border); margin-top: 0.8rem; }
.takeout-item { padding: 0.6rem 0.8rem; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); font-size: 0.82rem; color: var(--text-muted); }
.takeout-card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 1rem; margin-bottom: 0.6rem; }
.takeout-card { background: var(--dark-soft); border: 1px solid var(--border); overflow: hidden; transition: border-color 0.2s; }
.takeout-card:hover { border-color: var(--gold); }
.takeout-card img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.takeout-card-body { padding: 0.65rem 0.75rem; }
.takeout-card-body .name { font-size: 0.82rem; color: var(--text); line-height: 1.45; margin-bottom: 0.25rem; }
.takeout-card-body .name-sub { font-size: 0.7rem; color: var(--text-muted); line-height: 1.3; margin-bottom: 0.35rem; }
.takeout-card-body .desc { font-size: 0.68rem; color: var(--text-muted); line-height: 1.5; margin-bottom: 0.4rem; }
.takeout-card-body .price { font-size: 0.88rem; color: var(--gold); font-family: 'Noto Serif JP', serif; }
.uber-link-bar { display: flex; align-items: center; gap: 1rem; background: rgba(0,0,0,0.35); border: 1px solid var(--border); padding: 1rem 1.2rem; margin-bottom: 2rem; flex-wrap: wrap; }
.uber-link-bar p { font-size: 0.78rem; color: var(--text-muted); line-height: 1.6; flex: 1; min-width: 180px; }
.uber-link-bar a { display: inline-block; padding: 0.55rem 1.4rem; background: #000; color: #fff; font-size: 0.8rem; font-weight: 700; letter-spacing: 0.05em; border-radius: 4px; text-decoration: none; white-space: nowrap; }
.uber-link-bar a:hover { background: #333; }


/* ============================================================
   ACCESS PAGE (access.html)
   ============================================================ */
.access-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; align-items: start; }
.access-table { width: 100%; border-collapse: collapse; }
.access-table tr { border-bottom: 1px solid var(--border); }
.access-table tr:last-child { border-bottom: none; }
.access-table th { text-align: left; padding: 0.85rem 0.5rem 0.85rem 0; font-size: 0.76rem; color: var(--text-muted); font-weight: 500; white-space: nowrap; width: 90px; vertical-align: top; letter-spacing: 0.06em; }
.access-table td { padding: 0.85rem 0; font-size: 0.88rem; color: var(--text); line-height: 1.6; }
.access-table td a { color: var(--gold); text-decoration: none; }
.map-frame { width: 100%; height: 360px; border: 1px solid var(--border); display: block; }
.access-note { font-size: 0.78rem; color: var(--text-muted); margin-top: 1.5rem; line-height: 1.8; padding: 1rem; border-left: 3px solid var(--border); }


/* ============================================================
   CONTACT PAGE (contact.html)
   ============================================================ */
.contact-box { background: var(--dark-soft); border: 1px solid var(--border); padding: 2.5rem; margin-bottom: 2rem; }
.contact-box h2 { font-family: 'Noto Serif JP', serif; font-size: 1rem; color: var(--gold); margin-bottom: 1.5rem; letter-spacing: 0.08em; border-left: 3px solid var(--gold); padding-left: 0.7rem; }
.tel-block { text-align: center; padding: 2rem 0; }
.tel-block .label { font-size: 0.78rem; color: #888; margin-bottom: 0.4rem; }
.tel-block a { display: block; font-family: 'Noto Serif JP', serif; font-size: clamp(1.8rem, 5vw, 2.5rem); color: #E06060; text-decoration: none; letter-spacing: 0.08em; margin-bottom: 0.5rem; }
.tel-block .hours { font-size: 0.82rem; color: #888; line-height: 1.8; }
.gnavi-block { text-align: center; padding: 1.5rem 0; }
.gnavi-block p { font-size: 0.82rem; color: var(--text-muted); margin-bottom: 1.2rem; }
.gnavi-block a.btn-gnavi { display: inline-block; padding: 0.9rem 2.5rem; background: var(--red); color: white; text-decoration: none; font-size: 0.9rem; letter-spacing: 0.08em; transition: background 0.2s; }
.gnavi-block a.btn-gnavi:hover { background: var(--red-light); }
.form-table { width: 100%; border-collapse: collapse; }
.form-table tr { border-bottom: 1px solid var(--border); }
.form-table tr:last-child { border-bottom: none; }
.form-table th { text-align: left; padding: 1rem 0.5rem 1rem 0; font-size: 0.78rem; color: var(--text-muted); font-weight: 500; width: 120px; vertical-align: top; white-space: nowrap; }
.form-table td { padding: 0.8rem 0; }
.form-table input[type="text"],
.form-table input[type="email"],
.form-table input[type="tel"],
.form-table textarea { width: 100%; background: var(--dark); border: 1px solid var(--border); color: var(--text); padding: 0.6rem 0.8rem; font-size: 0.85rem; font-family: 'Noto Sans JP', sans-serif; outline: none; transition: border-color 0.2s; }
.form-table input:focus, .form-table textarea:focus { border-color: var(--gold); }
.form-table textarea { height: 140px; resize: vertical; }
.form-submit { text-align: center; margin-top: 1.5rem; }
.form-submit button { padding: 0.9rem 3rem; background: var(--red); color: white; border: none; font-size: 0.88rem; letter-spacing: 0.1em; cursor: pointer; font-family: 'Noto Sans JP', sans-serif; transition: background 0.2s; }
.form-submit button:hover { background: var(--red-light); }
.required { color: var(--red-light); font-size: 0.65rem; margin-left: 0.3rem; }
/* 汎用テキストスタイル */
.text-sm { font-size: 0.82rem; color: var(--text-muted); line-height: 1.8; }
.text-sm-note { font-size: 0.85rem; color: var(--text-muted); }
.mb-12 { margin-bottom: 1.2rem; }

.line-btn { display: inline-block; padding: 0.7rem 1.8rem; background: #06C755; color: #fff; font-size: 0.9rem; font-weight: 700; letter-spacing: 0.05em; border-radius: 4px; text-decoration: none; }
.line-btn:hover { background: #04a344; }


/* ============================================================
   GNAVI BAR
   ============================================================ */
.gnavi-bar { background: var(--dark-mid); padding: 0.9rem 1.5rem; text-align: center; }
.gnavi-bar a { color: var(--gold-light); font-size: 0.8rem; letter-spacing: 0.05em; text-decoration: none; }
.gnavi-bar a:hover { text-decoration: underline; }


/* ============================================================
   FOOTER
   ============================================================ */
footer { background: var(--dark); color: var(--text-muted); text-align: center; padding: 2rem 1.5rem; border-top: 1px solid var(--border); }
.footer-logo { display: flex; align-items: center; justify-content: center; gap: 10px; margin-bottom: 0.4rem; }
.footer-logo img { width: 36px; height: 36px; object-fit: contain; }
.footer-logo-text { font-family: 'Noto Serif JP', serif; font-size: 1rem; color: var(--gold); letter-spacing: 0.1em; }
footer p { font-size: 0.72rem; letter-spacing: 0.04em; margin-top: 0.3rem; }
footer nav ul { display: flex; flex-wrap: wrap; justify-content: center; list-style: none; margin: 1rem 0; }
footer nav ul li a { display: block; padding: 0.25rem 0.7rem; color: var(--text-muted); font-size: 0.72rem; text-decoration: none; border-right: 1px solid var(--border); letter-spacing: 0.04em; }
footer nav ul li:last-child a { border-right: none; }
footer nav ul li a:hover { color: var(--gold); }


/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
  /* ヘッダー */
  nav { display: none; }
  .hamburger { display: flex; }
  /* ヒーロー */
  .hero-img { height: auto; }
  .hero-overlay { position: static; background: var(--dark); display: block; pointer-events: auto; }
  .hero-content { padding: 1.5rem 1.2rem; max-width: 100%; }
  .hero-badge { font-size: 0.65rem; }
  .hero h1 { font-size: 1.6rem; }
  .hero p { font-size: 0.82rem; }
  .hero-actions .btn { text-align: center; width: 100%; }
  /* 共通 */
  .notice-bar { font-size: 0.74rem; padding: 0.7rem 1rem; }
  section { padding: 2.8rem 1.2rem; }
  .info-bar { padding: 1.5rem 1.2rem; }
  .info-bar-inner { flex-direction: column; gap: 0.8rem; }
  .info-grid { grid-template-columns: 1fr; gap: 2rem; }
  .moriage-list { grid-template-columns: 1fr; }
  /* 盛り合わせカードはスマホで1列 */
  .menu-section .menu-grid { grid-template-columns: 1fr; }
  .menu-tab { font-size: 0.72rem; padding: 0.5rem 0.7rem; }
  /* コースブロック */
  .course-block-inner { grid-template-columns: 1fr; }
  .course-detail { grid-template-columns: 1fr; }
  /* こだわり: タブレットでも2列維持、スマホで1列（480pxで制御） */
  .kodawari-grid { grid-template-columns: 1fr 1fr; }
  /* アクセス */
  .access-grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .btn { text-align: center; }
  .menu-grid { grid-template-columns: 1fr; }
  .course-grid { grid-template-columns: 1fr; }
  .kodawari-grid { grid-template-columns: 1fr; }
  .shop-photos { grid-template-columns: 1fr; }
  .menu-list { grid-template-columns: 1fr; }
  .takeout-card-grid { grid-template-columns: repeat(2, 1fr); }
  .course-price-badge { font-size: 0.72rem; }
  .course-price-badge strong { font-size: 0.9rem; }
  .sp-only { display: inline; }
}

@media (min-width: 769px) {
  .mobile-nav { display: none !important; }
}
