@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Template:   cocoon-master
Version:    0.0.5
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/
/*必要ならばここにコードを書く*/

/*全体*/
.content{
	margin-top: 0;
}
.wrap{
	width: 100%;
}
.entry-content{
	margin: 0;
}
main.main{
	padding: 0;
	border: none;
}
.outerarea{
	padding: 2em 0;
}
.outerarea02{
	padding: 1em 0;
}
.outerarea03{
	padding: 3em 0 1em;
}
.banner{
	text-align: center;
}
.bg01{
	background-color: #EFEFEF;
}
.bg02{
	background-color: #09aa39;
}
.outerarea.bg02 h1,.outerarea.bg02 h2,
.outerarea.bg02 h3,.outerarea.bg02 h4,
.outerarea.bg02 h5,.outerarea.bg02 h6,
.outerarea.bg02 p{
	color: #fff;
}
.outerarea.bg02 h2:before{
	background-color: #fff;
}
.innerarea{
	max-width: 1040px;
	padding: 0 3%;
	margin: auto;
	box-sizing: border-box;
}
a:hover{
	color: #09aa39;
}
@media screen and (max-width: 768px){
	.outerarea{
		padding: 2em 0;
	}
	.outerarea02{
		padding: 1em 0;
	}
	.outerarea03{
		padding: 1em 0 1em;
	}
}

/*header*/
.tagline{
	display: none;
}
.logo-image{
	padding: 20px 0;
}
#navi .navi-in a{
	display: block;
    padding: 0;
}
#navi .navi-in a:hover{
	background-color: transparent;
}
.header-container-in.hlt-top-menu .header{
	width: 20%;
}
.header-container-in.hlt-top-menu .logo-header{
	max-height: auto;
	display : -webkit-box;
	display : -webkit-flex;
	display : -ms-flexbox;
	display : flex;
    max-height: none;
}
.header-container-in.hlt-top-menu .logo-header .site-name{
	display: -webkit-inline-box;
  	display: -ms-inline-flexbox;
  	display: inline-flex;
}
.header-container-in.hlt-top-menu .logo-header img{
	max-height: none;
	height: auto;
	display: block;
}
#header-container{
	padding: 0;
}
.header .header-in{
	min-height: auto;
}
#header-container .navi{
	width: 100%;
}
.navi-in > ul{
	-webkit-justify-content: center;
    -ms-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-align-items: center;
	align-items: center;
    width: 100%;
    padding: 0 5%;
}
#navi-in > ul li,
.cl-slim #navi-in > ul li{
	text-align: center;
	flex-basis: 12%;
	height: auto;
	line-height: normal;
	position: relative;
	letter-spacing: 0.02em;
    font-weight: 500;
    line-height: 1.3;
    padding: 0;
}
#navi-in > ul li:after,
.cl-slim #navi-in > ul li:after{
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    height: 3px;
    background-color: #fff;
    width: 0;
    transition: width .4s;
}
#navi-in > ul li:hover:after,
#navi-in > ul li:focus:after,
#navi-in > ul li:active:after,
.cl-slim #navi-in > ul li:hover:after,
.cl-slim #navi-in > ul li:focus:after,
.cl-slim #navi-in > ul li:active:after{
	width: 100%;
}
#navi-in > ul li a,
.cl-slim #navi-in > ul li a{
	font-size: 17px;
}
#navi-in > ul li a .item-label,
.cl-slim #navi-in > ul li a .item-label{
	padding: 10% 4%;
}
@media screen and (max-width: 1100px) {
	#navi-in > ul li a,
	.cl-slim #navi-in > ul li a{
		font-size: 1.4vw;
	}
}

@media screen and (max-width: 767px) {
	.logo-image{
		padding: 20px 15%;
	}
}

/*footer*/
.entry-categories-tags{
	display: none;
}
.footer{
	margin-top: 0;
}
.footer-bottom-logo .logo-image{
	max-width: none;
}
.footer-bottom-logo img{
	margin: 0 auto;
	height: 44px;
}
.navi-footer-in > .menu-footer li.menu-item{
	border: none;
}

/*pagetop*/
.go-to-top{
	bottom: 70px;
}
.go-to-top-button{
	width: 70px;
	height: auto;
}

