@charset "utf-8";

/*
Theme Name: ideal2018
Theme URI: http://s-ideal.net/
Description: idealテーマ
Version: 2.0
Author: ideal shiraishi
Author URI: http://s-ideal.net/
*/

/* IMPORT BOOTSTRAP */
@import url("./css/bootstrap.css");



/********************************/
/*CSS初期設定           　　　　　 */
/********************************/

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
	border: none;
  margin: 0;
	padding: 0;
	vertical-align: baseline;
}
h2, h3, h4, h5, h6 {
  -ms-word-wrap: break-word;
  word-wrap:     break-word;
  line-height: 120%;
  margin: 30px 0 7px;
}
h1 {
  color: #666;
  font-size: 12px;
  margin: 2px 0 5px 0;
  font-weight: normal;
}
h2 {
  color: #222222;
  font-size: 22px;
}
h3 {
  color: #333333;
  font-size: 19px;
}
h4 {
  color: #444444;
  font-size: 17px;
}
h5 {
  color: #555555;
  font-size: 15px;
}
h6 {
  color: #666666;
  font-size: 14px;
}
p, ul, ol, li, dl, address {
  -ms-word-wrap: break-word;
  word-wrap: break-word;
  font-size: 16px;
  /*text-align: left;*/
}

ol {
	list-style-type: decimal;
  margin-left: 20px;
}
ol ol {
	list-style: upper-alpha;
}
ol ol ol {
	list-style: lower-roman;
}
ol ol ol ol {
	list-style: lower-alpha;
}
li{
	list-style-position: inside;
}
dl {
  margin-bottom: 20px;
}
dt {
	font-weight: bold;
}

strong {
	font-weight: bold;
}
cite, em, i {
	font-style: italic;
}
blockquote cite {
  display: block;
  font-style: normal;
	text-transform: uppercase;
}
a {
  color: #333;
  	text-decoration: underline;
    -webkit-transition: color 1s ease;
    -moz-transition: color 1s ease;
    -o-transition: color 1s ease;
    -ms-transition: color 1s ease;
    transition: color 1s ease;
}
a:hover{
	color: #f39f24;
	text-decoration: underline;
}


a img {
  border: none;
}
img {
  height: auto;
  max-width: 100%;
}
table {
  font-size: 14px;
  width: 100%;
}
table, td, th {
  border-collapse: collapse;
  text-align: left;
}
td, th {
  padding: 5px 8px;
}
th {
  font-weight: bold;
}
address {
  font-style: italic;
}
pre {
  margin-bottom: 20px;
  overflow: auto;
}
sup {
  vertical-align: super;
}
sub {
  vertical-align: sub;
}
iframe,
embed {
  clear: both;
  width: 100%;
}
hr {
  background: #e3e3e3;
  border: none;
  height: 1px;
  margin: 15px 0;
}

input,select,textarea{
	font-size: 16px;
	padding: 3px;
	box-sizing: border-box; 
}

.container{
	margin: 0 auto;
	overflow: hidden;
}

/********************************/
/*リンクエフェクト＆カラー設定　 */
/********************************/
.post-meta {
    clear: both;
    font-size: 13px;
    line-height: 21px;
    margin: 0;
    padding-bottom: 1em;
    color: #999;
}

.post-meta span {
    border-left: 1px solid #ccc;
    padding: 0 7px 0 10px;
    color: #999;
}

.post-meta span:first-child {
    border-left: none;
}


.post-meta a{
    text-decoration: none;
    color: #999;
}


.f-tel,
.f-tel2{
	text-align: center;
	margin-bottom: 10px;
}

.f-tel a{
	color: #333;
	-webkit-transition: color 1s ease;
    -moz-transition: color 1s ease;
    -o-transition: color 1s ease;
    -ms-transition: color 1s ease;
    transition: color 1s ease;
}

.f-tel2 a{
	color: #fff;
	-webkit-transition: color 1s ease;
    -moz-transition: color 1s ease;
    -o-transition: color 1s ease;
    -ms-transition: color 1s ease;
    transition: color 1s ease;
}


.f-tel a:hover,
.f-tel2 a:hover{
	color: #f39f24;
}

/********************************/
/*リンクボタンの設定　　　　　　*/
/********************************/

.cta-bt{
	width: auto;
	border-radius: 5px;
	font-size: 14px;
	text-align: center;
	text-decoration: none;
	display: block;
	border: 1px solid #f39f24;
	background-color: #fff;
	padding: 15px 0;
	margin-bottom: 10px;
	color: #f39f24;
	-webkit-transition: all 1s ease;
	-moz-transition: all 1s ease;
	-o-transition: all 1s ease;
	-ms-transition: all 1s ease;
	transition: all 1s ease;
}

.cta-bt:before{
	font-family: "Font Awesome 5 Free";
	content: "\f0e0";
	margin-right: 0.5em;
}

.cta-bt:hover{
	background-color: #f39f24;
	color: #fff;
	text-decoration: none;

}

.bt2,
.bt2_white{
	display: inline-block;
	padding: 5px 20px;
	border-radius: 10px;
	text-align: center;
	text-decoration: none;
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
}

.bt2{
	border: 1px solid #f39f24;
	color: #f39f24;
}

.bt2_white{
	border: 1px solid #fff;
	color: #fff;
}

.bt2:hover,
.bt2_white:hover{
	background-color: #f39f24;
	color: #fff;
	text-decoration: none;
}

.bt2_white:hover{
	border: 1px solid #1879c0;
}

.bt_sm{
	font-size: 16px;
	width: 100%;
	max-width: 380px;
}
.bt_lg{
	font-size: 25px;
	padding: 15px 0;
	width: 100%;
	max-width: 380px;
}

.circle_button:hover{
    background-color: #1879c0;
    border: 1px solid #1879c0;
	color: #fff !important;
    text-decoration: none;
}

.circle_button{
    border: 1px solid #fff;
    border-radius: 40px;
    color: white !important;
    display: inline-block;
    font-size: 18px;
    line-height: 18px;
    margin: 8px 0 3px;
    padding: 20px;
    text-decoration: none;
    text-transform: uppercase;
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
}
.read-more-button:hover, .intro-box .read-more-button:hover {
    color: #f39f24 !important;
    text-decoration: underline;
}
.read-more-button, .intro-box .read-more-button {
    color: #666 !important;
    font-size: 13px;
    line-height: 13px;
    text-decoration: underline;
    text-transform: uppercase;
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
}

.round-bt{
	display: inline-block;
	border: 1px solid #fff;
	padding: 5px 20px;
	border-radius: 20px;
	text-align: center;
	text-decoration: none;
	color: #fff;
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
}

.round-bt2{
	display: inline-block;
	border: 1px solid #333;
	color: #333;
	padding: 5px 20px;
	border-radius: 20px;
	text-align: center;
	text-decoration: none;
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
}

.line-bt{
	display: inline-block;
	background-color: #fff;
	padding: 5px 20px;
	border-radius: 20px;
	text-align: center;
	text-decoration: none;
	color: #00b900;
	width: 100%;
	max-width: 330px;
	position: relative;
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
}

.line-bt i{
	font-size: 30px;
	position: absolute;
	left: 100px;
	top: 3px;
}
.round-bt:hover,
.round-bt2:hover,
.line-bt:hover{
	border-color: #f39f24;
	color: #f39f24;
	text-decoration: none;
	 -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 6px #f39f24;
     box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 6px #f39f24;
}

.dl-bt{
	width: auto;
	border-radius: 10px;
	font-size: 14px;
	text-align: center;
	text-decoration: none;
	display: block;
	background-color: #f39f24;
	padding: 15px 0;
	margin-bottom: 10px;
	color: #ffffff;
}

.dl-bt:before{
	font-family: "Font Awesome 6 Free";
	content: "\f56d";
	margin-right: 0.5em;
}

/********************************/
/*スケルトンの設定　　　　　　　*/
/********************************/
body {
	color: #333;
	/*font-family: "Century Gothic","Helvetica","メイリオ","Meiryo","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","MS Pゴシック","MS P Gothic",sans-serif;*/
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo UI", "メイリオ", Meiryo, sans-serif;
	line-height: 160%;
	background-color: #fff;
}

#header {
	width: 100%;
	border-top: 3px solid #7fbf33;
}

#contents{
	background-color: rgba(255,255,255,0.7);
}

#main {
	width:100%;
}

#hero{
	background-color: #f3f7f8;
	padding: 40px 0;
}

#sidebar {
	width: 100%;
}

#footer {
	background-color: #282828;
}

