:root{
  --header-h: 56px;
  --bg: #ffffff;
  --fg: #111827;
  --fg-muted: #4b5563;
  --brand: #10b981; /* お好みで */
  --border: rgba(0,0,0,.06);
  --shadow: 0 2px 10px rgba(0,0,0,.06);
}

body{ padding-top: var(--header-h); }

.site-header{
  position: fixed;           /* ← ここをfixedに */
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;             /* コンテンツより手前に */
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow);
}

.header-container{
  height: var(--header-h);
  max-width: min(1200px, 92vw);
  margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; padding: 0 12px;
}

.logo{
  font-weight: 700; letter-spacing: .02em; color: var(--fg);
  text-decoration: none;
}

.site-nav{ display: none; }           /* モバイルでは隠す */
.nav-list{
  display: flex; align-items: center; gap: 20px; list-style: none; margin: 0; padding: 0;
}
.nav-list a{
  display: inline-block; padding: 8px 10px; border-radius: 8px;
  color: var(--fg); text-decoration: none; font-weight: 600;
}
.nav-list a:hover{ background: rgba(16,185,129,.08); color: var(--fg); }

/* ハンバーガー */
.menu-toggle{
  display: grid; place-items: center;
  width: 40px; height: 40px; border: 1px solid var(--border); border-radius: 10px;
  background: var(--bg); cursor: pointer;
}
.menu-toggle span{
  width: 20px; height: 2px; background: var(--fg); display: block; transition: transform .2s ease, opacity .2s ease;
}
.menu-toggle span + span{ margin-top: 4px; }

/* 開閉時のアニメ */
.site-header.is-open .menu-toggle span:nth-child(1){ transform: translateY(6px) rotate(45deg); }
.site-header.is-open .menu-toggle span:nth-child(2){ opacity: 0; }
.site-header.is-open .menu-toggle span:nth-child(3){ transform: translateY(-6px) rotate(-45deg); }

/* モバイルパネル */
.mobile-panel{
  position: fixed; inset: calc(var(--header-h)) 0 auto 0;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow);
  padding: 12px 16px 16px;
}
.mobile-nav-list{ list-style: none; margin: 0; padding: 8px 0; }
.mobile-nav-list li + li{ margin-top: 4px; }
.mobile-nav-list a{
  display: block; padding: 12px 10px; border-radius: 10px;
  color: var(--fg); text-decoration: none; font-weight: 600;
}
.mobile-nav-list a:hover{ background: rgba(16,185,129,.08); }

/* PCレイアウト */
@media (min-width: 768px){
  .site-nav{ display: block; }    /* PCで表示 */
  .menu-toggle{ display: none; }  /* PCで非表示 */
  .mobile-panel{ display: none !important; }
}

/* 低視覚効果設定に配慮 */
@media (prefers-reduced-motion: reduce){
  .menu-toggle span{ transition: none; }
}

/* iPhoneノッチ対策（ある場合だけ加算） */
@supports (padding: max(0px)){
  body{ padding-top: calc(var(--header-h) + env(safe-area-inset-top)); }
}