/* =========================================
   cmnnav Accordion Menu CSS（最終版）
   ・角丸なし / 白背景 / フラット
   ・親はリンクさせない（href="#" + JSでprevent）
   ・矢印なし / 三角なし
   ・ハンバーガー時に子が“切れない”よう overflow 対策
========================================= */

/* =========================================
   ハンバーガー内スクロール（これが正）
   ※ overflow: visible !important は入れない
========================================= */

/* PCのドロップダウンが切れないようにするのは「PC時だけ」 */
@media screen and (min-width: 1025px){
  .cmnnav{ overflow: visible; }
}

/* SP(ハンバーガー)は「cmnnav全体は固定」＋「navlistだけスクロール」 */
@media screen and (max-width: 1024px){

  /* メニュー全体 */
  .cmnnav.active{
    position: fixed;
    inset: 0;
    height: 100dvh;
    background: #fff;
    overflow: hidden;          /* ←ここ重要：外はスクロールさせない */
    z-index: 99999;
  }

  /* ロゴの分だけナビをスクロールさせたいなら */
  .cmnnav.active .splogo{
    flex: 0 0 auto;
  }

  /* スクロールさせる本体 */
  .cmnnav.active .navlist{
    overflow-y: auto;          /* ←ここでスクロール */
    -webkit-overflow-scrolling: touch;
    height: calc(100dvh - 110px); /* ←ロゴ/余白分（必要なら微調整） */
  }

  /* transform:scale があると当たり判定/スクロールがバグることがあるのでSP中は無効化 */
  .navlist{
    transform: none !important;
  }
}



/* -----------------------------
   1) トップ階層
------------------------------ */
.cmnnav .navlist .flexbox1 > li{
  position: relative;
}

.cmnnav .navlist .flexbox1 > li > a{
  display: flex;
  align-items: center;
  justify-content: center; /* いまの“中央並び”を維持 */
  gap: 10px;

  padding: 16px 14px;
  line-height: 1.4;
  text-decoration: none;

  background: #fff;
  color: #222;

  border-radius: 0;
  border: 0;
  box-shadow: none;

  position: relative;
}
@media screen and (max-width: 1024px) {
.cmnnav .navlist .flexbox1 > li > a{
  justify-content: flex-start;
}
}

/* 三角/吹き出し系の擬似要素は全部殺す */
.cmnnav .navlist .flexbox1 > li > a::before,
.cmnnav .navlist .flexbox1 > li > a::after{
  content: none !important;
}

/* hover（PCのみ） */
@media (hover:hover){
  .cmnnav .navlist .flexbox1 > li > a:hover{
    background: #f5f5f5;
  }
}

/* 親 nowpage */
.cmnnav .navlist .flexbox1 > li.nowpage > a{
  font-weight: 700;
border-bottom: 2px solid #1e96d4;
}
@media screen and (max-width: 1024px) {
.cmnnav .navlist .flexbox1 > li.nowpage > a{
border-bottom: unset;
}
}



/* -----------------------------
   2) アコーディオン親
------------------------------ */
.cmnnav .accordion_btn > a.header_nav_link{
  cursor: pointer;
}

/* 矢印（上向き/下向き）いらない */
.cmnnav .accordion_btn > a.header_nav_link::after{
  content: none !important;
}

/* SPで開いてる時の見た目（任意：薄い区切り） */
.cmnnav .accordion_btn.is-open > a.header_nav_link{
  border-bottom: 1px solid rgba(0,0,0,.12);
}

/* -----------------------------
   3) 子メニュー（SPは“中に出す” / PCはdropdown）
------------------------------ */
.cmnnav .accordionmenu{
  display: none;  /* JSで開閉 */
  margin: 0;      /* 接触問題を消す */
  padding: 0;
}

.cmnnav .accordionmenu_list{
  background: #fff;
  border: 1px solid rgba(0,0,0,.12);
  border-top: 0;              /* 親と密着 */
  border-radius: 0;
  box-shadow: none;
  overflow: hidden;
}
@media screen and (max-width: 1024px) {
.cmnnav .accordionmenu_list{
  border: unset;
}
}

/* SP時：中央並びメニューでも子は“読みやすい幅”を確保 */
@media screen and (max-width: 1024px){
  .cmnnav .accordionmenu_list{
    width: 100%;
    margin: 0 auto;          /* 中央に綺麗に */
    text-align: left;        /* 文字は左の方が読みやすい */
  }
}

.cmnnav .accordionmenu_item{
  border-top: 1px solid rgba(0,0,0,.08);
}
@media screen and (max-width: 1024px) {
.cmnnav .accordionmenu_item{
  border-top: unset;
}
}

.cmnnav .accordionmenu_item:first-child{
  border-top: 0;
}