/********************************/
/*ヘッダー内の設定　　　　　　　　*/
/********************************/
h1{
	text-align: center;
}
.sitettl-box,
.sitettl-box2{
	text-align: center;
}
.telbox{
	text-align: center;
	margin-bottom: 10px;
}
.telNum{
	font-size: 27px;
}

.telNum a{
	text-decoration: none;
}

.calltime{
	font-size: 12px;
	line-height: 120%;
	color: #999;
}

.sub_ttl,
.sub_ttl2{
	font-size: 13px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 10px;
}

.sub_ttl span,
.sub_ttl2 span{
	color: #7fbf33;
}

.one-h1{
	text-align: center;
}


/* ローカルナビ */
.local_nav1{
	border-top: 1px solid #999;
	border-bottom: 1px solid #999;
	margin-top: 60px;
}

.local_nav1 ul{
	overflow: hidden;
	padding: 25px 0;
	display: table;
	text-align: center;
	margin: 0 auto;
}

.local_nav1 li{
	float: left;
	list-style-type: none;
	border-right: 1px solid #999;
	padding: 0 1em;
}

.local_nav1 li:last-child{
	border-right: none;
}

.local_nav1 li a{
	text-decoration: none;
}


/********************************/
/*ナビゲーションの設定　　　    */
/********************************/

#toggle {
	width: 100%;
	background: #f39f24;
}
#toggle a{
	display: block;
	padding: 15px 0 15px;
	color:#FFF;
	text-align: center;
	text-decoration: none;
}


#globalnav .accbox{
    margin: 0 0 10px 0;
    padding: 0;
    max-width: 100%;
}

#globalnav .accbox li a {
	text-decoration: none;
}

/*1階層目のデザイン*/
.accbox > li{
	list-style-type: none;
	border-bottom: 1px solid #fff;
	background: #fff2cc;
    transition: all 0.5s;
}
.accbox > li > a,
.accbox > li > label{
	width: 100%;
	display: block;
    margin: 0;
    padding : 13px 12px;
    cursor :pointer;
	text-indent:-3px;
	font-weight: normal;
}

.accbox > li > a:hover{
	color: inherit;
}

.accbox > li > a > span,
.accbox > li > label > span{
	font-size: 12px;
	color: #7fbf33;
	font-weight: normal;
}


/*2階層目のデザイン*/
.accbox li ul{
	padding:  0 2em;
}

.accbox li ul li{
	border-bottom: 2px dotted #fff;
	padding: 5px 5px;
	background-color: inherit;
	font-size: 14px;
}

.accbox li ul li:last-child{
	border-bottom: none;
}

.accbox li ul li a{
    padding : 0;
}


/*アイコンを表示*/
.accbox > li > a:before,
.accbox > li > label:before {
    content: '\f054';
    font-family: "Font Awesome 5 Free";
    font-weight: bold;
    padding-right: 8px;
    color: #f39f24;
}

.accbox li ul li a:before {
    content: none;
    padding-right: 0;
}

/*ホバー時*/
.accbox > li:hover {
    background :#ffe9a9;
    color: #f39f24;
}

/*チェックは隠す*/
.accbox input {
    display: none;
}

/*中身を非表示にしておく*/
.accbox .accshow {
    height: 0;
    padding: 0;
    opacity: 0;
    transition: .5s;
    display: none;
}

/*クリックで中身表示*/
.cssacc:checked + label + .accshow {
    height: auto;
    opacity: 1;
    display: block;
}

/*アイコンを入れ替える*/
.cssacc:checked + label:before {
    content: '\f078';
    padding-right: 4px;
}

/* 画面サイズが768px以上の場合に適用sm */

@media (min-width: 768px){
	#toggle {
		display: none;
	}

	#globalnav .accbox {
		margin-bottom: 10px;
		overflow: hidden;
		display: block;
	}

	/*1階層目のデザイン*/

	#globalnav .accbox > li{
		float: left;
		background-color: inherit;
		border-left: 2px dotted #999;
		width: 16.6%;
		line-height: 120%;
		/*position: relative;*/
		height: auto;
	}

	#globalnav .accbox > li:first-child{
		border-left: none;
	}

	#globalnav .accbox > li > a,
	#globalnav .accbox > li > label{
		width: 100%;
		display: block;
		font-size: 14px;
		font-weight: bold;
		text-indent: 0;
		padding: 0;
		color: #333;
		padding: 10px 0;
		text-align: center;
		position: relative;
	}


	#globalnav .accbox li a span,
	#globalnav .accbox li label span{
		display: block;
	}


	/* 2階層目のデザイン */
	#globalnav .accbox > li ul{
		width: 192px;
		/*height: 100%;*/
		padding: 0;
		position: absolute;
		/*overflow: hidden;*/
		z-index: 1;
		top: 200px;
		list-style-type: none;
		background-color: #abd578;
	}

	#globalnav .accbox > li ul li{
		/*float: none;*/
		border-left: none;
		border-bottom: 2px dotted #fff;
		padding: 0;
		margin: 0;
	}

	#globalnav .accbox li ul li:last-child{
		border-bottom: none;
	}

	#globalnav .accbox li ul li a{
	    display: block;
	    padding: 10px 1em;
		font-size: 14px;
		width: 100%;
		line-height: 120%;
		color: #fff;
	}

	/* アイコンを非表示 */
	#globalnav .accbox li a:before,
	#globalnav .accbox li label:before {
	    content: none;
	}

	/*2階層目のホバーアニメーション*/
	.accbox > li ul li a:hover {
	    background-color :#7fbf33;
	}

	/* 1階層目のホバーアニメーション */
	#globalnav .accbox > li > a:before,
	#globalnav .accbox > li > label:before{
		background-color: #7fbf33;
		bottom: 0;
		content: "";
		position: absolute;
		width: 100%;
		height: 2px;
		left: 0;
		visibility: hidden;
		transform: scaleX(0);
		-webkit-transform: scaleX(0);
		transition: all .2s ease-in-out 0s;
		-webkit-transition: all .2s ease-in-out 0s;
	}

	#globalnav .accbox > li > a:hover:before,
	#globalnav .accbox > li > label:hover:before{
	  visibility: visible;
	  transform: scaleX(1);
	  -webkit-transform: scaleX(1);
	}
}

/* 画面サイズが992px以上の場合に適用 */

@media only screen and (min-width: 992px) {
	/* 2階層目の場所 */
	#globalnav .accbox > li ul{
		top: 165px;
	}

}
/********************************/
/*メインヴィジュアルの設定　　　*/
/********************************/

#hero-container{
	height: 297px;
	margin: 0 auto;
	background: url(./images/main-v_xs.jpg) no-repeat;
	background-position: center center;
	overflow: hidden;
	padding: 0 10px;
	z-index:0;
}

#hero-container .text1{
	max-width: 50%;
	min-width: 175px;
}


#hero-container .text4{
	overflow: hidden;
	padding-top: 5px;
}

#hero-container .text4 .plan{
	font-size: 16px;
	background: url(./images/pattern2.png) repeat;
	color: #fff;
	display: inline-block;
	font-weight: normal;
	margin: 0 10px 10px 0;
	padding: 0 5px;
}

#hero-container .text4 .price{
	font-size: 16px;

}
#hero-container .text4 .price .first{
	font-size: 50px;
	color: #e71218;
}
#hero-container .text4 .price .second{
	font-size: 35px;
	color: #e71218;
}

/* 画面サイズが481px以上の場合に適用(xs) */
@media (min-width: 481px){
	#hero-container{
		position: relative;
	}

	#hero-container .text1{
		position: absolute;
		max-width: 65%;
		top: 40px;
		left: 40px;
	}
	.wordingbox{
		background-color: rgba(255,255,255,0.5);
		border-radius: 5px;
		padding: 20px 20px 5px 20px ;
		position: absolute;
		left: 20px;
		bottom: 20px;

	}
	#hero-container{
		max-width: 1300px;
		height: 500px;
		background-image: url(./images/main-v.jpg);
	}

	#hero-container .text4{
		margin-bottom: 15px;
		padding-top: 12px;
		overflow: hidden;
	}

	#hero-container .text4 .plan{
		width: 195px;
		text-align: center;
		font-size: 16px;
		font-weight: bold;
		float: left;
		margin-top: 22px;
	}

	#hero-container .text4 .price{
		font-size: 20px;
		float: right;
	}
	#hero-container .text4 .price .first{
		font-size: 70px;
	}
	#hero-container .text4 .price .second{
		font-size: 50px;
	}
}

