:root {
  --red: #9f261f;
  --red-bright: #c52b21;
  --ink: #1c1815;
  --paper: #f2ede3;
  --sand: #d9cdb9;
  --white: #fffaf2;
  --line: rgba(28, 24, 21, 0.2);
  --serif: "Yu Mincho", "Hiragino Mincho ProN", "Noto Serif JP", serif;
  --sans: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: var(--sans); line-height: 1.9; }
img { display: block; width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link { position: fixed; z-index: 100; top: 8px; left: 8px; padding: 8px 14px; background: #fff; transform: translateY(-150%); }
.skip-link:focus { transform: translateY(0); }

.site-header { position: fixed; z-index: 20; inset: 0 0 auto; height: 84px; display: flex; align-items: center; justify-content: space-between; padding: 0 clamp(20px, 4vw, 64px); color: #fff; transition: background .3s, color .3s, height .3s; }
.site-header.scrolled { height: 68px; color: var(--ink); background: rgba(242,237,227,.94); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
.brand { display: flex; align-items: center; gap: 10px; }
.brand-mark { display: grid; place-items: center; width: 42px; height: 42px; font-family: var(--serif); font-size: 28px; line-height: 1; border: 1px solid currentColor; border-radius: 50%; }
.brand-name { font-family: var(--serif); font-size: 20px; letter-spacing: .18em; line-height: 1.1; }
.brand-name small { display: block; margin-top: 5px; font-family: var(--sans); font-size: 7px; letter-spacing: .38em; }
.global-nav { display: flex; align-items: center; gap: clamp(16px, 2.2vw, 34px); font-size: 11px; letter-spacing: .12em; }
.global-nav a { padding-block: 8px; }
.nav-reserve { padding: 10px 24px !important; color: #fff; background: var(--red); border: 1px solid var(--red); }
.menu-toggle { display: none; width: 44px; height: 44px; padding: 12px 8px; color: inherit; background: none; border: 0; }
.menu-toggle > span:not(.sr-only) { display: block; width: 100%; height: 1px; margin: 6px 0; background: currentColor; transition: transform .3s, opacity .3s; }

.hero { position: relative; min-height: 100svh; overflow: hidden; color: #fff; background: #24170f; }
.hero > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(15,8,4,.74) 0%, rgba(15,8,4,.3) 47%, rgba(15,8,4,.12) 100%), linear-gradient(0deg, rgba(0,0,0,.34), transparent 45%); }
.hero-copy { position: absolute; left: clamp(24px, 10vw, 150px); top: 50%; transform: translateY(-44%); }
.eyebrow, .section-kicker { margin: 0 0 20px; font-size: 10px; letter-spacing: .34em; font-weight: 600; }
.hero h1 { margin: 0; font-family: var(--serif); font-weight: 500; font-size: clamp(45px, 6.3vw, 94px); line-height: 1.32; letter-spacing: .09em; }
.hero h1 span { display: block; }
.hero-copy > p:last-child { margin-top: 28px; font-family: var(--serif); font-size: clamp(15px, 1.4vw, 19px); letter-spacing: .15em; }
.scroll-cue { position: absolute; right: clamp(20px, 4vw, 65px); bottom: 42px; display: flex; align-items: center; gap: 16px; font-size: 8px; letter-spacing: .28em; writing-mode: vertical-rl; }
.scroll-cue span { display: block; width: 1px; height: 54px; background: rgba(255,255,255,.8); }

.section { position: relative; }
.section-number { position: absolute; top: 90px; left: 5vw; font-family: var(--serif); font-size: 11px; }
.intro { min-height: 900px; display: grid; grid-template-columns: 1fr 1.05fr; align-items: center; gap: 10vw; padding: 130px max(6vw, 32px); }
.intro-copy { max-width: 480px; margin-left: auto; }
.section h2 { margin: 0 0 42px; font-family: var(--serif); font-size: clamp(38px, 5vw, 70px); line-height: 1.5; font-weight: 500; letter-spacing: .08em; }
.intro-copy > p:last-child, .gallery-heading > p:last-child { max-width: 410px; font-family: var(--serif); font-size: 15px; letter-spacing: .08em; }
.intro-image { margin: 0; position: relative; max-width: 610px; }
.intro-image img { aspect-ratio: .82; object-fit: cover; }
figcaption { margin-top: 12px; font-size: 10px; letter-spacing: .16em; color: #655b52; }

.food { display: grid; grid-template-columns: 1.15fr .85fr; min-height: 860px; color: var(--white); background: var(--ink); }
.food-visual { min-height: 620px; }
.food-visual img { width: 100%; height: 100%; object-fit: cover; }
.food-copy { padding: 110px clamp(30px, 6vw, 100px); align-self: center; }
.food-copy h2 { font-size: clamp(40px, 4.6vw, 68px); }
.menu-category { display: grid; grid-template-columns: 42px 1fr; gap: 20px; padding: 24px 0; border-top: 1px solid rgba(255,255,255,.18); }
.menu-category > span { font-size: 9px; color: #b8aa9d; }
.menu-category h3 { margin: -4px 0 5px; font-family: var(--serif); font-size: 22px; letter-spacing: .08em; font-weight: 500; }
.menu-category p { margin: 0; color: #c9beb3; font-size: 12px; line-height: 1.8; }
.menu-note { margin: 24px 0 0; color: #9d9185; font-size: 10px; }

.gallery { display: grid; grid-template-columns: .7fr 1fr; grid-template-rows: auto auto; gap: 60px 8vw; padding: 150px max(6vw, 30px); overflow: hidden; }
.gallery-heading { align-self: center; max-width: 500px; padding-left: 5vw; }
.gallery-main { margin: 0; }
.gallery-main img { aspect-ratio: .82; object-fit: cover; }
.gallery-sub { grid-column: 1 / 2; width: 80%; margin: -90px 0 0; }
.gallery-sub img { aspect-ratio: 1.18; object-fit: cover; }

.news { display: grid; grid-template-columns: .55fr 1fr; gap: 6vw; align-items: end; padding: 100px max(8vw, 30px); border-top: 1px solid var(--line); }
.news h2 { margin: 0; font-size: 44px; }
.news-item { display: grid; grid-template-columns: 130px 1fr; gap: 30px; padding: 28px 0; border-top: 1px solid var(--ink); border-bottom: 1px solid var(--line); }
.news-item time { font-size: 11px; letter-spacing: .12em; }
.news-item p { margin: 0; font-family: var(--serif); letter-spacing: .06em; }

.access { display: grid; grid-template-columns: .88fr 1.12fr; min-height: 850px; background: #ded4c3; }
.access-panel { padding: 110px clamp(30px, 7vw, 110px); align-self: center; }
.access-panel h2 { font-size: clamp(30px, 3vw, 46px); line-height: 1.65; }
.access-panel h2 strong { font-size: 1.45em; font-weight: 500; }
.access-panel dl { margin: 0 0 42px; }
.access-panel dl > div { display: grid; grid-template-columns: 90px 1fr; padding: 15px 0; border-top: 1px solid rgba(28,24,21,.15); }
.access-panel dt { font-size: 10px; letter-spacing: .14em; }
.access-panel dd { margin: 0; font-family: var(--serif); font-size: 13px; }
.text-link { display: inline-flex; gap: 50px; align-items: center; padding: 12px 0; border-bottom: 1px solid; font-size: 12px; }
.access-image { min-height: 600px; }
.access-image img { width: 100%; height: 100%; object-fit: cover; }

.reservation { position: relative; display: grid; place-items: center; min-height: 620px; padding: 80px 24px; color: #fff; text-align: center; background: var(--red); overflow: hidden; }
.reservation::before { content: "炉"; position: absolute; right: -2vw; bottom: -26vw; color: rgba(255,255,255,.045); font-family: var(--serif); font-size: 58vw; line-height: 1; }
.reservation-inner { position: relative; z-index: 1; }
.reservation h2 { margin-bottom: 22px; font-size: clamp(48px, 7vw, 88px); }
.reservation p:not(.section-kicker) { margin-bottom: 42px; font-family: var(--serif); letter-spacing: .08em; }
.reservation-actions { display: flex; justify-content: center; gap: 12px; }
.button { display: inline-flex; align-items: center; justify-content: space-between; min-width: 240px; padding: 18px 24px; border: 1px solid rgba(255,255,255,.7); font-size: 12px; letter-spacing: .1em; }
.button-primary { color: var(--red); background: #fff; border-color: #fff; }

.site-footer { display: grid; grid-template-columns: 1fr auto; gap: 70px; padding: 80px max(6vw, 30px) 35px; color: #e8ded3; background: var(--ink); }
.footer-brand { display: flex; align-items: center; gap: 18px; }
.footer-brand p { margin: 0; font-family: var(--serif); line-height: 1.5; letter-spacing: .08em; }
.footer-brand strong { font-size: 25px; font-weight: 500; }
.footer-links { display: flex; align-items: center; gap: 34px; font-size: 10px; letter-spacing: .12em; }
.copyright { grid-column: 1 / -1; margin: 25px 0 0; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.12); font-size: 9px; color: #a59b92; }
.mobile-reserve { display: none; }

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (max-width: 900px) {
  .site-header { height: 66px; }
  .menu-toggle { display: block; z-index: 2; }
  .menu-toggle[aria-expanded="true"] > span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .menu-toggle[aria-expanded="true"] > span:nth-child(2) { opacity: 0; }
  .menu-toggle[aria-expanded="true"] > span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .global-nav { position: fixed; inset: 0; display: flex; flex-direction: column; justify-content: center; gap: 20px; color: #fff; background: rgba(28,24,21,.98); opacity: 0; visibility: hidden; transition: opacity .3s, visibility .3s; }
  .global-nav.open { opacity: 1; visibility: visible; }
  .global-nav a { font-family: var(--serif); font-size: 18px; }
  .nav-reserve { margin-top: 10px; }
  .hero-copy { left: 8vw; }
  .intro { grid-template-columns: 1fr; min-height: 0; gap: 70px; padding-block: 110px; }
  .intro-copy { margin-left: 7vw; }
  .intro-image { width: 78%; margin-left: auto; }
  .food { grid-template-columns: 1fr; }
  .food-visual { min-height: 56vw; }
  .food-copy { padding-block: 90px; }
  .gallery { grid-template-columns: 1fr; grid-template-rows: auto; }
  .gallery-heading { padding-left: 4vw; }
  .gallery-main { width: 78%; margin-left: auto; }
  .gallery-sub { grid-column: auto; width: 60%; margin: -120px 0 0; }
  .news { grid-template-columns: 1fr; }
  .access { grid-template-columns: 1fr; }
  .access-image { min-height: 70vw; }
  .site-footer { grid-template-columns: 1fr; }
  .footer-links { flex-wrap: wrap; }
}

@media (max-width: 600px) {
  body { padding-bottom: 58px; }
  .brand-mark { width: 36px; height: 36px; font-size: 24px; }
  .brand-name { font-size: 16px; }
  .hero { min-height: 92svh; }
  .hero > img { object-position: 55% center; }
  .hero-copy { top: 48%; }
  .hero h1 { font-size: clamp(39px, 12vw, 58px); }
  .scroll-cue { bottom: 28px; }
  .section-number { display: none; }
  .intro { padding: 90px 22px; gap: 55px; }
  .intro-copy { margin-left: 0; }
  .section h2 { margin-bottom: 30px; font-size: 40px; }
  .intro-image { width: 88%; }
  .food-visual { min-height: 72vw; }
  .food-copy { padding: 75px 24px; }
  .food-copy h2 { font-size: 42px; }
  .gallery { gap: 50px; padding: 95px 22px 120px; }
  .gallery-heading { padding-left: 0; }
  .gallery-main { width: 88%; }
  .gallery-sub { width: 68%; margin-top: -90px; }
  .news { padding: 80px 22px; }
  .news-item { grid-template-columns: 1fr; gap: 8px; }
  .access-panel { padding: 85px 24px; }
  .access-panel dl > div { grid-template-columns: 76px 1fr; }
  .reservation { min-height: 540px; }
  .reservation h2 { font-size: 48px; }
  .reservation-actions { flex-direction: column; }
  .site-footer { padding: 65px 24px 30px; gap: 42px; }
  .footer-links { flex-direction: column; align-items: flex-start; gap: 16px; }
  .mobile-reserve { position: fixed; z-index: 18; inset: auto 0 0; display: grid; grid-template-columns: .8fr 1.2fr; height: 58px; color: #fff; background: var(--ink); box-shadow: 0 -5px 25px rgba(0,0,0,.18); }
  .mobile-reserve a { display: grid; place-items: center; font-size: 12px; letter-spacing: .08em; border-right: 1px solid rgba(255,255,255,.15); }
  .mobile-reserve a:last-child { background: var(--red); border: 0; }
}

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