/*共通style*/
.left{
	text-align: left;
}
.center{
	text-align: center;
}
.right{
	text-align: right;
}
.pc_none{
	display: none;
}
.sp_none{
	display: block;
}
.pt-10{
	padding-top: 10px;
}
.pt-20{
	padding-top: 20px;
}
.pt-30{
	padding-top: 30px;
}
.pb-10{
	padding-bottom: 10px;
}
.pb-20{
	padding-bottom: 20px;
}
.pb-30{
	padding-bottom: 30px;
}
@media screen and (max-width: 768px){
	.pc_none{
		display: block;
	}
	.sp_none{
		display: none;
	}
}

/*h,p*/
.article h1,.article h2,.article h3,
.article h4,.article h5,.article h6{
	margin: 0 0 1.5em;
}

.article h1,.article h2,.article h3{
	letter-spacing: 0.13em;
}
.article h4,.article h5,.article h6{
	letter-spacing: 0.1em;
}
.article h2{
position: relative;
padding: 15px;
margin-bottom: 1.5em;
background-color: transparent;
text-align: center;
font-size: 28px;
}
.article h2:before {
content: '';
position: absolute;
bottom: -5px;
display: inline-block;
width: 60px;
height: 5px;
left: 50%;
-moz-transform: translateX(-50%);
-webkit-transform: translateX(-50%);
-ms-transform: translateX(-50%);
transform: translateX(-50%);
background-color: #09aa39;
border-radius: 2px;
}
.article h3{
	font-size: 26px;
}
.article h4{
	font-size: 22px;
	border: none;
	padding: 0 0 0 25px;
	position: relative;
}
.article h4:before{
	content: "";
}
.article .head_title{
	font-size: 32px;
	letter-spacing: 0.3em;
	color: #09aa39;
	margin-bottom: 2em;
}
.article .head_title:before{
	content: none;
}
.article .head_title span{
	position: relative;
    padding: 20px 35px;
}
.article .head_title span:before{
	content: "";
	position: absolute;
    top: 0;
    left: 0;
    width: 30px;
    height: 45px;
    border-top: 4px solid;
    border-left: 4px solid;
}
.article .head_title span:after{
	content: "";
	position: absolute;
    bottom: 0;
    right: 0;
    width: 30px;
    height: 45px;
    border-bottom: 4px solid;
    border-right: 4px solid;
}
.article .head_txt{
    font-size: 22px;
    letter-spacing: 0.1em;
    line-height: 2em;
		color: #09aa39;
}
.article .head_txt:not(:last-child){
	margin-bottom: 0;
}

.article h3,
.article h5{
	position: relative;
	border: none;
	border-bottom: 4px solid #d6d4d4;
	padding: 0 0 12px 0;
}
.article h3:after,
.article h5:after {
	position: absolute;
	content: " ";
	display: block;
	border-bottom: solid 4px #09aa39;
	bottom: -4px;
	left: 0;
	width: 25%;
}
.article p,
.article li,
.article dd,
.article table td{
	letter-spacing: 0.08em;
	margin: 0 0 1.5em;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	font-weight: 500;
}
.article dt{
	letter-spacing: 0.1em;
}
.article dd{
	margin: 0 0 1.5em 1em;
}
.article table th{
	letter-spacing: 0.1em;
}
.article table td{
	text-align: left;
}

.article p.note{
    margin: 1% 0 0%;
}

@media screen and (max-width: 768px){
	.article .head_title{
		font-size: 7vw;
		padding: 0;
	}
	.article .head_title span{
	    padding: 5% 6%;
	}
	.article .head_title span:before{
    	width: 20px;
    	height: 30px;
    	border-top: 3px solid;
    	border-left: 3px solid;
	}
	.article .head_title span:after{
	    width: 20px;
	    height: 30px;
	    border-bottom: 3px solid;
	    border-right: 3px solid;
	}
	.article .head_txt{
		font-size: 18px;
	}
	.article h2{
		font-size: 20px;
	}
	.article h3{
		font-size: 18px;
	}
}

/*table*/
table{
	text-align: center;
	margin-bottom: 5%;
}

/*
parts
*/
.article .marks01{
	background: linear-gradient(transparent 72%, rgba(251,239,57,0.9) 72%);
}
.article .marks02{
	background: linear-gradient(transparent 72%, rgba(238,119,0,0.9) 72%);
}
.article .sub_ttl01{
	padding: 0;
}
.article .sub_ttl01 span {
	position: relative;
	padding-left: 35px;
	padding-right: 10px;
}

