@charset "UTF-8";

.ex-motion {
  transform: translate3d(0, 0, 0) perspective(0);
  -webkit-transform: translate3d(0, 0, 0);
  backface-visibility:hidden;
}

body {
  /*color: #414042;*/
  max-width: 100vw;
  overflow-x: hidden;
  font-family: 'M PLUS 1p',"Hiragino Sans W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
li {
  list-style-type: none;
}
.eisu01 {
  font-family: 'Roboto Condensed', sans-serif;
}
.eisu02 {
  font-family: 'Arvo', sans-serif;
}
.img-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: "object-fit: cover;";
}
.img-contain img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  font-family: "object-fit: contain;";
}
.img-cover-a a img {
  width: 100%!important;
  height: 100%!important;
  object-fit: cover;
  font-family: "object-fit: cover;";
}
.img-contain-a a img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  font-family: "object-fit: contain;";
}

.a-div-non{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  text-indent:-99px;
}
.a-div{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  /*text-indent:-99px;*/
}
.a-div:hover{
  background-color:#FFF;
  filter:alpha(opacity=50);
  -moz-opacity: 0.5;
  opacity: 0.5;
  transition: all 0.6s ease 0s;
}

.overflow-x-hidden {
  overflow-x: hidden;
}








.color-white {
  color: #fff;
}
.color-orenge {
  color: #ed7000;
}
.color-red {
  color: #FA0A00;
}
.color-blue {
  color: #0A1E6F;
}
.color-lightblue {
  color: #3F4AB6;
}
.color-gray {
  color: #707070;
}



/* color */
.text-white {
  color: #fff;
}
.text-darkblue {
  color: #152063;
}
.text-black {
  color: #414042;
}
.text-gray {
  color: #707070;
}
.text-magenta {
  color: #c82f8b;
}
.text-orenge {
  color: #ed7000;
}
.text-red {
  color: #e85c36;
}
.text-mainbule {
  color: #152063;
}
.text-cian {
  color: #00aacb;
}

/* background */
.bg-mainbule {
  background: #152063;
}
.bg-white {
  background-color: #fff;
}
.bg-black {
  background-color: #000;
}
.bg-darkgray {
  background-color: #38373B;
}
.bg-gray {
  background-color: #707070;
}
.bg-newgray {
  background-color: #b3b0b0;
}
.bg-lightgray {
  background-color: #F4F3F3;
}
.bg-blue {
  background-color: #0A1E6F;
}
.bg-lightblue {
  background-color: #3F4AB6;
}
.bg-beige {
  background-color: #9b7d69;
}
.bg-orange {
  background: #f08300;
}
.bg-lightorange {
  background: #F6E8D3;
}
.bg-magenta {
  background: #c82f8b;
}
.bg-green {
  background: #6fba2c;
}
.bg-line {
  background: #00c300;
}
.bg-cian {
  background: #00aacb;
}
.bg-lightblue {
  background: #e7e8ef;
}


/* border */
.border-magenta {
  border: solid #c82f8b 1px;
}
.border-cian {
  border: solid #00aacb 1px;
}
.border-white {
  border: solid #fff 1px;
}
.border-gray {
  border: solid #464747 1px;
}
.border-lightgray {
  border: solid #f0f0ef 1px;
}
.border-mainbule {
  border: solid #152063 1px;
}
.border3 {
  border-top: solid 1px #464747;
  border-left: solid 1px #464747;
  border-right: solid 1px #464747;
}
.bbb {
  border-bottom: solid 1px #464747;
}
.btb {
  border-top: solid 1px #464747;
}
.blb {
  border-left: solid 1px #464747;
}
.border3-or {
  border-top: solid 1px #f08300;
  border-left: solid 1px #f08300;
  border-right: solid 1px #f08300;
}
.bbb-or {
  border-bottom: solid 1px #f08300;
}
.blb-or {
  border-left: solid 1px #f08300;
}


/* border-radius */
.border-radius10 {
    border-radius: 10px;
}
.border-radius20 {
    border-radius: 20px;
}
.border-radius30 {
    border-radius: 30px;
}
.border-radius40 {
    border-radius: 40px;
}
.bb-white {
  border-bottom: solid 1px #fff;
}
.bb-black {
  border-bottom: solid 1px #000;
}
.bb-dotted {
  border-bottom: dotted 1px #464747;
}