/* 画面サイズが768px以上の場合に適用sm */
@media (min-width: 768px){
	.wordingbox{
		width: 590px;
		left: 40px;
	}

	#hero-container .text4{
		height: 80px;
		padding-top: 20px;
	}

	#hero-container .text4 .plan{
		width: 250px;
		font-size: 20px;
	}

	#hero-container .text4 .price .first{
		font-size: 80px;
	}

	#hero-container .text4 .price .second{
		font-size: 60px;
	}
}

/* 画面サイズが992px以上の場合に適用(md) */
@media (min-width: 992px){


}

/* 画面サイズが1200px以上の場合に適用(lg) */
@media (min-width: 1200px){


}

/********************************/
/*フッター内の設定　　　　　　　　*/
/********************************/
#footer p,
#footer ul li,
#footer ol li{
	font-size: 14px;
	line-height: 1.2em;
}



#footer-primary{
	color: #646464;
	padding: 40px 0;
	border-bottom: 1px dotted #646464;
	margin-bottom: 40px;
	text-align: center;
}

#footer-secondary{
	text-align: center;
}

#footer-secondary,
#footer-secondary a,
#footer-primary a{
	color: #646464;

}

#footer-secondary a:hover{
	color: #f39f24;
}


#copyright{
	font-size: 12px;
	padding: 20px 0 10px 0;
	margin: 0;
	text-align: center;
}

.f-tel,
.f-tel2{
	font-size: 50px !important;
	line-height: 1 !important;

}
.f-tel span,
.f-tel2 span{
	font-size: 14px;
}

.mail-bt{
	margin: 10px 0;
	width: 100%;
	max-width: 330px;
}

.f-nav li{
	list-style-type: none;
	display: inline;
	margin-right: 1em;
}

/*TOPへ戻る PC・タブレット追尾型
--------------------------------------*/
#page-top {
	opacity: 0.5;
	position: fixed;
	bottom: 40px;
	right: 20px;
	text-align: center;}

#page-top i {
	margin: 0;
}
#page-top a {
	background-color: #fff;
	text-decoration: none;
	color: #ccc;
	width: 60px;
	height: 60px;
	line-height: 60px;
	display: block;
	font-size: 18px;
	border-radius: 60px;
	border: 1px solid #ccc;
	-webkit-transition: all 1s ease;
	-moz-transition: all 1s ease;
	-o-transition: all 1s ease;
	-ms-transition: all 1s ease;
	transition: all 1s ease;
}
#page-top a:hover {
    background: #abd578;
    border: 1px solid #fff;
    color: white;
    opacity: 1;
    filter: alpha(opacity=100);
}


/********************************/
/*見出しの設定　　　　　　　　　*/
/********************************/


#contents-ttl{
    width: 100%;
    height: 70px;
    background-image: url("./images/pagetite_bg.png");
}

#contents-ttl h2{
text-align: center;
	color: white;
	font-size: 26px;
	line-height: 70px;
	margin: 0 auto 0 auto;
	text-shadow: -1px -1px 0px #93c950;
}
.ttl_type1{
display: table;
	background: url(./images/pattern1.png) repeat-x bottom;
	text-align: center;
	font-size:26px;
	font-weight: bold;
	margin: 0 auto 40px auto;
}

.ttl_type1:before{
	content: url(./images/eyechatch.png);
	display: block;
}

.ttl_type1_2{
	display: table;
	background: url(./images/pattern1.png) repeat-x bottom;
	text-align: center;
	font-size:28px;
	font-weight: bold;
	margin: 0 auto 40px auto;
}

.ttl_type2,
.ttl_type2_2{
	background: url(./images/pattern2.png) repeat;
	text-align: center;
	font-size: 25px;
	font-weight: normal;
	color: #fff;
	margin: 0;
	padding: 10px 0;
}

.ttl_type2_3{
	background: url(./images/pattern2.png) repeat;
	text-align: center;
	font-size: 20px;
	color: #fff;
	margin: 0;
	padding: 5px 0;
}

.ttl_type2_4{
	background: url(./images/pattern3.png) repeat;
	text-align: center;
	font-size: 20px;
	color: #fff;
	margin: 0;
	padding: 5px 0;
}


.ttl_type3{
	font-size: 18px;
	color: #333333;
	font-weight: bold;
	margin: 0;
}

.ttl_type3:before{
	font-size: 22px;
	color: #7fbf33;
	font-family: "Font Awesome 5 Free";
	content: "\f22d";
	margin: 0 .2em 0 0;
}

.ttl_type4,
.ttl_type4_2,
.ttl_type4_3,
.ttl_line{
	font-size: 25px;
	margin: 0;
	font-weight: normal;
	font-weight: bold;
}

.ttl_type4{
	color: #333;
}
.ttl_type4_2{
	color: #f39f24;
}
.ttl_type4_3{
	color: #7fbf33;
}

.ttl_line{
	color: #ffffff;
}

.ttl_line img{
	vertical-align: middle;
}

.ttl_type5,
.ttl_type5_2,
.ttl_type5_3{
	font-size: 20px;
	color: #333;
	font-weight: bold;
	margin: 0;
	text-align:center;
}

.ttl_type5_2:before{
	content:"-";
	margin-right: 0.5em;
}

.ttl_type5_2:after{
	content:"-";
	margin-left: 0.5em;
}

.ttl_type6{
	font-size: 16px;
	color: #f39f24;
	font-weight: bold;
	margin: 0;
}

.ttl_type7,
.ttl_type7_2{
	color: #f39f24;
	font-weight: normal;
	margin: 0;
	background: url(./images/good.png) no-repeat left 0;
}

.ttl_type7{
	font-size: 20px;
	padding: 7px 0 7px 2em;
}

.ttl_type7_2{
	font-size: 16px;
	font-weight: bold;
	padding: 9px 0 9px 2.5em;
}


.ttl_type8_phone{
	font-size: 20px;
	background: url(./images/phone.png) no-repeat left 0;
	margin: 0;
	padding: 8px 0 8px 40px;
}

.ttl_type8_car{
	font-size: 20px;

}

.ttl_type8_car:before{
	font-family: "Font Awesome 5 Free";
	content: "\f1b9";
	margin-right: 0.5em;
}

.ttl_type9,
.ttl_type9_2{
	font-size: 18px;
	color: #7fbf33;
	font-weight: bold;
	margin: 0;
}

.ttl_type9 span,
.ttl_type9_2 span{
	display: inline-block;
	padding: 2px 10px;
	background-image: url(./images/pattern2.png);
	color: #fff;
	font-weight: normal;
	border-radius: 3px;
	margin-right: 0.5em;
}

.ttl_type9 .type1,
.ttl_type9_2 .type1{
	margin-left: 10px;
}

.ttl_type9 .type2,
.ttl_type9_2 .type2{
	margin-right: 10px;
}

.ttl_type10{
	font-weight: normal;
	margin: 0;
	border-left: 5px solid #f39800;
	font-size: 24px;
	padding: 7px 0 7px .5em;
}

.ttl_type10_2{
	font-weight: normal;
	margin: 0;
	border-left: 5px solid #7fbf33;
	font-size: 24px;
	padding: 7px 0 7px .5em;
}

.ttl_type11{
	font-size: 20px;
	font-weight: bold;
	color: #7fbf33;
	background-color: #e7e7e7;
	padding: 15px 0;
	margin: 0;
}

.ttl_type12{
	position: relative;
	margin-bottom: 30px;
}

.ttl_type12:before{
	content: "";
	position: absolute;
	width: 100px;
	height: 2px;
	margin: 0 auto;
	left: 0;
	right: 0;
	bottom: -10px;
	background-color: #7fbf33;
}

.qa_ttl_q{
	font-size: 18px;
	color: #f39800;
	font-weight: normal;
}
.qa_ttl_q:before{
	content: "Q";
	display: inline-block;
	background-color: #f39800;
	color: #fff;
	padding: 5px 10px;
	border-radius: 5px;
	margin-right: 0.5em;
}
.qa_ttl_a{
	font-size: 18px;
	color: #666;
	font-weight: normal;
}
.qa_ttl_a:before{
	content: "A";
	display: inline-block;
	border: 2px solid #f39800;
	background-color: #fff;
	color: #f39800;
	padding: 5px 10px;
	border-radius: 5px;
	margin-right: 0.5em;
}
/********************************/
/*トップページ固有の設定    　　*/
/********************************/

#first{
	position: relative;
}

.oyakusoku{
	text-align: center;
	margin-bottom: 20px;
}

/* インフォメーションリスト-------------------------------------------------------------- */

.info_list{
	margin: 0;

}

.info_list dt{
	clear:left;
	float:left;
	padding: 1em 0 0 0;
}

