/*  ヘッダースタイル */
@charset "utf-8";

/*=========================================================================================
ハンバーガーメニューの出現タイミングは@media (max-width : 1060px) を調整してください。
==========================================================================================*/
/*=========================================================================================
ヘッダー部分
PC＆SP共通パーツ
==========================================================================================*/
#header {
  position: fixed;
  top: 0;
  left: 0;
  transition: .5s;
  width: 100%;
  z-index: 9999;
  background: rgba(244,247,248,0.8);
  padding: 0 15px;
  box-shadow: -1px -5px 20px 0px rgba(0, 0, 0, 0.15);
  backdrop-filter: blur(53px);
}

.h_main_frame {
  display: flex;
  gap: 0 20px;
  justify-content: space-between;
  box-sizing: border-box;
  align-items: center;
  height: 80px;
}

.head_h1 h1 {
  font-size: 12px;
  font-size: 1.2rem;
}

.h_left_area {
  width: fit-content;
  flex: 2;
}
.logo{
  display: block;
  max-width: 330px;
}
.h_right_area{
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
}
 /* .contact_area {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-shrink: 0;
}
.menu li a[href^="#"] {
  pointer-events: none;
}
.h_contact {
  background: url("images/メールアイコン.webp");
}

.h_btn01 {
  width: 60px;
  display: block;
  box-sizing: border-box;
  height: 100%;
  transition: all .3s ease;
  padding: 0 0 79px;
  position: relative;
}
.h_btn01.sp_view767{
  display: none;
}
.h_btn01::before {
  content: "";
  width: 18px;
  display: block;
  height: 18px;
  transition: all .3s ease;
  background: url(../img/common/h_www_icon.svg) 50% 50%/contain no-repeat;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  position: absolute;
}
.h_btn01 a:hover {
  text-decoration: none;
}
.h_btn01_sub_menu{
  top: 100%;
  position: absolute;
  width: 80px;
  right: 0;
  box-shadow: 0px 6px 9px 0px rgba(0, 0, 0, 0.05);
  z-index: 999999;
  overflow: hidden;
  opacity: 1;
}
.h_btn01:hover .h_btn01_sub_menu{
  opacity: 1;
}
.h_btn01_sub_menu a{
  background: #fff;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 500;
  height: 0;
  transition: .3s;
  display: flex;
  align-items: center;
  width: 100%;
  justify-content: center;
}
.h_btn01:hover a{
  height: 40px;
}
.h_btn01_sub_menu a:hover,.h_btn01_sub_menu .active a {
    color: rgba(85,85,85,0.4);
}

 .h_btn01 {
  width: 60px;
  display: block;
  box-sizing: border-box;
  height: 100%;
  transition: all .3s ease;
  padding: 0 0 79px;
  position: relative;
}
.h_btn01.sp_view767{
  display: none;
}
.h_btn01::before {
  content: "";
  width: 18px;
  display: block;
  height: 18px;
  transition: all .3s ease;
  background: url(../img/common/h_www_icon.svg) 50% 50%/contain no-repeat;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  position: absolute;
}
.h_btn01 a:hover {
  text-decoration: none;
}
.h_btn01_sub_menu{
  top: 100%;
  position: absolute;
  width: 80px;
  right: 0;
  box-shadow: 0px 6px 9px 0px rgba(0, 0, 0, 0.05);
  z-index: 999999;
  overflow: hidden;
  opacity: 1;
}
.h_btn01:hover .h_btn01_sub_menu{
  opacity: 1;
}
.h_btn01_sub_menu a{
  background: #fff;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 500;
  height: 0;
  transition: .3s;
  display: flex;
  align-items: center;
  width: 100%;
  justify-content: center;
}
.h_btn01:hover a{
  height: 40px;
} */
.h_btn01_sub_menu a:hover,.h_btn01_sub_menu .active a {
    color: rgba(85,85,85,0.4);
}
  
@media (any-hover: hover){
  .h_contact a:hover .h_mail{opacity: 0.4;}
.h_btn01 a:hover .h_icon01{opacity: 0.4;}
.h_btn01:hover::before {
  opacity: 0.7;
}
}
@media (any-hover: none){
  .h_contact a:active .h_mail {opacity: 0.4;}
.h_btn01 a:active .h_icon01{opacity: 0.4;}
.h_btn01:active::before {
  opacity: 0.7;
}
}

@media(max-width:1200px){
  .menu {
    gap: 20px !important;
}
}

@media(max-width:1100px){
  .logo {
    max-width: 190px;
}
}