/* font-size */
.f05 {
  font-size: .5rem;
}
.f06 {
  font-size: .6rem;
}
.f07 {
  font-size: .7rem;
}
.f08 {
  font-size: .8rem;
}
.f09 {
  font-size: .9rem;
}
.f1 {
  font-size: 1rem;
}
.f12 {
  font-size: 1.2rem;
}
.f15 {
  font-size: 1.5rem;
}
.f18 {
  font-size: 1.8rem;
}
.f2 {
  font-size: 2rem;
}
.f21 {
  font-size: 2.1rem;
}
.f22 {
  font-size: 2.2rem;
}
.f23 {
  font-size: 2.3rem;
}
.f24 {
  font-size: 2.4rem;
}
.f25 {
  font-size: 2.5rem;
}
.f3 {
  font-size: 3rem;
}



a {
  color: #414042;
  text-decoration: none;
}


.sidebar {
  position: fixed;
	z-index: 10;
	width: 300px;
	box-shadow: 0 0 5px 1px rgb(115 115 115 / 30%);
}
main {
	width : calc(100% - 300px) ;
  margin-left: 300px;
}

.max-width1200 {
  max-width: 1200px;
  margin: 0 auto;
}
.max-width1000 {
  max-width: 1000px;
  margin: 0 auto;
}
.max-width810 {
  max-width: 810px;
  margin: 0 auto;
}

.bg-effect {
  background:url(/assets/images/common/bg.jpg);
  width: calc(100% - 300px);
  height: 100%;
  position: fixed;
  z-index: -10;
}
.effect-wrap {
  position: relative;
  width: 100%;
  height: 100%;
}
.effect-wrap01 {
  position: absolute;
  width: 100%;
}
.effect-wrap02 {
  position: absolute;
  width: 100%;
}
#bg-effect01 {
    background-image: url(/assets/images/common/top-bg02@2x.png);
    position: absolute;
    width: 100%;
    height: 100%;
    top: calc((var(--vh, 1vh) * 100) - calc( 100vw * 360 / 1920 ));
    left: 0;
    background-position: left top ;
    background-repeat: no-repeat;
    background-size: 380px 650px;
    transition-property: transform;
    /*transition-duration: 0.7s;*/
    transition-duration: 0.9s;
    transition-delay: -0.035s;
    mix-blend-mode: multiply;
}
#bg-effect02 {
    background-image: url(/assets/images/common/top-bg03@2x.png);
    position: absolute;
    width: 100%;
    height: 100%;
    top: calc((var(--vh, 1vh) * 100) - calc( 100vw * 78 / 1920 ));
    left: 0;
    background-position: right top ;
    background-repeat: no-repeat;
    background-size: 380px 650px;
    transition-property: transform;
    /*transition-duration: 0.7s;*/
    transition-duration: 0.9s;
    transition-delay: -0.035s;
    mix-blend-mode: multiply;
}

.breadcrumb {
  background-color: #fff;
  padding: 6px 10px;
}
.breadcrumb-item {
  font-size: 12px;
}
.breadcrumb-item a {
  color: #3F4AB6;
}


.sub-title {
  position: relative;
  width: 100%;
  height: 211px;
}
.sub-title01 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 211px;
  padding-left: 220px;
}
.sub-title02 {
  position: absolute;
  top: 0;
  left: 0;
  height: 211px;
}
.sub-title02 img {
  object-position: left;
}
.sub-title03 {
  position: absolute;
  top: 70px;
  left: 25px;
  height: 50px;
}
.sub-title02 img , .sub-title03 img {
  object-position: left;
}
.sub-title04 {
  position: absolute;
  top: 100px;
  left: 45px;
  font-size: 20px;
  font-weight: 600;
}




/*==回転するリングの設定*/
.ring{
  /*animation:6s linear infinite rotation1;*/
}
@keyframes rotation1{
  0%{ transform:rotate(0);}
  100%{ transform:rotate(360deg); }
}