.info_list dd{
	border-top: 1px dashed #999;
	padding: 1em 0 1em 7em;
}

.info_list dd:last-child{
	border-bottom: 1px dashed #999;
}



/********************************/
/*記事＆記事一覧ページ固有の設定　    */
/********************************/

.sidebar-ttl{
	border-bottom: 1px dashed #7fbf33;
	padding-bottom: 10px;
}

.entry-exerpt p{
	font-size: 14px;
	color: #666;
	line-height: 140%;
}

.post-info-author:before{
	font-family: "Font Awesome 5 Free";
	content:"\f118";
}

.post-infodate:before{
	font-family: "Font Awesome 5 Free";
	content:"\f017";
}

.post-info-category:before{
	font-family: "Font Awesome 5 Free";
	content:"\f07b";
}

.post-category-icon{
	position: absolute;
	top: 0px;
	left: 5px;
	display: block;
	background-color: #fcee21;
	font-size: 10px;
	color: #000;
	padding:0 5px;
	transform: rotate(-25deg);
	-moz-transform: rotate(-25deg);
	-webkit-transform: rotate(-25deg);
}

.content-headline {
    float: left;
    margin: 0 0 13px;
    width: 100%;
}

#content .post-meta {
    margin: 0 0 20px;
    padding: 10px 5px;
    background-color: rgba(255,255,255,.5);
    border-radius: 5px;
}


.pager {
    text-align: center;
    font-size: 12px;
    margin-bottom: 40px;
}

.pager .current {
    width: 30px;
    height: 30px;
    border-radius: 15px;
    border: 1px solid #666;
    background-color: #666;
    color: #fff;
    display: inline-block;
    line-height: 30px;
}

.pager a{
	display: inline-block;
	width: 30px;
	height: 30px;
	border-radius: 15px;
	border: 1px solid #666;
	line-height: 30px;
	color: #666;
	text-decoration: none;
	-webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
}

.pager a:hover{
	border: 1px solid #f39f24;
	color: #f39f24;
}


.post-nav{
	overflow: hidden;
	border-bottom: 1px solid #999;
	border-top: 1px solid #999;
	padding: 10px 0;
}

/* サイドバー用サムネイル付き投稿一覧 */

.side-thmbnailtype-list li{
	list-style-type: none;
	overflow: hidden;
	border-top: 1px solid #eee;
	padding: 10px 0 5px 0;
}
.side-thmbnailtype-list li:last-child{
	border-bottom: 1px solid #eee;
}
.side-thmbnailtype-list .thumbnail{
	width: 100px;
	display: block;
	float: left;
}
.thmbnailtype-ttl{
	color: #333;
	float: right;
	width: calc(100% - 110px);
	text-align: left;
	font-size: 14px;
	line-height: 130%;
}
.thmbnailtype-ttl a{
	text-decoration: none;
}

/* パネル型投稿一覧*/
.post-entry_panel{
	margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 1px dashed #999;
    overflow: hidden;
}

.post-entry_panel .post-entry-headline{
	margin-top: 0;
	font-size: 14px;
}

.post-entry_panel .post-data{
    font-size: 13px;
    color: #999;
}

.post-entry_panel .post-entry-img{
	float: left;
	width: 40%;
	margin-right: 15px;
}
/* リスト型投稿一覧*/
.post-entry_list{
	padding: 30px 10px;
	border-top: 1px dotted #999;
	overflow: hidden;
}

.post-entry_list .post-entry_img{
	position: relative;
	margin-bottom: 10px;
}


.post-entry_list .entry-ttl{
	/*color: #f39f24;*/
	font-weight: normal;
	margin: 0 0 10px 0;
	font-size: 18px;
	font-weight: bold;
}

.post-entry_list .entry-data{
	font-size: 14px;
	margin-bottom: 10px;
	color: #999;
}

.post-entry_list .entry-data a{
	text-decoration: none;
	color: #999;
}

.post-entry_list .post-category-icon{
	left: -8px;
}

@media (min-width: 481px){

	.post-entry_list .post-entry_img{
		width: 40%;
		float: left;
		margin: 0 20px 0 0;
	}

	.post-entry_list .entry-ttl{
		font-size: 20px;
	}

}




/* entry-content 専用
-------------------------------------------------------------- */

.entry-content p{
  font-size: 16px;
  margin-bottom: 2.8em;
  line-height: 1.6em !important;
}

.entry-content b{
	color: #555;
}

.entry-content > h2{
  font-size: 22px;
  padding-bottom: 8px;
  border-bottom: 2px solid #d2ccce;
  margin-bottom: 2em;
  margin-top: 3em;
  font-weight: bold;
  /*background-color: #e3e0e1;*/
  position: relative;
}

.entry-content > h2:before{
	position: absolute;
	display: block;
	content: "";
	width: 20%;
	border-bottom: 2px solid #7fbf33 ;
	bottom:-2px;
	left: 0;
}
.entry-content h3{
  font-size: 20px;
  margin-bottom: 1.5em;
  margin-top: 3em;
  padding-bottom: 10px;
  border-bottom: 1px dashed #999;
  font-weight: bold;
  /*color: #7fbf33;*/
}

.entry-content h4{
  color: #333;
  font-size: 18px;
  padding: 5px 0;
  font-weight: normal;
  margin-bottom: 1em;
  border-left: 5px solid #7fbf33;
  padding-left: 0.5em;
}

.entry-content h5{
  color: #333;
  font-size: 18px;
  margin-bottom: 1em;
  font-weight: normal;
}

.entry-content h6{
  color: #333;
  font-size: 16px;
  margin-bottom: 1em;
}

.entry-content ul{
  margin-bottom: 2.8em;
}

.entry-content > blockquote {
  font-size: 18px;
  background: #e3e3e3;
  clear: both;
  color: #333333;
  font-style: italic;
  margin: 0 0 20px;
  padding: 15px;
}

.entry-headline {
    color: #333;
    font-size: 24px;
    line-height: 100%;
    margin: 1em 0 1em;
    padding: 0 0 8px;
    position: relative;
    z-index: 50;
    font-weight: normal;
}

.entry-content .code{
	background-color: #f4f4f4;
	border: 1px solid #e0e0e0;
	padding: 2px 0 2px 4px;
	color: #666;
}

.well {
	background-color: #f3f7f8;
    border-radius: 10px;
    padding: 20px;
    margin-bottom: 1.5em;
}

.well table,.well table tr,.well table td{
	border: none;
}

.well .well-ttl{
	font-size: 18px;
	font-weight: bold;
	margin: 0;
	border: none;
}

.well ul{
	margin: 0;
}

.well ul li{
	line-height: 2em;
}

.voice {
    margin: 1em 0 1.3em;
    font-size: 0.9em;
	overflow: hidden;
}

/*
.cf::before,
.cf::after{
    content: "";
    display: table;
}*/

.voice.l .icon {
    float: left;
}

.voice.r .icon {
    float: right;
}

.voice.md .icon {
    width: 23%;
}

.entry-content figure {
    clear: both;
    font-size: 90%;
    /*text-align: center;*/
 }

.voice .icon img {
    width: 80%;
    margin: 0;
    border-radius: 90px;
    border: 3px solid #eee;
}

.voice .icon .name {
    font-size: 85%;
    color: #999;
}
.entry-content figcaption {
    margin: 0 0 0.5em;
    font-size: 80%;
}


.voice.l .voicecomment::after {
    content: '';
    position: absolute;
    border-right: 10px solid #fff;
    border-bottom: 8px solid transparent;
    border-top: 8px solid transparent;
    top: 10px;
    left: -7px;
}
.voice.l .voicecomment::before {
    content: '';
    position: absolute;
    border-right: 8px solid #eee;
    border-bottom: 8px solid transparent;
    border-top: 8px solid transparent;
    top: 10px;
    left: -11px;
}

.voice.md .voicecomment {
    width: 76%;
}
.voice.l .voicecomment {
    float: right;
}

.voice.r .voicecomment {
    float: left;
}
.voice .voicecomment {
    border: 3px solid #eee;
    background-color: #fff;
    width: 80%;
    padding: 2.5%;
    position: relative;
    border-radius: 5px;
    text-align: left;
    letter-spacing: 0.1em;
    color: #666;
    font-size: 100%;
}

.circle-ttl{
	font-size: 20px;
	text-align: center;
}

.circle-cl1{
	color: #abc10b;
}

.circle-cl2{
	color: #8f82bc;
}
.circle-cl3{
	color: #e2943c;
}
.circle-cl4{
	color: #00a5d5;
}
.circle-cl5{
	color: #23ac38;
}
.circle-cl6{
	color: #df7d84;
}

