/* CSS Document */

@charset "utf-8";

/* PC/スマホ共通表示 */
.-----PC_MOBILE_COMMON_CSS_START----- {}

header{background-color: #fff;}

#sec-flow{
	background: none;
	font-family: "メイリオ",Meiryo,"ヒラギノ角ゴ Pro W3",HiraginoKakuGothicPro,"ＭＳ Ｐゴシック",sans-serif;
}
#wrapper{
	/*background: url(https://www.eishinkan.net/assets/img/global/bg-junior.png) repeat;*/
	/*background-image: radial-gradient(#def6ff 20%, transparent 0), radial-gradient(#def6ff 20%, transparent 0);
	background-position: 0 0, 10px 10px;
	background-size: 20px 20px;*/
}

#page_title{margin-bottom:0;}

section{border: none;margin:0; padding:0;}

.img-responsive {
	display: block;
	height: auto;
	max-width: 100%;
}

#sec-flow .btn{
	font-family: "メイリオ",Meiryo,"ヒラギノ角ゴ Pro W3",HiraginoKakuGothicPro,"ＭＳ Ｐゴシック",sans-serif;
	font-size: 2.1em;
	font-weight: bold;
	color: #fff;
}

#sec-flow .apply-appeal {
	font-size: 40px;
	text-align: center;
	position: relative;
	width: fit-content;
	margin: 35px auto -10px;;
	padding: 0 0 0 10px;
	font-weight: bold;
	z-index: 1;
}
.apply-appeal:before {
	content: "";
	position: absolute;
	top: 53%;
	left: 0%;
	height: 20px;
	background-color: #FAE800;
	width: 100%;
	z-index: -1;
}
.item{
	background-color: #fff;
	color: #d9534f;
	padding: 5px 15px 4px;
	display: block;
	margin: 0 50px 17px;
	font-size: 0.9em;
}

.well{
	text-align: left;
	font-size: 1em;
	line-height: 35px;
	padding: 45px;
	background-color: #fffeee;
	border: 1px solid #4cae4c;
	border-radius: 5px;
	box-shadow: none;
}
.yellow{
	color: #fff600;
}

.bg_yellow {background: yellow;}

#sec-flow .tsuiki {
	/*background-color: #3a7cee;*/
	background-color: #d90613;
	padding: 18px;
	color: #fff;
	font-size: 2.4em;
	line-height: 1.3em;
}
#sec-flow .tsuiki a {text-decoration: none; color: #fff;}

.flow-box h3{
	background-color: #4070c7;
	color: #fff;
	border-radius: 5px;
	margin: 0;
	position: relative;
	top: 3px;
	padding: 13px;
	max-width: 850px;
	letter-spacing: 0.1em;
	font-size: 1.8em;
}

.flow-box p{
	text-align: left;
	font-size: 1.2em;
	line-height: 35px;
	padding:47px 55px;
	background-color: #fffeee;
	border: 3px solid #4070c7;
	border-radius: 5px;
}

.einoshin{
	width: 125px;
	height: 176px;
	float: right;
	position:relative;
	right: -15px;
	top: -89px;
	z-index: 1;
}

.kanna{
	width: 224px;
	height: 137px;
	float: right;
	position:relative;
	right: -15px;
	top: -90px;
	z-index: 1;
}

.arrow{font-size: 2.0em;}

.swipe{
	color: #000;
}


/* --------------------------------
	メインタイトル
-------------------------------- */

.sample{
	margin-top: 15px;
}

.main_pho{margin-top: 40px;}

#sec-flow .el_img{width: 193px; height: 254px; float: left; position: absolute;left:30px;top: -23px; -webkit-animation-duration: 0.4s;animation-duration: 0.4s;-webkit-animation-duration: 0.8s;animation-delay:0.8s;}
#sec-flow .ju_img{width: 200px; height: 254px; float: right; position: absolute;right: 20px; top: -22px; -webkit-animation-duration: 0.4s;animation-duration: 0.4s;-webkit-animation-duration: 0.8s;animation-delay:0.8s;}

