@charset "UTF-8";

/* +++#features+++ */
.comment01{
	margin-bottom: 1em;
	font-size: 1.8rem;
}
.comment01 .text-red{
	font-size: 125%;
	padding-inline: .25em;
}
.comment02{
	width: fit-content;
	font-size: 2.4rem;
	margin: 0 auto 6rem;
	position: relative;
}
.comment02 .text-red{
	font-size: 150%;
}
.comment02 .slide-up{
	transform: translateY(3em);
}

.feature{
	width: 100%;
	position: relative;
	margin-bottom: 7.2rem;
	align-items: center;
}
.feature .pic-area{
	position: relative;
	width: min(43.548rem, calc(95vw * .382));
	height: min(43.548rem, calc(95vw * .382));
}
.feature .text{
	width: calc(61.8% - 7.2rem);
}
.feature:nth-of-type(2n+1){
	flex-direction: row-reverse;
}

.feature h3{
	font-size: 2.2rem;
	line-height: 1.75;
	margin-bottom: 1.8rem;
}
.feature p{
	font-size: 1.5rem;
}
.feature .pic{
	position: absolute;
}
.feature:nth-of-type(1) .pic01,
.feature:nth-of-type(3) .pic01{
	left: 0;
	top: 0;
	width: 61.8%;
}
.feature:nth-of-type(1) .pic02,
.feature:nth-of-type(3) .pic02{
	right: 0;
	bottom: 0;
	width: 61.8%;
}
.feature:nth-of-type(2) .pic01{
	left: 0;
	top: 0;
	width: 80%;
}
.feature:nth-of-type(2) .pic02{
	right: 0;
	bottom: 0;
	width: 80%;
}
.feature h3 .slide-up{
	transform: translateY(3em);
}
.feature p .slide-up{
	transform: translateY(100%);
}

mark{
	padding: 0 .5em;
	position: relative;
	font-size: 110%;
	background: none;
}
mark:before{
	content: "";
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: #e8ff00;
	mix-blend-mode: darken;
}
#features .slide-left-open:before,
#features .slide-right-open:before,
#features .slide-top-open:before,
#features .slide-bottom-open:before{
	background: #f5f8fa;
}





/* +++.philosophy+++ */
.philosophy p.comment02{
	font-size: 1.8rem;
	margin-bottom: 1.2rem;
	line-height: 1.75;
}

.comment03{
	font-size: 1.8rem;
	line-height: 1.75;
	margin: 4rem auto 3rem;
}
.comment03 mark{
	font-size: 110%;
	margin: 0 .25em;
}
.case{
	width: calc(50% - .5px);
	border: 4px solid #bbb;
}

.case .caption{
	font-size: 80%;
}
.philosophy div.s-between{
	max-width: 100rem;
	align-items: stretch;
}
.case h4{
	font-size: 1.7rem;
	text-align: center;
	padding: 1.2rem .6rem;
	line-height: 1.5;
	color: #fff;
	background: #bbb;
	width: 100%;
}

.case02{
	border-color: #f68026;
}
.case02 h4{
	background: #f68026;
}
.case .text{
	padding: 2rem;
}
.case .text p{
	font-size: 1.4rem;
}
.caption{
	font-size: 80%;
	margin-top: 1.5em;
	padding-left: 1em;
	text-indent: -1em;
	display: block;
}
.caption:before{
	content: "※";
	display: inline;
}
.arrow{
	margin: 3.6rem auto;
	position: relative;
}
.arrow .pic{
	width: 12rem;
	margin: auto;
	opacity: .5;
}
.arrow-text{
	font-size: 2.4rem;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
}
.case mark{
	background: #e8ff00;
}
.case mark:before{
	display: none;
}

.curriculum{
	align-items: flex-start !important;
	margin-bottom: 9.6rem;
}
.curriculum:last-of-type{
	margin-bottom: 4.8rem;
}
.curriculum:nth-of-type(2n+1){
	flex-direction: row-reverse;
}

.curriculum .text{
	width: calc(65% - 4.8rem);
	margin-top: 5.4rem;
}

.curriculum .text{
	margin-top: 3.6rem;
	padding: 3.6rem;
	background: #eee;
	width: calc(65% + 10vw);
	background: #f5faf9;
}
.curriculum:nth-of-type(2n+1) .text{
	margin-right: -10vw;
	padding-right: calc(3.6rem + 10vw);
	background: #f6f3f0;
}
.curriculum:nth-of-type(2n) .text{
	margin-left: -10vw;
	padding-left: calc(3.6rem + 10vw);
}

.curriculum .pic{
	width: 35%;
}

.curriculum p{
	font-size: 1.5rem;
}
.curriculum h4{
	line-height: 1.75;
	font-size: 2rem;
	margin-bottom: 1.6rem;
	font-weight: 500;
}
.curriculum .en{
	color: #62c1b1;
	margin-bottom: .8rem;
	line-height: .8;
	color: #39b6af;
}
.curriculum:nth-of-type(2n+1) .en{
	color: #f97520;
}