/*==================================================================================================================================================
PCヘッダー
全サイズハンバーガーメニューの場合はここのエリアは削除
=================================================================================================================================================*/
@media (min-width : 1061px) {

.sp_menu {
  display: none;
} 

.sp_nav {
  display: none;
}

.h_contact {
  width: 60px;
}
.h_contact a {
  display: block;
  box-sizing: border-box;
  border: solid #ACACAC;
  border-width: 0 1px;
  height: 100%;
  padding: 2px 0;
}
.h_contact a span{
  content: '';
  display: block;
  -webkit-mask-image: url(../img/common/h_mail_icon.svg);
  mask-image: url(../img/common/h_mail_icon.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  width: 20px;
  height: 15px;
  -webkit-mask-size: contain;
  mask-size: contain;
  transition: all .3s ease;
  background-color: var(--sub-color);
  margin: 0 auto;
}
.h_contact a:hover {
  text-decoration: none;
}
 
  /*=========================================================================================
グローバルメニュー
==========================================================================================*/
  .menu {
    display: flex;
    gap: 30px;
    padding: 0 20px 0 0;
    margin: 30px 0 0;
  }

  .menu>ul {
    display: flex;
    justify-content: flex-end;
  }


  .menu>li>a {
    display: block;
    position: relative;
    text-decoration: none;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
    letter-spacing: 0.05em;
    padding: 0 0 22px;
    letter-spacing: 0.2rem;
    font-weight: 500;
    font-size: 14px;
    font-size: 1.4rem;
    text-transform: capitalize;
  }
  .menu>li>a:before {
    content: '';
    position: absolute;
    bottom: 6px;
    background-color: #CC0000;
    transition: 0.3s all;
    width: 35px;
    height: 1px;
    left: 50%;
    transform: translateX(-50%);
    opacity: 0;
    transition: all .3s ease;
    bottom: 25px;
  }
  .menu>li.menu-item-has-children a{
    margin: 0 15px 0 0;
  }
  .menu>li>a:hover:before, .menu>li.current-menu-item>a:before, .menu>li.current-menu-parent a:before {
    width: 100%;
    opacity: 1;
  }
  .menu>li>a>strong.nav_main {
    display: block;
  }

  .menu>li>a>span.nav_sub {
    display: block;
    font-size: 12px;
    font-size: 1.2rem;
  }

     /*
  .menu>li.menu-item-has-children>a:after {
    content: '';
    display: inline-block;
    transform: rotate(135deg);
    width: 6px;
    height: 6px;
    border-top: solid 1px #444444;
    border-right: solid 1px #444444;
    transition: 0.3s all;
    vertical-align: 3px;
    margin: 0px 0 0 6px;
    position: absolute;
    right: -13px;
    top: 8px;
  }
  */


  .menu>li>a:hover:before,
  .menu>li.current-menu-item>a:before,
  .menu>li.current-category-ancestor>a:before,
  .menu>li.current-post-ancestor>a:before,
  .menu>li.current-menu-parent a:before {
    background: #D51C1D;
  }

 /*=========================================================================================
プルダウンメニュー
==========================================================================================*/
.menu-item {
  position: relative;
}

.menu-item .sub_menu_wrapper {
  position: absolute;
  width: 400px;
  top: 100%;
  opacity: 0;
  overflow: hidden;
  transition: 0.3s all;
  left: 50%;
  transform: translateX(-50%);
  pointer-events: none;
}

.menu-item:nth-last-child(-n+1) .sub_menu_wrapper {
  left: inherit;
  right: 0;
  transform: none;
}

.menu-item:hover .sub_menu_wrapper {
  overflow: visible;
  opacity: 1;
  z-index: 9999;
  pointer-events: inherit;
}

.menu-item .sub-menu li a {
  width: 100%;
  display: block;
  margin: 0;
  font-weight: normal;
  -moz-transition: 0.5s;
  -o-transition: 0.5s;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  padding: 15px 10px !important;
  position: relative;
  text-align: center;
  z-index: 1;
  background: #fff;
  border-top: 1px solid #CC0000;
}

.menu-item .sub-menu li:last-child a {
  border-bottom: 1px solid #CC0000;
}

.menu-item .sub-menu li a:hover {
  color: #fff;
  text-decoration: none;
}

.menu-item .sub-menu li a:after {
  content: '';
  border-top: 1px solid var(--main-color);
  background: var(--main-color);
  display: block;
  height: 100%;
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  transform: scaleX(0);
  transition: all .3s ease;
  opacity: 0;
  z-index: -1;
}

.menu-item .sub-menu li a:hover:after {
  transform-origin: center bottom;
  transform: scaleX(1);
  opacity: 1;
}

.menu-item .sub-menu li:last-child a:hover:after {
  border-bottom: 1px solid var(--main-color);
}


  /*=========================================================================================
トップページ色変更 
==========================================================================================*/
  .top_page #header.reverse_h:not(.fixed) {
    background: transparent;
    box-shadow: none;
  }

  .top_page #header.reverse_h+#wrap {
    margin: 0 auto !important;
  }

  .top_page #header.reverse_h:not(.fixed) .head_h1 h1 {
    color: #fff;
  }

  .top_page #header.reverse_h:not(.fixed) .logo img {
    filter: brightness(0) invert(1);
  }

  .top_page #header.reverse_h:not(.fixed) .menu>li>a {
    color: #fff;
  }

  .top_page #header.reverse_h:not(.fixed) .h_hour {
    color: #fff;
  }

  .top_page #header.reverse_h:not(.fixed) .h_tel_area .h_tel {
    color: #fff;
  }

  .top_page #header.reverse_h:not(.fixed) .h_tel_area .h_tel_icon::before {
    background-color: #fff;
  }

  .top_page #header.reverse_h:not(.fixed) .menu>li>a:after {
    background: #fff;
  }

  .top_page #header.reverse_h:not(.fixed) .menu>li.menu-item-has-children>a:before {
    border-top-color: #fff;
    border-right-color: #fff;
  }

  .top_page #header.reverse_h:not(.fixed) .menu>li.current-menu-item>a:after,
  .top_page #header.reverse_h:not(.fixed) .menu>li.current-category-ancestor>a:after,
  .top_page #header.reverse_h:not(.fixed) .menu>li.current-post-ancestor>a:after,
  .top_page #header.reverse_h:not(.fixed) .menu>li.current-menu-parent>a:after {
    background: #fff;
  }

  .top_page #header.reverse_h:not(.fixed) .menu-item .sub-menu li a,
  .top_page #header.reverse_h:not(.fixed) .menu-item .sub-menu li:last-child a {
    border: none;
  }

  .top_page #header.reverse_h:not(.fixed) .h_btn01 a {
    color: #fff;
    border-color: #fff;
  }

  .top_page #header.reverse_h:not(.fixed) .h_btn01 a:hover {
    background-color: var(--main-color);
    border-color: var(--main-color);
  }

  .top_page #header.reverse_h:not(.fixed) .h_btn01 a:after {
    background-color: #fff;
  }

  .top_page #header.reverse_h:not(.fixed) .h_btn01 a:hover:after {
    background-color: #fff;
  }

  .top_page #header.reverse_h:not(.fixed) .h_btn01 a .h_icon01:after {
    background-color: #fff;
  }
}


