@charset "utf-8";

html {
  scroll-behavior: smooth;
}


#first h1 {
	text-align: center;
}



#concept h2 span{
    color: #FF9900;
}

#feature h2 span{
    color: #2e98e5;
}

#price h2 span{
    color: #FF9900;
}

#school h2 span{
    color: #ff6600;
}

.youtube{
	margin-left: auto;
	margin-right: auto;
	text-align: center;
	aspect-ratio: 16/9;
}
	
.youtube iframe {
	width:100%;
	height:100%;
}


.mainimg {
	text-align: center;
}

.mainimg img {
	width:100%;
}

/*********************************
追加
*********************************/

	.linktext {
	color:#FF9900;
	font-weight:bold;
	}

	.work{
		display: flex;
		flex-wrap:wrap;
		max-width: 1000px;
		margin-left: auto;
		margin-right: auto;
		margin-top: 100px;
		margin-bottom: 100px;

		text-align: center;
	}

	.work li img{
		width: 400px;
		margin-left: 30px;
		margin-right: 30px;
	}

	.work a:hover img {
	opacity: 0.50;
	}

/*********************************
追加
*********************************/


/*********************************
#first img {
    border-radius: 15px;
}
*********************************/

#first:after{
	position: absolute;
	z-index: -1;
	content:'';
	top:1250px;
	left:-30%;
	width:150%;
	height: 500px;
	background: #f9f9f9;
	transform: rotate(-4deg);
}


@media (max-width: 600px){
	
#first:after{
	position: absolute;
	z-index: -1;
	content:'';
	top:575px;
	left:-30%;
	width:150%;
	height: 500px;
	background: #f9f9f9;
	transform: rotate(-4deg);
}
	
}


#school:after {
	position: absolute;
	z-index: -1;
	content:'';
	top:0px;
	left:-30%;
	width:150%;
    height: 400px;
	background: #f9f9f9;
	transform: rotate(-5deg);
}

#price:after {
    position: absolute;
    z-index: -1;
    content: '';
    top: 280px;
    left: -30%;
    width: 150%;
    height: 400px;
    background: #ddd;
    transform: rotate(5deg);
}


.color-back {
		display: block;
		width: 100%;
		margin-left: auto;
		margin-right: auto;
	}

.kinari {
		background-color: #FDFFF0;
	}

.haiiro {
		background-color: #f9f9f9;
	}


.orangetext {
color:#FF9900;
font-weight:bold;
}


.bluetext {
color:#2e98e5;
font-weight:bold;
}


.bodyText{
		margin-left: auto;
		margin-right: auto;
		text-align: left;
}

/* 見出し装飾 */
.marker {
    background: linear-gradient(transparent 60%, #ffff66 60%);
}
/* 見出し装飾 */


.outlineContainer img {
    border-radius: 15px;
}

/*********************************
教室一覧
*********************************/

#school p{
	text-align: center;
}

/* --------------------------------------------------------
	container
-------------------------------------------------------- */

.container {
	width: 85%;
	margin: 30px auto;
}

/* --------------------------------------------------------
	card
-------------------------------------------------------- */

.cardContainer {
	display: flex;
	flex-flow: row wrap;
	margin: 50px 0;
}
.cardBox {
	width: calc(33.3% - 20px);
	margin: 10px;
	background-color: #fff;
}

.cardBox img {
	display: block;
	max-width: 801px;
	margin: 0 auto 30px;
}

.cardText p {
	margin-bottom: 20px;
	text-align: center;
	font-size: 85%;
	font-weight: bold;
}

.cardBox {
	position: relative;
	padding: 40px 40px 60px;
}


.cardBox h4 {
	text-align: center;
	font-size: 120%;
	font-weight: bold;
	line-height: 1.5;
	margin-bottom: 30px;
}


@media screen and (max-width: 1200px) {
	.cardBox {
		width: 100%;
		margin-bottom: 50px;
	}
	
	.cardBox:last-child {
		margin-bottom: 20px;
	}
	
}




/*********************************
スマートフォン
*********************************/
@media (max-width: 600px){
	

	
	.outlineContainer{
		margin-left: auto;
		margin-right: auto;
		margin-top: 25px;
		margin-bottom: 25px;
		text-align: center;
	}
	
	.outline01{
		display: flex;
		flex-flow: column;
		justify-content: center;
		width: 100%;
		margin-top: 15px;
	}
	
_:lang(x)+_:-webkit-full-screen-document, .outline01 img{
		width: 80%;
		height: 80%;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 10px;
	}
	.outline02{
		display: flex;
		flex-flow: column;
		justify-content: center;
		width: 100%;
		margin-top: 15px;
	}
	
_:lang(x)+_:-webkit-full-screen-document, .outline02 img{
		width: 80%;
		height: 80%;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 10px;
	}

	.outlineText{
		margin: 0 20px;
	}
	.outlineText h1{
		text-align: left;
		font-size: 100%;
		margin-top: 25px;
		margin-bottom: 25px;
	}
	.outlineText h2{
		text-align: left;
		font-size: 100%;
	}
	.outlineText h3{
		text-align: left;
		font-size: 100%;
	}
	.outlineText p{
		text-align: left;
		font-size: 80%;
		margin-bottom: 25px;
	}
	
	
.bodyText {
	width: 85%;
}
	
.bodyText h1 {
	font-size: 100%;
	margin-bottom: 25px;
}
	
.bodyText h2,h3,p {
	font-size: 80%;
	margin-bottom: 25px;
}
	
.large-photo {
		width: 100%;
		margin-top: 25px;
		margin-bottom: 50px;
		margin-left: auto;
		margin-right: auto;
		text-align: center;
}
	
.large-photo img{
		width: 100%;
}

.youtube{
	width: 360px;
}
	
}



