@charset "UTF-8";

/*
ナビゲーション
*/

/*
メニュー本体
*/

nav .menu, .nav .menu {
  clear: both;
  padding: 0;
  margin: 0;
  list-style: none;
}
nav .menu-item, .nav .menu-item {
  padding: 0;
  margin: 0;
}
nav .menu-item-has-children > a::after, .nav .menu-item-has-children > a::after {
  font-family: icon;
  content: "\e97a"; /* chevron-down */
  vertical-align: top;
}
nav a, .nav a {
  display: block;
  padding: 0.5rem 1rem;
  font-size: 1.5rem;
  line-height: 2rem;
  font-weight: 400;
  text-decoration: none;
  word-break: break-all;
  color: var(--my-color-base-font);
}
/* nav .current-menu-item > a, .nav .current-menu-item > a {
  font-weight: 700;
} */
nav a:focus, nav a:hover, .nav a:focus, .nav a:hover {
  color: var(--my-color-base-hover);
}
@media only screen and (max-width: 959px) { /* not lg(large) */
  nav .menu-item.pc, .nav .menu-item.pc {
    display: none;
  }
}
@media only screen and (min-width: 960px) { /* lg(large) */
  nav .menu-item.mb, .nav .menu-item.mb {
    display: none;
  }
}

/*
サブメニュー
*/
nav .sub-menu, .nav .sub-menu {
  display: block;
  padding: 0 0 0 1.3rem;
  margin: 0;
  list-style: none;
}

/*
メニューON/OFF制御用チェックボックス
*/
#menu-switch-primary {
  display: none;
}

/*
トグルボタン（ハンバーガーボタン）
*/
#menu-toggle-primary {
  position: absolute;
  display: block;
  z-index: 1000;
  padding: 0 0 0.1rem 0;
  margin: 0;
  top: 2.2rem;
  right: 1rem;
  width: 3.5rem;
  height: 3.3rem;
  font-size: 2.6rem;
  line-height: 3.4rem;
  text-align: center;
  overflow: hidden;
  visibility: visible;
  color: var(--my-color-sub4-font);
  background-color: var(--my-color-sub4);
  border-radius: 0.4rem;
  box-shadow: inset 0 0 0 1px var(--my-color-sub4-font);
}
#menu-toggle-primary::before {
  width: 3.5rem;
  height: 3.5rem;
  font-family: icon;
  content: "\e99e"; /* menu */
}
#menu-switch-primary:checked ~ .menu-toggle-primary::before {
  content: "\e982"; /* cross1 */
}
@media only screen and (min-width: 720px) {
  #menu-toggle-primary {
    top: 3rem;
  }
}
@media only screen and (min-width: 960px) {
  #menu-toggle-primary {
    display: none;
    visibility: hidden;
  }
}