/*========= HEADER ===============*/
/*========= ドロップダウンのためのCSS ===============*/
/*==ナビゲーション全体の設定*/
nav ul{
  list-style: none;
  text-align: center;
}
/*ナビゲーションのリンク設定*/
nav ul li a{
    /*矢印の基点にするためrelativeを指定*/
  position: relative;
  display: block;
  text-decoration: none;
  color: #000;
  /* padding:20px 15px; */
  height: 100%;
  transition:all .3s;
}
nav ul li a:hover{
  color:#666;
}
nav ul li li a{
    padding:9px 0;
}

/*==2階層目以降の画像設定*/
nav ul li.has-child dt{
  overflow: hidden;
  height: 15vh;
  margin:0 0 10px 0;
}

/*== 2階層目の設定 */
nav li.has-child ul{
  /*絶対配置で位置を指定*/
  position: absolute;
  top:0;
  left:300px;
  z-index: 4;
  /*形状を指定*/
  width:300px;
  height: 100vh;
  background:rgba(63,74,182,0.9);
  /*はじめは非表示*/
  visibility: hidden;
  opacity: 0;
  /*アニメーション設定*/
  transition: all .3s;
}

/*hoverしたら表示*/
nav li.has-child:hover > ul{
  visibility: visible;
  opacity: 1;
}

/*ナビゲーションaタグの形状*/
nav li.has-child ul li a{
  color: #fff;
}

.gmanu-wrap {
	width: 300px;
  height: 100vh;
  overflow-y: scroll;
  /* IE, Edge 対応 */
  -ms-overflow-style: none;
  /* Firefox 対応 */
  scrollbar-width: none;
}

/* Chrome, Safari 対応 */
.gmanu-wrap::-webkit-scrollbar {
  display:none;
}
.menu-ilust {
  width: 70px;
}
.gmenu {
	width: 100%;
	height: 85px;
	padding: 10px 0 0 10px;
	background: url(/assets/images/common/gmenu-bg@2x.png) no-repeat top left / contain #0A1E6F;
	border-bottom: solid 1px #fff;
}
.gmenu:hover {
	background: #3F4AB6;
}
.gmenu01 {
	font-size: 12px;
	text-align: left;
}
.gmenu02 {
	font-size: 24px;
	font-weight: 600;
	text-align: left;
	line-height: 28px;
}
.gmenu03 {
	text-align: left;
	padding-left: 40px;
	background: url(/assets/images/common/footer-arrow@2x.png) no-repeat center left 25px / 8px 14px;
}
.gmenu03:hover {
	background: url(/assets/images/common/footer-arrow@2x.png) no-repeat center left 25px / 8px 14px #0A1E6F;
}

.tube-box {
  width: 250px;
}

.gmenu04 {
  position: relative;
	width: 100px;
	height: 100px;
}
.gmenu05 {
  border: unset;
  background: #F0F0F0;
  height: 35px;
}
input::placeholder {
  color: #cdcdcd;
  font-size: .8em;
}
.gmenu06 {
  border: unset;
	background: url(/assets/images/common/gmenu-serch@2x.png) no-repeat center center / contain #a6a3a3;
}
.gmenu07 {
	font-size: 16px;
}
.gmenu08 {
	font-size: 32px;
  font-weight: 600;
  line-height: 36px;
}
.gmenu09 {
	font-size: 12px;
}
.gmenu-box {
  width: 210px;
	background: url(/assets/images/common/gmenu-arrow@2x.png) no-repeat center right 5px / 8px 14px;
}
.Hlogo {
	padding: 30px;
}
.submenu {
	padding-top: 210px;
}
.sns-icon {
  position: relative;
  width: 60px;
  height: 60px;
  text-align: center;
  font-size: 10px;
  color: #333;
}
.sns-icon {
  position: relative;
  width: 60px;
  height: 60px;
}
.gmenu-btn01 a {
  display: block;
  border-radius: 5px;
  background: url(/assets/images/common/footer-arrow@2x.png) no-repeat center left 10px / 8px 14px #333;
  color: #ffffff;
  width: 220px;
  padding: 5px 5px 5px 35px;
  margin: 2px auto;
  transition: all 0.6s ease 0s;
}
.gmenu-btn01 a:hover {
  background: url(/assets/images/common/footer-arrow@2x.png) no-repeat center left 15px / 8px 14px #999;
  transition: all 0.6s ease 0s;
}