.article .sub_ttl01 span:before {
	position: absolute;
	content: '';
	bottom: -3px;
	left: 0;
	width: 0;
	height: 0;
	border: none;
	border-left: solid 15px transparent;
	border-bottom: solid 15px rgb(9, 170, 57);
}
.article .sub_ttl01 span:after {
	position: absolute;
	content: '';
	bottom: -3px;
	left: 10px;
	width: 100%;
	border-bottom: solid 3px rgb(9, 170, 57);
}
.article .sub_ttl02{
    position: relative;
    font-size: 22px;
    padding: 6px 10px 6px 30px;
    margin-bottom: 10px;
}
.article .sub_ttl02:before{
	content: "■";
    position: absolute;
    top: 13px;
    left: 11px;
    font-size: 13px;
    color: rgb(9, 170, 57);
}
.article .check_list01{
    padding-right: 20px;
    padding-left: 30px;
}
.article .check_list01 li{
    list-style-type: none;
    position: relative;
    margin-bottom: 10px;
}
.article .check_list01 li:before{
    content: " \f00c";
    font-family: FontAwesome;
    border-radius: 20%;
    position: absolute;
    left: 0;
    top: 2px;
    min-width: 23px;
    height: 23px;
    line-height: 23px;
    text-align: center;
    font-size: 60%;
    margin-right: 10px;
    background: #f3f3f3;
    color: #000;
    margin-left: -2.1em;
    min-width: 22px;
    height: 22px;
    line-height: 22px;
    color: rgb(9, 170, 57);
    font-size: 14px;
}
.btn01{
    border: 1px solid #fff;
    display: block;
    width: 100%;
    max-width: 280px;
    margin: 20px auto 0;
    cursor: pointer;
}
.btn01:hover{
	opacity: .7;

}
.btn01 span{
	border: 3px solid #fff;
    color: #fff;
    text-align: center;
    font-size: 24px;
    font-weight: 600;
    letter-spacing: 5px;
    display: block;
    padding: 15px 0;
    margin: 0 auto 0;
    width: 100%;
    position: relative;
}
.btn01 span:before{
	content: "\f138";
	font-family: "fontAwesome";
	position: absolute;
	top: 15px;
	right: 15px;
}

/*flex*/
.flexitem{
	display : -webkit-box;
	display : -webkit-flex;
	display : -ms-flexbox;
	display : flex;
	-webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
	padding: 2% 0;
}
.flexitem img{
	width: 100%;
	display: block;
}

.flex_25{
	-webkit-justify-content: space-between;
    -ms-justify-content: space-between;
  	justify-content: space-between;
}
.flex_25 .fbox{
	width: 23%;
}
.flex-justify-center {
	justify-content:center;
}




@media screen and (max-width: 768px){
	.article .sub_ttl01{
		font-size: 18px;
	}
	.article .sub_ttl01 span{
		display: inline-block;
	}
	.article .sub_ttl01 span:after{
		width: 93%;
	}
	.article .sub_ttl02{
		font-size: 18px;
	}
	.flexitem{
		display: block;
	}
}


/*box*/
.brackets_box01 {
    position: relative;
    padding: 0.25em 1em;
    margin: 0 auto 2em;
    top: 0;
    width: 75%;
    box-sizing: border-box;
}
.brackets_box01:before, .brackets_box01:after{ 
    position: absolute;
    top: 0;
    content:'';
    width: 10px;
    height: 100%;
    display: inline-block;
    box-sizing: border-box;
}
.brackets_box01:before{
    border-left: solid 4px #09aa39;
    border-top: solid 4px #09aa39;
    border-bottom: solid 4px #09aa39;
    left: 0;
}
.brackets_box01:after{
    border-top: solid 4px #09aa39;
    border-right: solid 4px #09aa39;
    border-bottom: solid 4px #09aa39;
    right: 0;
}
.brackets_box01 h2 {
    margin: 0;
    padding: 0;
    color: #09aa39;
    line-height: 2;
    font-size: 32px;
}
.brackets_box01 h2:before {
	content: none!important;
}
.point_box {
    position: relative;
    margin: 2.5em 0;
    padding: 0.5em 1em;
    border: solid 3px rgba(238,119,0,1);
    display: table;
}
.point_box .box_title {
    position: absolute;
    display: inline-block;
    top: -27px;
    left: -3px;
    padding: 0 9px;
    height: 25px;
    line-height: 25px;
    vertical-align: middle;
    font-size: 17px;
    background: rgba(238,119,0,1);
    color: #ffffff;
    font-weight: bold;
    border-radius: 5px 5px 0 0;
}
.point_box p {
    margin: 0; 
    padding: 0;
    font-family: "Noto Sans JP" ,sans-serif;
    letter-spacing: 0.1em;
    font-size: 17px;
}