/*
メインメニュー
*/
#nav-primary {
  position: absolute;
  z-index: 999;
  top: 1.5rem;
  right: 0;
  padding: 1rem 1.5rem;
  width: 40rem;
  max-width: 100%;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.25s ease-in;
  color: var(--my-color-sub4-font);
  background-color: var(--my-color-sub4);
  border: 1px solid var(--my-color-sub4-weak1);
}
#menu-switch-primary:checked ~ #nav-primary {
  visibility: visible;
  opacity: 1;
}
#nav-primary .menu-item {
  border-top: 1px solid var(--my-color-sub4-weak2);
}
#nav-primary .menu > .menu-item:first-of-type {
  border: 0 none;
}
#nav-primary a {
  padding: 1.5rem 0 1.5rem 1rem;
  text-indent: 0;
  color: var(--my-color-sub4-font);
}
#nav-primary a:hover {
  color: var(--my-color-sub4-hover);
}
#nav-primary a::before {
  content: '';
}
#nav-primary .sub-menu a {
  padding: 1.5rem 0.5rem 1.5rem 1rem;
}
@media only screen and (min-width: 960px) {
  #nav-primary {
    position: static;
    display: flex;
    z-index: 0;
    justify-content: flex-end;
    align-items: stretch;
    padding: 0 1rem;
    margin: 0 0 0 auto;
    width: auto;
    min-height: 7.9rem;
    visibility: visible;
    opacity: 1;
    background-color: transparent;
    border: 0 none;
  }
  #nav-primary .menu {
    display: flex;
    flex-wrap: wrap;
    height: 100%;
    align-content: space-evenly;
    align-items: center;
    justify-content: flex-end;
  }
  #nav-primary .menu > .menu-item {
    position: relative;
    border-top: 0 none;
  }
  #nav-primary .menu > .menu-item > a {
    padding: 0 1.2rem;
    text-indent: 0;
    line-height: 2.5rem;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    color: var(--my-color-base-font);
  }
  #nav-primary .menu > .menu-item > a:hover {
    color: var(--my-color-base-hover);
  }
  #nav-primary .menu > .menu-item > .sub-menu {
    position: absolute;
    display: block;
    z-index: 10000;
    right: 1rem;
    padding: 0 1.5rem;
    background-color: var(--my-color-sub4);
    border: 1px solid var(--my-color-sub4-weak2);
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.25s ease-in;
  }
  #nav-primary .menu > .menu-item:hover > .sub-menu {
    visibility: visible;
    opacity: 1;
    display: block;
  }
  #nav-primary .sub-menu > .menu-item {
    max-width: 35rem;
    white-space: nowrap;
  }
  #nav-primary .menu > .menu-item > .sub-menu > .menu-item:first-of-type {
    border-top: 0 none;
  }
  #nav-primary .sub-menu > .menu-item > a {
    padding-left: 1rem;
    padding-right: 1rem;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .header-widgets ~ #nav-primary {
    clear: both;
    justify-content: center;
    min-height: 0;
    padding-top: 1rem;
    padding-bottom: 1rem;
    border-top: 1px solid var(--my-color-main);
  }
  .header-widgets ~ #nav-primary .menu > .menu-item > a {
    line-height: 2.4rem;
  }
}

/*
ページ上メニュー
*/
#nav-secondary {
  padding: 0.5rem 0 0.4rem;
  margin: 0;
  color: var(--my-color-main-font);
  background-color: var(--my-color-main);
  border-bottom: 1px solid var(--my-color-main-weak2);
}
#nav-secondary > .wrap {
  max-width: var(--my-site-width);
  width: 100%;
  padding: 0;
  margin: 0 auto;
}
body.header-full-width #nav-secondary > .wrap {
  max-width: none;
}
#nav-secondary .menu {
  display: block;
}
#nav-secondary .menu-item {
  float: left;
  padding: 0.2rem 0.5rem;
}
#nav-secondary .menu-item.right {
  float: right;
}
#nav-secondary a {
  padding: 0 0.5rem;
  font-size: 1.3rem;
  color: var(--my-color-main-font);
}
#nav-secondary a:hover {
  color: var(--my-color-main-hover);
}

/*
ページ下メニュー
*/
#nav-tertiary {
  padding: 0.5rem 0;
  margin: 0;
  color: var(--my-color-main-font);
  background-color: var(--my-color-main);
}
#nav-tertiary .menu {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
#nav-tertiary .menu-item {
  padding: 0.5rem;
}
#nav-tertiary a {
  padding: 0 0.5rem;
  font-size: 1.3rem;
  color: var(--my-color-main-font);
}
#nav-tertiary a:hover {
  color: var(--my-color-main-hover);
}

/*
水平メニュー
*/
.nav-horiz {
  padding: 0.5rem 0;
  margin: 0;
}
.nav-horiz .menu {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.nav-horiz .menu-item {
  padding: 0.5rem;
}
.nav-horiz a {
  padding: 0 0.5rem;
}
.nav-horiz .menu-item-has-children > a::after {
  content: none;
}
.nav-horiz a:hover {
}
.nav-horiz .sub-menu {
  display: none;
}

