/* ===========================================
   共通ヘッダー／メニュー（全公開ページ共通）
   ※ヘッダー・メニューの見た目はこのファイル1つを編集すれば全ページに反映されます
=========================================== */
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;500;700&display=swap');

/* ─── Header ─── */
.harimayaHeader {
  position: sticky; top: 0; width: 100%;
  background: #fff; z-index: 1000;
}
.harimayaHeader__inner {
  max-width: 1920px; margin: 0 auto; padding: 0 56px;
  min-height: 80px;
  display: flex; align-items: stretch; justify-content: space-between;
  box-sizing: border-box;
}
.harimayaHeader__logo { margin: 0; flex-shrink: 0; display: flex; align-items: center; }
.harimayaHeader__logo a { display: flex; align-items: center; height: 100%; }
.harimayaHeader__logo img { display: block; width: 370px; height: auto; }
.harimayaHeader__nav { margin-left: auto; }
.harimayaHeader__menu {
  display: flex; height: 100%; margin: 0; padding: 0; list-style: none;
}
.harimayaHeader__menu li { display: flex; align-items: stretch; }
.harimayaHeader__menu a {
  position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 28px 12px; height: 100%; color: #222222; text-decoration: none;
  font-size: 14px; font-weight: 500; letter-spacing: 0.02em; line-height: 1.4;
  font-family: "Noto Serif JP", serif;
  transition: background .25s ease; box-sizing: border-box; white-space: nowrap; text-align: center;
}
.harimayaHeader__menu a .subtxt {
  display: block; font-size: 10px; font-weight: 400; color: #888; margin-top: 4px; letter-spacing: 0;
}
.harimayaHeader__menu li:hover a { background: #f4f2ee; }
.harimayaHeader__menu a::before {
  content: ""; position: absolute; left: 50%; top: 0;
  transform: translateX(-50%) scaleX(0);
  width: 100%; height: 5px; background: #e99413;
  transition: transform .25s ease;
}
.harimayaHeader__menu li:hover a::before,
.harimayaHeader__menu a.is-active::before { transform: translateX(-50%) scaleX(1); }
.harimayaHeader__menu a.is-active { color: #17345d; }

/* hamburger */
.harimayaHeader__toggle {
  display: none; width: 52px; height: 52px; margin: auto 0; padding: 0;
  border: none; background: transparent; cursor: pointer;
  position: relative; z-index: 1100;
  -webkit-tap-highlight-color: transparent;
}
.harimayaHeader__toggle span {
  position: absolute; left: 12px; width: 28px; height: 2px;
  background: #222; transition: transform .25s ease, opacity .25s ease, top .25s ease;
}
.harimayaHeader__toggle span:nth-child(1) { top: 17px; }
.harimayaHeader__toggle span:nth-child(2) { top: 25px; }
.harimayaHeader__toggle span:nth-child(3) { top: 33px; }
.harimayaHeader.is-open .harimayaHeader__toggle span:nth-child(1) { top: 25px; transform: rotate(45deg); }
.harimayaHeader.is-open .harimayaHeader__toggle span:nth-child(2) { opacity: 0; }
.harimayaHeader.is-open .harimayaHeader__toggle span:nth-child(3) { top: 25px; transform: rotate(-45deg); }

/* SPメニュー */
.harimayaSpMenu { display: none; }
.harimayaHeader__toggle:focus, .harimayaHeader__toggle:active { outline: none; box-shadow: none; }
.harimayaHeader__toggle::-moz-focus-inner { border: 0; }
body.menu-open { overflow: hidden; }

/* ハンバーガーを全幅で表示。横並びナビはPC(≥1700px)で併用表示 */
.harimayaHeader__logo img { width: 300px; }
.harimayaHeader__nav { display: none; }
.harimayaHeader__toggle { display: block; }
/* メニュー本体（基本定義。下のメディアクエリで上書きするため必ず先に置く） */
.harimayaSpMenu {
  display: flex; flex-direction: column; position: absolute; top: 100%; left: 0; width: 100%;
  height: calc(100vh - 100%); background: #fff; overflow-y: auto;
  opacity: 0; visibility: hidden; pointer-events: none;
  transform: translateY(-16px); transition: .35s ease; z-index: 999;
}
/* PC/タブレット：ハンバーガーを右端に固定。開いたらヘッダー(ロゴ・ナビ)を隠して全画面・縦中央化 */
@media (min-width: 768px) {
  .harimayaHeader__toggle { position: absolute; right: 28px; top: 0; bottom: 0; margin: auto 0; }
  .harimayaSpMenu { position: fixed; top: 0; height: 100vh; }
  .harimayaHeader.is-open .harimayaHeader__logo,
  .harimayaHeader.is-open .harimayaHeader__nav { display: none; }
}
@media (min-width: 1300px) {
  .harimayaHeader__nav { display: block; }
  /* 右端のハンバーガー(right:28px・幅52px)と重ならないよう余白を確保 */
  .harimayaHeader__inner { padding-right: 120px; }
}
.harimayaHeader.is-open .harimayaSpMenu {
  opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0);
}
.harimayaSpMenu__nav { margin: auto 0; width: 100%; }
.harimayaSpMenu__list { margin: 0 auto; padding: 0; list-style: none; max-width: 600px; }
.harimayaSpMenu__list li {
  opacity: 0; transform: translateY(-8px);
  transition: opacity .3s ease, transform .3s ease;
}
.harimayaHeader.is-open .harimayaSpMenu__list li { opacity: 1; transform: translateY(0); }
.harimayaSpMenu__list a {
  position: relative; display: block; padding: 18px 28px;
  color: #17345d; text-align: center; text-decoration: none;
  font-size: 22px; font-family: "Noto Serif JP", serif; letter-spacing: 0.08em;
  background: transparent; transition: color .25s ease;
}
.harimayaSpMenu__list a::after {
  content: ""; position: absolute; left: 50%; bottom: 10px;
  width: 0; height: 2px; background: #e99413;
  transform: translateX(-50%); transition: width .3s ease;
}
.harimayaSpMenu__list a:hover::after { width: 48px; }

@media (max-width: 767px) {
  .harimayaHeader__inner { padding: 14px 16px; min-height: 72px; align-items: center; }
  .harimayaHeader__logo img { width: 250px; }
  .harimayaHeader__nav { display: none; }
  .harimayaHeader__toggle { display: block; }
  .harimayaSpMenu {
    display: block; position: fixed; top: 72px; left: 0; width: 100%;
    height: calc(100vh - 72px); background: #fff; overflow-y: auto;
    opacity: 0; visibility: hidden; pointer-events: none;
    transform: translateY(-16px); transition: .35s ease; z-index: 999;
  }
  .harimayaHeader.is-open .harimayaSpMenu {
    opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0);
  }
  .harimayaSpMenu__list { margin: 0; padding: 0; list-style: none; max-width: none; }
  .harimayaSpMenu__list li {
    border-bottom: 1px solid #eaeaea;
    opacity: 0; transform: translateY(-8px);
    transition: opacity .3s ease, transform .3s ease;
  }
  .harimayaHeader.is-open .harimayaSpMenu__list li { opacity: 1; transform: translateY(0); }
  .harimayaSpMenu__list a {
    display: block; padding: 18px 16px; color: #4a4a4a; text-align: left;
    text-decoration: none; font-size: 16px;
    font-family: "Noto Serif JP", serif; letter-spacing: 0.04em;
    background: #fff; transition: background .25s ease;
  }
  .harimayaSpMenu__list a:hover { background: #f7f7f7; }
  .harimayaSpMenu__list a::after { display: none; }
}