/* mokuji
-------------------------------------------------------------- */
.mokuji{
	border: 5px solid #ccc;
	padding: 10px;
}

.mokuji_ttl{
	text-align: center;
	background-color: #ccc;
	color: #fff;
}

/* comments area
-------------------------------------------------------------- */

#comments {
	float: left;
	margin-top: 25px;
	width: 100%;
}
.single .comments-area-post {
	margin-top: 5px !important;
}
.page #comments {
  margin-top: 16px !important;
}

.commetslist > li {
	margin: 15px 0 0 0;
	padding: 20px;

}

.commetslist .children {
  list-style-type: none;
}

.commetslist .children li{
	border-top: 1px dashed #999;
	padding: 20px 0 0 0;
}


.commetslist {
  list-style-type: none;
  margin: 0 0 30px 0;
  background-color: #f3f7f8;
  border-radius: 10px;
}

.comment-reply-title {
  font-size: 20px;
  font-weight: normal;
  line-height: 100%;
  margin-top: 0;
}
#comments .entry-headline-wrapper {
  margin-bottom: -21px;
}

#comments .entry-headline {
  color: #333333;
  font-size: 20px;
  font-weight: normal;
  padding: 0;
}

.comment-reply-link {
  font-size: 13px;
  text-decoration: none;
}
.comment-reply-link:before {
  content: "\f112";
  font-family: FontAwesome;/*Font Awesomeのフォント使用*/
  margin-right:5px;
}
.comments-title {
  margin-top: 0;
}
.section-heading {
  font-weight: normal;
}

#comments ol ol {
  margin: 0 20px;
}
#comments ol li {
  margin: 15px 0 0 0;
  padding: 20px;
}

#comments .avatar,
#comments .fn {
  float: left;
  margin: 0 6px 0 0;
}
#comments .avatar{
  border-radius: 22px;
  width: 44px;
  height: 44px;
}

#comments .fn {
  font-style: italic;
  margin: 0 3px 0 0;
  font-weight: bold;
}

#comments .comment-author{
	float:left;
	width: 50%;
	margin-bottom: 10px;
}

#comments .commentmetadata,
#comments .edit-link {
  color: #555555;
  float: right;
  font-size: 13px;
}

#comments .comment-body p {
  clear: both;
  padding-top: 10px;
  font-size: 13px;
  margin-bottom: 10px;
  line-height: 140%;
}

#comments #comment-nav-below {
  float: left;
  margin: 10px 0 30px;
  width: 100%;
}
#comments input,
#comments textarea {
  margin-top: 7px;
}
#commentform .form-allowed-tags {
  color: #707070;
  font-size: 12px;
}
#comments .bypostauthor {
  margin-bottom: -15px;
}

#comments input,
#comments textarea {
	margin-top: 7px;
}

#comments textarea {
    font-size: 14px;
    overflow: auto;
    vertical-align: top;
    width: 100%;
}

.reply {
  width: 50%;
  font-size: 13px;
}


.comment-content .edit-link {
  margin: -15px 0 0;
  text-align: right;
  width: 50%;
}
.comment-content li {
  border: none;
  font-size: 13px;
  margin: 0;
  padding: 0;
}
#commentform p {
  color: #333333;
  font-size: 13px;
  margin-bottom: 5px;
}
#commentform .logged-in-as,
#commentform .comment-notes {
  margin-top: 0;
}
#comments #respond {
  float: none;
  margin-bottom: 20px;
  width: 100%;
}
#comments .comment-form-author label:after{
  content: "(必須)";
  font-size: 10px;
  color: #ff0000;
  margin-left:5px;
}

#comments .comment-form-author label:before{
	font-family: "Font Awesome 5 Free";
	content: "\f007";
	margin-right:5px;
}

#comments .comment-form-email label:before{
	font-family: "Font Awesome 5 Free";
	content: "\f003";
	margin-right:5px;
}

#comments .comment-form-url label:before{
	font-family: "Font Awesome 5 Free";
	content: "\f0ac";
	margin-right:5px;
}

/*******************************************/
/*メールフォーム　　　               　　　*/
/*******************************************/


.mailform {
	margin-bottom: 20px;
}

.mailform th,
.mailform td{
	width: 100%;
	display: block;
}

.mailform td{
	border-bottom: 1px dashed #999;
	padding-bottom: 20px;
}

.mailform th{
	padding-top: 20px;
	font-size: 18px;
	color: #444;
}

.mailform tr:first-child th {
	border-top: 1px dashed #999;
}

.mailform .wpcf7-form-control{
	display: block;
	width: 100%;
	padding: 6px 12px;
	font-size: 16px;
	line-height: 1.42857143;
	color: #555;
	background-color: #fff;
	background-image: none;
	border: 1px solid #ccc;
	border-radius: 4px;
	-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
	box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
	-webkit-transition: border-color ease-in-out .15s, -webkit-box-shadow ease-in-out .15s;
	-o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
	transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
}

@media (min-width: 991px) {

	.mailform tr:first-child td {
	border-top: 1px dashed #999;
}

	.mailform th,
	.mailform td{
		width: 100%;
		display: table-cell;
		border-bottom: 1px dashed #999;
		padding: 40px 20px;

	}

	.mailform th  {
		width: 30%;
		text-align: left;
		background-color: #f4f4f4;
		vertical-align: top;
	}
}

.recaptcha{
	width: 304px;
	margin: 0 auto 30px auto;
}
/********************************/
/*ページ共有パーツの設定*/
/********************************/

.sec_type1,
.sec_type2,
.sec_type3,
.sec_type4{
	padding-top: 50px;
	padding-bottom: 50px;
}

.sec_type2{
	background-color: #f3f7f8;
}
.sec_type3{
	background: url(./images/img5.jpg) center center / cover no-repeat;
	color: #333;
}

.sec_type4{
	background-color: #00b900;
	color: #fff;
}
.round-ttl-wrap{
	width: 250px;
	height: 250px;
	border-radius: 150px;
	background-color: #abd578;
	margin: 0 auto;
	color: #fff;
}

.round-ttl-wrap span{
	height: 250px;
	width: 250px;
	display:table-cell;
	vertical-align: middle;
	text-align: center;
	font-size: 35px;
	font-weight: normal;
	line-height: 1em;
}

.price_type1{
	font-size: 48px;
	color: #e71218;

}

.price_type1 span{
	font-size: 20px;
	color: #444;
}

.box-type1{
	background-color: #f4f4f4;
	border: 2px dashed #ccc;
	border-radius: 30px;
	padding: 25px;
}

.box-type1_2{
	background-color: #fff;
	border: 1px dashed #ccc;
	border-radius: 30px;
	padding: 25px;
}

.box-type2{
	border: 1px solid #ccc;
	border-radius: 15px;
	padding: 25px;
}

.box-type2_2{
	border: 1px solid #ccc;
	border-radius: 15px;
	padding: 25px;
	background-color: #f4f4f4;
}
.use-soft{
	border: 1px dotted #f39f24;
	color: #f39f24;
	text-align: center;
	margin-bottom: 10px;
}

.circle-img{
	width: 100%;
	max-width: 300px;
}

.mokuhyou{
	border-bottom: 2px solid #ccc;
}

.siteout:after{
	font-family: "Font Awesome 5 Free";
	content: "\f2f5";
	font-weight: 900;
}
/* コースリスト
-------------------------------------------------------------- */



.courselist h4{
	font-size: 20px;
}

.courselist h4 img{
	vertical-align: middle;
	margin-right: 0.5em;
}

.courselist .caption{
	border-bottom: 1px dotted #e3e0e1;
	padding: 1em;
}

.courselist .time{
	overflow: hidden;
	border-bottom: 1px solid #e3e0e1;
	margin-bottom: 2.5em;
}

.courselist .time h5{
	margin: 0;
	float: left;
	width: 50%;
	padding: 1em;
}

.courselist .time p{
	margin: 0;
	float: right;
	width: 50%;
	text-align: right;
	padding: 1em;
}

.courselist2{
	list-style: none;
	border-bottom: 1px dotted #ccc;
	padding: 20px 0;
	text-align: center;
}

.courselist2:last-child{
	border-bottom: none;
	margin-bottom: 0;
}

/* パンクズリスト
-------------------------------------------------------------- */

#breadcramb {
	width: 100%;
    background-color: #e3e0e1;
}

#breadcramb p {
    height: 30px;
    margin: 0 auto 0 auto;
    font-size: 86%;
    line-height: 30px;
}
/* ページナビ
-------------------------------------------------------------- */