/* +++ .voice +++ */
.pswp{
	z-index: 99999;
}
.voice-list li{
	width: calc(25% - 2.7rem);
	height: min(calc((95vw / 4) - 2.7rem), 25.8rem);
	overflow: hidden;
	margin-bottom: 3.6rem;
	position: relative;
}
.voice-list li:before{
	background: #f5f8fa;
}
.voice-list li:not(:nth-of-type(4n)){
	margin-right: 3.6rem;
}
.voice-list li *{
	display: block;
	width: 100%;
	height: 100%;
}
.voice-list img{
	display: block;
	transition: .3s all ease;
}
.voice-list a:hover img{
	transform: scale(1.05);
}





/* +++training+++ */
.training-list{
	justify-content: center;
	max-width: 140.4rem;
}
.training-list li{
	width: 25%;
	padding: 0 1.8rem 5.4rem;
	overflow: hidden;
	position: relative;
}
.training-list li:nth-of-type(n+5){
	padding-bottom: 0;
}
.training-list h3{
	font-size: 1.7rem;
	line-height: 1.5;
	margin: 2.4rem 0 1rem;
}
.training-list p{
	font-size: 1.4rem;
}

/* +++school-slide01+++ */
.school-slide01{
	transition: .8s all ease;
}
.portfolio{
	padding-inline: 0;
}




.school-slide01 a{
	display: block;
	position: relative;
}
.school-slide01 a h3{
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	transition: .3s all ease;
	transition-delay: 0;
	visibility: hidden;
	opacity: 0;
	font-size: 1.6rem;
}
.school-slide01 a:hover h3{
	opacity: 1;
	visibility: visible;
	transition-delay: .3s;
}
.school-slide01 li .pic{
	position: relative;
	overflow: hidden;
}
.school-slide01 .pic{
	height: calc(100vw / 3.5 / 3 * 2);
}

.school-slide .pic img{
	height: 100%;
	object-position: center top;
}

.school-slide01 li .pic:before{
	font-family: 'Outfit', 'Zen Kaku Gothic New', YuGothic, 游ゴシック, メイリオ, Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", sans-serif;
	--spacing: .1em;
	font-weight: 400;
	color: #fff;
	content: "";
	display: flex;
	justify-content: center;
	align-items: center;
	width: 120%;
	height: 100%;
	position: absolute;
	background: #3dd2b7;
	transform: skew(-15deg, 0) scale(0,1);
	left: -10%;
	top: 0;
	transition: .3s all ease;
	opacity: 0;
}
.school-slide01 li:hover .pic:before{
	transform: skew(-15deg, 0) scale(1,1);
	opacity: .85;
}


/* +++school-slide01+++ */
.outline .sec-title01{
	width: calc(30% - 2.4rem);
}
.outline .content{
	width: 70%;
}
.outline table{
	width: 100%;
	line-height: 1.75;
}
.outline th{
	font-weight: 500;
	text-align: left;
	vertical-align: top;
	width: 30%;
	border-bottom: 1px solid #434343;
	padding: 1.8rem 1.2rem;
	font-size: 1.5rem;
}
.outline td{
	width: 70%;
	border-bottom: 1px solid #ccc;
	padding: 1.8rem 1.2rem;
	font-size: 1.5rem;
}
.outline td dl:not(:last-of-type){
	margin-bottom: 1.5em;
}
.outline th:nth-of-type(1){
	border-top: 1px solid #434343;
}
.outline td:nth-of-type(1){
	border-top: 1px solid #ccc;
}

.outline td a{
	display: inline-block;
	width: fit-content;
	position: relative;
}
.outline td a[target="_blank"]:after{
	content: "";
	display: inline-block;
	width: .8em;
	height: .8em;
	margin-left: .5em;
	background: url(../images/new-window-icon01.svg) no-repeat;
	background-size: 100% auto;
	background-position: center center;
}
.outline td a:before{
	content: "";
	display: block;
	width: 100%;
	height: 1px;
	background: #434343;
	position: absolute;
	left: 0;
	bottom: 0;
	transition: .3s transform ease;
	transform-origin: left top;
}

.outline td a:hover:before{
	transform-origin: right top;
	transform: scaleX(0);

}


/* +++access+++ */
.map-area:not(:last-of-type){
	margin-bottom: 4.8rem;
}
.map-area{
	align-items: center;
}
.map-area .text{
	width: calc(50% + 10vw);
	margin-right: -10vw;
	padding: 3.6rem calc(3.6rem + 10vw) 3.6rem 3.6rem;
	background: #f2f2ed;
	font-size: 1.5rem;

	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;

	height: min(calc(45vw / 16 * 9 + 7.2rem), calc(32rem + 7.2rem));
}
.googlemap{
	width: 50%;
	height: min(calc(45vw / 16 * 9), 32rem);
}
.googlemap>iframe{
	display: block;
	width: 100%;
	height: 100%;
}
.access .slide-left-open:before{
	background: #f5f8fa;
	z-index: 999;
}