.gmenu-btn02 a {
  display: block;
  border-radius: 5px;
  background: url(/assets/images/common/footer-arrow@2x.png) no-repeat center left 10px / 8px 14px #0A1E6F;
  color: #ffffff;
  width: 220px;
  padding: 5px 5px 5px 35px;
  margin: 2px auto;
  transition: all 0.6s ease 0s;
}
.gmenu-btn02 a:hover {
  background: url(/assets/images/common/footer-arrow@2x.png) no-repeat center left 15px / 8px 14px #0a58ca;
  transition: all 0.6s ease 0s;
}




.btn01 a {
  position: relative;
    display: block;
    width: 180px;
    border: solid 2px #3F4AB6;
    border-radius: 30px;
    color: #3F4AB6;
    font-size: 14px;
    line-height: 26px;
    text-align: center;
    text-decoration: none;
  transition: all 0.6s ease 0s;
}
.btn01 a:hover {
    display: block;
    width: 180px;
    border: solid 2px #3F4AB6;
    border-radius: 30px;
    background-color: #3F4AB6;
    color: #fff;
    font-size: 14px;
    line-height: 26px;
    text-align: center;
    text-decoration: none;
  transition: all 0.6s ease 0s;
}
.btn01 a:after {
    position: absolute;
    top: 12px;
    right: -10px;
    content: "";
    height: 2px;
    background: #3F4AB6;
    width: 20px;
  transition: all 0.6s ease 0s;
}
.btn01 a:hover:after {
    position: absolute;
    top: 12px;
    right: 0;
    content: "";
    height: 2px;
    background: #3F4AB6;
    width: 0px;
  transition: all 0.6s ease 0s;
}

.btn-more a {
    position: relative;
    display: block;
    width: 100%;
    border: solid 2px #3F4AB6;
    border-radius: 30px;
    color: #3F4AB6;
    font-size: 12px;
    font-weight: 600;
    line-height: 22px;
    text-align: center;
    text-decoration: none;
    transition: all 0.6s ease 0s;
}
.btn-more a:hover {
    display: block;
    width: 100%;
    border: solid 2px #3F4AB6;
    border-radius: 30px;
    background-color: #3F4AB6;
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    line-height: 22px;
    text-align: center;
    text-decoration: none;
    transition: all 0.6s ease 0s;
}
.btn-more a:before {
    position: absolute;
    top: 10px;
    left: -10px;
    content: "";
    /* border: solid 1px #3F4AB6; */
    width: 20px;
    height: 2px;
    transition: all 0.6s ease 0s;
    background: #3F4AB6;
}
.btn-more a:hover:before {
    position: absolute;
    top: 10px;
    left: 0;
    content: "";
    height: 2px;
    background: #3F4AB6;
    width: 0px;
    transition: all 0.6s ease 0s;
}

.cont-btn01 {
  display: block;
  background: #e7e8ef;
  border: solid 1px #152063;
  border-radius: 30px;
  color: #152063;
  font-size: .9rem;
  text-align: center;
  padding: 8px 0;
  transition: all 0.6s ease 0s;
}
.cont-btn01:hover {
  color: #fff;
  background: #152063;
  transition: all 0.6s ease 0s;
}
.cont-btn02 {
  display: block;
  width: 100%;
  background: #152063;
  border: solid 1px #fff;
  border-radius: 40px;
  color: #fff;
  font-size: 1.5rem;
  font-weight: 600;
  text-align: center;
  padding: 15px 0;
  transition: all 0.6s ease 0s;
}
.cont-btn02:hover {
  color: #fff;
  background: #3F4AB6;
  transition: all 0.6s ease 0s;
}
.cont-btn03 {
  display: block;
  width: 100%;
  background: #707070;
  border: solid 1px #fff;
  border-radius: 40px;
  color: #fff;
  font-size: .8rem;
  text-align: center;
  padding: 8px 0;
  transition: all 0.6s ease 0s;
}
.cont-btn03:hover {
  color: #fff;
  background: #000;
  transition: all 0.6s ease 0s;
}

.arrow-forward {
  position: relative;
}
.arrow-forward:after {
  content: '\e5e1';
  font-family: 'Material Icons';
  padding-right: .5rem;
  position: absolute;
  right: 0;
}



.catch01 {
  border-radius: 20px;
  font-size: 18px;
  font-weight: 600;
  color: #fff;
  line-height: 30px;
  padding-left: 15px;
  background: #38373B;
}

