/* Shared final header alignment across top and lower pages. */
body.home-body .header-menu-mark,
body.home-body .floating-header-menu,
body.column-body .header-menu-mark {
  display: none !important;
  content: none !important;
}

body.home-body .site-header,
body.subpage-body .site-header,
body.reserve-body .site-header,
body.column-body .site-header,
body.menu-body .site-header {
  height: 72px !important;
  min-height: 72px !important;
  opacity: 1 !important;
  animation: none !important;
  transform: none !important;
}

body.home-body .nav-wrap,
body.subpage-body .nav-wrap,
body.reserve-body .nav-wrap,
body.column-body .nav-wrap,
body.menu-body .nav-wrap {
  position: relative !important;
  width: 100% !important;
  max-width: none !important;
  min-height: 72px !important;
  margin: 0 !important;
}

body.home-body .menu-toggle,
body.subpage-body .menu-toggle,
body.reserve-body .menu-toggle,
body.column-body .menu-toggle,
body.menu-body .menu-toggle {
  display: flex !important;
  position: absolute !important;
  top: 25px !important;
  right: 19px !important;
  z-index: 120 !important;
  width: 22px !important;
  height: 16px !important;
  min-width: 22px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  opacity: 1 !important;
  transform: none !important;
  align-items: stretch !important;
  justify-content: space-between !important;
  gap: 0 !important;
}

body.home-body .menu-toggle span,
body.subpage-body .menu-toggle span,
body.reserve-body .menu-toggle span,
body.column-body .menu-toggle span,
body.menu-body .menu-toggle span {
  display: block !important;
  width: 22px !important;
  height: 1px !important;
  min-height: 1px !important;
  margin: 0 !important;
  background: #ad8147 !important;
  border-radius: 0 !important;
}

body.home-body .header-micro {
  right: 52px !important;
  top: 30px !important;
}

body.column-body .site-nav,
body.menu-body .site-nav,
body.reserve-body .site-nav,
body.subpage-body .site-nav,
body.home-body .site-nav {
  right: 18px !important;
  top: 58px !important;
}

@media (max-width: 374px) {
  body.home-body .menu-toggle,
  body.subpage-body .menu-toggle,
  body.reserve-body .menu-toggle,
  body.column-body .menu-toggle,
  body.menu-body .menu-toggle {
    right: 16px !important;
  }

  body.home-body .header-micro {
    right: 48px !important;
  }
}

/* TOP header reset: keep the header on the page shell and remove haze/blur layers. */
body.home-body .site-header {
  position: absolute !important;
  top: 0 !important;
  right: auto !important;
  bottom: auto !important;
  left: 0 !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  filter: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  transform: none !important;
}

body.home-body .site-header::before,
body.home-body .site-header::after,
body.home-body .nav-wrap::before,
body.home-body .nav-wrap::after,
body.home-body .floating-header-micro,
body.home-body .floating-header-menu,
body.home-body .header-menu-mark {
  display: none !important;
  content: none !important;
}

body.home-body .nav-wrap {
  position: relative !important;
  width: 100% !important;
  min-height: 72px !important;
  padding: 12px 46px 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  filter: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  transform: none !important;
}

body.home-body .brand {
  position: absolute !important;
  left: 24px !important;
  top: 13px !important;
  z-index: 130 !important;
  display: block !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  transform: none !important;
}

body.home-body .brand-copy-script {
  display: block !important;
  width: max-content !important;
  transform: none !important;
}

body.home-body .brand-copy-script strong {
  display: block !important;
  font-size: 2.42rem !important;
  line-height: 0.72 !important;
}

body.home-body .brand-copy-script small {
  display: block !important;
  margin-top: -7px !important;
  padding-left: 43px !important;
  line-height: 1 !important;
}

body.home-body .header-micro {
  display: block !important;
  position: absolute !important;
  top: 31px !important;
  right: 52px !important;
  z-index: 130 !important;
  background: transparent !important;
}

/* Right-side boutique menu drawer. */
body.home-body .site-nav,
body.subpage-body .site-nav,
body.reserve-body .site-nav,
body.column-body .site-nav,
body.menu-body .site-nav,
body.legal-body .site-nav {
  position: absolute !important;
  top: 56px !important;
  right: 18px !important;
  left: auto !important;
  z-index: 118 !important;
  display: flex !important;
  width: 184px !important;
  max-width: calc(100vw - 42px) !important;
  padding: 12px 16px 14px !important;
  flex-direction: column !important;
  gap: 0 !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  color: #302b26 !important;
  background: rgba(251, 248, 242, 0.985) !important;
  border: 1px solid rgba(176, 131, 77, 0.26) !important;
  border-radius: 0 !important;
  box-shadow: 0 22px 42px rgba(61, 49, 35, 0.13) !important;
  filter: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  transform: translate3d(0, -4px, 0) !important;
  transition: opacity 180ms ease, transform 180ms ease, visibility 180ms ease !important;
}

body.home-body .site-nav.is-open,
body.subpage-body .site-nav.is-open,
body.reserve-body .site-nav.is-open,
body.column-body .site-nav.is-open,
body.menu-body .site-nav.is-open,
body.legal-body .site-nav.is-open {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translate3d(0, 0, 0) !important;
}