@media screen and (max-width: 768px){
/* +++#features+++ */
	.comment02{
		font-size: 1.6rem;
		margin: 0 auto 3.6rem;
	}
	.comment02 .text-red{
		font-size: 125%;
	}
	.comment02 .slide-up{
		transform: translateY(5em);
	}

	.feature-area{
		display: block;
	}
	.feature{
		width: 100%;
	}
	.feature .pic-area{
		width: calc(100% - 4rem);
		height: calc(100vw - 8rem);
		margin: 0 auto 2.4rem;
	}

	.feature h3{
		font-size: 1.6rem;
		margin-bottom: 1.2rem;
	}
	.feature p{
		font-size: 1.3rem;
	}
	.feature:nth-of-type(2){
		margin-top: 6rem;
	}
	.feature:nth-of-type(3){
		margin-top: 6rem;
	}
	.feature .text {
		width: 100%;
	}
	mark{
		padding: 0 .25em;
		font-size: 105%;
	}


/* +++.philosophy+++ */
	.philosophy{
		padding-inline: 0;
	}
	.philosophy p.comment02{
		font-size: 1.6rem;
		margin-bottom: 1.2rem;
		line-height: 1.75;
	}

	.comment03{
		font-size: 1.6rem;
		line-height: 1.75;
		margin: 2.4rem auto 1.8rem;
	}
	.comment03 mark{
		font-size: 105%;
		margin: 0 .1em;
	}
	.case{
		width: 100%;
		border: 3px solid #bbb;
	}

	.philosophy div.s-between{
		display: block;
		max-width: 100%;
		padding-inline: 2rem;
	}
	.case h4{
		font-size: 1.5rem;
		text-align: center;
		padding: .8rem .4rem;
	}

	.case02{
		border-color: #f68026;
		margin-top: 1.8rem;
	}

	.case .text{
		padding: 1.5rem;
	}
	.case .text p{
		font-size: 1.3rem;
	}

	.arrow{
		margin: 1.8rem auto;
	}
	.arrow .pic{
		width: 8rem;
	}
	.arrow-text{
		font-size: 1.6rem;
	}


	.curriculum{
		align-items: center !important;
		flex-direction: column-reverse;
		margin-bottom: 4.8rem;
		padding-inline: 0 !important;
	}
	.curriculum:last-of-type{
		margin-bottom: 3.6rem;
	}
	.curriculum:nth-of-type(2n+1){
		flex-direction: column-reverse;
	}

	.curriculum .text{
		width: 100%;
		margin-top: -4.8rem;
	}

	.curriculum .text{
		padding: 6.8rem 2rem 2rem;
	}
	.curriculum:nth-of-type(2n+1) .text{
		margin-right: 0;
		padding-right: 2rem;
	}
	.curriculum:nth-of-type(2n) .text{
		margin-left: 0;
		padding-left: 2rem;
	}
	.curriculum .pic{
		width: 61.8%;
		margin: 0 auto;
		position: relative;
		z-index: 9;
	}

	.curriculum p{
		font-size: 1.3rem;
	}
	.curriculum h4{
		line-height: 1.5;
		font-size: 1.7rem;
		margin-bottom: 1.2rem;
	}
	.curriculum .en{
		font-size: 1.2rem;
	}


/* +++ .voice +++ */
	.voice-list{
		justify-content: space-between;
	}
	.voice-list li{
		width: calc(50% - 1rem);
		height: calc(50vw - 2rem);
		margin: 0 0 2rem !important;
	}

/* +++training+++ */
	.training-list{
		justify-content: space-between;
		max-width: 100%;
	}
	.training-list li{
		width: calc(50% - 1rem);
		padding: 0 0 4rem;
	}
	.training-list li:nth-of-type(n+5){
		padding-bottom: 4rem;
	}
	.training-list h3{
		font-size: 1.6rem;
		line-height: 1.5;
		margin: 1.8rem 0 1rem;
	}
	.training-list p{
		font-size: 1.3rem;
	}
	.training{
		padding-bottom: 2rem;
	}





/* +++school-slide01+++ */
	.school-slide01{
		padding-bottom: 0;
	}
	.school-slide01 .pic{
		height: calc(100vw / 1.25 / 3 * 2);
	}


/* +++outline+++ */
	th,
	td{
		padding: 1.2rem .8rem !important;
		font-size: 1.3rem !important;
		line-height: 1.75 !important;
	}
	th{
		width: 35% !important;
	}
	td{
		width: 65% !important;
	}

	.outline .sec-title01{
		width: 100%;
	}
	.outline .content{
		width: 100%;
	}





/* +++access+++ */
	.access{
		padding-inline: 0;
		padding-bottom: 0;
	}
	.map-area:not(:last-of-type){
		margin-bottom: 4.8rem;
	}
	.map-area{
		flex-direction: column-reverse;
	}
	.map-area .text{
		width: 100%;
		margin-right: 0;
		padding: 6.8rem 2rem 3.6rem;
		font-size: 1.3rem;
		margin-top: -4.8rem;
		height: auto;
	}
	.map-area .button01{
		margin-top: 1.8rem;
	}




	.googlemap{
		width: calc(100vw - 4rem);
		height: calc((100vw - 4rem) / 16 * 9);
		position: relative;
		z-index: 99;
	}
}