.catch-inin {
  border-radius: 20px;
  font-size: 18px;
  font-weight: 600;
  color: #fff;
  line-height: 40px;
  padding-left: 15px;
  background: #dc3545;
}
.common-title {
  font-size: 22px;
  font-weight: 600;
  line-height: 32px;
}

.common-text {
  font-size: 14px;
  line-height: 28px;
}

.Bbox-icon {
    position: absolute;
    top: 10px;
    left: 10px;
    padding: 5px 10px;
    font-size: 12px;
    color: #fff;
  border-radius: 10px;
}
.Dbox-icon {
    padding: 5px 10px;
    font-size: 12px;
    color: #fff;
    border-radius: 10px;
}

.Bbox-icon01 {
  background: #C82F8B;
}
.Bbox-icon02 {
  background: #C3A928;
}
.Bbox-icon03 {
  background: #85b91f;
}
.Bbox-icon04 {
  background: #7800a7;
}
.Bbox-icon05 {
  background: #6BB4DF;
}
.Bbox-price {
  font-size: 20px;
  font-weight: 600;
  color: #E03F07;
  text-align: right;
  padding: 0;
}
.Bbox-price span {
  font-size: 12px;
  font-weight: 400;
  color: #666;
}
.Bbox-space {
  font-size: 12px;
  line-height: 20px;
}
.Bbox-catch {
  font-size: 16px;
  line-height: 20px;
}
.Bbox-soldout {
  border-radius: 20px;
  color: #fff;
  text-align: center;
  font-size: 12px;
  line-height: 28px;
  background: #dc3545;
}

.next-prev-btn {
  height: 20px;
}


.pager a {
    width: 20px;
    height: 30px;
    font-size: 14px;
    line-height: 30px;
    text-align: center;
    background: #ffffff;
    border: solid 1px #cdcdcd;
    color: #000;
    display: block;
}

.pager a:hover {
    background: #cdcdcd;
}


.text-required {
  font-size: .6ren;
  color: #FA0A00;
}

/*========= FOOTER ===============*/

footer {
    background-color: #fff;
    width: 100%;
}
.fmenu01 {
  width: 100%;
}
.fmenu02 {
  font-size: 12px;
}
.fmenu03 {
  font-size: 24px;
  font-weight: 600;
  line-height: 28px;
}
.fmenu04 {
  font-size: 12px;
}
.copyright {
  font-size: 10px;
}

.fmenu05 {
    font-size: 16px;
    font-weight: 600;
    background: url(/assets/images/common/footer-arrow@2x.png) no-repeat center left / 8px 14px;
    color: #fff;
    padding-left: 14px;
    text-decoration: none;
    margin-bottom: 6px;
}
.fmenu06 a {
    font-size: 12px;
    color: #fff;
    text-decoration: none;
}
.fmenu06 a:hover {
  text-decoration: underline;
}
.fmenu07 a {
    font-size: 12px;
    color: #fff;
    text-decoration: none;
}
.fmenu07 a:hover {
  text-decoration: underline;
}




.anim-box.fadeup.is-animated {
  animation: fadeup 3s cubic-bezier(0.33, 1, 0.68, 1) 1 forwards;
}

@keyframes fadeup {
  0% {
    transform: translateY(30px);
    opacity: 0;
  }
  80% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}




.float-button__wrap {
  display: none;/*最初は隠す*/
  width: 200px;
  height: auto;
  position: fixed;
  bottom: 0;
  right: 0;
  z-index: 10;
}