.main_title {
	font-family: "メイリオ",Meiryo,"ヒラギノ角ゴ Pro W3",HiraginoKakuGothicPro,"ＭＳ Ｐゴシック",sans-serif;
	font-weight: bold;font-size: 5.5em;position: relative; padding: 0.7em 0 0.6em;margin-top: 50px;/*margin-top: 25px;*/ line-height: 72px;background-color: #fff;/*background-color: #f3fbff;*/}
.main_title::before,
.main_title::after {position: absolute;left: 0;content: '';width: 100%;height: 10px;box-sizing: border-box;}
.main_title::before {top: 0;border-top: 3px solid #4070c7/*#00659f*/;border-bottom: 1px solid #4070c7/*#00659f*/;}
.main_title::after {bottom: 0;border-top: 1px solid #4070c7/*#00659f*/;border-bottom: 3px solid #4070c7/*#00659f*/;}
.main_title small{font-family: "メイリオ",Meiryo,"ヒラギノ角ゴ Pro W3",HiraginoKakuGothicPro,"ＭＳ Ｐゴシック",sans-serif; color: #000;}

.elem-b, .junior-b, .high-b{
	padding: 5px 15px 0;
	position: relative;
	top: -10px;
	left: 18px;
	margin-left: 20px;
	color: #fff;
	font-size: 0.5em;
}
.elem-b{background-color: #f87f2b;}
.junior-b{background-color: #1c8edf;}
.high-b{background-color: #1ba58a;}

#sec-flow .sub_title{font-size: 0.8em;}
#sec-flow .sub_title_a{
	font-size: 0.8em;
	position: relative;top: -5px;
}
#sec-flow .sub_title_b{
	background-color: #4070c7/*#00659f*/;
	color: #fff;
	padding: 5px 0 3px;
	text-align: center;
	font-size: 1.8em;
	margin-top: 15px;
	/*border-radius: 10px;*/
}

#sec-flow h2 {
	/*margin: 1.3em 0 0.2em;*/
	margin: 1.3em 0 0.8em;
	padding: 0.15em 0.5em;/*上下 左右の余白*/
	background: transparent;/*背景透明に*/
	border-left: solid 8px #4070c7/*#00659f*/;/*左線*/
	text-align: left;
	font-size: 2.6em;
	font-family: "メイリオ",Meiryo,"ヒラギノ角ゴ Pro W3",HiraginoKakuGothicPro,"ＭＳ Ｐゴシック",sans-serif;
}

#sec-flow h3 {
	font-size: 1.6em;
	font-family: "メイリオ",Meiryo,"ヒラギノ角ゴ Pro W3",HiraginoKakuGothicPro,"ＭＳ Ｐゴシック",sans-serif;
	margin-bottom: 16px;
}

#sec-flow p{
	font-size: 1.35em;
	line-height: 1.5em;
}


/* --------------------------------
	オープニング
-------------------------------- */

.clip-box-b {
	position: relative;
	margin: 25px auto 30px;
	padding: 1.3em 2.3em 1.1em 2.3em;
	/*width: 100%; /* ボックス幅 */
	background-color: #4070c7/*#00659f*/; /* ボックス背景色 */
	color: #fff; /* 文章色 */
	box-shadow: 4px 4px 0px #224fa0/*#005180*/; /* 影の色 */
}

.clip-box-b::before {
	position: absolute;
	content: '';
	top: -15px;
	right: 10px;
	height: 50px;
	width: 10px;
	border: 3px solid #d0d0d0; /*クリップ色 */
	background-color: none;
	border-radius: 12px;
	box-shadow: 1px 1px 1px #909090; /*クリップ影*/
	transform: rotate(10deg);
	z-index: 1;
}

.clip-box-b::after {
	position: absolute;
	content: '';
	top: 0px;
	width: 10px; 
	right: 20px;
	border: solid 5px #4070c7/*#00659f*/; /*背景色と同じ色に！*/
	z-index: 2;
}

#sec-flow .clip-box-b p{
	font-size: 1.45em;
	line-height: 1.7em;
	margin-bottom: 0;
}

.sub_t{
	line-height: 0;
	font-size: 1.8em;
	position: relative;
	top: 16px;
}


/* --------------------------------
	内容
-------------------------------- */


#sec-flow .table{
	background-color: #fff;
	margin: 0 0 30px;
	font-size: 1.4em;
}

#sec-flow .table th{
	vertical-align: middle;
	padding: 15px;
}

#sec-flow .table td{
	vertical-align: middle;
	padding: 15px;
}

.table-course th{width: 15%;}

.video{
	position:relative;
	width:100%;
	padding-top:56.25%;
}
.video iframe{
	position:absolute;
	top:0;
	right:0;
	width:100%;
	height:100%;
}

#sec-flow .rem-seats{background-color: #fff; padding:10px; margin-right: 10px; margin-bottom: 10px; border: 2px solid #2980b9; display: inline-block; border-radius: 5px;}
#sec-flow .rem-seats.full{background-color: #ea1010; border: 2px solid #ea1010; color: #fff;}
#sec-flow .rem-seats.soon{background-color: #ffed4d; border: 2px solid #ffba26;}



/* --------------------------------
	写真
-------------------------------- */

.photo{
	margin-bottom: 20px;
}

