.Header {
  font-family: 'Shippori Mincho', serif;
  display: flex;
  align-items: center;
  color: #bb4953;
  background-color: #fffdf8;
  font-size: min(0.75rem /* 12px (基準16px) */, 0.833vw /* 12px (基準1440px) */);
  padding-bottom: 0.313rem /* 5px (基準16px) */ 0;
  padding-left: 0.5rem /* 8px (基準16px) */;
  justify-content: space-between;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.5s ease;
}

.Header._visible {
  opacity: 1;
  pointer-events: auto;
}

.s .Header {
  height: 3.563rem /* 57px (基準16px) */;
}

.Header-logo {
  width: min(3.188rem /* 51px (基準16px) */, 3.542vw /* 51px (基準1440px) */);
}

.s .Header-logo {
  width: min(3.188rem /* 51px (基準16px) */, 13.6vw /* 51px (基準375px) */);
}

.Header-logo img {
  width: 100%;
  height: auto;
}

.Header-navList {
  display: flex;
  align-items: center;
  column-gap: min(2.563rem /* 41px (基準16px) */, 2.847vw /* 41px (基準1440px) */);
}

.s .Header-navList {
  display: none;
}

.Header-navItem {
  flex-shrink: 0;
}

.Header-navLink {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.Header-navLink span:nth-child(2) {
  font-size: min(0.5rem /* 8px (基準16px) */, 0.556vw /* 8px (基準1440px) */);
}

.Header-buttons {
  display: flex;
  align-items: center;
}

.s .Header-buttons {
  column-gap: 1rem /* 16px (基準16px) */;
  margin-right: 0.5rem /* 8px (基準16px) */;
}

.Header-buttonLink {
  width: min(8.063rem /* 129px (基準16px) */, 8.958vw /* 129px (基準1440px) */);
  height: auto;
  aspect-ratio: 129 / 56;
  border: 1px solid #bb4953;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
}

.Header-buttonLink._reserve {
  background-color: #bb4953;
  color: #fff;
  margin-left: min(1rem /* 16px (基準16px) */, 1.111vw /* 16px (基準1440px) */);
}

.s .Header-buttonLink {
  display: none;
}

.Header-hamburger {
  display: none;
}

.s .Header-hamburger {
  display: block;
}

.Header-hamburgerMenu._open {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 9;
  display: flex;
  background-color: #fffdf8;
}

.Header-hamburgerMenu._close {
  display: none;
}

.Header-hamburgerMenuCloseButton {
  position: absolute;
  right: 0;
  top: 0.625rem /* 10px (基準16px) */;
  right: 0.625rem /* 10px (基準16px) */;
  width: 2rem /* 32px (基準16px) */;
  height: 2rem /* 32px (基準16px) */;
  cursor: pointer;
}

.Header-hamburgerMenuLeft {
  width: min(8.5rem /* 136px (基準16px) */, 36.267vw /* 136px (基準375px) */);
}

.Header-hamburgerMenuLeft img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.Header-hamburgerMenuRight {
  padding-top: 5.75rem /* 92px (基準16px) */;
  padding-left: 1.063rem /* 17px (基準16px) */;
}

.Header-hamburgerMenuList {
  display: flex;
  flex-direction: column;
  row-gap: 0.75rem /* 12px (基準16px) */;
}

.Header-hamburgerMenuItem {
  font-size: min(0.875rem /* 14px (基準16px) */, 3.733vw /* 14px (基準375px) */);
}

.Header-hamburgerMenuButtons {
  display: flex;
  flex-direction: column;
  font-size: min(0.938rem /* 15px (基準16px) */, 4vw /* 15px (基準375px) */);
  margin-top: 1.688rem /* 27px (基準16px) */;
}

.Header-hamburgerMenuInstagram img {
  width: min(1.875rem /* 30px (基準16px) */, 8vw /* 30px (基準375px) */);
}

.Header-hamburgerMenuButtonLink {
  aspect-ratio: 210 / 46;
  width: min(13.125rem /* 210px (基準16px) */, 56vw /* 210px (基準375px) */);
  height: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  border: #bb4953 1px solid;
  border-radius: 6.25rem /* 100px (基準16px) */;
}

.Header-hamburgerMenuButtonLink._reserve {
  margin-top: 2.625rem /* 42px (基準16px) */;
}

.Header-hamburgerMenuButtonLink._contact {
  margin-top: 1rem /* 16px (基準16px) */;
}
