body {
  color: #3E3A39;
  font-family:YuGothic , '游ゴシック' , 'Hiragino Kaku Gothic ProN' , 'ヒラギノ角ゴ ProN' , Meiryo , 'メイリオ' , sans-serif;
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1;
  height: 100%;
  text-align: left;
  width: 100%;
}

.container {
  width: 730px;
  margin: auto;
}

.wrapper {
  margin: 20px auto 0;
  overflow:hidden;
  text-align: left;
  width: 730px;
}

.wrapper h2{
  color: #3E3A39;
  font-size: 24px;
  font-weight: bold;
  margin: 30px 0 10px 0;
}

.wrapper h3{
  color: #3E3A39;  
  font-size: 18px;
  font-weight: bold;
  line-height: 1.6;
  margin: 10px 0 12px 0;
}

.wrapper h4{
  color: #3E3A39;
  font-size: 16px;
  font-weight: bold;
  margin: 10px 0;
  line-height: 1.3;
}

.wrapper p{
  font-size: 16px;
  line-height: 1.6;
  margin-bottom: 10px;
}

.wrapper ul li{
  font-size: 16px;
  line-height: 1.3;
  margin-bottom: 10px;
}


.wrapper a{
  color: #333;
  text-decoration: underline;
}

.wrapper a:hover{text-decoration: none;}

.section {margin-bottom: 30px;}


.topLineStyle_hierarchy {
  border-top: 1px solid #3E3A39;
  display: inline-block;
  font-size: 2.1rem;
  font-weight: 700;
  letter-spacing: 2px;
  margin: 30px 0;
  padding-top: 14px;
  position: relative;
  width: 100%;
}

.topLineStyle_hierarchy::before {
  border-top: 5px solid #55217b;
  content: "";
  display: block; 
  position: absolute;
  left: 0;
  top: -1px;
  width: 65px;
}

.topLineStyle_hierarchy > span {
  font-size: 1.3rem;
  letter-spacing: 0;
}

.normalStyle {
  font-size: 28px;
  margin-bottom: 30px;
}

.normalStyle.small {
  font-size: 20px;
  font-weight: 700;
  margin:30px 0 20px;
}


.hrmAppLink { text-align: right; }

.hrmAppLink a {
  border-bottom: 2px solid #333;
  color: #333;
  display: inline-block;
  font-size: 15px;
  font-weight: 700;
  margin: 20px 0;
  transition: .3s;
  text-decoration: none;
}

.hrmAppLink img{
  margin-right: 5px;
  vertical-align: middle;
}

.hrmAppLink a:hover {
  opacity: .6;
  text-decoration: none;
}

/*===============================

    コンテンツ

================================*/

/*
    メニュー
================================*/
.menu_hierarchy {
  display: flex;
  font-size: 0;
  justify-content: space-between;
  margin: 10px 0 30px;
}

.menu_hierarchy > li {
  font-size: 14px;
  width: auto;
 }

.menu_hierarchy > li > a {
  color: #3E3A39;
  display: block;
  font-size: 14px;
  padding: 5px 5px 8px;
  position: relative;
  text-decoration: none;
  transition: .3s;
 }
 
 .menu_hierarchy > li > a::before {
  background-color: #55217b;
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  height: 3px;
  width: 0;
  transition: .3s;
  transform: translateX(-50%);
 }
 
 .menu_hierarchy > li > a:hover::before { width: 100%; }



/*
　追記
================================*/

.fl{ float:left; }
.fr{ float:right; }
.fn{ float:none; }
.fc{ clear: both; }

.c_text_left{text-align: left;}
.c_text_right{text-align: right;}
.c_text_center{text-align: center;}

.note {
  color: #999;
  font-size: 13px!important;
}

.trise_wrapper{
  display:flex;
  -js-display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-around;
  justify-content: space-around;
  position: relative;
}

.trise_box{
  position: relative;
  width: 30%;
  padding: 0 10px;
}

.list_box{margin-bottom:50px;}

.list_item{margin-bottom:30px;}

.list_item_txt{width:80%;}

.record{
  width: 47%;
  margin: 0 10px 10px 0;
  align-items: center;
  display: flex;
  -js-display: flex;
  flex-flow: row wrap;
  font-size: 14px;
  justify-content: space-between;
  margin-bottom: 20px;
}

.record > dt {
  flex: auto 0 0;
  line-height: 1.3;
  width: 50%;
}

.record > dd:first-of-type {
  margin-top: 0;
}

.record > dd + dt, .record > dt + dd {
  margin-top: 4px;
}

.record > dd > span {
  color: ;
  font-family: Arial, Helvetica, "sans-serif";
  font-size: 35px;
  font-weight: bold;
  margin-right: 3px;
  letter-spacing: 0;
}

.record_top_style {
  color: #fff;
  font-size: 16px!important;
  font-weight: 600;
  width: 100%;
}

.num{
  font-size: 20px!important;
  font-family: Arial, Helvetica, "sans-serif";
  font-weight: 600;
  color: #fff;
  background-color: #55217b;
  width: 30px;
  height: 30px;
  text-align: center;
  display: block;
  float: left;
  margin-right: 10px;
}