/*
partsここまで
*/

/*
sp_footmenu
*/
.sidebar-menu-button {
    display: none;
}
.menu-drawer li{
	padding: 3%;
}

/*
top
*/
body.home .entry-title{
	display: none;
}
body.home .heading{
	padding: 1em 0 1.5em;
}

.flex_quality{
	display : -webkit-box;
	display : -webkit-flex;
	display : -ms-flexbox;
	display : flex;
}
.flex_quality .fbox.img_box{
	width: 40%;
}
.flex_quality .fbox.text_box{
	width: 60%;
}
.flex_quality .l_fbox{
	order: 1;
}
.flex_quality .l_fbox.text_box{
	padding-right: 5%;
}
.flex_quality .r_fbox{
	order: 2;
}
.flex_quality .r_fbox.text_box{
	padding-left: 5%;
}

.price_head_txt{
	padding: 70;
}
.couse_banner_outer{
	padding: 0;
}
.couse_banner_area{
	display : -webkit-box;
	display : -webkit-flex;
	display : -ms-flexbox;
	display : flex;
	-webkit-justify-content: space-between;
    -ms-justify-content: space-between;
  	justify-content: space-between;
  	margin-bottom: 3%;
}
.couse_banner_area .couse_banner{
	width: 31.5%;
	padding-bottom: 2%;
    border: 5px solid #09aa39;
    border-radius: 35px;
    box-shadow: 0px 5px 10px 1px #b9bbb9;
}
.couse_banner_area .couse_banner h3{
	border: none;
    font-size: 24px;
    text-align: center;
    padding: 3%;
    background: green;
    border-radius: 25px 25px 0 0;
    color: #fff;
    margin: 0;
}

.couse_banner_area .couse_banner h3:after{
	content: none;
}
.couse_banner_area .couse_banner h3 span{
	font-size: 18px;
}
.couse_banner_area .couse_banner .txt01{
	font-size: 18px;
	font-weight: 700;
	padding: 0 5%;
    margin: 5% 0 0%;
    text-align: center;
}
.couse_banner_area .couse_banner .txt01 .price{
	color: red;
    font-size: 28px;
    font-weight: 700;
    display: block;
}
.couse_banner_area .couse_banner .txt01 .sub01{
	font-size: 14px;
	display: block;
}
.couse_banner_area .couse_banner .txt01 .sub02{
	font-size: 12px;
	font-weight: 500;
}
.couse_banner_area .couse_banner .btn01{
	border: 1px solid #09aa39;
	width: 100%;
	max-width: 200px;
    margin: 2% auto 0;
	text-decoration: none;
    background-image: linear-gradient(to right, rgba(0,0,0,0) 50%, rgba(9,170,57,1) 50%);
	background-position: 0 0;
	background-size: 200% auto;
	transition: .5s;
}

.couse_banner_area .couse_banner .btn01:hover{
	background-position: -100% 0;
	opacity: 1;
}
.couse_banner_area .couse_banner .btn01 span{
	border: 3px solid #09aa39;
    color: #09aa39;
    font-size: 17px;
    transition: .5s;
    letter-spacing: 2px;
    padding: 10px 0;
}
.couse_banner_area .couse_banner .btn01 span:before{
	top: 10px;
	right: 5px;
}
.couse_banner_area .couse_banner .btn01:hover span{
	color: #fff;
}

