@charset "UTF-8";


.cycle-wrap {
	padding: 0 0 5rem;
	opacity: 0;
	/*transform: scale(0.85);*/
	width: fit-content;
	margin: 0 auto;
}



.cycle-wrap.is-shown {
	opacity: 1;
	animation: zoomInAnime 0.5s forwards;
}
@keyframes zoomInAnime {
	from {
		transform: scale(0.85);
	}
	to {
		transform: scale(1);
	}
}
.cycle-background {
	/*transform: scale(0.85);*/
	opacity: 0.5;
}
.cycle-rotate {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%) /*scale(0.75)*/;
	animation: rotate-circle 8s linear infinite;
}
@keyframes rotate-circle {
	from {
		transform: translateX(-50%) translateY(-50%) /*scale(0.75)*/ rotate(0deg);
	}
	to {
		transform: translateX(-50%) translateY(-50%) /*scale(0.75)*/ rotate(360deg);
	}
}
.cycle-text-wrap p {
	position: absolute;
	font-size: 2.5rem;
	line-height: 1.25;
	color: #fff;
}
.cycle-text01 {
	top: 80px;
	left: 230px;
}
.cycle-text02 {
	top: 155px;
	right: 215px;
}
.cycle-text03 {
	top: 250px;
	left:220px;
}
.cycle-text04 {
	top: 275px;
	right:220px;
}
.text-outline01 {
	-webkit-text-stroke: 5px #53b9e9;
	text-stroke: 5px #53b9e9;
	paint-order: stroke;
}
.text-outline02 {
	-webkit-text-stroke: 5px #2398aa;
	text-stroke: 5px #2398aa;
	paint-order: stroke;
}
.text-outline03 {
	-webkit-text-stroke: 5px #1bc0d6;
	text-stroke: 5px #1bc0d6;
	paint-order: stroke;
}
.text-outline04 {
	-webkit-text-stroke: 5px #47b9af;
	text-stroke: 5px #47b9af;
	paint-order: stroke;
}
.text-center-wrap {
	text-align: center;
}
.learning-tool_text {
	margin: 3rem 0;
	font-size: 1.8rem;
}
#diff-table {
	width: 720px;
	margin: 0 auto 7rem;
}
#diff-table th {
	padding: 2rem 1rem;
}
#diff-table td {
	padding: 2rem 1rem 2rem;
}
#diff-table th:first-child,
#diff-table td:first-child {
	width: 30%;
	text-align: left;
	font-weight: 500;
}
#diff-table tr td:nth-child(2),
#diff-table tr td:nth-child(3) {
	text-align: center;
}
#diff-table tr:nth-child(odd) td:first-child,
#diff-table tr:nth-child(odd) th:first-child {
	background-color: #fff;
}
#diff-table tr:nth-child(even) td:first-child,
#diff-table tr:nth-child(even) th:first-child {
	background-color: #f2f2f2;
}
#diff-table tr:nth-child(odd) td:nth-child(2),
#diff-table tr:nth-child(odd) th:nth-child(2) {
	background-color: #cdecf2;
}
#diff-table tr:nth-child(even) td:nth-child(2),
#diff-table tr:nth-child(even) th:nth-child(2) {
	background-color: #e4f5f8;
}
#diff-table tr:nth-child(odd) td:nth-child(3),
#diff-table tr:nth-child(odd) th:nth-child(3) {
	background-color: #fde5e8;
}
#diff-table tr:nth-child(even) td:nth-child(3),
#diff-table tr:nth-child(even) th:nth-child(3) {
	background-color: #fef4f5;
}

/* +++#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 4rem;
	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: 1.2rem;
	line-height: 1.75;
}

.comment03{
	font-size: 1.8rem;
	line-height: 1.75;
	margin: 4rem auto 5rem;
}
.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;
}

.cycle-picture{ background-image:url(../images/learning-tool-visual.jpg); background- background-size:cover; background-color:rgba(255,255,255,0.8); background-blend-mode:lighten;width:658px; height:439px; }

@media screen and (max-width: 768px){
  .cycle-picture{background-image:url(../images/learning-tool-visual.jpg); width:340px; height:435px; background-repeat:no-repeat; margin-inline:auto; background-position:center center; margin-left: -1rem; margin-right:-1rem;}
  .cycle-text-wrap p{font-size:1.8rem; }
  .cycle-text01{left:55px; top:90px; }
  .cycle-text02{right:70px;top:130px; }
  .cycle-text03{left:60px;top:260px; }
  .cycle-text04{right:50px; }
	.text-center-wrap {
		text-align: left;
	}
	.learning-tool_text mark {
		display: inline-block;
		box-decoration-break: clone;
	}

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

	#diff-table {
		width: 95%;
		margin: 0 auto 7rem;
	}
}