/*
* Prefixed by https://autoprefixer.github.io
* PostCSS: v8.4.14,
* Autoprefixer: v10.4.7
* Browsers: last 4 version
*/


@charset "utf-8";
@media screen and (min-width:1200px) {
/* レスポンシブメニュー　 */
header {
 display: none;
}
	#nav-drawer { display: none;}
}
@media screen and (max-width:1199px) {
/* レスポンシブメニュー　 */
header {
    position: fixed;
    padding: 10px;
    background: #ccc;
    top: 0;
    right: 0;
    z-index: 9999;
}
#nav-drawer {
  position: relative;
}
/*チェックボックス等は非表示に*/
.nav-unshown {
  display: none;
}
/*アイコンのスペース*/
#nav-open {
  display: inline-block;
  width: 30px;
  height: 22px;
  vertical-align: middle;
}
/*ハンバーガーの形をCSSで表現*/
#nav-open span, #nav-open span:before, #nav-open span:after {
  position: absolute;
  height: 3px; /*線の太さ*/
  width: 25px; /*長さ*/
  border-radius: 3px;
  background: #555;
  display: block;
  content: '';
  cursor: pointer;
}
#nav-open span:before {
  bottom: -8px;
}
#nav-open span:after {
  bottom: -16px;
}
/*閉じる用の薄黒箇所*/
#nav-close {
  display: none;
  position: fixed;
  z-index: 99;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: black;
  opacity: 0;
  -webkit-transition: .3s ease-in-out;
  -o-transition: .3s ease-in-out;
  transition: .3s ease-in-out;
}
/*メニューの中身*/
#nav-content {
  overflow: auto;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  width: 90%;
  max-width: 330px; /*最大幅（お好みで調整を）*/
  height: 100%;
  background: #fff;
  -webkit-transition: .3s ease-in-out;
  -o-transition: .3s ease-in-out;
  transition: .3s ease-in-out;
  -webkit-transform: translateX(-105%);
  -ms-transform: translateX(-105%);
      transform: translateX(-105%);
}
/*チェックがついたら表示させる*/
#nav-input:checked ~ #nav-close {
  display: block;
  opacity: .5;
}
#nav-input:checked ~ #nav-content {
  -webkit-transform: translateX(0%);
  -ms-transform: translateX(0%);
      transform: translateX(0%);
  -webkit-box-shadow: 6px 0 25px rgba(0, 0, 0, .15);
          box-shadow: 6px 0 25px rgba(0, 0, 0, .15);
}
.header-logo-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  display: -moz-flex;
  display: -o-flex;
  display: -ms-flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
          flex-direction: row;
  -moz-flex-direction: row;
  -o-flex-direction: row;
  -ms-flex-direction: row;
}
.accordion {
margin: 3em auto;
max-width: 70vw;
}
.toggle {
display: none;
}
.option {
position: relative;
margin-bottom: 1em;
	border-bottom: 1px solid #E3E3E3;
}
.title,
.content {
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
-webkit-transform: translateZ(0);
        transform: translateZ(0);
-webkit-transition: all 0.3s;
-o-transition: all 0.3s;
transition: all 0.3s;
}
.title {
padding: 1em;
display: block;
color: #333;
font-weight: bold;
}
.title::after,
.title::before {
content: "";
position: absolute;
right: 1.25em;
top: 1.25em;
width: 2px;
height: 0.75em;
background-color: #999;
-webkit-transition: all 0.3s;
-o-transition: all 0.3s;
transition: all 0.3s;
}
.title::after {
-webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
        transform: rotate(90deg);
}
.content {
max-height: 0;
overflow: hidden;
}

.toggle:checked + .title + .content {
max-height: 500px;
-webkit-transition: all 1.5s;
-o-transition: all 1.5s;
transition: all 1.5s;
}
.toggle:checked + .title::before {
-webkit-transform: rotate(90deg) !important;
    -ms-transform: rotate(90deg) !important;
        transform: rotate(90deg) !important;
}
	.content ul{
		padding-left: 1em;
	}
	.content ul li a{
		display: block;
		padding: .5em 0;
		color: #666!important;
	}
	.onebtn{
		padding: 0 1em 1em 1em;border-bottom: 1px solid #E3E3E3;
	}
	.onebtn a{
		font-weight: bold;
		display: block;
		padding: .5em 0;color: #666!important;
	}
}
/*--------------------------*/
.o_img_center {
  text-align: center;
  margin: 2em auto;
}
.o_img_center p {
  text-align: center;

  font-size: .9em;
}
/*　スクロールで固定追従*/
/*===================================*/
.sub-fix-block {
  position: sticky;
  top: 20px;
}
@media screen and (max-width:1024px) {
  .sub-fix-block {
    position: relative;
    top: 0;
  }
}
/* ドロップダウンメニュー*/
/*===================================*/
#g-nav ul {
  position: relative;
  top: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: right;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