.ability_nav {
  align-items: center;
  display: flex;
  -js-display: flex;
  justify-content: center;
  line-height:1.2;
  width: 100%;
}

.ability_nav > li {
  width: 100%;
}

.ability_nav > li > a {
  align-items: center;
  color: #fff;
  font-weight:bold;
  font-size:14px;
  display: flex;
  -js-display: flex;
  flex-flow: row wrap;
  height: 50px;
  justify-content: center;
  text-align: center;
  text-decoration: none;
  width: 99%;
}

.ability_nav > li:hover {
  opacity: .6;
  transition: .3s;
}

.ability_bg_chuken {background: #d6006f;}

.ability_bg_shinnin {background: #940683;}

.ability_bg_chukyu {background: #601986;}

.ability_bg_joukyu {background: #24004b;}


.ability_table{
  border-color: #dcdddd;
  border-width: 1px 0 0 1px;
  border-style: solid;
  margin: 20px 0 0;
  table-layout: auto;
  width: 100%;
  border-collapse: collapse;
}

.ability_table:last-child{margin: 20px 0;}


.table_top_style{
  color: #fff;
  font-size:18px!important;
  font-weight:600;
  margin: 0!important;
}

.ability_table th{
  border-color: #dcdddd;
  border-width: 0 1px 1px 0;
  border-style: solid;
  font-size: 16px;
  background-color: #f7f8f8;
  padding: 8px;
  text-align: center;
  vertical-align: middle;
  width: 30%;
}

.ability_table td{
  border-color: #dcdddd;
  border-width: 0 1px 1px 0;
  border-style: solid;
  font-size: 16px;
  line-height: 1.3;
  padding: 8px;
  vertical-align: middle;
}

.half_wrapper{
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -js-display: flex;
  justify-content: space-between;
  width: 100%;
}

.hierarchy_box{
  width: 49%;
  margin: 0 10px 10px 0;
  font-size: 16px;
  line-height: 1.6;
  border: 1px solid #dcdddd;
}

.hierarchy_box:nth-child(2n) {margin-right: 0;}

.hierarchy_box ul {padding: 10px 0;}

.hierarchy_box li{margin-bottom: 10px;}

.hierarchy_box li:last-child{margin-bottom: 0;}

.hierarchy_box a {
  display: inline;
}

.hierarchy_cont{
  border-bottom: 1px solid #dcdddd;
  margin: 0 10px;
  padding: 10px;
}

.hierarchy_cont:last-child {border-bottom: none;}

.management_box {
  line-height: 1.6;
  font-size: 16px;
  margin: 10px 0;
  width: 100%;
  padding-bottom: 10px;
  border-bottom: 1px solid #dcdddd;
}

.management_box:last-child {
  border-bottom: none;
  margin-bottom: 30px;
}


.management_box span{
  background-color: #9571A6;
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  padding: 2px 5px;
  display: inline-block;
}

.management_item{}


.hierarchy_square::before{
  color: #55217b;
  content: "■";
  display: inline-block;
  font-size: 12px;
  margin-right: 5px;
  vertical-align: middle;
}

.rotate{}

.download{float:right;}

.download_btn{
  background: #F23030;
  color: #fff!important;
  display: inline-block;
  padding: 5px 15px;
  text-align: center;
  font-weight:bold;
  text-decoration: underline;
}

.download_btn:hover{text-decoration: none;}

.pc {}

.sp {display: none !important;}

.menu_hierarchy_box{
  width: 85%;
  margin: 20px auto;
  padding: 8px 16px;
  background: #F0ECF6;
}


/*===============================

    ★★レスポンシブ

================================*/
@media screen and (max-width:768px) {

body {
  width: 95%;
  margin: 0 auto;
}

img {
  max-width: 100%;
  height: auto;
  margin: 0;
}

.wrapper { width: 100%; }

.container {
  float: none;
  width: 100%;
}



/* 追記 */


.fl{
  float:none;
  clear:both;
}

.fr{
  float:none;
  clear:both;
}


.trise_wrapper{
  height: auto;
  position: unset;
}

.half_wrapper{
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -js-display: flex;
  justify-content: space-between;
  width: 100%;
}

.list_item_txt{width:100%;}

.record{width: 100%;}

.hierarchy_box {
  width: 100%;
  margin: 0 0 10px 0;
}

.trise_box {
  width: 100%;
  padding: 10px 0;
}

.hierarchy_img {
  float: none;
  text-align: center;
  margin-bottom: 10px;
}

.rotate{transform: rotate( 90deg );}

.sp {
  display: block !important;
  margin: auto;
}

.pc {display: none !important;}

.menu_hierarchy_box{
  width: 100%;
}



}/* @media */

@media screen and (max-width:599px) {

.ability_nav {display: block;}

.ability_nav > li > a {height: 30px;}

.ability_nav > li {margin-bottom: 5px!important;}


}/* @media */