@charset "UTF-8";
/* strengths.css */

/* メインビジュアルの画像(適時変更) */
#lower_mv {
	background-image: url(../../img/strengths/mvSP.jpg);
    background-position: right bottom !important;
}
@media screen and (min-width:769px) {
	#lower_mv {
		background-image: url(../../img/strengths/mvPC.jpg);
	}
}



/* heading */
.h2_bgBorder::before {
	height: 28px;
	max-width: 25px;
	/* あとで画像入れる */
	background-image: url(../../img/strengths/icon_human.svg);
	background-size: contain;
}

.flex_box {
    justify-content: space-between;
}

/*========= strength ===============*/

/* div内の左右にダブルコーテーションの背景 */
.BGcoat:before {
	background-image: url(../../img/strengths/strBG_coatL.svg),
				      url(../../img/strengths/strBG_coatR.svg);
}

#sec_strengths .h2decoL:before {
	background-image: url(../../img/strengths/face_icon_1.svg);
}

.phillosophy {
	text-align: center;
	font-weight: bold;
	font-size: 19px;
	margin-bottom: 30px;
	color: #2196c9;
}

.phillosophy:before {
	margin-bottom: 15px;
}

.phillosophy:after {
	margin-top: 15px;
}

.phillosophy:before,.phillosophy:after {
	content: "";
    width: 100%;
    height: 4px;
    display: block;
    background-image: url(../../img/strengths/strengths_title_border.svg);
    background-size: contain;
}

#sec_strengths ul {
	color: #2196c9;
}

#sec_strengths ul li {
	text-align: center;
	font-size: 16px;
	margin-bottom: 30px;
}
.mark_ul li {
    font-weight: bold;
}
.policy li {
    list-style-type: decimal;
    text-align: left !important;
    margin-left: 1.5em;
}

.principal {
	text-align: center;
}

.principal + p {
	text-align: center;
}

.principal + p img {
	max-width: 260px;
}

#sec_strengths::after {
	content: "";
    width: 100%;
    height: 4px;
    display: block;
    background-image: url(../../img/strengths/border_dot.svg);
    background-size: contain;
	background-repeat: repeat-x;
	margin-top: 30px;
}

#sec_features .h2decoL:before {
	background-image: url(../../img/strengths/face_icon_2.svg);
}

#sec_features .h2decoL + p {
	font-size: 16px;
	font-weight: bold;
	text-align: center;
	color: #4d4d4d;
}

#sec_features .seed_bnrs_features {
	padding: 0;
}

#sec_features .box_shadow {
	background-color: #fff;
	padding: 15px;
	box-shadow: 3px 3px 0px #d3d3d3;
}

#sec_features .box_shadow .box_child {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 15px;
}

#sec_features .box_shadow .box_child > p:first-of-type {
	width: 35%;
}

#sec_features .box_shadow .box_child > p:nth-of-type(2) {
	width: 58%;
}

#sec_features .box_shadow h3 {
	text-align: left;
	font-size: 18px;
}

#sec_features .box_white {
	padding: 20px 15px 15px;
	background-color: #fff;
	border-radius: 20px;
}

#sec_features .box_white h3 {
	font-size: 20px;
	text-align: center;
	color: #e75e98;
}

#sec_features .box_white:nth-of-type(2) h3 {
	color: #62ae04;
}

#sec_features .box_white:nth-of-type(3) h3 {
	color: #f18d1e;
}

#sec_features .box_white:nth-of-type(4) h3 {
	color: #2196c9;
}

#sec_features .box_white h3 span {
	display: inline-block;
	vertical-align: middle;
}

#sec_features .box_white h3:before {
	content: '';/*何も入れない*/
	display: inline-block;/*忘れずに！*/
    width: 70px;
	height: 60px;/*画像の高さ*/
	background-image: url(../../img/strengths/support_1.svg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	vertical-align: middle;
	margin-right: 15px;
}

#sec_features .box_white:nth-of-type(2) h3:before {
	background-image: url(../../img/strengths/support_2.svg);
}