a.thumnail {
	background: #fff;
	padding:8px;
	box-shadow:9px 9px 0px -5px #c4c4c4;
	-moz-box-shadow:9px 9px 0px -5px #c4c4c4;
	-webkit-box-shadow:9px 9px 0px -5px #c4c4c4;
	margin: 20px 0;
}

#sec-flow img {
	height: auto;
	-webkit-transition:all 0.25s ease-in-out;
	transition:all 0.25s ease-in-out;
	width: 100%;
	vertical-align: bottom;
}

#sec-flow figure {
	margin: 0;
	overflow: hidden;
	position: relative;
	text-align: center;
}

figcaption {
	background-color: rgba(100,190,208,0.9);
	color: #FFF;
	opacity: 0;
	font-size: 1.5em;
	position: absolute;
	text-align: center;
	-webkit-transition:all 0.25s ease-in-out;
		transition:all 0.25s ease-in-out;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	padding-top: 30%;
	line-height: 27px;
}

a:hover>figure img {
	transform: scale(1.15,1.15);
	-webkit-transform:scale(1.15,1.15);
	-moz-transform:scale(1.15,1.15);
	-ms-transform:scale(1.15,1.15);
	-o-transform:scale(1.15,1.15);
}

a:hover>figure figcaption {
	opacity: 1;
}


/* --------------------------------
	タブ設定
-------------------------------- */

