/* pc時の全体幅 */
.keni-main .keni-section_wrap {
    padding: 0px 0px!important;
	margin: 0;
}
img{
	width: 100%;
}
.section_inner{
	width: 90%;
	margin: 0 auto;
}

/* PC背景画像 */
.keni-main_wrap {
    background: #fff;
    background-size: cover;
    background-attachment: fixed;
}
 .keni-mv_wrap {
    overflow: hidden;
    background: #fff;
}

/* 自動<p>タグの非表示 */
p:empty{display: none;}
/* 自動<p>タグの非表示 */

/*目次非表示  */
#toc_container {
    background: #f9f9f9;
    border: 1px solid #aaa;
    padding: 10px;
    margin-bottom: 1em;
    width: auto;
    display: table;
    font-size: 95%;
    display: none!important;
}

/*サイドメニュー  */
.wj_title {
margin: 0!important;
}

/*ヘッダーメニュー*/
.keni-gnav_inner ul {
    border-top: 0;
    letter-spacing: -.5em;
    margin: 0 auto;
}

.keni-copyright {
	text-align: center;
	font-weight: bold;
}

@media (min-width: 1181px){
.keni-gnav_inner li a{
padding: 20px 40px !important;
color: #333!important;
font-weight: bold;
}
}
@media screen and (min-width:769px) and ( max-width:1180px) {
.keni-gnav_inner li a{
    padding: 6px 2vw !important;
}
}
@media (min-width: 768px){
.keni-gnav_inner li a {
display: block;
padding: 15px;
color: #000;
text-decoration: none;
line-height: 2.5!important;
letter-spacing: 2px!important;
}
	
.keni-gnav_inner ul {
    border-top: 0;
    letter-spacing: 1em!important;
    margin: 0 auto;
}
.keni-gnav_inner ul {
    border-top: 0;
    letter-spacing: 1px!important;
    margin: 0 auto;
}
	
.keni-gnav_wrap{
		margin:0 !important;
}

.keni-gnav_inner li a:hover{
    border-bottom: 2px solid #859989 !important;
}
	
.keni-gnav_inner li ul li a:hover{
    border-bottom:none !important;
}

.keni-gnav_inner li::before{
    content: "";
    position: absolute;
    top: 46%;
    transform: translatey(-50%);
    padding-top: 2em !important;
    border-left: solid 1px #A59383 !important;
	line-height: 40px;
}

.keni-gnav_inner #menu-item-193::before{
    content: none !important;
}
.keni-gnav-child_btn {
display:none !important;
}
	.keni-gnav_inner li a:active{
		border-bottom-color: #F7931E !important;
	}
}/*ここまで*/

/*ヘッダーメニュー サブメニュー*/
@media (min-width: 768px){
	.keni-gnav_inner li ul.sub-menu {
    border-top: 1px solid #fff !important;
}
.keni-gnav_inner li ul.sub-menu li {

    border-bottom: 1px solid #fff !important;
}
.keni-gnav_inner li ul.sub-menu a {
    background: var(--blue) !important;
    color: #fff !important;
    padding: 14px 2px 14px 14px !important;
}
	.keni-gnav_inner li ul.sub-menu li:last-child {
    border-bottom:none !important;
}
	.keni-gnav_inner li ul.sub-menu a:hover{
    background: #5CAF90 !important;
}
	}/*ここまで*/

/*ハンバーガーメニュー*/
@media (max-width: 768px) {
.keni-gnav_btn {
   background: #333!important;
	border-radius:8px !important;
	border:solid 1px #fff !important;
}
	.keni-gnav_btn_icon-open,.keni-gnav_btn_icon-open:before,.keni-gnav_btn_icon-open:after{
    background-color: #333 !important;
}
	.keni-gnav_btn_icon-close::before{
		color:#fff !important;
	}
	.search-box{
		display:none !important;
	}
	.keni-gnav_inner li a{
		background: var(--light_blue)!important;
		color:　var(--blue);!important;
		letter-spacing: 2px;
	}
	
	/*ハンバーガーメニュー サブメニュー*/
	#menu-item-246 .keni-gnav-child_btn,	#menu-item-247 .keni-gnav-child_btn{
		    width: 100% !important;
    text-align: right !important;
    padding-right: 15px !important;
	}
	.keni-gnav_cont .keni-gnav-child_btn_icon-close > .keni-gnav-child_btn::before,	.keni-gnav_cont .keni-gnav-child_btn_icon-open > .keni-gnav-child_btn::before{
		color:#fff !important;
	}
	.keni-gnav-child_btn_icon-close > ul li a{
		    background: var(--light_blue) !important;
	}
}/*ここまで*/

/*全体フォント変更  */
body {
font-family: 'HiraKakuProN-W3', sans-serif;
color:#5c4e4d;
}

/*改行  */
.pc_br {
    display: block;
}

.sp_br {
    display: none;
}
@media screen and (max-width: 768px) {
.pc_br {
display: none;
}
.sp_br {
display: block;
}
}