/*********************************
タブレット
*********************************/
@media (min-width: 601px) and (max-width: 1024px){
	
	.outline01{
		display: flex;
		align-items: center;
	}
	.outline01 img{
		width: 50%;
		height: 50%;
	}
	.outline02{
		display: flex;
		flex-flow:row-reverse nowrap;
		align-items: center;
	}
	
	.outline02 img{
		width: 50%;
		height: 50%;
	}
	.outlineText{
		margin: 0 50px;
	}
	.outlineText h1{
		text-align: left;
		font-size: 180%;
		margin-top: 50px;
		margin-bottom: 50px;
	}
	.outlineText h2{
		text-align: left;
		font-size: 120%
	}
	
	.outlineText h3{
		text-align: left;
		font-size: 120%
	}
	
	.outlineText p{
		text-align: left;
		font-size: 110%;
		margin-bottom: 100px;
	}
	
	/*概要説明部2*/
	.outlineContainer{
		display: block;
		margin-left: auto;
		margin-right: auto;
		text-align: center;
		width: 950px;
	}
	
	.color-back {
		margin-top: 50px;
		margin-bottom: 50px;
		padding-top: 50px;
		padding-bottom: 50px;
	}
	
.bodyText {
	width: 600px;
}

.bodyText h1 {
	font-size: 180%;
}

.bodyText h2,h3,p {
	font-size: 110%;
	margin-bottom: 25px;
}

.large-photo {
		width: 100%;
		margin-top: 25px;
		margin-bottom: 50px;
		margin-left: auto;
		margin-right: auto;
		text-align: center;
}
	
.large-photo img{
		width: 100%;
}
	
.youtube{
	width: 850px;
}
	
}



/*********************************
パソコン
*********************************/
@media (min-width: 1025px){

	.outline01{
		display: flex;
		align-items: center;
	}
	.outline01 img{
		width: 50%;
		height: 50%;
	}
	.outline02{
		display: flex;
		flex-flow:row-reverse nowrap;
		align-items: center;
	}

	.outline02 img{
		width: 50%;
		height: 50%;
	}
	
	.outlineText{
		margin: 0 50px;
	}
	.outlineText h1{
		text-align: left;
		font-size: 180%;
		margin-top: 50px;
		margin-bottom: 25px;
	}
	.outlineText h2{
		text-align: left;
		font-size: 120%
	}
	
	.outlineText h3{
		text-align: left;
		font-size: 120%
	}
	
	.outlineText p{
		text-align: left;
		font-size: 110%;
		margin-bottom: 100px;
	}
	
	.outlineContainer{
		display: block;
		margin-left: auto;
		margin-right: auto;
		text-align: center;
		width: 1400px;
	}
	
	.color-back {
		margin-top: 50px;
		margin-bottom: 75px;
		padding-top: 50px;
		padding-bottom: 50px;
	}
	
.bodyText {
	width: 850px;
}
	
.bodyText h1 {
	font-size: 180%;
}

.bodyText h2,h3,p {
	font-size: 110%;
	margin-bottom: 25px;
}
	
.large-photo {
		width: 1200px;
		margin-top: 50px;
		margin-bottom: 100px;
		margin-left: auto;
		margin-right: auto;
		text-align: center;
}
	
.large-photo img{
		width: 1200px;
}
	
.youtube{
	width: 1000px;
}
	
}



/* スペース */

.mt20 {
		margin-top: 20px;
}

.mt25 {
		margin-top: 25px;
}

.mt50 {
		margin-top: 50px;
}

.mt75 {
		margin-top: 75px;
}

.mt100 {
		margin-top: 100px;
}

.mt125 {
		margin-top: 125px;
}

.mt150 {
		margin-top: 150px;
}

.mt200 {
		margin-top: 200px;
}

.mb20 {
		margin-bottom: 20px;
}

.mb25 {
		margin-bottom: 25px;
}

.mb50 {
		margin-bottom: 50px;
}

.mb75 {
		margin-bottom: 75px;
}

.mb100 {
		margin-bottom: 100px;
}

.mb125 {
		margin-bottom: 125px;
}

.mb150 {
		margin-bottom: 150px;
}

.mb200 {
		margin-bottom: 200px;
}

/* スペース */