@charset "utf-8";

/*------------------------------------------------------

	グローバル

------------------------------------------------------*/

body { min-width: 0px; font-size: 0.85em;}

.ta_right-s_center { text-align: center;}
.ta_left-s_center { text-align: center;}
.ta_center-s_left { text-align: left;}

.hidden_s { display: none !important;}

.mb40-20 { margin-bottom: 20px !important;}
.mb60-30 { margin-bottom: 30px !important;}
.mb80-40 { margin-bottom: 40px !important;}
.mb100-60 { margin-bottom: 60px !important;}
.mb120-60 { margin-bottom: 60px !important;}
.mb120-80 { margin-bottom: 80px !important;}
.mb160-80 { margin-bottom: 80px !important;}

/* ------------------------
	ヘッダー
------------------------ */

.header { padding: 15px 0px 0px 15px;}
.header h1 img { width: 70px; height: auto;}

.header_btn { right: 55px; width: auto; position: fixed; z-index: 9999;}
.header_btn li { width: 50px;}
.header_btn li:not(:first-child) { margin-left: 5px;}

.clone-nav { display: none;}

/* ------------------------
	グローバルナビ
------------------------ */

/* ハンバーガーメニュー */
.humberger {
	background: #f19ca6;
	cursor: pointer;
	display: block;
	position: fixed;
	top: 0px;
	right: 0px;
	width: 50px;
	height: 50px;
	z-index: 10001;
}
.humberger span {
	background: #fff;
	border-radius: 15px;
	position: absolute;
	left: 10px;
	width: 30px;
	height: 3px;
	transition: 0.4s;
}
.humberger span:nth-of-type(1) { top: 9px;}
.humberger span:nth-of-type(2) { top: 17px;}
.humberger span:nth-of-type(3) { top: 25px;}
.humberger:after {
	color: #fff;
	content: 'MENU';
	display: block;
	font-size: 10px;
	text-decoration: none;
	text-align: center;
	transition: 0.4s;
	position: absolute;
	left: 0;
	bottom: 1px;
	width: 100%;
}
.is-open .humberger:after { content: 'CLOSE';}
.is-open .humberger span:nth-of-type(1) {
  -webkit-transform: translateY(6px) rotate(-45deg);
	  -ms-transform: translateY(6px) rotate(-45deg);
		  transform: translateY(6px) rotate(-45deg);
}
.is-open .humberger span:nth-of-type(2) { opacity: 0;}
.is-open .humberger span:nth-of-type(3) {
  -webkit-transform: translateY(-10px) rotate(45deg);
	  -ms-transform: translateY(-10px) rotate(45deg);
		  transform: translateY(-10px) rotate(45deg);
}
/* ナビ本体 */
.sp-navi { -webkit-text-size-adjust: 100%;}
.sp-navi.is-open .sp-navi-inner {
	opacity: 1;
	visibility: visible;
	z-index: 10000;
}
.sp-navi .sp-navi-inner {
	background: #fcebee;
	overflow-y: auto;
	opacity: 0;
	visibility: hidden;
	position: fixed;
	top: 0;
	left: 0px;
	height: 100%;
	width: 100%;
	transition: .5s;
	padding-bottom: 30px;
}
.sp-navi .logo { padding: 5px 0px 5px 10px; background: #fff;}
.sp-navi .logo img { width: auto; height: 40px !important;}
.sp-navi .list01 a { color: #000;}
.sp-navi .list01 li > a, .sp-navi .list01 li > span { display: block; text-decoration: none; border-bottom: solid 1px #fff; padding: 7px 5px 7px 40px; font-size: 1.15em; position: relative;}
.sp-navi .list01 > li > a:before, .sp-navi .list01 > li > span:before { content: ""; position: absolute; left: 15px; top: 50%; margin-top: -1.5px; width: 10px; height: 3px; background-color: #f19ca6;}
.sp-navi .list01 > li li a { display: block; text-decoration: none; border-bottom: dashed 1px #fff; padding: 7px 5px 7px 55px; font-size: 1.15em; position: relative;}
.sp-navi .list01 > li li a:before { content: ""; position: absolute; left: 30px; top: 50%; margin-top: -0.5px; width: 10px; height: 1px; background-color: #f19ca6;}

.header_btn { justify-content: center; align-items: center;}
.header_btn a { border-radius: 8px;}

.sp-navi .blog_content { padding: 25px 15px 0px;}
.sp-navi .blog_content .add_btn { display: flex; justify-content: center; align-items: center;}
.sp-navi .blog_content .add_btn li { padding: 0px; width: 47%; margin: 0px 1.5%;}
.sp-navi .blog_content .add_btn li:before { display: none;}
.sp-navi .blog_content .btn01 { min-width: 0px; width: 100%;}
.sp-navi .blog_content .add_btn span { padding: 10px 20px; font-size: 0.95em;}


/* ------------------------
	フッター
------------------------ */

.footer_contact { padding: 30px 15%; border-radius: 0px;}
.footer_contact .box01 { max-width: 400px;}
.footer_contact .box_inner { padding: 20px 10px;}
.more_btn.app_btn a { padding: 13px 30px; min-width: 0px;}
.more_btn.app_btn a:before { width: 13px; height: 20px; margin-top: -0.2em;}
.more_btn.app_btn a:after { width: 10px; height: 10px;}

.footer_contact .tel a:before { width: 14px; height: 20px;}

.footer .bg { padding: 40px 0px 10px;}
.footer .bg:before { height: 7%;}
.footer .bg .logo img { width: 70px; height: auto;}

.footer_list { flex-wrap: wrap;}
.footer_list > li { margin: 0px 15px 20px !important;}
.footer_list .app_btn { width: 250px;}

.footer .list03 img { width: auto; height: 20px;}

.footer_sns li { width: 35px; margin: 0px 7px;}

@media only screen and (max-width: 480px) {
	.footer_contact .box01 { font-size: 3vw; padding: 7px;}
	.footer_contact .fo09.mb10 { margin-bottom: 5px !important;}
	.footer_contact .more_btn { margin-bottom: 15px;}
	
	.footer_list .list02 { display: block;}
	.footer_list .list02 .ta_left { text-align: center; margin-top: 3px;}
	.footer_list .list02 .hide_sp { display: none;}
}


/*------------------------------------------------------

	トップページ

------------------------------------------------------*/

.slide_wrap:after { height: 15%;}
.slide_wrap .text_box { font-size: 3.8vw; letter-spacing: 0.1em;}
.slide_wrap .text_box .fo_noto { margin-bottom: 15px;}
.slide_wrap { height: 70%;}
.slide_box { width: 130%; margin-left: -15%;}

.top_news { padding: 30px 0px;}
.top_news:after { height: 7px;}
.top_news .box_wrap, .top_news dl, .top_news dd { width: auto; display: block;}
.top_news .box_wrap > div:nth-child(2) { width: auto; margin: 15px 0px 20px;}
.top_news .more_btn { width: auto;}
.top_news dt, .top_news .category { display: inline-block; width: auto; margin: 0px 1em 5px 0px; padding: 0px;}

.en_subttl { font-size: 2em;}

.top_concept:before { width: 90px; height: 90px; top: -10px; right: 5%;}
.top_concept .box { max-width: initial;}
.top_concept .img_box { display: flex; justify-content: center; align-items: center; padding: 0px 5%;}
.top_concept .img_box .pos_ab { position: static;}

.top_concept .text01:before { margin-left: -30px; width: 20px; height: 40px;}
.top_concept .box02 { display: block;}
.top_concept .box02 .box_inner { width: auto; margin-bottom: 30px;}
.top_concept .box02 h3 { padding-bottom: 10px; width: 220px; font-size: 1.45em;}
.top_concept .box02 figure { padding-left: 18%;}

.top_lesson { padding: 55px 0px 1px;}
.wave:before, .wave:after { height: 7px;}
.top_lesson section { display: block;}
.top_lesson section figure { width: auto; padding: 30px 5% 0px;}
.top_lesson section .box_inner { width: auto;}
.top_lesson section:nth-of-type(odd) figure img, .top_lesson section:nth-of-type(even) figure img { margin: 0px;}
.top_lesson h3 { font-size: 1.5em;}

.top_teacher .box figure { width: 40%; margin-right: 5%;}
.top_teacher .box .box_inner { width: 55%;}
.top_teacher .box figure > div img:first-child { max-width: 100%; width: 90%;}
.top_teacher .box figure > div:after { width: 30px; height: 80px; right: -10px;}
.top_teacher .box figure .pos_ab { width: 65px; left: 10px; bottom: -5px;}

.top_about { padding: 50px 0px;}
.top_about .box02 { width: calc(100% - 300px);}

.topics_box { display: block;}
.topics_box:after { display: none;}
.topics_box section { width: auto;}
.topics_box section:first-child { margin-bottom: 60px;}
.topics_box dl { margin-bottom: 15px; padding-bottom: 15px;}
.topics_box dl:last-of-type { margin-bottom: 30px;}

.topics_box .art { margin-bottom: 30px;}
.topics_box .art figure { width: 120px;}
.topics_box .art .box_inner { width: calc(100% - 140px);}
.topics_box .cat_wrap.mb10 { justify-content: flex-start; margin-bottom: 0px !important;}
.topics_box .cat_wrap p { margin-right: 1em;}

@media only screen and (max-width: 640px) {
	.top_concept .text01 { font-size: 4.6vw; padding-left: 15px;}

	.top_teacher h2.mb60 { margin-bottom: 45px !important;}
	.top_teacher .box { display: block;}
	.top_teacher .box figure, .top_teacher .box .box_inner { width: auto;}
	.top_teacher .box figure { padding: 30px 10% 0px;}
	.top_teacher .box figure .pos_ab { width: 23%; left: 0px;}

	.top_about .box { display: block;}
	.top_about .box02 { width: auto; margin: 40px 0px 0px;}
	.top_about .map iframe { height: 250px;}
}

/*------------------------------------------------------

	下層ページ

------------------------------------------------------*/

/* ----------------------------
	固定ページテンプレート
---------------------------- */

.mainimage img { width: 150% !important; margin-left: -25%; max-width: initial !important;}
.mainimage:after { height: 7px;}

.pagettl { font-size: 2em; padding-bottom: 15px;}
.pagettl:after { width: 200px; border-bottom: dotted 5px #f19ca6;}

.main_contents:last-child { margin-bottom: 80px;}

.catchcopy { font-size: 1.5em; margin-bottom: 60px;}

.img_wide { margin-bottom: 60px;}

.imgbox { display: block; margin: 60px 0px;}
.imgbox figure { max-width: 640px; width: auto; margin: 25px auto !important;}
.imgbox > div { width: auto; padding: 0px 15px;}

.img_right figure:after { right: -20px; bottom: -15px;}
.img_left figure:after { left: -20px; bottom: -15px;}

.blog_content .box_img_left h6.image:before, .blog_content .box_img_left h6.image:after { width: 13px; height: 25px;}

.step_sec01 > figure:before { width: 100px; height: 100px; bottom: -30px; left: -30px;}
.step_sec01 > div { width: 60%; padding-left: 35px;}
.step_sec01 .num_box { margin-bottom: 20px; font-size: 1.5em;}
.step_sec01 .num_box:before { width: 30px; height: 30px; left: -40px;}

.step_sec02 > figure { width: 40%;}
.step_sec02 > figure:before { width: 30px; top: 20px; height: 60px;}
.step_sec02 > figure:after { width: 30px; height: 25px;}
.step_sec02 figcaption { top: 0px; font-size: 1.5em;}


@media only screen and (max-width: 640px) {
	.box30 { display: block; margin: auto;}
	.box30 > div { width: 100%; display: flex; flex-wrap: wrap; flex-flow: column-reverse; margin: 0px 0px 50px;}

	.box50 { display: block;}
	.box50 > div { width: 100%;}
	
	.imgbox figure { margin: 25px 20px !important;}
	
	.step_sec01, .step_sec02 { display: block;}
	.step_sec01 > figure, .step_sec01 > div, .step_sec02 > div { width: auto;}
	.step_sec02 > figure { width: 75%; max-width: 400px; margin: 0px auto 20px;}
}



/* ------------------------
	contact
------------------------ */

.contact_sec .btn_area input { background-size: 7px auto; padding: 7px 30px; min-width: 180px;}

@media only screen and (max-width: 570px) {
	.contact_sec01 h3 .show_sp { display: inline;}

	.contact_sec dl { display: block;}
	.contact_sec dt, .contact_sec dd {
		display: block;
		border-bottom: none;
		padding: 0px;
	}
	.contact_sec dt {
		width: 100%;
		margin-bottom: 10px;
	}
	.contact_sec dt span {
		display: inline-block;
		vertical-align: middle;
		padding: 3px 5px;
		float: none;
		margin-left: 10px;
	}
	.contact_sec dt br { display: none;}
	.contact_sec input[type="text"], .contact_sec input[type="email"], .contact_sec textarea, .contact_sec select { width: 100%;}
}

/* ------------------------
	投稿
------------------------ */

.blog_wrap { display: block;}
.contents { width: auto; margin-bottom: 60px; padding: 30px 15px; border-radius: 25px;}
.rNavi { width: auto; max-width: 600px; margin: auto;}
.rNavi:before, .rNavi:after { width: 70px; height: 35px;}
.rNavi:before { margin: 0px auto 10px;}
.rNavi h2 { font-size: 1.4em; box-shadow: 4px 4px 0px #f19ca6; padding: 6px 8px 9px;}

.blog_header h1 { margin-left: 20px; font-size: 1.8em;}
.blog_header h1:before { left: -25px; top: 0.3em; width: 18px; height: 30px;}

/* 本文 */
.blog_content h2 { font-size: 1.7em !important; padding-left: 25px;}
.blog_content h2:before { width: 17px; height: 28px; margin-left: -25px;}
.blog_content h3 { font-size: 1.6em;}
.blog_content h4, .blog_content h5, .blog_content h6 { font-size: 1.45em;}
.blog_content h4 { background-size: auto 8px; padding-bottom: 15px;}
.blog_content h5 { padding-left: 25px;}
.blog_content h5:before { width: 15px; height: 15px;}

.blog_content blockquote { padding: 30px 6%;}
.blog_content blockquote:before, .blog_content blockquote:after { width: 40px; height: 14px;}
.blog_content blockquote:before { left: 20px;}
.blog_content blockquote:after { right: 20px;}

.blog_content li { padding-left: 20px;}
.blog_content li:before { width: 11px; height: 11px; top: 0.3em;}

.blog_content table th, .blog_content table td { padding: 5px 0.5em; font-size: 0.8em;}

.blog_content a.icon { background-size: auto 10px; padding-left: 17px;}
.blog_content a.box { background-size: auto 10px; padding: 5px 20px 5px 35px;}

.note:before { width: 10px; height: 20px; top: 0.05em;}

.pagination .number { position: static; margin-right: 15px;}

.pager .previous a:before, .pager .next a:before { width: 13px; height: 13px;}
.pager .previous a:before { left: -20px;}
.pager .next a:before { right: -20px;}

.breadcrumb { padding-left: 15px;}
.breadcrumb:before { width: 11px; height: 22px;}

/*WP用 投稿表示*/
img.aligncenter, img.alignright, img.alignleft { display: block; margin: 0px auto 20px; float: none;}

.blog_related h2 img { width: 145px; height: auto; margin-bottom: -15px;}

@media only screen and (max-width: 640px) {
	.blog_related > ul > li { width: 46%; margin: 0px 2% 20px;}
	.blog_related figure { padding: 7px;}
}