.nav-next {
    float: right;
    margin: 0;
    text-align: right;
    width: 50%;
    font-size: 14px;
}
.nav-previous {
    float: left;
    margin: 0;
    width: 50%;
    font-size: 14px;
}

/* テーブル
-------------------------------------------------------------- */
.tbl1{
  border-collapse: collapse;
  margin-bottom: 30px;

}
.tbl1 td {
  vertical-align: middle;
  padding: 10px;
  background-color: #fff;
  border: 1px solid #e3e0e1;
}
.tbl1 th {
  background-color: #ecf6e1;
  border: 1px solid #e3e0e1;
  text-align: center;
  vertical-align: middle;
  padding: 10px;
  font-weight: bold;
  color: #666666;
}
.tbl1 img {
  vertical-align: middle;
  margin-right: 10px;
}
.tbl1 .detail{
	font-size: 85%;
	font-weight: normal;
	display:inline-block;
	margin-top: 10px;
	line-height: 100%;
}

.tbl1 .text_xs{
	font-size: 75%;
	font-weight: normal;
}

.tbl1 .blankcell{
	background-color: #e5e5e5;
	height: 15px;
	padding: 0;
}

.tbl1 .bg2{
	background-color: #f6ece1;
}

.tbl-center td{
	text-align: center;
}

/*tbl2使わないかも↓*/

.tbl2{
	border: none;
}

.tbl2 tbody tr {
	display: block;
	margin-bottom: 2em;
}

.tbl2 tbody th {
	display:block;
	font-size: 20px;
}

.tbl2 tbody th img{
	vertical-align: middle;
	margin-right: 1em;
}

.tbl2 tbody td {
	display:block;
	border-left: none;
	border-right: none;
	border-top: none;
	border-bottom: 1px dotted #e3e0e1;
	padding: 1em 0;
}

.tbl2 tbody td::before {
	content: attr(label);
	float: left;
	clear:both;
	font-weight:bold;
}

.tbl2 tbody td:last-child{
	border-bottom: 1px solid #e3e0e1;
	text-align: right;
}



@media (min-width: 768px) {
	.tbl1 td,
	.tbl2 th{
		padding: 20px;
	}

	.tbl2 {
		width:100%;
		border:#e3e0e1 solid 1px;
		border-collapse: collapse;
	}
	.tbl2 tbody tr{
		display: table-row;
	}
	.tbl2 tbody th {
		display: table-cell;
		background:#ecf6e1;
		color:#666;
		padding:10px 15px;
		border:#e3e0e1 solid 1px;
		vertical-align:middle;
	}

	.tbl2 tbody td {
		display: table-cell;
		background:#FFF;
		padding:10px 15px;
		border:1px solid #e3e0e1;
		vertical-align:top;
	}
}
/* リスト
-------------------------------------------------------------- */
.list_style_no{
	list-style-type: none;
}

.checklist,
.list_style1,
.list_style2{
	margin: 0;
}

.checklist li{
	list-style-type: none;
	margin: 0 0 0.5em 40px;
}

.checklist li:before{
	font-size: 140%;
	font-family: "Font Awesome 5 Free";
    content: '\f00c';
    font-weight: bold;
    margin-right: -1em;
    color: #7fbf33;
	position: relative;
	left: -40px;
}

.checklist_md li{
	font-size: 16px;
}


.list_style1 li,
.list_style1_2 li{
	border-bottom: 1px dotted #999;
	padding: 10px 0;
}

.list_style1_2 li{
	list-style-type: none;
}

.list_style2 li,
.list_style2_2 li{
	list-style-type: none;
	border-bottom: 1px solid #ccc;
	padding: 20px 0;
	position: relative;
}

.list_style2 li:after,
.list_style2_2 li:after{
	width: 20px;
	height: 20px;
	content: "";
	display: block;
	border-left: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	background-color: #fff;
	position: absolute;
	bottom: -10px;
	left: 50%;
	transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	-webkit-transform: rotate(-45deg);
}

.list_style2_2 li:after{
	background-color: #f3f7f8;;
}


.list_style2 li:last-child:after,
.list_style2_2 li:last-child:after{
	display: none;
}

.list_style3 li{
	border-bottom: 1px dotted #999;
	padding: 5px 0;
	font-size: 12px;
	position: relative;
	overflow: hidden;
}
.resson_type_icon{
	display: block;
	float: right;
}
.icon_a,
.icon_b{
	display: inline-block;
	color: #fff;
	padding: 2px 0.5em;
	margin: 0 2px;
	border-radius: 3px;
}

.icon_a{
	background-color: #80add7;
}

.icon_b{
	background-color: #d87e9d;
}


.checkmark li{
	list-style-type: none;
	background: url(./images/checkmark2.png) no-repeat 0 14px;
	padding-left: 20px;
}

.checklist span{
	font-size: 1.1em;
	font-weight: bold;
	color: #7fbf33;

}

.angle-mark li{
	list-style-type: none;
}
.angle-mark li:before{
    font-family: "Font Awesome 5 Free";
    content: "\f105";
    margin-right: 5px;
    color: #7fbf33;
    font-weight: bold;
}

.badge{
    display: inline-block;
    min-width: 10px;
    margin-top : 5px;
    padding: 3px 7px;
    font-size: 12px;
    font-weight: bold;
    float: right;
    line-height: 1;
    list-style-type: none;
    color: #FFF;
    text-align: center;
    background-color: #ccc;
    border-radius: 10px;
    box-sizing: border-box;
}

.regulations li{
	border-bottom: 1px dotted #999;
	padding: 10px 0;
	list-style-type: none;
}

.regulations li input[type=checkbox]{
	display: none;
}
.regulations li .mwform-checkbox-field-text{
  padding-left: 25px;
  position:relative;
  margin-right: 10px;
}
.regulations li .mwform-checkbox-field-text::before{
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  border: 1px solid #999;
  border-radius: 4px;
}
.regulations li input[type=checkbox]:checked + .mwform-checkbox-field-text{
  color: #f39800;
}
.regulations li input[type=checkbox]:checked + .mwform-checkbox-field-text::after{
  content: "";
  display: block;
  position: absolute;
  top: -5px;
  left: 8px;
  width: 10px;
  height: 20px;
  transform: rotate(40deg);
  border-bottom: 3px solid #f39800;
  border-right: 3px solid #f39800;
}

/* ステップフロー
-------------------------------------------------------------- */

.step-flow{
	list-style-type: none;
	text-align: center;
}

.step-flow li{
	background-color: #f2f7f8;
	padding: 20px 20px 10px 20px;
	position: relative;
	margin-bottom: 70px;
}

.step-flow li:last-child{
	padding: 20px;
	margin-bottom: 0;
}

.step-flow li:not(:last-child):after{
	content: "";
	position: absolute;
	right: 0;
	left: 0;
	bottom: -50px;
	width: 0px;
	height: 0px;
	margin: auto;
	border-style: solid;
	border-color: #f2f7f8 transparent transparent transparent;
	border-width: 50px calc(50vw - 15px) 0  calc(50vw - 15px);
  }

.step-flow img{
	max-width: 200px;
}

.step-num{
	font-size: 1.5rem;
	color: #7fbf33;
	height: 100%;
	margin: 20px 0 20px;
}

.step-num span{
	font-size: 3rem;
}

/* アコーディオン
-------------------------------------------------------------- */


.accordion label h4{
	font-size: 20px;
	margin-bottom: 1em;
	cursor: pointer;
	-webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;

}

.accordion .ac-cont,
.accordion2 .ac-cont{
	height: 0;
	overflow: hidden;
	/*padding: 0 10px;*/
	padding: 0;
	-webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    transition: all 0.5s ease;
}

.accordion input:checked ~ .ac-cont,
.accordion2 input:checked ~ .ac-cont {
	height: auto;
	/*padding: 10px;*/
	padding: 10px 0;
}

.accordion2 input[type=checkbox]{
	display: none;
}

.q_num{
	font-size: 200%;
	color: #f39f24;
}

.ans_box {
    position: relative;
    background-color: #f4f4f4;
    padding: 85px 20px 20px 20px;
    border: 1px solid #d2ccce;
    border-radius: 10px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    margin: 10px 0 20px 0;
}

.ans_box .ans_img {
    position: absolute;
    top: -20px;
    left: 10px;
}

.accordion2 .ac-open{
	text-decoration: underline;
	font-weight: normal;
	text-align: center;
	font-size: 18px;
	width: 80%;
	border-top: 1px solid #999;
	border-bottom: 1px solid #999;
	margin: 0 auto;
	padding: 10px 0;
	cursor: pointer;
}


