/* --------------------------------------------------------------------
パラメーターによるクラス付与（changeActive.js）
--------------------------------------------------------------------- */
.mainframe_ #navi_menu.js-change-active-area,
.mainframe_ #title_list.js-change-active-area,
.wrapper_:not(:has(.mainframe_)) #navi_menu.js-change-active-area,
.wrapper_:not(:has(.mainframe_)) #title_list.js-change-active-area {
  /* カラー設定：タブボタン・タイトル */
  --js-color-font-on: #ffffff;    /* ONボタン：文字 */
  --js-color-bg-on: #313131;    /* ONボタン：背景 */

  --js-color-font-off: #111111;      /* OFFボタン：文字 */
  --js-color-bg-off: #ffffff;      /* OFFボタン：背景 */
  --js-color-border-off: #ded1d1;      /* OFFボタン：ボーダー */
  --js-color-linkover-off: #f2ebeb;    /* OFFボタン：マウスオーバー */
}

/* ナビメニュー（#navi_menu）
================================================== */
.mainframe_ #navi_menu.js-change-active-area {
  margin-top: 20px;
}

.mainframe_ #navi_menu.js-change-active-area ul {
  display: flex;
  justify-content: center;
  gap: 2px;
  width: 100%;
}

.mainframe_ #navi_menu.js-change-active-area ul li {
  width: 100%;
}
.mainframe_ #navi_menu.js-change-active-area ul li.js-key-all { width: 60%; }

.mainframe_ #navi_menu.js-change-active-area ul li a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--js-color-font-off);
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.2;
  text-align: center;
  width: 100%;
  height: 70px;
  background: var(--js-color-bg-off);
  border: 1px solid var(--js-color-border-off);
  border-radius: 8px;
}

.mainframe_ #navi_menu.js-change-active-area ul li .mini {
  font-size: 1.3rem;
}

/* 指定の「カテゴリーから探す」以外の時の表示（価格から探す等） */
.mainframe_ #navi_menu.js-change-active-area ul:has( > li.active-item) {
  border-bottom: 5px solid var(--js-color-bg-on);
}

.mainframe_ #navi_menu.js-change-active-area ul:has( > li.active-item) li a {
  border-bottom: none;
  border-radius: 8px 8px 0 0;
}

/* マウスオーバー */
.mainframe_ #navi_menu.js-change-active-area ul li a:hover {
  opacity: 1;
  background: var(--js-color-linkover-off);
}

/* タイトル（#title_list）
================================================== */
.mainframe_ #title_list.js-change-active-area p {
  display: none;
  color: var(--js-color-font-off);
  text-align: center;
  font-size: 2.0rem;
  font-weight: bold;
  padding: 10px 0 0 0;
}

.mainframe_ #title_list.js-change-active-area p .mini {
  font-size: 1.6rem;
}

/* 【JS】アクティブボタン用CSS（.js-change-active-area）※active=ON
================================================== */
/* ナビボタン */
.mainframe_ #navi_menu.js-change-active-area ul .active-item {
  position: relative;
}

.mainframe_ #navi_menu.js-change-active-area ul .active-item::before {
  content: '';
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgb(0, 0, 0, 0.0);
}

.mainframe_ #navi_menu.js-change-active-area ul .active-item a {
  color: #fff;
  background: var(--js-color-bg-on);
  border-color: var(--js-color-bg-on);
}

/* タイトル */
.mainframe_ #title_list.js-change-active-area p.active-item {
  display: block;
}

/*--------------------- SP -------------------------------------------------*/
/* ナビメニュー（#navi_menu）
================================================== */
.wrapper_:not(:has(.mainframe_)) #navi_menu.js-change-active-area ul {
  display: flex;
  justify-content: start;
  flex-wrap: wrap;
  padding: 0 1%;
  margin: 10px 0;
}

.wrapper_:not(:has(.mainframe_)) #navi_menu.js-change-active-area ul li {
  width: calc((100% / 2) - 2%);
  margin: 1%;
}

.wrapper_:not(:has(.mainframe_)) #navi_menu.js-change-active-area ul li a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--js-color-font-off);
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1;
  text-align: center;
  width: 100%;
  height: 70px;
  padding: 10px 0 15px 0;
  background: var(--js-color-bg-off);
  border: 2px solid var(--js-color-border-off);
  border-radius: 3px;
}

.wrapper_:not(:has(.mainframe_)) #navi_menu.js-change-active-area ul li a::after {
  content: '';
  position: absolute;
  bottom: 8px;
  width: 8px;
  height: 8px;
  border-right: solid 1px #111;
  border-bottom: solid 1px #111;
  transform: rotate(45deg);
}

.wrapper_:not(:has(.mainframe_)) #navi_menu.js-change-active-area ul li .name {
  letter-spacing: -0.15rem;
}

.wrapper_:not(:has(.mainframe_)) #navi_menu.js-change-active-area ul li .mini {
  font-size: 1.2rem;
  letter-spacing: -0.05rem;
}

/* タイトル（#title_list）
================================================== */
.wrapper_:not(:has(.mainframe_)) #title_list.js-change-active-area {
  margin: 10px 0 0 0;
  border-top: 4px solid var(--js-color-bg-on);
}

.wrapper_:not(:has(.mainframe_)) #title_list.js-change-active-area p {
  color: var(--js-color-font-off);
  font-size: 2.0rem;
  text-align: center;
  font-weight: bold;
  line-height: 1;
  padding: 10px 0;
  border-bottom: 1px solid #bebebe;
}

.wrapper_:not(:has(.mainframe_)) #title_list.js-change-active-area p .mini {
  font-size: 1.6rem;
}

/* 【JS】アクティブボタン用CSS（.js-change-active-area）※active=ON
================================================== */
/* ナビボタン */
.wrapper_:not(:has(.mainframe_)) #navi_menu.js-change-active-area ul .active-item {
  position: relative;
}

.wrapper_:not(:has(.mainframe_)) #navi_menu.js-change-active-area ul .active-item::before {
  content: '';
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgb(0, 0, 0, 0.0);
}

.wrapper_:not(:has(.mainframe_)) #navi_menu.js-change-active-area ul .active-item a {
  color: #fff;
  font-weight: bold;
  background: var(--js-color-bg-on);
  border-color: var(--js-color-bg-on);
}

.wrapper_:not(:has(.mainframe_)) #navi_menu.js-change-active-area ul .active-item a::after {
  content: unset;
}

/* タイトル */
.wrapper_:not(:has(.mainframe_)) #title_list.js-change-active-area p {
  display: none;
}

.wrapper_:not(:has(.mainframe_)) #title_list.js-change-active-area p.active-item {
  display: block;
}