#g-nav ul ul {
  display: block;
  margin: 0;
}
#g-nav ul li a {
  position: relative;
  display: block;
  text-decoration: none;
  color: #fff;
  padding: 6px 20px;
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
  text-align: center;
  color: #737373 !important;
  margin-left: 10px;
}
#g-nav ul > li > ul > li > a {
  padding: 10px;
  text-align: left;
}
#g-nav ul > li > ul > li > a span {
  margin-left: 20px;
}
#g-nav ul > li > ul > li > a span:before {
  content: '';
  /*絶対配置で矢印の位置を決める*/
  position: absolute;
  top: 42%;
  left: 13px;
  margin-right: 10px;
  /*矢印の形状*/
  width: 5px;
  height: 5px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}
/*hoverした際の移動*/
#g-nav ul > li > ul > li > a span:hover::before {
  left: 17px;
}
#g-nav ul li a:hover {
  color: #fff;
}
#g-nav ul li.has-child > a::before {
  content: '';
  position: absolute;
  left: -5px;
  top: 18px;
  width: 6px;
  height: 6px;
  border-top: 2px solid #2D287F;
  border-right: 2px solid #2D287F;
  -webkit-transform: rotate(135deg);
  -ms-transform: rotate(135deg);
  transform: rotate(135deg);
}
#g-nav li.has-child ul {
  position: absolute;
  top: 58px;
  left: 0;
  z-index: 4;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  background-color: rgba(255, 255, 255, 0.7);
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
  width: 100%;
  border-radius: 5px;
  visibility: hidden;
  opacity: 0;
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
}
#g-nav li.has-child:hover > ul {
  visibility: visible;
  opacity: 1;
}
#g-nav li.has-child ul li {
  width: 50%;
}
/*見出し*/
#g-nav li.has-child ul li.menu_midashi {
  width: 100%;
  font-size: 1.1em;
  padding: 10px 0;
  border-bottom: 1px solid #fff;
  position: relative;
  background-color: rgba(255, 255, 255, 0.6);
  -webkit-backdrop-filter: blur(3px);
          backdrop-filter: blur(3px);
}
#g-nav li.has-child ul li.menu_midashi span {
  padding-left: 20px;
}
#g-nav li.has-child ul li.menu_midashi span:before {
  content: '';
  /*絶対配置で矢印の位置を決める*/
  position: absolute;
  top: 42%;
  left: 13px;
  /*矢印の形状*/
  width: 8px;
  height: 8px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(136deg);
      -ms-transform: rotate(136deg);
          transform: rotate(136deg);
}
/*画像*/
#g-nav li.has-child ul li.menu_img {
  width: 100% !important;
}
#g-nav li.has-child ul li.menu_img div {
  position: relative;
}
#g-nav li.has-child ul li.menu_img div img {
  width: 100%;
  height: 70px;
  -o-object-fit: cover;
     object-fit: cover;
}
/*画像の上のタイトル*/
#g-nav li.has-child ul li.menu_img div h3 {
  position: absolute;
  top: 20px;
  left: 60px;
  font-size: 1.3em;
  text-shadow: 0px 0px 5px rgb(45 40 127 / 67%), 0px 0px 20px rgb(38 77 38 / 20%);
  color: #fff;
  font-weight: normal;
}
#g-nav li.has-child ul li.p_smp_item010 {
  width: 50%;
}
/* misc */
#g-nav ul li.sp_misc {
  display: none;
}
#g-nav li.has-child ul li a {
  color: #2D287F !important;
  font-size: 1em;
}
#g-nav li.has-child ul li a:hover {
  border-bottom: 3px solid rgba(253, 208, 0, .5);
  -webkit-backdrop-filter: blur(1px);
  backdrop-filter: blur(1px);
  color: #fff;
}
@media screen and (max-width:1200px) {
  #g-nav ul li a {
    padding: 5px;
  }
}
@media screen and (max-width:1200px) {
  /* misc */
  #g-nav ul li.sp_misc {
    display: block;
  }
  #g-nav p {
    display: block;
    margin: 30px auto 0 auto;
    width: 80px;
  }
  #g-nav ul {
    display: block;
    margin: 0;
  }
  #g-nav li.has-child ul {
    position: relative;
    left: 0;
    top: 0;
    width: 100%;
    visibility: visible;
    opacity: 1;
    display: none;
    -webkit-transition: none;
    -o-transition: none;
    transition: none;
    border-radius: 0;
    padding: 0;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  #g-nav ul li {
    border-bottom: 1px solid rgba(255, 255, 255, 0.8);
  }
  #g-nav li.has-child ul li {
    width: 100%;
    text-align: left;
  }
  #g-nav ul li a {
    padding: 15px 20px 15px 40px;
    color: #2D287F;
    margin-left: 0;
    text-align: left;
  }
  #g-nav ul > li > ul > li > a {
    padding: 15px;
    text-align: left;
  }
  #g-nav ul li a:hover {
    color: #fff;
  }
  #g-nav ul li li a {
    padding: 0;
  }
  #g-nav ul li.has-child > a::before {
    top: 29px;
    left: 20px;
    -webkit-transform: rotate(135deg);
    -ms-transform: rotate(135deg);
    transform: rotate(135deg);
  }
  #g-nav ul li.has-child.active > a::before {
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
  /*見出し*/
  #g-nav li.has-child ul li.menu_midashi {
    width: 100%;
    font-size: 1.1em;
    border-bottom: none;
    background-color: rgba(5, 30, 65, 0.4);
  }
  #g-nav li.has-child ul li.menu_midashi a {
    text-align: center;
  }
  /*画像*/
  #g-nav li.has-child ul li.menu_img {
    display: none;
  }
  /*画像の上のタイトル*/
  #g-nav li.has-child ul li.menu_img div h3 {
    display: none;
  }
  #g-nav {
    display: none;
  }
  #g-nav.panelactive {
    display: block;
    position: fixed;
    z-index: 99;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background-color: rgba(255, 255, 255, 0.8);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
  }
  #g-nav-list {
    opacity: 0;
    position: fixed;
    z-index: 99;
    width: 100%;
    height: 100vh;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }
  #g-nav.panelactive #g-nav-list {
    opacity: 1;
  }
  #g-nav ul {
    opacity: 0;
    width: 90%;
    margin: 0 auto 60px auto;
  }
  #g-nav ul ul {
    margin: 0;
  }
  #g-nav.panelactive ul {
    opacity: 1;
  }
  #g-nav li.has-child ul li.p_smp_item010 {
    width: 100%;
  }
}
.openbtn {
  display: none;
}
@media screen and (max-width:1200px) {
  /*ボタン外側*/
  .openbtn {
	  display: none;
/*    display: block;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 999;
    cursor: pointer;
    width: 50px;
    height: 50px;
    background-color: #2D287F;
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);*/
  }
  /*ボタン内側*/
  .openbtn span {
    display: inline-block;
    -webkit-transition: all .4s;
    -o-transition: all .4s;
    transition: all .4s;
    position: absolute;
    left: 14px;
    height: 2px;
    border-radius: 5px;
    background: #fff;
    width: 45%;
  }
  .openbtn span:nth-of-type(1) {
    top: 13px;
  }
  .openbtn span:nth-of-type(2) {
    top: 19px;
  }
  .openbtn span:nth-of-type(3) {
    top: 25px;
  }
  .openbtn span:nth-of-type(3)::after {
    content: "Menu";
    position: absolute;
    top: 5px;
    left: -2px;
    color: #fff;
    font-size: 0.6rem;
    text-transform: uppercase;
  }
  .openbtn.active span:nth-of-type(1) {
    top: 14px;
    left: 18px;
    -webkit-transform: translateY(6px) rotate(-45deg);
    -ms-transform: translateY(6px) rotate(-45deg);
    transform: translateY(6px) rotate(-45deg);
    width: 30%;
  }
  .openbtn.active span:nth-of-type(2) {
    opacity: 0;
  }
  .openbtn.active span:nth-of-type(3) {
    top: 26px;
    left: 18px;
    -webkit-transform: translateY(-6px) rotate(45deg);
    -ms-transform: translateY(-6px) rotate(45deg);
    transform: translateY(-6px) rotate(45deg);
    width: 30%;
  }
  .openbtn.active span:nth-of-type(3)::after {
    content: "Close";
    -webkit-transform: translateY(0) rotate(-45deg);
    -ms-transform: translateY(0) rotate(-45deg);
    transform: translateY(0) rotate(-45deg);
    top: 5px;
    left: 4px;
  }
}
/*内側の線*/
.pushcircle:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  /*線の形状*/
  width: 90%;
  height: 90%;
  border-radius: 10px;
  -webkit-transform: translate(-50%, -50%) scale(1.1);
  -ms-transform: translate(-50%, -50%) scale(1.1);
  transform: translate(-50%, -50%) scale(1.1);
  -webkit-transition: .3s ease;
  -o-transition: .3s ease;
  transition: .3s ease;
}
.sub-btn-list li:first-child a {
  background: #2D287F;
}
.sub-btn-list li:last-child a {
  background: #2D287F;
}
.sub-btn-list li:first-child a.pushcircle:after {
  border: 1px solid #2D287F;
}
.sub-btn-list li:last-child a.pushcircle:after {
  border: 1px solid #2D287F;
}
/*hoverをしたら枠線が小さくなる*/
.sub-btn-list li:first-child a.pushcircle:hover:after, .sub-btn-list li:last-child a.pushcircle:hover:after {
  -webkit-transform: translate(-50%, -50%) scale(1);
  -ms-transform: translate(-50%, -50%) scale(1);
  transform: translate(-50%, -50%) scale(1);
  border-color: rgba(255, 255, 255, 0.8);
}