@charset "UTF-8";

:root {
  --ink: #171411;
  --ink-soft: #29231e;
  --paper: #f1eadc;
  --paper-deep: #e2d7c4;
  --red: #a52e1d;
  --ember: #d75a2a;
  --gold: #bd9460;
  --line: rgba(23, 20, 17, .22);
  --max: 1180px;
  --serif: "Yu Mincho", "Hiragino Mincho ProN", "Noto Serif JP", serif;
  --sans: "Helvetica Neue", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  line-height: 1.85;
  letter-spacing: .04em;
  -webkit-font-smoothing: antialiased;
}
body.menu-open { overflow: hidden; }
a { color: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
.skip-link { position: fixed; z-index: 999; left: 12px; top: -100px; padding: 10px 16px; background: #fff; color: #000; }
.skip-link:focus { top: 12px; }
.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; }

.site-header {
  position: fixed;
  z-index: 100;
  top: 0;
  left: 0;
  right: 0;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 28px;
  min-height: 76px;
  padding: 10px clamp(18px, 4vw, 64px);
  color: var(--paper);
  border-bottom: 1px solid rgba(241, 234, 220, .17);
  transition: background .25s, min-height .25s;
}
.site-header.scrolled { min-height: 64px; background: rgba(23, 20, 17, .96); backdrop-filter: blur(12px); }
.brand { display: inline-flex; align-items: baseline; gap: 9px; text-decoration: none; white-space: nowrap; }
.brand span { font-family: var(--serif); font-size: 12px; letter-spacing: .12em; }
.brand strong { font-family: var(--serif); font-size: 38px; line-height: 1; font-weight: 600; }
.desktop-nav { justify-self: center; display: flex; gap: clamp(20px, 3vw, 46px); }
.desktop-nav a { position: relative; font-size: 12px; text-decoration: none; }
.desktop-nav a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -7px; height: 1px; background: var(--paper); transition: right .2s; }
.desktop-nav a:hover::after, .desktop-nav a:focus-visible::after { right: 0; }
.header-call { padding: 10px 16px; border: 1px solid rgba(241, 234, 220, .55); text-decoration: none; font-size: 11px; }
.header-call span { margin-left: 8px; font-size: 13px; letter-spacing: .08em; }
.menu-button { display: none; }