.cmnnav .accordionmenu_link{
  display: block;
  padding: 14px 14px;
  font-size: 15px;
  line-height: 1.4;
  text-decoration: none;
  color: #222;
  background: #fff;
  position: relative;
}

.cmnnav .accordionmenu_link::before,
.cmnnav .accordionmenu_link::after{
  content: none !important;
}

@media (hover:hover){
  .cmnnav .accordionmenu_link:hover{
    background: #f3f3f3;
  }
}

/* .cmnnav .accordionmenu_item.nowpage > .accordionmenu_link{
  background: #f6f6f6;
  font-weight: 700;
  border-left: 4px solid #005bac;
} */

/* -----------------------------
   4) PC：hoverドロップダウン
------------------------------ */
@media screen and (min-width: 1025px){

  .cmnnav .accordion_btn .accordionmenu{
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 999;
    width: 280px;
  }

  .cmnnav .accordionmenu_list{
    width: 100%;
    margin: 0;
  }
}

/* -----------------------------
   5) SP用単体リンク（spstyle）
------------------------------ */
.cmnnav .spstyle > a{
  display: block;
  padding: 16px 14px;
  background: #fff;
  color: #222;
  text-decoration: none;
  border-radius: 0;
}

.cmnnav .spstyle > a::before,
.cmnnav .spstyle > a::after{
  content: none !important;
}

@media (hover:hover){
  .cmnnav .spstyle > a:hover{
    background: #f5f5f5;
  }
}

.cmnnav .spstyle.nowpage > a{
  font-weight: 700;
  border-bottom: 2px solid #005bac;
}


/* ===============================
   SP(ハンバーガー) 親だけ色つける
=============================== */
@media screen and (max-width: 1024px){
  /* アコーディオン親（活動内容/法人概要）だけ色付け */
  .cmnnav .accordion_btn > a.header_nav_link{
    background: #f1f7ff;                 /* 薄い青 */
    border: 1px solid rgba(0,91,172,.25);
    font-weight: 700;
  }

  /* 押したとき（開いてる時）は少し濃く */
  .cmnnav .accordion_btn.is-open > a.header_nav_link{
    background: #e3f1ff;
  }
}

/* ===============================
   ハンバーガー表示中：メニュー内だけスクロール
=============================== */
.cmnnav.active{
  position: fixed;   /* すでにfixedなら不要 */
  inset: 0;
  z-index: 9999;
}

/* スクロールさせる領域（メニュー本体） */
.cmnnav.active .navlist{
  height: 100vh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch; /* iOS滑らか */
}

/* 変なスクロール連鎖（下のページへ伝播）を抑止 */
.cmnnav.active .navlist{
  overscroll-behavior: contain;
}

.cmnnav.active .inner1,
.cmnnav.active .flexbox1{
  overflow: visible;
}
/* ===============================
   【強制】ハンバーガー内だけスクロール
   ※CSSの一番最後に追記
=============================== */

/* 背景ページはJSで固定。メニューは画面全面に固定 */
.cmnnav.active{
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 100vh !important;
  z-index: 99999 !important;
  overflow: hidden !important;  /* ここはnavlistにスクロールを渡す */
}

/* スクロール領域は navlist にする */
.cmnnav.active .navlist{
  position: relative !important;
  height: 100vh !important;
  max-height: 100vh !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

/* 親や子で overflow:hidden が当たってても殺す */
.cmnnav.active .inner1{
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
}

.cmnnav.active .flexbox1{
  display: block !important;   /* flexだと高さ潰れ/スクロール阻害の元になりがち */
  height: auto !important;
  overflow: visible !important;
}

/* ついで：liやaが変に固定高なら解除（保険） */
.cmnnav.active .flexbox1 > li{
  height: auto !important;
}


/* ===============================
   SP: ハンバーガー内だけスクロール（確実版）
=============================== */
@media screen and (max-width: 1024px){

  /* cmnnavは器：ここはスクロールさせない */
  .cmnnav.active{
    position: fixed !important;
    inset: 0 !important;
    height: 100dvh !important;
    background: #fff !important;
    overflow: hidden !important;   /* ←重要 */
    z-index: 99999 !important;
  }

  /* navlistをスクロール領域にする */
  .cmnnav.active .navlist{
    display: block !important;
    visibility: visible !important;

    /* transformが入ってるとスクロール/タップがバグることがあるのでSPは切る */
    transform: none !important;

    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;

    /* ロゴが上にある前提：ロゴ分を引く（ここが肝） */
    height: calc(100dvh - 120px) !important;
    max-height: calc(100dvh - 120px) !important;
  }

  /* inner1/flexbox1はスクロール邪魔しないように */
  .cmnnav.active .inner1{
    height: auto !important;
  }
  .cmnnav.active .flexbox1{
    display: block !important;
  }
}
