.submenu_smp{
  display: none !important;
}
/*
 ナビゲーション（PC）
----------------------------------------------------------- */
.wrapper_navi {
  position: relative;
  width: 200px;
  z-index: 110;
  background-color: #fff;
  box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.15);
}
.wrapper_navi_inner {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  height: 100vh;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  overflow-x: hidden;
  overflow-y: auto;
}
.wrapper_navi_inner a {
  color: #063e8d;
}
/*ロゴ----------------------------------------------------*/
.wrapper_navi_inner h1 {
  -webkit-box-flex: 1;
  flex: 1;
  width: 158px;
  min-height: 55px;
  max-height: 115px;
  padding-top: 10px;
  padding-bottom: 10px;
  margin: 0 auto;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
/*ナビ----------------------------------------------------*/
.navigation {
  -webkit-box-flex: 1;
  flex: 1;
  min-height: 320px;
  max-height: 400px;
}
.navigation_menu {
  height: 100%;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.navigation_menu li {
  -webkit-box-flex: 1;
  flex: 1;
  position: relative;
  width: 100%;
  vertical-align: middle;
  color:
  #063e8d;
  font-weight: bold;
  font-size: 15px;
  cursor: pointer;
}
.navigation_menu li a {
  display: table;
  position: relative;
  width: 100%;
  width: calc(100% - 33px);
  height: 100%;
  padding-left: 18px;
}
.navigation_menu li a .blank{
  width: 16px;
  margin-left: 10px;
  vertical-align: middle;
}
.navigation_menu li a::after{
  content: '';
  display: block;
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  height: 20px;
  width: 1px;
  background-color: #d2d7e4;
}
.navigation_menu li a:hover{
  background-color: #edf0f8;
}
.navigation_menu li span{
  display: table-cell;
  height: 100%;
  vertical-align: middle;
}
.navigation_menu li .ico{
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1;
  width: 33px;
  height: 100%;
  background: url(/common/img/ico_arrow.svg) no-repeat center center;
  background-size: 6px 8px;
  background-color: #fff;  
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
.navigation_menu li.active .ico,
.navigation_menu li .ico:hover{
  background-image: url(/common/img/ico_arrow_w.svg);
  background-color: #ba9716;
}

/*aside----------------------------------------------------*/
.aside {
  position: relative;
  -webkit-box-flex: 1;
  flex: 1;
  width: 100%;
  margin-top: 10px;  
  margin-bottom: 10px;
  -webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	justify-content: flex-end;

}
.aside_inner {
  height: 100%;
  min-height: 230px;
  max-height: 280px;    
  -webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
  -webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
  -webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
  overflow: hidden;
}
.aside ul {
  width: 164px;
  text-align: center;
  margin: 0 auto;
}
.aside_menu01{
  position: relative;
  height: 100%;
  max-height: 158px;
  margin: 0 auto;
}
.aside_menu01 ul{
  -webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
  -webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
  height: 100%;
}
.aside_menu01 li{
  -webkit-box-flex: 1;
  flex: 1;
}
.aside_menu01 li p,
.aside_menu01 li a {
  display: table;
  height: 100%;  
  width: 100%;
  border: solid 1px #c3d1e4;
  font-size: 13px;
}
.aside_menu01 li p span,
.aside_menu01 li a span {
/*  height: 50px;*/
  display: table-cell;
  vertical-align: middle;
  line-height: 1.286;
  height: 100%;
}
.aside_menu01 li:nth-child(1) p {
  text-align: left;
  color: #063e8d;
  padding-left: 41px;
  background: url(/common/img/ico_person.png) no-repeat left 15px center;
  background-size: 16px auto;
}
.aside_menu01 li:nth-child(1) p img,
.aside_menu01 li:nth-child(1) a img {
  width: 6px;
  margin-left: 14px;
  vertical-align: middle;
}
.aside_menu01 li:nth-child(2) {
  margin: 4px 0;
}
.aside_menu01 li:nth-child(2) a {
  background-color: #063e8d;
  border-color: #063e8d;
  color: #fff;
}
.aside_menu01 li:nth-child(1) p:hover,
.aside_menu01 li:nth-child(3) a:hover{
  opacity: 1;
  background-color: #f1f6fc;
}
ul.aside_menu02 {
  margin-top: 3px;
  margin:5px auto;
}
.aside_menu02 li {
  width: 33.33%;
  font-size: 9px;
  line-height: 1;
}
.aside_menu02 li:nth-child(2) {
  border-left: solid 1px #c2d0e3;
  border-right: solid 1px #c2d0e3;
}
.aside_menu02 li a {
  display: block;
  height: 45px;
  padding-top: 33px;
}
.aside_menu02 li.search a {
  background: url(/common/img/aside_search.svg) no-repeat top 2px center;
  background-size: 28px auto;
}
.aside_menu02 li.access a {
  background: url(/common/img/aside_access.svg) no-repeat top 2px center;
  background-size: 22px auto;
}
.aside_menu02 li.language a {
  background: url(/common/img/aside_language.png) no-repeat top 2px center;
  background-size: 26px auto;
}
.aside_menu02 li a:hover{
  opacity: 1;
  background-color: #edf0f8;
}
.aside_menu03 {
  margin-top: 3px;
  height: 45px;
}
.aside_menu03 li {
  display: table;  
  width: 33.33%;
  height: 100%;
}
.aside_menu03 li a{
  display: table-cell;
  height: 100%;
  vertical-align: middle;
}
.aside_menu03 li img {
  width: 24px;
}
.aside_menu03 li.bibbs img {
  width: 50px;
}
.aside_menu03 li a:hover{
  opacity: 1;
  background-color: #edf0f8;
}
/*
 下層メニュー（PC）
----------------------------------------------------------- */
.submenu {
  position: fixed;
  left: 200px;
  top: 0;
  z-index: 100;
  height: 100vh;
  padding: 5vh 0 5% 48px;
  background-color: #fff;
  overflow-y: auto;
  -webkit-transition: all 0.3s linear;
  transition: all 0.3s linear;
  border-left: solid 10px #bf9f28;
  -webkit-transform: translateX(-100%);
  transform: translateX(-100%);
  max-width: calc(100% - 200px);
  opacity: 0;
}
.submenu.active {
  -webkit-transform: translateX(0);
  transform: translateX(0);
  opacity: 1;
}
.submenu_inner {
  position: relative;
  padding-right: 56px;
}
.submenu .submenu_navi {
  display: none;
}
.submenu .submenu_navi.active {
  display: block;
}
/*第二階層*/
.submenu .top {
  position: relative;
  margin-bottom: 40px;
}
.submenu .top a {
  font-size: 27px;
}
.submenu .top a span {
  display: inline-block;
  font-size: 18px;
}
.submenu .top a span::after {
  display: inline-block;
  content: '';
  width: 8px;
  height: 12px;
  background: url(/common/img/ico_arrow_b.svg) no-repeat center center;
  background-size: contain;
  margin-left: 38px;
}
.submenu .top a::after {
  content: '';
  display: block;
  width: 46px;
  height: 2px;
  margin-top: 10px;
  background-color: #063e8d;
}
.submenu .top .en {
  display: block;
  margin-top: 10px;
  font-size: 14px;
  font-size: 1.4rem;
  font-family: 'Roboto Condensed', sans-serif;
  font-style: italic;
}
/*第三階層*/
.submenu_navi_inner {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  /*width: 536px; */ 
  width: 600px; 
  max-width: 100%;
  padding-bottom: 20px;
}
.submenu_navi_inner.col3{
  width: 815px;  
}
.submenu_navi_inner.col4{
  width: 1094px;  
}
.submenu_navi_inner .col{
  border-top: solid 1px #000;
}
.submenu_navi_inner.col1 .col{
  width: 100%;
  max-width: 400px; 
}
.submenu_navi_inner.col2 .col{
  width: 47%;
}
.submenu_navi_inner.col3 .col {
  width: 31%;
}
.submenu_navi_inner.col4 .col {
  width: 23%;
}
.submenu_navi_inner .link {
  font-size: 16px;
  border-bottom: solid 1px #000;
}
.submenu_navi_inner .third a {
  display: block;
  width: 100%;
  padding: 10px 9% 10px 2px;
  background: url(/common/img/ico_arrow_b.svg) no-repeat right 5% center;
  background-size: 6px 9px;
}
.submenu_navi_inner .third a:hover{
  background-color: #fbf7eb;
}
.submenu .top .blank,
.submenu_navi_inner a .blank{
  width: 15px;
  margin-left: 5px;
  vertical-align: middle;
}
/*見出し*/
.submenu_navi_inner .caption a::before,
.submenu_navi_inner .caption span::before{
  content: '◆';
  color: #bf9f28;
  font-size: 14px;
  margin-right: 7px;
}
.submenu_navi_inner .caption a{
  display: block;
  width: 100%;  
  padding: 8px 9% 8px 25px;
  text-indent: -22px;
  line-height: 1.3;
  background: url(/common/img/ico_arrow_b.svg) no-repeat right 5% center;
  background-size: 6px 9px;
}
.submenu_navi_inner .caption a:hover{
  background-color: #fbf7eb;
}
.submenu_navi_inner .caption span{
  display: block;
  width: 100%;  
  padding: 8px 9% 8px 25px;
  text-indent: -22px;
  line-height: 1.3;
}
/*第四階層*/
.submenu_navi_inner .fourth a {
  display: block;
  padding: 8px 0 8px 25px;
  line-height: 1.3;
  background: url(/common/img/ico_arrow_b.svg) no-repeat left 4% top 12px;
  background-size: 6px 9px;
}

.submenu_navi_inner .fourth a:hover{
  background-color: #fbf7eb;
}
/*閉じるボタン*/
.submenu .close {
  position: absolute;
  right: 0;
  bottom:5%;
  width: 50px;
  padding: 11.5px 0;
  background-color: #ba9716;
  text-align: center;
  line-height: 1;
  color: #fff;
  font-size: 27px;
  z-index: 101;
  cursor: pointer;
}
.submenu_smp {
  display: none;
}

/*
 対象者
----------------------------------------------------------- */
.targetmenu {
  position: fixed;
  left: 200px;
  top: 0;
  z-index: 100;
  height: 100vh;
  padding: 8vh 0 5% 48px;
  overflow-y: auto;
  -webkit-transition: all 0.3s linear;
  transition: all 0.3s linear;
  border-left: solid 10px #184c96;
  -webkit-transform: translateX(-100%);
  transform: translateX(-100%);
  max-width: calc(100% - 200px);
  min-width: 369px;
  opacity: 0;
  background:#f1f6fc;
}
.targetmenu.active {
  -webkit-transform: translateX(0);
  transform: translateX(0);
  opacity: 1;
}
.targetmenu_inner {
  position: relative;
  padding-right: 56px;
}
.targetmenu .ttl{
  margin-bottom: 40px;
  font-size: 25px;
  font-size: 2.5rem;
  color: #063e8d;
  padding-left: 40px;
  background: url(/common/img/ico_person.png) no-repeat left center;
  background-size: 27px 30px;
}
.targetmenu ul{
  border-top: solid 1px #96aed0;
}
.targetmenu ul li{
  border-bottom: solid 1px #96aed0;
}
.targetmenu ul li a{
  display: block;
  padding: 22px 0 22px 9px;
  color: #063e8d;
  background: url(/common/img/ico_arrow.svg) no-repeat right 12px center;
  background-size: 6px 9px;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;  
}
.targetmenu ul li a:hover{
  background-color: #e3eefb;
}
.targetmenu ul li a img{
  width: 29px;
  margin-right: 16px;
}
/*閉じるボタン*/
.targetmenu .close {
  position: absolute;
  right: 0;
  bottom:5%;
  width: 50px;
  padding: 11.5px 0;
  background-color: #063e8d;
  text-align: center;
  line-height: 1;
  color: #fff;
  font-size: 27px;
  z-index: 101;
  cursor: pointer;
}



/*
 以前あなたが見たページ
----------------------------------------------------------- */
.btn_bookmark_pc{
  position: fixed;
  left: 200px;
  bottom: 204px;
  /* bottom: 17.5%; */
  z-index: 90;
  height:62px;
  background: url(/common/img/bg_bookmark.png)no-repeat right center;
  padding-left: 10px;
  padding-right: 22px;
}
.btn_bookmark_pc a{
  color: #fff;
  height: 100%;
  display: flex;
  align-items: center;
  font-size: 14px;
  font-size: 1.4rem;
  background: url(/common/img/ico_arrow_w.svg) no-repeat right center,url(/common/img/ico_bookmark.png) no-repeat left center;
  background-size: 6px auto, 24px auto;
  padding-right: 20px;
}
.btn_bookmark_pc a span{
  display: block;
  width: 183px;
  white-space: nowrap;
  padding-left: 28px;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;    
  overflow: hidden;  
  opacity: 1;  
}

.btn_bookmark_pc.off a span{
  width: 26px;
  opacity: 0;
}
.btn_bookmark_pc.off a:hover span{
  width: 183px;
  opacity: 1;  
}


@media print{
  .wrap_contents {
    display: block;
  }
  .wrapper_navi{
    display: none;
  }  
  
  .btn_bookmark_pc{
    display: none;
  }
  .targetmenu,
  .submenu{
    display: none;
  }
}