.hero {
  position: relative;
  min-height: min(880px, 100svh);
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(330px, .95fr);
  align-items: center;
  gap: 40px;
  padding: 130px max(5vw, calc((100vw - var(--max)) / 2)) 80px;
  overflow: hidden;
  color: var(--paper);
  background:
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px) 0 0 / 70px 70px,
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px) 0 0 / 70px 70px,
    var(--ink);
}
.hero::before { content: ""; position: absolute; width: 500px; height: 500px; left: -280px; top: 150px; border: 1px solid rgba(241,234,220,.16); border-radius: 50%; }
.hero-copy { position: relative; z-index: 2; }
.eyebrow { margin: 0 0 24px; font-size: 10px; font-weight: 700; letter-spacing: .25em; text-transform: uppercase; }
.eyebrow::before { content: ""; display: inline-block; width: 42px; height: 1px; margin-right: 14px; vertical-align: middle; background: currentColor; }
.hero h1 { margin: 0; font-family: var(--serif); font-size: clamp(44px, 6.1vw, 84px); line-height: 1.25; font-weight: 500; letter-spacing: .08em; }
.hero h1 span { color: var(--gold); }
.hero-lead { margin: 30px 0 0; font-family: var(--serif); font-size: 16px; line-height: 2; letter-spacing: .12em; }
.hero-actions { display: flex; align-items: center; gap: 30px; margin-top: 42px; }
.button { display: inline-flex; min-height: 52px; align-items: center; justify-content: center; padding: 13px 28px; border: 1px solid var(--red); background: var(--red); color: #fff; text-decoration: none; font-size: 13px; transition: transform .2s, background .2s; }
.button:hover, .button:focus-visible { transform: translateY(-2px); background: #8c2316; }
.text-link { font-size: 12px; text-underline-offset: 6px; }
.text-link span { margin-left: 8px; }
.hero-art { position: relative; min-height: 560px; display: grid; place-items: center; }
.hero-art::before, .hero-art::after { content: ""; position: absolute; border-radius: 50%; border: 1px solid rgba(241, 234, 220, .18); }
.hero-art::before { width: min(36vw, 480px); aspect-ratio: 1; }
.hero-art::after { width: min(29vw, 380px); aspect-ratio: 1; border-color: rgba(189, 148, 96, .35); }
.hero-art > p { position: relative; z-index: 2; margin: 0; font-family: Georgia, serif; font-size: clamp(90px, 14vw, 190px); line-height: 1; letter-spacing: -.04em; color: rgba(241,234,220,.04); writing-mode: vertical-rl; }
.sun { position: absolute; z-index: 1; width: 220px; height: 220px; border-radius: 50%; background: radial-gradient(circle at 45% 40%, #d75a2a, #932313 67%, transparent 68%); opacity: .8; filter: blur(.2px); }
.skewer { position: absolute; z-index: 3; display: flex; flex-direction: column; gap: 5px; align-items: center; transform-origin: center; }
.skewer::after { content: ""; width: 3px; height: 150px; background: linear-gradient(var(--paper-deep), #826d50); }
.skewer i { width: 38px; height: 48px; border-radius: 44% 52% 38% 55%; background: linear-gradient(135deg, #7a2b19, #d06c34 48%, #552016); box-shadow: inset 5px 4px rgba(255,255,255,.08); }
.skewer-one { left: 30%; top: 14%; transform: rotate(-18deg); }
.skewer-two { right: 25%; bottom: 5%; transform: rotate(18deg); }
.smoke { position: absolute; z-index: 2; width: 90px; height: 240px; border: 2px solid rgba(241,234,220,.18); border-color: rgba(241,234,220,.18) transparent transparent rgba(241,234,220,.18); border-radius: 50%; filter: blur(2px); }
.smoke-one { top: 20px; right: 25%; transform: rotate(22deg); }
.smoke-two { top: 90px; left: 22%; transform: rotate(-28deg); }
.hero-side { position: absolute; z-index: 4; right: 18px; bottom: 70px; margin: 0; writing-mode: vertical-rl; font-size: 9px; letter-spacing: .2em; color: rgba(241,234,220,.7); }

.ticker { overflow: hidden; padding: 13px 0; color: var(--paper); background: var(--red); white-space: nowrap; }
.ticker div { display: inline-flex; gap: 28px; align-items: center; min-width: 200%; animation: ticker 25s linear infinite; }
.ticker span { font-family: var(--serif); font-size: 13px; letter-spacing: .16em; }
.ticker i { font-style: normal; font-size: 7px; }
@keyframes ticker { to { transform: translateX(-50%); } }

.section { width: min(100%, var(--max)); margin: 0 auto; padding: clamp(90px, 11vw, 150px) clamp(20px, 4vw, 60px); }
.section-heading { max-width: 660px; }
.section-heading h2 { margin: 0; font-family: var(--serif); font-size: clamp(34px, 5vw, 60px); line-height: 1.45; font-weight: 500; letter-spacing: .08em; }
.section-heading > p:last-child:not(.eyebrow) { max-width: 560px; margin: 25px 0 0; font-size: 13px; }
.about { display: grid; grid-template-columns: .9fr 1.1fr; column-gap: 9%; }
.about-copy { padding-top: 54px; }
.about-copy p { margin: 0 0 22px; font-size: 13px; }
.about-copy .large-copy { font-family: var(--serif); font-size: clamp(17px, 2vw, 22px); line-height: 2.1; }
.about-numbers { grid-column: 1 / -1; display: grid; grid-template-columns: repeat(3, 1fr); margin-top: 90px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.about-numbers div { display: flex; align-items: flex-end; gap: 18px; padding: 28px 7%; border-right: 1px solid var(--line); }
.about-numbers div:last-child { border-right: 0; }
.about-numbers strong { font: 400 clamp(46px, 6vw, 76px)/1 Georgia, serif; color: var(--red); }
.about-numbers span { padding-bottom: 6px; font-size: 8px; line-height: 1.5; letter-spacing: .14em; }

.dark-section { position: relative; width: 100%; max-width: none; padding-left: max(20px, calc((100vw - var(--max)) / 2 + 60px)); padding-right: max(20px, calc((100vw - var(--max)) / 2 + 60px)); color: var(--paper); background: var(--ink); }
.menu { display: grid; grid-template-columns: .75fr 1.25fr; gap: 8%; }
.menu-list { border-top: 1px solid rgba(241,234,220,.25); }
.menu-list article { display: grid; grid-template-columns: 50px 1fr 1fr; align-items: center; gap: 20px; padding: 28px 0; border-bottom: 1px solid rgba(241,234,220,.25); }
.menu-list article > span { color: var(--gold); font: italic 18px Georgia, serif; }
.menu-list h3 { margin: 0; font: 500 25px var(--serif); letter-spacing: .12em; }
.menu-list div p { margin: 4px 0 0; font: italic 11px Georgia, serif; color: var(--gold); }
.menu-list article > p { margin: 0; font-size: 12px; color: rgba(241,234,220,.7); }
.menu-note { grid-column: 2; display: grid; grid-template-columns: 130px 1fr; gap: 24px; margin-top: 15px; padding: 22px 0; }
.menu-note span { font-size: 11px; color: var(--gold); }
.menu-note p { margin: 0; font-size: 10px; color: rgba(241,234,220,.6); }

.gallery-grid { display: grid; grid-template-columns: 1.4fr .8fr .8fr; gap: 14px; margin-top: 60px; }
.scene-card { position: relative; min-height: 430px; display: flex; align-items: center; justify-content: center; overflow: hidden; color: var(--paper); background: var(--ink-soft); }
.scene-card::before { content: ""; position: absolute; inset: 0; opacity: .8; }
.scene-card span { position: relative; z-index: 2; font: 500 clamp(80px, 12vw, 160px)/1 var(--serif); color: rgba(241,234,220,.86); text-shadow: 8px 10px 0 rgba(0,0,0,.18); }
.scene-card p { position: absolute; z-index: 2; left: 16px; bottom: 10px; font-size: 9px; letter-spacing: .24em; }
.scene-fire::before { background: radial-gradient(circle at 65% 55%, #e57630 0 2%, transparent 3%), radial-gradient(circle at 40% 70%, #d5411e, transparent 32%), linear-gradient(140deg, #191512, #3c1a11); }
.scene-counter::before { background: repeating-linear-gradient(90deg, transparent 0 29px, rgba(255,255,255,.03) 30px), linear-gradient(130deg, #49372b, #171411); }
.scene-night::before { background: radial-gradient(circle at 35% 25%, rgba(189,148,96,.45), transparent 4%), linear-gradient(155deg, #0c1116, #2b2420); }
.gallery-action { display: flex; align-items: center; justify-content: space-between; gap: 30px; margin-top: 28px; }
.gallery-action p { max-width: 520px; margin: 0; font-size: 12px; }
.button-outline { background: transparent; color: var(--ink); border-color: var(--ink); }
.button-outline:hover, .button-outline:focus-visible { color: var(--paper); background: var(--ink); }

.news { display: grid; grid-template-columns: .6fr 1.4fr; gap: 8%; padding-top: 50px; border-top: 1px solid var(--line); }
.news-card { display: grid; grid-template-columns: 110px 1fr 40px; align-items: start; gap: 22px; padding: 8px 0 28px; border-bottom: 1px solid var(--line); }
.news-card time { font: italic 13px Georgia, serif; color: var(--red); }
.news-card h3 { margin: 0 0 8px; font: 500 16px var(--serif); }
.news-card p { margin: 0; font-size: 11px; }
.news-card > a { display: grid; place-items: center; width: 40px; height: 40px; border: 1px solid var(--line); text-decoration: none; }

.access-layout { display: grid; grid-template-columns: 1.15fr .85fr; gap: 7%; margin-top: 60px; }
.map-card { position: relative; min-height: 470px; display: flex; flex-direction: column; justify-content: flex-end; align-items: flex-start; padding: 35px; overflow: hidden; background: #d9cebc; color: var(--ink); }
.map-lines { position: absolute; inset: -10%; transform: rotate(-8deg); background: repeating-linear-gradient(24deg, transparent 0 45px, rgba(23,20,17,.09) 46px 49px), repeating-linear-gradient(96deg, transparent 0 75px, rgba(23,20,17,.1) 76px 80px); }
.map-lines::after { content: ""; position: absolute; left: 38%; top: -10%; width: 20px; height: 130%; background: rgba(165,46,29,.22); transform: rotate(17deg); }
.map-pin { position: absolute; z-index: 2; left: 48%; top: 36%; width: 74px; height: 74px; display: grid; place-items: center; border-radius: 50% 50% 50% 0; transform: rotate(-45deg); color: #fff; background: var(--red); box-shadow: 0 12px 30px rgba(0,0,0,.22); }
.map-pin strong, .map-pin span { grid-area: 1/1; transform: rotate(45deg); }
.map-pin strong { font: 500 30px var(--serif); }
.map-pin span { margin-top: 46px; font-size: 8px; }
.map-card p, .map-card a { position: relative; z-index: 2; }
.map-card p { margin: 0 0 15px; font-size: 12px; font-weight: 700; }
.button-light { color: var(--ink); background: var(--paper); border-color: var(--paper); }
.button-light:hover, .button-light:focus-visible { color: #fff; background: var(--red); border-color: var(--red); }
.shop-info { margin: 0; }
.shop-info > div { display: grid; grid-template-columns: 100px 1fr; gap: 20px; padding: 19px 0; border-bottom: 1px solid rgba(241,234,220,.22); }
.shop-info dt { font-size: 10px; color: var(--gold); }
.shop-info dd { margin: 0; font-size: 13px; }
.shop-info a { text-underline-offset: 5px; }
.access-caution { max-width: var(--max); margin: 28px auto 0; font-size: 9px; color: rgba(241,234,220,.55); }

.reservation { text-align: center; }
.reservation .eyebrow::before { display: none; }
.reservation h2 { margin: 0; font: 500 clamp(38px, 6vw, 65px) var(--serif); }
.reservation > p:not(.eyebrow):not(.small) { margin: 18px 0; font-size: 13px; }
.call-large { display: inline-flex; align-items: center; gap: 18px; margin: 15px 0; font: 400 clamp(27px, 4vw, 48px) Georgia, serif; text-decoration: none; letter-spacing: .04em; border-bottom: 1px solid var(--ink); }
.call-large span { padding: 6px 9px; color: #fff; background: var(--red); font: 700 9px var(--sans); letter-spacing: .15em; }
.reservation .small { font-size: 9px; color: rgba(23,20,17,.65); }

.site-footer { display: grid; grid-template-columns: 1fr auto; gap: 50px; align-items: end; padding: 60px max(20px, calc((100vw - var(--max)) / 2)); color: var(--paper); background: var(--ink); }
.footer-brand { display: grid; grid-template-columns: auto auto 1fr; align-items: baseline; gap: 9px; }
.footer-brand span { font: 12px var(--serif); }
.footer-brand strong { font: 500 52px/1 var(--serif); }
.footer-brand p { margin: 0 0 5px 12px; font-size: 8px; letter-spacing: .2em; color: var(--gold); }
.footer-links { display: flex; gap: 25px; }
.footer-links a { font-size: 10px; text-underline-offset: 5px; }
.copyright { grid-column: 1 / -1; margin: 22px 0 0; padding-top: 22px; border-top: 1px solid rgba(241,234,220,.2); font-size: 9px; color: rgba(241,234,220,.55); }
.mobile-call { display: none; }

@media (max-width: 900px) {
  .desktop-nav, .header-call { display: none; }
  .site-header { grid-template-columns: 1fr auto; min-height: 68px; padding: 9px 18px; }
  .brand strong { font-size: 34px; }
  .menu-button { display: grid; place-content: center; gap: 7px; width: 48px; height: 48px; padding: 0; border: 0; color: var(--paper); background: transparent; cursor: pointer; }
  .menu-button i { display: block; width: 26px; height: 1px; background: currentColor; transition: transform .25s; }
  .menu-button[aria-expanded="true"] i:first-of-type { transform: translateY(4px) rotate(45deg); }
  .menu-button[aria-expanded="true"] i:last-of-type { transform: translateY(-4px) rotate(-45deg); }
  .mobile-menu { position: fixed; z-index: -1; inset: 0; display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 32px; padding: 90px 25px 40px; color: var(--paper); background: rgba(23,20,17,.985); }
  .mobile-menu[hidden] { display: none; }
  .mobile-menu nav { display: grid; gap: 16px; width: min(100%, 360px); }
  .mobile-menu nav a { min-height: 48px; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid rgba(241,234,220,.2); font: 500 24px var(--serif); text-decoration: none; }
  .mobile-menu nav a::after { content: "↘"; font: 13px var(--sans); color: var(--gold); }
  .instagram-link { font-size: 11px; }
  .hero { min-height: 850px; grid-template-columns: 1fr; padding: 120px 22px 80px; }
  .hero-copy { align-self: start; }
  .hero-art { position: absolute; width: 70%; height: 52%; right: -8%; bottom: 3%; min-height: 0; opacity: .86; }
  .hero-art::before { width: 360px; }
  .hero-art::after { width: 290px; }
  .hero-side { display: none; }
  .about, .menu, .news { grid-template-columns: 1fr; }
  .about-copy { padding-top: 35px; }
  .menu-list { margin-top: 55px; }
  .menu-note { grid-column: 1; }
  .gallery-grid { grid-template-columns: 1.2fr .8fr; }
  .scene-card { min-height: 360px; }
  .scene-night { grid-column: 1 / -1; min-height: 220px; }
  .news { gap: 35px; }
  .access-layout { grid-template-columns: 1fr; }
}

@media (max-width: 620px) {
  body { padding-bottom: 66px; }
  .hero { min-height: 760px; padding-top: 110px; }
  .hero h1 { font-size: clamp(39px, 12vw, 57px); }
  .hero-lead { font-size: 14px; }
  .hero-actions { align-items: flex-start; flex-direction: column; gap: 18px; margin-top: 32px; }
  .hero-art { width: 88%; height: 48%; right: -25%; bottom: 0; }
  .sun { width: 170px; height: 170px; }
  .skewer i { width: 29px; height: 38px; }
  .skewer::after { height: 110px; }
  .ticker div { gap: 19px; }
  .section { padding: 82px 20px; }
  .section-heading h2 { font-size: 34px; }
  .about-numbers { grid-template-columns: 1fr; margin-top: 55px; }
  .about-numbers div { border-right: 0; border-bottom: 1px solid var(--line); }
  .about-numbers div:last-child { border-bottom: 0; }
  .menu-list article { grid-template-columns: 32px 1fr; gap: 14px; }
  .menu-list article > p { grid-column: 2; }
  .menu-note { grid-template-columns: 1fr; gap: 8px; }
  .gallery-grid { grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 38px; }
  .scene-card { min-height: 280px; }
  .scene-fire { grid-column: 1 / -1; min-height: 360px; }
  .scene-night { grid-column: auto; min-height: 280px; }
  .gallery-action { align-items: stretch; flex-direction: column; }
  .news-card { grid-template-columns: 1fr 40px; }
  .news-card time { grid-column: 1 / -1; }
  .map-card { min-height: 400px; padding: 24px; }
  .shop-info > div { grid-template-columns: 78px 1fr; }
  .call-large { gap: 8px; font-size: 28px; }
  .site-footer { grid-template-columns: 1fr; gap: 35px; padding-bottom: 50px; }
  .footer-links { flex-direction: column; gap: 12px; }
  .copyright { grid-column: 1; }
  .mobile-call { position: fixed; z-index: 90; left: 0; right: 0; bottom: 0; display: block; padding: 8px 12px; background: var(--red); }
  .mobile-call a { min-height: 50px; display: flex; align-items: center; justify-content: center; gap: 13px; color: #fff; text-decoration: none; }
  .mobile-call span { font-size: 10px; }
  .mobile-call strong { font: 400 19px Georgia, serif; letter-spacing: .08em; }
}

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