/* --------- mobile menu button (only on small screens) --------- */

/* デフォルトは非表示（PCでは出さない） */
.mobile-header-search-menu {
  display: none !important;
}

/* スマホ幅で表示 */
@media (max-width: 768px) {
  .mobile-header-search-menu {
    display: block !important;
    position: absolute;
    left: 14px;
    top: 12px;
    z-index: 9999;
  }

  .mobile-header-search-menu .menu-button {
    display: inline-block !important;
  display: inline-flex !important;       /* inline-block → inline-flex に変更 */
  align-items: center !important;        /* 縦方向の中央揃え */
  justify-content: center !important;    /* 横方向の中央揃え */

    padding: 8px 24px !important;
 min-width: 80px !important;            /* ボタンの最低横幅を確保 */
  height: 40px !important;               /* 高さを固定すると安定します */
    border: 2px solid #2C4D67 !important;        /* 枠色（screen.min.css に合わせた濃い青） */
    background-color: #2C4D67 !important;        /* 背景色（「詳しくみる」と同系） */
    color: #ffffff !important;                   /* 文字は白 */
    font-size: 16px !important;
    font-weight: 600 !important;
    border-radius: 4px !important;
    text-decoration: none !important;
    line-height: 1.2 !important;
    box-sizing: border-box !important;
    cursor: pointer !important;
    -webkit-tap-highlight-color: transparent;
  }

  .mobile-header-search-menu .menu-button:hover,
  .mobile-header-search-menu .menu-button:focus {
    background-color: #233f52 !important;   /* ホバー時に少し濃く */
    border-color: #233f52 !important;
    color: #fff !important;
    outline: none !important;
  }

  /* 場合によっては expand-global-nav が link の色を上書きしていることがあるので
     より具体的に書いておく */
  .mobile-header-search-menu a.menu-button.expand-global-nav {
    color: #ffffff !important;
    background-color: #2C4D67 !important;
  }
}

/* 大きなフォントやレイアウトに影響する場合はここで微調整 */


/* スマホ幅で閉じた状態をデフォルトに */
@media (max-width: 768px) {
  .sub-menu--mobile {
    display: none;
    padding: 10px 20px;
    background-color: #f8f8f8;
  }

  .sub-menu--mobile ul {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .sub-menu--mobile li {
    margin: 8px 0;
  }

  .sub-menu--mobile a {
    display: block;
    padding: 8px;
    border: 1px solid #ddd;
    border-radius: 4px;
    background-color: #ffffff;
    text-decoration: none;
    color: #333;
  }

  .sub-menu--mobile a:hover {
    background-color: #0072ce;
    color: #fff;
    border-color: #0072ce;
  }

  /* 開いたときだけ表示 */
  .sub-menu--mobile.open {
    display: block;
  }
}