body.home-body .site-nav a,
body.subpage-body .site-nav a,
body.reserve-body .site-nav a,
body.column-body .site-nav a,
body.menu-body .site-nav a,
body.legal-body .site-nav a,
body.home-body .site-nav .nav-cta,
body.subpage-body .site-nav .nav-cta,
body.reserve-body .site-nav .nav-cta,
body.column-body .site-nav .nav-cta,
body.menu-body .site-nav .nav-cta,
body.legal-body .site-nav .nav-cta {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 24px !important;
  align-items: center !important;
  min-height: 34px !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #2f2a25 !important;
  font-family: "Cormorant Garamond", "Times New Roman", serif !important;
  font-size: 0.92rem !important;
  font-style: italic !important;
  font-weight: 500 !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  text-align: right !important;
  text-decoration: none !important;
  background: transparent !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(176, 131, 77, 0.2) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

body.home-body .site-nav a::after,
body.subpage-body .site-nav a::after,
body.reserve-body .site-nav a::after,
body.column-body .site-nav a::after,
body.menu-body .site-nav a::after,
body.legal-body .site-nav a::after {
  content: "" !important;
  display: block !important;
  width: 21px !important;
  height: 1px !important;
  justify-self: end !important;
  background: rgba(176, 131, 77, 0.62) !important;
}

body.home-body .site-nav a:last-child,
body.subpage-body .site-nav a:last-child,
body.reserve-body .site-nav a:last-child,
body.column-body .site-nav a:last-child,
body.menu-body .site-nav a:last-child,
body.legal-body .site-nav a:last-child {
  border-bottom: 0 !important;
  color: #69745f !important;
}

body.home-body .menu-toggle span,
body.subpage-body .menu-toggle span,
body.reserve-body .menu-toggle span,
body.column-body .menu-toggle span,
body.menu-body .menu-toggle span,
body.legal-body .menu-toggle span {
  transform-origin: center !important;
  transition: transform 180ms ease !important;
}

body.home-body .menu-toggle[aria-expanded="true"] span:first-child,
body.subpage-body .menu-toggle[aria-expanded="true"] span:first-child,
body.reserve-body .menu-toggle[aria-expanded="true"] span:first-child,
body.column-body .menu-toggle[aria-expanded="true"] span:first-child,
body.menu-body .menu-toggle[aria-expanded="true"] span:first-child,
body.legal-body .menu-toggle[aria-expanded="true"] span:first-child {
  transform: translateY(7px) rotate(18deg) !important;
}

body.home-body .menu-toggle[aria-expanded="true"] span:last-child,
body.subpage-body .menu-toggle[aria-expanded="true"] span:last-child,
body.reserve-body .menu-toggle[aria-expanded="true"] span:last-child,
body.column-body .menu-toggle[aria-expanded="true"] span:last-child,
body.menu-body .menu-toggle[aria-expanded="true"] span:last-child,
body.legal-body .menu-toggle[aria-expanded="true"] span:last-child {
  transform: translateY(-7px) rotate(-18deg) !important;
}

@media (max-width: 374px) {
  body.home-body .site-nav,
  body.subpage-body .site-nav,
  body.reserve-body .site-nav,
  body.column-body .site-nav,
  body.menu-body .site-nav,
  body.legal-body .site-nav {
    right: 14px !important;
    width: 176px !important;
  }
}

/* Drawer CTA uses Japanese copy, so align it with the site typography. */
body.home-body .site-nav .nav-cta,
body.subpage-body .site-nav .nav-cta,
body.reserve-body .site-nav .nav-cta,
body.column-body .site-nav .nav-cta,
body.menu-body .site-nav .nav-cta,
body.legal-body .site-nav .nav-cta {
  font-family: "Hiragino Mincho ProN", "Yu Mincho", YuMincho, "Noto Serif JP", serif !important;
  font-size: 0.72rem !important;
  font-style: normal !important;
  font-weight: 500 !important;
  line-height: 1 !important;
}

/* Raster logo alignment: use the shared transparent PNG across every page. */
body.home-body .brand,
body.subpage-body .brand,
body.reserve-body .brand,
body.column-body .brand,
body.menu-body .brand,
body.legal-body .brand {
  position: absolute !important;
  left: 24px !important;
  top: 14px !important;
  z-index: 130 !important;
  display: block !important;
  width: 112px !important;
  height: 52px !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  transform: none !important;
  text-decoration: none !important;
}

body.home-body .brand-logo-img,
body.subpage-body .brand-logo-img,
body.reserve-body .brand-logo-img,
body.column-body .brand-logo-img,
body.menu-body .brand-logo-img,
body.legal-body .brand-logo-img {
  display: block !important;
  width: 112px !important;
  height: auto !important;
  max-width: none !important;
  filter: saturate(0.92) brightness(1.02) contrast(0.94) !important;
}

body.column-body .brand,
body.faq-body .brand,
body.access-body .brand,
body.reserve-body .brand,
body.menu-body .brand,
body.legal-body .brand {
  left: 24px !important;
  top: 13px !important;
}

body.home-body .header-micro,
body.access-body .access-nav-note {
  top: 31px !important;
  right: 54px !important;
}

body.home-body .menu-toggle,
body.subpage-body .menu-toggle,
body.reserve-body .menu-toggle,
body.column-body .menu-toggle,
body.menu-body .menu-toggle,
body.legal-body .menu-toggle {
  top: 26px !important;
  right: 19px !important;
}