.accordion2 label{
	display: inline;
	text-decoration: none;
}
/*トグルボタン*/

input[type=checkbox].toggle_button + label {
  width: 34px;
  height: 14px;
  background: #999;
  display: block;
  border-radius: 10px;
  position: relative;
  cursor: pointer;
  margin: 0 auto;
}


input[type=checkbox].toggle_button + label:before,
input[type=checkbox].toggle_button + label:after {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background: white;
  border-radius: 50%;
  border:1px solid #999;
  position: absolute;
  top: -3px;
  left: 0;
  transition: all .2s;
}

input[type=checkbox].toggle_button {
  display: none;
}


input[type=checkbox].toggle_buttonh:checked + label {
  background: rgba(3, 155, 229, 0.5);
}


input[type=checkbox].toggle_button:checked + label:before,
input[type=checkbox].toggle_button:checked + label:after {
  left: 14px;
  background: #f39f24;
  border: 1px solid #f39f24;
}

/*contactform7のreCapterバッチ非表示*/
.grecaptcha-badge {
    opacity: 0;
    left: 10px;
}

/* fit-sidebar */
.fit-sidebar-fixed{
	margin-top:10px!important;
	margin-bottom:0!important;
	position:fixed;
}
.fit-sidebar-blank{
	z-index:0;
	background-color:transparent;
	visibility:hidden;
}


/********************************/
/*XXS以下のアジャスト*/
/********************************/
@media (max-width: 480px){
	.hide_xxs{
		display: none;
	}
}

/********************************/
/*XXS以上のアジャスト*/
/********************************/
@media (min-width: 481px){

}



/********************************/
/*SM以下のアジャスト*/
/********************************/
@media (max-width: 767px){
	.hide_xs{
		display: none;
	}


	#contents{
		padding-top:30px;
	}
	#first{
		top:0px;
	}

	#header{
		padding-bottom: 10px;
		position: relative;
	}

	#footer-primary{
		text-align: center;
	}

	.footer-logo{
		margin: 0 0 20px 0;
	}

	.f-nav{
		margin: 20px 0;
	}

	.round-ttl-wrap{
		height: auto;
		width: 70%;
    min-width: 320px;
		border-radius: 0;
		background: url(./images/pattern2.png) repeat;
		text-align: center;
		font-size: 25px;
		font-weight: normal;
		color: #fff;
		margin: 0 auto;
		padding: 10px 0;
	}

	.round-ttl-wrap span{
		height: auto;
		width: auto;
		display:inline;
		font-size: 22px;
	}
}
/********************************/
/*SM以上のアジャスト*/
/********************************/
@media (min-width: 768px) {
	h1{
		text-align: left;
	}
	table{
		font-size: 16px;
	}
	.sitettl-box{
		text-align: left;
	}
	.telbox{
		padding-top: 10px;
		text-align:left;

	}
	.sub_ttl{
		text-align: left;
	}


	#contents-ttl{
	    height: 99px;
	}

	#contents-ttl h2{
		line-height: 99px;
		font-size: 35px;
	}
	.cta-bt{
		background-color: #f39f24;
		color: #fff;
		-webkit-transition: all 1s ease;
	    -moz-transition: all 1s ease;
	    -o-transition: all 1s ease;
	    -ms-transition: all 1s ease;
	    transition: all 1s ease;
	}

	.cta-bt:hover{
		color: #fff;
		-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 6px #f39f24;
	     box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 6px #f39f24;
	}

	.oyakusoku{
		text-align: left;
	}
	.ttl_type1,
	.ttl_type1_2{
		font-size: 35px;
		display: table;
		margin-bottom: 60px;
		font-weight: normal;
	}
	.ttl_type1:before{
		display: inline;
	}
	.ttl_type5,
	.ttl_type5_2,
	.ttl_type5_3{
		font-size: 26px;
		font-weight: normal;
	}
	.ttl_type6{
		font-size: 20px;
		font-weight: normal;
	}
	.ttl_type7{
		font-size: 24px;
	}

	.ttl_type7_2{
		font-size: 20px;
		padding: 7px 0 7px 2.5em;
	}

	.ttl_type9_2{
		font-size: 24px;
	}
	.hide_xs_over{
		display: none;
	}

	.ttl_type11{
		font-size: 24px;
		padding: 20px 0;
	}

	.qa_ttl_q,
	.qa_ttl_a{
		font-size: 24px;
	}
	.checklist_top li{
		font-size: 20px;
	}

	.checklist_md li{
		font-size: 20px;
	}

	.accordion label h4{
		font-size: 24px;
	}

	.ans_box {
	    padding: 20px 20px 20px 155px;
	    margin-top: 10px;
	}

	.ans_box .ans_img {
	    position: absolute;
	    top: -20px;
	    left: 10px;
	}
	.entry-content p{
	  letter-spacing: 0.3em;
	  line-height: 1.8em !important;
	}

	.entry-content > h2{
	  font-size: 28px;
	  /*padding: 15px;*/
	}

	.entry-content h3{
	  font-size: 24px;
	}

	.entry-content h4{
	  font-size: 20px;
	}

	.entry-content h5{
	  font-size: 20px;
	}

	.entry-headline {
	    font-size: 34px;
	}
	.post-entry_panel{
    	height: 115px;
	}
	.circle-ttl{
		font-size: 30px;
		text-align: left;
		color: #fff;
		border-radius: 100px;
		text-align: center;
		vertical-align: middle;
		width: 135px;
		height: 135px;
		margin: 0 auto;
		padding: 15px 0 0 0;
	}
	.circle-cl1{
		background-color: #abc10b;
	}
	.circle-cl2{
		background-color: #8f82bc;
	}
	.circle-cl3{
		background-color: #e2943c;
	}
	.circle-cl4{
		background-color: #00a5d5;
	}
	.circle-cl5{
		background-color: #23ac38;
	}
	.circle-cl6{
		background-color: #df7d84;
	}

	.courselist2{
		text-align: left;
	}

	.courselist2 .col1,
	.courselist2 .col2,
	.courselist2 .col3,
	.courselist2 .col4{
		display: table-cell;
		vertical-align: middle;
	}

	.courselist2 .col1{
		width: 20vw ;
	}
	
	.courselist2 .col2{
		width: 45vw ;
		padding-left: 20px;
	}
	
	.courselist2 .col3{
		width: 20vw ;
		text-align: right;
		padding-right: 20px;
	}
	
	.courselist2 .col4{
		width: 15vw ;
		border-left: 1px dotted #ccc;
		padding-left: 20px;
	}

	.step-flow li:not(:last-child):after{
			border-width: 50px 360px 0  360px;
	  }
	
}

/********************************/
/*SM以下のアジャスト*/
/********************************/
@media (max-width: 991px){
	.hide_sm{
		display: none;
	}

	.ttl_type2{
		width: 70%;
		min-width: 320px;
		margin: 0 auto;
		font-size: 22px;
	}

	.ttl_type2{
		width: 100%;
		margin: 0 auto;
		font-size: 22px;
	}

	.footer-logo{
		float: none;
	}
}
/********************************/
/*MD以上のアジャスト　*/
/********************************/
@media (min-width: 992px) {
	.sitettl-box{
		float: left;
		margin-right: 20px;
	}
	.sub_ttl{
		float: left;
		margin: 15px 0 0 0 ;
	}
	.ttl_type5_3{
		text-align: left;
	}
	.telbox{
		padding-top: 20px;
		width: 100%;
		overflow: hidden;
	}

	.telNum{
		float:left;
		border-right: 1px solid #333;
		padding-right: 10px;
		margin-right: 10px;
	}
	.calltime{
		float: left;
		text-align: left;
	}
	.oyakusoku{
		text-align: center;
	}

	.checklist_top{
		padding-top: 30px;
	}

	input[type=checkbox].toggle_button + label {
		display: inline-block;
	}

	.post-entry_panel{
		height: 240px;
	}

	.post-entry_panel .post-entry-img{
		float: none;
		width: 100%;
		margin-right: 0;
	}

	.step-flow li{
		display: flex;
	}

	.step-flow .col1{
		flex: 0 1 15%;
		align-self: center;
	}

	.step-flow .col2{
		flex: 0 1 20%;
		margin: 0 20px
	}

	.step-flow .col3{
		flex: 0 1 65%;
		text-align: left;
	}
	
	.ttl_type12{
		margin-top: 0;
		font-size: 24px;

	}
	.ttl_type12:before{
		right: auto;
	}
	
	.step-flow li:not(:last-child):after{
		border-width: 50px 470px 0  470px;
	}

	.step-num{
		font-size: 2rem;
	}	
	.step-num span{
		font-size: 4rem;
	}
}