/* Bnr
-----------------------------------------*/
.Bnr{
  width: 600px;
  height: auto;
  position: fixed;
  bottom: 20px;
  left: calc(50% + 150px);
  z-index: 10;
  display: none;
  transform: translateX(-50%);
  -webkit- transform: translateX(-50%);
}
.Bnr .Bnr__img{
  /* position: fixed; */
  bottom: 0;
  box-shadow: 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
  z-index: 88;
}
.Bnr__img__inner{
  width: 100%;
  /* height: 80px; */
  box-sizing:border-box;
  padding: 5px;
  background-color: #fafafa;
}
.Bnr .Bnr__img__inner a{
  display: block;
}
.Bnr .Bnr__img p.close{
  position: absolute;
  left: -10px;
  top: -10px;
  background: #99b822;
  border-radius: 20px;
}
.Bnr .Bnr__img p.close a{
  display: block;
  width: 25px;
  height: 25px;
  text-align: center;
}
.Bnr .Bnr__img p.close a span{
  display: block;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.Bnr .Bnr__img p.close a i{
  font-size: 20px;
  z-index: 888;
  color: #fff;
}



@media (max-width: 640px) {
  .Bnr{
    width: 90%;
    left: 5%;
    transform: unset;
    -webkit- transform: unset;
  }
}




@media (max-width: 991.98px) {


  /* font-size */
  .spf05 {
    font-size: .5rem;
  }
  .spf06 {
    font-size: .6rem;
  }
  .spf07 {
    font-size: .7rem;
  }
  .spf08 {
    font-size: .8rem;
  }
  .spf09 {
    font-size: .9rem;
  }
  .spf1 {
    font-size: 1rem;
  }
  .spf12 {
    font-size: 1.2rem;
  }
  .spf15 {
    font-size: 1.5rem;
  }
  .spf18 {
    font-size: 1.8rem;
  }
  .spf2 {
    font-size: 2rem;
  }
  .spf25 {
    font-size: 2.5rem;
  }
  .spf3 {
    font-size: 3rem;
  }







/*========= HEADER ===============*/

.sidebar {
    position: fixed;
    width: 100%;
    min-height: unset;
}
main {
	width : 100% ;
  padding-top: 120px;
  margin-left: 0;
}

.max-width1200 {
    width: 100%;
    max-width: unset;
}
.max-width810 {
    width: 100%;
    padding-right: var(--bs-gutter-x,.75rem);
    padding-left: var(--bs-gutter-x,.75rem);
    margin: 0 auto;
}


.bg-effect {
  width: 100%;
}
#bg-effect01 {
    background-size: 160px 325px;
}
#bg-effect02 {
    background-size: 160px 325px;
}



nav{
	background:#333;
	color: #fff;
}
nav li.has-child ul li{
	text-align: left;
}
nav li.has-child ul li dl{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
nav li.has-child ul li dt{
	width:30%;
	height: auto;
	margin: 0;
}
nav li.has-child ul li dd{
	width:64%;
}
nav li.has-child ul{
	position: fixed;
	left:0;
	top:120px;
	width:100%;
	height: 100%;
	visibility:visible;/*JSで制御するため一旦表示*/
	opacity:1;/*JSで制御するため一旦表示*/
	display: none;/*JSのslidetoggleで表示させるため非表示に*/
	transition:none;/*JSで制御するためCSSのアニメーションを切る*/
  padding-top: 10px;
}
nav ul li a{
	color: #fff;
  padding-top: 10px;
  padding-bottom: 10px;
}

/*矢印の位置と向き*/
nav ul li.has-child a::before{
    transform: rotate(135deg);
	left:20px;
	right: inherit;
}
nav ul li.has-child.active a::before{
    transform: rotate(-45deg);
}

.sp-header {
  position: relative;
  z-index: 30;
  background: #fff;
  height: 50px;
}
.gmanu-wrap {
  width: 100%;
  height: unset;
  overflow-y: unset;
}
.menu-ilust {
  width: auto;
}
.gmenu {
  position: relative;
  /*width: 25%;*/
  width: 33.3%;
  height: 70px;
  padding: 0;
  background:  #3F4AB6;
  border-bottom: solid 1px #fff;
}
.gmenu01 {
	display: none!important;
}
.gmenu02 {
    font-size: 14px;
    font-weight: 600;
    text-align: center;
    line-height: 20px;
}
.gmenu-box {
    width: 100%;
    position: absolute;
    top: 49px;
    background: #0b1e6f;
}
.spmenu-a {
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
    border: none;
}
.submenu {
  width: 100%;
  height: 100%;
  padding-top: 0;
}
.spH-logo {
  height: 50px;
  position: relative;
    padding: 0 0 0 5px;
}
.spH-logo a {
  position: absolute;
  width: 130px;
  top: 50%;
  transform: translateY(-50%) ;
  -webkit- transform: translateY(-50%) ;
}
.spH-icon01 {
  width: 35px;
  height: 35px;
  padding-top: 7px;
}
.spH-icon02 {
  width: 50px;
  height: 50px;
  margin-left: 15px;
}




/*ハンバーガーボタン*/
.hamburger {
    display: block;
    position: fixed;
    z-index: 3;
    right: 0;
    top: 0;
    width: 50px;
    height: 50px;
    cursor: pointer;
    text-align: center;
    padding: 0;
}

#gnav-btn {
/*  color: gray;
  padding: 10px;
  font-size: 30px;*/
  position: fixed;
/*  top: 10px;
  right: 10px;*/
  z-index: 100;
}
#gnav-input:checked ~ #gnav-content {
  top: 0;
}
#gnav-input:checked ~ #overlay {
  opacity: 1;
  background: rgba(0,0,0,0.5);
  transition: all 0.6s ease 0s;
  position: fixed;
  top: 0;
  left:0;
  z-index: 5;
  width: 100%;
  height: 100%;
}
#gnav-content {
  position: fixed;
  top: -155%;
  right: 0;
  z-index: 20;
  transition: all 0.6s ease 0s;
  width: 100%;
  overflow-y: scroll;
  overflow-x: hidden;
  height: 100%;
  background: #3F4AB6;
  padding-top: 60px;
}
#overlay {
  opacity: 0;

}
.humb-menu__title {
  padding: 1rem;
}
#gnav-content > label {
  display: flex;
  justify-content: space-between;
  padding: 0.5rem 2rem;
  cursor: pointer;
  margin-bottom: 0;