@keyframes tabAnim{
	0%{opacity:0;}
	100%{opacity:1;}
}
input[type="radio"]{display:none;}
.tab_wrap{margin:0 auto; padding-top: 40px;}
.tab_area{font-size:0; padding:0;/*padding:0 55px;*/}
.tab_area label{width:17%;/*width:500px;*/ display:inline-block; padding:20px 0 10px; color:#000; background:#e6f5ff; text-align:center; font-size:17px; cursor:pointer; transition:ease 0.2s opacity; border-top-left-radius:10px; border-top-right-radius:10px; vertical-align:bottom; transition:ease 0.2s; margin: 0;/*margin:10px 5px 0;*/ font-weight: 100;}
.tab_area label:hover{opacity:0.5;}
.tab_panel{width:100%; padding:0; opacity:0; display:none;}
/*.tab_panel p{font-size:14px; letter-spacing:1px; text-align:center;}*/
.panel_area{/*background:#fff;*/ border-bottom-right-radius:10px; border-bottom-left-radius:10px; border-top:8px solid #4070c7/*#00659f*/;}
#tab1:checked ~ .tab_area .tab1_label{background:#4070c7/*#00659f*/; color:#fff;}
#tab1:checked ~ .panel_area #panel1{display:block; animation:tabAnim ease 0.6s forwards; -ms-animation:tabAnim ease 0.6s forwards;}
#tab2:checked ~ .tab_area .tab2_label{background:#4070c7/*#00659f*/; color:#fff;}
#tab2:checked ~ .panel_area #panel2{display:block; animation:tabAnim ease 0.6s forwards; -ms-animation:tabAnim ease 0.6s forwards;}
#tab3:checked ~ .tab_area .tab3_label{background:#4070c7/*#00659f*/; color:#fff;}
#tab3:checked ~ .panel_area #panel3{display:block; animation:tabAnim ease 0.6s forwards; -ms-animation:tabAnim ease 0.6s forwards;}
#tab4:checked ~ .tab_area .tab4_label{background:#4070c7/*#00659f*/; color:#fff;}
#tab4:checked ~ .panel_area #panel4{display:block; animation:tabAnim ease 0.6s forwards; -ms-animation:tabAnim ease 0.6s forwards;}
#tab5:checked ~ .tab_area .tab5_label{background:#4070c7/*#00659f*/; color:#fff;}
#tab5:checked ~ .panel_area #panel5{display:block; animation:tabAnim ease 0.6s forwards; -ms-animation:tabAnim ease 0.6s forwards;}
#tab6:checked ~ .tab_area .tab6_label{background:#4070c7/*#00659f*/; color:#fff;}
#tab6:checked ~ .panel_area #panel6{display:block; animation:tabAnim ease 0.6s forwards; -ms-animation:tabAnim ease 0.6s forwards;}
.tab_title{
	font-size: 1.7em;
	font-weight: bold;
}
#tab3_label{width: calc(100% - (17%*5:));}

/*ここから特別に設定*/
#tab1_label, #tab2_label, #tab3_label, #tab4_label, #tab5_label, #tab6_label, #tab7_label, #tab8_label{width: 12.5%;}
#tab7:checked ~ .tab_area .tab7_label{background:#4070c7/*#00659f*/; color:#fff;}
#tab7:checked ~ .panel_area #panel7{display:block; animation:tabAnim ease 0.6s forwards; -ms-animation:tabAnim ease 0.6s forwards;}
#tab8:checked ~ .tab_area .tab8_label{background:#4070c7/*#00659f*/; color:#fff;}
#tab8:checked ~ .panel_area #panel8{display:block; animation:tabAnim ease 0.6s forwards; -ms-animation:tabAnim ease 0.6s forwards;}

.box-v1{border: 1px solid #000;padding: 20px 30px;margin-bottom: 30px;background-color: #fff;}
.box-v1 p{line-height: 30px; margin: 0;}
/*ここまで特別に設定*/



/* --------------------------------
	保護者の声
-------------------------------- */

.box {
	border-radius: 5px;
	border: solid 1px #dedede;
	/*background-color: #f8fff5;*/
	background-color: #fff;
	padding:10px 25px 50px;
	text-align: left;
	display: block;
	margin: 60px 0 10px;
}

.box-icon {
	display: table;
	margin: 0 auto;
	margin-top: -65px;
}

.hogosya{
	background-color: #4070c7/*#00659f*/;;
	padding: 8px 13px;
	color: #fff;
	position: relative;
	top: 20px;
	font-size: 1.35em;
}


.-----PC_MOBILE_COMMON_CSS_END----- {}


/* スマートフォン用CSS */
@media screen and (max-width: 640px) {
	
	.-----MOBILE_ONLY_CSS_START----- {}

	.main_pho{
	margin-top: 30px;}

	.main_title {
		font-size: 2.5em;
		position: relative;
		padding: 0.5em 0;
		line-height: 1.2em;
		letter-spacing: -0.03em;
		margin: 30px 0 20px;
	}

	.elem-b, .junior-b, .high-b{
		padding: 5px 13px;
		position: relative;
		top: -5px;
		left: 0px;
		margin-left: 20px;
		font-size: 0.6em;
	}

	.sub_title_a{position: relative;top: -3px;}

	.sub_title_b{
		padding: 7px;
		/*font-size: 1.0em;*/
		margin-bottom: 20px;
	}

	#sec-flow .btn{
		font-size: 1.2em!important;
		/*margin: 0 0 30px;*/
	}

	#sec-flow .apply-appeal {
		font-size: 1.5em!important;
		margin: 30px auto -20px;
		padding: 0;
		line-height: 1.3em;
	}
	.apply-appeal:before {
		position: absolute;
		top: 72%;
		left: 0%;
		height: 20px;
	}
	.item{
		padding: 5px 15px 4px;
		margin: 0 10px 15px;
		font-size: 0.7em;
	}

	#sec-flow .table{
		font-size: 1.0em;
		/*margin: 0 0 30px;*/
	}

	.table-horizontal th{
		display: block;
	}
	.table-horizontal td{
		display: block;
	}

	.table-course th{width: 100%;}

	#sec-flow h2 {
		padding: 0.15em 0.4em;/*上下 左右の余白*/
		border-left: solid 7px #4070c7/*#00659f*/;/*左線*/
		text-align: left;
		font-size: 1.6em;
		margin: 40px 0 20px;
		letter-spacing: 0;
	}

	#sec-flow h3 {font-size: 1.1em;}

	.clip-box-b {
		/*padding: 0 0.9em 1em 1.2em;*/
		padding: 1.0em 1.7em 1.0em 1.2em;
		margin-top: 25px;
		margin-bottom: 40px;
	}
	.clip-box-b p{
		/*font-size: 1.0em;*/
		line-height: 1.6em;
	}

	.sub_t{
		line-height: 1.3em;
		margin-top: 0;
		font-size: 1.6em;
		position: relative;
		top: 4px;
	}

	/*#sec-flow .tsuiki {
		font-size: 1.0em;
	}*/

	/*タブ*/
	.tab_wrap{padding-top: 30px;}
	.tab_area{padding:0;}
	.tab_area label{padding: 17px 0 9px; margin:10px 0 0; width:50%;}
	.tab_title{font-size: 2.4em;}
	#tab3_label{width:50%;}

	/*ここから特別に設定*/
	#tab1_label, #tab2_label, #tab3_label, #tab4_label, #tab5_label, #tab6_label, #tab7_label, #tab8_label{width: 50%;}

	.box{padding:10px 25px 55px;}

	.hogosya{
		font-size: 0.9em;
		top: 25px;
		padding: 10px 13px 11px;
	}

	.table-responsive{
		border: none;
	}

	#sec-flow .table-responsive .table{
		margin-bottom: 0;
	}

	figcaption{font-size: 0.8em;}
}