h2,
.h2_training {
	text-align: center!important;
}

h2 {
	background: var(--grey)!important;
}
.h2_training {
	background: var(--grey)!important;
}

h3,
.h3_ttl {
	border-top: 0px!important;
	text-align: center!important;
}

h3 {
	border-bottom: 2px solid var(--grey)!important;
	color: var(--grey)!important;
}

.h3_ttl {
	border-bottom: 2px solid #777777!important;
	color: #777777!important;
}

ul {
	margin: 0!important;
	list-style: none;
}

.photo {
	margin-bottom: 20px;
}

.sub-section_title {
	background: var(--grey)!important;
	color: #fff!important;
	font-weight: bold!important;
}

/*位置調整  */
 .keni-header_cont {
	 margin-top: 40px!important;
}

/*カラー  */
:root {
  --green: #28a745;
  --blue: #007bff;
	--light_green: #90ee90;
	--light_blue: #e6f2ff;
	--orange: #fd7e14;
	--grey: #777777;
	
}

/*---------------------------------------PC表示のCSS---------------------------------------  */
/* お知らせ */
.new {
	background: var(--light_blue);
	padding: 30px 20px;
	border-radius: 20px;
	margin-bottom: 30px;
}
.new p {
	margin-bottom: 0!important;
	text-align: center;
}

/*テーブルデザイン　トレーニングプラン  */
table , td, th {
	border: 1px solid #595959;
	border-collapse: collapse;
}
td, th {
	padding: 3px;
	width: 30px;
	height: 25px;
}
th {
	background: #f0e6cc;
}
.even {
	background: #fbf8f0;
}
.odd {
	background: #fefcf9;
}


/*トレーニングまでの流れ  */
.flow_training {
	margin-bottom: 40px!important;
}

.flow_training li {
	margin: 20px 160px;
	border-radius: 20px;
	font-weight: bold;
	font-size: 22px;
	text-align: center;
	position: relative;
	padding: 20px;
}

.flow_training li {
	background: #EEEEEE;
	color: var(--orange);
}

.flow_training li::after {
	position: absolute;
	bottom: -55%;
	left: 50%;
	transform: translatex(-50%);
	content: "";
	border: 23px solid transparent;
}

.flow_training li::after {
	border-top: 14px solid var(--orange);
}

.flow_training li:last-child::after {
	content: none!important;
}

/* リスト */
.list {
	margin-bottom: 20px;
}

.list li::before {
	content: "";     
	width:  15px;               
	height:  15px;              
	display:  inline-block;     
	border-radius:  50%;      
	margin-right: 5px;
	background-color: var(--blue);
}

/*料金について  */
.training_price {
	width: 100%;
	margin: 20px auto;
	border-collapse: collapse;
	background-color: #fff;
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}
.training_price th, 
.training_price td {
	padding: 15px;
	text-align: left;
	border-bottom: 1px solid #ddd;
}

.training_price th {
	background-color: #f2f2f2;
	font-weight: bold;
	color: #555;
}

.training_price tr:hover {
	background-color: #f9f9f9;
}

.training_price p {
	text-align: center;
	margin: 20px auto;
	font-size: 1.1em;
	color: #555;
}

/* キャンペーン */
.bg {
	background: var(--light_blue);
	padding: 30px 0;
}

.campaign {
    background-color: #fff;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    margin: 20px auto;
    padding: 20px;
    width: 80%;
}

.campaign h2 {
    text-align: center;
    color: #fff;
}

.campaign-box {
    margin-bottom: 20px;
}

.campaign-box h3 {
    color: #555;
    border-bottom: 2px solid #007BFF;
    padding-bottom: 5px;
}

.campaign-box p {
    margin: 10px 0;
}

/* アクセス */
.access {
    background-color: #fff;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    margin: 20px auto;
    padding: 20px;
    width: 80%;
}

.access h2 {
    text-align: center;
    color: #007BFF;
}

.access_info {
	padding: 0 0 20px 0;
	margin: 0 auto;
}

.access_info h3 {
    color: #555;
    margin-top: 20px;
}

.access_info p {
    margin: 10px 0;
}

.access_info th {
	width: 30%!important;
}
/*コンタクト  */
.contact {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	padding-bottom: 30px;
}

.contact　p {
	
}

.tel_item {
	width: 48%;
}

.line_item {
	width: 48%;
}

.contact_btn {
	padding-bottom: 20px;
}
/*---------------------------------------SP表示のCSS---------------------------------------  */
@media screen and (max-width: 768px) {
	/*Spヘッダー非表示　SP*/
.keni-header_cont,
.site-description{
display: none!important;
}

/*キャンペーンSP  */
.campaign {
	width: 90%;
}
	
/*料金  */
.training_price {
    width: 100%;
}
/*流れ  */
.flow_training li {
	height: 80px;
	line-height: 1.2;
	bottom: -50%;
}
	
}