#sec_features .box_white:nth-of-type(3) h3:before {
	background-image: url(../../img/strengths/support_3.svg);
}

#sec_features .box_white:nth-of-type(4) h3:before {
	background-image: url(../../img/strengths/support_4.svg);
}

.classroom p {
	margin-bottom: 15px;
}
.room_text span {
	display: block;
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	line-height: 1.5;
	color: #2196c9;
	margin: 15px 0;
}

/*========= min-769 ===============*/

@media screen and (min-width: 769px) {
	/*==== 下層共通になる予定 ====*/
	/* heading */
	/* h2 */
	h2.h2_bgBorder  {
		font-size: 30px;
		padding:20px;
	}
	/* h3 */
	h3.h3_underLine {
		font-size: 16px;
		margin-bottom:  20px;
		padding-bottom: 20px;
	}

	/* content */

	li,
	p  { font-size:16px; }

	/* decoration */
	/* テキスト下の区切りのボーダー(上下「PC余白M」分のアキ) */
	.cont_borderB {
		margin-bottom:  40px;
		padding-bottom: 40px;
	}
	
	/*==== strength ====*/
	.phillosophy {
		font-size: 40px;
		max-width: 750px;
		margin: 60px auto 100px;;
	}
	#sec_strengths ul {
		margin: 40px 0 60px;
	}
	#sec_strengths ul li {
		font-size: 20px;
		margin-bottom: 20px;
	}
    .mark_ul li {
        font-size: 24px !important;
    }
    .policy li {
     max-width: 100%;   
    }
	#sec_strengths h3 {
		font-size: 20px;
		text-align: left;
	}
	.principal {
		text-align: left;
	}
	.message {
		display: flex;
		justify-content: space-between;
	}
	.message > div:first-of-type {
		width: 30%;
		margin-right: 40px;
	}
	.message > div:first-of-type  img {
		width: 100%;
		height: auto;
	}
	.message > div:nth-of-type(2) {
		width: calc(70% - 40px);
	}
	.message > div:nth-of-type(2) h3 {
		text-align: center !important;
	}
	#sec_strengths::after {
	margin-top: 80px;
	}
	#sec_features .seed_bnrs_features {
		padding: 0;
	}
	#sec_features .seed_bnrs_features > p {
		width: 31.5%;
	}
	#sec_features .flex_box > div {
		width: calc(50% - 20px);
		padding: 40px;
	}
    #sec_features .h2decoL + p {
        font-size: 26px;   
    }
	#sec_features .flex_box > div > div.pc_blk > div.flex_box {
		justify-content: start;
		margin: 20px 0 15px;
	}
	#sec_features .flex_box > div > div.pc_blk > div.flex_box > p:first-of-type {
		width: 25%;
		margin-right: 30px;
	}
	#sec_features .support_contents {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	#sec_features .support_contents > div {
		width: calc(50% - 20px);
		padding: 40px;
	}
	#sec_features .box_white:last-of-type {
		margin-bottom: 40px !important;
	}
	#sec_features .classroom {
		flex-wrap: nowrap;
		justify-content: space-between;
		margin-bottom: 40px;
	}
	#sec_features .classroom p {
		width: calc(50% - 20px);
		margin-bottom: 0;
	}
	#sec_features .room_text .use_time {
		margin: 40px 0;
	}
	
	/* ボックス内h3 wrapを同じタイミング */
    #sec_features .box_shadow h3 {
        font-size: min(2.2vw,20px);
        min-width: 295px;
        margin-top: 10px;
    }
	
	/* ボックス内h3 wrapさせない */
    #sec_features .box_white h3 {
        font-size: 20px;
        font-size: min(2.3vw,20px) !important;
        white-space: nowrap;
    }
}

@media screen and (min-width: 1160px) {
	/* ボックス内h3 wrapを同じタイミング */
    #sec_features .box_shadow h3 {
        margin-top: 0 !important;
    }
    
}