/*==================================================================================================================================================
PCヘッダーここまで
=================================================================================================================================================*/
/*=========================================================================================
ハンバーガーメニュー 
==========================================================================================*/
@media (max-width : 1060px) {
  .sp_nav {
    display: none;
  }
.h_fax_area{
  display: none;
}
  .sp_nav.sp_nav_on {
    display: block;
  }

  #header {
    padding: 0 0 0 15px;
  }
.h_main_frame {
    height: 60px;
}
  .head_h1 {
    display: none;
  }

  .h_right_area {
    display: flex;
    flex-direction: row;
    gap: 5px;
  }

  .h_hour {
    display: none;
  }

  .contact_area {
    margin: 0;
    gap: 5px;
    z-index: 0;
  }
  .h_contact {
    width: 50px;
    height: 50px;
  }
.h_btn01 {
    width: 50px;
    height: 50px;
    padding: 0;
}
  .h_btn01.pc_view767 {
    display: none;
}
  .h_btn01.sp_view767 {
    display: block;
}
  .h_btn01 a {
    border: 1px solid #555;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
}
  .h_btn01:hover a {
    height: 100%;
}
  .sp_menu {
    width: 50px;
    height: 50px;
  }

  .h_contact a {
    display: block;
    height: 100%;
    background: var(--main-color);
    border: 1px solid var(--main-color);
  }

  .h_mail {
    display: inline-block;
    text-indent: -9999px;
    padding: 0;
    width: 100%;
    height: 100%;
  }

  .h_mail_icon {
    position: relative;
    z-index: 40;
  }

  .h_mail_icon::before {
    content: '';
    display: inline-block;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 21px;
    height: 16px;
    -webkit-mask-image: url(../img/common/h_mail_icon.svg);
    mask-image: url(../img/common/h_mail_icon.svg);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: 100% auto;
    mask-size: 100% auto;
    background-color: #fff;
  }

  .pc_nav_off {
    display: none;
  }
