@charset "utf-8";
/*********************************************
 	ヘッダー2026
*********************************************/
#header2026 {
  top: 0;
  z-index: 100;
  box-sizing: border-box;
  background-color: #FFF;
  border-bottom: solid 1px #CCC;
}

/* スマホはロゴとハンバーガーのみ */
@media (max-width: 767px) {
  #header2026 {
    padding: 0.5rem 0.8rem;
    display: flex;
    align-items: center; /* 垂直方向の中央揃え */
    justify-content: space-between; /* 両端に配置 */
    height: 80px;
  }
  #header2026 #logo {
    display: flex;
    align-items: center;
    height: 100%; 
    text-decoration: none;
  }
  /* ロゴの中の画像（imgタグの場合） */
  #header2026 #logo img {
    height: 100%;    /* 親要素の高さに合わせる */
    width: auto;     /* 横幅は自動調整して比率を維持 */
    display: block;
    object-fit: contain; /* 枠内に綺麗に収める（お好みで） */
  }
}

/* パソコン */
@media (min-width: 768px) {
  #header2026 {
    padding: 0.5rem 1.5rem 0;
  }
}

/*********************************************
 	ヘッダー2026 ハンバーガーアイコン
*********************************************/
/* アイコン全体のサイズと配置 */
.hamburger {
  width: 48px;  /* クリック範囲を 48px に固定 */
  height: 48px; /* クリック範囲を 48px に固定 */
  position: relative;
  cursor: pointer;
  z-index: 100;
  margin-left: 1.5rem;
  /* padding は使わずに、中の span を absolute で中央に寄せます */
  box-sizing: border-box; 
}

/* 3本の線の共通スタイル */
.hamburger span {
  display: block;
  position: absolute;
  /* 横方向の中央揃え（一番確実な方法） */
  left: 50%;
  transform: translateX(-50%); 
  width: 28px;  /* 線の長さ（48pxに対してこれくらいが綺麗） */
  height: 4px;  /* 線の太さ */
  background-color: #283A92;
  border-radius: 4px;
  transition: all 0.4s;
}

/* 縦方向の完璧な配置（48pxの中心 24px を基準に計算） */
/* 24px - (線の太さ4px / 2) = 22px が真ん中の線の top です */
.hamburger span:nth-child(1) { top: 14px; } /* 上（22 - 8） */
.hamburger span:nth-child(2) { top: 22px; } /* 真ん中 */
.hamburger span:nth-child(3) { top: 30px; } /* 下（22 + 8） */

/* アクティブ時のアニメーション（真ん中の 22px 位置で交差させる） */
.hamburger.active span:nth-child(1) {
  top: 22px;
  transform: translateX(-50%) rotate(-45deg);
}
.hamburger.active span:nth-child(2) {
  opacity: 0;
}
.hamburger.active span:nth-child(3) {
  top: 22px;
  transform: translateX(-50%) rotate(45deg);
}

@media (min-width: 768px) {
  /* パソコンは非表示 */
  .hamburger {
    display: none;
  }
}

/*********************************************
 	ヘッダー2026　ナビメニュー基本設定
*********************************************/
#header2026 nav {
  font-weight: bold;
}

/* --- スマホ用メニューの基本スタイル --- */
@media (max-width: 767px) {
  #header2026 nav {
    position: fixed;
    top: 80px;
    left: 0;
    width: 100%;
    height: calc(100vh - 80px);
    background-color: rgba(0, 0, 0, 0.8); /* 紺色の半透明背景 */
    z-index: 90; /* アイコン(100)より下に配置 */
    
    /* 初期は非表示設定 */
    opacity: 0;
    visibility: hidden;
    transition: all 0.5s;
  }
}

/* アイコンがタップされた時（activeクラスがついた時） */
#header2026 nav.active {
  opacity: 1;
  visibility: visible;
}

/*********************************************
 	ヘッダー2026　アコーディオンメニュー
*********************************************/
/* パソコンは横並び */
@media (min-width: 768px) {
  #header2026 ul#main-menu {
    display: flex;
  }
}

#header2026 ul#main-menu li {
  border-bottom: solid 1px #CCC;
}

#header2026 ul#main-menu li a {
  text-decoration: none;
  color: #283A92;
}

/* スマホ版の余白 */
@media (max-width: 767px) {
  #header2026 ul#main-menu li {
    padding: 0.8rem;
  }
}

/* パソコン表示 */
@media (min-width: 768px) {
  #header2026 ul#main-menu li:not(:last-child) {
    border-right: solid 1px #CCC;
  }
  #header2026 ul#main-menu li a {
    cursor: pointer;
    display: inline-block;
    padding: 0.5rem 2rem;
    border-bottom: 5px solid transparent;
    box-sizing: border-box;
  }
  #header2026 ul#main-menu li a:hover {
    background-color: #FF6;
    border-bottom: solid 5px #283A92;
  }
}

#header2026 ul#dropdown-menu1 {
  border-bottom: solid 1px #CCC;
}

#header2026 ul#dropdown-menu2 {
  border-bottom: solid 1px #CCC;
}

/* パソコンは最初非表示 */
@media (min-width: 768px) {
  #header2026 ul#dropdown-menu1 {
    display: none;
  }
  #header2026 ul#dropdown-menu2 {
    display: none;
  }
}
