
/* ============================================================
   炭火焼鳥 ゆ鳥 | 新サイト共通スタイル
   HTML内の data-edit 属性、assets/js/site-data.js のコメントを目印に編集できます。
   ============================================================ */
:root {
  --ink: #1b1916;
  --ink-soft: #3e3932;
  --sumi: #272421;
  --sumi-2: #171614;
  --paper: #f3ead7;
  --paper-light: #fffdf7;
  --paper-dark: #e8dcc4;
  --fire: #a43017;
  --fire-dark: #76200f;
  --gold: #c49136;
  --line: rgba(50, 39, 28, .18);
  --white: #fffdf8;
  --container: min(1120px, calc(100% - 40px));
  --shadow: 0 18px 42px rgba(31, 22, 14, .16);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-width: 320px;
  color: var(--ink);
  background: var(--paper) url('../img/background_wasi.jpg') repeat;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic", Meiryo, sans-serif;
  font-size: 16px;
  line-height: 1.8;
}
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
a:hover { opacity: .82; }
img { max-width: 100%; display: block; }
button { font: inherit; }

/* Shared structural blocks */
.container { width: var(--container); margin-inline: auto; }
.paper-section { padding: clamp(64px, 8vw, 104px) 0; }
.ink-section { padding: clamp(64px, 8vw, 104px) 0; color: var(--white); background: linear-gradient(145deg, var(--sumi-2), var(--sumi)); }
.section-header { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 32px; }
.section-kicker { display: inline-flex; align-items: center; gap: 10px; margin: 0 0 10px; color: var(--fire); font-size: .76rem; font-weight: 800; letter-spacing: .18em; }
.section-kicker::before { content: ""; width: 26px; height: 1px; background: currentColor; }
.section-title { margin: 0; font-family: "Yu Mincho", "Hiragino Mincho ProN", serif; font-size: clamp(2rem, 4vw, 3.35rem); line-height: 1.18; letter-spacing: .07em; }
.section-title--light { color: var(--white); }
.section-lead { margin: 16px 0 0; max-width: 680px; color: var(--ink-soft); }
.section-lead--light { color: rgba(255,253,248,.74); }
.text-link { display: inline-flex; align-items: center; gap: 10px; font-size: .9rem; font-weight: 700; color: var(--fire); }
.text-link::after { content: "→"; transition: transform .18s ease; }
.text-link:hover::after { transform: translateX(4px); }