.sub-menu{
  display: none;
}
  /*
メニュー内
==========================================================================================*/
  .nav_wrapper {
    flex-direction: column;
    justify-content: center;
    height: 100vh;
    background: #CC0000;
    transition: 0.5s;
    overflow-y: scroll;
    padding: 50px 20px 150px;
  }

  /*
メニューリスト共通パーツ
==========================================================================================*/
  .menu li a {
    color: #fff;
  }

  .menu li a:hover {
    text-decoration: none;
  }

  /*
メニューリスト親
==========================================================================================*/
  .menu>li {
    position: relative;
    border-bottom: 1px solid #fff;
  }

  .menu>li>a {
    display: inline-block;
    font-size: 18px;
    font-size: 1.8rem;
    padding: 15px 30px 15px 10px;
  }

  .menu>li>a:hover {
    color: #fff;
    text-decoration: none;
  }

  .menu>li>a:after {
    display: none;
  }

  .menu>li.current-menu-item>a {
    color: #fff;
  }

  .menu>li.current-menu-item>a:after {
    display: none;
  }

  .nav_main {
    display: block;
  }

  /*
メニューリスト子
==========================================================================================*/
  .sub_menu_wrapper {
    display: none;
  }

  .menu-item .sub-menu li a {
    display: inline-block;
    font-size: 16px;
    font-size: 1.6rem;
    padding: 10px 10px 10px 30px;
  }

  .sub_menu_toggle {
    position: absolute;
    top: 33px;
    right: 10px;
    transform: translateY(-50%);
    display: block;
    width: 30px;
    height: 30px;
    white-space: nowrap;
    z-index: 100;
  }

  .sub_menu_toggle:before {
    display: block;
    content: '';
    position: absolute;
    width: 10px;
    height: 10px;
    top: 50%;
    left: 50%;
    transition: .2s;
    transform: translate(-50%, -50%) rotate(135deg);
    -webkit-transform: translate(-50%, -50%) rotate(135deg);
    border: solid #fff;
    border-width: 2px 2px 0 0;
  }
  .sub_menu_toggle.selected:before {
    transform: translate(-50%, -50%) rotate(-45deg);
    -webkit-transform: translate(-50%, -50%) rotate(-45deg);
  }

  .sub_menu_toggle.selected:after {
    background-color: transparent;
  }

  .sp_menu_tigger {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    position: relative;
    z-index: 40;
  }

  .sp_menu_tigger span,
  .sp_menu_tigger span:before,
  .sp_menu_tigger span:after {
    width: 30px;
    height: 2px;
    background-color: #c00;
    position: relative;
    transition: 0.3s all;
  }

  .sp_menu_tigger span:before,
  .sp_menu_tigger span:after {
    content: '';
    position: absolute;
  }

  .sp_menu_tigger span:before {
    top: 10px;
  }

  .sp_menu_tigger span:after {
    bottom: 10px;
  }

  .sp_menu_area {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    z-index: -1;
    opacity: 0;
    transition: 0.3s all;
  }

  .nav_area {
    position: fixed;
    width: 100%;
    top: 0;
    right: 0;
    z-index: 30;
    visibility: hidden;
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
    -webkit-transition: -webkit-transform 0.5s, visibility 0s 0.5s;
    transition: transform 0.5s, visibility 0s 0.5s;
  }

  .nav_area.active {
    visibility: visible;
    -webkit-transform: translateX(0%);
    transform: translateX(0%);
    -webkit-transition: -webkit-transform 0.5s;
    transition: transform 0.5s;
  }

  /*
sp_menu_open
==========================================================================================*/
  .sp_menu_tigger.open span {
    background: transparent;
  }

  .sp_menu_tigger.open span:before {
    top: 0;
    transform: rotate(-45deg);
    background: #ffff;
  }

  .sp_menu_tigger.open span:after {
    bottom: 0;
    transform: rotate(45deg);
    background: #fff;
  }

  .sp_menu_area.active {
    opacity: 1;
    z-index: 2;
    background: rgba(255, 255, 255, 0.8);
  }

  #header.scroll .nav_wrapper {
    opacity: 0;
  }
}

@media (max-width : 960px) {
  .head_h1 {
    display: none;
  }
}
