.navOpen {
  overflow-y: hidden;
 -webkit-overflow-scrolling: touch!important; 
 touch-action: none !important;
 pointer-events: none !important;
}
body.navOpen, body.navOpen *, body.navOpen *:hover, body.navOpen *:focus, body.navOpen *:active {
 touch-action: none !important;
 -ms-touch-action: none !important;
 pointer-events: none !important;
} 
body.navOpen .hamburger1, body.navOpen #menu_toggle_mb, body.navOpen #menu_toggle_mb * {
 touch-action: auto !important;
 -ms-touch-action: auto !important;
 pointer-events: visible !important;
}

.hamburger-inner, .hamburger-inner:after, .hamburger-inner:before {
  width: 40px;
  height: 2px;
  background: #fff;
}
.hamburger1 {
  top: 0;
  right: 0;
  position: fixed;
  z-index: 1111;
  padding: 22px 23px 0;
  display: inline-block;
  cursor: pointer;
  transition-property: opacity, filter;
  transition-duration: 0.15s;
  transition-timing-function: linear;
  font: inherit;
  color: #fff;
  text-transform: none;
  margin: 0;
  overflow: visible;
  background: #000;
  width: 86px;
  height: 84px;
  box-sizing: border-box;
}
.hamburger1:hover{
  opacity: .8;
}

.hamburger1.is-active {
  right: 17px;
  padding-top: 19px;
}
.hamburger1:before {
  content: "MENU";
  color: #fff;
  font-size: 14px;
  position: absolute;
  bottom: 14px;
  left: 21px;
  letter-spacing: 0;
  line-height: 1;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "メイリオ", Meiryo, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.navOpen .hamburger1:before{
  content: 'CLOSE';
}
.hamburger-box {
  width: 40px;
  height: 17px;
}
.hamburger-inner:after {
  bottom: -8px;
}
.hamburger-inner::before {
  top: -8px;
}
.navOpen #menu_toggle_mb {
  opacity: 1;
  visibility: visible;
  pointer-events: visible;
}
.navOpen #menu_toggle_mb li {
  opacity: 1;
  transform: matrix(1, 0, 0, 1, 0, 0);
}

/**/
header .menu_toggle {
  padding: 143px 0 2%;
  background: rgba(255, 255, 255, .9);
  color: #565656;
  transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  opacity: 0;
  visibility: hidden;
  position: fixed;
  width: 100% !important;
  top: 0px;
  right: 0;
  height: 100vh;
  overflow-y: scroll;
  z-index: 1000;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  display: block!important;
}
header .menu_toggle ul {
  padding: 0;
  list-style-type: none;
  list-style-position: outside;
}
header .menu_toggle ul li {
  position: relative;
  padding: 0;
  transform: matrix(1, 0, 0, 1, 0, -20);
  transition: all ease 0.5s 0.3s;
  opacity: 0;
  margin-bottom: 8px;
}

header .menu_toggle a {
  display: block;
  text-decoration: none;
  font-size: 20px;
  padding: 0;
  margin: 0;
  position: relative;
}


#ft_fixed {
  position: fixed;
  bottom: 0;
  right: 0;
  left: 0;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  z-index: 999;
}
.has_nav #ft_fixed {
  opacity: 1;
  visibility: visible;
}
#ft_fixed ul{
  z-index: 100;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row;
  flex-flow: row;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
  box-sizing: border-box;
  width: 100%;
  height: 100%;
}
#ft_fixed ul li a{
  width: 100%;
  height: 100%;
  display: block;
}
#ft_fixed li:nth-child(1){
  /*width: 50%;*/
  width: 100%;
}
#ft_fixed li:nth-child(2){
  width: 50%;
}
@media screen and (max-width: 767px) {
  .hamburger1 {
    padding: 13px 15px 0;
    width: 60px;
    height: 61px;
}
.hamburger-box {
  width: 30px;
}
.hamburger-inner, .hamburger-inner:after, .hamburger-inner:before {
  width: 30px;
  height: 3px;
}
.hamburger-inner::before {
  top: -9px;
}
.hamburger-inner:after {
  bottom: -9px;
}
.hamburger1:before {
  font-size: 13px;
  bottom: 8px;
  left: 50%;
  transform: translateX(-50%);
}
.hamburger1.is-active {
  right: 0;
  padding-top: 11px;
}
header .menu_toggle {
  padding: 18vw 0 30%;
}
header .menu_toggle .box {
  display: block;
}
header .menu_toggle .wrap {
  padding: 0 3%!important;
}



/* iPhone X */
@media only screen and (min-device-width: 375px) and (min-device-height: 812px) and (-webkit-device-pixel-ratio: 3) and (orientation: portrait) {
  .has_nav footer:after {
    background: #000;
    content: '';
    position: fixed;
    bottom: 0px;
    left: 0;
    right: 0;
    height: 36px;
    z-index: 99;
  }
  #ft_fixed {
    bottom: calc(env(safe-area-inset-bottom) - 0px);
  }
  #pagetop{
      bottom: calc(env(safe-area-inset-bottom) + 90px) !important;
  }
  footer{
    padding-bottom: calc(env(safe-area-inset-bottom) + 22vw) !important;
  }
}

/* iPhone XR */
@media only screen and (min-device-width: 414px) and (min-device-height: 896px) and (-webkit-device-pixel-ratio: 2) and (orientation: portrait) {
  .has_nav footer:after {
    background: #000;
    content: '';
    position: fixed;
    bottom: 0px;
    left: 0;
    right: 0;
    height: 36px;
    z-index: 99;
  }
  #ft_fixed {
    bottom: calc(env(safe-area-inset-bottom) - 0px);
  }
  #pagetop{
      bottom: calc(env(safe-area-inset-bottom) + 90px) !important;
  }
  footer{
    padding-bottom: calc(env(safe-area-inset-bottom) + 22vw) !important;
  }
}

/* iPhone 11 */
@media only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 2), only screen and (device-width: 375px) and (device-height: 812px) and (-webkit-device-pixel-ratio: 3), only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 3) {
  .has_nav footer:after {
    background: #000;
    content: '';
    position: fixed;
    bottom: 0px;
    left: 0;
    right: 0;
    height: 36px;
    z-index: 99;
  }
  #ft_fixed {
    bottom: calc(env(safe-area-inset-bottom) - 0px);
  }
  #pagetop{
      bottom: calc(env(safe-area-inset-bottom) + 90px) !important;
  }
  footer{
    padding-bottom: calc(env(safe-area-inset-bottom) + 22vw) !important;
  }
}
}