/*  border-top: 0.5px solid #c7c5c5;*/
}

#gnav-content > label:hover {
   background-color: #0b1e6f;
}
.humb-menu input {
  display: none;
}
.humb-menu .accshow {
  height: 0;
  overflow: hidden;
  transition: all 0.6s ease 0s;
}
.humb-menu .accshow p {
  padding: 1.5rem;
}
.humb-menu .cssacc:checked + .accshow {
  height: auto;
  padding: 1.5rem 0;
  background: rgba(0,0,0,0.5);
  transition: all 0.6s ease 0s;
}
.bmenu01 {
  font-size: 1rem;
  color:#fff;
  text-align: left;
  padding-left: 20px;
  background: url(/assets/images/common/footer-arrow@2x.png) no-repeat center left / 8px 14px;
}

.bmenu02 {
  display: block;
  color: #fff;
  font-size: 0.6rem;
}
.bmenu03 {
  color:#fff;
}
.bmenu04 {
  padding: 0.5rem 2rem;
}
.bmenu04 a {
  font-size: .9rem;
  color:#fff;
  text-decoration: none;
}
.bmenu04 a:hover {
  font-size: .9rem;
  color:#fff;
  text-decoration: underline;
}


.sub-title {
  height: 100px;
}
.sub-title01 {
  height: 100px;
  padding-left: 90px;
}
.sub-title02 {
  height: 100px;
}
.sub-title03 {
  display: none;
}
.sub-title04 {
  position: absolute;
  top: 40px;
  left: 15px;
  font-size: 14px;
}
.sub-title02 img , .sub-title03 img {
  object-position: left;
}



.posi-rela {
  position: relative;
}
.posi-rela a {
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  text-indent:-999px;
}


.btn01 a {
  margin: 0 auto;
  background: #fff;
}


.Bbox-icon {
    font-size: 10px;
}
/*========= FOOTER ===============*/

.fmenu01 {
  width: 90%;
}
.fmenu02 {
  font-size: 11px;
}
.fmenu06 {
  font-size: 14px;
}





}/*max-width*/


.icon-npd {
  transform: scale(0.75);
  transform-origin: top left;
}

.icon-npd.origin-bl {
  transform-origin: bottom left;
}

.icon-npd.nm-3 {
  transform: scale(0.75) translate(-1rem, -1rem);
}

.icon-npd.sc50 {
  transform: scale(0.5);
}

.icon-npd.sc50.nm-3 {
  transform: scale(0.5) translate(-1rem, -1rem);
}

.icon-npd.blink,
.icon-npd .blink {
  animation: ani-blink 1.0s ease-in 0s infinite alternate both;
}

@keyframes ani-blink {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

.movie-label {
  position: absolute;
  bottom: 0;
  right: 0;
  color: #fff;
  background-color: #152063aa;
  padding: 0.25rem 0.5rem;
}
