@charset "UTF-8";

.message {
    padding-top: 0;
}
.message .pic {
    margin-bottom: 7.2rem;
}
.message .sec-title02 {
    font-size: 2.4rem;
}
.message p {
    margin-bottom: 1em;
}
.message p, .reason {
    max-width: 96rem;
    margin-left: auto;
    margin-right: auto;
}

/* +++#award+++ */
.award-pic {
	width: 42%;
	margin: 0 3% 0 0;
}
.award-pic img {
	width: 100%;
}
#award .txt {
	width: 55%;
}

/* +++#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);
}
.circle-wrap {
	margin: 0 auto;
	padding: 0 0 5rem 0;
	width: 500px;
	z-index: 3;
	opacity: 0;
	transform: translateY(-100px) scale(0.8);
	transition: opacity 0.5s ease-out, transform 0.5s ease-out;
	transform-origin: center top;
}
.circle-wrap.is-shown {
  opacity: 1;
  transform: translateY(0) scale(0.9);
}
.circle-area {
	text-align: center;
}
.large-circle {
	border: 7px dotted #18436e;
	border-radius: 50%;
	width: 350px;
	height: 350px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-40%);
	animation: rotate-circle 30s linear infinite;
}
@keyframes rotate-circle {
	from {
		transform: translateX(-50%) translateY(-40%) rotate(0deg);
	}
	to {
		transform: translateX(-50%) translateY(-40%) rotate(360deg);
	}
}
.circle-text {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	width: 120%;
}
.circle-text p {
	font-size: 1.8rem;
}
.circle-features {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10rem 16rem;
	justify-items: center;
}
.circle-feature {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}
.circle-feature:nth-child(1) {
	grid-column: 1 / -1;
	justify-self: center;
}
.circle-feature:nth-child(2),
.circle-feature:nth-child(3) {
	grid-column: span 1;
}
.small-circle {
	width: 150px;
	height: 150px;
	border-radius: 50%;
	align-items: center;
	justify-content: center;
	color: #fff;
}
.catch-copy01 {
	font-size: 2rem;
}
.catch-copy02 {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-25%);
	width: 200%;
	font-size: 1.5rem;
}
.back-color01 { background-color: #18436e; }
.back-color02 { background-color: #227c54; }
.back-color03 { background-color: #8e1028; }
.font-color01 { color: #18436e; }
.font-color02 { color: #227c54; }
.font-color03 { color: #8e1028; }
.text-outline01 {
	-webkit-text-stroke: 5px #18436e;
	text-stroke: 5px #18436e;
	paint-order: stroke;
}
.text-outline02 {
	-webkit-text-stroke: 5px #227c54;
	text-stroke: 5px #227c54;
	paint-order: stroke;
}
.text-outline03 {
	-webkit-text-stroke: 5px #8e1028;
	text-stroke: 5px #8e1028;
	paint-order: stroke;
}
.text-outline04 {
	-webkit-text-stroke: 4px #fff;
	text-stroke: 4px #fff;
	paint-order: stroke;
}
.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: 3rem;
	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% - 2.4rem);
	border: 2px solid #bbb;
}
.case02{
	border-color: #f68026;
}
.case .pic{
	width: 100%;
	padding: 2.4rem;
}

.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 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;
}


/* +++++こんなに違うのセクション+++++++ */
.lead-area{
	margin-bottom: 3rem;
}
.lead{
	padding: .75em;
	background: #d71010 !important;
	font-size: 135%;
	color: #fff;
}
.lead-area p{
	padding-left: 1em;
	font-size: 112.5%;
}


/* +++ .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;
}





.conditions {
	font-weight: 500;
	width: 7em;
	height: 1.8em;
	border-radius: .9em;
	border: 1px solid #434343;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 0 0.5rem;
}
.button-tyousei {
	margin: 0 auto 1.5rem;
}
.kentei-button {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	max-width: 98rem;
	margin: 3.5rem auto 0;
}
.sikaku-wrap {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0 3rem;
}
.meyasu {
	background: #fff;
	font-size: 1.4rem;
	line-height: 1.75;
	margin-top: 3rem;
	border-top: 1px solid #efefef;
}
.meyasu tr,
.meyasu th,
.meyasu td {
	display: block;
}
.meyasu tr {
	display: block;
	border: 1px solid #efefef;
	border-top: none;
}
.meyasu th {
	font-weight: 500;
	padding: 1.8rem 2.4rem;
	text-align: left;
	background: #f5faf9;
	vertical-align: top;
	color: #068;
}
.meyasu td {
	padding: 1.8rem 2.4rem;
	vertical-align: top;
	min-height: 250px;
}
.meyasu ul li {
	list-style: disc;
	list-style-position: inside;
}





@media screen and (max-width: 768px){

	.school-main-pic01 img,
	.school-main-pic02 img {
		width: 100%;
	}

/* +++#award+++ */
.award-pic {
	width: 100%;
	margin: 0 0 2.4rem;
}
#award .txt {
	width: 100%;
}

/* +++#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;
	}


/* +++++こんなに違うのセクション+++++++ */
	.lead-area{
		margin-bottom: 1.8rem;
	}
	.lead{
		font-size: 110%;
		width: calc(100% - 3rem);
		text-align: center;
		margin-bottom: 1rem;
	}
	.lead-area p{
		padding-inline: 1.5rem;
		font-size: 100%;
		font-weight: 500;
	}
	.case .pic{
		padding: 1.5rem;
	}


/* +++ .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;
	}





	.kentei-button {
		grid-template-columns: 1fr;
	}
	.sikaku-wrap {
		grid-template-columns: 1fr;
		
	}
	.meyasu{
		font-size: 1.3rem;
		width: 100%;
		max-width: 100%;
		margin-top: 2.4rem;
		display: block;
	}
	.meyasu tbody,
	.meyasu tr,
	.meyasu th,
	.meyasu td{
		display: block;
		width: 100% !important;
	}
	.meyasu th{
		padding: 1.5rem !important;
		text-align: left;
	}
	.meyasu td{
		padding: 1.5rem !important;
		min-height: 300px;
	}



}