.couse_banner_area .couse_banner.bn_orange{
	border: 5px solid #ffb36b;
}
.couse_banner_area .couse_banner.bn_orange h3{
	background-color: #ffb36b;
}
.couse_banner_area .couse_banner.bn_orange .btn01{
	border: 1px solid #ffb36b;
	background-image: linear-gradient(to right, rgba(0,0,0,0) 50%, #ffb36b 50%);
}
.couse_banner_area .couse_banner.bn_orange .btn01 span{
	border: 3px solid #ffb36b;
    color: #ffb36b;
}
.couse_banner_area .couse_banner.bn_red{
	border: 5px solid #f88080;
}
.couse_banner_area .couse_banner.bn_red h3{
	background-color: #f88080;
}
.couse_banner_area .couse_banner.bn_red .btn01{
	border: 1px solid #f88080;
	background-image: linear-gradient(to right, rgba(0,0,0,0) 50%, #f88080 50%);
}
.couse_banner_area .couse_banner.bn_red .btn01 span{
	border: 3px solid #f88080;
    color: #f88080;
}
.couse_banner_area .couse_banner.bn_blue{
	border: 5px solid #4f9df4;
}
.couse_banner_area .couse_banner.bn_blue h3{
	background-color: #4f9df4;
}
.couse_banner_area .couse_banner.bn_blue .btn01{
	border: 1px solid #4f9df4;
	background-image: linear-gradient(to right, rgba(0,0,0,0) 50%, #4f9df4 50%);
}
.couse_banner_area .couse_banner.bn_blue .btn01 span{
	border: 3px solid #4f9df4;
    color: #4f9df4;
}
.couse_banner_area .couse_banner.bn_orange .btn01:hover span,
.couse_banner_area .couse_banner.bn_red .btn01:hover span,
.couse_banner_area .couse_banner.bn_blue .btn01:hover span{
	color: #fff;
}
.discount_box{
    padding: 5% 0 0;
}
.achievement_area{
	padding: 3% 0;
}

.flex_map{
	padding: 0;
}
.flex_map .l_fbox{
	width: 50%;
	box-sizing: border-box;
	background-color: #09aa39;
	padding: 5%;
	order: 1;
}
.flex_map .r_fbox{
	width: 50%;
	box-sizing: border-box;
	order: 2;
}
.flex_map dl div{
	display: flex;
	margin-bottom: 3%;
}
.flex_map dl div dt{
	position: relative;
	color: #fff;
	padding-right: 10px;
	letter-spacing: 0.15em;
}
.flex_map dl div dt:after{
	content: "";
	width: 2px;
	height: 20px;
	position: absolute;
	top: 5px;
	right: 0;
	background: #fff;
}
.flex_map dl div dt.name{
	font-size: 20px;
}
.flex_map dl div dt.name:after{
	content: none;
}
.flex_map dl div dd,
.flex_map dl div dd a{
	color: #fff;
}
.flex_map iframe{
	display: block;
}

@media screen and (max-width: 768px){
	.flex_quality{
		display : block;
	}
	.flex_quality .fbox.img_box{
		width: 100%;
	}
	.flex_quality .fbox.text_box{
		width: 100%;
		padding-top: 5%;
	}
	.flex_quality .l_fbox.text_box{
		padding-right: 0;
	}
	.flex_quality .r_fbox.text_box{
		padding-left: 0;
	}
	.couse_banner_area{
		display: block;
		padding: 0 25px 10px;
	}
	.couse_banner_area .couse_banner{
    	width: 100%;
	    max-width: 400px;
	    margin: 0 auto 5%;
	}
	.flex_map .l_fbox{
		width: 100%;
		padding: 5%;
	}
	.flex_map .r_fbox{
		width: 100%;
	}
	.flex_map iframe{
		height: 300px;
	}
}

/*お知らせ*/
.news_area h3{
	margin-bottom: 0px;
}
.news_area ul{
	padding: 0;
}
.news_area ul li{
	list-style: none;
	border-bottom: 2px solid #eee!important;
	margin: 0 0 15px;
	height: 140px!important;
	overflow: hidden;
}
.news_area ul li:last-child{
	border: none;
	margin-bottom: 0;
	padding-bottom: 0;
}
.news_area ul li a{
	text-decoration: none;
	color: #424242;
}
.news_area ul li a:hover{
	opacity: 0.8;
	text-decoration: underline;
}
.news_area ul li a:focus{
	outline: none;
}
.news_area ul li p{
	margin: 0 0 10px;
	line-height: 1.3;
	letter-spacing: 0;
}
.news_area ul li .tag_area .date{
	font-size: 14px;
	margin: 0 0 10px;
}
.news_area ul li .txt01{
	font-weight: 700;
	font-size: 18px;
	margin: 0 0 2px;
}
.news_area ul li .txt02{
	margin: 0;
}

/*page*/
body.page .entry-title{
	display: none;
}
.sub_mainvisual{
	position: relative;
}
.sub_mainvisual h1{
position: absolute;
top: 50%;
left: 50%;
-moz-transform: translate(-50%,-50%);
-webkit-transform: translate(-50%,-50%);
-ms-transform: translate(-50%,-50%);
transform: translate(-50%,-50%);
padding: 3%;
margin: 0;
background-color: transparent;
text-align: center;
font-size: 36px;
color: #fff;
background-color: #09aa39;
border-radius: 5px;
}
.sub_mainvisual h1:after {
content: '';
position: absolute;
display: inline-block;
left: 50%;
-moz-transform: translateX(-50%);
-webkit-transform: translateX(-50%);
-ms-transform: translateX(-50%);
transform: translateX(-50%);
border-radius: 5px;
bottom: 0;
width: 100%;
height: 7px;
background: -webkit-repeating-linear-gradient(-45deg, #09aa39, #09aa39 2px, #fff 2px, #fff 4px);
background: repeating-linear-gradient(-45deg, #09aa39, #09aa39 2px, #fff 2px, #fff 4px);
}
body.page-id-12 .sub_mainvisual h1{
	background-color: #ffb36b;
}
body.page-id-12 .sub_mainvisual h1:after {
background: -webkit-repeating-linear-gradient(-45deg, #ffb36b, #ffb36b 2px, #fff 2px, #fff 4px);
background: repeating-linear-gradient(-45deg, #ffb36b, #ffb36b 2px, #fff 2px, #fff 4px);
}
body.page-id-14 .sub_mainvisual h1{
	background-color: #f88080;
}
body.page-id-14 .sub_mainvisual h1:after {
background: -webkit-repeating-linear-gradient(-45deg, #f88080, #f88080 2px, #fff 2px, #fff 4px);
background: repeating-linear-gradient(-45deg, #f88080, #f88080 2px, #fff 2px, #fff 4px);
}
body.page-id-16 .sub_mainvisual h1{
	background-color: #4f9df4;
}
body.page-id-16 .sub_mainvisual h1:after {
background: -webkit-repeating-linear-gradient(-45deg, #4f9df4, #4f9df4 2px, #fff 2px, #fff 4px);
background: repeating-linear-gradient(-45deg, #4f9df4, #4f9df4 2px, #fff 2px, #fff 4px);
}

@media screen and (max-width: 768px){
	.sub_mainvisual h1{
	font-size: 28px;
    width: 80%;
    max-width: 260px;
	}
}

/*
course
*/
.head_area{
	padding: 5% 0;
	max-width: 880px;
	margin: auto;
}
.head_area p{
	color: #09aa39;
}
.head_area p:not(:last-child){
	margin-bottom: 0;
}
.flex_course{
    background-color: #09aa39;
    padding: 2% 0;
}
.flex_course .l_fbox{
	width: 50%;
	padding: 5% 3%;
	box-sizing: border-box;
}
.flex_course .r_fbox{
	width: 50%;
	padding: 5% 3%;
	box-sizing: border-box;
}
.course_box{
	padding: 1em 0;
}
body .course_box:nth-child(1),.course_box:nth-child(4),.course_box:nth-child(5){
	background-color: #f7f7f7;
}
body .course_box:nth-child(2),.course_box:nth-child(3),.course_box:nth-child(6){
	background-color: #fff;
}
.add_class{
	margin-top: 5%;
}
.flex_5_5 .l_fbox{
	width: 50%;
	padding-right: 2%;
	box-sizing: border-box;
}
.flex_5_5 .r_fbox{
	width: 50%;
	padding-left: 2%;
	box-sizing: border-box;
}
@media screen and (max-width: 768px){
	.head_area{
		padding: 5% 0;
	}
	.brackets_box01{
		width: 100%;
	}
	.brackets_box01 h2{
		font-size: 24px;
	}
	.flex_course .l_fbox{
		width: 100%;
		padding: 7% 5%;
		box-sizing: border-box;
	}
	.flex_course .r_fbox{
		width: 100%;
		padding: 7% 5%;
		box-sizing: border-box;
	}
	body .course_box:nth-child(odd){
		background-color: #f7f7f7;
	}
	body .course_box:nth-child(even){
		background-color: #fff;
	}
	.flex_5_5 .l_fbox,.flex_5_5 .r_fbox{
		width: 100%;
		padding: 1% 0;
	}
}


/*form*/
.contact-page{
	padding: 130px 0;
}
.cform th {
	font-size: 14px;
	width: 280px; /*変なところで改行される場合はここの数字を変更します。*/
	text-align: right;
	border-bottom: solid 1px #d6d6d6;
	padding: 10px 3% 10px 15px;
	font-weight: normal;
}

.cform td {
	font-size: 14px;
	line-height: 150%;
	border-bottom: solid 1px #d6d6d6;
	padding: 10px 5px;
}

.cform {
	width: 100%;
	margin: auto;
}

.cform [type=submit] {
	display: inline-block;
	font-size: 20px;
	padding: 10px 30px;
	text-decoration: none;
	background: #ff8f00;
	color: #FFF;
	border-bottom: solid 4px #B17C00;
	border-radius: 3px;
}

.cform option,
.cform textarea,
.cform input[type=text],
.cform input[type=email],
.cform input[type=search],
.cform input[type=url] {
	width: 100%;
}

.required-srt {
	font-size: 8pt;
	padding: 5px;
	background: #09aa39;
	color: #fff;
	border-radius: 3px;
	margin-left: 10px;
	vertical-align: middle;
}
select{
	width: auto;
}

@media only screen and (max-width:767px) {
	.contact-page{
		padding: 13% 0;
	}
	.cform th {
		text-align: left;
	}
	.cform th,
	.cform td {
		width: 100%;
		display: block;
		border-top: none;
	}
}

.back-btn input {
	background: #bfbcbc;
	width: 60%;
	max-width: 550px;
	min-width: 220px;
	margin: 30px auto;
	display: block;
	border: 3px #bfbcbc solid;
	text-align: center;
	padding: 15px;
	margin-bottom: 20px;
	color: #fff;
	transition: all 0.4s ease;
    font-size: 18px;
    border-radius: 10px;
    letter-spacing: 0.1em;
}

.back-btn input:hover {
	background: #fff;
	color: #bfbcbc;
}

.submit-btn input {
	background: #09aa39;
	width: 60%;
	max-width: 550px;
	min-width: 220px;
	margin: 30px auto;
	display: block;
	border: 3px #09aa39 solid;
	text-align: center;
	padding: 15px;
	color: #fff;
	transition: all 0.4s ease;
    font-size: 18px;
    border-radius: 10px;
    letter-spacing: 0.1em;
}

.submit-btn input:hover {
	background: #fff;
	color: #09aa39;
}

/*お知らせ一覧*/
.cat-news{
	padding: 15px 0;
}
.cat-news h3{
	font-size: 26px;
	position: relative;
	border: none;
	border-bottom: 4px solid #d6d4d4;
	padding: 0 15px 12px;
	margin: 0 auto 30px;
	max-width: 1040px;
}
.cat-news h3:after{
	position: absolute;
	content: " ";
	display: block;
	border-bottom: solid 4px #09aa39;
	bottom: -4px;
	left: 0;
	width: 25%;
}
.cat-news ul.news-ul{
	list-style: none;
	padding: 0 15px;
	width: 100%;
	border: none;
	max-width: 1040px;
	margin: 0 auto;
}
.cat-news ul.news-ul .parent-li + .parent-li{
	margin-top: 15px;
	padding-top: 15px;
	border-top: 1px dotted;
}
.cat-news p{
	margin: 0 0 10px;
	line-height: 1.3;
	letter-spacing: 0;
}
.cat-news .date{
	font-size: 14px;
	margin: 0 0 10px;
}
.cat-news .heading{
	font-size: 18px;
	font-weight: 700;
	margin: 0 0 2px;
}
@media screen and (max-width: 767px){
	.cat-news h3 {
		margin: 0 3% 30px;
	}
	.cat-news ul.news-ul {
		display: block;
		padding: 0 3%;
	}
}


/*合格体験一覧*/
.cat-result {
	padding: 15px 0;
}
.cat-result h3 {
	font-size: 26px;
	position: relative;
	border: none;
	border-bottom: 4px solid #d6d4d4;
	padding: 0 15px 12px;
	margin: 0 auto 30px;
	max-width: 1040px;
}
.cat-result h3:after {
	position: absolute;
	content: " ";
	display: block;
	border-bottom: solid 4px #09aa39;
	bottom: -4px;
	left: 0;
	width: 25%;
}
.cat-result ul.result-ul{
	display: flex;
	flex-wrap: wrap;
	padding: 0 15px;
  max-width: 1040px;
  list-style: none;
	margin: 0 auto;
	position: relative;
}
.cat-result ul.result-ul:after {
	content: "";
	position: absolute;
	width: 2px;
	height: 100%;
	background: #fff;
	top: 0;
	left: 15px;
}
.cat-result ul.result-ul:before {
	content: "";
	position: absolute;
	width: 100%;
	height: 2px;
	background: #fff;
	bottom: 0;
	left: 15px;
}
.cat-result ul.result-ul li{
	width: 33.33333%;
	padding: 10px 20px;
	border-bottom: 1px dashed;
	border-left: 1px dashed;
}
.cat-result ul.result-ul li:last-child:not(:nth-child(3n)){
	border-right: 1px dashed;
}

.result-item .box1 .juken-gakkou{
	position: relative;
	padding: 0 0 0 45px;
}
.result-item .box1 .juken-gakkou img{
	position: absolute;
	top: 0;
	left: 0;
}
.result-item .box1 .juken-gakkou h4{
	font-size: 18px;
	/* color: #09aa39; */
	line-height: 1.3;
}
.result-item .box1 .juken-gakkou .gakka{
	margin: 0;
	font-size: 14px;
	/* color: #09aa39; */
	line-height: 1.3;
}
.result-item .box1 .name{
	margin: 10px 0 0;
	font-size: 16px;
	line-height: 1.3;
}
.result-item .box1 .shusshin-school{
	font-size: 14px;
	margin: 0;
	line-height: 1.3;
}
.result-item .box1 .ama-course{
	font-size: 13px;
	padding: 1px 5px;
	margin: 10px 0 0;
	border: 1px solid;
	display: inline-block;
	background-color: rgba(9, 170, 57, 0.1);
	color: #09aa39;
}
.result-item .box1 .comment-title{
	font-size: 15px;
	font-weight: 700;
	margin: 5px 0 0;
}
.result-item .box2 .open-text{
	height: auto;
	overflow: visible;
	margin: 0;
}
.result-item .box2 .open-text.closed{
	height: 75px;
	overflow: hidden;
}
.result-item .box2 .open-text > p{
	font-size: 15px;
	line-height: 1.5;
}
.result-item .box2 .open-text > p:first-child{
	margin-top: 0;
}
.result-item .open-text-toggle{
	text-align: center;
}
.result-item .box2 .open-toggle-btn,
.result-item .box2 .close-toggle-btn{
	position: relative;
	padding-left: 20px;
	text-align: center;
}
.result-item .box2 .open-toggle-btn:before{
	content: "＋";
	position: absolute;
	top: 50%;
	left: 0;
	transform: translate(0,-50%);
	color: #09aa39;
	font-weight: 700;
}
.result-item .box2 .close-toggle-btn:before{
	content: "－";
	position: absolute;
	top: 50%;
	left: 0;
	transform: translate(0,-50%);
	color: #09aa39;
	font-weight: 700;
}

@media screen and (max-width: 767px){
	.cat-result h3 {
		margin: 0 3% 30px;
	}
	.cat-result ul.result-ul {
		display: block;
		padding: 0 3%;
	}
	.cat-result ul.result-ul li {
		width: 100%;
		border-left: none;
	}
	.cat-result ul.result-ul li:last-child:not(:nth-child(3n)) {
    border-right: none;
	}
}

/*pager*/
ul.page-numbers{
	list-style: none;
	border: none;
	width: 100%;
	height: auto;
	flex-wrap: wrap;
	padding: 0;
}
ul.page-numbers li{
	margin-bottom: 10px;
}
ul.page-numbers li .page-numbers {
	padding: 0;
	width: 45px;
	height: 45px;
	line-height: 45px;
	font-size: 18px;
	margin: 0 6px;
}



/*フッター固定メニュー*/
.search-menu-button{
	display: none;
}

.navi-in > ul > .menu-item-has-children > a::after {
  padding: 10% 4%;
}