/* Header / navigation */
.site-header { position: sticky; z-index: 30; top: 0; background: rgba(23, 22, 20, .96); box-shadow: 0 8px 26px rgba(0,0,0,.14); backdrop-filter: blur(10px); }
.header-inner { width: var(--container); min-height: 78px; margin-inline: auto; display: flex; align-items: center; justify-content: space-between; gap: 22px; }
.brand { display: inline-flex; align-items: center; gap: 14px; flex-shrink: 0; }
.brand img { width: 96px; height: auto; }
.brand-copy { display: grid; gap: 2px; color: var(--white); }
.brand-copy small { font-size: .58rem; letter-spacing: .17em; color: rgba(255,255,255,.58); white-space: nowrap; }
.brand-copy strong { font-family: "Yu Mincho", "Hiragino Mincho ProN", serif; font-size: 1rem; letter-spacing: .13em; font-weight: 600; white-space: nowrap; }
.primary-nav { display: flex; align-items: center; gap: 4px; }
.primary-nav a { position: relative; display: block; padding: 26px 13px 22px; color: rgba(255,255,255,.82); font-size: .87rem; font-weight: 700; letter-spacing: .04em; }
.primary-nav a::after { content: ""; position: absolute; right: 13px; bottom: 17px; left: 13px; height: 2px; background: var(--gold); transform: scaleX(0); transform-origin: center; transition: transform .2s ease; }
.primary-nav a:hover, .primary-nav a[aria-current="page"] { color: #fff; }
.primary-nav a:hover::after, .primary-nav a[aria-current="page"]::after { transform: scaleX(1); }
.menu-button { display: none; width: 44px; height: 44px; padding: 0; color: #fff; background: transparent; border: 1px solid rgba(255,255,255,.3); cursor: pointer; }
.menu-button span { display: block; width: 19px; height: 1px; margin: 5px auto; background: currentColor; transition: transform .2s ease; }
.mobile-panel { display: none; }

/* Buttons */
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 52px; padding: 13px 23px; border: 1px solid transparent; border-radius: 0; font-weight: 800; letter-spacing: .06em; transition: transform .18s ease, background .18s ease; }
.button:hover { opacity: 1; transform: translateY(-2px); }
.button--fire { color: var(--white); background: var(--fire); box-shadow: 0 10px 20px rgba(118,32,15,.2); }
.button--fire:hover { background: var(--fire-dark); }
.button--outline { color: var(--white); border-color: rgba(255,255,255,.5); }
.button--outline:hover { background: rgba(255,255,255,.12); }
.button--paper { color: var(--ink); background: var(--paper); }
.button--paper:hover { background: #fff; }
.button-row { display: flex; flex-wrap: wrap; gap: 12px; }

/* Footer */
.site-footer { color: rgba(255,255,255,.78); background: #151412; }
.footer-inner { width: var(--container); margin-inline: auto; padding: 52px 0 24px; display: grid; grid-template-columns: 1fr auto; gap: 32px; }
.footer-brand { display: flex; align-items: center; gap: 18px; }
.footer-brand img { width: 80px; }
.footer-brand-name { margin: 0; font-family: "Yu Mincho", "Hiragino Mincho ProN", serif; color: #fff; font-size: 1.2rem; letter-spacing: .14em; }
.footer-brand-text { margin: 8px 0 0; font-size: .82rem; color: rgba(255,255,255,.55); }
.footer-nav { display: flex; flex-wrap: wrap; align-content: flex-start; justify-content: flex-end; gap: 10px 20px; max-width: 460px; }
.footer-nav a { font-size: .82rem; }
.footer-bottom { width: var(--container); margin-inline: auto; padding: 18px 0 25px; border-top: 1px solid rgba(255,255,255,.13); color: rgba(255,255,255,.42); font-size: .7rem; letter-spacing: .05em; }

/* Home */
.home-hero { position: relative; isolation: isolate; overflow: hidden; min-height: min(730px, calc(100svh - 78px)); color: #fff; background: var(--sumi-2); }
.home-hero::before { content: ""; position: absolute; z-index: 1; inset: 0; background: radial-gradient(circle at 78% 58%, rgba(191,93,27,.22), transparent 36%), linear-gradient(90deg, rgba(10,10,9,.88) 0%, rgba(20,17,14,.58) 42%, rgba(20,17,14,.12) 100%); }
.home-hero::after { content: ""; position: absolute; z-index: 1; inset: 0; opacity: .11; background-image: url('../img/background_wasi.jpg'); mix-blend-mode: screen; pointer-events: none; }
/* 編集場所：トップの焼鳥写真。画像を入れ替える時は index.html の hero-photo を変更します。 */
.hero-photo { position: absolute; z-index: 0; right: 0; top: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; filter: saturate(1.02) contrast(1.05) brightness(.92); }
.hero-inner { position: relative; z-index: 2; width: var(--container); min-height: inherit; margin-inline: auto; display: flex; flex-direction: column; justify-content: center; padding: 72px 0 100px; }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 12px; margin: 0 0 20px; color: #e3c074; font-size: .72rem; font-weight: 800; letter-spacing: .18em; }
.hero-eyebrow::before { content: ""; width: 38px; height: 1px; background: currentColor; }
.hero-title { max-width: 8.1em; margin: 0; font-family: "Yu Mincho", "Hiragino Mincho ProN", serif; font-size: clamp(3.3rem, 8.4vw, 7.6rem); line-height: 1.02; letter-spacing: .12em; font-weight: 600; text-shadow: 0 8px 24px rgba(0,0,0,.28); }
.hero-title span { display: block; margin-top: .35em; margin-left: .95em; color: #e8c875; font-size: .44em; letter-spacing: .24em; }
.hero-copy { max-width: 500px; margin: 26px 0 30px; color: rgba(255,255,255,.82); font-size: clamp(.95rem, 1.6vw, 1.08rem); }
.hero-bottom-note { position: absolute; right: max(20px, calc((100% - 1120px) / 2)); bottom: 30px; display: flex; gap: 12px; align-items: center; color: rgba(255,255,255,.55); font-size: .71rem; letter-spacing: .11em; writing-mode: vertical-rl; }
.hero-bottom-note::before { content: ""; width: 1px; height: 52px; background: rgba(255,255,255,.45); }
.home-intro { position: relative; background: var(--paper-light) url('../img/background_wasi.jpg') repeat; }
.home-intro-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(34px, 6vw, 80px); align-items: center; }
.intro-image { position: relative; padding: 16px 16px 0 0; }
.intro-image::before { content: ""; position: absolute; z-index: 0; right: 0; top: 0; width: 74%; height: 86%; background: var(--fire); }
.intro-image img { position: relative; z-index: 1; width: 100%; min-height: 340px; object-fit: cover; }
.intro-copy { padding: 24px 0; }
.intro-copy .section-title { color: var(--ink); }
.intro-quote { margin: 24px 0; padding-left: 20px; border-left: 3px solid var(--gold); font-family: "Yu Mincho", "Hiragino Mincho ProN", serif; font-size: 1.16rem; line-height: 2; }
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.feature-card { position: relative; min-height: 360px; overflow: hidden; color: #fff; background: #201d1a; }
.feature-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(0deg, rgba(9,8,7,.9) 0%, rgba(9,8,7,.05) 70%); }
.feature-card img { width: 100%; height: 100%; min-height: 360px; object-fit: cover; transition: transform .35s ease; }
.feature-card:hover img { transform: scale(1.045); }
.feature-card-content { position: absolute; z-index: 1; right: 0; bottom: 0; left: 0; padding: 27px 25px; }
.feature-tag { display: inline-block; margin-bottom: 10px; padding: 4px 10px; color: #fff; background: #8f1e1e; font-size: .7rem; font-weight: 800; letter-spacing: .08em; }
.feature-card h3 { margin: 0; font-family: "Yu Mincho", "Hiragino Mincho ProN", serif; font-size: 1.55rem; letter-spacing: .08em; }
.feature-card p { margin: 9px 0 0; color: rgba(255,255,255,.74); font-size: .86rem; line-height: 1.7; }
.news-layout { display: grid; grid-template-columns: .82fr 1.18fr; gap: clamp(34px, 6vw, 80px); }
.news-list { margin: 0; padding: 0; list-style: none; border-top: 1px solid var(--line); }
.news-list li { border-bottom: 1px solid var(--line); }
.news-list a { display: grid; grid-template-columns: 100px 64px 1fr; gap: 14px; align-items: center; padding: 17px 0; }
.news-date { color: var(--ink-soft); font-size: .78rem; font-weight: 700; }
.news-category { display: inline-flex; justify-content: center; padding: 2px 7px; color: var(--fire); border: 1px solid rgba(164,48,23,.35); font-size: .62rem; font-weight: 800; letter-spacing: .1em; }
.news-title { font-size: .94rem; }
.shop-callout { display: flex; flex-direction: column; justify-content: center; padding: clamp(30px,5vw,54px); color: var(--white); background: linear-gradient(135deg, #9c2f18, #67200f); box-shadow: var(--shadow); }
.shop-callout .section-kicker { color: #e7c170; }
.shop-callout .section-title { max-width: 9em; }
.shop-callout p { color: rgba(255,255,255,.77); }

/* Inner page hero */
.page-hero { position: relative; overflow: hidden; min-height: 330px; color: #fff; background: #211f1c; }
.page-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(13,12,10,.86), rgba(13,12,10,.48)); }
.page-hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: saturate(.85) contrast(1.08) brightness(.74); }
.page-hero-inner { position: relative; z-index: 1; width: var(--container); min-height: 330px; margin-inline: auto; display: flex; flex-direction: column; justify-content: center; padding: 50px 0; }
.page-hero .section-kicker { color: #e1bd6c; }
.page-hero h1 { max-width: 12em; margin: 0; font-family: "Yu Mincho", "Hiragino Mincho ProN", serif; font-size: clamp(2.6rem, 5.5vw, 4.7rem); line-height: 1.15; letter-spacing: .11em; }
.page-hero p { max-width: 560px; margin: 15px 0 0; color: rgba(255,255,255,.76); font-size: .94rem; }

/* Menu */
.menu-summary { display: grid; grid-template-columns: .86fr 1.14fr; gap: 46px; align-items: center; padding: 28px; background: var(--paper-light); border: 1px solid var(--line); }
.menu-summary img { width: 100%; height: 270px; object-fit: cover; }
.menu-summary h2 { margin: 0; font-family: "Yu Mincho", "Hiragino Mincho ProN", serif; font-size: 2rem; letter-spacing: .08em; }
.menu-summary p { margin: 13px 0 0; color: var(--ink-soft); }
.menu-note { margin-top: 16px; color: #6e3d23; font-size: .81rem; }
.menu-anchor-nav { position: sticky; z-index: 10; top: 78px; display: flex; gap: 7px; overflow-x: auto; margin: 44px 0 0; padding: 10px 0; background: rgba(243,234,215,.92); backdrop-filter: blur(8px); }
.menu-anchor-nav a { flex: 0 0 auto; padding: 9px 15px; color: var(--ink-soft); border: 1px solid var(--line); background: var(--paper-light); font-size: .8rem; font-weight: 700; }
.menu-anchor-nav a:hover { color: var(--white); background: var(--fire); }
.menu-section { scroll-margin-top: 145px; padding: 68px 0; border-bottom: 1px solid var(--line); }
.menu-section:last-child { border-bottom: none; }
.menu-heading { display: grid; grid-template-columns: 1fr minmax(250px, .65fr); gap: 32px; align-items: center; margin-bottom: 30px; }
.menu-heading-copy h2 { margin: 0; font-family: "Yu Mincho", "Hiragino Mincho ProN", serif; font-size: clamp(2rem,4vw,3rem); letter-spacing: .08em; }
.menu-heading-copy p { margin: 12px 0 0; color: var(--ink-soft); }
.menu-heading img { width: 100%; height: 190px; object-fit: cover; box-shadow: var(--shadow); }
.menu-items { display: grid; grid-template-columns: repeat(2,1fr); gap: 0 30px; border-top: 1px solid var(--line); }
.menu-item { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; min-height: 52px; padding: 13px 2px; border-bottom: 1px solid var(--line); }
.menu-item-name { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; font-size: .94rem; font-weight: 700; }
.menu-item-price { flex: 0 0 auto; color: var(--fire); font-size: .9rem; font-weight: 800; white-space: nowrap; }
.food-tag { padding: 2px 6px; color: var(--white); background: var(--fire); font-size: .61rem; font-weight: 800; letter-spacing: .05em; line-height: 1.45; }

/* Party */
.party-intro { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(35px,5vw,70px); align-items: center; }
.party-intro-photo { position: relative; }
.party-intro-photo::after { content: ""; position: absolute; left: -16px; bottom: -16px; width: 52%; height: 46%; border: 1px solid var(--gold); }
.party-intro-photo img { position: relative; z-index: 1; width: 100%; height: 420px; object-fit: cover; }
.party-intro-list { margin: 24px 0 0; padding: 0; list-style: none; border-top: 1px solid var(--line); }
.party-intro-list li { padding: 12px 0; border-bottom: 1px solid var(--line); }
.party-intro-list strong { color: var(--fire); }
.plan-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 24px; }
.plan-card { overflow: hidden; background: var(--paper-light); border: 1px solid var(--line); box-shadow: 0 12px 28px rgba(53,38,24,.08); }
.party-course-photo { margin: 0 0 24px; }
.party-course-photo img { width: 100%; height: 340px; object-fit: cover; border: 1px solid rgba(196,145,54,.28); box-shadow: 0 16px 34px rgba(0,0,0,.18); }
.plan-card img { width: 100%; height: 220px; object-fit: cover; }
.plan-card--textonly { border-top: 4px solid var(--gold); }
.plan-card-content { padding: 25px; }
.plan-type { display: inline-block; margin-bottom: 10px; color: var(--fire); font-size: .72rem; font-weight: 800; letter-spacing: .12em; }
.plan-card h3 { margin: 6px 0 10px; font-family: "Yu Mincho", "Hiragino Mincho ProN", serif; font-size: 1.65rem; letter-spacing: .06em; }
.plan-card h3 span { display: inline-block; padding: 8px 14px; color: #fff; background: #2a2119; box-shadow: inset 0 0 0 1px rgba(255,255,255,.08); }
.plan-price { margin: 0; color: var(--fire); font-size: 1.4rem; font-weight: 800; }
.plan-card .plan-description { margin: 12px 0 0; color: var(--ink-soft); font-size: .88rem; }
.plan-items-label { margin: 20px 0 0; padding-top: 16px; border-top: 1px solid var(--line); color: var(--ink); font-size: .76rem; font-weight: 800; letter-spacing: .1em; }
.plan-items { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 0 18px; margin: 8px 0 0; padding: 0; list-style: none; }
.plan-items li { position: relative; padding: 7px 0 7px 12px; border-bottom: 1px solid rgba(50,39,28,.12); color: var(--ink-soft); font-size: .83rem; line-height: 1.55; }
.plan-items li::before { content: "・"; position: absolute; left: 0; color: var(--fire); }
.party-note { margin-top: 20px; padding: 20px 24px; color: #2a2119; border: 1px solid rgba(196,145,54,.48); border-left: 4px solid var(--gold); background: #fffaf0; box-shadow: 0 8px 18px rgba(0,0,0,.12); font-size: .9rem; line-height: 1.85; }
.party-note--strong { display: flex; align-items: center; gap: 14px; margin-bottom: 24px; padding: 18px 22px; color: #fff; border: 1px solid rgba(225,189,108,.5); border-left: 8px solid #f0c766; background: linear-gradient(90deg, #8c1d17, #b43a22); box-shadow: 0 12px 26px rgba(0,0,0,.22); font-size: 1rem; }
.party-note--strong strong { flex: 0 0 auto; padding: 6px 10px; color: #2a2119; background: #f0c766; font-size: .85rem; letter-spacing: .08em; }
.party-note--strong span { font-size: 1.02rem; font-weight: 700; }

/* Stores */
.store-tools { display: grid; grid-template-columns: minmax(0,1fr) auto; gap: 14px; margin-bottom: 26px; }
.store-search { width: 100%; min-height: 52px; padding: 0 16px; color: var(--ink); background: var(--paper-light); border: 1px solid var(--line); border-radius: 0; outline: none; }
.store-search:focus { border-color: var(--fire); box-shadow: 0 0 0 3px rgba(164,48,23,.1); }
.store-count { display: inline-flex; align-items: center; padding: 0 12px; color: var(--ink-soft); font-size: .84rem; white-space: nowrap; }
.store-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.store-card { display: flex; flex-direction: column; min-height: 100%; padding: 25px; background: var(--paper-light); border: 1px solid var(--line); transition: transform .2s ease, box-shadow .2s ease; }
.store-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.store-prefecture { color: var(--fire); font-size: .68rem; font-weight: 800; letter-spacing: .12em; }
.store-card h2 { margin: 5px 0 20px; font-family: "Yu Mincho", "Hiragino Mincho ProN", serif; font-size: 1.7rem; letter-spacing: .06em; }
.store-info { margin: 0; }
.store-info div { display: grid; grid-template-columns: 74px 1fr; gap: 8px; padding: 10px 0; border-top: 1px solid var(--line); }
.store-info dt { color: #7c6b55; font-size: .72rem; font-weight: 800; }
.store-info dd { margin: 0; font-size: .85rem; line-height: 1.65; }
.store-features { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 16px; }
.store-feature { padding: 2px 7px; color: #6b3a12; background: #f3dfb8; font-size: .66rem; font-weight: 800; }
.store-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; margin-top: auto; padding-top: 21px; }
.store-actions a { padding: 10px 8px; text-align: center; color: var(--white); background: var(--fire); font-size: .74rem; font-weight: 800; }
.store-actions a:last-child { color: var(--ink); background: var(--paper-dark); }
.empty-message { grid-column: 1 / -1; margin: 0; padding: 50px 20px; text-align: center; color: var(--ink-soft); background: rgba(255,253,247,.58); border: 1px dashed var(--line); }

/* Recruit */
.recruit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; }
.recruit-card { padding: 34px; background: var(--paper-light); border: 1px solid var(--line); }
.recruit-card h2 { margin: 0; font-family: "Yu Mincho", "Hiragino Mincho ProN", serif; font-size: 2rem; letter-spacing: .06em; }
.recruit-card p { color: var(--ink-soft); }
.recruit-card ul { margin: 20px 0 0; padding: 0; list-style: none; }
.recruit-card li { padding: 10px 0; border-top: 1px solid var(--line); font-size: .9rem; }
.recruit-image { overflow: hidden; }
.recruit-image img { width: 100%; height: 100%; min-height: 350px; object-fit: cover; }

/* Reveal animation */
.js-reveal { opacity: 0; transform: translateY(14px); transition: opacity .5s ease, transform .5s ease; }
.js-reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (max-width: 920px) {
  .primary-nav { display: none; }
  .menu-button { display: block; }
  .mobile-panel { position: fixed; z-index: 29; top: 78px; right: 0; left: 0; padding: 14px 20px 22px; background: rgba(23,22,20,.98); box-shadow: 0 14px 24px rgba(0,0,0,.22); }
  .mobile-panel.is-open { display: block; }
  .mobile-panel a { display: block; padding: 14px 5px; color: rgba(255,255,255,.9); border-bottom: 1px solid rgba(255,255,255,.12); font-size: .94rem; font-weight: 700; }
  .home-intro-grid, .news-layout, .party-intro, .menu-summary { grid-template-columns: 1fr; }
  .intro-image { max-width: 680px; }
  .feature-grid, .plan-grid, .store-grid { grid-template-columns: repeat(2, 1fr); }
  .menu-heading { grid-template-columns: 1fr .7fr; }
  .footer-inner { grid-template-columns: 1fr; }
  .footer-nav { justify-content: flex-start; }
}

@media (max-width: 640px) {
  :root { --container: min(100% - 28px, 1120px); }
  .header-inner { min-height: 68px; }
  .brand img { width: 75px; }
  .brand-copy strong { font-size: .87rem; }
  .brand-copy small { font-size: .49rem; }
  .mobile-panel { top: 68px; }
  .home-hero { min-height: 670px; }
  .hero-photo { width: 100%; opacity: .54; }
  .home-hero::before { background: linear-gradient(0deg, rgba(10,10,9,.94), rgba(10,10,9,.37)), linear-gradient(90deg, rgba(10,10,9,.66), rgba(10,10,9,.22)); }
  .hero-inner { justify-content: flex-end; padding: 50px 0 84px; }
  .hero-title { font-size: clamp(3.2rem, 17vw, 5.8rem); }
  .hero-copy { margin-top: 20px; font-size: .9rem; }
  .hero-bottom-note { display: none; }
  .section-header { display: block; }
  .section-header .text-link { margin-top: 20px; }
  .feature-grid, .plan-grid, .store-grid, .recruit-grid { grid-template-columns: 1fr; }
  .party-course-photo img { height: 240px; }
  .party-note--strong { flex-direction: column; align-items: flex-start; }
  .feature-card, .feature-card img { min-height: 300px; }
  .news-list a { grid-template-columns: 80px 52px 1fr; gap: 9px; }
  .news-date, .news-category { font-size: .62rem; }
  .news-title { font-size: .82rem; }
  .page-hero, .page-hero-inner { min-height: 280px; }
  .page-hero h1 { font-size: 2.5rem; }
  .menu-anchor-nav { top: 68px; margin-top: 28px; }
  .menu-heading { grid-template-columns: 1fr; gap: 18px; }
  .menu-heading img { height: 200px; }
  .menu-items { grid-template-columns: 1fr; gap: 0; }
  .menu-item { min-height: 48px; }
  .menu-item-name { font-size: .85rem; }
  .menu-item-price { font-size: .82rem; }
  .party-intro-photo img { height: 300px; }
  .store-tools { grid-template-columns: 1fr; }
  .store-count { padding: 0; }
  .footer-inner { padding-top: 42px; }
  .footer-brand { align-items: flex-start; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition-duration: .01ms !important; animation-duration: .01ms !important; }
}


/* 改修：全メニュー・税別表示・お知らせ一覧 */
.brand-copy strong { display: block; font-size: .9rem; letter-spacing: .08em; }
.news-more { margin: 24px 0 0; text-align: right; }
.feature-price { margin: 18px 0 0 !important; color: var(--gold); font-family: "Yu Mincho", "Hiragino Mincho ProN", serif; font-size: 1.1rem; font-weight: 700; }
.feature-price small { font-size: .72rem; font-family: inherit; }
.tax-note { margin: 18px 0 0; color: var(--ink-soft); font-size: .82rem; line-height: 1.75; }
.tax-note--menu { margin-top: 24px; text-align: right; }
.menu-groups { display: grid; gap: 28px; }
.menu-group { padding: 0; }
.menu-group h3 { margin: 0 0 12px; padding: 10px 16px; color: var(--white); background: var(--sumi); font-family: "Yu Mincho", "Hiragino Mincho ProN", serif; font-size: 1.13rem; letter-spacing: .06em; }
.menu-group-note { margin: 12px 0 0; color: var(--ink-soft); font-size: .8rem; }
.news-list--full { margin-top: 34px; }
.news-list--full li a { padding: 18px 0; }
.news-page { max-width: 900px; }

@media (min-width: 860px) {
  .menu-groups { grid-template-columns: repeat(2, minmax(0, 1fr)); align-items: start; }
  .menu-section#yakitori .menu-groups,
  .menu-section#drink .menu-groups { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
  .news-more { text-align: left; }
  .feature-price { margin-top: 12px !important; }
  .menu-group h3 { padding: 9px 12px; font-size: 1rem; }
  .tax-note--menu { text-align: left; }
}


/* 採用情報：スタッフ写真 */
.page-hero--recruit img { object-position: center 34%; background: #332921; }
.recruit-image { display: flex; align-items: stretch; justify-content: center; background: #2c211a; }
.recruit-image img { object-position: center; }

@media (max-width: 720px) {
  .plan-grid { grid-template-columns: 1fr; }
  .plan-card img { height: 205px; }
  .plan-items { grid-template-columns: 1fr; }
}