/********************************/
/*MD以下のアジャスト/
/********************************/
@media (max-width: 1199px) {
	.hide_md{
		display: none;
	}

	.f-tel,
	.f-tel2{
		font-size: 43px !important;
	}
	.ttl_type4,
	.ttl_type4_3{
		font-size: 18px;
	}

	.icon_a,.icon_b{
		font-size: 14px;
	}
}

/********************************/
/*LGサイズ以上のアジャスト/
/********************************/
@media (min-width: 1200px) {

	.telNum{
		font-size: 35px;
	}
	.cta-bt{
		font-size: 16px;
	}
	.post-entry_panel{
		height: 270px;
	}
/*スケルトンの設定*/

	#main {
		width: 840px;
		float: left;
		margin-right: 30px;
	}

	#sidebar {
		float: left;
		width: 300px;
	}

/* リスト */

	.checklist_top{
		padding-top: 55px;
	}

	.checklist_top li{
		font-size: 25px;
	}

	.step-flow li:not(:last-child):after{
		border-width: 50px 585px 0  585px;
	}

/*その他*/
	.hide_lg{
		display: none;
  	}

}

/*ユーティリティー
/********************************/

.mb-lg{
	margin-bottom: 100px !important;
}
.mb-md{
	margin-bottom: 50px !important;
}
.mb-sm{
	margin-bottom: 20px !important;
}
.mb-xs{
	margin-bottom: 10px !important;
}
.mb-1em{
	margin-bottom: 1em !important;
}
.mb-harf{
	margin-bottom: 0.5em !important;
}
.mt-lg{
	margin-top: 100px !important;
}
.mt-md{
	margin-top: 50px !important;
}
.mt-sm{
	margin-top: 20px !important;
}
.mt-xs{
	margin-top: 10px !important;
}

.mb-no{
	margin-bottom: 0px !important;
}
.mt-no{
	margin-top: 0px !important;
}
.mg-no{
	margin: 0px !important;
}

.pd-xs{
	padding: 10px !important;
}
.pd-sm{
	padding: 20px !important;
}
.pd-md{
	padding: 50px !important;
}
.pl-no{
	padding-left: 0 !important;
}
.pd-no-side{
	padding-left: 0 !important;
	padding-right: 0 !important;
}
.pd-xs-side{
	padding: 0 10px !important;
}
.pd-sm-side{
	padding: 0 20px !important;
}
.pd-md-side{
	padding: 0 50px !important;
}
.pb-xl{
	padding-bottom: 100px !important;
}
.pb-md{
	padding-bottom: 50px !important;
}
.pb-sm{
	padding-bottom: 20px !important;
}
.pb-xs{
	padding-bottom: 10px !important;
}
.pb-no{
	padding-bottom: 0px !important;
}
.pt-xl{
	padding-top: 100px !important;
}
.pt-md{
	padding-top: 50px !important;
}
.pt-sm{
	padding-top: 20px !important;
}
.pt-xs{
	padding-top: 10px !important;
}
.pt-no{
	padding-top: 0px !important;
}

.fs12{ font-size: 12px !important;}
.fs14{ font-size: 14px !important;}
.fs16{ font-size: 16px !important;}
.fs18{ font-size: 18px !important;}
.fs20{ font-size: 20px !important;}
.fs22{ font-size: 22px !important;}
.fs24{ font-size: 24px !important;}
.fs28{ font-size: 28px !important;}
.fs32{ font-size: 32px !important;}
.fs36{ font-size: 36px !important;}
.fs42{ font-size: 42px !important;}

.fwbd{ font-weight: bold;}
.fwnm{ font-weight: normal;}
.fsob{ font-style: oblique;}
.centerling{
  text-align: center;
  }
.ar{ text-align: right !important;;}
.al{ text-align: left !important;;}
.fl{ float: left;}
.fr{ float: right;}
.oh{ overflow: hidden;}

.cl1{ color: #fff;}
.cl2{ color: #7fbf33;}/* ライムグリーン*/
.cl3{ color: #5589ae;}/* 青2*/
.cl4{ color: #e71218;}/* 赤　*/
.cl5{ color: #f39800;}/* オレンジ */
.cl6{ color: #666;}
.cl7{ color: #999;}

.bloc-centerling{
  margin-left: auto;
  margin-right: auto;
}
.dsp-b{ display: block;}
.dsp-i{ display: inline;}
.dsp-talbe{ display: table;}
.dsp-cell{ display: table-cell;}
.oh{ overflow: hidden;}
.oa{ overflow: auto;}
.clr{ clear:both;}
.pst-r{ position: relative};
.w100per{ width: 100% !important;}

/* box-shadow */
.shadow1{
box-shadow:rgba(0, 0, 0, 0.1) 2px 2px 0px -1px;
-webkit-box-shadow:rgba(0, 0, 0, 0.1) 2px 2px 0px -1px;
-moz-box-shadow:rgba(0, 0, 0, 0.1) 2px 2px 0px -1px;
}
.bloc-v-centerling{
  vertical-align: middle;
}
.border-top-none{
  border-top: none;
}
.border-top_dashed-lightgray{
  border-top: 1px dashed #999;
}

.border-bottom_dashed-lightgray{
  border-bottom: 1px dashed #999;
}

.border-bottom_dashed-verylightgray{
  border-bottom: 1px dashed rgba(0,0,0,0.1);
}

.wavy {
	background:url(./images/wavy.png) bottom repeat-x;
	padding-bottom: 5px;
}
.pink_marker {
    background: rgba(0, 0, 0, 0) linear-gradient(transparent 40%, #fad5dc 40%) repeat scroll 0 0;
    font-weight: bold;
}
.yellow_marker {
    background: rgba(0, 0, 0, 0) linear-gradient(transparent 40%, #ffffbf 40%) repeat scroll 0 0;
    font-weight: bold;
}
.green_marker {background:linear-gradient(transparent 60%, #99cccc 60%);}
.orange_marker {background:linear-gradient(transparent 60%, #FFC23F 60%);}

/* SMP Utility
-------------------------------------------------------------------*/

@media (max-width: 767px){
	.mg-clear_smp{
		margin:0;
	}
	.mg-sm_smp{
		margin-top:10px;
		margin-bottom:5px;
	}
	.mg-md_smp{
		margin-top:10px;
		margin-bottom:20px;
	}
	.mg-lg_smp{
		margin-top:10px;
		margin-bottom:40px;
	}
	.mg-xs-side_smp{
		margin-left: 10px !important;
		margin-right: 10px !important;
	}
	.mb-lg_smp{
		margin-bottom: 100px !important;
	}
	.mb-md_smp{
		margin-bottom: 50px !important;
	}
	.mb-sm_smp{
		margin-bottom: 20px !important;
	}
	.mb-xs_smp{
		margin-bottom: 10px !important;
	}

	.mb-no_smp{
		margin-bottom: 0px !important;
	}
	.mt-no_smp{
		margin-top: 0px !important;
	}

	.pd-xs_smp{
		padding: 10px !important;
	}
	.pd-sm_smp{
		padding: 20px !important;
	}
	.pd-md_smp{
		padding: 50px !important;
	}
	.pl-no_smp{
		padding-left: 0 !important;
	}

	.pt-no_smp{
		padding-top: 0 !important;
	}

	.pb-no_smp{
		padding-bottom: 0 !important;
	}

	.pd-no-side_smp{
		padding-left: 0 !important;
		padding-right: 0 !important;
	}

	.pd-xs-side_smp{
		padding: 0 10px !important;
	}
	.pd-sm-side_smp{
		padding: 0 20px !important;
	}
	.pd-md-side_smp{
		padding: 0 50px !important;
	}
	.pb-xl_smp{
		padding-bottom: 100px !important;
	}

	.pb-md_smp{
		padding-bottom: 50px !important;
	}

	.pb-sm_smp{
		padding-bottom: 20px !important;
	}

	.pb-xs_smp{
		padding-bottom: 10px !important;
	}

	.text-left_smp {
	  text-align: left;
	}
	.text-right_smp {
		text-align: right;
	}
	.text-center_smp {
		text-align: center;
	}
	.border-bt-none_smp{
		border-bottom: none !important;
	}

	.border-bottom_dashed-lightgray_smp{
		border-bottom: 1px dashed #999;
	}

	.border-bottom_dashed-verylightgray_smp{
		border-bottom: 1px dashed rgba(0,0,0,0.1);
	}
	.centerling{
		margin-left: auto;
		margin-right: auto;
	}
}
