:root {
  --black: #111111;
  --white: #ffffff;
  --soft-white: #fafafa;
  --line: #1a1a1a;
  --muted: #555555;
  --red-small: #9a1f1f;
  --green: #b7cf58;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--white);
  color: var(--black);
  font-family: "Noto Serif JP", "Yu Mincho", "Hiragino Mincho ProN", serif;
  line-height: 2;
  letter-spacing: 0.08em;
}
a { color: inherit; text-decoration: none; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
.header { height: 180px; padding: 42px 24px 24px; display: flex; justify-content: space-between; align-items: flex-start; background: #fff; }
.logo-kicker { color: var(--red-small); font-size: 14px; line-height: 1.5; letter-spacing: 0.12em; margin: 0 0 8px; }
.logo-sub { margin: 0 0 12px; font-size: 14px; }
.logo-main { margin: 0; font-size: 46px; font-weight: 700; letter-spacing: 0.16em; line-height: 1; transform: scaleX(1.08); transform-origin: left center; }
.logo-en { margin: 8px 0 0; font-size: 11px; font-style: italic; letter-spacing: 0.08em; }
.header-actions { display: flex; gap: 22px; align-items: center; margin-top: 36px; }
.phone-icon { width: 56px; height: 56px; border-radius: 50%; background: #000; color: #fff; display: flex; align-items: center; justify-content: center; font-size: 24px; }
.menu-toggle { width: 52px; height: 42px; border: none; background: transparent; padding: 0; display: flex; flex-direction: column; justify-content: center; gap: 8px; }
.menu-toggle span { display: block; height: 1px; width: 100%; background: #111; }
.global-nav { max-height: 0; overflow: hidden; border-top: 1px solid #111; border-bottom: 1px solid #111; }
.global-nav.is-open { max-height: 500px; }
.global-nav a { display: block; padding: 14px 24px; border-bottom: 1px solid #111; font-size: 14px; font-family: "Noto Sans JP", sans-serif; }
.hero { background: #fff; padding: 0 0 72px; }
.hero-image { width: 100%; height: auto; aspect-ratio: 16 / 9; display: block; object-fit: cover; background: #f4f4f4; }
.hero-copy { padding: 32px 28px 0; text-align: center; }
.hero-lead { font-size: 20px; letter-spacing: 0.12em; margin: 0; }
.hero-title-line { margin: 28px 0 0; display: inline-block; background: rgba(250,250,250,0.9); padding: 14px 24px; font-size: 22px; letter-spacing: 0.16em; }
.hero-sub { margin: 18px 0 0; font-size: 15px; color: #444; }
.hero-links { margin: 32px auto 0; width: calc(100% - 48px); display: grid; gap: 14px; }
.button-outline { height: 58px; border: 1px solid #111; background: transparent; color: #111; display: flex; align-items: center; justify-content: center; position: relative; font-size: 16px; letter-spacing: 0.12em; }
.button-outline::after { content: ">"; position: absolute; right: 22px; }
.button-primary { background: #111; color: #fff; border: 1px solid #111; }
.section-news, .menu-feature, .menu-list-section, .footer { padding: 72px 24px; }
.section-title { text-align: center; font-size: 28px; font-weight: 500; letter-spacing: 0.2em; margin: 0 0 42px; }
.section-title::after { content: ""; display: block; width: 72px; height: 3px; background: #b7cf58; margin: 14px auto 0; }
.news-list { border-top: 1px solid #ddd; }
.news-item { padding: 22px 0; border-bottom: 1px solid #ddd; }
.news-date { font-size: 15px; margin: 0 0 12px; }
.news-title { font-size: 16px; line-height: 1.9; margin: 0; }
.intro-section { position: relative; padding: 80px 24px; background: linear-gradient(150deg, #fafafa, #f2f2f2 45%, #fbfbfb); }
.intro-panel { background: rgba(255,255,255,0.86); padding: 34px 28px; border: 1px solid rgba(0,0,0,0.12); }
.intro-heading { font-size: 28px; line-height: 1.7; letter-spacing: 0.14em; font-weight: 500; margin: 0 0 24px; }
.heading-line { width: 100%; height: 1px; background: #111; margin: 24px 0; }
.intro-text, .menu-text, .contact-text, .access-info p { font-size: 16px; line-height: 2.2; margin: 0; }
.section-link-wrap { margin: 26px 0 0; }
.menu-photo { width: 100%; height: 280px; margin-bottom: 34px; background: radial-gradient(circle at 35% 45%, #f9f9f8 0 30%, #d6dce1 30% 33%, #efefef 33% 100%), radial-gradient(circle at 50% 48%, #bb7f4a 0 22%, #a34d2d 22% 50%, #7f3422 50% 70%, transparent 70%); }
.menu-photo-alt { background: radial-gradient(circle at 40% 46%, #fafaf8 0 30%, #d7dce1 30% 33%, #efefef 33% 100%), radial-gradient(circle at 50% 52%, #8fa455 0 20%, #b88945 20% 38%, #a54e2d 38% 62%, transparent 62%); }
.menu-kicker { font-size: 15px; letter-spacing: 0.18em; margin: 0 0 8px; }
.menu-title { margin: 0; font-size: 30px; line-height: 1.6; letter-spacing: 0.16em; font-weight: 500; }
.menu-title::after { content: ""; display: block; height: 1px; width: 100%; background: #111; margin: 24px 0; }
.menu-list-section { background: #fafafa; }
.list-nav { border-top: 1px solid #111; }
.list-row { height: 72px; border-bottom: 1px solid #111; display: flex; align-items: center; justify-content: center; font-size: 18px; letter-spacing: 0.14em; position: relative; }
.list-row::after { content: ">"; position: absolute; right: 20px; }
.contact-section { background: #eef4d8; padding: 80px 28px; text-align: center; }
.contact-store { margin: 0 0 8px; font-size: 14px; }
.contact-title { margin: 0 0 32px; font-size: 28px; letter-spacing: 0.18em; }
.contact-text { text-align: left; }
.contact-phone { display: inline-block; margin: 36px 0 12px; font-size: 32px; letter-spacing: 0.08em; }
.contact-meta { margin: 0; }
.access-section { padding: 0 0 72px; }
.map-placeholder { height: 300px; background: #e8e8e8; display: flex; align-items: center; justify-content: center; border-top: 1px solid #ddd; border-bottom: 1px solid #ddd; }
.access-info { padding: 34px 24px 0; text-align: left; }
.footer { background: #fff; text-align: center; padding-bottom: 120px; }
.footer-nav { border-top: 1px solid #111; }
.footer-nav a { display: flex; align-items: center; justify-content: center; height: 64px; border-bottom: 1px solid #111; letter-spacing: 0.14em; font-size: 16px; }
.copyright { margin-top: 36px; font-size: 13px; line-height: 1.8; }
@media (min-width: 900px) {
  .global-nav { max-height: none; display: flex; border-bottom: 1px solid #111; }
  .global-nav a { flex: 1; text-align: center; border-bottom: none; border-right: 1px solid #111; }
  .global-nav a:last-child { border-right: none; }
  .hero-links { max-width: 620px; }
  .menu-feature, .section-news, .menu-list-section, .footer, .contact-section { padding-left: 10%; padding-right: 10%; }
}

.menu-categories-section { padding: 72px 24px; background: #fff; }
.menu-intro { margin: 0 auto 36px; max-width: 860px; font-size: 15px; color: #444; text-align: center; }
.menu-category-grid { display: grid; gap: 28px; }
.menu-tile { position: relative; min-height: 620px; background-color: #24201b; background-image: linear-gradient(rgba(0,0,0,.32), rgba(0,0,0,.78)), var(--tile-image); background-size: cover; background-position: center; border: 1px solid rgba(255,255,255,.35); box-shadow: inset 0 0 0 1px rgba(255,255,255,.2); }
.menu-tile::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(9,9,9,.18) 8%, rgba(14,13,11,.64) 58%, rgba(12,12,12,.86) 100%); }
.menu-tile-inner { position: relative; z-index: 1; color: #fff; padding: 56px 28px 24px; height: 100%; display: flex; flex-direction: column; }
.menu-tile-heading { text-align: center; margin: 0 0 26px; }
.menu-tile-en { margin: 0; font-size: clamp(44px, 8vw, 66px); letter-spacing: .12em; line-height: 1.12; }
.menu-tile-ja { margin: 8px 0 0; font-size: 24px; letter-spacing: .2em; }
.menu-tile-copy { margin: 0 0 20px; font-size: 15px; line-height: 2; }
.menu-tile ul { margin: 0 0 24px; padding-left: 20px; font-size: 15px; line-height: 1.95; }
.tile-button { margin-top: auto; align-self: center; width: min(420px, 100%); text-align: center; border: 1px solid rgba(255,255,255,.85); padding: 12px 18px; font-size: 14px; letter-spacing: .16em; }
.tile-button::after { content: ' >'; }
.menu-note { margin: 28px 0 0; text-align: center; font-size: 12px; color: #666; }
@media (min-width: 900px){
  .menu-category-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .menu-tile { min-height: 640px; }
  .menu-tile:last-child { grid-column: 1 / -1; max-width: calc(50% - 14px); }
}
